Developer Documentation
Python.cc
1 
2 /*===========================================================================*\
3 * *
4 * OpenFlipper *
5  * Copyright (c) 2001-2015, RWTH-Aachen University *
6  * Department of Computer Graphics and Multimedia *
7  * All rights reserved. *
8  * www.openflipper.org *
9  * *
10  *---------------------------------------------------------------------------*
11  * This file is part of OpenFlipper. *
12  *---------------------------------------------------------------------------*
13  * *
14  * Redistribution and use in source and binary forms, with or without *
15  * modification, are permitted provided that the following conditions *
16  * are met: *
17  * *
18  * 1. Redistributions of source code must retain the above copyright notice, *
19  * this list of conditions and the following disclaimer. *
20  * *
21  * 2. Redistributions in binary form must reproduce the above copyright *
22  * notice, this list of conditions and the following disclaimer in the *
23  * documentation and/or other materials provided with the distribution. *
24  * *
25  * 3. Neither the name of the copyright holder nor the names of its *
26  * contributors may be used to endorse or promote products derived from *
27  * this software without specific prior written permission. *
28  * *
29  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS *
30  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED *
31  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A *
32  * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER *
33  * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, *
34  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, *
35  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR *
36  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF *
37  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING *
38  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS *
39  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *
40 * *
41 \*===========================================================================*/
42 
43 #include <pybind11/include/pybind11/pybind11.h>
44 #include <pybind11/include/pybind11/embed.h>
45 
46 
47 #include <FileSTL.hh>
48 #include <QString>
49 #include <QChar>
50 #include <QCoreApplication>
51 
52 #include <OpenFlipper/BasePlugin/PythonFunctions.hh>
53 #include <OpenFlipper/PythonInterpreter/PythonTypeConversions.hh>
54 
55 
56 
57 namespace py = pybind11;
58 
59 
60 
61 PYBIND11_EMBEDDED_MODULE(FileSTL, m) {
62 
63  QObject* pluginPointer = getPluginPointer("FileSTL");
64 
65  if (!pluginPointer) {
66  std::cerr << "Error Getting plugin pointer for Plugin-FileSTL" << std::endl;
67  return;
68  }
69 
70  FileSTLPlugin* plugin = qobject_cast<FileSTLPlugin*>(pluginPointer);
71 
72  if (!plugin) {
73  std::cerr << "Error converting plugin pointer for Plugin-FileSTL" << std::endl;
74  return;
75  }
76 
77  // Export our core. Make sure that the c++ worlds core object is not deleted if
78  // the python side gets deleted!!
79  py::class_< FileSTLPlugin,std::unique_ptr<FileSTLPlugin, py::nodelete> > stl(m, "FileSTL");
80 
81  // On the c++ side we will just return the existing core instance
82  // and prevent the system to recreate a new core as we need
83  // to work on the existing one.
84  stl.def(py::init([plugin]() { return plugin; }));
85 
86 
87 
88  stl.def("loadObject", static_cast<int (FileSTLPlugin::*)(QString)>( &FileSTLPlugin::loadObject),
89  QCoreApplication::translate("PythonDocFileSTL","Loads an object and returns its id").toLatin1().data(),
90  py::arg(QCoreApplication::translate("PythonDocFileSTL","Filename").toLatin1().data()) );
91 
92 
93  stl.def("saveObject", static_cast<bool (FileSTLPlugin::*)(int,QString)>( &FileSTLPlugin::saveObject),
94  QCoreApplication::translate("PythonDocFileSTL","saves a given object to a file").toLatin1().data(),
95  py::arg(QCoreApplication::translate("PythonDocFileSTL","Object id to save").toLatin1().data()),
96  py::arg(QCoreApplication::translate("PythonDocFileSTL","Filename").toLatin1().data()) );
97 
98  stl.def("saveObject", static_cast<bool (FileSTLPlugin::*)(int,QString,const bool, const std::streamsize)>( &FileSTLPlugin::saveObject),
99  QCoreApplication::translate("PythonDocFileSTL","saves a given object to a file").toLatin1().data(),
100  py::arg(QCoreApplication::translate("PythonDocFileSTL","Object id to save").toLatin1().data()),
101  py::arg(QCoreApplication::translate("PythonDocFileSTL","Filename").toLatin1().data()),
102  py::arg(QCoreApplication::translate("PythonDocFileSTL","Binary mode?").toLatin1().data()),
103  py::arg(QCoreApplication::translate("PythonDocFileSTL","Precision").toLatin1().data()) = 6 );
104 
105 
106 
107 }
int loadObject(QString _filename)
Loads Object as triangle mesh.
Definition: FileSTL.cc:98