split py files
authorTomi Valkeinen <tomi.valkeinen@ti.com>
Sun, 22 May 2016 20:14:38 +0000 (23:14 +0300)
committerTomi Valkeinen <tomi.valkeinen@ti.com>
Mon, 23 May 2016 06:43:27 +0000 (09:43 +0300)
py/CMakeLists.txt
py/pykms.cpp
py/pykmsbase.cpp [new file with mode: 0644]
py/pykmstest.cpp [new file with mode: 0644]

index ff689393a476e054a866eac3592615415b8f20b5..f48ec2ca480a6a0a0c19d529387e6a133171f444 100644 (file)
@@ -10,7 +10,7 @@ endif()
 
 include_directories(${PROJECT_SOURCE_DIR}/ext/pybind11/include)
 
-add_library(pykms SHARED pykms.cpp)
+add_library(pykms SHARED pykms.cpp pykmsbase.cpp pykmstest.cpp)
 target_link_libraries(pykms kms++ kmstest ${LIBDRM_LIBRARIES})
 
 # Don't add a 'lib' prefix to the shared library
index c31d5ce48a797e44f919b6b4fd774182807c2886..deb827693506e803318b7c057dd0a2fb752a2f88 100644 (file)
@@ -1,13 +1,15 @@
 #include <pybind11/pybind11.h>
 #include <pybind11/stl.h>
 #include <kms++.h>
-#include "kmstest.h"
 
 namespace py = pybind11;
 
 using namespace kms;
 using namespace std;
 
