Add nodeeditor (#1046)
* Add nodeeditor * qt5base: add support for MinGW on Linux and macOS * Small refactor * final fix * final fix2 --'pull/1047/head
parent
99c66bec69
commit
4359f03bcc
3 changed files with 119 additions and 52 deletions
@ -0,0 +1,34 @@ |
||||
diff --git a/include/nodes/internal/NodePainterDelegate.hpp b/include/nodes/internal/NodePainterDelegate.hpp
|
||||
index d532619..f22496c 100644
|
||||
--- a/include/nodes/internal/NodePainterDelegate.hpp
|
||||
+++ b/include/nodes/internal/NodePainterDelegate.hpp
|
||||
@@ -1,6 +1,6 @@
|
||||
#pragma once
|
||||
|
||||
-#include <QPainter>
|
||||
+#include <QtGui/QPainter>
|
||||
|
||||
#include "NodeGeometry.hpp"
|
||||
#include "NodeDataModel.hpp"
|
||||
diff --git a/include/nodes/internal/QStringStdHash.hpp b/include/nodes/internal/QStringStdHash.hpp
|
||||
index 3d47a3f..cc5eb68 100644
|
||||
--- a/include/nodes/internal/QStringStdHash.hpp
|
||||
+++ b/include/nodes/internal/QStringStdHash.hpp
|
||||
@@ -1,5 +1,11 @@
|
||||
#pragma once
|
||||
|
||||
+#include <QtCore/QtGlobal>
|
||||
+
|
||||
+#if (QT_VERSION < QT_VERSION_CHECK(5, 14, 0))
|
||||
+
|
||||
+// As of 5.14 there is a specialization std::hash<QString>
|
||||
+
|
||||
#include <functional>
|
||||
|
||||
#include <QtCore/QString>
|
||||
@@ -17,3 +23,5 @@ struct hash<QString>
|
||||
}
|
||||
};
|
||||
}
|
||||
+
|
||||
+#endif
|
@ -0,0 +1,46 @@ |
||||
package("nodeeditor") |
||||
set_homepage("https://github.com/paceholder/nodeeditor") |
||||
set_description("Qt Node Editor. Dataflow programming framework") |
||||
set_license("BSD-3") |
||||
|
||||
set_urls("https://github.com/paceholder/nodeeditor/archive/refs/tags/$(version).tar.gz", |
||||
"https://github.com/paceholder/nodeeditor.git") |
||||
add_versions("2.1.3", "4e3194a04ac4a2a2bf4bc8eb6cc27d5cc154923143c1ecf579ce7f0115a90585") |
||||
add_patches("2.1.3", path.join(os.scriptdir(), "patches", "2.1.3", "fix_qt.patch"), "11b6e765f8c8b0002f84ef0c3eb7dde23076b0564679760b7f4c8ba7c7e46887") |
||||
|
||||
add_deps("cmake") |
||||
|
||||
on_load(function (package) |
||||
package:add("deps", "qt5core", "qt5gui", "qt5widgets", {debug = package:is_debug()}) |
||||
if package:config("shared") then |
||||
package:add("defines", "NODE_EDITOR_SHARED") |
||||
else |
||||
package:add("defines", "NODE_EDITOR_STATIC") |
||||
end |
||||
end) |
||||
|
||||
on_install("windows", "linux", "mingw", "macosx", function (package) |
||||
local qt = package:dep("qt5core"):fetch().qtdir |
||||
|
||||
local configs = {"-DBUILD_EXAMPLES=OFF", "-DBUILD_TESTING=OFF"} |
||||
table.insert(configs, "-DBUILD_SHARED_LIBS=" .. (package:config("shared") and "ON" or "OFF")) |
||||
table.insert(configs, "-DCMAKE_BUILD_TYPE=" .. (package:debug() and "Debug" or "Release")) |
||||
if qt then |
||||
table.insert(configs, "-DQt5_DIR=" .. path.join(qt.libdir, "cmake", "Qt5")) |
||||
end |
||||
|
||||
import("package.tools.cmake").install(package, configs) |
||||
end) |
||||
|
||||
on_test(function (package) |
||||
local cxflags |
||||
if not package:is_plat("windows") then |
||||
cxflags = "-fPIC" |
||||
end |
||||
assert(package:check_cxxsnippets({test = [[ |
||||
void test() { |
||||
QtNodes::FlowScene scene(std::make_shared<QtNodes::DataModelRegistry>()); |
||||
QtNodes::FlowView view(&scene); |
||||
} |
||||
]]}, {configs = {languages = "c++14", cxflags = cxflags}, includes = {"nodes/FlowScene", "nodes/FlowView"}})) |
||||
end) |
Loading…
Reference in new issue