summaryrefslogtreecommitdiff
path: root/doc
diff options
context:
space:
mode:
authorJulian Andres Klode <jak@debian.org>2009-07-15 14:14:44 +0200
committerJulian Andres Klode <jak@debian.org>2009-07-15 14:14:44 +0200
commit360477dcc304b8a18c467e59435d8c766bbb76bb (patch)
treeb4e2406964c10600c36681fd4888425383460940 /doc
parent7009c7dff71064526dafd0ed114f39c970448da0 (diff)
downloadpython-apt-360477dcc304b8a18c467e59435d8c766bbb76bb.tar.gz
python/python-apt.h: Introduce the C++ API
The C++ API provides support for creating Python objects from C++ objects given by pointer or reference (depending on the implementation of the Python object) and for retrieving the underlying C++ object from the Python object and for checking the type of the Python object.
Diffstat (limited to 'doc')
-rw-r--r--doc/client-example.cc46
1 files changed, 46 insertions, 0 deletions
diff --git a/doc/client-example.cc b/doc/client-example.cc
new file mode 100644
index 00000000..7fa6672f
--- /dev/null
+++ b/doc/client-example.cc
@@ -0,0 +1,46 @@
+/*
+ * client-example.cc - A simple example for using the python-apt C++ API.
+ *
+ * Copyright 2009 Julian Andres Klode <jak@debian.org>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program 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 General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
+ * MA 02110-1301, USA.
+ */
+#include <python-apt/python-apt.h>
+
+int main(int argc, char *argv[]) {
+ Py_Initialize();
+ if (import_apt_pkg() < 0)
+ return 1;
+
+ // Initialize a module.
+ PyObject *Module = Py_InitModule("client", NULL);
+
+ // Create a HashString, which will be added to the module.
+ HashString *hash = new HashString("0966a120bb936bdc6fdeac445707aa6b");
+ // Create a Python object for the hashstring and add it to the module
+ PyModule_AddObject(Module, "hash", PyHashString_FromCpp(hash));
+
+ // Another example: Add the HashString type to the module.
+ Py_INCREF(&PyHashString_Type);
+ PyModule_AddObject(Module, "HashString", (PyObject*)(&PyHashString_Type));
+
+ // Run IPython, adding the client module to the namespace.
+ PySys_SetArgv(argc, argv);
+ PyRun_SimpleString("from IPython.Shell import start\n");
+ PyRun_SimpleString("import client\n");
+ PyRun_SimpleString("start(user_ns=dict(client=client)).mainloop()\n");
+ Py_Finalize();
+}