summaryrefslogtreecommitdiffstats
path: root/include/ingen/Log.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'include/ingen/Log.hpp')
-rw-r--r--include/ingen/Log.hpp105
1 files changed, 105 insertions, 0 deletions
diff --git a/include/ingen/Log.hpp b/include/ingen/Log.hpp
new file mode 100644
index 00000000..afde276a
--- /dev/null
+++ b/include/ingen/Log.hpp
@@ -0,0 +1,105 @@
+/*
+ This file is part of Ingen.
+ Copyright 2007-2024 David Robillard <http://drobilla.net/>
+
+ Ingen is free software: you can redistribute it and/or modify it under the
+ terms of the GNU Affero General Public License as published by the Free
+ Software Foundation, either version 3 of the License, or any later version.
+
+ Ingen is distributed in the hope that it will be useful, but WITHOUT ANY
+ WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
+ A PARTICULAR PURPOSE. See the GNU Affero General Public License for details.
+
+ You should have received a copy of the GNU Affero General Public License
+ along with Ingen. If not, see <http://www.gnu.org/licenses/>.
+*/
+
+#ifndef INGEN_LOG_HPP
+#define INGEN_LOG_HPP
+
+#include <ingen/LV2Features.hpp>
+#include <ingen/fmt.hpp>
+#include <ingen/ingen.h>
+#include <lv2/core/lv2.h>
+#include <lv2/log/log.h>
+#include <lv2/urid/urid.h>
+
+#include <cstdarg>
+#include <functional>
+#include <string>
+#include <utility>
+
+namespace ingen {
+
+class Node;
+class URIs;
+
+class INGEN_API Log
+{
+public:
+ using Sink = std::function<int(LV2_URID, const char*, va_list)>;
+
+ Log(LV2_Log_Log* log, URIs& uris);
+
+ struct Feature : public LV2Features::Feature {
+ const char* uri() const override { return LV2_LOG__log; }
+
+ std::shared_ptr<LV2_Feature>
+ feature(World& world, Node* block) override;
+
+ struct Handle {
+ LV2_Log_Log lv2_log;
+ Log* log;
+ Node* node;
+ };
+ };
+
+ void rt_error(const char* msg);
+
+ void error(const std::string& msg);
+ void info(const std::string& msg);
+ void warn(const std::string& msg);
+ void trace(const std::string& msg);
+
+ template <typename... Args>
+ void error(const char* format, Args&&... args)
+ {
+ error(fmt(format, std::forward<Args>(args)...));
+ }
+
+ template <typename... Args>
+ void info(const char* format, Args&&... args)
+ {
+ info(fmt(format, std::forward<Args>(args)...));
+ }
+
+ template <typename... Args>
+ void warn(const char* format, Args&&... args)
+ {
+ warn(fmt(format, std::forward<Args>(args)...));
+ }
+
+ template <typename... Args>
+ void trace(const char* format, Args&&... args)
+ {
+ trace(fmt(format, std::forward<Args>(args)...));
+ }
+
+ int vtprintf(LV2_URID type, const char* fmt, va_list args);
+ int tprintf(LV2_URID type, const char* fmt, ...);
+
+ void set_flush(bool f) { _flush = f; }
+ void set_trace(bool f) { _trace = f; }
+ void set_sink(Sink s) { _sink = std::move(s); }
+
+private:
+ LV2_Log_Log* _log;
+ URIs& _uris;
+ Sink _sink;
+ bool _flush{false};
+ bool _trace{false};
+};
+
+} // namespace ingen
+
+#endif // INGEN_LOG_HPP