+void init_pykmstest(py::module &m);
+void init_pykmsbase(py::module &m);
+
 class PyPageFlipHandlerBase : PageFlipHandlerBase
 {
 public:
@@ -27,94 +29,7 @@ public:
 PYBIND11_PLUGIN(pykms) {
        py::module m("pykms", "kms bindings");
 
-       py::class_<Card>(m, "Card")
-                       .def(py::init<>())
-                       .def_property_readonly("fd", &Card::fd)
-                       .def("get_first_connected_connector", &Card::get_first_connected_connector)
-                       .def_property_readonly("connectors", &Card::get_connectors)
-                       .def_property_readonly("crtcs", &Card::get_crtcs)
-                       .def_property_readonly("encoders", &Card::get_encoders)
-                       .def_property_readonly("planes", &Card::get_planes)
-                       .def_property_readonly("has_atomic", &Card::has_atomic)
-                       .def("call_page_flip_handlers", &Card::call_page_flip_handlers)
-                       .def("get_prop", (Property* (Card::*)(uint32_t) const)&Card::get_prop)
-                       .def("get_prop", (Property* (Card::*)(const string&) const)&Card::get_prop)
-                       ;
-
-       py::class_<DrmObject, DrmObject*>(m, "DrmObject")
-                       .def_property_readonly("id", &DrmObject::id)
-                       .def("refresh_props", &DrmObject::refresh_props)
-                       .def_property_readonly("prop_map", &DrmObject::get_prop_map)
-                       .def_property_readonly("card", &DrmObject::card)
-                       ;
-
-       py::class_<Connector, Connector*>(m, "Connector",  py::base<DrmObject>())
-                       .def_property_readonly("fullname", &Connector::fullname)
-                       .def("get_default_mode", &Connector::get_default_mode)
-                       .def("get_current_crtc", &Connector::get_current_crtc)
-                       .def("get_modes", &Connector::get_modes)
-                       .def("__repr__", [](const Connector& o) { return "<pykms.Connector " + to_string(o.id()) + ">"; })
-                       ;
-
-       py::class_<Crtc, Crtc*>(m, "Crtc",  py::base<DrmObject>())
-                       .def("set_mode", &Crtc::set_mode)
-                       .def("page_flip", &Crtc::page_flip)
-                       .def("set_plane", &Crtc::set_plane)
-                       .def_property_readonly("possible_planes", &Crtc::get_possible_planes)
-                       .def("__repr__", [](const Crtc& o) { return "<pykms.Crtc " + to_string(o.id()) + ">"; })
-                       ;
-
-       py::class_<Encoder, Encoder*>(m, "Encoder",  py::base<DrmObject>())
-                       ;
-
-       py::class_<Plane, Plane*>(m, "Plane",  py::base<DrmObject>())
-                       .def("supports_crtc", &Plane::supports_crtc)
-                       .def_property_readonly("plane_type", &Plane::plane_type)
-                       .def("__repr__", [](const Plane& o) { return "<pykms.Plane " + to_string(o.id()) + ">"; })
-                       ;
-
-       py::enum_<PlaneType>(m, "PlaneType")
-                       .value("Overlay", PlaneType::Overlay)
-                       .value("Primary", PlaneType::Primary)
-                       .value("Cursor", PlaneType::Cursor)
-                       ;
-
-       py::class_<Property, Property*>(m, "Property",  py::base<DrmObject>())
-                       .def_property_readonly("name", &Property::name)
-                       ;
-
-       py::class_<Framebuffer>(m, "Framebuffer",  py::base<DrmObject>())
-                       ;
-
-       py::class_<DumbFramebuffer>(m, "DumbFramebuffer",  py::base<Framebuffer>())
-                       .def(py::init<Card&, uint32_t, uint32_t, const string&>(),
-                            py::keep_alive<1, 2>())    // Keep Card alive until this is destructed
-                       .def_property_readonly("width", &DumbFramebuffer::width)
-                       .def_property_readonly("height", &DumbFramebuffer::height)
-                       ;
-
-       py::class_<Videomode>(m, "Videomode")
-                       .def(py::init<>())
-
-                       .def_readwrite("name", &Videomode::name)
-
-                       .def_readwrite("clock", &Videomode::clock)
-
-                       .def_readwrite("hdisplay", &Videomode::hdisplay)
-                       .def_readwrite("hsync_start", &Videomode::hsync_start)
-                       .def_readwrite("hsync_end", &Videomode::hsync_end)
-                       .def_readwrite("htotal", &Videomode::htotal)
-
-                       .def_readwrite("vdisplay", &Videomode::vdisplay)
-                       .def_readwrite("vsync_start", &Videomode::vsync_start)
-                       .def_readwrite("vsync_end", &Videomode::vsync_end)
-                       .def_readwrite("vtotal", &Videomode::vtotal)
-
-                       .def_readwrite("vrefresh", &Videomode::vrefresh)
-
-                       .def_readwrite("flags", &Videomode::flags)
-                       .def_readwrite("type", &Videomode::type)
-                       ;
+       init_pykmsbase(m);
 
        py::class_<PyPageFlipHandlerBase>(m, "PageFlipHandlerBase")
                        .alias<PageFlipHandlerBase>()
@@ -122,33 +37,7 @@ PYBIND11_PLUGIN(pykms) {
                        .def("handle_page_flip", &PageFlipHandlerBase::handle_page_flip)
                        ;
 
-       py::class_<AtomicReq>(m, "AtomicReq")
-                       .def(py::init<Card&>(),
-                            py::keep_alive<1, 2>())    // Keep Card alive until this is destructed
-                       .def("add", (void (AtomicReq::*)(DrmObject*, const string&, uint64_t)) &AtomicReq::add)
-                       .def("test", &AtomicReq::test)
-                       .def("commit", &AtomicReq::commit)
-                       .def("commit_sync", &AtomicReq::commit_sync)
-                       ;
-
-
-
-       /* libkmstest */
-
-       py::class_<RGB>(m, "RGB")
-                       .def(py::init<>())
-                       .def(py::init<uint8_t, uint8_t, uint8_t&>())
-                       .def(py::init<uint8_t, uint8_t, uint8_t, uint8_t&>())
-                       ;
-
-       // Use lambdas to handle IMappedFramebuffer
-       m.def("draw_test_pattern", [](DumbFramebuffer& fb) { draw_test_pattern(fb); } );
-       m.def("draw_color_bar", [](DumbFramebuffer& fb, int old_xpos, int xpos, int width) {
-               draw_color_bar(fb, old_xpos, xpos, width);
-       } );
-       m.def("draw_rect", [](DumbFramebuffer& fb, uint32_t x, uint32_t y, uint32_t w, uint32_t h, RGB color) {
-               draw_rect(fb, x, y, w, h, color);
-       } );
+       init_pykmstest(m);
 
        return m.ptr();
 }
diff --git a/py/pykmsbase.cpp b/py/pykmsbase.cpp
new file mode 100644 (file)
index 0000000..53c7351
--- /dev/null
@@ -0,0 +1,109 @@
+#include <pybind11/pybind11.h>
+#include <pybind11/stl.h>
+#include <kms++.h>
+
+namespace py = pybind11;
+
+using namespace kms;
+using namespace std;
+
+void init_pykmsbase(py::module &m)
+{
+       py::class_<Card>(m, "Card")
+                       .def(py::init<>())
+                       .def_property_readonly("fd", &Card::fd)
+                       .def("get_first_connected_connector", &Card::get_first_connected_connector)
+                       .def_property_readonly("connectors", &Card::get_connectors)
+                       .def_property_readonly("crtcs", &Card::get_crtcs)
+                       .def_property_readonly("encoders", &Card::get_encoders)
+                       .def_property_readonly("planes", &Card::get_planes)
+                       .def_property_readonly("has_atomic", &Card::has_atomic)
+                       .def("call_page_flip_handlers", &Card::call_page_flip_handlers)
+                       .def("get_prop", (Property* (Card::*)(uint32_t) const)&Card::get_prop)
+                       .def("get_prop", (Property* (Card::*)(const string&) const)&Card::get_prop)
+                       ;
+
+       py::class_<DrmObject, DrmObject*>(m, "DrmObject")
+                       .def_property_readonly("id", &DrmObject::id)
+                       .def("refresh_props", &DrmObject::refresh_props)
+                       .def_property_readonly("prop_map", &DrmObject::get_prop_map)
+                       .def_property_readonly("card", &DrmObject::card)
+                       ;
+
+       py::class_<Connector, Connector*>(m, "Connector",  py::base<DrmObject>())
+                       .def_property_readonly("fullname", &Connector::fullname)
+                       .def("get_default_mode", &Connector::get_default_mode)
+                       .def("get_current_crtc", &Connector::get_current_crtc)
+                       .def("get_modes", &Connector::get_modes)
+                       .def("__repr__", [](const Connector& o) { return "<pykms.Connector " + to_string(o.id()) + ">"; })
+                       ;
+
+       py::class_<Crtc, Crtc*>(m, "Crtc",  py::base<DrmObject>())
+                       .def("set_mode", &Crtc::set_mode)
+                       .def("page_flip", &Crtc::page_flip)
+                       .def("set_plane", &Crtc::set_plane)
+                       .def_property_readonly("possible_planes", &Crtc::get_possible_planes)
+                       .def("__repr__", [](const Crtc& o) { return "<pykms.Crtc " + to_string(o.id()) + ">"; })
+                       ;
+
+       py::class_<Encoder, Encoder*>(m, "Encoder",  py::base<DrmObject>())
+                       ;
+
+       py::class_<Plane, Plane*>(m, "Plane",  py::base<DrmObject>())
+                       .def("supports_crtc", &Plane::supports_crtc)
+                       .def_property_readonly("plane_type", &Plane::plane_type)
+                       .def("__repr__", [](const Plane& o) { return "<pykms.Plane " + to_string(o.id()) + ">"; })
+                       ;
+
+       py::enum_<PlaneType>(m, "PlaneType")
+                       .value("Overlay", PlaneType::Overlay)
+                       .value("Primary", PlaneType::Primary)
+                       .value("Cursor", PlaneType::Cursor)
+                       ;
+
+       py::class_<Property, Property*>(m, "Property",  py::base<DrmObject>())
+                       .def_property_readonly("name", &Property::name)
+                       ;
+
+       py::class_<Framebuffer>(m, "Framebuffer",  py::base<DrmObject>())
+                       ;
+
+       py::class_<DumbFramebuffer>(m, "DumbFramebuffer",  py::base<Framebuffer>())
+                       .def(py::init<Card&, uint32_t, uint32_t, const string&>(),
+                            py::keep_alive<1, 2>())    // Keep Card alive until this is destructed
+                       .def_property_readonly("width", &DumbFramebuffer::width)
+                       .def_property_readonly("height", &DumbFramebuffer::height)
+                       ;
+
+       py::class_<Videomode>(m, "Videomode")
+                       .def(py::init<>())
+
+                       .def_readwrite("name", &Videomode::name)
+
+                       .def_readwrite("clock", &Videomode::clock)
+
+                       .def_readwrite("hdisplay", &Videomode::hdisplay)
+                       .def_readwrite("hsync_start", &Videomode::hsync_start)
+                       .def_readwrite("hsync_end", &Videomode::hsync_end)
+                       .def_readwrite("htotal", &Videomode::htotal)
+
+                       .def_readwrite("vdisplay", &Videomode::vdisplay)
+                       .def_readwrite("vsync_start", &Videomode::vsync_start)
+                       .def_readwrite("vsync_end", &Videomode::vsync_end)
+                       .def_readwrite("vtotal", &Videomode::vtotal)
+
+                       .def_readwrite("vrefresh", &Videomode::vrefresh)
+
+                       .def_readwrite("flags", &Videomode::flags)
+                       .def_readwrite("type", &Videomode::type)
+                       ;
+
+       py::class_<AtomicReq>(m, "AtomicReq")
+                       .def(py::init<Card&>(),
+                            py::keep_alive<1, 2>())    // Keep Card alive until this is destructed
+                       .def("add", (void (AtomicReq::*)(DrmObject*, const string&, uint64_t)) &AtomicReq::add)
+                       .def("test", &AtomicReq::test)
+                       .def("commit", &AtomicReq::commit)
+                       .def("commit_sync", &AtomicReq::commit_sync)
+                       ;
+}
diff --git a/py/pykmstest.cpp b/py/pykmstest.cpp
new file mode 100644 (file)
index 0000000..781a43a
--- /dev/null
@@ -0,0 +1,27 @@
+#include <pybind11/pybind11.h>
+#include <pybind11/stl.h>
+#include <kms++.h>
+#include "kmstest.h"
+
+namespace py = pybind11;
+
+using namespace kms;
+using namespace std;
+
+void init_pykmstest(py::module &m)
+{
+       py::class_<RGB>(m, "RGB")
+                       .def(py::init<>())
+                       .def(py::init<uint8_t, uint8_t, uint8_t&>())
+                       .def(py::init<uint8_t, uint8_t, uint8_t, uint8_t&>())
+                       ;
+
+       // Use lambdas to handle IMappedFramebuffer
+       m.def("draw_test_pattern", [](DumbFramebuffer& fb) { draw_test_pattern(fb); } );
+       m.def("draw_color_bar", [](DumbFramebuffer& fb, int old_xpos, int xpos, int width) {
+               draw_color_bar(fb, old_xpos, xpos, width);
+       } );
+       m.def("draw_rect", [](DumbFramebuffer& fb, uint32_t x, uint32_t y, uint32_t w, uint32_t h, RGB color) {
+               draw_rect(fb, x, y, w, h, color);
+       } );
+}