aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--DEV_README295
-rw-r--r--README246
-rwxr-xr-xbin/eo_graph_gen.py (renamed from eo_parser/eo_graph_gen.py)135
-rwxr-xr-xbin/eo_js_gen.py167
-rwxr-xr-xbin/eo_py_gen.py204
-rwxr-xr-xbin/eo_xml_gen.py (renamed from eo_parser/eo_xml_gen.py)42
-rw-r--r--eo_js/README36
-rw-r--r--eo_js/elm.h20
-rwxr-xr-xeo_js/eo_js_gen.py80
-rw-r--r--eo_parser/tests.py77
-rw-r--r--eo_parser/types.xml16
-rw-r--r--eo_py/README55
-rw-r--r--eo_py/elm_add.pxd4
-rw-r--r--eo_py/elm_add.pxi20
-rwxr-xr-xeo_py/eo_py_gen.py149
-rw-r--r--eo_py/eodefault.pxd8
-rw-r--r--eo_py/eodefault.pyx48
-rw-r--r--eoparser/__init__.py (renamed from eo_parser/__init__.py)0
-rw-r--r--eoparser/cparser.py (renamed from eo_parser/Cparser.py)228
-rw-r--r--eoparser/data/types.xml82
-rw-r--r--eoparser/helper.py (renamed from eo_parser/helper.py)54
-rw-r--r--eoparser/xmlparser.py (renamed from eo_parser/XMLparser.py)665
-rw-r--r--eorepo/EoBase.xml90
-rw-r--r--eorepo/__init__.py3
-rw-r--r--eorepo/eobase.c5268
-rw-r--r--eorepo/eobase.pxd40
-rw-r--r--eorepo/eobase.pxi108
-rw-r--r--eorepo/eobase.pyx1
-rw-r--r--eorepo/eodefault.c4095
-rw-r--r--eorepo/eodefault.pxd84
-rw-r--r--eorepo/eodefault.pyx149
-rw-r--r--examples/elm_elm.js201
-rw-r--r--examples/elw_button.js159
-rw-r--r--examples/elw_button_new_names.js162
-rw-r--r--examples/elw_button_old.js247
-rw-r--r--examples/elw_eoisa.js24
-rw-r--r--examples/elw_mixin.js18
-rw-r--r--examples/elw_signal.js54
-rw-r--r--examples/evas_elem_test.py66
-rw-r--r--examples/evas_lib_test.py2
-rw-r--r--examples/evas_test.py32
-rw-r--r--examples/evas_test2.py154
-rw-r--r--examples/mixin_test.py13
-rw-r--r--examples/signal_test.py62
-rw-r--r--examples/simple_test.py14
-rw-r--r--setup.py91
-rw-r--r--tests/test_data.in28
-rw-r--r--tests/tests.py98
48 files changed, 12954 insertions, 940 deletions
diff --git a/DEV_README b/DEV_README
new file mode 100644
index 0000000..7d0b7da
--- /dev/null
+++ b/DEV_README
@@ -0,0 +1,295 @@
+
+Yakov Goldberg <yakov.g@samsung.com>
+
+EO introspection is set of tools to generate high-level
+language bindings for C libraries based on Eo (E Object) library,
+ Usual workflow:
+ - parsing C-sources and generating XML
+ - generating source files, makefiles
+ < include additional modules
+ - compile module
+
+ This document describes current development issues,
+ and supposes that reader has some knowledge
+ about Eo, Elementary, Python and JS bindings
+
+#############################################################
+
+* Generating function names
+
+ Issues:
+ Names of funcs to be generated, name clashes.
+
+ In the beginning there was idea to cut func name from OP_ID.
+
+ There is OP_ID 'SOME_CLASS_SUB_ID_COLOR_GET' and public function
+ 'some_class_color_get()' which connected with OP_ID,
+ so 'color_get()' will be generated.
+
+ If there is another class ANOTHER_CLASS(SOME_CLASS) with
+ 'ANOTHER_CLASS_SUB_ID_COLOR_GET' and 'another_class_color_get()'
+ public function, another 'color_get()' func will be generated.
+
+ I don't check for names clash.
+ There won't be an error and function will be simply overloaded,
+ but it will be completely wrong.
+
+ There shouldn't be function overloading at all, that's all done
+ in library itself, in bindings I call only for most base func.
+
+ Conflict should be resolved in library itself. If we want single
+ 'color_set()' for all classes, they need to be overloaded
+ in proper way.
+
+ At the moment full names like some_class_color_set() and
+ another_class_color_set() will be generated.
+
+#############################################################
+
+* Properties names parsing
+ If func name ends with '_set'/'_get'
+ parameters are checked on direction 'in' for 'set' prop
+ and on 'out' for 'get' prop.
+ If it's wrong, this function will be generated as a method.
+
+ Too common implementation. Need to provide descriptions(comments).
+
+
+#############################################################
+
+* Parameter's Types;
+ Basic types can be detected;
+ also "types" file can be provided which says how to cast to basic types:
+ <type from="Evas_Font_Size" to="int"/>
+ <type from="Eo_Callback_Priority" to="short"/>
+ <type from="Evas_Smart" to="Eo"/>
+
+ if some type wasn't found, function will not be generated.
+
+ Issues:
+ Types like Eina_List, arrays, structs need wrapping to Python types
+ can be done by providing descriptions(comments), but requires work.
+
+ Returning existing Object or new one.
+ Need to check returning instance with eo_base_data_get("Python instance");
+ if o != NULL:
+ return o
+ else: ( need to create one:)
+ get class name,
+ find constructor
+ create object
+
+ Requires work.
+
+#############################################################
+
+* Constructing object:
+ Now objects are constructed with default constuctor.
+ Some classes provide custom constructors and some ONLY custom constructors.
+
+ example for window:
+ eo_add_custom(eo, elm_win_constructor("my win", ELM_WIN_BASIC))
+
+ in Python:
+ can be called like this
+ win = ElmWin("my win", ELM_WIN_BASIC)
+
+ in JS??
+ in elev8 - this is hardcoded, ("main" ELM_WIN_BASIC) is created
+
+ Issues:
+ How to fetch custom constructors from source?
+ Add decorators to comments. Looks like fine.
+
+ How to call custom constructors with same signature, but with different name?
+ eo_add_custom(eo, elm_win_constructor_one("my win", ELM_WIN_BASIC))
+ eo_add_custom(eo, elm_win_constructor_two("my win", ELM_WIN_BASIC))
+
+ What to do in Python?
+ Define additional variable?
+ win = ElmWin(win.CONSTR1, "my win", ELM_WIN_BASIC)
+
+ and provide the way to parse argv[] in __init__ func?
+
+#############################################################
+
+* Callbacks in Python.
+ Issues:
+ Pass data to callback.
+ Add callback to Evas_Object
+
+ Description:
+ All callbacks are added to Eo object on registered event in this/parent class.
+ To add callback EoBase.event_callback_priority_add() is used.
+ Callback can be added for introspected events.
+
+ Adding callback:
+
+ func(obj, data)
+
+ cb_obj = (func, data)
+ py_obj.event_callback_priority_add(class.EVENT_ID, 0, cb_obj)
+ py_obj.event_callback_del(class.EVENT_ID, cb_obj)
+
+ it's also possible to add callback like this:
+
+ py_obj.event_callback_priority_add(class.EVENT_ID, 0, (func, data))
+
+ reference of (func, data) object is incremented,
+ so callback will be called properly.
+ But it won't be possible to delete it.
+
+ What's going on inside:
+ Proxy _callback() function(eo signature) is added to real C
+ object for desired event; Py cb_obj is set as data.
+ When event occurs, _callback() is called with data; Py func and data are fetched
+ and Py cb is called.
+
+ Maybe it's not the best idea to add data like this, but the idea
+ is to give Eo as much work as possible.
+ So no internal lists are managed to pass and keep
+ callback data as (*args **kwargs).
+
+
+ Adding callbacks to Evas_Object:
+ In C, callbacks are added with evas_object_event_callback_add(),
+ which is not in eo indrospection at all.
+ Evas Events are also not in introspection scope,
+ because they are not added to Eo objects.
+
+ Issue:
+ What to do with Evas events?
+ It's possible to add stuff manually:
+ - define extern evas_object_event_callback_add()
+ - define extern event's enum
+ - define public event_add/del funcs for class
+
+#############################################################
+
+* Callbacks in JS:
+ In elev8 one callback per event was implemented, without adding cb data.
+
+ There are some ideas how to put several callbacks and data if needed, but it must be checked.
+
+#############################################################
+
+* Adding elm_init() and other additional funcs
+
+ Sometimes some additional functions like elm_init(), elm_run()
+ are needed. These functions are not introspectable,
+ they must be added manually.
+
+ Example for python:
+ To do this, the user must provide definitions in *.pxd, *.pxi files,
+ include *.pxi into generated 'module_name.pyx' file and compile.
+
+ Usual workflow:
+ - generating XML
+ - generating source files, makefiles
+ < add files manually
+ - compile module
+
+#############################################################
+
+* Enums from headers.
+ Need to provide descriptions(comments), to understand how to fetch it
+
+#############################################################
+
+* Issues about elementary:
+ After parsing sources, found headers are included
+ into generated files.
+
+ All include error must be fixed manually, t.e. issues with
+ including elm_*.h and Elementary.h and compilation flags like
+ -DELM_INTERNAL_API_ARGESFSDFEFC=1
+
+#############################################################
+
+* EO repository for Python
+ initial eorepo package will be installed with eoparser package.
+ Layout:
+ eorepo /
+ eobase.so
+ eodefault.so
+ __init__.py
+ EoBase.xml
+ eobase.pxd
+ eobase.c
+ eodefault.pxd
+ eodefault.c
+
+ When generating cython files for some module:
+ - all classes are parsed
+ - EoBase will be parent for some classes,
+ so EoBase will be imported from eorepo.eobase
+ also eodeafault will be cimported from eorepo.eobase.
+ - packages will be also installed into eorepo folder.
+
+ ! but, I can't include packages different from eobase
+ ! need to provide mechanism to import any parent modules
+
+ Correct layout should be like this:
+
+ eorepo /
+ eobase /
+ c_eobase.so
+ eodefault.so
+ __init__.py
+ import eodefault
+ eodefault.eo_init()
+ from eorepo.eobase.c_eobase import EoBase
+ evas /
+ c_evas.so
+ __init__.py
+ from eorepo.evas.c_evas import EvasObj
+ elementary /
+ c_elementary.so
+ __init__.py # this can be autogenerated
+ from eorepo.elementary.c_elementary import ElmWin
+
+ if we want to create module "elementary", setup.py will be created,
+ which creates package "elementary", with "c_elementary.so" module and
+ proper __init__.py, which imports ElmWin from "c_elementary.so" into
+ elementary
+
+ Each module, being installed must provide some package desc
+ file:
+ it must content all classes of module and path to this module.
+ {EvasObj : [eorepo.evas.c_evas]}
+ {ElmWin : [eorepo.elm.c_elm]}
+ If I need to include some class, I search for this "desc file";
+ look for class name in it, and include class from package.
+
+ And so I don't need XML_INCLUDE or look for parent's XMLs.
+ And I don't need XML files at all.
+
+ Usage in users app:
+ import eorepo.elementary -
+ #this will activate __init__ in elementary folder, and will
+ # import ElmWin from c_elementary into elementary
+ # so eorepo.elementary.ElmWin can be used
+ # or like this
+ from eorepo.elementary import ElmWin
+
+#############################################################
+
+* Eorepo for js:
+ Currently there are several base files, which must be used in module compilation:
+ CElmObject.cc/h
+ elm.h
+ main.cc
+
+ eobase.cc/h - autogenerated for Eo_Base
+
+ 1. Think, if this files must be copied for compilation
+ Or statically linked...
+ ...or smth else
+
+ 2. elev8 looks for modules in its folder, so I have to install module into this folder
+ need to find way to solve it
+
+ 3. In repo need to save module's h files, to include into childs modules
+ 4. So each module must install some desc file: {class name : header}
+
+
diff --git a/README b/README
index ccf454a..a980af8 100644
--- a/README
+++ b/README
@@ -1,70 +1,238 @@
#####################################################
-EO Introspection - Scanner, Graph Generator
+EO Introspection
#####################################################
+0. About
+1. Compiling and installing
+2. Folder Introspection and class graph
+3. Generating python bindings
+4. Generating JS bindings (elev8 and V8 are required)
-Scanner is a part of EObject introspection module.
-It analyzes source and header C files, which can contain EO-styled class definition,
- and generates XML - description for each found class
+####################################################
+0. About
+
+ EO introspection is a set of tools to generate high-level
+ language bindings for C libraries based on Eo (E Object) library.
+ Eo is a part of Enlightenent Foundation Libraries.
+ http://svn.enlightenment.org/svn/e/trunk/efl/
+
+ Eo library provides an opportunity
+ to use object oriented concepts in C.
+
+ EO Introspection provides easy generation
+ of Python and JS bindings for your Eo-based library.
+
+ Set of tools:
+ Scanner
+ Graph Generator
+ Python code generator
+ JS code generator
+
+ Scanner
+ analyzes source and header C files,
+ which can contain EO-styled class definition;
+ and then it generates XML-description for each found class.
+
+ Graph generator
+ builds classes diagram according to XML-descriptions.
+
+ Python code generator
+ analyzes XML files and generates Cython files that are compiled
+ into Python module.
+
+ JS code generator
+ analyzes XML files and generates C++ files that are compiled into
+ elev8 module. Elev8 is V8-based js-engine.
+
+#####################################################
+
+1. Compiling and installing
+
+ 1.1 Requirements:
+
+ python-dev package is required, to build extension
+ from source c files.
+ Install python-dev package:
+ > sudo apt-get install python-dev build-essential
+
+ 1.2 Installing eoparser:
+
+ > python setup.py build
+ (do this as root unless you are installing in your users directories)
+ > python setup.py install
+
+ --prefix option can be used, to install package into user's dir.
+ Add install_dir into PYTHONPATH.
+
+ 1.3 To compile Cython files, cython (0.17) is required.
+
+ Install pip (python installs packages):
+ > sudo apt-get install python-pip
+ Install cython:
+ > pip install cython
+ or upgrade:
+ > pip install --upgrade cython
#####################################################
-1. Introspecting folder:
+2. Introspecting folder and building class graph:
+
+ 2.1 Folder introspection
Scanner runs recursively on defined folders
- a. > python eo_xml_gen.py --dir=IN_DIR --dir=IN_DIR2 --outdir=OUT_DIR -include=INCLUDE_DIR
- script searches for dependency xmlfiles in Python env paths.
- if PYTHONPATH wasn't set explicit --include=INCLUDE_DIR can be needed
-
- b. Building classes graph chart:
- Graph generator runs recursively on defined folders and generates graphviz dot file,
- which can be used to generate image
-
- > python eo_graph_gen.py --dir=FOLDER_WITH_XML1 --dir=FOLDER_WITH_XMLS --outfile=OUTFILE.dot
- > dot -Tpng OUTFILE.dot -o out.png
- > eog out.png
-
-2. Generating python-bindings: read /eo_py/README
-
-
-1. Creating eobase module:
- a. Creating new dir - PY_EOBASE
- b. Introspecting base module folder - EOBASE
- > python e_scan.py --dir=EOBASE --outdir=PY_EOBASE
- - eobase.xml will be created in PY_EOBASE
- c. Creating eobase python sources:
- > python e_compile.py --dir=PY_EOBASE --outdir=PY_EOBASE --module=eobase
- --pkg="elementary eo"
- To create base module use option --module="eobase"
- - eobase.pxd, eobase.pyx - will be created
- - eodefault.pxd, eodefault.pyx - will be copied from script folder
- - setup.py will be created.
- setup.py can be modified in order to add include paths and libraries,
- which weren't mentioned in --pkg option
- d. Compiling python sources into python module.
- > python setup.py build_ext --inplace
- - eodefault.so, eobase.so will be created
- e. Copy __init__.py to PY_EOBASE
- Add PYTHONPATH = PY_EOBASE
+ > eo_xml_gen.py --dir IN_DIR --dir IN_DIR2 --outdir OUT_DIR
+ Parent's classes should be found automatically in python search path.
+ --xmldir=XML_DIR can be used to add additional search paths.
+ 2.2 Building classes graph chart:
+ Graph generator runs recursively on defined folders
+ and generates png image.
+# > python eo_graph_gen.py --dir=FOLDER_WITH_XML1 --dir=FOLDER_WITH_XMLS --outfile=OUTFILE.dot
+# > dot -Tpng OUTFILE.dot -o out.png
+# > eog out.png
+ > eo_graph_gen.py --dir FOLDER_WITH_XML1
+ --dir FOLDER_WITH_XMLS --outfile graph.png
+ > eog graph.png
+#####################################################
+3. Generating python bindings
+
+ 3.1 Generating python module for classes defined in XMLs:
+ > eo_py_gen.py --dir XML_DIR --outdir OUTDIR --module MODULE_NAME
+ --pkg "lib1 lib2" --xmldir INCLUDE_XML_DIR
+ -lname -I/include -DSOME_VAR=1
+
+ Parent's classes should be found automatically in python search path.
+ --xmldir=XML_DIR can be used to add additional search paths.
+
+ --xmldir XML_DIR - path to search for parent classes
+ (XMLs fith parent classes descriptions)
+ --outdir OUTDIR - directory for output.
+ --module - name of module to generate
+ --pkg "lib1 lib2" - provide libraries compilation information with pkg-config
+ --xmldir - path to parent's classes XMLSw, which are not in search path
+
+ -I - to include search path for headers
+ -L - to include search path for libraries
+ -l - library to link with
+ -D - to define macros
+
+ Files to be generated:
+ - *.pxi files will be created for each *.xml
+ - *.pxd will be created one for module.
+ - MODULE_NAME.pyx (only one pyx allowed for compiling module)
+ this file includes all *.pxi
+ - setup.py
+ setup.py can be edited in order to add include paths, libraries
+ (which were not mentioned in --pkg option)
+ compile options
+
+ Addition:
+ Sometimes, additional functions, which are not introspectable,
+ must be included. User must implement and add them manually.
+ (Cython knowledge is required)
+
+ To do this, user must provide definitions in *.pxd, *.pxi files,
+ include *.pxi into generated 'module_name.pyx' file and compile.
+
+ 3.2 Creating install package and installing generated module:
+ Creating installation package for module
+ > python setup.py sdist
+
+ Building module
+ > python setup.py build
+
+ Installing module (root maybe required)
+ > python setup.py install
+
+########################################################################
+
+ 3.3 Creating PY base module for Eo base class:
+ Base module folder being introspected - Eo lib itself
+ > python eo_xml_gen.py --dir=(eo lib itself) --outdir=OUTDIR
+ - eobase.xml will be created in OUTDIR folder
+ Creating eobase python sources:
+ > python eo_py_gen.py --dir=OUTDIR --outdir=TMP --module=eobase
+ --pkg="eo" --xmldir=DEFAULT
+ To create base module, option --module must be "eobase".
+ DEFAULT - is a folder with cython files for eodefault module,
+ which provides infrastructure.
+
+ TMP folder will have following layout:
+ tmp\
+ setup.py
+ eorepo\
+ eodefault.pxd
+ eodefault.pyx
+ eobase.pyx
+ eobase.pxi
+ eobase.pxd
+ __init__.py
+ - eobase.pxd, eobase.pyx - will be created
+ - eodefault.pxd, eodefault.pyx - will be copied into
+ - __init__.py - will be copied
+ - setup.py will be created.
+ setup.py can be modified in order to add include paths
+ and libraries, which weren't mentioned in command line options
+ Creating installation package for module
+ > python setup.py sdist
+ Building module
+ > python setup.py build
+ Installing module (root maybe required)
+ > python setup.py install
+ According to layout, package 'eorepo' will be installed into
+ installation path.
+ It can be used as following:
+ from eorepo.eobase import EoBase
+#####################################################################
+4. Generating js module for classes defined in XMLs:
+ > eo_js_gen.py --dir=XML_FOLDER --outdir=OUTDIR
+ --module=MODULE_NAME --xmldir=INCLUDE_XML_DIR -lname -I/include
+ -DSOME_PATH=\"/path\"
+ Parent's classes should be found automatically in python search path.
+ --xmldir=XML_DIR can be used to add additional search paths.
+ --xmldir XML_DIR - path to search for parent classes
+ (XMLs fith parent classes descriptions)
+ --outdir OUTDIR - directory for output.
+ --module - name of module to generate
+ --pkg "lib1 lib2" - provide libraries compilation information with pkg-config
+ --xmldir - path to parent's classes XMLSw, which are not in search path
+ -I - to include search path for headers
+ -L - to include search path for libraries
+ -l - library to link with
+ -D - to define macros
+ Files to be generated:
+ - *.cc, *.h will be created for each *.xml
+ - _module.cc with EoRegisterModule() func
+ if you need to call any functions on module load,
+ add them in this func.
+ - Makefile
+ Compiling module:
+ You can edit generated Makefile, if you need to add some additional flags
+ > make
+ - modul_name.so will be compiled
+ /*
+ Need to copy followinf files to compile module, (or static link?)
+ main.cc, elm.h, CElmObject.cc, CElmObject.h, _eobase.h, _eobase.c"
+ */
+####################################################################
diff --git a/eo_parser/eo_graph_gen.py b/bin/eo_graph_gen.py
index 3ede4e6..d7b2342 100755
--- a/eo_parser/eo_graph_gen.py
+++ b/bin/eo_graph_gen.py
@@ -1,9 +1,9 @@
#!/usr/bin/env python
-from eo_parser.helper import isXML, dir_files_get, abs_path_get
-from eo_parser.XMLparser import XMLparser
+from eoparser.helper import isXML, dir_files_get, abs_path_get
+from eoparser.xmlparser import XMLparser
from argparse import ArgumentParser
-import os
+import os, sys
def verbose_true(mes):
print mes
@@ -14,23 +14,21 @@ def verbose_false(mes):
def main():
parser = ArgumentParser()
parser.add_argument("-d", "--dir", dest="directory",
- action="append", help="Source files directory")
+ action="append", help="Path to XML descriptions", required=True)
parser.add_argument("-o", "--outfile", dest="outfile",
- action="store", help="Path for output files")
+ action="store", help="Out file in png format. Default: \"out.png\"", default="out.png")
parser.add_argument("-v", "--verbose",
action="store_true", dest="verbose", default=False,
- help="Print status messages to stdout")
-
+ help="Verbose output")
+ """
parser.add_argument("--graphstyle", action="store", dest="graphstyle", default="digraph",
help="Set graph style. Default: \"digraph\"")
+ """
- parser.add_argument("--edge", action="store", dest="edge", default="solid",
- help="Set line style for parent edge. Default: \"solid\"")
-
- parser.add_argument("--extedge", action="store", dest="extedge", default="dashed",
- help="Set line style for extension edge. Default: \"dashed\"")
+ parser.add_argument("--extedge", action="store", dest="extedge", default="dashed, dashed, dotted, dashed",
+ help="Set line style for extension edges depending on extension type(REGULAR, MIXIN, INTERFACE, NO_INSTANT).[\"solid, dotted, dashed, bold\"]. Default: \"dashed, dashed, dotted, dashed\"")
parser.add_argument("--rankdir", action="store", dest="rankdir", default="BT",
help="Direction of directed graph[BT, TB, LR, RL]. Default: \"BT\"")
@@ -47,68 +45,71 @@ def main():
parser.add_argument("--nodeshape", action="store", dest="nodeshape", default="polygon",
help="Node shape.[\"polygon\", \"circle\", \"ellipse\"] Default: \"polygon\"")
+ parser.add_argument("--long-names", action="store", dest="short_long", default="short",
+ help="Node shape.[\"short\", \"long\"] Default: \"short\"")
styles = {}
args = parser.parse_args()
- styles["edge"] = args.edge
- styles["extedge"] = args.extedge
- styles["graphstyle"] = args.graphstyle
+ styles["extedge"] = args.extedge.replace(" ", "").split(",")
+ if len (styles["extedge"]) < 4:
+ print "--extedge option is not correct"
+ exit(1)
+ styles["graphstyle"] = "digraph"# args.graphstyle
styles["rankdir"] = args.rankdir
styles["graphfontsize"] = args.graphfontsize
styles["graphlabel"] = args.graphlabel
styles["nodefontsize"] = args.nodefontsize
styles["nodeshape"] = args.nodeshape
+ SHORT_LONG = 0 if args.short_long == "short" else 1
+
+ TYPE_REGULAR = "EO_CLASS_TYPE_REGULAR"
+ TYPE_MIXIN = "EO_CLASS_TYPE_MIXIN"
+ TYPE_INTERFACE = "EO_CLASS_TYPE_INTERFACE"
+ TYPE_NO_INSTANT = "EO_CLASS_TYPE_REGULAR_NO_INSTANT"
+ types_list = (TYPE_REGULAR, TYPE_MIXIN, TYPE_INTERFACE, TYPE_NO_INSTANT)
- types = {
- "REGULAR":"EO_CLASS_TYPE_REGULAR",
- "MIXIN" : "EO_CLASS_TYPE_MIXIN",
- "INTERFACE":"EO_CLASS_TYPE_INTERFACE",
- "NO_INSTANT":"EO_CLASS_TYPE_REGULAR_NO_INSTANT"
+ type_names = {
+ TYPE_REGULAR : ("REGULAR", "EO_CLASS_TYPE_REGULAR"),
+ TYPE_MIXIN : ("MIXIN", "EO_CLASS_TYPE_MIXIN"),
+ TYPE_INTERFACE : ("INTERFACE", "EO_CLASS" ),
+ TYPE_NO_INSTANT : ("NO INSTANT", "EO_CLASS_TYPE_REGULAR_NO_INSTANT")
}
+ #node colors
n_color = {
- types["REGULAR"]:"green",
- types["MIXIN"] : "blue",
- types["INTERFACE"]:"red",
- types["NO_INSTANT"]:"darkviolet"
+ TYPE_REGULAR :"green",
+ TYPE_MIXIN : "blue",
+ TYPE_INTERFACE :"red",
+ TYPE_NO_INSTANT :"darkviolet"
}
+ #ext edge line style
+ p_edge = {}
+ p_edge[TYPE_REGULAR] = styles["extedge"][0]
+ p_edge[TYPE_MIXIN] = styles["extedge"][1]
+ p_edge[TYPE_INTERFACE] = styles["extedge"][2]
+ p_edge[TYPE_NO_INSTANT] = styles["extedge"][3]
+
verbose_print = None
if args.verbose is True:
verbose_print = verbose_true
else:
verbose_print = verbose_false
- verbose_print("Options: %s"%args)
- verbose_print("Args: %s"%args)
+ directories = args.directory + sys.path
+ directories = abs_path_get(directories, False)
- directories = []
- outfile = ""
+ outfile = args.outfile
+ outfile = os.path.expanduser(outfile)
+ outfile = os.path.abspath(outfile)
- if args.directory == None:
- print "ERROR: no source directory was provided"
- exit(1)
- elif args.outfile == None:
- print "ERROR: no output file was provided"
+ outdir = os.path.split(outfile)[0]
+ if not os.path.exists(outdir):
+ print "ERROR: output directory %s doesn't exists... Aborting..."%outdir
exit(1)
- else:
- directories = abs_path_get(args.directory)
-
- outfile = args.outfile
- outfile = os.path.expanduser(outfile)
- outfile = os.path.abspath(outfile)
-
- outdir = os.path.split(outfile)[0]
- if not os.path.exists(outdir):
- print "ERROR: output directory %s doesn't exists... Aborting..."%outdir
- exit(1)
-
- verbose_print("Dirs: %s"%directories)
- verbose_print("Outfile: %s"%outfile)
-
xml_files = dir_files_get(directories)
xml_files = filter(isXML, xml_files)
@@ -138,14 +139,8 @@ def main():
#generating dot node description for node, for each class
for n, o in graph.items():
- if o.eo_type == types["REGULAR"]:
- line = " \"%s\" [label = \"%s \\n %s\", color = \"%s\"];"%(n, o.c_name, o.eo_type, n_color[types["REGULAR"]])
- elif o.eo_type == types["MIXIN"]:
- line = " \"%s\" [label = \"%s \\n %s\", color = \"%s\"];"%(n, o.c_name, o.eo_type, n_color[types["MIXIN"]])
- elif o.eo_type == types["INTERFACE"]:
- line = " \"%s\" [label = \"%s \\n %s\", color = \"%s\"];"%(n, o.c_name, o.eo_type, n_color[types["INTERFACE"]])
- elif o.eo_type == types["NO_INSTANT"]:
- line = " \"%s\" [label = \"%s \\n %s\", color = \"%s\"];"%(n, o.c_name, o.eo_type, n_color[types["NO_INSTANT"]])
+ if o.eo_type in types_list:
+ line = " \"%s\" [label = \"%s \\n %s\", color = \"%s\"];"%(n, o.c_name, type_names[o.eo_type][SHORT_LONG], n_color[o.eo_type])
else:
line = " \"%s\" [label = \"%s \\n %s\"];"%(n, o.c_name, o.eo_type)
@@ -160,32 +155,34 @@ def main():
if parent in graph:
p_type = graph[parent].eo_type
else:
- p_type = types["REGULAR"]
- line = " \"%s\" -> \"%s\" [style = \"%s\", color=\"%s\"];"%(n, parent, styles["edge"], n_color[p_type])
+ p_type = TYPE_REGULAR
+ line = " \"%s\" -> \"%s\" [style = \"%s\", color=\"%s\"];"%(n, parent, "solid", n_color[p_type])
lines.append(line)
for l in ext:
- if graph[l].eo_type == types["REGULAR"]:
- line = " \"%s\" -> \"%s\" [style=\"%s\", color=\"%s\"] ;"%(n, l, "dashed", n_color[types["REGULAR"]])
- elif graph[l].eo_type == types["MIXIN"]:
- line = " \"%s\" -> \"%s\" [style=\"%s\", color=\"%s\"] ;"%(n, l, "dashed", n_color[types["MIXIN"]])
- elif graph[l].eo_type == types["INTERFACE"]:
-# line = " \"%s\" -> \"%s\" [style=\"%s\"] ;"%(k, l, styles["extedge"])
- line = " \"%s\" -> \"%s\" [style=\"%s\", color = \"%s\"] ;"%(n, l, "dotted", n_color[types["INTERFACE"]])
- elif graph[l].eo_type == types["NO_INSTANT"]:
- line = " \"%s\" -> \"%s\" [style=\"%s\", color=\"%s\"] ;"%(n, l, "dashed", n_color[types["NO_INSTANT"]])
+ eo_type_tmp = graph[l].eo_type
+ if eo_type_tmp in types_list:
+ line = " \"%s\" -> \"%s\" [style=\"%s\", color=\"%s\"] ;"%(n, l, p_edge[eo_type_tmp], n_color[eo_type_tmp])
else:
line = " \"%s\" -> \"%s\" [style=\"%s\", color=\"%s\"] ;"%(k, l, "dashed", "black")
lines.append(line)
lines.append("}")
- f = open(outfile, 'w')
+ tmp_dot_file = "tmp.dot"
+ f = open(tmp_dot_file, 'w')
for l in lines:
f.write(l+'\n')
f.close()
- verbose_print("dot file: %s was generated"%(outfile))
+ verbose_print("Dot file: '%s' was generated"%(tmp_dot_file))
+ verbose_print("Graph file: '%s was generated"%(outfile))
+ os.system("dot -Tpng %s -o %s"%(tmp_dot_file, outfile))
+ #os.system("neato -Tpng %s -o %s_neato"%(tmp_dot_file, outfile))
+ #os.system("twopi -Tpng %s -o %s_twopi"%(tmp_dot_file, outfile))
+ #os.system("circo -Tpng %s -o %s_circo"%(tmp_dot_file, outfile))
+ #os.system("fdp -Tpng %s -o %s_fdp"%(tmp_dot_file, outfile))
+ #os.system("sfdp -Tpng %s -o %s_sfdp"%(tmp_dot_file, outfile))
if __name__ == "__main__":
main()
diff --git a/bin/eo_js_gen.py b/bin/eo_js_gen.py
new file mode 100755
index 0000000..b7d0b1f
--- /dev/null
+++ b/bin/eo_js_gen.py
@@ -0,0 +1,167 @@
+#!/usr/bin/env python
+
+from eoparser.helper import isXML, abs_path_get, dir_files_get, normalize_names
+from eoparser.helper import _const
+from eoparser.xmlparser import XMLparser
+from argparse import ArgumentParser
+import os, sys
+
+const = _const()
+
+
+def verbose_true(mes):
+ print mes
+
+def verbose_false(mes):
+ pass
+
+def makefile_file_generate(args, c_files, outdir):
+ module_name = args.module
+ pkg = args.pkg
+ incl_paths = ["."]
+ if args.include_paths is not None:
+ incl_paths += args.include_paths
+ libs = args.libraries
+ lib_paths = args.library_paths
+ cpp_defines = args.cpp_defines
+
+ #if someone wants to add -DSOME_STR=\"str\"
+ #I will add one more escape symbol, because I also generate Makefile
+ if cpp_defines is not None:
+ lst_tmp = []
+ for d in cpp_defines:
+ lst_tmp.append(d.replace("\"", "\\\""))
+ cpp_defines = list(lst_tmp)
+ del lst_tmp
+
+ makefile_file = "Makefile"
+ default_c_files = ['main.cc', 'CElmObject.cc', '_eobase.cc', '_module.cc']
+ c_files = default_c_files + c_files
+
+ lines = []
+ lines.append("CC=g++")
+ lines.append("all: lib%s.so"%module_name)
+ lines.append("\n")
+ lines.append("lib_SOURCES = \\")
+ for f in c_files:
+ lines.append("%s \\"%f)
+ lines[-1] = lines[-1][:-2]
+
+ lines.append("")
+ lines.append("lib_OBJECTS = $(lib_SOURCES:.cc=.o)")
+
+ lines.append("")
+ lines.append("lib_CFLAGS = \\")
+ # lines.append("-I. \\")
+ #lines.append("-DPACKAGE_DATA_DIR=\\\"/tmp\\\" \\")
+ #lines.append("-DPACKAGE_TMP_DIR=\\\"/tmp\\\" \\")
+
+ for i in incl_paths:
+ lines.append("-I%s \\"%i)
+
+ for l in pkg.split():
+ lines.append("`pkg-config --cflags %s` \\"%l)
+
+ if cpp_defines is not None:
+ for d in cpp_defines:
+ lines.append("-D%s \\"%d)
+ lines[-1] = lines[-1][:-2]
+
+ lines.append("")
+ lines.append("lib_LDFLAGS = \\")
+ for l in pkg.split():
+ lines.append("`pkg-config --libs %s` \\"%l)
+
+ if lib_paths is not None:
+ for l in lib_paths:
+ lines.append("-L%s \\"%l)
+
+ if libs is not None:
+ for l in libs:
+ lines.append("-l%s \\"%l)
+ lines[-1] = lines[-1][:-2]
+
+ lines.append("")
+ lines.append("lib%s.so: $(lib_OBJECTS)"%module_name)
+ lines.append("\t$(CC) -shared -Wl,-soname,$@ -o $@ $^ $(lib_LDFLAGS)")
+
+ lines.append("")
+ lines.append("%.o : %.cc $(libjse_HEADERS)")
+ lines.append("\t$(CC) -fPIC $(lib_CFLAGS) -c $< -o $@")
+
+ lines.append("")
+ lines.append("clean:")
+ lines.append("\trm -f *~ *.o *.so")
+
+
+ f = open(os.path.join(outdir, makefile_file), 'w')
+ for l in lines:
+ f.write(l + "\n")
+ f.close()
+
+def main():
+ parser = ArgumentParser()
+ parser.add_argument("-d", "--dir", dest="directory",
+ action="append", help="Path to XML descriptions", required=True)
+
+ parser.add_argument("-o", "--outdir", dest="outdir",
+ action="store", help="Output directory", required=True)
+
+ parser.add_argument("-v", "--verbose",
+ action="store_true", dest="verbose", default=False,
+ help="Verbose output")
+
+ parser.add_argument("-X", "--xmldir", dest="xmldir", default=sys.path,
+ action="append", help="Directory to search for parent classes's XMLs")
+
+ parser.add_argument("--pkg", dest="pkg", default = "eo",
+ action="store", help="pkg-confing libraries. Default: \"eo\"")
+
+ parser.add_argument("-m", "--module", dest="module",
+ action="store", help="Name of module", required=True)
+
+ parser.add_argument("-I", "--include", dest="include_paths",
+ action="append", help="Pre-processor include path")
+
+ parser.add_argument("-l", "--library", dest="libraries",
+ action="append", help="Libraries of this unit")
+
+ parser.add_argument("-L", "--library-path", dest="library_paths",
+ action="append", help="Directories to search for libraries")
+
+ parser.add_argument("-D", "--define", dest="cpp_defines",
+ action="append", help="Pre-processor define")
+
+
+ args = parser.parse_args()
+
+ verbose_print = verbose_true if args.verbose is True else verbose_false
+
+ directories = []
+ outdir = ""
+ sourcedir = ""
+ incl_dirs = []
+
+ directories = abs_path_get(args.directory)
+ outdir = abs_path_get([args.outdir])[0]
+ if args.xmldir is not None:
+ incl_dirs = abs_path_get(args.xmldir, False)
+
+ xml_files = dir_files_get(directories, False)
+ xml_files = filter(isXML, xml_files)
+
+ xp = XMLparser()
+ xp.module_parse(args.module, xml_files, incl_dirs)
+ xp.js_code_generate(outdir)
+
+ c_files = []
+ for n, o in xp.objects.items():
+ c_files.append(o.V.c_file.name)
+
+ makefile_file_generate(args, c_files, outdir)
+
+ del xp
+
+if __name__ == "__main__":
+ main()
+
diff --git a/bin/eo_py_gen.py b/bin/eo_py_gen.py
new file mode 100755
index 0000000..1874584
--- /dev/null
+++ b/bin/eo_py_gen.py
@@ -0,0 +1,204 @@
+#!/usr/bin/env python
+
+from eoparser.helper import isXML, abs_path_get, dir_files_get, _const
+from eoparser.xmlparser import XMLparser
+from argparse import ArgumentParser
+import os, sys, shutil
+
+
+const = _const()
+
+def verbose_true(mes):
+ print mes
+
+def verbose_false(mes):
+ pass
+
+
+def setup_file_generate(args, outdir):
+ module_name = args.module
+ pkg = args.pkg
+ incl_paths = args.include_paths
+ libs = args.libraries
+ lib_paths = args.library_paths
+ cpp_defines = args.cpp_defines
+
+ #if someone wants to add -DSOME_STR=\"str\"
+ #I will add one more escape symbol, because I also generate setup.py
+ if cpp_defines is not None:
+ lst_tmp = []
+ for d in cpp_defines:
+ lst_tmp.append(d.replace("\"", "\\\""))
+ cpp_defines = list(lst_tmp)
+ del lst_tmp
+
+ module_file = module_name + ".pyx"
+
+ lines = []
+ lines.append("from distutils.core import setup")
+ lines.append("from distutils.extension import Extension")
+ lines.append("from Cython.Distutils import build_ext")
+ lines.append("import commands")
+ lines.append("")
+
+ lines.append("def pkgconfig(_libs):")
+ lines.append(" cf = commands.getoutput(\"pkg-config --cflags %s\"%_libs).split()")
+ lines.append(" ldf = commands.getoutput(\"pkg-config --libs %s\"%_libs).split()")
+ lines.append(" return (cf, ldf)")
+ lines.append("")
+
+ lines.append("(e_compile_args, e_link_args) = pkgconfig(\"%s\")"%pkg)
+ lines.append("")
+
+ if cpp_defines is not None:
+ for d in cpp_defines:
+ lines.append("e_compile_args.append(\"-D%s\")"%d)
+
+ include_dirs = ["\".\""]
+ if incl_paths is not None:
+ for i in incl_paths:
+ include_dirs.append("\"%s\""%i)
+ lines.append("e_include_dirs = [%s]"%', '.join(include_dirs))
+ del include_dirs
+
+ lib_dirs = []
+ if lib_paths is not None:
+ for i in lib_paths:
+ lib_dirs.append("\"%s\""%i)
+ lines.append("e_library_dirs = [%s]"%', '.join(lib_dirs))
+ del lib_dirs
+
+ lib_names = []
+ if libs is not None:
+ for i in libs:
+ lib_names.append("\"%s\""%i)
+ lines.append("e_libraries = [%s]"%', '.join(lib_names))
+ del lib_names
+
+ lines.append("")
+
+ lines.append("setup(")
+ lines.append(" cmdclass = {'build_ext': build_ext},")
+
+ if module_name == "eobase":
+ lines.append(" name = 'eobase_test_name',")
+ lines.append(" packages=['%s'],"%const.PREFIX)
+ lines.append(" package_data={'%s': ['EoBase.xml', 'eodefault.pxd']},"%(const.PREFIX))
+
+ lines.append(" ext_modules = [")
+ lines.append(" Extension(\"%s.%s\", ['%s/%s'], include_dirs = e_include_dirs, library_dirs = e_library_dirs, libraries = e_libraries, extra_compile_args = e_compile_args, extra_link_args = e_link_args),"%(const.PREFIX, "eodefault", const.PREFIX, "eodefault.pyx"))
+
+ lines.append(" Extension(\"%s.%s\", ['%s/%s'], include_dirs = e_include_dirs, library_dirs = e_library_dirs, libraries = e_libraries, extra_compile_args = e_compile_args, extra_link_args = e_link_args),"%(const.PREFIX, module_name, const.PREFIX, module_name + ".pyx"))
+
+ else:
+ lines.append(" name='%s',"%module_name)
+ lines.append(" ext_package='%s',"%const.PREFIX)
+ lines.append(" ext_modules = [")
+ lines.append(" Extension(\"%s\", ['%s'], include_dirs = e_include_dirs, library_dirs = e_library_dirs, libraries = e_libraries, extra_compile_args = e_compile_args, extra_link_args = e_link_args),"%(module_name, module_name + ".pyx"))
+
+ lines.append(" ])\n\n")
+
+
+ f = open(os.path.join(outdir, "setup.py"), 'w')
+ for l in lines:
+ f.write(l + "\n")
+ f.close()
+
+
+def main():
+ parser = ArgumentParser()
+ parser.add_argument("-d", "--dir", dest="directory",
+ action="append", help="Path to XML descriptions", required=True)
+
+ parser.add_argument("-o", "--outdir", dest="outdir",
+ action="store", help="Output directory", required=True)
+
+ parser.add_argument("-v", "--verbose",
+ action="store_true", dest="verbose", default=False,
+ help="Verbose output")
+
+ parser.add_argument("-X", "--xmldir", dest="xmldir", default=sys.path,
+ action="append", help="Directory to search for parent classes's XMLs")
+
+ parser.add_argument("--pkg", dest="pkg", default = "eo",
+ action="store", help="pkg-confing libraries. Default: \"eo\"")
+
+ parser.add_argument("-m", "--module", dest="module",
+ action="store", help="Name of module", required=True)
+
+ parser.add_argument("-I", "--include", dest="include_paths",
+ action="append", help="Pre-processor include path")
+
+ parser.add_argument("-l", "--library", dest="libraries",
+ action="append", help="Libraries of this unit")
+
+ parser.add_argument("-L", "--library-path", dest="library_paths",
+ action="append", help="Directories to search for libraries")
+
+ parser.add_argument("-D", "--define", dest="cpp_defines",
+ action="append", help="Pre-processor define")
+
+ args = parser.parse_args()
+
+ verbose_print = verbose_true if args.verbose is True else verbose_false
+
+ directories = []
+ outdir = ""
+ sourcedir = ""
+ incl_dirs = []
+
+ directories = abs_path_get(args.directory)
+ outdir = abs_path_get([args.outdir])[0]
+ if args.xmldir is not None:
+ incl_dirs = abs_path_get(args.xmldir, False)
+
+ xml_files = dir_files_get(directories, False)
+ xml_files = filter(isXML, xml_files)
+
+ xp = XMLparser()
+ xp.module_parse(args.module, xml_files, incl_dirs)
+
+ if args.module == "eobase":
+ outdir_tmp = os.path.join(outdir, const.PREFIX)
+ if not os.path.exists(outdir_tmp):
+ os.mkdir(outdir_tmp)
+ xp.py_code_generate(args.module ,outdir_tmp)
+ else:
+ xp.py_code_generate(args.module ,outdir)
+
+ setup_file_generate(args, outdir)
+
+ #Looking for "eodefault.pxd" module. Needed to include
+ if args.module == "eobase":
+ for d in incl_dirs:
+ d_tmp = os.path.join(d, "eodefault.pxd")
+ if os.path.exists(d_tmp):
+ sourcedir = d
+ break
+
+ if sourcedir == "":
+ print "ERROR: no include files were found... Aborting... (Use: -X(--xmldir=)XML_DIR)"
+ exit(1)
+
+ #copying eodefault module into source dir
+ f_pyx = os.path.join(sourcedir, "eodefault.pyx")
+ f_pxd = os.path.join(sourcedir, "eodefault.pxd")
+ f_init = os.path.join(sourcedir,"__init__.py")
+ try:
+ #this file is needed only to build eodefault.
+ outdir_tmp = os.path.join(outdir, const.PREFIX)
+ shutil.copy(f_pyx, outdir_tmp)
+ shutil.copy(f_pxd, outdir_tmp)
+ shutil.copy(f_init, outdir_tmp)
+ except IOError as ex:
+ print "%s"%ex
+ print "Aborting"
+ exit(1)
+ except shutil.Error as er:
+ print "Warning: %s"%er
+
+ del xp
+
+if __name__ == "__main__":
+ main()
+
diff --git a/eo_parser/eo_xml_gen.py b/bin/eo_xml_gen.py
index f87c380..cfbd298 100755
--- a/eo_parser/eo_xml_gen.py
+++ b/bin/eo_xml_gen.py
@@ -1,9 +1,9 @@
#!/usr/bin/env python
-from eo_parser.helper import dir_files_get, abs_path_get, isC, isH, isXML
-from eo_parser.helper import _const
-from eo_parser.XMLparser import XMLparser
-from eo_parser.Cparser import Cparser
+from eoparser.helper import dir_files_get, abs_path_get, isC, isH, isXML
+from eoparser.helper import _const
+from eoparser.xmlparser import XMLparser
+from eoparser.cparser import Cparser
from argparse import ArgumentParser
import sys
@@ -19,20 +19,20 @@ def main():
parser = ArgumentParser()
parser.add_argument("-d", "--dir", dest="directory",
- action="append", help="source files")
+ action="append", help="Source C-files to introspect", required=True)
parser.add_argument("-o", "--outdir", dest="outdir",
- action="store", help="output directory")
+ action="store", help="Output directory", required=True)
parser.add_argument("-t", "--typedefs", dest="typedefs",
action="store", help="Additional typedefs for parser")
- parser.add_argument("-i", "--include", dest="xmldir", default = sys.path,
- action="append", help="Include xml directory")
+ parser.add_argument("-X", "--xmldir", dest="xmldir", default = sys.path,
+ action="append", help="Directory to search for parent classes's XMLs")
parser.add_argument("-v", "--verbose",
action="store_true", dest="verbose", default=False,
- help="print status messages to stdout")
+ help="Verbose output")
args = parser.parse_args()
verbose_print = None
@@ -47,25 +47,15 @@ def main():
typedefs = ""
xmldir = []
- if args.directory == None:
- print "No source directory was provided"
- exit(1)
- elif args.outdir == None:
- print "No out directory was provided"
- exit(1)
- else:
- directories = abs_path_get(args.directory)
- if args.xmldir is not None:
- xmldir = abs_path_get(args.xmldir, False)# not abort if dir doesn't exist
+ directories = abs_path_get(args.directory)
+ outdir = abs_path_get([args.outdir])[0]
- outdir = abs_path_get([args.outdir])[0]
+ if args.xmldir is not None:
+ xmldir = abs_path_get(args.xmldir, False)# not abort if dir doesn't exist
if args.typedefs != None:
typedefs = abs_path_get([args.typedefs])[0]
- verbose_print("dirs %s"%directories)
- verbose_print("outdir %s"%outdir)
-
files = dir_files_get(directories)
c_files = filter(isC, files)
h_files = filter(isH, files)
@@ -86,7 +76,6 @@ def main():
for f in h_files:
cp.h_file_data_get(f)
-
#remove records, which are not class, t.e. they don't have GET_FUNCTION key
cl_data_tmp = dict(cp.cl_data) #deep copy of dictionary
for k in cl_data_tmp:
@@ -109,8 +98,6 @@ def main():
cl_data_tmp2 = dict(cp.cl_data)
parents_to_find = filter(lambda ll: True if ll not in cl_data_tmp2 else False, list_of_parents)
- verbose_print("parents_to_find: %s"%parents_to_find)
-
#if we have parents to find
if len(parents_to_find) != 0:
if len(xmldir) == 0:
@@ -123,7 +110,6 @@ def main():
if len(xml_files) == 0:
print "ERROR: no include files found for %s classes... Aborting..."% ",".join(parents_to_find)
exit(1)
- verbose_print("xml_files: %s\n"%xml_files)
#parsing include XMLs
xp = XMLparser()
@@ -139,7 +125,6 @@ def main():
parents_to_find.pop(i)
del xp
-
#if there are still parents, which we need to find - exit
if len(parents_to_find) != 0:
print "ERROR: XML files weren't found for %s classes... Aborting"%(",".join(parents_to_find))
@@ -149,7 +134,6 @@ def main():
for k in cp.cl_data:
cp.build_xml(k)
- #cp.print_data()
del cp
if __name__ == "__main__":
diff --git a/eo_js/README b/eo_js/README
deleted file mode 100644
index 3a783e0..0000000
--- a/eo_js/README
+++ /dev/null
@@ -1,36 +0,0 @@
-############################################################################
-
-EO Introspection - JavaScript Bindings
-
-############################################################################
-
-It analyzes XML files generated by EO introspection scanner and generates
-module, which can be used with V8-based js-engine - elev8.
-
-############################################################################
-
-1. Generating js module for classes defined in XMLs:
- a. > python eo_js_gen.py --dir=XML_FOLDER --outdir=OUTDIR
- --module=MODULE_NAME --include=INCLUDE_DIR
-
- In case if some class is needed
- (usually parent class, which is not in the tree being analyzed),
- include XMLs are searched in python system paths.
- If include file wasn't found, explicit --include=INCLUDE_DIR dir is needed
-
- Files to be generated:
- - *.cc, *.h will be created for each *.xml
- b. Compiling module:
- > not yet.
- following files are needed to compile
- elm.h
- CElmObject.cc
- CElmObject.h
-
- *.so module will be compiled
-
-############################################################################
-############################################################################
-############################################################################
-
-
diff --git a/eo_js/elm.h b/eo_js/elm.h
index be88c11..0dd1507 100644
--- a/eo_js/elm.h
+++ b/eo_js/elm.h
@@ -66,30 +66,36 @@ extern int log_domain;
#define PROPERTY(name_) \
#name_, Callback_## name_ ##_get, Callback_## name_ ##_set, NULL
+#define PROPERTY_RO(name_) \
+ #name_, Callback_## name_ ##_get, NULL, NULL
+
+#define PROPERTY_SO(name_) \
+ #name_, NULL, Callback_## name_ ##_set, NULL
+
#define METHOD(name_) \
#name_, NULL, NULL, Callback_## name_
#define EO_GENERATE_PROPERTY_CALLBACKS(class_,name_) \
Handle<Value> Callback_## name_ ##_get(Local<String>, const AccessorInfo &info) { \
HandleScope scope; \
- return scope.Close(GetObjectFromAccessorInfo<class_>(info)->name_ ##_get()); \
+ return scope.Close(GetObjectFromAccessorInfo<class_>(info)->__## name_ ##_get()); \
} \
void Callback_## name_ ##_set(Local<String>, Local<Value> value, const AccessorInfo &info) { \
HandleScope scope; \
- GetObjectFromAccessorInfo<class_>(info)->name_ ##_set(value); \
+ GetObjectFromAccessorInfo<class_>(info)->__## name_ ##_set(value); \
}
#define EO_GENERATE_PROPERTY_GET_CALLBACK(class_,name_) \
Handle<Value> Callback_## name_ ##_get(Local<String>, const AccessorInfo &info) { \
HandleScope scope; \
- return scope.Close(GetObjectFromAccessorInfo<class_>(info)->name_ ##_get()); \
+ return scope.Close(GetObjectFromAccessorInfo<class_>(info)->__## name_ ##_get()); \
}
#define EO_GENERATE_PROPERTY_SET_CALLBACK(class_,name_) \
void Callback_## name_ ##_set(Local<String>, Local<Value> value, const AccessorInfo &info) { \
HandleScope scope; \
- GetObjectFromAccessorInfo<class_>(info)->name_ ##_set(value); \
+ GetObjectFromAccessorInfo<class_>(info)->__## name_ ##_set(value); \
}
#define EO_GENERATE_PROPERTY_GET_EMPTY_CALLBACK(class_,name_) \
@@ -121,9 +127,13 @@ extern int log_domain;
#define EO_GENERATE_METHOD_CALLBACKS(class_,name_) \
Handle<Value> Callback_## name_(const Arguments& args) { \
HandleScope scope; \
- return scope.Close(GetObjectFromArguments<class_>(args)->name_(args)); \
+ return scope.Close(GetObjectFromArguments<class_>(args)->__## name_(args)); \
}
+#define EO_GENERATE_STATIC_METHOD(class_, name_) \
+ static Handle<Value> static_## name_(const Arguments& args) { \
+ return Undefined(); \
+ }
#define EO_REGISTER_STATIC_METHOD(_name) \
GetTemplate()->GetFunction()->ToObject()->Set(String::NewSymbol(#_name), FunctionTemplate::New(_name)->GetFunction())
diff --git a/eo_js/eo_js_gen.py b/eo_js/eo_js_gen.py
deleted file mode 100755
index 93da51b..0000000
--- a/eo_js/eo_js_gen.py
+++ /dev/null
@@ -1,80 +0,0 @@
-#!/usr/bin/env python
-
-from eo_parser.helper import isXML, abs_path_get, dir_files_get, normalize_names
-from eo_parser.helper import _const
-from eo_parser.XMLparser import XMLparser
-from argparse import ArgumentParser
-import os, sys
-
-const = _const()
-
-
-def verbose_true(mes):
- print mes
-
-def verbose_false(mes):
- pass
-
-def main():
- parser = ArgumentParser()
- parser.add_argument("-d", "--dir", dest="directory",
- action="append", help="Source files")
-
- parser.add_argument("-o", "--outdir", dest="outdir",
- action="store", help="Output directory")
-
- parser.add_argument("-v", "--verbose",
- action="store_true", dest="verbose", default=False,
- help="Print status messages to stdout. Default: False")
-
- parser.add_argument("-i", "--include", dest="xmldir", default=sys.path,
- action="append", help="Include eobase directory")
-
- parser.add_argument("--pkg", dest="pkg", default = "elementary eo",
- action="store", help="pkg-confing libraries. Default: \"elementary eo\"")
-
- parser.add_argument("-m", "--module", dest="module",
- action="store", help="Name of module to generate")
-
- args = parser.parse_args()
-
- verbose_print = verbose_true if args.verbose is True else verbose_false
- verbose_print("Options: %s"%args)
-
- directories = []
- outdir = ""
- sourcedir = ""
- incl_dirs = []
-
- if args.directory == None:
- print "ERROR: No source directory was provided"
- exit(1)
- elif args.outdir == None:
- print "ERROR: No out directory was provided"
- exit(1)
- elif args.module == None:
- print "ERROR: No module name was provided"
- exit(1)
- else:
- directories = abs_path_get(args.directory)
- outdir = abs_path_get([args.outdir])[0]
- if args.xmldir is not None:
- incl_dirs = abs_path_get(args.xmldir, False)
-
- verbose_print("Dirs: %s"%directories)
- verbose_print("Outdir: %s"%outdir)
- verbose_print("Include dirs: %s"%incl_dirs)
-
- xml_files = dir_files_get(directories, False)
- xml_files = filter(isXML, xml_files)
- verbose_print("In Files: %s"%xml_files)
-
- xp = XMLparser()
- xp.module_parse(args.module, xml_files, incl_dirs)
- xp.js_code_generate(outdir)
-
- del xp
-
-if __name__ == "__main__":
- main()
-
diff --git a/eo_parser/tests.py b/eo_parser/tests.py
deleted file mode 100644
index 2427658..0000000
--- a/eo_parser/tests.py
+++ /dev/null
@@ -1,77 +0,0 @@
-import unittest
-from XMLparser import XMLparser
-from eo_parser.Cparser import Cparser
-
-class testP(unittest.TestCase):
-
- def setUp(self):
- self.c_parser = Cparser(False)
-
- def test_strip(self):
- s = """
- #define MY_TEST_CLASS_NAME "test_class_name"
-
-static const Eo_Op_Description _elm_pan_op_desc[] = {
- EO_OP_DESCRIPTION(ELM_OBJ_PAN_SUB_ID_POS_SET, "description here"),
- EO_OP_DESCRIPTION(ELM_OBJ_PAN_SUB_ID_POS_GET, "description here"),
- EO_OP_DESCRIPTION_SENTINEL
-};
-
-static const Eo_Event_Description *event_desc[] = {
- EO_EV_CALLBACK_ADD,
- EO_EV_CALLBACK_DEL,
- EO_EV_DEL,
- NULL
-};
-
-static const Eo_Class_Description test_class_desc = {
- EO_VERSION,
- MY_TEST_CLASS_NAME,
- EO_CLASS_TYPE_REGULAR,
- EO_CLASS_DESCRIPTION_OPS(&ELM_OBJ_PAN_BASE_ID, _elm_pan_op_desc, ELM_OBJ_PAN_SUB_ID_LAST),
- event_desc,
- sizeof(Elm_Pan_Smart_Data),
- _elm_pan_class_constructor,
- NULL
-};
-
- EO_DEFINE_CLASS(class_get, &test_class_desc, parent, brother, NULL)
-
- """
- class_def_answer = {"class_get" : ["parent",
- ["brother"],
- "test_class_name",
- "EO_CLASS_TYPE_REGULAR",
- ["ELM_OBJ_PAN_BASE_ID",
- [("ELM_OBJ_PAN_SUB_ID_POS_SET", "pos_set"), ("ELM_OBJ_PAN_SUB_ID_POS_GET", "pos_get")],
- "ELM_OBJ_PAN_SUB_ID_LAST"],
- ["EO_EV_CALLBACK_ADD", "EO_EV_CALLBACK_DEL", "EO_EV_DEL"]
- ]}
- answer = class_def_answer
-
- ret = self.c_parser.fetch_data(s)
- self.assertEqual(ret, answer)
-# self.assertEqual(self.prs.strip_replace("{test str}", "{} "), "teststr" )
- """
- def test_strip2(self):
- s = "(teststr)"
- self.assertEqual(self.prs.strip_replace(" [te stst r] ", "[] "), "teststr")
-
- def test_parse(self):
- s = "EO_DEFINE_CLASS(elm_button_class_get, &desc)"
- self.assertEqual(self.prs.parse_class_desc(s), ["elm_button_class_get", "desc"])
- self.assertEqual(self.prs.defs, ["elm_button_class_get", "desc"])
- self.assertEqual(self.prs.dic, {"a" : "b" , 1 :34} )
-"""
-
-def suite():
-
- suite = unittest.TestSuite()
- suite.addTest(unittest.makeSuite(testP))
- return suite
-
-
-
-if __name__ == '__main__':
-
- unittest.main()
diff --git a/eo_parser/types.xml b/eo_parser/types.xml
deleted file mode 100644
index 61f30c2..0000000
--- a/eo_parser/types.xml
+++ /dev/null
@@ -1,16 +0,0 @@
-<?xml version="1.0" ?>
-<types>
- <type from="Evas_Object" to="Eo"/>
- <type from="Evas_Smart" to="Eo"/>
- <type from="Evas_Map" to="Eo"/>
- <type from="Evas_Text_Style_Type" to="Eo"/>
- <type from="Evas_Colorspace" to="Eo"/>
- <type from="Evas_Render_Op" to="Eo"/>
- <type from="Evas_Aspect_Control" to="Eo"/>
- <type from="a" to="int"/>
- <type from="b" to="a*"/>
- <type from="c" to="char"/>
- <type from="d" to="c*"/>
-
-
-</types>
diff --git a/eo_py/README b/eo_py/README
deleted file mode 100644
index 85b4e29..0000000
--- a/eo_py/README
+++ /dev/null
@@ -1,55 +0,0 @@
-############################################################################
-
-EO Introspection - Python Bindings
-
-############################################################################
-
-It analyzes XML files generated by EO introspection scanner and generates
-python module.
-
-############################################################################
-
-1. Generating python module for classes defined in XMLs:
- a. > python eo_py_gen.py --dir=XML_FOLDER --outdir=OUTDIR --pkg="lib1 lib2"
- --module=MODULE_NAME --include=INCLUDE_DIR
- In case if some class is needed (usually parent class, which is not in the tree being analyzed),
- include XMLs are searched in python system paths.
- If include file wasn't found, explicit --include=INCLUDE_DIR dir is needed
-
- Files to be generated:
- - MODULE_NAME.pyx
- - *.pxi, *.pxd will be created for each *.xml
- - setup.py
- setup.py can be edited in order to add include paths and libraries,
- which were not mentioned in --pkg option
- b. Compiling module:
- > python setup.py build_ext --inplace
- - py_module.so will be generated.
-
- Put module into python search path and import into your code.
-
-############################################################################
-############################################################################
-############################################################################
-
-1. Creating eobase module:
- a. Create new dir - PY_EOBASE
- b. Base module folder being introspected - EOBASE
- > python eo_xml_gen.py --dir=EOBASE --outdir=PY_EOBASE
- - eobase.xml will be created in PY_EOBASE
- c. Creating eobase python sources:
- > python eo_py_gen.py --dir=PY_EOBASE --outdir=PY_EOBASE --module=eobase
- --pkg="elementary eo"
- To create base module, option --module must be "eobase"
- - eobase.pxd, eobase.pyx - will be created
- - eodefault.pxd, eodefault.pyx - will be copied into PY_EOBASE
- - setup.py will be created.
- setup.py can be modified in order to add include paths and libraries,
- which weren't mentioned in --pkg option
- d. Compiling python sources into python module.
- > python setup.py build_ext --inplace
- - eodefault.so, eobase.so will be created
- e. Copy __init__.py to PY_EOBASE
- Add PYTHONPATH = PY_EOBASE
-
-
diff --git a/eo_py/elm_add.pxd b/eo_py/elm_add.pxd
new file mode 100644
index 0000000..dcc5d57
--- /dev/null
+++ b/eo_py/elm_add.pxd
@@ -0,0 +1,4 @@
+
+cdef extern from "Elementary.h":
+ int elm_init(int argc, char **argv)
+ void elm_run()
diff --git a/eo_py/elm_add.pxi b/eo_py/elm_add.pxi
new file mode 100644
index 0000000..0d16713
--- /dev/null
+++ b/eo_py/elm_add.pxi
@@ -0,0 +1,20 @@
+
+
+cimport elm_add
+
+def elm_run():
+ elm_add.elm_run()
+
+
+def elm_init(argv):
+ cdef void *p
+# s = " ".join(argv)
+# cdef char *cstr
+# cdef char **p_cstr
+# cstr = <char*>s
+# print "cstr = ", cstr
+# c_csrt = <char**>cstr
+# print "p_cstr[0] = ", p_cstr[0]
+ p = NULL
+ return <int>(elm_add.elm_init(len(argv), NULL))
+
diff --git a/eo_py/eo_py_gen.py b/eo_py/eo_py_gen.py
deleted file mode 100755
index b3eac5c..0000000
--- a/eo_py/eo_py_gen.py
+++ /dev/null
@@ -1,149 +0,0 @@
-#!/usr/bin/env python
-
-from eo_parser.helper import isXML, abs_path_get, dir_files_get, normalize_names
-from eo_parser.XMLparser import XMLparser
-from argparse import ArgumentParser
-import os, sys, shutil
-
-def verbose_true(mes):
- print mes
-
-def verbose_false(mes):
- pass
-
-
-def setup_file_generate(module_name, pkg, outdir):
- module_file = module_name + ".pyx"
-
- lines = []
- lines.append("from distutils.core import setup")
- lines.append("from distutils.extension import Extension")
- lines.append("from Cython.Distutils import build_ext")
- lines.append("import commands, os")
- lines.append("")
-
- lines.append("def pkgconfig(_libs):")
- lines.append(" cf = commands.getoutput(\"pkg-config --cflags %s\"%_libs).split()")
- lines.append(" ldf = commands.getoutput(\"pkg-config --libs %s\"%_libs).split()")
- lines.append(" return (cf, ldf)")
- lines.append("")
-
- lines.append("(e_compile_args, e_link_args) = pkgconfig(\"%s\")"%pkg)
- lines.append("")
-
- lines.append("e_include_dirs = [\".\"]")
- lines.append("e_library_dirs = []")
- lines.append("e_libraries = []")
- lines.append("")
-
- lines.append("setup(")
- lines.append(" cmdclass = {'build_ext': build_ext},")
- lines.append(" ext_modules = [")
-
- if module_name == "eobase":
- lines.append(" Extension(\"%s\", ['%s'], include_dirs = e_include_dirs, library_dirs = e_library_dirs, libraries = e_libraries, extra_compile_args = e_compile_args, extra_link_args = e_link_args),"%("eodefault", "eodefault.pyx"))
-
- lines.append(" Extension(\"%s\", ['%s'], include_dirs = e_include_dirs, library_dirs = e_library_dirs, libraries = e_libraries, extra_compile_args = e_compile_args, extra_link_args = e_link_args),"%(module_name, module_name + ".pyx"))
-
- lines.append(" ])\n\n")
-
-
- f = open(os.path.join(outdir, "setup.py"), 'w')
- for l in lines:
- f.write(l + "\n")
- f.close()
-
-
-def main():
- parser = ArgumentParser()
- parser.add_argument("-d", "--dir", dest="directory",
- action="append", help="Source files")
-
- parser.add_argument("-o", "--outdir", dest="outdir",
- action="store", help="Output directory")
-
- parser.add_argument("-v", "--verbose",
- action="store_true", dest="verbose", default=False,
- help="Print status messages to stdout. Default: False")
-
- parser.add_argument("-i", "--include", dest="xmldir", default=sys.path,
- action="append", help="Include eobase directory")
-
- parser.add_argument("--pkg", dest="pkg", default = "elementary eo",
- action="store", help="pkg-confing libraries. Default: \"elementary eo\"")
-
- parser.add_argument("-m", "--module", dest="module",
- action="store", help="Name of module to generate")
-
- args = parser.parse_args()
-
- verbose_print = verbose_true if args.verbose is True else verbose_false
-
- verbose_print("Options: %s"%args)
-
- directories = []
- outdir = ""
- sourcedir = ""
- incl_dirs = []
-
- if args.directory == None:
- print "ERROR: No source directory was provided"
- exit(1)
- elif args.outdir == None:
- print "ERROR: No out directory was provided"
- exit(1)
- elif args.module == None:
- print "ERROR: No module name was provided"
- exit(1)
- else:
- directories = abs_path_get(args.directory)
- outdir = abs_path_get([args.outdir])[0]
- if args.xmldir is not None:
- incl_dirs = abs_path_get(args.xmldir, False)
-
-
- verbose_print("Dirs: %s"%directories)
- verbose_print("Outdir: %s"%outdir)
- verbose_print("Include dirs: %s"%incl_dirs)
-
- xml_files = dir_files_get(directories, False)
- xml_files = filter(isXML, xml_files)
- verbose_print("In Files: %s"%xml_files)
-
- xp = XMLparser()
- xp.module_parse(args.module, xml_files, incl_dirs)
- xp.py_code_generate(args.module ,outdir)
-
- setup_file_generate(args.module, args.pkg, outdir)
-
- #Looking for "eodefault.pxd" module. Needed to include
- for d in incl_dirs:
- d_tmp = os.path.join(d, "eodefault.pxd")
- if os.path.exists(d_tmp):
- sourcedir = d
- break
-
- if sourcedir == "":
- print "ERROR: no include files were found... Aborting... (Use: --include=INCLUDE_DIR)"
- exit(1)
-
- #copying eodefault module into source dir
- f_pyx = os.path.join(sourcedir, "eodefault.pyx")
- f_pxd = os.path.join(sourcedir, "eodefault.pxd")
- f_init = os.path.join(sourcedir, "__init__.py")
- try:
- shutil.copy(f_pyx, outdir)
- shutil.copy(f_pxd, outdir)
- shutil.copy(f_init, outdir)
- except IOError as ex:
- print "%s"%ex
- print "Aborting"
- exit(1)
- except shutil.Error as er:
- print "Warning: %s"%er
-
- del xp
-
-if __name__ == "__main__":
- main()
-
diff --git a/eo_py/eodefault.pxd b/eo_py/eodefault.pxd
index e7c3960..2f3aadc 100644
--- a/eo_py/eodefault.pxd
+++ b/eo_py/eodefault.pxd
@@ -51,6 +51,7 @@ cdef extern from "Eo.h":
Eo_Class *eo_base_class_get()
Eo* eo_add(Eo_Class *klass, Eo *parent)
+ Eo* eo_add_custom(Eo_Class *klass, Eo *parent, ...)
Eo* eo_ref(Eo *obj)
void eo_unref(Eo *obj)
@@ -69,17 +70,12 @@ cdef extern from "Eo.h":
Eina_Bool eo_class_do(Eo_Class *klass, ...)
-cdef extern from "Elementary.h":
- int elm_init(int argc, char **argv)
- void elm_run()
-
-
cdef class EoDefault:
cdef Eo *eo
cdef object name
cdef int print_func_name(self, f_name)
cdef int _eo_instance_set(self, Eo *eo)
- cpdef _eo_instance_set2(self, klass, EoDefault parent)
+ cpdef _eo_instance_set2(self, unsigned long long klass, EoDefault parent)
cdef Eo* _eo_instance_get(EoDefault pyobj)
cdef Eina_Bool _object_callback(void *data, Eo *o, Eo_Event_Description *desc, void *event_info)
diff --git a/eo_py/eodefault.pyx b/eo_py/eodefault.pyx
index 67d6c9d..0842514 100644
--- a/eo_py/eodefault.pyx
+++ b/eo_py/eodefault.pyx
@@ -18,21 +18,6 @@ CALLBACK_STOP = 12345
def init():
return bool(eodefault.eo_init())
-def elem_run():
- eodefault.elm_run()
-
-def py_elm_init(argv):
- cdef void *p
-# s = " ".join(argv)
-# cdef char *cstr
-# cdef char **p_cstr
-# cstr = <char*>s
-# print "cstr = ", cstr
-# c_csrt = <char**>cstr
-# print "p_cstr[0] = ", p_cstr[0]
- p = NULL
- return <int>(eodefault.elm_init(len(argv), NULL))
-
#########################################################
cdef Eo *_eo_instance_get(EoDefault pyobj):
@@ -88,6 +73,9 @@ cdef class EoDefault:
eodefault.eo_ref(self.eo)
return self
+ def unref(self):
+ eodefault.eo_unref(self.eo)
+
# eo_ref_get()
def ref_get(self):
ref_count = <object>eodefault.eo_ref_get(self.eo)
@@ -109,17 +97,28 @@ cdef class EoDefault:
def name_get(self):
return self.name
-
+ #this func can be called only from this (c-styled)module
cdef int _eo_instance_set(self, Eo *eo):
assert self.eo == NULL, "Object must be clean"
self.eo = eo
self.name = self.__class__.__name__
- cpdef _eo_instance_set2(self, _kl, EoDefault p):
- kl = <long>_kl
- cdef Eo_Class *kl2 = <Eo_Class*>kl
- self._eo_instance_set(eodefault.eo_add(kl2, eodefault._eo_instance_get(p)))
-
+ # this func is main routine to add new object
+ # using default constructor
+ # and connect C and Py objects
+ cpdef _eo_instance_set2(self, unsigned long long _kl, EoDefault p):
+ cdef Eo_Class *kl = <Eo_Class*>_kl
+ cdef Eo *o = eodefault.eo_add(kl, eodefault._eo_instance_get(p))
+ self._eo_instance_set(o)
+ self._data_set(EoDefault.PY_EO_NAME, self)
+
+ # this func can be called outside(this c-styled module), because receives Eo* as long.
+ # it was added to be able to call eo_add_custom with different params
+ # and connect C and Py objects after it
+ def _eo_instance_set3(self, unsigned long long _eo):
+ cdef Eo *o = <Eo*>_eo
+ self._eo_instance_set(o)
+ self._data_set(EoDefault.PY_EO_NAME, self)
cdef int print_func_name(self, f_name):
print self.__class__, " :: ", f_name, " :: ", sys.getsizeof(self)
@@ -136,8 +135,11 @@ cdef Eina_Bool _object_callback(void *data, Eo *o,
eodefault.eo_do(o, eodefault.EO_BASE_BASE_ID+eodefault.EO_BASE_SUB_ID_DATA_GET, <const_char_ptr>EoDefault.PY_EO_NAME, &c_py_obj)
py_obj = <object>c_py_obj
- f = <object>data
- res = f(py_obj)
+ #cb_struct is tuple: (func, data)
+ cb_struct = <object>data
+ f = cb_struct[0]
+ cb_data = cb_struct[1]
+ res = f(py_obj, cb_data)
if res == CALLBACK_STOP:
return EINA_FALSE
diff --git a/eo_parser/__init__.py b/eoparser/__init__.py
index e69de29..e69de29 100644
--- a/eo_parser/__init__.py
+++ b/eoparser/__init__.py
diff --git a/eo_parser/Cparser.py b/eoparser/cparser.py
index 0b47d32..7f23b05 100644
--- a/eo_parser/Cparser.py
+++ b/eoparser/cparser.py
@@ -34,7 +34,80 @@ class Cparser(object):
self.typedefs = {"Evas_Coord" : "int",
"Evas_Angle":"int",
"Evas_Font_Size" : "int",
+ "Evas_Object" : "Eo",
+ "Evas_Smart" : "Eo",
+ "Evas_Map" : "Eo",
+ "Evas_Text_Style_Type" : "int",#enum
+ "Evas_Colorspace" : "int",#enum
+ "Evas_Render_Op" : "int",#enum
+ "Evas_Aspect_Control" : "int",#enum
+ "Evas_Object_Pointer_Mode" : "int", #enum
+ "Evas_Image_Scale_Hint" : "int", #enum
+ "Evas_Image_Content_Hint" : "int", #enum
+ "Evas_Image_Animated_Loop_Hint" : "int", #enum
+ "Evas_Border_Fill_Mode" : "int", #enum
+ "Evas_Object_Table_Homogeneous_Mode" : "int", #enum
+ "Evas_Textgrid_Font_Style" : "int",
+ "Evas_Textgrid_Palette" : "int",
+ "Evas_Modifier_Mask" : "unsigned long long",
+ "Evas_Button_Flags" : "int",
+ "Evas_Fill_Spread" : "int",
+ "Evas_Event_Flags" : "int",
+ "Evas_Font_Hinting_Flags" : "int",
+ "Evas_Load_Error" : "int",
+ "Elm_Photocam_Zoom_Mode" : "int",
"Eina_Bool" : "bool",
+ "Elm_Bg_Option" : "int",
+ "Elm_Fileselector_Mode" : "int",
+ "Elm_Object_Select_Mode" : "int",
+ "Elm_Actionslider_Pos" : "int",
+ "Elm_Web_Zoom_Mode" : "int",
+ "Elm_Icon_Type" : "int",
+ "Elm_Colorselextor_Mode" : "int",
+ "Elm_List_Mode" : "int",
+ "Elm_Image_Orient" : "int",
+ "Elm_Map_Route_Type" : "int",
+ "Elm_Map_Zoom_Mode" : "int",
+ "Elm_Map_Source_Type" : "int",
+ "Elm_Clock_Edit_Mode" : "int",
+ "Elm_Dayselector_Day" : "int",
+ "Elm_Thumb_Animation_Setting" : "int",
+ "Elm_Win_Keyboard_Mode" : "int",
+ "Elm_Toolbar_Shrink_Mode" : "int",
+ "Elm_Icon_Lookup_Order" : "int",
+ "Elm_Datetime_Field_Type" : "int",
+ "Elm_Gesture_Type" : "int",
+ "Evas_BiDi_Direction" : "int",
+ "Elm_Bubble_Pos" : "int",
+ "Ecore_X_Window" : "unsigned int",
+
+ "Elm_Flip_Interaction" : "int",
+ "Elm_Flip_Direction" : "int",
+ "Elm_Flip_Interaction" : "int",
+ "Elm_Flip_Mode" : "int",
+ "Elm_Calendar_Weekday" : "int",
+ "Elm_Calendar_Selectable" : "int",
+ "Elm_Calendar_Weekday" : "int",
+ "Elm_Calendar_Select_Mode" : "int",
+ "Elm_Illume_Command" : "int",
+ "Elm_Win_Keyboard_Mode" : "int",
+ "Elm_Win_Indicator_Opacity_Mode" : "int",
+ "Elm_Win_Indicator_Mode" : "int",
+ "Ecore_Wl_Window" : "int",
+ "Elm_GLView_Render_Policy" : "int",
+ "Elm_GLView_Mode" : "int",
+ "Elm_Panel_Orient" : "int",
+ "Elm_Popup_Orient" : "int",
+ "Elm_Wrap_Type" : "int",
+ "Elm_Cnp_Mode" : "int",
+ "Elm_Input_Panel_Lang" : "int",
+ "Elm_Text_Format" : "int",
+ "Elm_Input_Panel_Return_Key_Type" : "int",
+ "Elm_Wrap_Type" : "int",
+ "Elm_Autocapital_Type" : "int",
+ "Elm_Text_Format" : "int",
+ "Elm_Object_Select_Mode" : "int",
+ "Elm_List_Mode" : "int",
"Eo_Callback_Priority": "short"}
@@ -114,7 +187,7 @@ class Cparser(object):
#event_desc structure
# { EV_CLICKED, EV_BUTTON_DOWN, EV_BUTTON_UP, NULL }
#
- reg = "Eo_Event_Description[ *]*([a-zA-Z0-9_]*)[][ =]*{([^}]*)};"
+ reg = "Eo_Event_Description[ *]*([\w]*)[][ =]*{([^}]*)};"
af = _in_data.replace("\n", "")
ev_list = re.findall(reg, af)
@@ -130,20 +203,21 @@ class Cparser(object):
# fetching
# op description
#
- reg = "Eo_Op_Description[ ]*([a-zA-Z0-9_]*)\[\][ =]*{([^}]*)};"
+ reg = "Eo_Op_Description[ ]*([\w]*)\[\][ =]*{([^}]*)};"
all_op_descs = re.findall(reg, af)
op_desc = {"NULL" : []}
for tup in all_op_descs:
s_tmp = tup[1]
# fetching op_ids and descriptions
- reg = "EO_OP_DESCRIPTION[^\)]*\([ ]*([A-Z_]*)[ ]*,[ ]*\"([^\"]*)\"[ ]*\),"
+ reg = "EO_OP_DESCRIPTION[^\)]*\([ ]*([A-Z0-9_]*)[ ]*,[ ]*\"([^\"]*)\"[ ]*\),"
ids_and_descs = re.findall(reg, s_tmp)
op_list = []
for t in ids_and_descs:
op_id = t[0] #op_id
func_name = re.findall("SUB_ID_(.*)", op_id)
- op_list.append((op_id, func_name[0].lower()))
+ func_name = func_name[0].lower()
+ op_list.append((op_id, func_name))
op_desc[tup[0]] = op_list
@@ -161,7 +235,7 @@ class Cparser(object):
#[7] NULL
# }
#
- reg = "Eo_Class_Description[ ]*([a-zA-Z0-9_]*)[ =]*{([^}]*)};"
+ reg = "Eo_Class_Description[ ]*([\w]*)[ =]*{([^}]*)};"
desc_list = re.findall(reg, af)
for tup in desc_list:
@@ -189,7 +263,6 @@ class Cparser(object):
name = ll[0]
name = name.strip("\"")
-# l_tmp = tup[1].split(",")
class_desc[key] = [name, cl_type, desc_ops, ev_desc[ev_desc_var]]
#mapping class_desc_var_name to content
@@ -238,12 +311,7 @@ class Cparser(object):
for tup in class_desc_ops[1]:
self.cl_data[cl_id][const.FUNCS][tup[1]] = {const.OP_ID : tup[0], const.C_MACRO: ""}
- s = class_desc_ops[0]
- if s == "NULL" and cl_name == "Eo Base":
-#FIXME: hardcoded EO_BASE_BASE_ID
- print cl_name, "Warning: hardcoded EO_BASE_BASE_ID"
- s = "EO_BASE_BASE_ID"
- self.cl_data[cl_id][const.BASE_ID] = s
+ self.cl_data[cl_id][const.BASE_ID] = class_desc_ops[0]
# resolving parameters's types and names according to
@@ -256,37 +324,46 @@ class Cparser(object):
op_desc = self.cl_data[cl_id][const.OP_DESC]
defines = self.cl_data[cl_id][const.DEFINES]
macros = self.cl_data[cl_id][const.OP_MACROS]
+ b_id = self.cl_data[cl_id][const.BASE_ID]
+ b_id_macro = ""
+ for d in defines:
+ o = re.match("#define ([\w]*)\(([^\)]*)\) \(%s[\W]*\\2[\W]*\)"%(b_id), d)
+ if o != None:
+ b_id_macro = o.group(1)
#looking for op_id in define; if found, cutting op_macro from define
#and checking if it is in macros list. If not - we forgot to add comment
#if yes - cutting types from define
for op, f in op_desc:
+ found = False
for d in defines:
- pos = d.find(op)
- if pos != -1 and d[pos : d.find(")", pos)] == op:
- s_tmp = d[d.find(' ') + 1:]
- s_tmp = s_tmp.replace(" ", "")
- s_tmp = s_tmp.split('(')[0]
+ # looking for #define elm_obj_flip_get ELM_OBJ_FLIP_ID(ELM_OBJ_FLIP_SUB_ID_GET)
+ o = re.match("#define ([\w]*)\([^\)]*\) %s\(%s\).*"%(b_id_macro, op), d)
+ if o != None:
+ found = True
+ s_tmp = o.group(1)
+
if s_tmp not in macros:
print "Warning: no comments for \"%s\"; file: \"%s\" "%(s_tmp, self.cl_data[cl_id][const.H_FILE])
else:
params = []
- params_direction = macros[s_tmp]
+ params_direction = macros[s_tmp]
reg = "%s\(([^,]*),([^,]*)\)"%const.EO_TYPECHECK
ss = re.findall(reg, d)
i = 0
for tup in ss:
lst = list(tup)
+ modifier = "const" if lst[0].find("const") != -1 else ""
lst[0] = lst[0].replace("const", "")
lst[0] = " ".join(lst[0].split())
lst[0] = lst[0].replace(" *", "*")
lst[1] = lst[1].replace(" ", "")
if len(lst) == 2:
try:
- tok = ",".join(list(params_direction[i]))
- params.append((lst[1], lst[0], tok))
+ tok = params_direction[i]
+ params.append((lst[1], modifier, lst[0], tok))
except IndexError:
print "Warning: error in description %s in %s"%(s_tmp,self.cl_data[cl_id][const.H_FILE])
@@ -294,22 +371,26 @@ class Cparser(object):
print "ERROR: check parameters in EO_TYPECHECK"
exit(1)
i += 1
-
self.cl_data[cl_id][const.FUNCS][f][const.PARAMETERS] = params
self.cl_data[cl_id][const.FUNCS][f][const.C_MACRO] = s_tmp
+
+ if not found:
+ print "Warning: no API for %s in %s"%(op, self.cl_data[cl_id][const.H_FILE])
+ print "Function won't be added"
+ self.cl_data[cl_id][const.FUNCS].pop(f)
+
#generating XML
def build_xml(self, cl_id):
- #FIXME: because i don't parse several EO_DEFINE_CLASS in file
- #if const.C_NAME not in self.cl_data[cl_id]:
- # return
self.cl_data[cl_id][const.XML_FILE] = os.path.join(self.outdir, normalize_names([self.cl_data[cl_id][const.C_NAME]])[0] + ".xml")
cl_data = self.cl_data[cl_id]
module = Element(const.MODULE)
module.set(const.NAME, cl_data[const.C_NAME])
+
+ SubElement(module, const.PARSE_VERSION, {const.NUM : const.VER_NUM} )
SubElement(module, const.INCLUDE, {const.NAME: os.path.split(cl_data[const.H_FILE])[1]})
cl_parent = ""
@@ -355,16 +436,19 @@ class Cparser(object):
for k in cl_data[const.FUNCS]:
SubElement(op_tag, const.XML_SUB_ID, {const.NAME:cl_data[const.FUNCS][k][const.OP_ID]})
+ c_macro = cl_data[const.FUNCS][k][const.C_MACRO]
+ #if generating XML not for base class, change func name to avoid name clash
+ func_name = k if cl_id == "EO_BASE_CLASS" else c_macro
- m = SubElement(m_tag, const.METHOD, {const.NAME : k,
+ m = SubElement(m_tag, const.METHOD, {const.NAME : func_name,
const.OP_ID:cl_data[const.FUNCS][k][const.OP_ID],
- const.C_MACRO:cl_data[const.FUNCS][k][const.C_MACRO]})
+ const.C_MACRO:c_macro})
#defining parameter type
if const.PARAMETERS in cl_data[const.FUNCS][k]:
params = cl_data[const.FUNCS][k][const.PARAMETERS]
- for v, t, d in params:
- p = SubElement(m, const.PARAMETER, {const.NAME:v, const.C_TYPENAME:t, const.PRIMARY_TYPE : self.typedef_resolve(t),const.DIRECTION:d})
+ for v_name, modifier, t, d in params:
+ p = SubElement(m, const.PARAMETER, {const.NAME:v_name, const.MODIFIER:modifier, const.C_TYPENAME:t, const.PRIMARY_TYPE : self.typedef_resolve(t),const.DIRECTION:d})
if const.EV_DESC in cl_data:
@@ -383,6 +467,15 @@ class Cparser(object):
f.write(res)
f.close()
+ def get_param_dir_from_comment(self, com):
+ res = re.findall("@param.*", com)
+ l_tmp = []
+ for s in res:
+ s = s.replace(" ", "")
+ ret = re.match("@param\[([inout,]*)\]", s)
+ l_tmp.append(ret.group(1) if (ret != None and ret.group(1) in ["in", "out", "in,out"]) else "in,out");
+ return l_tmp
+
#parsing header file
def h_file_data_get(self, filename):
f = open (filename, 'r')
@@ -391,71 +484,28 @@ class Cparser(object):
#fetch all "#define" from file
matcher = re.compile(r"^[ \t]*(#define(.*\\\n)*.*$)",re.MULTILINE)
- ss = matcher.findall(allfile, re.MULTILINE)
- d_list = []
+ ss = matcher.findall(allfile)
+ def_list = []
for tup in ss:
s_tmp = tup[0].replace("\n", "").replace("\\", "")
s_tmp = " ".join(s_tmp.split())
- d_list.append(s_tmp)
-
- def_list = d_list
+ def_list.append(s_tmp)
- """
#fetch all "@def" from file
- #matcher = re.compile(r"^/\*\*( \*.*\n)*.*\*/$",re.MULTILINE)
- matcher = re.compile("(^/\*\*\n( \*.*\n)*.* \*/$)",re.MULTILINE)
- ss = matcher.findall(allfile, re.MULTILINE)
- for s in ss:
- print "s====================", s[0]
- """
-
- #fetch all data from "@def" comments
+ matcher = re.compile("(^/\*\*\n(((.(?!\*/))*\n)*).*\*/$)",re.MULTILINE)
+ all_comments_list = matcher.findall(allfile)
macro = {}
- pos = allfile.find("@def")
- while pos != -1:
- pos_start = pos
- pos_end = allfile.find("*/", pos_start)
- if pos_end != -1:
- tmp = allfile[pos_start : pos_end]
- #tmp = tmp.replace("\n", "") #deleting next string
- tmp = tmp.replace("*", "") #removing *
- lst = tmp.split("\n")
-
- lst = filter(macro_filter_func, lst)
-
- for i in range(len(lst)):
- lst[i] = " ".join(lst[i].split()) #removing more than one spaces
-
- macro_name = lst[0]
- par_lst = []
- macro_name = macro_name.split("(")[0]
-
- macro_name = macro_name[macro_name.find(" ")+1:].strip(" ")
- for l in lst:
- if l.startswith("@param"):
- s = ""
- s1 = re.match("@param\[(in|out|in,out)\]", l)
- if s1:
- s = s1.group(1)
- s = s.replace(" ", "")
- s_tmp = []
- if s != "":
- s = s.split(",")
- if "in" in s:
- s_tmp.append("in")
- if "out" in s:
- s_tmp.append("out")
- else:
- s_tmp.append("in")
- s_tmp.append("out")
- t = tuple(s_tmp)
- if len(t) == 0:
- print "ERROR: check parameter's description in #define %s"%(macro_name)
- exit(1)
- par_lst.append(t)
- macro[macro_name] = par_lst
-
- pos = allfile.find("@def", pos_end)
+ for comment in all_comments_list:
+ comment_tmp = comment[1]
+
+ #looking for @def token in comment
+ res = re.search("@def[ ]+([\w]*)", comment_tmp)
+ if res == None:
+ continue
+
+ macro_name = res.group(1)
+ #looking for parameters direction in comment
+ macro[macro_name] = self.get_param_dir_from_comment(comment_tmp)
#looking for class_get function to get class macro
current_class = ""
@@ -465,10 +515,10 @@ class Cparser(object):
for k in self.cl_data:
pos = 0
get_func = ""
-
+
for d in def_list:
# looking for #define SOME_CLASS some_class_get()
- reg = '#define[ ]*[a-zA-Z_]*[ ]*%s\(\)'%k
+ reg = '#define[ ]*[\w]*[ ]*%s\(\)'%k
res = re.findall(reg, d)
if re.match(reg, d):
lst = d.split()
diff --git a/eoparser/data/types.xml b/eoparser/data/types.xml
new file mode 100644
index 0000000..3336bd8
--- /dev/null
+++ b/eoparser/data/types.xml
@@ -0,0 +1,82 @@
+<?xml version="1.0" ?>
+<types>
+ <type from="Evas_Object" to="Eo"/>
+ <type from="Evas_Coord" to="int"/>
+ <type from="Evas_Angle" to="int"/>
+ <type from="Evas_Font_Size" to="int"/>
+ <type from="Evas_Bool" to="bool"/>
+ <type from="Eo_Callback_Priority" to="short"/>
+ <type from="Evas_Smart" to="Eo"/>
+ <type from="Evas_Map" to="Eo"/>
+ <type from="Evas_Text_Style_Type" to="int"/>
+ <type from="Evas_Colorspace" to="int"/>
+ <type from="Evas_Render_Op" to="int"/>
+ <type from="Evas_Aspect_Control" to="int"/>
+ <type from="Evas_Object_Ponter_Mode" to="int"/>
+ <type from="Evas_Image_Scale_Hint" to="int"/>
+ <type from="Evas_Image_Content_Hint" to="int"/>
+ <type from="Evas_Image_Animated_Loop_Hint" to="int"/>
+ <type from="Evas_Border_Fill_Mode" to="int"/>
+ <type from="Evas_Object_Table_Homogeneous_Mode" to="int"/>
+ <type from="Evas_Textgrid_Font_Style" to="int"/>
+ <type from="Evas_Textgrid_Palette" to="int"/>
+ <type from="Evas_Modifier_Mask" to="unsigned long long"/>
+ <type from="Evas_Button_Flags" to="int"/>
+ <type from="Evas_Fill_Spread" to="int"/>
+ <type from="Evas_Event_Flags" to="int"/>
+ <type from="Evas_Font_Hinting_Flags" to="int"/>
+ <type from="Evas_Load_Error" to="int"/>
+ <type from="Elm_Photocam_Zoom_Mode" to="int"/>
+ <type from="Elm_Bg_Option" to="int"/>
+ <type from="Elm_Fileselector_Mode" to="int"/>
+ <type from="Elm_Object_Select_Mode" to="int"/>
+ <type from="Elm_Actionslider_Pos" to="int"/>
+ <type from="Elm_Web_Zoom_Mode" to="int"/>
+ <type from="Elm_Icon_Type" to="int"/>
+ <type from="Elm_Colorselector_Mode" to="int"/>
+ <type from="Elm_List_Mode" to="int"/>
+ <type from="Elm_Image_Orient" to="int"/>
+ <type from="Elm_Map_Route_Type" to="int"/>
+ <type from="Elm_Map_Zoom_Mode" to="int"/>
+ <type from="Elm_Map_Source_Type" to="int"/>
+ <type from="Elm_Clock_Edit_Mode" to="int"/>
+ <type from="Elm_Dayselector_Day" to="int"/>
+ <type from="Elm_Thumb_Animation_Setting" to="int"/>
+ <type from="Elm_Win_Keyboard_Mode" to="int"/>
+ <type from="Elm_Toolbar_Shrink_Mode" to="int"/>
+ <type from="Elm_Icon_Lookup_Order" to="int"/>
+ <type from="Elm_Datetime_Field_Type" to="int"/>
+ <type from="Elm_Gesture_Type" to="int"/>
+ <type from="Evas_BiDi_Direction" to="int"/>
+ <type from="Elm_Bubble_Pos" to="int"/>
+ <type from="Ecore_X_Window" to="unsigned int"/>
+
+ <type from="Elm_Flip_Interaction" to="int"/>
+ <type from="Elm_Flip_Direction" to="int"/>
+ <type from="Elm_Flip_Interaction" to="int"/>
+ <type from="Elm_Flip_Mode" to="int"/>
+ <type from="Elm_Calendar_Weekday" to="int"/>
+ <type from="Elm_Calendar_Selectable" to="int"/>
+ <type from="Elm_Calendar_Weekday" to="int"/>
+ <type from="Elm_Calendar_Select_Mode" to="int"/>
+ <type from="Elm_Illume_Command" to="int"/>
+ <type from="Elm_Win_Keyboard_Mode" to="int"/>
+ <type from="Elm_Win_Indicator_Opacity_Mode" to="int"/>
+ <type from="Elm_Win_Indicator_Mode" to="int"/>
+ <type from="Ecore_Wl_Window" to="int"/>
+ <type from="Elm_GLView_Render_Policy" to="int"/>
+ <type from="Elm_GLView_Mode" to="int"/>
+ <type from="Elm_Panel_Orient" to="int"/>
+ <type from="Elm_Popup_Orient" to="int"/>
+ <type from="Elm_Wrap_Type" to="int"/>
+ <type from="Elm_Cnp_Mode" to="int"/>
+ <type from="Elm_Input_Panel_Lang" to="int"/>
+ <type from="Elm_Text_Format" to="int"/>
+ <type from="Elm_Input_Panel_Return_Key_Type" to="int"/>
+ <type from="Elm_Wrap_Type" to="int"/>
+ <type from="Elm_Autocapital_Type" to="int"/>
+ <type from="Elm_Text_Format" to="int"/>
+ <type from="Elm_Object_Select_Mode" to="int"/>
+ <type from="Elm_List_Mode" to="int"/>
+
+</types>
diff --git a/eo_parser/helper.py b/eoparser/helper.py
index 5e0acdc..18cf703 100644
--- a/eo_parser/helper.py
+++ b/eoparser/helper.py
@@ -13,10 +13,15 @@ class _const:
# most of constants are used as internal dict keys,
# but some of them are also used as tags in XML
# Changing this constans will only spoil the view of XML
+ self.PREFIX = "eorepo" #used as xml-tag
self.NAME = "name" #used as xml-tag
self.C_NAME = "c_name" #used as xml-tag
+ self.MODIFIER = "modifier" #used as xml-tag
self.MODULE = "module" #used as xml-tag
+ self.PARSE_VERSION = "parse_version" #used as xml-tag
+ self.NUM = "num" #used as xml-tag
+ self.VER_NUM = "1.0.1"
self.TYPE = "type" #used as xml-tag
self.CLASS_CONSTRUCTOR = "class_constructor"
self.BASE_ID = "base_id"
@@ -69,31 +74,30 @@ class _const:
self.DIRECTION = "direction" #used as xml-tag
-def isC(s):
+def isC(_path):
#FIXME when parsing eobase we can catch "eo.c" with EO_DEFINE_CLASS
- path_lst = s.split('.')
- if len(path_lst) == 2:
- if path_lst[1] in ["c", "cc", "cpp"]:
- return True
- else:
- return False
-
-
-def isH(s):
- path_lst = s.split('.')
- if len(path_lst) == 2:
- if path_lst[1] in ["h"]:
- return True
- else:
- return False
-
-def isXML(s):
- path_lst = s.split('.')
- if len(path_lst) == 2:
- if path_lst[1] in ["xml"]:
- return True
- else:
- return False
+ (d, f) = os.path.split(_path)
+ f_name = f.split('.')
+ if len(f_name) == 2:
+ return True if f_name[1] in ["c", "cc", "cpp"] else False
+ else:
+ return False
+
+def isH(_path):
+ (d, f) = os.path.split(_path)
+ f_name = f.split('.')
+ if len(f_name) == 2:
+ return True if f_name[1] in ["h"] else False
+ else:
+ return False
+
+def isXML(_path):
+ (d, f) = os.path.split(_path)
+ f_name = f.split('.')
+ if len(f_name) == 2:
+ return True if f_name[1] in ["xml"] else False
+ else:
+ return False
# dir_files_get(_directories, func, recursive)
#
@@ -148,6 +152,8 @@ def abs_path_get(_paths, _warning = True):
if _warning:
print "ERROR: path %s doesn't exist... Aborting..."%path_tmp
exit(1)
+ else:
+ print "Warning: path %s doesn't exist..."%path_tmp
return res
diff --git a/eo_parser/XMLparser.py b/eoparser/xmlparser.py
index 85b2663..d3a197f 100644
--- a/eo_parser/XMLparser.py
+++ b/eoparser/xmlparser.py
@@ -1,7 +1,7 @@
import xml.parsers.expat, os, shutil
-from eo_parser.helper import isXML, abs_path_get, dir_files_get
+from eoparser.helper import isXML, abs_path_get, dir_files_get
from helper import normalize_names, _const
-import copy
+import copy, sys
const = _const()
@@ -17,7 +17,6 @@ def O_TYPE_CHECK(o, class_type):
def class_name_get(_o):
return _o.__class__.__name__
-
#Wrapping class to pass Visitor object and call for visit function
class VAcceptor(object):
def accept(self, v):
@@ -28,9 +27,8 @@ class VAcceptor(object):
#Class to save data about each function
#This is one item from Mod.functions list
class Func(VAcceptor):
- def __init__(self, _name, _prop_name,_op_id, _c_macro, _parameters, _prop_type, _cl_obj):
+ def __init__(self, _name, _op_id, _c_macro, _parameters, _prop_type, _cl_obj):
self.name = _name
- self.prop_name = _prop_name
self.op_id = _op_id
self.c_macro = _c_macro
self.parameters = _parameters
@@ -72,6 +70,8 @@ class Mod(object):
self.sub_id_function = ""
self.source_file = ""
self.parents = []
+ self.path = ""
+ self.objects_incl = {}
self.V = None
# dictionary to save all object which have to be visited: Func, Ev, Init
@@ -82,8 +82,6 @@ class Mod(object):
o.accept(self.V)
-
-
# Visitor Design Pattern
# Visitor - base class for different visitors.
# visit function implements dispatching depending on class name of object
@@ -97,7 +95,6 @@ class Visitor(object):
else:
print "%s is not callable attribute"%(method_name)
-
def cast(self, _in):
t = _in
@@ -113,9 +110,10 @@ class Visitor(object):
"char**" : "char*"}
internal_types = {
- "void*": ["void*", "object"],
+ # orig_type: ["how c obj will be defined and ho to cast to cobj", "how in Py objj will be defined"]
+ "void*": ["void*", "object"], #FIXME "ToObject?"
"char*": ["char*", "object", "ToString"],
- "Eo*": ["Eo*", "EoDefault", "ToObject"],
+ "Eo*": ["Eo*", "EoDefault", "ToEo"], #ToEo
"short" : ["int", "int", "ToInt32"],
"short*" : ["int", "int", "ToInt32"],
"int": ["int", "int", "ToInt32"],
@@ -130,15 +128,17 @@ class Visitor(object):
"bool*" : ["unsigned char","int", "ToBoolean"],
"unsigned int": ["unsigned int", "unsigned int", "ToUint32"],
"unsigned int*": ["unsigned int", "unsigned int", "ToUint32"],
+ "unsigned short": ["unsigned int", "unsigned int", "ToUint32"],
+ "unsigned short*": ["unsigned int", "unsigned int", "ToUint32"],
"unsigned long": ["unsigned long", "unsigned long", "ToUint32"],
"unsigned long*": ["unsigned long", "unsigned long", "ToNumber"],
"unsigned long long": ["unsigned long long", "unsigned long long", "ToNumber"],
"unsigned long long*": ["unsigned long long", "unsigned long long", "ToNumber"],
"float": ["float", "float", "ToNumber"],
- "double": ["double", "double", "ToNumber" ],
- "long double": ["long double", "long double", "ToNumber"],
"float*": ["float", "float", "ToNumber"],
+ "double": ["double", "double", "ToNumber" ],
"double*": ["double", "double", "ToNumber" ],
+ "long double": ["long double", "long double", "ToNumber"],
"long double*": ["long double", "long double", "ToNumber"],
"Eo_Event_Description*":["long","long", "ToNumber"],
"Eo_Event_Cb":["Eo_Event_Cb","object", "ToNumber"]
@@ -149,12 +149,11 @@ class Abstract(object):
def __init__(self):
pass
-
-
class JsVisitor(Visitor):
def __init__(self):
self.visited_properties = []
+ self.func_name_prefix = "__"
self.c_file = Abstract()
self.c_file.name = ""
@@ -180,13 +179,15 @@ class JsVisitor(Visitor):
self.class_info.public = []
- self.js_types = { "ToBoolean" : "Boolean",
- "ToString" : "String",
- "ToUint32" : "Number",
- "ToInt32" : "Number",
- "ToNumber" : "Number",
- "ToObject" : "Local <Object>"
- }
+ self.c_to_js_constr = { "ToBoolean" : "Boolean",
+ "ToString" : "String",
+ "ToUint32" : "Number",
+ "ToInt32" : "Number",
+ "ToNumber" : "Number",
+# "ToObject" : "Local <Object>",
+ "ToVoid" : "VOID",
+ "ToEo" : "#error"
+ }
#Func visit function, to generate code for functions
def visit_Func(self, _o):
@@ -200,11 +201,11 @@ class JsVisitor(Visitor):
self.visited_properties.append(prop_name)
self.c_file.cb_generate_macros.append("EO_GENERATE_PROPERTY_SET_CALLBACK(%s, %s);\n"%(_o.cl_obj.kl_id, prop_name))
self.c_file.cb_generate_macros.append("EO_GENERATE_PROPERTY_GET_CALLBACK(%s, %s);\n"%(_o.cl_obj.kl_id, prop_name))
- self.class_info.public.append(" Handle<Value> %s_get() const;\n"%(prop_name))
- self.class_info.public.append(" void %s_set(Handle<Value> val);\n"%(prop_name))
+ self.class_info.public.append(" Handle<Value> %s%s_get() const;\n"%(self.func_name_prefix, prop_name))
+ self.class_info.public.append(" void %s%s_set(Handle<Value> _val);\n"%(self.func_name_prefix, prop_name))
self.h_file.prop_cb_headers.append(" Handle<Value> Callback_%s_get(Local<String>, const AccessorInfo &info);\n"%(prop_name))
- self.h_file.prop_cb_headers.append(" void Callback_%s_set(Local<String>, Local<Value> val, const AccessorInfo &info);\n"%(prop_name))
+ self.h_file.prop_cb_headers.append(" void Callback_%s_set(Local<String>, Local<Value> _val, const AccessorInfo &info);\n"%(prop_name))
self.c_file.tmpl.append(" PROPERTY(%s)"% prop_name)
@@ -212,27 +213,27 @@ class JsVisitor(Visitor):
self.visit_prop_set_get(_o)
prop_name = _o.name[:-4]
self.c_file.cb_generate_macros.append("EO_GENERATE_PROPERTY_SET_CALLBACK(%s, %s);\n"%(_o.cl_obj.kl_id, prop_name))
- self.c_file.cb_generate_macros.append("EO_GENERATE_PROPERTY_GET_EMPTY_CALLBACK(%s, %s);\n"%(_o.cl_obj.kl_id, prop_name))
+ #self.c_file.cb_generate_macros.append("EO_GENERATE_PROPERTY_GET_EMPTY_CALLBACK(%s, %s);\n"%(_o.cl_obj.kl_id, prop_name))
- self.class_info.public.append(" Handle<Value> %s_get() const;\n"%(prop_name))
- self.class_info.public.append(" void %s_set(Handle<Value> val);\n"%(prop_name))
+ #self.class_info.public.append(" Handle<Value> %s%s_get() const;\n"%(self.func_name_prefix, prop_name))
+ self.class_info.public.append(" void %s%s_set(Handle<Value> _val);\n"%(self.func_name_prefix, prop_name))
- self.c_file.tmpl.append(" PROPERTY(%s)"% prop_name)
- self.h_file.prop_cb_headers.append(" Handle<Value> Callback_%s_get(Local<String>, const AccessorInfo &info);\n"%(prop_name))
- self.h_file.prop_cb_headers.append(" void Callback_%s_set(Local<String>, Local<Value> val, const AccessorInfo &info);\n"%(prop_name))
+ self.c_file.tmpl.append(" PROPERTY_SO(%s)"% prop_name)
+ #self.h_file.prop_cb_headers.append(" Handle<Value> Callback_%s_get(Local<String>, const AccessorInfo &info);\n"%(prop_name))
+ self.h_file.prop_cb_headers.append(" void Callback_%s_set(Local<String>, Local<Value> _val, const AccessorInfo &info);\n"%(prop_name))
elif _o.prop_type == const.GET_ONLY:
self.visit_prop_set_get(_o)
prop_name = _o.name[:-4]
self.c_file.cb_generate_macros.append("EO_GENERATE_PROPERTY_GET_CALLBACK(%s, %s);\n"%(_o.cl_obj.kl_id, prop_name))
- self.c_file.cb_generate_macros.append("EO_GENERATE_PROPERTY_SET_EMPTY_CALLBACK(%s, %s);\n"%(_o.cl_obj.kl_id, prop_name))
+ #self.c_file.cb_generate_macros.append("EO_GENERATE_PROPERTY_SET_EMPTY_CALLBACK(%s, %s);\n"%(_o.cl_obj.kl_id, prop_name))
- self.class_info.public.append(" Handle<Value> %s_get() const;\n"%(prop_name))
- self.class_info.public.append(" void %s_set(Handle<Value> val);\n"%(prop_name))
+ self.class_info.public.append(" Handle<Value> %s%s_get() const;\n"%(self.func_name_prefix, prop_name))
+ #self.class_info.public.append(" void %s%s_set(Handle<Value> _val);\n"%(self.func_name_prefix, prop_name))
- self.c_file.tmpl.append(" PROPERTY(%s)"% prop_name)
+ self.c_file.tmpl.append(" PROPERTY_RO(%s)"% prop_name)
self.h_file.prop_cb_headers.append(" Handle<Value> Callback_%s_get(Local<String>, const AccessorInfo &info);\n"%(prop_name))
- self.h_file.prop_cb_headers.append(" void Callback_%s_set(Local<String>, Local<Value> val, const AccessorInfo &info);\n"%(prop_name))
+ #self.h_file.prop_cb_headers.append(" void Callback_%s_set(Local<String>, Local<Value> _val, const AccessorInfo &info);\n"%(prop_name))
elif _o.prop_type == const.METHOD:
self.visit_method(_o)
@@ -251,16 +252,16 @@ class JsVisitor(Visitor):
self.class_info.public.append("\n")
- self.class_info.public.append(" Handle<Value> %s_get() const;\n"%(ev))
- self.class_info.public.append(" void %s_set(Handle<Value> val);\n"%(ev))
- self.class_info.public.append(" void %s(void *event_info);\n"%(ev))
- self.class_info.public.append(" static Eina_Bool %s_wrapper(void *data, Eo *obj, const Eo_Event_Description *desc, void *event_info);\n"%(ev))
+ self.class_info.public.append(" Handle<Value> %s%s_get() const;\n"%(self.func_name_prefix, ev))
+ self.class_info.public.append(" void %s%s_set(Handle<Value> _val);\n"%(self.func_name_prefix,ev))
+ self.class_info.public.append(" void %s%s(void *event_info);\n"%(self.func_name_prefix,ev))
+ self.class_info.public.append(" static Eina_Bool %s%s_wrapper(void *data, Eo *obj, const Eo_Event_Description *desc, void *event_info);\n"%(self.func_name_prefix,ev))
self.h_file.ev_cb_headers.append(" Handle<Value> Callback_%s_get(Local<String>, const AccessorInfo &info);\n"%(ev))
- self.h_file.ev_cb_headers.append(" void Callback_%s_set(Local<String>, Local<Value> val, const AccessorInfo &info);\n"%(ev))
+ self.h_file.ev_cb_headers.append(" void Callback_%s_set(Local<String>, Local<Value> _val, const AccessorInfo &info);\n"%(ev))
#event function
- self.c_file.functions.append("void %s::%s(void *event_info) //parse of event_info need to be added \n"%(_o.cl_obj.kl_id, ev))
+ self.c_file.functions.append("void %s::%s%s(void *event_info) //parse of event_info need to be added \n"%(_o.cl_obj.kl_id, self.func_name_prefix, ev))
self.c_file.functions.append("{\n")
self.c_file.functions.append(" Handle<Function> callback(Function::Cast(*cb.%s));\n"%ev_prefix)
self.c_file.functions.append(" Handle<Value> args[1] = {jsObject};\n")
@@ -269,41 +270,39 @@ class JsVisitor(Visitor):
self.c_file.functions.append("\n")
#event function wrapper
- self.c_file.functions.append("Eina_Bool %s::%s_wrapper(void *data, Eo *obj, const Eo_Event_Description *desc, void *event_info)\n"%(_o.cl_obj.kl_id, ev))
+ self.c_file.functions.append("Eina_Bool %s::%s%s_wrapper(void *data, Eo *obj, const Eo_Event_Description *desc, void *event_info)\n"%(_o.cl_obj.kl_id, self.func_name_prefix, ev))
self.c_file.functions.append("{\n\
HandleScope scope;\n\
- static_cast<%s*>(data)->%s(event_info);\n\
+ dynamic_cast<%s*>(static_cast<CElmObject*>(data))->%s%s(event_info);\n\
return EINA_TRUE;\n\
(void) obj;\n\
(void) desc;\n\
- }\n"%(_o.cl_obj.kl_id, ev))
+ }\n"%(_o.cl_obj.kl_id, self.func_name_prefix, ev))
self.c_file.functions.append("\n")
#event function get
- self.c_file.functions.append("Handle<Value> %s::%s_get() const\n"%(_o.cl_obj.kl_id, ev))
+ self.c_file.functions.append("Handle<Value> %s::%s%s_get() const\n"%(_o.cl_obj.kl_id, self.func_name_prefix, ev))
self.c_file.functions.append("{\n\
return cb.%s;\n\
}\n"%ev_prefix)
self.c_file.functions.append("\n")
#event function set
- self.c_file.functions.append("void %s::%s_set(Handle<Value> val)\n"%(_o.cl_obj.kl_id, ev))
+ self.c_file.functions.append("void %s::%s%s_set(Handle<Value> _val)\n"%(_o.cl_obj.kl_id, self.func_name_prefix, ev))
self.c_file.functions.append("{\n")
- self.c_file.functions.append(" if (!val->IsFunction())\n\
+ self.c_file.functions.append(" if (!_val->IsFunction())\n\
return;\n")
self.c_file.functions.append(" if (!cb.%s.IsEmpty())\n\
{\n\
cb.%s.Dispose();\n\
cb.%s.Clear();\n\
- eo_do(eobj, eo_event_callback_del(%s, %s_wrapper, this));\n\
- }\n"%(ev_prefix, ev_prefix, ev_prefix, _o.ev_id, ev))
- self.c_file.functions.append(" cb.%s = Persistent<Value>::New(val);\n\
- eo_do(eobj, eo_event_callback_add(%s, %s_wrapper, this));\n"%(ev_prefix, _o.ev_id, ev))
+ eo_do(eobj, eo_event_callback_del(%s, %s%s_wrapper, dynamic_cast<CElmObject*>(this)));\n\
+ }\n"%(ev_prefix, ev_prefix, ev_prefix, _o.ev_id, self.func_name_prefix, ev))
+ self.c_file.functions.append(" cb.%s = Persistent<Value>::New(_val);\n\
+ eo_do(eobj, eo_event_callback_add(%s, %s%s_wrapper, dynamic_cast<CElmObject*>(this)));\n"%(ev_prefix, _o.ev_id, self.func_name_prefix, ev))
self.c_file.functions.append("}\n")
self.c_file.functions.append("\n")
-
-
#is called by visit_Func to parse function as a property
def visit_prop_set_get(self, _o):
@@ -313,12 +312,12 @@ class JsVisitor(Visitor):
direction = "out" if prop_type == "_get" else "in"
params_tmp = []
- add_this_func = True
- for i, (n, c_t, d, p_t) in enumerate(_o.parameters):
+ add_this_func_with_error = False
+ for i, (n, modifier, c_t, d, p_t) in enumerate(_o.parameters):
if d != direction:
- print "Warning wrong direction: property: %s; parameter: %s; direction: %s"%(prop_name + "_get", n, d)
- print "Property \"%s\" will not be defined"%(prop_name + "_get")
- add_this_func = False
+ print "Warning wrong direction: class: \"%s\"; property: \"%s\"; parameter: \"%s\"; direction: \"%s\""%(_o.cl_obj.c_name, _o.name, n, d)
+ print "Property \"%s\", from class \"%s\" will be added with message error"%(_o.name, _o.cl_obj.c_name)
+ add_this_func_with_error = True
break
c_t_tmp = self.cast(p_t)
@@ -327,17 +326,24 @@ class JsVisitor(Visitor):
if c_t_tmp in self.internal_types:
c_t_internal = self.internal_types[c_t_tmp][0]
+ if len(self.internal_types[c_t_tmp]) < 3:
+ add_this_func_with_error = True
+ break
js_type = self.internal_types[c_t_tmp][2]
- params_tmp.append((c_t, n, d, c_t_internal, js_type))
+ params_tmp.append((modifier, c_t, n, d, c_t_internal, js_type))
else:
- print "Warning: type: \"%s\" wasn't found in self.internal_types. Funct ion \"%s\" will not be defined"%(c_t_tmp, prop_name + "_get")
- add_this_func = False
+ print "Warning: type: \"%s\" wasn't found in self.internal_types.\n Property \"%s\", from class \"%s\" will be added with error message"%(c_t_tmp, _o.name, _o.cl_obj.c_name)
+ add_this_func_with_error = True
break
- if not add_this_func:
- return
+ if add_this_func_with_error:
+ if prop_type == "_get":
+ self.prop_get_err_generate(_o, params_tmp)
+ elif prop_type == "_set":
+ self.prop_set_err_generate(_o, params_tmp)
- if prop_type == "_get":
+
+ elif prop_type == "_get":
self.prop_get_generate(_o, params_tmp)
elif prop_type == "_set":
@@ -357,31 +363,47 @@ class JsVisitor(Visitor):
#do not need to
self.c_file.cb_generate_macros.append("EO_GENERATE_METHOD_CALLBACKS(%s, %s);\n"%(_o.cl_obj.kl_id, _o.name))
- self.class_info.public.append(" Handle<Value> %s(const Arguments&);\n"%(_o.name))
+ self.class_info.public.append(" Handle<Value> %s%s(const Arguments&);\n"%(self.func_name_prefix, _o.name))
self.c_file.tmpl.append(" METHOD(%s)"% _o.name)
self.h_file.meth_cb_headers.append(" Handle<Value> Callback_%s(const Arguments&);\n"%(_o.name))
+ functions_tmp_save = list(self.c_file.functions)
+ self.c_file.functions.append("/* generated by 'visit method() ' */\n")
- self.c_file.functions.append("Handle<Value> %s::%s(const Arguments& args)\n"%(_o.cl_obj.kl_id, _o.name))
+ self.c_file.functions.append("Handle<Value> %s::%s%s(const Arguments& args)\n"%( _o.cl_obj.kl_id, self.func_name_prefix, _o.name))
self.c_file.functions.append("{\n")
self.c_file.functions.append(" HandleScope scope;\n")
pass_params = []
ret_params = []
in_param_counter = 0
- for i, (n, c_t, d, p_t) in enumerate(_o.parameters):
+
+ add_this_func = True
+ add_end_func = []
+ args_not_used = True
+ for i, (n, modifier, c_t, d, p_t) in enumerate(_o.parameters):
+ args_not_used = False
c_t_tmp = self.cast(p_t)
+ casting = "(%s %s)"%(modifier, c_t)
js_type = ""
c_t_internal = ""
if c_t_tmp in self.internal_types:
c_t_internal = self.internal_types[c_t_tmp][0]
- js_type = self.internal_types[c_t_tmp][2]
+ if len(self.internal_types[c_t_tmp]) < 3:
+ print "Warning: JS TYPE for type: \"%s\" wasn't found in self.internal_types. Function \"%s\" from class \"%s\" will not be defined"%(c_t_tmp, n, _o.cl_obj.c_name)
+ add_this_func = False
+ else:
+ js_type = self.internal_types[c_t_tmp][2]
else:
- print "Warning: type: \"%s\" wasn't found in self.internal_types. Function \"%s\" will not be defined"%(c_t_tmp, m)
- continue
+ print "Warning: type: \"%s\" wasn't found in self.internal_types. Function \"%s\" from class \"%s\" will not be defined"%(c_t_tmp, n, _o.cl_obj.c_name)
+ add_this_func = False
+
+ if not add_this_func:
+ self.c_file.functions = list(functions_tmp_save)
+ return
if d == "in":
self.c_file.functions.append(" Local<Value> _%s = args[%d];\n"%(n, in_param_counter))
@@ -389,21 +411,33 @@ class JsVisitor(Visitor):
self.c_file.functions.append(" %s %s;\n"%(c_t_internal, n))
if js_type == "ToString":
- self.c_file.functions.append(" %s = strdup(*String::Utf8Value(_%s->%s()));\n"%(n, n, js_type))
- elif js_type == "ToObject":
+ self.c_file.functions.append(" %s = strdup(*String::Utf8Value(_%s->%s()));\n"%(n, n, js_type))
+ self.c_file.functions.append(" if (!strcmp(%s, \"null\")) %s = NULL;\n"%(n, n))
+ add_end_func.append(" free(%s);\n"%n)
+ pass_params.append(casting + n)
+ elif js_type == "ToEo":
self.c_file.functions.append(" %s = static_cast<CElmObject*>(_%s->ToObject()->GetPointerFromInternalField(0))->GetEo();\n"%(n, n))
+ pass_params.append(casting + n)
else:
self.c_file.functions.append(" %s = _%s->%s()->Value();\n"%(n, n, js_type))
+
+ if c_t.find("*") != -1:
+ pass_params.append(casting + '&' + n)
+ else:
+ pass_params.append(casting + n)
+ """
if c_t.find(c_t_internal) != -1 and c_t.replace(c_t_internal, "") == "*":
pass_params.append('&' + n)
else:
pass_params.append(n)
+ """
+
elif d == "out":
self.c_file.functions.append(" %s %s;\n"%(c_t_internal, n))
- pass_params.append('&' + n)
+ pass_params.append(casting + '&' + n)
- js_type = self.js_types[js_type]
- ret_params.append((n, js_type))
+ js_constr = self.c_to_js_constr[js_type]
+ ret_params.append((n, js_type, js_constr))
elif d == "in,out":
self.c_file.functions.append(" Local<Value> _%s = args[%d];\n"%(n, in_param_counter))
@@ -411,103 +445,152 @@ class JsVisitor(Visitor):
self.c_file.functions.append(" %s %s;\n"%(c_t_internal, n))
if js_type == "ToString":
- self.c_file.functions.append(" %s = strdup(*String::Utf8Value(_%s->%s()));\n"%(n, n, js_type))
- elif js_type == "ToObject":
+ self.c_file.functions.append(" %s = strdup(*String::Utf8Value(_%s->%s()));\n"%(n, n, js_type))
+ self.c_file.functions.append(" if (!strcmp(%s, \"null\")) %s = NULL;\n"%(n, n))
+ add_end_func.append(" free(%s);\n"%n)
+ elif js_type == "ToEo":
self.c_file.functions.append(" %s = static_cast<CElmObject*>(_%s->ToObject()->GetPointerFromInternalField(0))->GetEo();\n"%(n, n))
else:
self.c_file.functions.append(" %s = _%s->%s()->Value();\n"%(n, n, js_type))
- pass_params.append('&' + n)
- js_type = self.js_types[js_type]
- ret_params.append((n, js_type))
+ pass_params.append(casting + '&' + n)
+ js_constr = self.c_to_js_constr[js_type]
+ ret_params.append((n, js_type, js_constr))
self.c_file.functions.append(" eo_do(eobj, %s(%s));\n"%( _o.c_macro, ", ".join(pass_params)))
if len(ret_params) == 1:
- for par, t in ret_params:
+ args_not_used = False
+ for par, js_type, js_constr in ret_params:
#FIXME: case then we work with EO
- self.c_file.functions.append(" return scope.Close(%s::New(%s));//need to put proper values\n"%(t, par))
+ if js_type in ["ToEo", "ToVoid"]:
+ self.c_file.functions.append(" return Undefined(); //need to fix case when returning object!\n")
+ else:
+ self.c_file.functions += add_end_func
+ add_end_func = []
+ self.c_file.functions.append(" return scope.Close(%s::New(%s));//need to put proper values\n"%(js_constr, par))
elif len(ret_params) > 1:
+ args_not_used = False
self.c_file.functions.append(" Local<Object> obj__ = Object::New();\n")
- for p, t in ret_params:
- self.c_file.functions.append(" obj__->Set(String::NewSymbol(\"%s\"), %s::New(%s));\n"%(p, t, p))
- self.c_file.functions.append(" return scope.Close(obj__); //need to put proper values\n")
+ for par, js_type, js_constr in ret_params:
+ self.c_file.functions.append(" obj__->Set(String::NewSymbol(\"%s\"), %s::New(%s));\n"%(par, js_constr, par))
+ self.c_file.functions += add_end_func
+ add_end_func = []
+ self.c_file.functions.append(" return scope.Close(obj__); //should be right\n")
else:
+ self.c_file.functions += add_end_func
+ add_end_func = []
self.c_file.functions.append(" return Undefined();\n")
+ #if no return params
+
+ if args_not_used:
+ self.c_file.functions.append(" (void)args;\n")
self.c_file.functions.append("}\n")
self.c_file.functions.append("\n")
# is called by prop_set_get_visit, to generate body for property getter
def prop_get_generate(self, _o, params_tmp):
- self.c_file.functions.append("Handle<Value> %s::%s() const\n"%(_o.cl_obj.kl_id, _o.name))
+ self.c_file.functions.append("/* generated by 'prop_get_generate() ' */\n")
+ self.c_file.functions.append("Handle<Value> %s::%s%s() const\n"%(_o.cl_obj.kl_id, self.func_name_prefix, _o.name))
self.c_file.functions.append("{\n")
self.c_file.functions.append(" HandleScope scope;\n")
pass_params = []
ret_params = []
- for (c_t, n, d, c_t_internal, js_type) in params_tmp:
+ for (modifier, c_t, n, d, c_t_internal, js_type) in params_tmp:
+ casting = "(%s %s)"%(modifier, c_t)
self.c_file.functions.append(" %s %s;\n"%(c_t_internal, n))
- pass_params.append('&' + n)
+ pass_params.append(casting + '&' + n)
- js_type = self.js_types[js_type]
- ret_params.append((n, js_type))
+ js_constr = self.c_to_js_constr[js_type]
+ ret_params.append((n, js_type, js_constr))
self.c_file.functions.append(" eo_do(eobj, %s(%s));\n"%(_o.c_macro, ", ".join(pass_params)))
if len(ret_params) == 1:
- for par, t in ret_params:
- self.c_file.functions.append(" return scope.Close(%s::New(%s));//need to put proper val ues\n"%(t, par))
+ for par, js_type, js_constr in ret_params:
+ self.c_file.functions.append("/* %s */\n"%js_type)
+ if js_type in ["ToEo", "ToVoid"]:
+ self.c_file.functions.append(" return Undefined(); //need to fix case when returning object!\n")
+ else:
+ self.c_file.functions.append(" return scope.Close(%s::New(%s));//need to put proper values\n"%(js_constr, par))
elif len(ret_params) > 1:
self.c_file.functions.append(" Local<Object> obj__ = Object::New();\n")
- for par, t in ret_params:
- self.c_file.functions.append(" obj__->Set(String::NewSymbol(\"%s\"), %s::New(%s));\n"% (par, t, par))
+ for par, js_type, js_constr in ret_params:
+ self.c_file.functions.append(" obj__->Set(String::NewSymbol(\"%s\"), %s::New(%s));\n"% (par, js_constr, par))
self.c_file.functions.append(" return scope.Close(obj__);//need to put proper values\n")
else:
self.c_file.functions.append(" return Undefined();\n")
self.c_file.functions.append("}\n\n")
-
# is called by prop_set_get_visit, to generate body for property setter
def prop_set_generate(self, _o, params_tmp):
+ self.c_file.functions.append("/* generated by 'prop_set_generate() ' */\n")
- self.c_file.functions.append("void %s::%s(Handle<Value> val)\n"%(_o.cl_obj.kl_id, _o.name))
+ self.c_file.functions.append("void %s::%s%s(Handle<Value> _val)\n"%(_o.cl_obj.kl_id, self.func_name_prefix, _o.name))
self.c_file.functions.append("{\n")
pass_params = []
add_end_func = []
if len(params_tmp) > 1:
- self.c_file.functions.append(" Local<Object> __o = val->ToObject();\n")
+ self.c_file.functions.append(" Local<Object> __o = _val->ToObject();\n")
- for (c_t, n, d, c_t_internal, js_type) in params_tmp:
+ for (modifier, c_t, n, d, c_t_internal, js_type) in params_tmp:
+ casting = "(%s %s)"%(modifier, c_t)
self.c_file.functions.append(" %s %s;\n"%(c_t_internal, n))
if js_type == "ToString":
self.c_file.functions.append(" %s = strdup(*String::Utf8Value(__o->Get(String::NewSymbol(\"%s\"))->%s()));\n"%(n, n, js_type))
+ self.c_file.functions.append(" if (!strcmp(%s, \"null\")) %s = NULL;\n"%(n, n))
+ add_end_func.append(" free(%s);\n"%n)
+ pass_params.append(casting + n)
+
else:
self.c_file.functions.append(" %s = __o->Get(String::NewSymbol(\"%s\"))->%s()->Value();\n"%(n, n, js_type))
-
+
+ if c_t.find("*") != -1:
+ pass_params.append(casting + '&' + n)
+ else:
+ pass_params.append(casting + n)
+ """
if c_t.find(c_t_internal) != -1 and c_t.replace(c_t_internal, "") == "*":
pass_params.append('&' + n)
else:
pass_params.append(n)
+ """
elif len(params_tmp) == 1:
- for (c_t, n, d, c_t_internal, js_type) in params_tmp:
- self.c_file.functions.append(" %s %s;\n"%(c_t_internal, n))
+ for (modifier, c_t, n, d, c_t_internal, js_type) in params_tmp:
+ casting = "(%s %s)"%(modifier, c_t)
if js_type == "ToString":
- self.c_file.functions.append(" %s = strdup(*String::Utf8Value(val->%s()));\n"%(n, js_type))
- add_end_func.append(" free(%s);"%n)
+ self.c_file.functions.append(" %s %s;\n"%(c_t_internal, n))
+ self.c_file.functions.append(" %s = strdup(*String::Utf8Value(_val->%s()));\n"%(n, js_type))
+ self.c_file.functions.append(" if (!strcmp(%s, \"null\")) %s = NULL;\n"%(n, n))
+ add_end_func.append(" free(%s);\n"%n)
+ pass_params.append(casting + n)
+ elif js_type == "ToEo":
+ self.c_file.functions.append(" %s %s;\n"%(c_t_internal, n))
+ self.c_file.functions.append(" %s = static_cast<CElmObject*>(_val->ToObject()->GetPointerFromInternalField(0))->GetEo();\n"%(n))
+ pass_params.append(casting + n)
else:
- self.c_file.functions.append(" %s = val->%s()->Value();\n"%(n, js_type))
+ self.c_file.functions.append(" %s %s;\n"%(c_t_internal, n))
+ self.c_file.functions.append(" %s = _val->%s()->Value();\n"%(n, js_type))
+
+ if c_t.find("*") != -1:
+ pass_params.append(casting + '&' + n)
+ else:
+ pass_params.append(casting + n)
+ """
if c_t.find(c_t_internal) != -1 and c_t.replace(c_t_internal, "") == "*":
pass_params.append('&' + n)
else:
pass_params.append(n)
+ """
self.c_file.functions.append(" eo_do(eobj, %s(%s));\n"%(_o.c_macro, ", ".join(pass_params)))
self.c_file.functions += add_end_func
@@ -515,7 +598,24 @@ class JsVisitor(Visitor):
self.c_file.functions.append("}\n")
self.c_file.functions.append("\n")
+ # is called by prop_set_get_visit, to generate body for property getter
+ def prop_get_err_generate(self, _o, params_tmp):
+ self.c_file.functions.append("/* generated by 'prop_get_err_generate() ' */\n")
+ self.c_file.functions.append("Handle<Value> %s::%s%s() const\n"%(_o.cl_obj.kl_id, self.func_name_prefix, _o.name))
+ self.c_file.functions.append("{\n")
+ self.c_file.functions.append(" printf(\"%s : This method wasn't implemented becase of type issue\\n\",__func__);\n")
+
+ self.c_file.functions.append(" return Undefined(); //need to fix case when returning object!\n")
+ self.c_file.functions.append("}\n\n")
+ # is called by prop_set_get_visit, to generate body for property setter
+ def prop_set_err_generate(self, _o, params_tmp):
+ self.c_file.functions.append("/* generated by 'prop_set_err_generate() ' */\n")
+ self.c_file.functions.append("void %s::%s%s(Handle<Value> _val)\n"%(_o.cl_obj.kl_id, self.func_name_prefix, _o.name))
+ self.c_file.functions.append("{\n")
+ self.c_file.functions.append(" printf(\"%s : This method wasn't implemented becase of type issue\\n\",__func__);")
+ self.c_file.functions.append("}\n")
+ self.c_file.functions.append("\n")
def visit_Init(self, _o):
@@ -524,7 +624,7 @@ class JsVisitor(Visitor):
self.h_file.name = _o.cl_obj.js_h_file
self.c_file.header.append("/**\n * generated from \"%s\"\n */\n"%(_o.cl_obj.source_file))
- self.c_file.header.append("#include \"%s\"\n"%(os.path.split(_o.cl_obj.js_h_file)[1] ))
+ self.c_file.header.append("#include \"%s\"\n"%_o.cl_obj.js_h_file)
self.c_file.header.append("namespace elm {\n\n")
self.c_file.header.append("using namespace v8;\n\n")
@@ -547,7 +647,6 @@ class JsVisitor(Visitor):
inherit = ", ".join(lst)
self.class_info.header ="class %s : %s\n"%(_o.cl_obj.kl_id, inherit)
-
if _o.cl_obj.eo_type == const.CLASS_TYPE_REGULAR:
self.class_info.private.append(" static Persistent<FunctionTemplate> tmpl;\n")
self.class_info.private.append("\n")
@@ -555,7 +654,7 @@ class JsVisitor(Visitor):
#implementing constructor
self.class_info.protected.append(" %s(Local<Object> _jsObject, CElmObject *parent);\n"%(_o.cl_obj.kl_id))
self.c_file.functions.append("%s::%s(Local<Object> _jsObject, CElmObject *parent)\n"%(_o.cl_obj.kl_id, _o.cl_obj.kl_id))
- self.c_file.functions.append(" : CElmObject(_jsObject, eo_add(%s , parent ? parent->GetEo() : NULL))\n"%(_o.cl_obj.macro))
+ self.c_file.functions.append(" : CElmObject(_jsObject, eo_add(%s, parent ? parent->GetEo() : NULL))\n"%(_o.cl_obj.macro))
self.c_file.functions.append("{\n jsObject->SetPointerInInternalField(0, static_cast<CElmObject*>(this));\n}\n")
self.class_info.protected.append(" static Handle<FunctionTemplate> GetTemplate();\n")
@@ -567,7 +666,7 @@ class JsVisitor(Visitor):
#implementing Initialize
self.c_file.init_f.append("void %s::Initialize(Handle<Object> target)\n"%_o.cl_obj.kl_id)
self.c_file.init_f.append("{\n")
- self.c_file.init_f.append(" target->Set(String::NewSymbol(\"%s\") , GetTemplate()->GetFunction());\n"%_o.cl_obj.kl_id)
+ self.c_file.init_f.append(" target->Set(String::NewSymbol(\"%s\"), GetTemplate()->GetFunction());\n"%_o.cl_obj.kl_id)
self.c_file.init_f.append("}\n")
self.class_info.public.insert(0, " virtual void DidRealiseElement(Local<Value> obj);\n")
@@ -588,10 +687,7 @@ class JsVisitor(Visitor):
self.class_info.protected.append(" virtual ~%s();\n"%(_o.cl_obj.kl_id))
-
-
-
- #saving data to pxi file
+ #saving data to cc file
def js_cc_file_to_dir_save(self, _outdir):
lines = []
@@ -618,7 +714,9 @@ class JsVisitor(Visitor):
lines.append(line)
lines.append("\n} //end namespace elm\n\n")
- f = open (self.c_file.name, 'w')
+
+
+ f = open(os.path.join(_outdir, self.c_file.name), 'w')
for line in lines:
f.write(line)
f.close()
@@ -677,14 +775,11 @@ class JsVisitor(Visitor):
lines.append("\n")
lines.append("#endif\n")
- f = open (self.h_file.name, 'w')
+ f = open(os.path.join(_outdir, self.h_file.name), 'w')
for line in lines:
f.write(line)
f.close()
-
-
-
# PyVisitor
# Py code generation. Generates code depending on object type(input data)
# Under "object type" we understand just some set of data, which has
@@ -693,10 +788,12 @@ class JsVisitor(Visitor):
class PyVisitor(Visitor):
- def __init__(self):
+ def __init__(self, _module_name):
# PyVisitor generates 2 types of files: pxi and pxd
# head, ev, funcs_parsed - are hooks for different parts of source code
+ self.py_module_name = _module_name
+
self.visited_properties = []
self.pxi = Abstract()
@@ -705,18 +802,25 @@ class PyVisitor(Visitor):
self.pxi.ev = []
self.pxi.funcs_parsed = []
-
+ """
self.pxd = Abstract()
self.pxd.name = ""
self.pxd.head = []
self.pxd.ev = []
+ """
+
+ self.pxd2 = Abstract()
+ self.pxd2.name = ""
+ self.pxd2.head = []
+ self.pxd2.ev = []
self._funcs = {"instance_set2" : "_eo_instance_set2",
"instance_get" : "_eo_instance_get",
"do" : "eo_do"}
- self.basemodule = {"macro" : "EO_DEFAULT_CLASS",
+ self.eodefault = {"macro" : "EO_DEFAULT_CLASS",
"module" : "eodefault",
+ "prefix" : const.PREFIX,
"name": "EoDefault",
"parentmodule": "NULL",
"type" :"EO_CLASS_TYPE_REGULAR_NO_INSTANCE",
@@ -739,13 +843,13 @@ class PyVisitor(Visitor):
def visit_Func(self, _o):
# print "func Func: ", _o.name, _o.op_id, _o.c_macro, _o.parameters
eo_base_ops = ["EO_BASE_SUB_ID_EVENT_FREEZE", "EO_BASE_SUB_ID_EVENT_FREEZE_GET", \
- "EO_BASE_SUB_ID_EVENT_THAW", "EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE",
- "EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE_GET",\
- "EO_BASE_SUB_ID_EVENT_GLOBAL_THAW", "EO_BASE_SUB_ID_DATA_SET", \
- "EO_BASE_SUB_ID_DATA_GET", "EO_BASE_SUB_ID_DATA_DEL", \
- "EO_BASE_SUB_ID_EVENT_CALLBACK_PRIORITY_ADD",
- "EO_BASE_SUB_ID_EVENT_CALLBACK_DEL", \
- "EO_BASE_SUB_ID_EVENT_CALLBACK_CALL"]
+ "EO_BASE_SUB_ID_EVENT_THAW", "EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE",
+ "EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE_GET",\
+ "EO_BASE_SUB_ID_EVENT_GLOBAL_THAW", "EO_BASE_SUB_ID_DATA_SET", \
+ "EO_BASE_SUB_ID_DATA_GET", "EO_BASE_SUB_ID_DATA_DEL", \
+ "EO_BASE_SUB_ID_EVENT_CALLBACK_PRIORITY_ADD",
+ "EO_BASE_SUB_ID_EVENT_CALLBACK_DEL", \
+ "EO_BASE_SUB_ID_EVENT_CALLBACK_CALL"]
in_params = []
pass_params =[]
@@ -760,9 +864,10 @@ class PyVisitor(Visitor):
return
if _o.op_id == "EO_BASE_SUB_ID_EVENT_CALLBACK_PRIORITY_ADD":
function_lines.append("def event_callback_priority_add(self, long _desc, int _priority, object _cb):")
- function_lines.append(" if not callable(_cb):")
+ function_lines.append(" if not callable(_cb[0]):")
function_lines.append(" raise TypeError(\"func must be callable\")")
function_lines.append(" cdef Eo_Event_Cb cb = <Eo_Event_Cb> eodefault._object_callback")
+ function_lines.append(" Py_INCREF(_cb)")
function_lines.append(" eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_PRIORITY_ADD), _desc, _priority, cb, <void*>_cb)")
if_ret = True
@@ -770,6 +875,7 @@ class PyVisitor(Visitor):
function_lines.append("def event_callback_del(self, long _desc, object _func):")
function_lines.append(" cdef Eo_Event_Cb func = <Eo_Event_Cb> eodefault._object_callback")
function_lines.append(" eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_DEL), _desc, func, <void*>_func)")
+ function_lines.append(" Py_DECREF(_func)")
function_lines.append("\n")
if_ret = True
@@ -786,6 +892,13 @@ class PyVisitor(Visitor):
function_lines.append(" _key = pytext_to_utf8(_key)")
function_lines.append(" cdef char* key = <char*> _key")
function_lines.append(" eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_SET), key, <void*>_data, NULL)")
+
+ function_lines.append("")
+ function_lines.append("def _data_set(self, object _key, object _data):")
+ function_lines.append(" _key = pytext_to_utf8(_key)")
+ function_lines.append(" cdef char* key = <char*> _key")
+ function_lines.append(" eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_SET), key, <void*>_data, NULL)")
+
if_ret = True
elif _o.op_id == "EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE":
@@ -812,13 +925,13 @@ class PyVisitor(Visitor):
if if_ret:
function_lines.append("\n")
- self.pxi["funcs_parsed"] += function_lines
+ self.pxi.funcs_parsed += function_lines
return
if True:#"parameters" in fparams:
- for i, (n, c_t, d, p_t) in enumerate(_o.parameters):
+ for i, (n, modifier, c_t, d, p_t) in enumerate(_o.parameters):
c_t_tmp = self.cast(p_t)
py_type = ""
@@ -828,22 +941,26 @@ class PyVisitor(Visitor):
c_t_internal = self.internal_types[c_t_tmp][0]
py_type = self.internal_types[c_t_tmp][1]
else:
- print "Warning: type: \"%s\" wasn't found in self.internal_types. Function \"%s\" will not be defined"%(c_t_tmp, _o.name)
+ print "Warning: type: \"%s\" wasn't found in self.internal_types.\n Function \"%s\" from class: \"%s\" will not be defined"%(c_t_tmp, _o.name, _o.cl_obj.c_name)
return
if d == "in":
in_params.append(py_type + ' _' + n)
if c_t_internal == "Eo*":
- l = " cdef %s %s = <%s> _%s"%(c_t_internal, n, c_t_internal, n + ".eo")
+ l = " cdef %s %s = NULL if _%s is None else <%s> _%s"%(c_t_internal, n, n, c_t_internal, n + ".eo")
+ function_lines.append(l)
elif c_t_internal == "Eo_Event_Cb":
l = " cdef %s %s = <%s> %s"%(c_t_internal, n, c_t_internal, "eodefault._object_callback")
+ function_lines.append(l)
else:
if c_t_internal == "char*" :
- l = " _%s = pytext_to_utf8(_%s)"%(n, n)
+ l = " _%s = None if _%s is None else pytext_to_utf8(_%s)"%(n, n, n)
+ function_lines.append(l)
+ l = " cdef %s %s = NULL if _%s is None else <%s> _%s"%(c_t_internal, n, n, c_t_internal, n)
+ function_lines.append(l)
+ else:
+ l = " cdef %s %s = <%s> _%s"%(c_t_internal, n, c_t_internal, n)
function_lines.append(l)
- l = " cdef %s %s = <%s> _%s"%(c_t_internal, n, c_t_internal, n)
- function_lines.append(l)
-
if c_t.find(c_t_internal) != -1 and c_t.replace(c_t_internal, "") == "*":
pass_params.append('&' + n)
@@ -860,7 +977,7 @@ class PyVisitor(Visitor):
in_params.append('_' + n)
pass_params.append('&' + n)
if c_t_internal == "Eo*":
- l = " cdef %s %s = <%s> _%s"%(c_t_internal, n, c_t_internal, n + ".eo")
+ l = " cdef %s %s = NULL if _%s is None else <%s> _%s"%(c_t_internal, n, n, c_t_internal, n + ".eo")
else:
l = " cdef %s %s = <%s> _%s"%(c_t_internal, n, c_t_internal, n)
ret_params.append((n + '_', c_t_internal))
@@ -905,7 +1022,6 @@ class PyVisitor(Visitor):
function_lines.append("")
self.pxi.funcs_parsed += function_lines
-
#generating __init_function, and all header data for files
def visit_Init(self, _o):
cl_obj = _o.cl_obj
@@ -930,29 +1046,34 @@ class PyVisitor(Visitor):
function_lines.append(l)
l = " self.%s(klass, parent)"%self._funcs["instance_set2"]
function_lines.append(l)
- l = " self.data_set(EoDefault.PY_EO_NAME, self)"
- function_lines.append(l)
+# l = " self.data_set(EoDefault.PY_EO_NAME, self)"
+# function_lines.append(l)
function_lines.append("")
function_lines.append("")
self.pxi.funcs_parsed += function_lines
-
self.pxi.name = cl_obj.mod_name + ".pxi"
- self.pxd.name = cl_obj.mod_name + ".pxd"
+ self.pxd2.name = cl_obj.mod_name + ".pxd"
pattern = "########################################################"
l = '%s\n##\n## generated from from \"%s\"\n##\n%s'%(pattern, cl_obj.source_file, pattern)
self.pxi.head.append(l + '\n')
- self.pxd.head.append(l + '\n')
-
+ #REMOVEself.pxd.head.append(l + '\n')
#inserting cimports
- l = "cimport %s"%cl_obj.mod_name
+ #l = "cimport %s"%cl_obj.mod_name
+
+ #now we have one pxd for all extern definitions
+ #so we cimport it with preper name
+ #proper name only for nice
+
+ l = "cimport %s as %s"%(self.py_module_name, cl_obj.mod_name)
self.pxi.head.append(l)
- l = "cimport %s"%cl_obj.basemodule
- self.pxi.head.append(l + '\n')
+
+ #l = "cimport %s"%cl_obj.basemodule
+ #self.pxi.head.append(l + '\n')
#defining class
parents = []
@@ -961,15 +1082,36 @@ class PyVisitor(Visitor):
if cl_obj.kl_id == "EoBase":
parents = []
- parents.append(self.basemodule["name"])
- l = "from %s import %s"%(self.basemodule["module"], self.basemodule["name"])
+ parents.append(self.eodefault["name"])
+ l = "from %s import %s"%(self.eodefault["module"], self.eodefault["name"])
+ self.pxi.head.append(l + "\n")
+ l = "from cpython cimport Py_INCREF, Py_DECREF"
self.pxi.head.append(l + "\n")
if "EoBase" in parents:
- l = "from %s import %s"%("eobase", "EoBase")
+ l = "from %s.%s import %s"%(self.eodefault["prefix"], "eobase", "EoBase")
self.pxi.head.append(l + "\n")
-
- l = "from %s import %s"%(self.basemodule["module"], "pytext_to_utf8")
+
+ for p in parents:
+ #if we have some parent obj to incl, t.e. it is not in the tree
+ if p in cl_obj.objects_incl:
+ path = cl_obj.objects_incl[p].path
+ sys_path = list(sys.path)
+ sys_path.sort(key = len, reverse = True)
+ #this parent should be in search path
+ for pth in sys_path:
+ if pth in path:
+ (d, n) = os.path.split(path)
+ prefix = d.replace(pth, "").replace("/", ".").lstrip(".")
+
+ #FIXME
+ #now prefix is like dir1.dir2
+ #so we can make from dir1.dir2.mod_name import ParentClass
+ # but I don't know mod_name, t.e. *.so!
+
+
+
+ l = "from %s.%s import %s"%(self.eodefault["prefix"], self.eodefault["module"], "pytext_to_utf8")
self.pxi.head.append(l + "\n")
#defining _id function
@@ -982,21 +1124,22 @@ class PyVisitor(Visitor):
#defining class
parents = ','.join(parents)
l = 'class %s(%s):'%(cl_obj.kl_id, parents)
-
self.pxi.head.append(l)
#inserting cimports
- l = "from %s cimport *"%(cl_obj.basemodule)
- self.pxd.head.append(l + '\n')
+ #REMOVEl = "from %s cimport *"%(cl_obj.basemodule)
+ #REMOVEself.pxd.head.append(l + '\n')
#inserting externs from H
l = "cdef extern from \"%s\":"%(cl_obj.includes[0])
- self.pxd.head.append(l + '\n')
+ #REMOVEself.pxd.head.append(l + '\n')
+ self.pxd2.head.append(l + '\n')
if cl_obj.extern_base_id != "":
l = ' %s %s'%("Eo_Op", cl_obj.extern_base_id)
- self.pxd.head.append(l + '\n')
+ #REMOVEself.pxd.head.append(l + '\n')
+ self.pxd2.head.append(l + '\n')
enum_lines = []
enum_lines.append(" ctypedef enum:")
@@ -1008,13 +1151,15 @@ class PyVisitor(Visitor):
if len(enum_lines) > 1:
for l in enum_lines:
- self.pxd.head.append(l)
- self.pxd.head.append('\n')
+ #REMOVEself.pxd.head.append(l)
+ self.pxd2.head.append(l)
+ #REMOVEself.pxd.head.append('\n')
+ self.pxd2.head.append('\n')
for v in cl_obj.extern_funcs:
l = ' %s %s'%(v[1], v[0])
- self.pxd.head.append(l)
-
+ #REMOVEself.pxd.head.append(l)
+ self.pxd2.head.append(l)
#generating event defenitions
def visit_Ev(self, _o):
@@ -1027,8 +1172,8 @@ class PyVisitor(Visitor):
l = " %s = <long>%s.%s"%(name, _o.cl_obj.mod_name, v)
self.pxi.ev.append(l)
l = ' %s %s'%("Eo_Event_Description *", v)
- self.pxd.ev.append(l)
-
+ #REMOVEself.pxd.ev.append(l)
+ self.pxd2.ev.append(l)
#saving data to pxi file
def pxi_file_to_dir_save(self, _outdir):
@@ -1050,8 +1195,8 @@ class PyVisitor(Visitor):
f.write("\n")
f.close()
-
#saving data to pxd file
+ """
def pxd_file_to_dir_save(self, _outdir):
f = open(os.path.join(_outdir, self.pxd.name), 'w')
@@ -1065,8 +1210,22 @@ class PyVisitor(Visitor):
f.write(l+'\n')
f.write("\n")
f.close()
+"""
+ #saving data to pxd file
+ def get_pxd_lines_from_module(self):
+ ret = []
+ lst = self.pxd2.head
+ for l in lst:
+ ret.append(l+'\n')
+ ret.append('\n')
+
+ lst = self.pxd2.ev
+ for l in lst:
+ ret.append(l+'\n')
+ ret.append('\n')
+ return (ret, self.pxd2.name)
class XMLparser(object):
def __init__(self):
@@ -1081,6 +1240,7 @@ class XMLparser(object):
self.ev_ids = []
self.op_ids = []
self.extern_funcs = []
+ self.xml_ver = False
self.class_data = {}
self.functions = {} #function names with parameters
@@ -1097,6 +1257,9 @@ class XMLparser(object):
if name == const.METHOD:
self.current_func = attrs[const.NAME]
self.functions.setdefault(self.current_func, {const.OP_ID : attrs[const.OP_ID], const.C_MACRO : attrs[const.C_MACRO], const.PARAMETERS:[]})
+ elif name == const.PARSE_VERSION:
+ if attrs[const.NUM] == const.VER_NUM:
+ self.xml_ver = True
elif name == const.PARAMETER:
func_att = self.functions[self.current_func]
@@ -1105,7 +1268,7 @@ class XMLparser(object):
name = attrs[const.NAME]
if name in self.python_reserved:
name += "__"
- par_att.append((name, attrs[const.C_TYPENAME], attrs[const.DIRECTION], attrs[const.PRIMARY_TYPE]))
+ par_att.append((name, attrs[const.MODIFIER], attrs[const.C_TYPENAME], attrs[const.DIRECTION], attrs[const.PRIMARY_TYPE]))
elif name == const.INCLUDE:
self.includes.append(attrs[const.NAME])
@@ -1138,6 +1301,12 @@ class XMLparser(object):
p.StartElementHandler = self.start_element_handler
p.ParseFile(open(fName, 'r'))
+ if self.class_data == {}:
+ return
+
+ if self.xml_ver == False:
+ print "Wrong xml file version: %s"%(fName)
+ exit()
mod_name = normalize_names([self.class_data[const.C_NAME]])[0].lower()
#defining _id function
if self.class_data[const.BASE_ID] != "":
@@ -1167,33 +1336,67 @@ class XMLparser(object):
mod_o.sub_id_function = self.class_data["sub_id_function"]
mod_o.source_file = self.source_file
mod_o.parents = parent_list
+ mod_o.path = fName
# Saving function's description as Func object
# Defining if current function can be set/get property, property type is saved in seperate field
# Properties are relevant only for JS
+ func_name_list_not_visited = []
+ for name in self.functions:
+ func_name_list_not_visited.append(name)
+
for i in self.functions:
T = ""
- prop_name = i
if mod_o.kl_id == "Eo Base":
T = const.METHOD
- mod_o.visitees[i] = Func(i, prop_name, self.functions[i][const.OP_ID], self.functions[i][const.C_MACRO], self.functions[i][const.PARAMETERS], T, mod_o)
+ mod_o.visitees[i] = Func(i, self.functions[i][const.OP_ID], self.functions[i][const.C_MACRO], self.functions[i][const.PARAMETERS], T, mod_o)
continue
- if i[-4:] == "_set":
- prop_name = i[:-4]
- if i[:-4]+"_get" in self.functions:
- T = const.SET_GET
- else:
- T = const.SET_ONLY
- elif i[-4:] == "_get":
- prop_name = i[:-4]
- if i[:-4]+"_set" in self.functions:
- T = const.SET_GET
- else:
- T = const.GET_ONLY
+
+ #check if both properties are in tree; and if they are in,
+ # if their parameters are all in or out
+ prefix = i[:-4]
+ postfix = i[-4:]
+ if postfix in ["_set", "_get"]:
+ if prefix + "_set" in func_name_list_not_visited and prefix + "_get" in func_name_list_not_visited:
+ T = const.SET_GET
+ for (n, m ,t1, d, t2) in self.functions[prefix+"_set"][const.PARAMETERS]:
+ if d != "in":
+ T = const.METHOD
+
+ for (n, m ,t1, d, t2) in self.functions[prefix+"_get"][const.PARAMETERS]:
+ if d != "out":
+ T = const.METHOD
+
+ n = prefix + "_get"
+ mod_o.visitees[n] = Func(n, self.functions[n][const.OP_ID], self.functions[n][const.C_MACRO], self.functions[n][const.PARAMETERS], T, mod_o)
+ func_name_list_not_visited.remove(n)
+
+ n = prefix + "_set"
+ mod_o.visitees[n] = Func(n, self.functions[n][const.OP_ID], self.functions[n][const.C_MACRO], self.functions[n][const.PARAMETERS], T, mod_o)
+ func_name_list_not_visited.remove(n)
+
+ elif prefix + "_set" in func_name_list_not_visited:
+ T = const.SET_ONLY
+ for (n, m ,t1, d, t2) in self.functions[prefix+"_set"][const.PARAMETERS]:
+ if d != "in":
+ T = const.METHOD
+ n = prefix + "_set"
+ mod_o.visitees[n] = Func(n, self.functions[n][const.OP_ID], self.functions[n][const.C_MACRO], self.functions[n][const.PARAMETERS], T, mod_o)
+ func_name_list_not_visited.remove(n)
+
+ elif prefix + "_get" in func_name_list_not_visited:
+ T = const.GET_ONLY
+ for (n, m ,t1, d, t2) in self.functions[prefix+"_get"][const.PARAMETERS]:
+ if d != "out":
+ T = const.METHOD
+ n = prefix + "_get"
+ mod_o.visitees[n] = Func(n, self.functions[n][const.OP_ID], self.functions[n][const.C_MACRO], self.functions[n][const.PARAMETERS], T, mod_o)
+ func_name_list_not_visited.remove(n)
+
else:
T = const.METHOD
- mod_o.visitees[i] = Func(i, prop_name, self.functions[i][const.OP_ID], self.functions[i][const.C_MACRO], self.functions[i][const.PARAMETERS], T, mod_o)
-
+ mod_o.visitees[i] = Func(i, self.functions[i][const.OP_ID], self.functions[i][const.C_MACRO], self.functions[i][const.PARAMETERS], T, mod_o)
+ func_name_list_not_visited.remove(i)
for i in self.ev_ids:
mod_o.visitees[i] = Ev(i, mod_o)
@@ -1208,6 +1411,8 @@ class XMLparser(object):
self.op_ids = []
self.ev_ids = []
self.extern_funcs = []
+ self.class_data = {}
+ self.xml_ver = False
#For each class(object) in current tree, checks if parent is also in current tree.
@@ -1216,6 +1421,7 @@ class XMLparser(object):
def module_parse(self, _module_name, _xml_files, _incl_dirs):
+ #parsing each XML
for f in _xml_files:
self.parse(f)
@@ -1246,7 +1452,7 @@ class XMLparser(object):
xml_files = filter(isXML, xml_files)
if len(xml_files) == 0:
- print "ERROR: no include files found for %s classes... Aborting...(Use: --include=INCLUDE_DIR)"% ",".join(parents_to_find)
+ print "ERROR: no include files found for %s classes... Aborting...(Use: -X(--xmldir=)XML_DIR)"% ",".join(parents_to_find)
exit(1)
#Creating temp parser to look for parents in include files.
@@ -1255,7 +1461,7 @@ class XMLparser(object):
xp_incl.parse(f)
#Looking for parents, and saving proper object in include dictionary
- #FIXME: but later I never use it ??
+ #FIXME: but later I never use it USED! 12.12.12
for n, o in xp_incl.objects.items():
if n in parents_to_find:
i = parents_to_find.index(n)
@@ -1270,8 +1476,6 @@ class XMLparser(object):
exit(1)
-
-
def parents_to_find_get(self):
list_of_parents = []
@@ -1348,20 +1552,27 @@ class XMLparser(object):
l = list(set(l + prnts))
return l
-
#normalize all names and ids, which depend in C class name.
#T.e. Some_Class name -> SomeClassName
def normalize_module_names(self):
objects_tmp = {}
for n, o in self.objects.items():
- o.c_name = normalize_names([o.c_name])[0]
+ #o.c_name = normalize_names([o.c_name])[0]
o.kl_id = normalize_names([o.kl_id])[0]
o.parents = normalize_names(o.parents)
objects_tmp[o.kl_id] = o
- self.objects = objects_tmp
+ self.objects = dict(objects_tmp)
+ del objects_tmp
+ #self.objects_incl - all parents which wasn't founc in current tree
+ #o.objects_incl - parents for current obj, which wasn't found in
+ #curren tree and need to import
+ for n, o in self.objects.items():
+ for p in o.parents:
+ if p in self.objects_incl:
+ o.objects_incl[p] = self.objects_incl[p]
- def py_code_generate(self, module_name ,outdir):
+ def py_code_generate(self, module_name, outdir):
#normalizing names for each class object (Evas_Object Class -> EvasObjectClass)
self.normalize_module_names()
@@ -1369,15 +1580,35 @@ class XMLparser(object):
for n, o in self.objects.items():
o.parents = self.reorder_parents(o.parents)
- o.V = PyVisitor()
+ o.V = PyVisitor(module_name)
o.resolve()
+ lines = []
+ names = []
#saving files
for n, o in self.objects.items():
o.V.pxi_file_to_dir_save(outdir)
- o.V.pxd_file_to_dir_save(outdir)
- #generating "pyx" module file,
+ #saving all pxd data in one file
+ (l, name) = o.V.get_pxd_lines_from_module()
+ lines += l
+ names.append(name)
+
+ f = open (os.path.join(outdir, module_name + ".pxd"), 'w')
+
+ pattern = "########################################################"
+ l = '%s\n##\n## generated from \"%s\"\n##\n%s'%(pattern, ", ".join(names), pattern)
+ f.write(l + "\n")
+ pv = PyVisitor("tmp")
+ f.write("from %s.eodefault cimport *\n\n"%pv.eodefault["prefix"])
+ f.write("cimport %s.eodefault as eodefault\n\n"%pv.eodefault["prefix"])
+ del pv
+
+ for l in lines:
+ f.write(l)
+ f.close()
+
+ #generating "pyx" module file,
#which simply includes source files "pxi" of each class
#building right order of including files
cl_parents = {}
@@ -1405,7 +1636,8 @@ class XMLparser(object):
exit(1)
lines = []
- lines.append("from eodefault cimport *\n")
+ #put it into pxd 12.12.12
+ #lines.append("from eodefault cimport *\n")
for k in lst:
lines.append("include \"%s\""%self.objects[k].V.pxi.name)
#FIXME adding filenames of include modules?
@@ -1419,8 +1651,8 @@ class XMLparser(object):
self.normalize_module_names()
for n, o in self.objects.items():
- o.js_h_file = os.path.join(outdir, "_" + o.mod_name + ".h")
- o.js_cc_file = os.path.join(outdir, "_" + o.mod_name + ".cc")
+ o.js_h_file = "_" + o.mod_name + ".h"
+ o.js_cc_file = "_" + o.mod_name + ".cc"
eo_base_ops = ["INIT", "EO_BASE_SUB_ID_EVENT_FREEZE", "EO_BASE_SUB_ID_EVENT_FREEZE_GET", "EO_BASE_SUB_ID_EVENT_THAW", "EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE", "EO_BASE_SUB_ID_EVENT_GLOBAL_THAW"]
@@ -1468,9 +1700,13 @@ class XMLparser(object):
o.V.c_file.tmpl.append(" METHOD(%s)"%f.name)
continue
if f.prop_type == const.METHOD:
- o.V.c_file.tmpl.append(" METHOD(%s)"%f.prop_name)
- else:
- o.V.c_file.tmpl.append(" PROPERTY(%s)"%f.prop_name)
+ o.V.c_file.tmpl.append(" METHOD(%s)"%f.name)
+ elif f.prop_type == const.SET_GET:
+ o.V.c_file.tmpl.append(" PROPERTY(%s)"%f.name[:-4])
+ elif f.prop_type == const.SET_ONLY:
+ o.V.c_file.tmpl.append(" PROPERTY_SO(%s)"%f.name[:-4])
+ elif f.prop_type == const.GET_ONLY:
+ o.V.c_file.tmpl.append(" PROPERTY_RO(%s)"%f.name[:-4])
elif f.__class__.__name__ == "Ev":
o.V.c_file.tmpl.append(" PROPERTY(%s)"%f.ev_id.lower())
@@ -1484,8 +1720,41 @@ class XMLparser(object):
if o.instantiateable == "False":
o.V.c_file.tmpl = ""
+ class_name_header_name = []
#saving files
for n, o in self.objects.items():
o.V.js_cc_file_to_dir_save(outdir)
o.V.js_h_file_to_dir_save(outdir)
+ if o.eo_type == const.CLASS_TYPE_REGULAR:
+ class_name_header_name.append((o.kl_id, o.V.h_file.name))
+
+ #generating separate file to add calls to Initialize for each class
+ lines = []
+ lines.append("/*This file was autogenerated to provide init on module load.")
+ lines.append("Additional code can be added here, but it will be droppeded on next generation.*/\n\n")
+ lines.append("#include <v8.h>\n")
+ lines.append("using namespace v8;\n")
+
+ lines.append("#include \"elm.h\"\n")
+
+ for kl, h in class_name_header_name:
+ lines.append("#include \"%s\""%h)
+
+ lines.append("\nnamespace elm {\n")
+
+ lines.append("/* elm_init() must be called from here. */")
+ lines.append("void EoRegisterModule(Handle<Object> target)")
+ lines.append("{")
+
+ for kl, h in class_name_header_name:
+ lines.append(" %s::Initialize(target);"%kl)
+ lines.append("}")
+
+ lines.append("}") #namespace elm end
+
+ f = open(os.path.join(outdir, "_module.cc"), 'w')
+ for l in lines:
+ f.write(l + "\n")
+ f.close()
+
diff --git a/eorepo/EoBase.xml b/eorepo/EoBase.xml
new file mode 100644
index 0000000..5829ced
--- /dev/null
+++ b/eorepo/EoBase.xml
@@ -0,0 +1,90 @@
+<?xml version="1.0" ?>
+<module name="Eo Base">
+ <parse_version num="1.0.1"/>
+ <include name="Eo.h"/>
+ <extern_function name="eo_base_class_get()" typename="Eo_Class*"/>
+ <class c_name="Eo Base" extensions="" get_function="eo_base_class_get" instantiateable="False" macro="EO_BASE_CLASS" parent="" type="EO_CLASS_TYPE_REGULAR_NO_INSTANT">
+ <op_id>
+ <base_id name="EO_BASE_BASE_ID"/>
+ <sub_id name="EO_BASE_SUB_ID_WREF_DEL"/>
+ <sub_id name="EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE"/>
+ <sub_id name="EO_BASE_SUB_ID_EVENT_CALLBACK_FORWARDER_DEL"/>
+ <sub_id name="EO_BASE_SUB_ID_EVENT_GLOBAL_THAW"/>
+ <sub_id name="EO_BASE_SUB_ID_EVENT_CALLBACK_DEL"/>
+ <sub_id name="EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE_GET"/>
+ <sub_id name="EO_BASE_SUB_ID_DATA_SET"/>
+ <sub_id name="EO_BASE_SUB_ID_EVENT_THAW"/>
+ <sub_id name="EO_BASE_SUB_ID_WREF_ADD"/>
+ <sub_id name="EO_BASE_SUB_ID_DESTRUCTOR"/>
+ <sub_id name="EO_BASE_SUB_ID_DATA_GET"/>
+ <sub_id name="EO_BASE_SUB_ID_DATA_DEL"/>
+ <sub_id name="EO_BASE_SUB_ID_CONSTRUCTOR"/>
+ <sub_id name="EO_BASE_SUB_ID_EVENT_CALLBACK_CALL"/>
+ <sub_id name="EO_BASE_SUB_ID_EVENT_FREEZE_GET"/>
+ <sub_id name="EO_BASE_SUB_ID_EVENT_FREEZE"/>
+ <sub_id name="EO_BASE_SUB_ID_EVENT_CALLBACK_PRIORITY_ADD"/>
+ <sub_id name="EO_BASE_SUB_ID_EVENT_CALLBACK_FORWARDER_ADD"/>
+ </op_id>
+ <events>
+ <event name="EO_EV_CALLBACK_ADD"/>
+ <event name="EO_EV_CALLBACK_DEL"/>
+ <event name="EO_EV_DEL"/>
+ </events>
+ <methods>
+ <method c_macro="eo_wref_del" name="wref_del" op_id="EO_BASE_SUB_ID_WREF_DEL">
+ <parameter c_typename="Eo**" direction="in,out" modifier="" name="wref" primary_type="Eo**"/>
+ </method>
+ <method c_macro="eo_event_global_freeze" name="event_global_freeze" op_id="EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE"/>
+ <method c_macro="eo_event_callback_forwarder_del" name="event_callback_forwarder_del" op_id="EO_BASE_SUB_ID_EVENT_CALLBACK_FORWARDER_DEL">
+ <parameter c_typename="Eo_Event_Description*" direction="in" modifier="const" name="desc" primary_type="Eo_Event_Description*"/>
+ <parameter c_typename="Eo*" direction="in" modifier="" name="new_obj" primary_type="Eo*"/>
+ </method>
+ <method c_macro="eo_event_global_thaw" name="event_global_thaw" op_id="EO_BASE_SUB_ID_EVENT_GLOBAL_THAW"/>
+ <method c_macro="eo_event_callback_del" name="event_callback_del" op_id="EO_BASE_SUB_ID_EVENT_CALLBACK_DEL">
+ <parameter c_typename="Eo_Event_Description*" direction="in" modifier="const" name="desc" primary_type="Eo_Event_Description*"/>
+ <parameter c_typename="Eo_Event_Cb" direction="in" modifier="" name="func" primary_type="Eo_Event_Cb"/>
+ <parameter c_typename="void*" direction="in" modifier="const" name="user_data" primary_type="void*"/>
+ </method>
+ <method c_macro="eo_event_global_freeze_get" name="event_global_freeze_get" op_id="EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE_GET">
+ <parameter c_typename="int*" direction="out" modifier="" name="fcount" primary_type="int*"/>
+ </method>
+ <method c_macro="eo_base_data_set" name="data_set" op_id="EO_BASE_SUB_ID_DATA_SET">
+ <parameter c_typename="char*" direction="in" modifier="const" name="key" primary_type="char*"/>
+ <parameter c_typename="void*" direction="in" modifier="const" name="data" primary_type="void*"/>
+ <parameter c_typename="eo_base_data_free_func" direction="in" modifier="" name="free_func" primary_type="eo_base_data_free_func"/>
+ </method>
+ <method c_macro="eo_event_thaw" name="event_thaw" op_id="EO_BASE_SUB_ID_EVENT_THAW"/>
+ <method c_macro="eo_wref_add" name="wref_add" op_id="EO_BASE_SUB_ID_WREF_ADD">
+ <parameter c_typename="Eo**" direction="in,out" modifier="" name="wref" primary_type="Eo**"/>
+ </method>
+ <method c_macro="eo_destructor" name="destructor" op_id="EO_BASE_SUB_ID_DESTRUCTOR"/>
+ <method c_macro="eo_base_data_get" name="data_get" op_id="EO_BASE_SUB_ID_DATA_GET">
+ <parameter c_typename="char*" direction="in" modifier="const" name="key" primary_type="char*"/>
+ <parameter c_typename="void**" direction="out" modifier="" name="data" primary_type="void**"/>
+ </method>
+ <method c_macro="eo_base_data_del" name="data_del" op_id="EO_BASE_SUB_ID_DATA_DEL">
+ <parameter c_typename="char*" direction="in" modifier="const" name="key" primary_type="char*"/>
+ </method>
+ <method c_macro="eo_constructor" name="constructor" op_id="EO_BASE_SUB_ID_CONSTRUCTOR"/>
+ <method c_macro="eo_event_callback_call" name="event_callback_call" op_id="EO_BASE_SUB_ID_EVENT_CALLBACK_CALL">
+ <parameter c_typename="Eo_Event_Description*" direction="in" modifier="const" name="desc" primary_type="Eo_Event_Description*"/>
+ <parameter c_typename="void*" direction="in" modifier="const" name="event_info" primary_type="void*"/>
+ <parameter c_typename="Eina_Bool*" direction="out" modifier="" name="aborted" primary_type="bool*"/>
+ </method>
+ <method c_macro="eo_event_freeze_get" name="event_freeze_get" op_id="EO_BASE_SUB_ID_EVENT_FREEZE_GET">
+ <parameter c_typename="int*" direction="out" modifier="" name="fcount" primary_type="int*"/>
+ </method>
+ <method c_macro="eo_event_freeze" name="event_freeze" op_id="EO_BASE_SUB_ID_EVENT_FREEZE"/>
+ <method c_macro="eo_event_callback_priority_add" name="event_callback_priority_add" op_id="EO_BASE_SUB_ID_EVENT_CALLBACK_PRIORITY_ADD">
+ <parameter c_typename="Eo_Event_Description*" direction="in" modifier="const" name="desc" primary_type="Eo_Event_Description*"/>
+ <parameter c_typename="Eo_Callback_Priority" direction="in" modifier="" name="priority" primary_type="short"/>
+ <parameter c_typename="Eo_Event_Cb" direction="in" modifier="" name="cb" primary_type="Eo_Event_Cb"/>
+ <parameter c_typename="void*" direction="in" modifier="const" name="data" primary_type="void*"/>
+ </method>
+ <method c_macro="eo_event_callback_forwarder_add" name="event_callback_forwarder_add" op_id="EO_BASE_SUB_ID_EVENT_CALLBACK_FORWARDER_ADD">
+ <parameter c_typename="Eo_Event_Description*" direction="in" modifier="const" name="desc" primary_type="Eo_Event_Description*"/>
+ <parameter c_typename="Eo*" direction="in" modifier="" name="new_obj" primary_type="Eo*"/>
+ </method>
+ </methods>
+ </class>
+</module>
diff --git a/eorepo/__init__.py b/eorepo/__init__.py
new file mode 100644
index 0000000..562b866
--- /dev/null
+++ b/eorepo/__init__.py
@@ -0,0 +1,3 @@
+import eodefault
+eodefault.init()
+
diff --git a/eorepo/eobase.c b/eorepo/eobase.c
new file mode 100644
index 0000000..7420a4e
--- /dev/null
+++ b/eorepo/eobase.c
@@ -0,0 +1,5268 @@
+/* Generated by Cython 0.17.2 on Thu Dec 13 18:28:03 2012 */
+
+#define PY_SSIZE_T_CLEAN
+#include "Python.h"
+#ifndef Py_PYTHON_H
+ #error Python headers needed to compile C extensions, please install development version of Python.
+#elif PY_VERSION_HEX < 0x02040000
+ #error Cython requires Python 2.4+.
+#else
+#include <stddef.h> /* For offsetof */
+#ifndef offsetof
+#define offsetof(type, member) ( (size_t) & ((type*)0) -> member )
+#endif
+#if !defined(WIN32) && !defined(MS_WINDOWS)
+ #ifndef __stdcall
+ #define __stdcall
+ #endif
+ #ifndef __cdecl
+ #define __cdecl
+ #endif
+ #ifndef __fastcall
+ #define __fastcall
+ #endif
+#endif
+#ifndef DL_IMPORT
+ #define DL_IMPORT(t) t
+#endif
+#ifndef DL_EXPORT
+ #define DL_EXPORT(t) t
+#endif
+#ifndef PY_LONG_LONG
+ #define PY_LONG_LONG LONG_LONG
+#endif
+#ifndef Py_HUGE_VAL
+ #define Py_HUGE_VAL HUGE_VAL
+#endif
+#ifdef PYPY_VERSION
+#define CYTHON_COMPILING_IN_PYPY 1
+#define CYTHON_COMPILING_IN_CPYTHON 0
+#else
+#define CYTHON_COMPILING_IN_PYPY 0
+#define CYTHON_COMPILING_IN_CPYTHON 1
+#endif
+#if PY_VERSION_HEX < 0x02050000
+ typedef int Py_ssize_t;
+ #define PY_SSIZE_T_MAX INT_MAX
+ #define PY_SSIZE_T_MIN INT_MIN
+ #define PY_FORMAT_SIZE_T ""
+ #define CYTHON_FORMAT_SSIZE_T ""
+ #define PyInt_FromSsize_t(z) PyInt_FromLong(z)
+ #define PyInt_AsSsize_t(o) __Pyx_PyInt_AsInt(o)
+ #define PyNumber_Index(o) ((PyNumber_Check(o) && !PyFloat_Check(o)) ? PyNumber_Int(o) : \
+ (PyErr_Format(PyExc_TypeError, \
+ "expected index value, got %.200s", Py_TYPE(o)->tp_name), \
+ (PyObject*)0))
+ #define __Pyx_PyIndex_Check(o) (PyNumber_Check(o) && !PyFloat_Check(o) && \
+ !PyComplex_Check(o))
+ #define PyIndex_Check __Pyx_PyIndex_Check
+ #define PyErr_WarnEx(category, message, stacklevel) PyErr_Warn(category, message)
+ #define __PYX_BUILD_PY_SSIZE_T "i"
+#else
+ #define __PYX_BUILD_PY_SSIZE_T "n"
+ #define CYTHON_FORMAT_SSIZE_T "z"
+ #define __Pyx_PyIndex_Check PyIndex_Check
+#endif
+#if PY_VERSION_HEX < 0x02060000
+ #define Py_REFCNT(ob) (((PyObject*)(ob))->ob_refcnt)
+ #define Py_TYPE(ob) (((PyObject*)(ob))->ob_type)
+ #define Py_SIZE(ob) (((PyVarObject*)(ob))->ob_size)
+ #define PyVarObject_HEAD_INIT(type, size) \
+ PyObject_HEAD_INIT(type) size,
+ #define PyType_Modified(t)
+ typedef struct {
+ void *buf;
+ PyObject *obj;
+ Py_ssize_t len;
+ Py_ssize_t itemsize;
+ int readonly;
+ int ndim;
+ char *format;
+ Py_ssize_t *shape;
+ Py_ssize_t *strides;
+ Py_ssize_t *suboffsets;
+ void *internal;
+ } Py_buffer;
+ #define PyBUF_SIMPLE 0
+ #define PyBUF_WRITABLE 0x0001
+ #define PyBUF_FORMAT 0x0004
+ #define PyBUF_ND 0x0008
+ #define PyBUF_STRIDES (0x0010 | PyBUF_ND)
+ #define PyBUF_C_CONTIGUOUS (0x0020 | PyBUF_STRIDES)
+ #define PyBUF_F_CONTIGUOUS (0x0040 | PyBUF_STRIDES)
+ #define PyBUF_ANY_CONTIGUOUS (0x0080 | PyBUF_STRIDES)
+ #define PyBUF_INDIRECT (0x0100 | PyBUF_STRIDES)
+ #define PyBUF_RECORDS (PyBUF_STRIDES | PyBUF_FORMAT | PyBUF_WRITABLE)
+ #define PyBUF_FULL (PyBUF_INDIRECT | PyBUF_FORMAT | PyBUF_WRITABLE)
+ typedef int (*getbufferproc)(PyObject *, Py_buffer *, int);
+ typedef void (*releasebufferproc)(PyObject *, Py_buffer *);
+#endif
+#if PY_MAJOR_VERSION < 3
+ #define __Pyx_BUILTIN_MODULE_NAME "__builtin__"
+ #define __Pyx_PyCode_New(a, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos) \
+ PyCode_New(a, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos)
+#else
+ #define __Pyx_BUILTIN_MODULE_NAME "builtins"
+ #define __Pyx_PyCode_New(a, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos) \
+ PyCode_New(a, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos)
+#endif
+#if PY_MAJOR_VERSION < 3 && PY_MINOR_VERSION < 6
+ #define PyUnicode_FromString(s) PyUnicode_Decode(s, strlen(s), "UTF-8", "strict")
+#endif
+#if PY_MAJOR_VERSION >= 3
+ #define Py_TPFLAGS_CHECKTYPES 0
+ #define Py_TPFLAGS_HAVE_INDEX 0
+#endif
+#if (PY_VERSION_HEX < 0x02060000) || (PY_MAJOR_VERSION >= 3)
+ #define Py_TPFLAGS_HAVE_NEWBUFFER 0
+#endif
+#if PY_VERSION_HEX > 0x03030000 && defined(PyUnicode_KIND)
+ #define CYTHON_PEP393_ENABLED 1
+ #define __Pyx_PyUnicode_READY(op) (likely(PyUnicode_IS_READY(op)) ? \
+ 0 : _PyUnicode_Ready((PyObject *)(op)))
+ #define __Pyx_PyUnicode_GET_LENGTH(u) PyUnicode_GET_LENGTH(u)
+ #define __Pyx_PyUnicode_READ_CHAR(u, i) PyUnicode_READ_CHAR(u, i)
+ #define __Pyx_PyUnicode_READ(k, d, i) PyUnicode_READ(k, d, i)
+#else
+ #define CYTHON_PEP393_ENABLED 0
+ #define __Pyx_PyUnicode_READY(op) (0)
+ #define __Pyx_PyUnicode_GET_LENGTH(u) PyUnicode_GET_SIZE(u)
+ #define __Pyx_PyUnicode_READ_CHAR(u, i) ((Py_UCS4)(PyUnicode_AS_UNICODE(u)[i]))
+ #define __Pyx_PyUnicode_READ(k, d, i) ((k=k), (Py_UCS4)(((Py_UNICODE*)d)[i]))
+#endif
+#if PY_MAJOR_VERSION >= 3
+ #define PyBaseString_Type PyUnicode_Type
+ #define PyStringObject PyUnicodeObject
+ #define PyString_Type PyUnicode_Type
+ #define PyString_Check PyUnicode_Check
+ #define PyString_CheckExact PyUnicode_CheckExact
+#endif
+#if PY_VERSION_HEX < 0x02060000
+ #define PyBytesObject PyStringObject
+ #define PyBytes_Type PyString_Type
+ #define PyBytes_Check PyString_Check
+ #define PyBytes_CheckExact PyString_CheckExact
+ #define PyBytes_FromString PyString_FromString
+ #define PyBytes_FromStringAndSize PyString_FromStringAndSize
+ #define PyBytes_FromFormat PyString_FromFormat
+ #define PyBytes_DecodeEscape PyString_DecodeEscape
+ #define PyBytes_AsString PyString_AsString
+ #define PyBytes_AsStringAndSize PyString_AsStringAndSize
+ #define PyBytes_Size PyString_Size
+ #define PyBytes_AS_STRING PyString_AS_STRING
+ #define PyBytes_GET_SIZE PyString_GET_SIZE
+ #define PyBytes_Repr PyString_Repr
+ #define PyBytes_Concat PyString_Concat
+ #define PyBytes_ConcatAndDel PyString_ConcatAndDel
+#endif
+#if PY_VERSION_HEX < 0x02060000
+ #define PySet_Check(obj) PyObject_TypeCheck(obj, &PySet_Type)
+ #define PyFrozenSet_Check(obj) PyObject_TypeCheck(obj, &PyFrozenSet_Type)
+#endif
+#ifndef PySet_CheckExact
+ #define PySet_CheckExact(obj) (Py_TYPE(obj) == &PySet_Type)
+#endif
+#define __Pyx_TypeCheck(obj, type) PyObject_TypeCheck(obj, (PyTypeObject *)type)
+#if PY_MAJOR_VERSION >= 3
+ #define PyIntObject PyLongObject
+ #define PyInt_Type PyLong_Type
+ #define PyInt_Check(op) PyLong_Check(op)
+ #define PyInt_CheckExact(op) PyLong_CheckExact(op)
+ #define PyInt_FromString PyLong_FromString
+ #define PyInt_FromUnicode PyLong_FromUnicode
+ #define PyInt_FromLong PyLong_FromLong
+ #define PyInt_FromSize_t PyLong_FromSize_t
+ #define PyInt_FromSsize_t PyLong_FromSsize_t
+ #define PyInt_AsLong PyLong_AsLong
+ #define PyInt_AS_LONG PyLong_AS_LONG
+ #define PyInt_AsSsize_t PyLong_AsSsize_t
+ #define PyInt_AsUnsignedLongMask PyLong_AsUnsignedLongMask
+ #define PyInt_AsUnsignedLongLongMask PyLong_AsUnsignedLongLongMask
+#endif
+#if PY_MAJOR_VERSION >= 3
+ #define PyBoolObject PyLongObject
+#endif
+#if PY_VERSION_HEX < 0x03020000
+ typedef long Py_hash_t;
+ #define __Pyx_PyInt_FromHash_t PyInt_FromLong
+ #define __Pyx_PyInt_AsHash_t PyInt_AsLong
+#else
+ #define __Pyx_PyInt_FromHash_t PyInt_FromSsize_t
+ #define __Pyx_PyInt_AsHash_t PyInt_AsSsize_t
+#endif
+#if (PY_MAJOR_VERSION < 3) || (PY_VERSION_HEX >= 0x03010300)
+ #define __Pyx_PySequence_GetSlice(obj, a, b) PySequence_GetSlice(obj, a, b)
+ #define __Pyx_PySequence_SetSlice(obj, a, b, value) PySequence_SetSlice(obj, a, b, value)
+ #define __Pyx_PySequence_DelSlice(obj, a, b) PySequence_DelSlice(obj, a, b)
+#else
+ #define __Pyx_PySequence_GetSlice(obj, a, b) (unlikely(!(obj)) ? \
+ (PyErr_SetString(PyExc_SystemError, "null argument to internal routine"), (PyObject*)0) : \
+ (likely((obj)->ob_type->tp_as_mapping) ? (PySequence_GetSlice(obj, a, b)) : \
+ (PyErr_Format(PyExc_TypeError, "'%.200s' object is unsliceable", (obj)->ob_type->tp_name), (PyObject*)0)))
+ #define __Pyx_PySequence_SetSlice(obj, a, b, value) (unlikely(!(obj)) ? \
+ (PyErr_SetString(PyExc_SystemError, "null argument to internal routine"), -1) : \
+ (likely((obj)->ob_type->tp_as_mapping) ? (PySequence_SetSlice(obj, a, b, value)) : \
+ (PyErr_Format(PyExc_TypeError, "'%.200s' object doesn't support slice assignment", (obj)->ob_type->tp_name), -1)))
+ #define __Pyx_PySequence_DelSlice(obj, a, b) (unlikely(!(obj)) ? \
+ (PyErr_SetString(PyExc_SystemError, "null argument to internal routine"), -1) : \
+ (likely((obj)->ob_type->tp_as_mapping) ? (PySequence_DelSlice(obj, a, b)) : \
+ (PyErr_Format(PyExc_TypeError, "'%.200s' object doesn't support slice deletion", (obj)->ob_type->tp_name), -1)))
+#endif
+#if PY_MAJOR_VERSION >= 3
+ #define PyMethod_New(func, self, klass) ((self) ? PyMethod_New(func, self) : PyInstanceMethod_New(func))
+#endif
+#if PY_VERSION_HEX < 0x02050000
+ #define __Pyx_GetAttrString(o,n) PyObject_GetAttrString((o),((char *)(n)))
+ #define __Pyx_SetAttrString(o,n,a) PyObject_SetAttrString((o),((char *)(n)),(a))
+ #define __Pyx_DelAttrString(o,n) PyObject_DelAttrString((o),((char *)(n)))
+#else
+ #define __Pyx_GetAttrString(o,n) PyObject_GetAttrString((o),(n))
+ #define __Pyx_SetAttrString(o,n,a) PyObject_SetAttrString((o),(n),(a))
+ #define __Pyx_DelAttrString(o,n) PyObject_DelAttrString((o),(n))
+#endif
+#if PY_VERSION_HEX < 0x02050000
+ #define __Pyx_NAMESTR(n) ((char *)(n))
+ #define __Pyx_DOCSTR(n) ((char *)(n))
+#else
+ #define __Pyx_NAMESTR(n) (n)
+ #define __Pyx_DOCSTR(n) (n)
+#endif
+
+
+#if PY_MAJOR_VERSION >= 3
+ #define __Pyx_PyNumber_Divide(x,y) PyNumber_TrueDivide(x,y)
+ #define __Pyx_PyNumber_InPlaceDivide(x,y) PyNumber_InPlaceTrueDivide(x,y)
+#else
+ #define __Pyx_PyNumber_Divide(x,y) PyNumber_Divide(x,y)
+ #define __Pyx_PyNumber_InPlaceDivide(x,y) PyNumber_InPlaceDivide(x,y)
+#endif
+
+#ifndef __PYX_EXTERN_C
+ #ifdef __cplusplus
+ #define __PYX_EXTERN_C extern "C"
+ #else
+ #define __PYX_EXTERN_C extern
+ #endif
+#endif
+
+#if defined(WIN32) || defined(MS_WINDOWS)
+#define _USE_MATH_DEFINES
+#endif
+#include <math.h>
+#define __PYX_HAVE__eorepo__eobase
+#define __PYX_HAVE_API__eorepo__eobase
+#include "Eina.h"
+#include "Eo.h"
+#include "stdio.h"
+#include "pythread.h"
+#ifdef _OPENMP
+#include <omp.h>
+#endif /* _OPENMP */
+
+#ifdef PYREX_WITHOUT_ASSERTIONS
+#define CYTHON_WITHOUT_ASSERTIONS
+#endif
+
+
+/* inline attribute */
+#ifndef CYTHON_INLINE
+ #if defined(__GNUC__)
+ #define CYTHON_INLINE __inline__
+ #elif defined(_MSC_VER)
+ #define CYTHON_INLINE __inline
+ #elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L
+ #define CYTHON_INLINE inline
+ #else
+ #define CYTHON_INLINE
+ #endif
+#endif
+
+/* unused attribute */
+#ifndef CYTHON_UNUSED
+# if defined(__GNUC__)
+# if !(defined(__cplusplus)) || (__GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 4))
+# define CYTHON_UNUSED __attribute__ ((__unused__))
+# else
+# define CYTHON_UNUSED
+# endif
+# elif defined(__ICC) || (defined(__INTEL_COMPILER) && !defined(_MSC_VER))
+# define CYTHON_UNUSED __attribute__ ((__unused__))
+# else
+# define CYTHON_UNUSED
+# endif
+#endif
+
+typedef struct {PyObject **p; char *s; const long n; const char* encoding; const char is_unicode; const char is_str; const char intern; } __Pyx_StringTabEntry; /*proto*/
+
+
+/* Type Conversion Predeclarations */
+
+#define __Pyx_PyBytes_FromUString(s) PyBytes_FromString((char*)s)
+#define __Pyx_PyBytes_AsUString(s) ((unsigned char*) PyBytes_AsString(s))
+
+#define __Pyx_Owned_Py_None(b) (Py_INCREF(Py_None), Py_None)
+#define __Pyx_PyBool_FromLong(b) ((b) ? (Py_INCREF(Py_True), Py_True) : (Py_INCREF(Py_False), Py_False))
+static CYTHON_INLINE int __Pyx_PyObject_IsTrue(PyObject*);
+static CYTHON_INLINE PyObject* __Pyx_PyNumber_Int(PyObject* x);
+
+static CYTHON_INLINE Py_ssize_t __Pyx_PyIndex_AsSsize_t(PyObject*);
+static CYTHON_INLINE PyObject * __Pyx_PyInt_FromSize_t(size_t);
+static CYTHON_INLINE size_t __Pyx_PyInt_AsSize_t(PyObject*);
+
+#if CYTHON_COMPILING_IN_CPYTHON
+#define __pyx_PyFloat_AsDouble(x) (PyFloat_CheckExact(x) ? PyFloat_AS_DOUBLE(x) : PyFloat_AsDouble(x))
+#else
+#define __pyx_PyFloat_AsDouble(x) PyFloat_AsDouble(x)
+#endif
+#define __pyx_PyFloat_AsFloat(x) ((float) __pyx_PyFloat_AsDouble(x))
+
+#ifdef __GNUC__
+ /* Test for GCC > 2.95 */
+ #if __GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95))
+ #define likely(x) __builtin_expect(!!(x), 1)
+ #define unlikely(x) __builtin_expect(!!(x), 0)
+ #else /* __GNUC__ > 2 ... */
+ #define likely(x) (x)
+ #define unlikely(x) (x)
+ #endif /* __GNUC__ > 2 ... */
+#else /* __GNUC__ */
+ #define likely(x) (x)
+ #define unlikely(x) (x)
+#endif /* __GNUC__ */
+
+static PyObject *__pyx_m;
+static PyObject *__pyx_b;
+static PyObject *__pyx_empty_tuple;
+static PyObject *__pyx_empty_bytes;
+static int __pyx_lineno;
+static int __pyx_clineno = 0;
+static const char * __pyx_cfilenm= __FILE__;
+static const char *__pyx_filename;
+
+
+static const char *__pyx_f[] = {
+ "eobase.pxi",
+ "eobase.pyx",
+ "eodefault.pxd",
+ "type.pxd",
+ "bool.pxd",
+ "complex.pxd",
+};
+
+/*--- Type declarations ---*/
+struct __pyx_obj_6eorepo_9eodefault_EoDefault;
+
+/* "eorepo/eodefault.pxd":73
+ *
+ *
+ * cdef class EoDefault: # <<<<<<<<<<<<<<
+ * cdef Eo *eo
+ * cdef object name
+ */
+struct __pyx_obj_6eorepo_9eodefault_EoDefault {
+ PyObject_HEAD
+ struct __pyx_vtabstruct_6eorepo_9eodefault_EoDefault *__pyx_vtab;
+ Eo *eo;
+ PyObject *name;
+};
+
+
+
+struct __pyx_vtabstruct_6eorepo_9eodefault_EoDefault {
+ int (*print_func_name)(struct __pyx_obj_6eorepo_9eodefault_EoDefault *, PyObject *);
+ int (*_eo_instance_set)(struct __pyx_obj_6eorepo_9eodefault_EoDefault *, Eo *);
+ PyObject *(*_eo_instance_set2)(struct __pyx_obj_6eorepo_9eodefault_EoDefault *, unsigned PY_LONG_LONG, struct __pyx_obj_6eorepo_9eodefault_EoDefault *, int __pyx_skip_dispatch);
+};
+static struct __pyx_vtabstruct_6eorepo_9eodefault_EoDefault *__pyx_vtabptr_6eorepo_9eodefault_EoDefault;
+#ifndef CYTHON_REFNANNY
+ #define CYTHON_REFNANNY 0
+#endif
+#if CYTHON_REFNANNY
+ typedef struct {
+ void (*INCREF)(void*, PyObject*, int);
+ void (*DECREF)(void*, PyObject*, int);
+ void (*GOTREF)(void*, PyObject*, int);
+ void (*GIVEREF)(void*, PyObject*, int);
+ void* (*SetupContext)(const char*, int, const char*);
+ void (*FinishContext)(void**);
+ } __Pyx_RefNannyAPIStruct;
+ static __Pyx_RefNannyAPIStruct *__Pyx_RefNanny = NULL;
+ static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname); /*proto*/
+ #define __Pyx_RefNannyDeclarations void *__pyx_refnanny = NULL;
+#ifdef WITH_THREAD
+ #define __Pyx_RefNannySetupContext(name, acquire_gil) \
+ if (acquire_gil) { \
+ PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure(); \
+ __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), __LINE__, __FILE__); \
+ PyGILState_Release(__pyx_gilstate_save); \
+ } else { \
+ __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), __LINE__, __FILE__); \
+ }
+#else
+ #define __Pyx_RefNannySetupContext(name, acquire_gil) \
+ __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), __LINE__, __FILE__)
+#endif
+ #define __Pyx_RefNannyFinishContext() \
+ __Pyx_RefNanny->FinishContext(&__pyx_refnanny)
+ #define __Pyx_INCREF(r) __Pyx_RefNanny->INCREF(__pyx_refnanny, (PyObject *)(r), __LINE__)
+ #define __Pyx_DECREF(r) __Pyx_RefNanny->DECREF(__pyx_refnanny, (PyObject *)(r), __LINE__)
+ #define __Pyx_GOTREF(r) __Pyx_RefNanny->GOTREF(__pyx_refnanny, (PyObject *)(r), __LINE__)
+ #define __Pyx_GIVEREF(r) __Pyx_RefNanny->GIVEREF(__pyx_refnanny, (PyObject *)(r), __LINE__)
+ #define __Pyx_XINCREF(r) do { if((r) != NULL) {__Pyx_INCREF(r); }} while(0)
+ #define __Pyx_XDECREF(r) do { if((r) != NULL) {__Pyx_DECREF(r); }} while(0)
+ #define __Pyx_XGOTREF(r) do { if((r) != NULL) {__Pyx_GOTREF(r); }} while(0)
+ #define __Pyx_XGIVEREF(r) do { if((r) != NULL) {__Pyx_GIVEREF(r);}} while(0)
+#else
+ #define __Pyx_RefNannyDeclarations
+ #define __Pyx_RefNannySetupContext(name, acquire_gil)
+ #define __Pyx_RefNannyFinishContext()
+ #define __Pyx_INCREF(r) Py_INCREF(r)
+ #define __Pyx_DECREF(r) Py_DECREF(r)
+ #define __Pyx_GOTREF(r)
+ #define __Pyx_GIVEREF(r)
+ #define __Pyx_XINCREF(r) Py_XINCREF(r)
+ #define __Pyx_XDECREF(r) Py_XDECREF(r)
+ #define __Pyx_XGOTREF(r)
+ #define __Pyx_XGIVEREF(r)
+#endif /* CYTHON_REFNANNY */
+#define __Pyx_CLEAR(r) do { PyObject* tmp = ((PyObject*)(r)); r = NULL; __Pyx_DECREF(tmp);} while(0)
+#define __Pyx_XCLEAR(r) do { if((r) != NULL) {PyObject* tmp = ((PyObject*)(r)); r = NULL; __Pyx_DECREF(tmp);}} while(0)
+
+static PyObject *__Pyx_GetName(PyObject *dict, PyObject *name); /*proto*/
+
+static CYTHON_INLINE int __Pyx_TypeTest(PyObject *obj, PyTypeObject *type); /*proto*/
+
+static void __Pyx_RaiseArgtupleInvalid(const char* func_name, int exact,
+ Py_ssize_t num_min, Py_ssize_t num_max, Py_ssize_t num_found); /*proto*/
+
+static void __Pyx_RaiseDoubleKeywordsError(const char* func_name, PyObject* kw_name); /*proto*/
+
+static int __Pyx_ParseOptionalKeywords(PyObject *kwds, PyObject **argnames[], \
+ PyObject *kwds2, PyObject *values[], Py_ssize_t num_pos_args, \
+ const char* function_name); /*proto*/
+
+static int __Pyx_ArgTypeTest(PyObject *obj, PyTypeObject *type, int none_allowed,
+ const char *name, int exact); /*proto*/
+
+static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Generic(PyObject *o, PyObject* j) {
+ PyObject *r;
+ if (!j) return NULL;
+ r = PyObject_GetItem(o, j);
+ Py_DECREF(j);
+ return r;
+}
+#define __Pyx_GetItemInt_List(o, i, size, to_py_func) (((size) <= sizeof(Py_ssize_t)) ? \
+ __Pyx_GetItemInt_List_Fast(o, i) : \
+ __Pyx_GetItemInt_Generic(o, to_py_func(i)))
+static CYTHON_INLINE PyObject *__Pyx_GetItemInt_List_Fast(PyObject *o, Py_ssize_t i) {
+#if CYTHON_COMPILING_IN_CPYTHON
+ if (likely((0 <= i) & (i < PyList_GET_SIZE(o)))) {
+ PyObject *r = PyList_GET_ITEM(o, i);
+ Py_INCREF(r);
+ return r;
+ }
+ else if ((-PyList_GET_SIZE(o) <= i) & (i < 0)) {
+ PyObject *r = PyList_GET_ITEM(o, PyList_GET_SIZE(o) + i);
+ Py_INCREF(r);
+ return r;
+ }
+ return __Pyx_GetItemInt_Generic(o, PyInt_FromSsize_t(i));
+#else
+ return PySequence_GetItem(o, i);
+#endif
+}
+#define __Pyx_GetItemInt_Tuple(o, i, size, to_py_func) (((size) <= sizeof(Py_ssize_t)) ? \
+ __Pyx_GetItemInt_Tuple_Fast(o, i) : \
+ __Pyx_GetItemInt_Generic(o, to_py_func(i)))
+static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Tuple_Fast(PyObject *o, Py_ssize_t i) {
+#if CYTHON_COMPILING_IN_CPYTHON
+ if (likely((0 <= i) & (i < PyTuple_GET_SIZE(o)))) {
+ PyObject *r = PyTuple_GET_ITEM(o, i);
+ Py_INCREF(r);
+ return r;
+ }
+ else if ((-PyTuple_GET_SIZE(o) <= i) & (i < 0)) {
+ PyObject *r = PyTuple_GET_ITEM(o, PyTuple_GET_SIZE(o) + i);
+ Py_INCREF(r);
+ return r;
+ }
+ return __Pyx_GetItemInt_Generic(o, PyInt_FromSsize_t(i));
+#else
+ return PySequence_GetItem(o, i);
+#endif
+}
+#define __Pyx_GetItemInt(o, i, size, to_py_func) (((size) <= sizeof(Py_ssize_t)) ? \
+ __Pyx_GetItemInt_Fast(o, i) : \
+ __Pyx_GetItemInt_Generic(o, to_py_func(i)))
+static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Fast(PyObject *o, Py_ssize_t i) {
+#if CYTHON_COMPILING_IN_CPYTHON
+ if (PyList_CheckExact(o)) {
+ Py_ssize_t n = (likely(i >= 0)) ? i : i + PyList_GET_SIZE(o);
+ if (likely((n >= 0) & (n < PyList_GET_SIZE(o)))) {
+ PyObject *r = PyList_GET_ITEM(o, n);
+ Py_INCREF(r);
+ return r;
+ }
+ }
+ else if (PyTuple_CheckExact(o)) {
+ Py_ssize_t n = (likely(i >= 0)) ? i : i + PyTuple_GET_SIZE(o);
+ if (likely((n >= 0) & (n < PyTuple_GET_SIZE(o)))) {
+ PyObject *r = PyTuple_GET_ITEM(o, n);
+ Py_INCREF(r);
+ return r;
+ }
+ } else { /* inlined PySequence_GetItem() */
+ PySequenceMethods *m = Py_TYPE(o)->tp_as_sequence;
+ if (likely(m && m->sq_item)) {
+ if (unlikely(i < 0) && likely(m->sq_length)) {
+ Py_ssize_t l = m->sq_length(o);
+ if (unlikely(l < 0)) return NULL;
+ i += l;
+ }
+ return m->sq_item(o, i);
+ }
+ }
+#else
+ if (PySequence_Check(o)) {
+ return PySequence_GetItem(o, i);
+ }
+#endif
+ return __Pyx_GetItemInt_Generic(o, PyInt_FromSsize_t(i));
+}
+
+#if CYTHON_COMPILING_IN_CPYTHON && PY_MAJOR_VERSION >= 3
+#define __Pyx_PyCallable_Check(obj) ((obj)->ob_type->tp_call != NULL)
+#else
+#define __Pyx_PyCallable_Check(obj) PyCallable_Check(obj)
+#endif
+
+static CYTHON_INLINE void __Pyx_ErrRestore(PyObject *type, PyObject *value, PyObject *tb); /*proto*/
+static CYTHON_INLINE void __Pyx_ErrFetch(PyObject **type, PyObject **value, PyObject **tb); /*proto*/
+
+static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb, PyObject *cause); /*proto*/
+
+static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, long level); /*proto*/
+
+static CYTHON_INLINE void __Pyx_RaiseImportError(PyObject *name);
+
+static PyObject *__Pyx_FindPy2Metaclass(PyObject *bases); /*proto*/
+
+static PyObject *__Pyx_CreateClass(PyObject *bases, PyObject *dict, PyObject *name,
+ PyObject *modname); /*proto*/
+
+#define __Pyx_CyFunction_USED 1
+#include <structmember.h>
+#define __Pyx_CYFUNCTION_STATICMETHOD 0x01
+#define __Pyx_CYFUNCTION_CLASSMETHOD 0x02
+#define __Pyx_CYFUNCTION_CCLASS 0x04
+#define __Pyx_CyFunction_GetClosure(f) \
+ (((__pyx_CyFunctionObject *) (f))->func_closure)
+#define __Pyx_CyFunction_GetClassObj(f) \
+ (((__pyx_CyFunctionObject *) (f))->func_classobj)
+#define __Pyx_CyFunction_Defaults(type, f) \
+ ((type *)(((__pyx_CyFunctionObject *) (f))->defaults))
+#define __Pyx_CyFunction_SetDefaultsGetter(f, g) \
+ ((__pyx_CyFunctionObject *) (f))->defaults_getter = (g)
+typedef struct {
+ PyCFunctionObject func;
+ int flags;
+ PyObject *func_dict;
+ PyObject *func_weakreflist;
+ PyObject *func_name;
+ PyObject *func_doc;
+ PyObject *func_code;
+ PyObject *func_closure;
+ PyObject *func_classobj; /* No-args super() class cell */
+ void *defaults;
+ int defaults_pyobjects;
+ PyObject *defaults_tuple; /* Const defaults tuple */
+ PyObject *(*defaults_getter)(PyObject *);
+} __pyx_CyFunctionObject;
+static PyTypeObject *__pyx_CyFunctionType = 0;
+#define __Pyx_CyFunction_NewEx(ml, flags, self, module, code) \
+ __Pyx_CyFunction_New(__pyx_CyFunctionType, ml, flags, self, module, code)
+static PyObject *__Pyx_CyFunction_New(PyTypeObject *,
+ PyMethodDef *ml, int flags,
+ PyObject *self, PyObject *module,
+ PyObject* code);
+static CYTHON_INLINE void *__Pyx_CyFunction_InitDefaults(PyObject *m,
+ size_t size,
+ int pyobjects);
+static CYTHON_INLINE void __Pyx_CyFunction_SetDefaultsTuple(PyObject *m,
+ PyObject *tuple);
+static int __Pyx_CyFunction_init(void);
+
+static int __Pyx_Print(PyObject*, PyObject *, int); /*proto*/
+#if CYTHON_COMPILING_IN_PYPY || PY_MAJOR_VERSION >= 3
+static PyObject* __pyx_print = 0;
+static PyObject* __pyx_print_kwargs = 0;
+#endif
+
+static int __Pyx_PrintOne(PyObject* stream, PyObject *o); /*proto*/
+
+static CYTHON_INLINE unsigned char __Pyx_PyInt_AsUnsignedChar(PyObject *);
+
+static CYTHON_INLINE unsigned short __Pyx_PyInt_AsUnsignedShort(PyObject *);
+
+static CYTHON_INLINE unsigned int __Pyx_PyInt_AsUnsignedInt(PyObject *);
+
+static CYTHON_INLINE char __Pyx_PyInt_AsChar(PyObject *);
+
+static CYTHON_INLINE short __Pyx_PyInt_AsShort(PyObject *);
+
+static CYTHON_INLINE int __Pyx_PyInt_AsInt(PyObject *);
+
+static CYTHON_INLINE signed char __Pyx_PyInt_AsSignedChar(PyObject *);
+
+static CYTHON_INLINE signed short __Pyx_PyInt_AsSignedShort(PyObject *);
+
+static CYTHON_INLINE signed int __Pyx_PyInt_AsSignedInt(PyObject *);
+
+static CYTHON_INLINE int __Pyx_PyInt_AsLongDouble(PyObject *);
+
+static CYTHON_INLINE unsigned long __Pyx_PyInt_AsUnsignedLong(PyObject *);
+
+static CYTHON_INLINE unsigned PY_LONG_LONG __Pyx_PyInt_AsUnsignedLongLong(PyObject *);
+
+static CYTHON_INLINE long __Pyx_PyInt_AsLong(PyObject *);
+
+static CYTHON_INLINE PY_LONG_LONG __Pyx_PyInt_AsLongLong(PyObject *);
+
+static CYTHON_INLINE signed long __Pyx_PyInt_AsSignedLong(PyObject *);
+
+static CYTHON_INLINE signed PY_LONG_LONG __Pyx_PyInt_AsSignedLongLong(PyObject *);
+
+static int __Pyx_check_binary_version(void);
+
+#if !defined(__Pyx_PyIdentifier_FromString)
+#if PY_MAJOR_VERSION < 3
+ #define __Pyx_PyIdentifier_FromString(s) PyString_FromString(s)
+#else
+ #define __Pyx_PyIdentifier_FromString(s) PyUnicode_FromString(s)
+#endif
+#endif
+
+static PyObject *__Pyx_ImportModule(const char *name); /*proto*/
+
+static PyTypeObject *__Pyx_ImportType(const char *module_name, const char *class_name, size_t size, int strict); /*proto*/
+
+static void* __Pyx_GetVtable(PyObject *dict); /*proto*/
+
+static int __Pyx_ImportFunction(PyObject *module, const char *funcname, void (**f)(void), const char *sig); /*proto*/
+
+typedef struct {
+ int code_line;
+ PyCodeObject* code_object;
+} __Pyx_CodeObjectCacheEntry;
+struct __Pyx_CodeObjectCache {
+ int count;
+ int max_count;
+ __Pyx_CodeObjectCacheEntry* entries;
+};
+static struct __Pyx_CodeObjectCache __pyx_code_cache = {0,0,NULL};
+static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line);
+static PyCodeObject *__pyx_find_code_object(int code_line);
+static void __pyx_insert_code_object(int code_line, PyCodeObject* code_object);
+
+static void __Pyx_AddTraceback(const char *funcname, int c_line,
+ int py_line, const char *filename); /*proto*/
+
+static int __Pyx_InitStrings(__Pyx_StringTabEntry *t); /*proto*/
+
+
+/* Module declarations from 'eorepo.eodefault' */
+static PyTypeObject *__pyx_ptype_6eorepo_9eodefault_EoDefault = 0;
+static Eo *(*__pyx_f_6eorepo_9eodefault__eo_instance_get)(struct __pyx_obj_6eorepo_9eodefault_EoDefault *); /*proto*/
+static Eina_Bool (*__pyx_f_6eorepo_9eodefault__object_callback)(void *, Eo *, Eo_Event_Description *, void *); /*proto*/
+
+/* Module declarations from 'cpython.version' */
+
+/* Module declarations from 'cpython.ref' */
+
+/* Module declarations from 'cpython.exc' */
+
+/* Module declarations from 'cpython.module' */
+
+/* Module declarations from 'cpython.mem' */
+
+/* Module declarations from 'cpython.tuple' */
+
+/* Module declarations from 'cpython.list' */
+
+/* Module declarations from 'libc.stdio' */
+
+/* Module declarations from 'cpython.object' */
+
+/* Module declarations from 'cpython.sequence' */
+
+/* Module declarations from 'cpython.mapping' */
+
+/* Module declarations from 'cpython.iterator' */
+
+/* Module declarations from '__builtin__' */
+
+/* Module declarations from 'cpython.type' */
+static PyTypeObject *__pyx_ptype_7cpython_4type_type = 0;
+
+/* Module declarations from 'cpython.number' */
+
+/* Module declarations from 'cpython.int' */
+
+/* Module declarations from '__builtin__' */
+
+/* Module declarations from 'cpython.bool' */
+static PyTypeObject *__pyx_ptype_7cpython_4bool_bool = 0;
+
+/* Module declarations from 'cpython.long' */
+
+/* Module declarations from 'cpython.float' */
+
+/* Module declarations from '__builtin__' */
+
+/* Module declarations from 'cpython.complex' */
+static PyTypeObject *__pyx_ptype_7cpython_7complex_complex = 0;
+
+/* Module declarations from 'cpython.string' */
+
+/* Module declarations from 'cpython.unicode' */
+
+/* Module declarations from 'cpython.dict' */
+
+/* Module declarations from 'cpython.instance' */
+
+/* Module declarations from 'cpython.function' */
+
+/* Module declarations from 'cpython.method' */
+
+/* Module declarations from 'cpython.weakref' */
+
+/* Module declarations from 'cpython.getargs' */
+
+/* Module declarations from 'cpython.pythread' */
+
+/* Module declarations from 'cpython.pystate' */
+
+/* Module declarations from 'cpython.cobject' */
+
+/* Module declarations from 'cpython.oldbuffer' */
+
+/* Module declarations from 'cpython.set' */
+
+/* Module declarations from 'cpython.buffer' */
+
+/* Module declarations from 'cpython.bytes' */
+
+/* Module declarations from 'cpython.pycapsule' */
+
+/* Module declarations from 'cpython' */
+
+/* Module declarations from 'eorepo.eobase' */
+static int __pyx_f_6eorepo_6eobase_eobase_sub_id(int); /*proto*/
+#define __Pyx_MODULE_NAME "eorepo.eobase"
+int __pyx_module_is_main_eorepo__eobase = 0;
+
+/* Implementation of 'eorepo.eobase' */
+static PyObject *__pyx_builtin_staticmethod;
+static PyObject *__pyx_builtin_exit;
+static PyObject *__pyx_builtin_TypeError;
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_event_thaw(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self); /* proto */
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_2event_freeze(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self); /* proto */
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_4__init__(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, CYTHON_UNUSED struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_parent); /* proto */
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_6event_global_freeze_get(CYTHON_UNUSED PyObject *__pyx_self); /* proto */
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_8event_global_freeze(CYTHON_UNUSED PyObject *__pyx_self); /* proto */
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_10data_get(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, PyObject *__pyx_v__key); /* proto */
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_12event_callback_del(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, long __pyx_v__desc, PyObject *__pyx_v__func); /* proto */
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_14event_freeze_get(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self); /* proto */
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_16event_global_thaw(CYTHON_UNUSED PyObject *__pyx_self); /* proto */
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_18data_del(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, PyObject *__pyx_v__key); /* proto */
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_20event_callback_call(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, long __pyx_v__desc, PyObject *__pyx_v__event_info); /* proto */
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_22event_callback_priority_add(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, long __pyx_v__desc, int __pyx_v__priority, PyObject *__pyx_v__cb); /* proto */
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_24data_set(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, PyObject *__pyx_v__key, PyObject *__pyx_v__data); /* proto */
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_26_data_set(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, PyObject *__pyx_v__key, PyObject *__pyx_v__data); /* proto */
+static char __pyx_k_1[] = "Class '%s' is not instantiate-able. Aborting.";
+static char __pyx_k_3[] = "func must be callable";
+static char __pyx_k_5[] = "eorepo.eodefault";
+static char __pyx_k_8[] = "/home/yakov/eo_bindings/eorepo/eobase.pxi";
+static char __pyx_k_9[] = "eorepo.eobase";
+static char __pyx_k_16[] = "event_global_freeze_get";
+static char __pyx_k_31[] = "event_callback_priority_add";
+static char __pyx_k__cb[] = "cb";
+static char __pyx_k__DEL[] = "DEL";
+static char __pyx_k___cb[] = "_cb";
+static char __pyx_k__key[] = "key";
+static char __pyx_k___key[] = "_key";
+static char __pyx_k__data[] = "data";
+static char __pyx_k__desc[] = "desc";
+static char __pyx_k__exit[] = "exit";
+static char __pyx_k__func[] = "func";
+static char __pyx_k__self[] = "self";
+static char __pyx_k___data[] = "_data";
+static char __pyx_k___desc[] = "_desc";
+static char __pyx_k___func[] = "_func";
+static char __pyx_k__data_[] = "data_";
+static char __pyx_k__EoBase[] = "EoBase";
+static char __pyx_k__fcount[] = "fcount";
+static char __pyx_k__parent[] = "parent";
+static char __pyx_k__aborted[] = "aborted";
+static char __pyx_k__fcount_[] = "fcount_";
+static char __pyx_k____init__[] = "__init__";
+static char __pyx_k____main__[] = "__main__";
+static char __pyx_k____name__[] = "__name__";
+static char __pyx_k____test__[] = "__test__";
+static char __pyx_k__aborted_[] = "aborted_";
+static char __pyx_k__data_del[] = "data_del";
+static char __pyx_k__data_get[] = "data_get";
+static char __pyx_k__data_set[] = "data_set";
+static char __pyx_k__EoDefault[] = "EoDefault";
+static char __pyx_k__TypeError[] = "TypeError";
+static char __pyx_k____class__[] = "__class__";
+static char __pyx_k___data_set[] = "_data_set";
+static char __pyx_k___priority[] = "_priority";
+static char __pyx_k__eodefault[] = "eodefault";
+static char __pyx_k__event_info[] = "event_info";
+static char __pyx_k__event_thaw[] = "event_thaw";
+static char __pyx_k___event_info[] = "_event_info";
+static char __pyx_k__CALLBACK_ADD[] = "CALLBACK_ADD";
+static char __pyx_k__CALLBACK_DEL[] = "CALLBACK_DEL";
+static char __pyx_k__event_freeze[] = "event_freeze";
+static char __pyx_k__staticmethod[] = "staticmethod";
+static char __pyx_k__pytext_to_utf8[] = "pytext_to_utf8";
+static char __pyx_k__instantiateable[] = "instantiateable";
+static char __pyx_k__event_freeze_get[] = "event_freeze_get";
+static char __pyx_k__event_global_thaw[] = "event_global_thaw";
+static char __pyx_k__event_callback_del[] = "event_callback_del";
+static char __pyx_k__event_callback_call[] = "event_callback_call";
+static char __pyx_k__event_global_freeze[] = "event_global_freeze";
+static PyObject *__pyx_kp_s_1;
+static PyObject *__pyx_n_s_16;
+static PyObject *__pyx_kp_s_3;
+static PyObject *__pyx_n_s_31;
+static PyObject *__pyx_n_s_5;
+static PyObject *__pyx_kp_s_8;
+static PyObject *__pyx_n_s_9;
+static PyObject *__pyx_n_s__CALLBACK_ADD;
+static PyObject *__pyx_n_s__CALLBACK_DEL;
+static PyObject *__pyx_n_s__DEL;
+static PyObject *__pyx_n_s__EoBase;
+static PyObject *__pyx_n_s__EoDefault;
+static PyObject *__pyx_n_s__TypeError;
+static PyObject *__pyx_n_s____class__;
+static PyObject *__pyx_n_s____init__;
+static PyObject *__pyx_n_s____main__;
+static PyObject *__pyx_n_s____name__;
+static PyObject *__pyx_n_s____test__;
+static PyObject *__pyx_n_s___cb;
+static PyObject *__pyx_n_s___data;
+static PyObject *__pyx_n_s___data_set;
+static PyObject *__pyx_n_s___desc;
+static PyObject *__pyx_n_s___event_info;
+static PyObject *__pyx_n_s___func;
+static PyObject *__pyx_n_s___key;
+static PyObject *__pyx_n_s___priority;
+static PyObject *__pyx_n_s__aborted;
+static PyObject *__pyx_n_s__aborted_;
+static PyObject *__pyx_n_s__cb;
+static PyObject *__pyx_n_s__data;
+static PyObject *__pyx_n_s__data_;
+static PyObject *__pyx_n_s__data_del;
+static PyObject *__pyx_n_s__data_get;
+static PyObject *__pyx_n_s__data_set;
+static PyObject *__pyx_n_s__desc;
+static PyObject *__pyx_n_s__eodefault;
+static PyObject *__pyx_n_s__event_callback_call;
+static PyObject *__pyx_n_s__event_callback_del;
+static PyObject *__pyx_n_s__event_freeze;
+static PyObject *__pyx_n_s__event_freeze_get;
+static PyObject *__pyx_n_s__event_global_freeze;
+static PyObject *__pyx_n_s__event_global_thaw;
+static PyObject *__pyx_n_s__event_info;
+static PyObject *__pyx_n_s__event_thaw;
+static PyObject *__pyx_n_s__exit;
+static PyObject *__pyx_n_s__fcount;
+static PyObject *__pyx_n_s__fcount_;
+static PyObject *__pyx_n_s__func;
+static PyObject *__pyx_n_s__instantiateable;
+static PyObject *__pyx_n_s__key;
+static PyObject *__pyx_n_s__parent;
+static PyObject *__pyx_n_s__pytext_to_utf8;
+static PyObject *__pyx_n_s__self;
+static PyObject *__pyx_n_s__staticmethod;
+static PyObject *__pyx_int_1;
+static PyObject *__pyx_k_tuple_2;
+static PyObject *__pyx_k_tuple_4;
+static PyObject *__pyx_k_tuple_6;
+static PyObject *__pyx_k_tuple_10;
+static PyObject *__pyx_k_tuple_12;
+static PyObject *__pyx_k_tuple_14;
+static PyObject *__pyx_k_tuple_18;
+static PyObject *__pyx_k_tuple_20;
+static PyObject *__pyx_k_tuple_22;
+static PyObject *__pyx_k_tuple_25;
+static PyObject *__pyx_k_tuple_27;
+static PyObject *__pyx_k_tuple_29;
+static PyObject *__pyx_k_tuple_32;
+static PyObject *__pyx_k_tuple_34;
+static PyObject *__pyx_k_codeobj_7;
+static PyObject *__pyx_k_codeobj_11;
+static PyObject *__pyx_k_codeobj_13;
+static PyObject *__pyx_k_codeobj_15;
+static PyObject *__pyx_k_codeobj_17;
+static PyObject *__pyx_k_codeobj_19;
+static PyObject *__pyx_k_codeobj_21;
+static PyObject *__pyx_k_codeobj_23;
+static PyObject *__pyx_k_codeobj_24;
+static PyObject *__pyx_k_codeobj_26;
+static PyObject *__pyx_k_codeobj_28;
+static PyObject *__pyx_k_codeobj_30;
+static PyObject *__pyx_k_codeobj_33;
+static PyObject *__pyx_k_codeobj_35;
+
+/* "/home/yakov/eo_bindings/eorepo/eobase.pxi":14
+ * from eorepo.eodefault import pytext_to_utf8
+ *
+ * cdef int eobase_sub_id(int sub_id): # <<<<<<<<<<<<<<
+ * return eobase.EO_BASE_BASE_ID + sub_id
+ *
+ */
+
+static int __pyx_f_6eorepo_6eobase_eobase_sub_id(int __pyx_v_sub_id) {
+ int __pyx_r;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("eobase_sub_id", 0);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":15
+ *
+ * cdef int eobase_sub_id(int sub_id):
+ * return eobase.EO_BASE_BASE_ID + sub_id # <<<<<<<<<<<<<<
+ *
+ * class EoBase(EoDefault):
+ */
+ __pyx_r = (EO_BASE_BASE_ID + __pyx_v_sub_id);
+ goto __pyx_L0;
+
+ __pyx_r = 0;
+ __pyx_L0:;
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_1event_thaw(PyObject *__pyx_self, PyObject *__pyx_v_self); /*proto*/
+static PyMethodDef __pyx_mdef_6eorepo_6eobase_6EoBase_1event_thaw = {__Pyx_NAMESTR("event_thaw"), (PyCFunction)__pyx_pw_6eorepo_6eobase_6EoBase_1event_thaw, METH_O, __Pyx_DOCSTR(0)};
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_1event_thaw(PyObject *__pyx_self, PyObject *__pyx_v_self) {
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("event_thaw (wrapper)", 0);
+ __pyx_r = __pyx_pf_6eorepo_6eobase_6EoBase_event_thaw(__pyx_self, ((PyObject *)__pyx_v_self));
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "/home/yakov/eo_bindings/eorepo/eobase.pxi":23
+ * CALLBACK_ADD = <long>eobase.EO_EV_CALLBACK_ADD
+ *
+ * def event_thaw(self): # <<<<<<<<<<<<<<
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_THAW))
+ *
+ */
+
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_event_thaw(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self) {
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("event_thaw", 0);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":24
+ *
+ * def event_thaw(self):
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_THAW)) # <<<<<<<<<<<<<<
+ *
+ * def event_freeze(self):
+ */
+ if (!(likely(((__pyx_v_self) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_self, __pyx_ptype_6eorepo_9eodefault_EoDefault))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 24; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_t_1 = __pyx_v_self;
+ __Pyx_INCREF(__pyx_t_1);
+ eo_do(__pyx_f_6eorepo_9eodefault__eo_instance_get(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_t_1)), __pyx_f_6eorepo_6eobase_eobase_sub_id(EO_BASE_SUB_ID_EVENT_THAW));
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.event_thaw", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_3event_freeze(PyObject *__pyx_self, PyObject *__pyx_v_self); /*proto*/
+static PyMethodDef __pyx_mdef_6eorepo_6eobase_6EoBase_3event_freeze = {__Pyx_NAMESTR("event_freeze"), (PyCFunction)__pyx_pw_6eorepo_6eobase_6EoBase_3event_freeze, METH_O, __Pyx_DOCSTR(0)};
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_3event_freeze(PyObject *__pyx_self, PyObject *__pyx_v_self) {
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("event_freeze (wrapper)", 0);
+ __pyx_r = __pyx_pf_6eorepo_6eobase_6EoBase_2event_freeze(__pyx_self, ((PyObject *)__pyx_v_self));
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "/home/yakov/eo_bindings/eorepo/eobase.pxi":26
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_THAW))
+ *
+ * def event_freeze(self): # <<<<<<<<<<<<<<
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_FREEZE))
+ *
+ */
+
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_2event_freeze(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self) {
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("event_freeze", 0);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":27
+ *
+ * def event_freeze(self):
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_FREEZE)) # <<<<<<<<<<<<<<
+ *
+ * def __init__(self, EoDefault parent):
+ */
+ if (!(likely(((__pyx_v_self) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_self, __pyx_ptype_6eorepo_9eodefault_EoDefault))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 27; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_t_1 = __pyx_v_self;
+ __Pyx_INCREF(__pyx_t_1);
+ eo_do(__pyx_f_6eorepo_9eodefault__eo_instance_get(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_t_1)), __pyx_f_6eorepo_6eobase_eobase_sub_id(EO_BASE_SUB_ID_EVENT_FREEZE));
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.event_freeze", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_5__init__(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
+static PyMethodDef __pyx_mdef_6eorepo_6eobase_6EoBase_5__init__ = {__Pyx_NAMESTR("__init__"), (PyCFunction)__pyx_pw_6eorepo_6eobase_6EoBase_5__init__, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)};
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_5__init__(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
+ PyObject *__pyx_v_self = 0;
+ CYTHON_UNUSED struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_parent = 0;
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("__init__ (wrapper)", 0);
+ {
+ static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__self,&__pyx_n_s__parent,0};
+ PyObject* values[2] = {0,0};
+ if (unlikely(__pyx_kwds)) {
+ Py_ssize_t kw_args;
+ const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
+ switch (pos_args) {
+ case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ case 0: break;
+ default: goto __pyx_L5_argtuple_error;
+ }
+ kw_args = PyDict_Size(__pyx_kwds);
+ switch (pos_args) {
+ case 0:
+ if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__self)) != 0)) kw_args--;
+ else goto __pyx_L5_argtuple_error;
+ case 1:
+ if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__parent)) != 0)) kw_args--;
+ else {
+ __Pyx_RaiseArgtupleInvalid("__init__", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 29; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ }
+ if (unlikely(kw_args > 0)) {
+ if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "__init__") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 29; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ } else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
+ goto __pyx_L5_argtuple_error;
+ } else {
+ values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ }
+ __pyx_v_self = values[0];
+ __pyx_v_parent = ((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)values[1]);
+ }
+ goto __pyx_L4_argument_unpacking_done;
+ __pyx_L5_argtuple_error:;
+ __Pyx_RaiseArgtupleInvalid("__init__", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 29; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ __pyx_L3_error:;
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __Pyx_RefNannyFinishContext();
+ return NULL;
+ __pyx_L4_argument_unpacking_done:;
+ if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_parent), __pyx_ptype_6eorepo_9eodefault_EoDefault, 1, "parent", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 29; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_r = __pyx_pf_6eorepo_6eobase_6EoBase_4__init__(__pyx_self, __pyx_v_self, __pyx_v_parent);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "/home/yakov/eo_bindings/eorepo/eobase.pxi":29
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_FREEZE))
+ *
+ * def __init__(self, EoDefault parent): # <<<<<<<<<<<<<<
+ * instantiateable = False
+ * if not instantiateable:
+ */
+
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_4__init__(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, CYTHON_UNUSED struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_parent) {
+ int __pyx_v_instantiateable;
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ int __pyx_t_1;
+ PyObject *__pyx_t_2 = NULL;
+ PyObject *__pyx_t_3 = NULL;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("__init__", 0);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":30
+ *
+ * def __init__(self, EoDefault parent):
+ * instantiateable = False # <<<<<<<<<<<<<<
+ * if not instantiateable:
+ * print "Class '%s' is not instantiate-able. Aborting."%(self.__class__.__name__)
+ */
+ __pyx_v_instantiateable = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":31
+ * def __init__(self, EoDefault parent):
+ * instantiateable = False
+ * if not instantiateable: # <<<<<<<<<<<<<<
+ * print "Class '%s' is not instantiate-able. Aborting."%(self.__class__.__name__)
+ * exit(1)
+ */
+ __pyx_t_1 = (!__pyx_v_instantiateable);
+ if (__pyx_t_1) {
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":32
+ * instantiateable = False
+ * if not instantiateable:
+ * print "Class '%s' is not instantiate-able. Aborting."%(self.__class__.__name__) # <<<<<<<<<<<<<<
+ * exit(1)
+ *
+ */
+ __pyx_t_2 = PyObject_GetAttr(__pyx_v_self, __pyx_n_s____class__); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 32; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_2);
+ __pyx_t_3 = PyObject_GetAttr(__pyx_t_2, __pyx_n_s____name__); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 32; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+ __pyx_t_2 = PyNumber_Remainder(((PyObject *)__pyx_kp_s_1), __pyx_t_3); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 32; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(((PyObject *)__pyx_t_2));
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+ if (__Pyx_PrintOne(0, ((PyObject *)__pyx_t_2)) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 32; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":33
+ * if not instantiateable:
+ * print "Class '%s' is not instantiate-able. Aborting."%(self.__class__.__name__)
+ * exit(1) # <<<<<<<<<<<<<<
+ *
+ *
+ */
+ __pyx_t_2 = PyObject_Call(__pyx_builtin_exit, ((PyObject *)__pyx_k_tuple_2), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 33; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_2);
+ __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+ goto __pyx_L3;
+ }
+ __pyx_L3:;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_2);
+ __Pyx_XDECREF(__pyx_t_3);
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.__init__", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_7event_global_freeze_get(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused); /*proto*/
+static PyMethodDef __pyx_mdef_6eorepo_6eobase_6EoBase_7event_global_freeze_get = {__Pyx_NAMESTR("event_global_freeze_get"), (PyCFunction)__pyx_pw_6eorepo_6eobase_6EoBase_7event_global_freeze_get, METH_NOARGS, __Pyx_DOCSTR(0)};
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_7event_global_freeze_get(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused) {
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("event_global_freeze_get (wrapper)", 0);
+ __pyx_r = __pyx_pf_6eorepo_6eobase_6EoBase_6event_global_freeze_get(__pyx_self);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "/home/yakov/eo_bindings/eorepo/eobase.pxi":37
+ *
+ * @staticmethod
+ * def event_global_freeze_get(): # <<<<<<<<<<<<<<
+ * cdef int fcount
+ * eodefault.eo_class_do(eobase.eo_base_class_get(), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE_GET), &fcount)
+ */
+
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_6event_global_freeze_get(CYTHON_UNUSED PyObject *__pyx_self) {
+ int __pyx_v_fcount;
+ PyObject *__pyx_v_fcount_ = NULL;
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("event_global_freeze_get", 0);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":39
+ * def event_global_freeze_get():
+ * cdef int fcount
+ * eodefault.eo_class_do(eobase.eo_base_class_get(), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE_GET), &fcount) # <<<<<<<<<<<<<<
+ * fcount_ = <object>fcount
+ * return (fcount_)
+ */
+ eo_class_do(eo_base_class_get(), __pyx_f_6eorepo_6eobase_eobase_sub_id(EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE_GET), (&__pyx_v_fcount));
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":40
+ * cdef int fcount
+ * eodefault.eo_class_do(eobase.eo_base_class_get(), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE_GET), &fcount)
+ * fcount_ = <object>fcount # <<<<<<<<<<<<<<
+ * return (fcount_)
+ *
+ */
+ __pyx_t_1 = PyInt_FromLong(__pyx_v_fcount); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 40; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __Pyx_INCREF(((PyObject *)__pyx_t_1));
+ __pyx_v_fcount_ = __pyx_t_1;
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":41
+ * eodefault.eo_class_do(eobase.eo_base_class_get(), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE_GET), &fcount)
+ * fcount_ = <object>fcount
+ * return (fcount_) # <<<<<<<<<<<<<<
+ *
+ *
+ */
+ __Pyx_XDECREF(__pyx_r);
+ __Pyx_INCREF(__pyx_v_fcount_);
+ __pyx_r = __pyx_v_fcount_;
+ goto __pyx_L0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.event_global_freeze_get", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XDECREF(__pyx_v_fcount_);
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_9event_global_freeze(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused); /*proto*/
+static PyMethodDef __pyx_mdef_6eorepo_6eobase_6EoBase_9event_global_freeze = {__Pyx_NAMESTR("event_global_freeze"), (PyCFunction)__pyx_pw_6eorepo_6eobase_6EoBase_9event_global_freeze, METH_NOARGS, __Pyx_DOCSTR(0)};
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_9event_global_freeze(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused) {
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("event_global_freeze (wrapper)", 0);
+ __pyx_r = __pyx_pf_6eorepo_6eobase_6EoBase_8event_global_freeze(__pyx_self);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "/home/yakov/eo_bindings/eorepo/eobase.pxi":45
+ *
+ * @staticmethod
+ * def event_global_freeze(): # <<<<<<<<<<<<<<
+ * eodefault.eo_class_do(eobase.eo_base_class_get(), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE))
+ *
+ */
+
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_8event_global_freeze(CYTHON_UNUSED PyObject *__pyx_self) {
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("event_global_freeze", 0);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":46
+ * @staticmethod
+ * def event_global_freeze():
+ * eodefault.eo_class_do(eobase.eo_base_class_get(), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE)) # <<<<<<<<<<<<<<
+ *
+ *
+ */
+ eo_class_do(eo_base_class_get(), __pyx_f_6eorepo_6eobase_eobase_sub_id(EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE));
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_11data_get(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
+static PyMethodDef __pyx_mdef_6eorepo_6eobase_6EoBase_11data_get = {__Pyx_NAMESTR("data_get"), (PyCFunction)__pyx_pw_6eorepo_6eobase_6EoBase_11data_get, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)};
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_11data_get(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
+ PyObject *__pyx_v_self = 0;
+ PyObject *__pyx_v__key = 0;
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("data_get (wrapper)", 0);
+ {
+ static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__self,&__pyx_n_s___key,0};
+ PyObject* values[2] = {0,0};
+ if (unlikely(__pyx_kwds)) {
+ Py_ssize_t kw_args;
+ const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
+ switch (pos_args) {
+ case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ case 0: break;
+ default: goto __pyx_L5_argtuple_error;
+ }
+ kw_args = PyDict_Size(__pyx_kwds);
+ switch (pos_args) {
+ case 0:
+ if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__self)) != 0)) kw_args--;
+ else goto __pyx_L5_argtuple_error;
+ case 1:
+ if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s___key)) != 0)) kw_args--;
+ else {
+ __Pyx_RaiseArgtupleInvalid("data_get", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 49; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ }
+ if (unlikely(kw_args > 0)) {
+ if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "data_get") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 49; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ } else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
+ goto __pyx_L5_argtuple_error;
+ } else {
+ values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ }
+ __pyx_v_self = values[0];
+ __pyx_v__key = values[1];
+ }
+ goto __pyx_L4_argument_unpacking_done;
+ __pyx_L5_argtuple_error:;
+ __Pyx_RaiseArgtupleInvalid("data_get", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 49; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ __pyx_L3_error:;
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.data_get", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __Pyx_RefNannyFinishContext();
+ return NULL;
+ __pyx_L4_argument_unpacking_done:;
+ __pyx_r = __pyx_pf_6eorepo_6eobase_6EoBase_10data_get(__pyx_self, __pyx_v_self, __pyx_v__key);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "/home/yakov/eo_bindings/eorepo/eobase.pxi":49
+ *
+ *
+ * def data_get(self, object _key): # <<<<<<<<<<<<<<
+ * _key = None if _key is None else pytext_to_utf8(_key)
+ * cdef char* key = NULL if _key is None else <char*> _key
+ */
+
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_10data_get(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, PyObject *__pyx_v__key) {
+ char *__pyx_v_key;
+ void *__pyx_v_data;
+ PyObject *__pyx_v_data_ = NULL;
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ int __pyx_t_2;
+ PyObject *__pyx_t_3 = NULL;
+ PyObject *__pyx_t_4 = NULL;
+ PyObject *__pyx_t_5 = NULL;
+ void *__pyx_t_6;
+ char *__pyx_t_7;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("data_get", 0);
+ __Pyx_INCREF(__pyx_v__key);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":50
+ *
+ * def data_get(self, object _key):
+ * _key = None if _key is None else pytext_to_utf8(_key) # <<<<<<<<<<<<<<
+ * cdef char* key = NULL if _key is None else <char*> _key
+ * cdef void* data
+ */
+ __pyx_t_2 = (__pyx_v__key == Py_None);
+ if (__pyx_t_2) {
+ __Pyx_INCREF(Py_None);
+ __pyx_t_1 = Py_None;
+ } else {
+ __pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__pytext_to_utf8); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 50; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __pyx_t_4 = PyTuple_New(1); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 50; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_4);
+ __Pyx_INCREF(__pyx_v__key);
+ PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_v__key);
+ __Pyx_GIVEREF(__pyx_v__key);
+ __pyx_t_5 = PyObject_Call(__pyx_t_3, ((PyObject *)__pyx_t_4), NULL); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 50; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_5);
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+ __Pyx_DECREF(((PyObject *)__pyx_t_4)); __pyx_t_4 = 0;
+ __pyx_t_1 = __pyx_t_5;
+ __pyx_t_5 = 0;
+ }
+ __Pyx_DECREF(__pyx_v__key);
+ __pyx_v__key = __pyx_t_1;
+ __pyx_t_1 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":51
+ * def data_get(self, object _key):
+ * _key = None if _key is None else pytext_to_utf8(_key)
+ * cdef char* key = NULL if _key is None else <char*> _key # <<<<<<<<<<<<<<
+ * cdef void* data
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_GET), key, &data)
+ */
+ __pyx_t_2 = (__pyx_v__key == Py_None);
+ if (__pyx_t_2) {
+ __pyx_t_6 = NULL;
+ } else {
+ __pyx_t_7 = PyBytes_AsString(__pyx_v__key); if (unlikely((!__pyx_t_7) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 51; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_t_6 = ((char *)__pyx_t_7);
+ }
+ __pyx_v_key = __pyx_t_6;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":53
+ * cdef char* key = NULL if _key is None else <char*> _key
+ * cdef void* data
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_GET), key, &data) # <<<<<<<<<<<<<<
+ * data_ = None if data == NULL else <object>data
+ * return (data_)
+ */
+ if (!(likely(((__pyx_v_self) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_self, __pyx_ptype_6eorepo_9eodefault_EoDefault))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 53; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_t_1 = __pyx_v_self;
+ __Pyx_INCREF(__pyx_t_1);
+ eo_do(__pyx_f_6eorepo_9eodefault__eo_instance_get(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_t_1)), __pyx_f_6eorepo_6eobase_eobase_sub_id(EO_BASE_SUB_ID_DATA_GET), __pyx_v_key, (&__pyx_v_data));
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":54
+ * cdef void* data
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_GET), key, &data)
+ * data_ = None if data == NULL else <object>data # <<<<<<<<<<<<<<
+ * return (data_)
+ *
+ */
+ if ((__pyx_v_data == NULL)) {
+ __Pyx_INCREF(Py_None);
+ __pyx_t_1 = Py_None;
+ } else {
+ __Pyx_INCREF(((PyObject *)__pyx_v_data));
+ __pyx_t_1 = ((PyObject *)__pyx_v_data);
+ }
+ __pyx_v_data_ = __pyx_t_1;
+ __pyx_t_1 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":55
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_GET), key, &data)
+ * data_ = None if data == NULL else <object>data
+ * return (data_) # <<<<<<<<<<<<<<
+ *
+ * def event_callback_del(self, long _desc, object _func):
+ */
+ __Pyx_XDECREF(__pyx_r);
+ __Pyx_INCREF(__pyx_v_data_);
+ __pyx_r = __pyx_v_data_;
+ goto __pyx_L0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_XDECREF(__pyx_t_3);
+ __Pyx_XDECREF(__pyx_t_4);
+ __Pyx_XDECREF(__pyx_t_5);
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.data_get", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XDECREF(__pyx_v_data_);
+ __Pyx_XDECREF(__pyx_v__key);
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_13event_callback_del(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
+static PyMethodDef __pyx_mdef_6eorepo_6eobase_6EoBase_13event_callback_del = {__Pyx_NAMESTR("event_callback_del"), (PyCFunction)__pyx_pw_6eorepo_6eobase_6EoBase_13event_callback_del, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)};
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_13event_callback_del(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
+ PyObject *__pyx_v_self = 0;
+ long __pyx_v__desc;
+ PyObject *__pyx_v__func = 0;
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("event_callback_del (wrapper)", 0);
+ {
+ static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__self,&__pyx_n_s___desc,&__pyx_n_s___func,0};
+ PyObject* values[3] = {0,0,0};
+ if (unlikely(__pyx_kwds)) {
+ Py_ssize_t kw_args;
+ const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
+ switch (pos_args) {
+ case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
+ case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ case 0: break;
+ default: goto __pyx_L5_argtuple_error;
+ }
+ kw_args = PyDict_Size(__pyx_kwds);
+ switch (pos_args) {
+ case 0:
+ if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__self)) != 0)) kw_args--;
+ else goto __pyx_L5_argtuple_error;
+ case 1:
+ if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s___desc)) != 0)) kw_args--;
+ else {
+ __Pyx_RaiseArgtupleInvalid("event_callback_del", 1, 3, 3, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 57; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ case 2:
+ if (likely((values[2] = PyDict_GetItem(__pyx_kwds, __pyx_n_s___func)) != 0)) kw_args--;
+ else {
+ __Pyx_RaiseArgtupleInvalid("event_callback_del", 1, 3, 3, 2); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 57; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ }
+ if (unlikely(kw_args > 0)) {
+ if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "event_callback_del") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 57; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ } else if (PyTuple_GET_SIZE(__pyx_args) != 3) {
+ goto __pyx_L5_argtuple_error;
+ } else {
+ values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
+ }
+ __pyx_v_self = values[0];
+ __pyx_v__desc = __Pyx_PyInt_AsLong(values[1]); if (unlikely((__pyx_v__desc == (long)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 57; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ __pyx_v__func = values[2];
+ }
+ goto __pyx_L4_argument_unpacking_done;
+ __pyx_L5_argtuple_error:;
+ __Pyx_RaiseArgtupleInvalid("event_callback_del", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 57; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ __pyx_L3_error:;
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.event_callback_del", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __Pyx_RefNannyFinishContext();
+ return NULL;
+ __pyx_L4_argument_unpacking_done:;
+ __pyx_r = __pyx_pf_6eorepo_6eobase_6EoBase_12event_callback_del(__pyx_self, __pyx_v_self, __pyx_v__desc, __pyx_v__func);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "/home/yakov/eo_bindings/eorepo/eobase.pxi":57
+ * return (data_)
+ *
+ * def event_callback_del(self, long _desc, object _func): # <<<<<<<<<<<<<<
+ * cdef Eo_Event_Cb func = <Eo_Event_Cb> eodefault._object_callback
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_DEL), _desc, func, <void*>_func)
+ */
+
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_12event_callback_del(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, long __pyx_v__desc, PyObject *__pyx_v__func) {
+ Eo_Event_Cb __pyx_v_func;
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("event_callback_del", 0);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":58
+ *
+ * def event_callback_del(self, long _desc, object _func):
+ * cdef Eo_Event_Cb func = <Eo_Event_Cb> eodefault._object_callback # <<<<<<<<<<<<<<
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_DEL), _desc, func, <void*>_func)
+ * Py_DECREF(_func)
+ */
+ __pyx_v_func = ((Eo_Event_Cb)__pyx_f_6eorepo_9eodefault__object_callback);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":59
+ * def event_callback_del(self, long _desc, object _func):
+ * cdef Eo_Event_Cb func = <Eo_Event_Cb> eodefault._object_callback
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_DEL), _desc, func, <void*>_func) # <<<<<<<<<<<<<<
+ * Py_DECREF(_func)
+ *
+ */
+ if (!(likely(((__pyx_v_self) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_self, __pyx_ptype_6eorepo_9eodefault_EoDefault))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 59; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_t_1 = __pyx_v_self;
+ __Pyx_INCREF(__pyx_t_1);
+ eo_do(__pyx_f_6eorepo_9eodefault__eo_instance_get(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_t_1)), __pyx_f_6eorepo_6eobase_eobase_sub_id(EO_BASE_SUB_ID_EVENT_CALLBACK_DEL), __pyx_v__desc, __pyx_v_func, ((void *)__pyx_v__func));
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":60
+ * cdef Eo_Event_Cb func = <Eo_Event_Cb> eodefault._object_callback
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_DEL), _desc, func, <void*>_func)
+ * Py_DECREF(_func) # <<<<<<<<<<<<<<
+ *
+ *
+ */
+ Py_DECREF(__pyx_v__func);
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.event_callback_del", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_15event_freeze_get(PyObject *__pyx_self, PyObject *__pyx_v_self); /*proto*/
+static PyMethodDef __pyx_mdef_6eorepo_6eobase_6EoBase_15event_freeze_get = {__Pyx_NAMESTR("event_freeze_get"), (PyCFunction)__pyx_pw_6eorepo_6eobase_6EoBase_15event_freeze_get, METH_O, __Pyx_DOCSTR(0)};
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_15event_freeze_get(PyObject *__pyx_self, PyObject *__pyx_v_self) {
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("event_freeze_get (wrapper)", 0);
+ __pyx_r = __pyx_pf_6eorepo_6eobase_6EoBase_14event_freeze_get(__pyx_self, ((PyObject *)__pyx_v_self));
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "/home/yakov/eo_bindings/eorepo/eobase.pxi":65
+ *
+ *
+ * def event_freeze_get(self): # <<<<<<<<<<<<<<
+ * cdef int fcount
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_FREEZE_GET), &fcount)
+ */
+
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_14event_freeze_get(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self) {
+ int __pyx_v_fcount;
+ PyObject *__pyx_v_fcount_ = NULL;
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("event_freeze_get", 0);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":67
+ * def event_freeze_get(self):
+ * cdef int fcount
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_FREEZE_GET), &fcount) # <<<<<<<<<<<<<<
+ * fcount_ = <object>fcount
+ * return (fcount_)
+ */
+ if (!(likely(((__pyx_v_self) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_self, __pyx_ptype_6eorepo_9eodefault_EoDefault))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 67; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_t_1 = __pyx_v_self;
+ __Pyx_INCREF(__pyx_t_1);
+ eo_do(__pyx_f_6eorepo_9eodefault__eo_instance_get(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_t_1)), __pyx_f_6eorepo_6eobase_eobase_sub_id(EO_BASE_SUB_ID_EVENT_FREEZE_GET), (&__pyx_v_fcount));
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":68
+ * cdef int fcount
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_FREEZE_GET), &fcount)
+ * fcount_ = <object>fcount # <<<<<<<<<<<<<<
+ * return (fcount_)
+ *
+ */
+ __pyx_t_1 = PyInt_FromLong(__pyx_v_fcount); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 68; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __Pyx_INCREF(((PyObject *)__pyx_t_1));
+ __pyx_v_fcount_ = __pyx_t_1;
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":69
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_FREEZE_GET), &fcount)
+ * fcount_ = <object>fcount
+ * return (fcount_) # <<<<<<<<<<<<<<
+ *
+ * @staticmethod
+ */
+ __Pyx_XDECREF(__pyx_r);
+ __Pyx_INCREF(__pyx_v_fcount_);
+ __pyx_r = __pyx_v_fcount_;
+ goto __pyx_L0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.event_freeze_get", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XDECREF(__pyx_v_fcount_);
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_17event_global_thaw(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused); /*proto*/
+static PyMethodDef __pyx_mdef_6eorepo_6eobase_6EoBase_17event_global_thaw = {__Pyx_NAMESTR("event_global_thaw"), (PyCFunction)__pyx_pw_6eorepo_6eobase_6EoBase_17event_global_thaw, METH_NOARGS, __Pyx_DOCSTR(0)};
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_17event_global_thaw(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused) {
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("event_global_thaw (wrapper)", 0);
+ __pyx_r = __pyx_pf_6eorepo_6eobase_6EoBase_16event_global_thaw(__pyx_self);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "/home/yakov/eo_bindings/eorepo/eobase.pxi":72
+ *
+ * @staticmethod
+ * def event_global_thaw(): # <<<<<<<<<<<<<<
+ * eodefault.eo_class_do(eobase.eo_base_class_get(), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_GLOBAL_THAW))
+ *
+ */
+
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_16event_global_thaw(CYTHON_UNUSED PyObject *__pyx_self) {
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("event_global_thaw", 0);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":73
+ * @staticmethod
+ * def event_global_thaw():
+ * eodefault.eo_class_do(eobase.eo_base_class_get(), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_GLOBAL_THAW)) # <<<<<<<<<<<<<<
+ *
+ *
+ */
+ eo_class_do(eo_base_class_get(), __pyx_f_6eorepo_6eobase_eobase_sub_id(EO_BASE_SUB_ID_EVENT_GLOBAL_THAW));
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_19data_del(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
+static PyMethodDef __pyx_mdef_6eorepo_6eobase_6EoBase_19data_del = {__Pyx_NAMESTR("data_del"), (PyCFunction)__pyx_pw_6eorepo_6eobase_6EoBase_19data_del, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)};
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_19data_del(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
+ PyObject *__pyx_v_self = 0;
+ PyObject *__pyx_v__key = 0;
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("data_del (wrapper)", 0);
+ {
+ static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__self,&__pyx_n_s___key,0};
+ PyObject* values[2] = {0,0};
+ if (unlikely(__pyx_kwds)) {
+ Py_ssize_t kw_args;
+ const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
+ switch (pos_args) {
+ case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ case 0: break;
+ default: goto __pyx_L5_argtuple_error;
+ }
+ kw_args = PyDict_Size(__pyx_kwds);
+ switch (pos_args) {
+ case 0:
+ if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__self)) != 0)) kw_args--;
+ else goto __pyx_L5_argtuple_error;
+ case 1:
+ if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s___key)) != 0)) kw_args--;
+ else {
+ __Pyx_RaiseArgtupleInvalid("data_del", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 76; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ }
+ if (unlikely(kw_args > 0)) {
+ if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "data_del") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 76; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ } else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
+ goto __pyx_L5_argtuple_error;
+ } else {
+ values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ }
+ __pyx_v_self = values[0];
+ __pyx_v__key = values[1];
+ }
+ goto __pyx_L4_argument_unpacking_done;
+ __pyx_L5_argtuple_error:;
+ __Pyx_RaiseArgtupleInvalid("data_del", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 76; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ __pyx_L3_error:;
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.data_del", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __Pyx_RefNannyFinishContext();
+ return NULL;
+ __pyx_L4_argument_unpacking_done:;
+ __pyx_r = __pyx_pf_6eorepo_6eobase_6EoBase_18data_del(__pyx_self, __pyx_v_self, __pyx_v__key);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "/home/yakov/eo_bindings/eorepo/eobase.pxi":76
+ *
+ *
+ * def data_del(self, object _key): # <<<<<<<<<<<<<<
+ * _key = None if _key is None else pytext_to_utf8(_key)
+ * cdef char* key = NULL if _key is None else <char*> _key
+ */
+
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_18data_del(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, PyObject *__pyx_v__key) {
+ char *__pyx_v_key;
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ int __pyx_t_2;
+ PyObject *__pyx_t_3 = NULL;
+ PyObject *__pyx_t_4 = NULL;
+ PyObject *__pyx_t_5 = NULL;
+ void *__pyx_t_6;
+ char *__pyx_t_7;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("data_del", 0);
+ __Pyx_INCREF(__pyx_v__key);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":77
+ *
+ * def data_del(self, object _key):
+ * _key = None if _key is None else pytext_to_utf8(_key) # <<<<<<<<<<<<<<
+ * cdef char* key = NULL if _key is None else <char*> _key
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_DEL), key)
+ */
+ __pyx_t_2 = (__pyx_v__key == Py_None);
+ if (__pyx_t_2) {
+ __Pyx_INCREF(Py_None);
+ __pyx_t_1 = Py_None;
+ } else {
+ __pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__pytext_to_utf8); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 77; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __pyx_t_4 = PyTuple_New(1); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 77; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_4);
+ __Pyx_INCREF(__pyx_v__key);
+ PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_v__key);
+ __Pyx_GIVEREF(__pyx_v__key);
+ __pyx_t_5 = PyObject_Call(__pyx_t_3, ((PyObject *)__pyx_t_4), NULL); if (unlikely(!__pyx_t_5)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 77; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_5);
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+ __Pyx_DECREF(((PyObject *)__pyx_t_4)); __pyx_t_4 = 0;
+ __pyx_t_1 = __pyx_t_5;
+ __pyx_t_5 = 0;
+ }
+ __Pyx_DECREF(__pyx_v__key);
+ __pyx_v__key = __pyx_t_1;
+ __pyx_t_1 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":78
+ * def data_del(self, object _key):
+ * _key = None if _key is None else pytext_to_utf8(_key)
+ * cdef char* key = NULL if _key is None else <char*> _key # <<<<<<<<<<<<<<
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_DEL), key)
+ *
+ */
+ __pyx_t_2 = (__pyx_v__key == Py_None);
+ if (__pyx_t_2) {
+ __pyx_t_6 = NULL;
+ } else {
+ __pyx_t_7 = PyBytes_AsString(__pyx_v__key); if (unlikely((!__pyx_t_7) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 78; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_t_6 = ((char *)__pyx_t_7);
+ }
+ __pyx_v_key = __pyx_t_6;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":79
+ * _key = None if _key is None else pytext_to_utf8(_key)
+ * cdef char* key = NULL if _key is None else <char*> _key
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_DEL), key) # <<<<<<<<<<<<<<
+ *
+ * def event_callback_call(self, long _desc, object _event_info):
+ */
+ if (!(likely(((__pyx_v_self) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_self, __pyx_ptype_6eorepo_9eodefault_EoDefault))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 79; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_t_1 = __pyx_v_self;
+ __Pyx_INCREF(__pyx_t_1);
+ eo_do(__pyx_f_6eorepo_9eodefault__eo_instance_get(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_t_1)), __pyx_f_6eorepo_6eobase_eobase_sub_id(EO_BASE_SUB_ID_DATA_DEL), __pyx_v_key);
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_XDECREF(__pyx_t_3);
+ __Pyx_XDECREF(__pyx_t_4);
+ __Pyx_XDECREF(__pyx_t_5);
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.data_del", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XDECREF(__pyx_v__key);
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_21event_callback_call(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
+static PyMethodDef __pyx_mdef_6eorepo_6eobase_6EoBase_21event_callback_call = {__Pyx_NAMESTR("event_callback_call"), (PyCFunction)__pyx_pw_6eorepo_6eobase_6EoBase_21event_callback_call, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)};
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_21event_callback_call(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
+ PyObject *__pyx_v_self = 0;
+ long __pyx_v__desc;
+ PyObject *__pyx_v__event_info = 0;
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("event_callback_call (wrapper)", 0);
+ {
+ static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__self,&__pyx_n_s___desc,&__pyx_n_s___event_info,0};
+ PyObject* values[3] = {0,0,0};
+ if (unlikely(__pyx_kwds)) {
+ Py_ssize_t kw_args;
+ const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
+ switch (pos_args) {
+ case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
+ case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ case 0: break;
+ default: goto __pyx_L5_argtuple_error;
+ }
+ kw_args = PyDict_Size(__pyx_kwds);
+ switch (pos_args) {
+ case 0:
+ if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__self)) != 0)) kw_args--;
+ else goto __pyx_L5_argtuple_error;
+ case 1:
+ if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s___desc)) != 0)) kw_args--;
+ else {
+ __Pyx_RaiseArgtupleInvalid("event_callback_call", 1, 3, 3, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 81; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ case 2:
+ if (likely((values[2] = PyDict_GetItem(__pyx_kwds, __pyx_n_s___event_info)) != 0)) kw_args--;
+ else {
+ __Pyx_RaiseArgtupleInvalid("event_callback_call", 1, 3, 3, 2); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 81; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ }
+ if (unlikely(kw_args > 0)) {
+ if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "event_callback_call") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 81; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ } else if (PyTuple_GET_SIZE(__pyx_args) != 3) {
+ goto __pyx_L5_argtuple_error;
+ } else {
+ values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
+ }
+ __pyx_v_self = values[0];
+ __pyx_v__desc = __Pyx_PyInt_AsLong(values[1]); if (unlikely((__pyx_v__desc == (long)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 81; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ __pyx_v__event_info = values[2];
+ }
+ goto __pyx_L4_argument_unpacking_done;
+ __pyx_L5_argtuple_error:;
+ __Pyx_RaiseArgtupleInvalid("event_callback_call", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 81; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ __pyx_L3_error:;
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.event_callback_call", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __Pyx_RefNannyFinishContext();
+ return NULL;
+ __pyx_L4_argument_unpacking_done:;
+ __pyx_r = __pyx_pf_6eorepo_6eobase_6EoBase_20event_callback_call(__pyx_self, __pyx_v_self, __pyx_v__desc, __pyx_v__event_info);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "/home/yakov/eo_bindings/eorepo/eobase.pxi":81
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_DEL), key)
+ *
+ * def event_callback_call(self, long _desc, object _event_info): # <<<<<<<<<<<<<<
+ * cdef long desc = <long> _desc
+ * cdef void* event_info = <void*> _event_info
+ */
+
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_20event_callback_call(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, long __pyx_v__desc, PyObject *__pyx_v__event_info) {
+ long __pyx_v_desc;
+ void *__pyx_v_event_info;
+ unsigned char __pyx_v_aborted;
+ PyObject *__pyx_v_aborted_ = NULL;
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("event_callback_call", 0);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":82
+ *
+ * def event_callback_call(self, long _desc, object _event_info):
+ * cdef long desc = <long> _desc # <<<<<<<<<<<<<<
+ * cdef void* event_info = <void*> _event_info
+ * cdef unsigned char aborted
+ */
+ __pyx_v_desc = ((long)__pyx_v__desc);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":83
+ * def event_callback_call(self, long _desc, object _event_info):
+ * cdef long desc = <long> _desc
+ * cdef void* event_info = <void*> _event_info # <<<<<<<<<<<<<<
+ * cdef unsigned char aborted
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_CALL), desc, event_info, &aborted)
+ */
+ __pyx_v_event_info = ((void *)__pyx_v__event_info);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":85
+ * cdef void* event_info = <void*> _event_info
+ * cdef unsigned char aborted
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_CALL), desc, event_info, &aborted) # <<<<<<<<<<<<<<
+ * aborted_ = <object>aborted
+ * return (aborted_)
+ */
+ if (!(likely(((__pyx_v_self) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_self, __pyx_ptype_6eorepo_9eodefault_EoDefault))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 85; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_t_1 = __pyx_v_self;
+ __Pyx_INCREF(__pyx_t_1);
+ eo_do(__pyx_f_6eorepo_9eodefault__eo_instance_get(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_t_1)), __pyx_f_6eorepo_6eobase_eobase_sub_id(EO_BASE_SUB_ID_EVENT_CALLBACK_CALL), __pyx_v_desc, __pyx_v_event_info, (&__pyx_v_aborted));
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":86
+ * cdef unsigned char aborted
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_CALL), desc, event_info, &aborted)
+ * aborted_ = <object>aborted # <<<<<<<<<<<<<<
+ * return (aborted_)
+ *
+ */
+ __pyx_t_1 = PyInt_FromLong(__pyx_v_aborted); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 86; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __Pyx_INCREF(((PyObject *)__pyx_t_1));
+ __pyx_v_aborted_ = __pyx_t_1;
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":87
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_CALL), desc, event_info, &aborted)
+ * aborted_ = <object>aborted
+ * return (aborted_) # <<<<<<<<<<<<<<
+ *
+ * def event_callback_priority_add(self, long _desc, int _priority, object _cb):
+ */
+ __Pyx_XDECREF(__pyx_r);
+ __Pyx_INCREF(__pyx_v_aborted_);
+ __pyx_r = __pyx_v_aborted_;
+ goto __pyx_L0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.event_callback_call", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XDECREF(__pyx_v_aborted_);
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_23event_callback_priority_add(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
+static PyMethodDef __pyx_mdef_6eorepo_6eobase_6EoBase_23event_callback_priority_add = {__Pyx_NAMESTR("event_callback_priority_add"), (PyCFunction)__pyx_pw_6eorepo_6eobase_6EoBase_23event_callback_priority_add, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)};
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_23event_callback_priority_add(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
+ PyObject *__pyx_v_self = 0;
+ long __pyx_v__desc;
+ int __pyx_v__priority;
+ PyObject *__pyx_v__cb = 0;
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("event_callback_priority_add (wrapper)", 0);
+ {
+ static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__self,&__pyx_n_s___desc,&__pyx_n_s___priority,&__pyx_n_s___cb,0};
+ PyObject* values[4] = {0,0,0,0};
+ if (unlikely(__pyx_kwds)) {
+ Py_ssize_t kw_args;
+ const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
+ switch (pos_args) {
+ case 4: values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
+ case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
+ case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ case 0: break;
+ default: goto __pyx_L5_argtuple_error;
+ }
+ kw_args = PyDict_Size(__pyx_kwds);
+ switch (pos_args) {
+ case 0:
+ if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__self)) != 0)) kw_args--;
+ else goto __pyx_L5_argtuple_error;
+ case 1:
+ if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s___desc)) != 0)) kw_args--;
+ else {
+ __Pyx_RaiseArgtupleInvalid("event_callback_priority_add", 1, 4, 4, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 89; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ case 2:
+ if (likely((values[2] = PyDict_GetItem(__pyx_kwds, __pyx_n_s___priority)) != 0)) kw_args--;
+ else {
+ __Pyx_RaiseArgtupleInvalid("event_callback_priority_add", 1, 4, 4, 2); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 89; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ case 3:
+ if (likely((values[3] = PyDict_GetItem(__pyx_kwds, __pyx_n_s___cb)) != 0)) kw_args--;
+ else {
+ __Pyx_RaiseArgtupleInvalid("event_callback_priority_add", 1, 4, 4, 3); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 89; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ }
+ if (unlikely(kw_args > 0)) {
+ if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "event_callback_priority_add") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 89; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ } else if (PyTuple_GET_SIZE(__pyx_args) != 4) {
+ goto __pyx_L5_argtuple_error;
+ } else {
+ values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
+ values[3] = PyTuple_GET_ITEM(__pyx_args, 3);
+ }
+ __pyx_v_self = values[0];
+ __pyx_v__desc = __Pyx_PyInt_AsLong(values[1]); if (unlikely((__pyx_v__desc == (long)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 89; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ __pyx_v__priority = __Pyx_PyInt_AsInt(values[2]); if (unlikely((__pyx_v__priority == (int)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 89; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ __pyx_v__cb = values[3];
+ }
+ goto __pyx_L4_argument_unpacking_done;
+ __pyx_L5_argtuple_error:;
+ __Pyx_RaiseArgtupleInvalid("event_callback_priority_add", 1, 4, 4, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 89; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ __pyx_L3_error:;
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.event_callback_priority_add", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __Pyx_RefNannyFinishContext();
+ return NULL;
+ __pyx_L4_argument_unpacking_done:;
+ __pyx_r = __pyx_pf_6eorepo_6eobase_6EoBase_22event_callback_priority_add(__pyx_self, __pyx_v_self, __pyx_v__desc, __pyx_v__priority, __pyx_v__cb);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "/home/yakov/eo_bindings/eorepo/eobase.pxi":89
+ * return (aborted_)
+ *
+ * def event_callback_priority_add(self, long _desc, int _priority, object _cb): # <<<<<<<<<<<<<<
+ * if not callable(_cb[0]):
+ * raise TypeError("func must be callable")
+ */
+
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_22event_callback_priority_add(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, long __pyx_v__desc, int __pyx_v__priority, PyObject *__pyx_v__cb) {
+ Eo_Event_Cb __pyx_v_cb;
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ int __pyx_t_2;
+ int __pyx_t_3;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("event_callback_priority_add", 0);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":90
+ *
+ * def event_callback_priority_add(self, long _desc, int _priority, object _cb):
+ * if not callable(_cb[0]): # <<<<<<<<<<<<<<
+ * raise TypeError("func must be callable")
+ * cdef Eo_Event_Cb cb = <Eo_Event_Cb> eodefault._object_callback
+ */
+ __pyx_t_1 = __Pyx_GetItemInt(__pyx_v__cb, 0, sizeof(long), PyInt_FromLong); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 90; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __pyx_t_2 = __Pyx_PyCallable_Check(__pyx_t_1); if (unlikely(__pyx_t_2 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 90; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ __pyx_t_3 = (!__pyx_t_2);
+ if (__pyx_t_3) {
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":91
+ * def event_callback_priority_add(self, long _desc, int _priority, object _cb):
+ * if not callable(_cb[0]):
+ * raise TypeError("func must be callable") # <<<<<<<<<<<<<<
+ * cdef Eo_Event_Cb cb = <Eo_Event_Cb> eodefault._object_callback
+ * Py_INCREF(_cb)
+ */
+ __pyx_t_1 = PyObject_Call(__pyx_builtin_TypeError, ((PyObject *)__pyx_k_tuple_4), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 91; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __Pyx_Raise(__pyx_t_1, 0, 0, 0);
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ {__pyx_filename = __pyx_f[0]; __pyx_lineno = 91; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ goto __pyx_L3;
+ }
+ __pyx_L3:;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":92
+ * if not callable(_cb[0]):
+ * raise TypeError("func must be callable")
+ * cdef Eo_Event_Cb cb = <Eo_Event_Cb> eodefault._object_callback # <<<<<<<<<<<<<<
+ * Py_INCREF(_cb)
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_PRIORITY_ADD), _desc, _priority, cb, <void*>_cb)
+ */
+ __pyx_v_cb = ((Eo_Event_Cb)__pyx_f_6eorepo_9eodefault__object_callback);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":93
+ * raise TypeError("func must be callable")
+ * cdef Eo_Event_Cb cb = <Eo_Event_Cb> eodefault._object_callback
+ * Py_INCREF(_cb) # <<<<<<<<<<<<<<
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_PRIORITY_ADD), _desc, _priority, cb, <void*>_cb)
+ *
+ */
+ Py_INCREF(__pyx_v__cb);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":94
+ * cdef Eo_Event_Cb cb = <Eo_Event_Cb> eodefault._object_callback
+ * Py_INCREF(_cb)
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_PRIORITY_ADD), _desc, _priority, cb, <void*>_cb) # <<<<<<<<<<<<<<
+ *
+ *
+ */
+ if (!(likely(((__pyx_v_self) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_self, __pyx_ptype_6eorepo_9eodefault_EoDefault))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 94; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_t_1 = __pyx_v_self;
+ __Pyx_INCREF(__pyx_t_1);
+ eo_do(__pyx_f_6eorepo_9eodefault__eo_instance_get(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_t_1)), __pyx_f_6eorepo_6eobase_eobase_sub_id(EO_BASE_SUB_ID_EVENT_CALLBACK_PRIORITY_ADD), __pyx_v__desc, __pyx_v__priority, __pyx_v_cb, ((void *)__pyx_v__cb));
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.event_callback_priority_add", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_25data_set(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
+static PyMethodDef __pyx_mdef_6eorepo_6eobase_6EoBase_25data_set = {__Pyx_NAMESTR("data_set"), (PyCFunction)__pyx_pw_6eorepo_6eobase_6EoBase_25data_set, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)};
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_25data_set(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
+ PyObject *__pyx_v_self = 0;
+ PyObject *__pyx_v__key = 0;
+ PyObject *__pyx_v__data = 0;
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("data_set (wrapper)", 0);
+ {
+ static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__self,&__pyx_n_s___key,&__pyx_n_s___data,0};
+ PyObject* values[3] = {0,0,0};
+ if (unlikely(__pyx_kwds)) {
+ Py_ssize_t kw_args;
+ const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
+ switch (pos_args) {
+ case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
+ case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ case 0: break;
+ default: goto __pyx_L5_argtuple_error;
+ }
+ kw_args = PyDict_Size(__pyx_kwds);
+ switch (pos_args) {
+ case 0:
+ if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__self)) != 0)) kw_args--;
+ else goto __pyx_L5_argtuple_error;
+ case 1:
+ if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s___key)) != 0)) kw_args--;
+ else {
+ __Pyx_RaiseArgtupleInvalid("data_set", 1, 3, 3, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 97; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ case 2:
+ if (likely((values[2] = PyDict_GetItem(__pyx_kwds, __pyx_n_s___data)) != 0)) kw_args--;
+ else {
+ __Pyx_RaiseArgtupleInvalid("data_set", 1, 3, 3, 2); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 97; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ }
+ if (unlikely(kw_args > 0)) {
+ if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "data_set") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 97; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ } else if (PyTuple_GET_SIZE(__pyx_args) != 3) {
+ goto __pyx_L5_argtuple_error;
+ } else {
+ values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
+ }
+ __pyx_v_self = values[0];
+ __pyx_v__key = values[1];
+ __pyx_v__data = values[2];
+ }
+ goto __pyx_L4_argument_unpacking_done;
+ __pyx_L5_argtuple_error:;
+ __Pyx_RaiseArgtupleInvalid("data_set", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 97; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ __pyx_L3_error:;
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.data_set", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __Pyx_RefNannyFinishContext();
+ return NULL;
+ __pyx_L4_argument_unpacking_done:;
+ __pyx_r = __pyx_pf_6eorepo_6eobase_6EoBase_24data_set(__pyx_self, __pyx_v_self, __pyx_v__key, __pyx_v__data);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "/home/yakov/eo_bindings/eorepo/eobase.pxi":97
+ *
+ *
+ * def data_set(self, object _key, object _data): # <<<<<<<<<<<<<<
+ * _key = pytext_to_utf8(_key)
+ * cdef char* key = <char*> _key
+ */
+
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_24data_set(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, PyObject *__pyx_v__key, PyObject *__pyx_v__data) {
+ char *__pyx_v_key;
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ PyObject *__pyx_t_2 = NULL;
+ PyObject *__pyx_t_3 = NULL;
+ char *__pyx_t_4;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("data_set", 0);
+ __Pyx_INCREF(__pyx_v__key);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":98
+ *
+ * def data_set(self, object _key, object _data):
+ * _key = pytext_to_utf8(_key) # <<<<<<<<<<<<<<
+ * cdef char* key = <char*> _key
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_SET), key, <void*>_data, NULL)
+ */
+ __pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__pytext_to_utf8); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 98; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 98; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_2);
+ __Pyx_INCREF(__pyx_v__key);
+ PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_v__key);
+ __Pyx_GIVEREF(__pyx_v__key);
+ __pyx_t_3 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_t_2), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 98; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0;
+ __Pyx_DECREF(__pyx_v__key);
+ __pyx_v__key = __pyx_t_3;
+ __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":99
+ * def data_set(self, object _key, object _data):
+ * _key = pytext_to_utf8(_key)
+ * cdef char* key = <char*> _key # <<<<<<<<<<<<<<
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_SET), key, <void*>_data, NULL)
+ *
+ */
+ __pyx_t_4 = PyBytes_AsString(__pyx_v__key); if (unlikely((!__pyx_t_4) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 99; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_v_key = ((char *)__pyx_t_4);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":100
+ * _key = pytext_to_utf8(_key)
+ * cdef char* key = <char*> _key
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_SET), key, <void*>_data, NULL) # <<<<<<<<<<<<<<
+ *
+ * def _data_set(self, object _key, object _data):
+ */
+ if (!(likely(((__pyx_v_self) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_self, __pyx_ptype_6eorepo_9eodefault_EoDefault))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 100; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_t_3 = __pyx_v_self;
+ __Pyx_INCREF(__pyx_t_3);
+ eo_do(__pyx_f_6eorepo_9eodefault__eo_instance_get(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_t_3)), __pyx_f_6eorepo_6eobase_eobase_sub_id(EO_BASE_SUB_ID_DATA_SET), __pyx_v_key, ((void *)__pyx_v__data), NULL);
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_XDECREF(__pyx_t_2);
+ __Pyx_XDECREF(__pyx_t_3);
+ __Pyx_AddTraceback("eorepo.eobase.EoBase.data_set", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XDECREF(__pyx_v__key);
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_27_data_set(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
+static PyMethodDef __pyx_mdef_6eorepo_6eobase_6EoBase_27_data_set = {__Pyx_NAMESTR("_data_set"), (PyCFunction)__pyx_pw_6eorepo_6eobase_6EoBase_27_data_set, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)};
+static PyObject *__pyx_pw_6eorepo_6eobase_6EoBase_27_data_set(PyObject *__pyx_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
+ PyObject *__pyx_v_self = 0;
+ PyObject *__pyx_v__key = 0;
+ PyObject *__pyx_v__data = 0;
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("_data_set (wrapper)", 0);
+ {
+ static PyObject **__pyx_pyargnames[] = {&__pyx_n_s__self,&__pyx_n_s___key,&__pyx_n_s___data,0};
+ PyObject* values[3] = {0,0,0};
+ if (unlikely(__pyx_kwds)) {
+ Py_ssize_t kw_args;
+ const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
+ switch (pos_args) {
+ case 3: values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
+ case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ case 0: break;
+ default: goto __pyx_L5_argtuple_error;
+ }
+ kw_args = PyDict_Size(__pyx_kwds);
+ switch (pos_args) {
+ case 0:
+ if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__self)) != 0)) kw_args--;
+ else goto __pyx_L5_argtuple_error;
+ case 1:
+ if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s___key)) != 0)) kw_args--;
+ else {
+ __Pyx_RaiseArgtupleInvalid("_data_set", 1, 3, 3, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 102; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ case 2:
+ if (likely((values[2] = PyDict_GetItem(__pyx_kwds, __pyx_n_s___data)) != 0)) kw_args--;
+ else {
+ __Pyx_RaiseArgtupleInvalid("_data_set", 1, 3, 3, 2); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 102; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ }
+ if (unlikely(kw_args > 0)) {
+ if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_data_set") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 102; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ } else if (PyTuple_GET_SIZE(__pyx_args) != 3) {
+ goto __pyx_L5_argtuple_error;
+ } else {
+ values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ values[2] = PyTuple_GET_ITEM(__pyx_args, 2);
+ }
+ __pyx_v_self = values[0];
+ __pyx_v__key = values[1];
+ __pyx_v__data = values[2];
+ }
+ goto __pyx_L4_argument_unpacking_done;
+ __pyx_L5_argtuple_error:;
+ __Pyx_RaiseArgtupleInvalid("_data_set", 1, 3, 3, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 102; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ __pyx_L3_error:;
+ __Pyx_AddTraceback("eorepo.eobase.EoBase._data_set", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __Pyx_RefNannyFinishContext();
+ return NULL;
+ __pyx_L4_argument_unpacking_done:;
+ __pyx_r = __pyx_pf_6eorepo_6eobase_6EoBase_26_data_set(__pyx_self, __pyx_v_self, __pyx_v__key, __pyx_v__data);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "/home/yakov/eo_bindings/eorepo/eobase.pxi":102
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_SET), key, <void*>_data, NULL)
+ *
+ * def _data_set(self, object _key, object _data): # <<<<<<<<<<<<<<
+ * _key = pytext_to_utf8(_key)
+ * cdef char* key = <char*> _key
+ */
+
+static PyObject *__pyx_pf_6eorepo_6eobase_6EoBase_26_data_set(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_self, PyObject *__pyx_v__key, PyObject *__pyx_v__data) {
+ char *__pyx_v_key;
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ PyObject *__pyx_t_2 = NULL;
+ PyObject *__pyx_t_3 = NULL;
+ char *__pyx_t_4;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("_data_set", 0);
+ __Pyx_INCREF(__pyx_v__key);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":103
+ *
+ * def _data_set(self, object _key, object _data):
+ * _key = pytext_to_utf8(_key) # <<<<<<<<<<<<<<
+ * cdef char* key = <char*> _key
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_SET), key, <void*>_data, NULL)
+ */
+ __pyx_t_1 = __Pyx_GetName(__pyx_m, __pyx_n_s__pytext_to_utf8); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 103; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 103; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_2);
+ __Pyx_INCREF(__pyx_v__key);
+ PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_v__key);
+ __Pyx_GIVEREF(__pyx_v__key);
+ __pyx_t_3 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_t_2), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 103; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0;
+ __Pyx_DECREF(__pyx_v__key);
+ __pyx_v__key = __pyx_t_3;
+ __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":104
+ * def _data_set(self, object _key, object _data):
+ * _key = pytext_to_utf8(_key)
+ * cdef char* key = <char*> _key # <<<<<<<<<<<<<<
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_SET), key, <void*>_data, NULL)
+ *
+ */
+ __pyx_t_4 = PyBytes_AsString(__pyx_v__key); if (unlikely((!__pyx_t_4) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 104; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_v_key = ((char *)__pyx_t_4);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":105
+ * _key = pytext_to_utf8(_key)
+ * cdef char* key = <char*> _key
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_SET), key, <void*>_data, NULL) # <<<<<<<<<<<<<<
+ *
+ *
+ */
+ if (!(likely(((__pyx_v_self) == Py_None) || likely(__Pyx_TypeTest(__pyx_v_self, __pyx_ptype_6eorepo_9eodefault_EoDefault))))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 105; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_t_3 = __pyx_v_self;
+ __Pyx_INCREF(__pyx_t_3);
+ eo_do(__pyx_f_6eorepo_9eodefault__eo_instance_get(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_t_3)), __pyx_f_6eorepo_6eobase_eobase_sub_id(EO_BASE_SUB_ID_DATA_SET), __pyx_v_key, ((void *)__pyx_v__data), NULL);
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_XDECREF(__pyx_t_2);
+ __Pyx_XDECREF(__pyx_t_3);
+ __Pyx_AddTraceback("eorepo.eobase.EoBase._data_set", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XDECREF(__pyx_v__key);
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+static PyMethodDef __pyx_methods[] = {
+ {0, 0, 0, 0}
+};
+
+#if PY_MAJOR_VERSION >= 3
+static struct PyModuleDef __pyx_moduledef = {
+ PyModuleDef_HEAD_INIT,
+ __Pyx_NAMESTR("eobase"),
+ 0, /* m_doc */
+ -1, /* m_size */
+ __pyx_methods /* m_methods */,
+ NULL, /* m_reload */
+ NULL, /* m_traverse */
+ NULL, /* m_clear */
+ NULL /* m_free */
+};
+#endif
+
+static __Pyx_StringTabEntry __pyx_string_tab[] = {
+ {&__pyx_kp_s_1, __pyx_k_1, sizeof(__pyx_k_1), 0, 0, 1, 0},
+ {&__pyx_n_s_16, __pyx_k_16, sizeof(__pyx_k_16), 0, 0, 1, 1},
+ {&__pyx_kp_s_3, __pyx_k_3, sizeof(__pyx_k_3), 0, 0, 1, 0},
+ {&__pyx_n_s_31, __pyx_k_31, sizeof(__pyx_k_31), 0, 0, 1, 1},
+ {&__pyx_n_s_5, __pyx_k_5, sizeof(__pyx_k_5), 0, 0, 1, 1},
+ {&__pyx_kp_s_8, __pyx_k_8, sizeof(__pyx_k_8), 0, 0, 1, 0},
+ {&__pyx_n_s_9, __pyx_k_9, sizeof(__pyx_k_9), 0, 0, 1, 1},
+ {&__pyx_n_s__CALLBACK_ADD, __pyx_k__CALLBACK_ADD, sizeof(__pyx_k__CALLBACK_ADD), 0, 0, 1, 1},
+ {&__pyx_n_s__CALLBACK_DEL, __pyx_k__CALLBACK_DEL, sizeof(__pyx_k__CALLBACK_DEL), 0, 0, 1, 1},
+ {&__pyx_n_s__DEL, __pyx_k__DEL, sizeof(__pyx_k__DEL), 0, 0, 1, 1},
+ {&__pyx_n_s__EoBase, __pyx_k__EoBase, sizeof(__pyx_k__EoBase), 0, 0, 1, 1},
+ {&__pyx_n_s__EoDefault, __pyx_k__EoDefault, sizeof(__pyx_k__EoDefault), 0, 0, 1, 1},
+ {&__pyx_n_s__TypeError, __pyx_k__TypeError, sizeof(__pyx_k__TypeError), 0, 0, 1, 1},
+ {&__pyx_n_s____class__, __pyx_k____class__, sizeof(__pyx_k____class__), 0, 0, 1, 1},
+ {&__pyx_n_s____init__, __pyx_k____init__, sizeof(__pyx_k____init__), 0, 0, 1, 1},
+ {&__pyx_n_s____main__, __pyx_k____main__, sizeof(__pyx_k____main__), 0, 0, 1, 1},
+ {&__pyx_n_s____name__, __pyx_k____name__, sizeof(__pyx_k____name__), 0, 0, 1, 1},
+ {&__pyx_n_s____test__, __pyx_k____test__, sizeof(__pyx_k____test__), 0, 0, 1, 1},
+ {&__pyx_n_s___cb, __pyx_k___cb, sizeof(__pyx_k___cb), 0, 0, 1, 1},
+ {&__pyx_n_s___data, __pyx_k___data, sizeof(__pyx_k___data), 0, 0, 1, 1},
+ {&__pyx_n_s___data_set, __pyx_k___data_set, sizeof(__pyx_k___data_set), 0, 0, 1, 1},
+ {&__pyx_n_s___desc, __pyx_k___desc, sizeof(__pyx_k___desc), 0, 0, 1, 1},
+ {&__pyx_n_s___event_info, __pyx_k___event_info, sizeof(__pyx_k___event_info), 0, 0, 1, 1},
+ {&__pyx_n_s___func, __pyx_k___func, sizeof(__pyx_k___func), 0, 0, 1, 1},
+ {&__pyx_n_s___key, __pyx_k___key, sizeof(__pyx_k___key), 0, 0, 1, 1},
+ {&__pyx_n_s___priority, __pyx_k___priority, sizeof(__pyx_k___priority), 0, 0, 1, 1},
+ {&__pyx_n_s__aborted, __pyx_k__aborted, sizeof(__pyx_k__aborted), 0, 0, 1, 1},
+ {&__pyx_n_s__aborted_, __pyx_k__aborted_, sizeof(__pyx_k__aborted_), 0, 0, 1, 1},
+ {&__pyx_n_s__cb, __pyx_k__cb, sizeof(__pyx_k__cb), 0, 0, 1, 1},
+ {&__pyx_n_s__data, __pyx_k__data, sizeof(__pyx_k__data), 0, 0, 1, 1},
+ {&__pyx_n_s__data_, __pyx_k__data_, sizeof(__pyx_k__data_), 0, 0, 1, 1},
+ {&__pyx_n_s__data_del, __pyx_k__data_del, sizeof(__pyx_k__data_del), 0, 0, 1, 1},
+ {&__pyx_n_s__data_get, __pyx_k__data_get, sizeof(__pyx_k__data_get), 0, 0, 1, 1},
+ {&__pyx_n_s__data_set, __pyx_k__data_set, sizeof(__pyx_k__data_set), 0, 0, 1, 1},
+ {&__pyx_n_s__desc, __pyx_k__desc, sizeof(__pyx_k__desc), 0, 0, 1, 1},
+ {&__pyx_n_s__eodefault, __pyx_k__eodefault, sizeof(__pyx_k__eodefault), 0, 0, 1, 1},
+ {&__pyx_n_s__event_callback_call, __pyx_k__event_callback_call, sizeof(__pyx_k__event_callback_call), 0, 0, 1, 1},
+ {&__pyx_n_s__event_callback_del, __pyx_k__event_callback_del, sizeof(__pyx_k__event_callback_del), 0, 0, 1, 1},
+ {&__pyx_n_s__event_freeze, __pyx_k__event_freeze, sizeof(__pyx_k__event_freeze), 0, 0, 1, 1},
+ {&__pyx_n_s__event_freeze_get, __pyx_k__event_freeze_get, sizeof(__pyx_k__event_freeze_get), 0, 0, 1, 1},
+ {&__pyx_n_s__event_global_freeze, __pyx_k__event_global_freeze, sizeof(__pyx_k__event_global_freeze), 0, 0, 1, 1},
+ {&__pyx_n_s__event_global_thaw, __pyx_k__event_global_thaw, sizeof(__pyx_k__event_global_thaw), 0, 0, 1, 1},
+ {&__pyx_n_s__event_info, __pyx_k__event_info, sizeof(__pyx_k__event_info), 0, 0, 1, 1},
+ {&__pyx_n_s__event_thaw, __pyx_k__event_thaw, sizeof(__pyx_k__event_thaw), 0, 0, 1, 1},
+ {&__pyx_n_s__exit, __pyx_k__exit, sizeof(__pyx_k__exit), 0, 0, 1, 1},
+ {&__pyx_n_s__fcount, __pyx_k__fcount, sizeof(__pyx_k__fcount), 0, 0, 1, 1},
+ {&__pyx_n_s__fcount_, __pyx_k__fcount_, sizeof(__pyx_k__fcount_), 0, 0, 1, 1},
+ {&__pyx_n_s__func, __pyx_k__func, sizeof(__pyx_k__func), 0, 0, 1, 1},
+ {&__pyx_n_s__instantiateable, __pyx_k__instantiateable, sizeof(__pyx_k__instantiateable), 0, 0, 1, 1},
+ {&__pyx_n_s__key, __pyx_k__key, sizeof(__pyx_k__key), 0, 0, 1, 1},
+ {&__pyx_n_s__parent, __pyx_k__parent, sizeof(__pyx_k__parent), 0, 0, 1, 1},
+ {&__pyx_n_s__pytext_to_utf8, __pyx_k__pytext_to_utf8, sizeof(__pyx_k__pytext_to_utf8), 0, 0, 1, 1},
+ {&__pyx_n_s__self, __pyx_k__self, sizeof(__pyx_k__self), 0, 0, 1, 1},
+ {&__pyx_n_s__staticmethod, __pyx_k__staticmethod, sizeof(__pyx_k__staticmethod), 0, 0, 1, 1},
+ {0, 0, 0, 0, 0, 0, 0}
+};
+static int __Pyx_InitCachedBuiltins(void) {
+ __pyx_builtin_staticmethod = __Pyx_GetName(__pyx_b, __pyx_n_s__staticmethod); if (!__pyx_builtin_staticmethod) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 36; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_builtin_exit = __Pyx_GetName(__pyx_b, __pyx_n_s__exit); if (!__pyx_builtin_exit) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 33; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_builtin_TypeError = __Pyx_GetName(__pyx_b, __pyx_n_s__TypeError); if (!__pyx_builtin_TypeError) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 91; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ return 0;
+ __pyx_L1_error:;
+ return -1;
+}
+
+static int __Pyx_InitCachedConstants(void) {
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("__Pyx_InitCachedConstants", 0);
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":33
+ * if not instantiateable:
+ * print "Class '%s' is not instantiate-able. Aborting."%(self.__class__.__name__)
+ * exit(1) # <<<<<<<<<<<<<<
+ *
+ *
+ */
+ __pyx_k_tuple_2 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 33; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_k_tuple_2);
+ __Pyx_INCREF(__pyx_int_1);
+ PyTuple_SET_ITEM(__pyx_k_tuple_2, 0, __pyx_int_1);
+ __Pyx_GIVEREF(__pyx_int_1);
+ __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_2));
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":91
+ * def event_callback_priority_add(self, long _desc, int _priority, object _cb):
+ * if not callable(_cb[0]):
+ * raise TypeError("func must be callable") # <<<<<<<<<<<<<<
+ * cdef Eo_Event_Cb cb = <Eo_Event_Cb> eodefault._object_callback
+ * Py_INCREF(_cb)
+ */
+ __pyx_k_tuple_4 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 91; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_k_tuple_4);
+ __Pyx_INCREF(((PyObject *)__pyx_kp_s_3));
+ PyTuple_SET_ITEM(__pyx_k_tuple_4, 0, ((PyObject *)__pyx_kp_s_3));
+ __Pyx_GIVEREF(((PyObject *)__pyx_kp_s_3));
+ __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_4));
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":23
+ * CALLBACK_ADD = <long>eobase.EO_EV_CALLBACK_ADD
+ *
+ * def event_thaw(self): # <<<<<<<<<<<<<<
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_THAW))
+ *
+ */
+ __pyx_k_tuple_6 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_6)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 23; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_k_tuple_6);
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__self));
+ PyTuple_SET_ITEM(__pyx_k_tuple_6, 0, ((PyObject *)__pyx_n_s__self));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__self));
+ __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_6));
+ __pyx_k_codeobj_7 = (PyObject*)__Pyx_PyCode_New(1, 0, 1, 0, 0, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_k_tuple_6, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_8, __pyx_n_s__event_thaw, 23, __pyx_empty_bytes); if (unlikely(!__pyx_k_codeobj_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 23; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":26
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_THAW))
+ *
+ * def event_freeze(self): # <<<<<<<<<<<<<<
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_FREEZE))
+ *
+ */
+ __pyx_k_tuple_10 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 26; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_k_tuple_10);
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__self));
+ PyTuple_SET_ITEM(__pyx_k_tuple_10, 0, ((PyObject *)__pyx_n_s__self));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__self));
+ __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_10));
+ __pyx_k_codeobj_11 = (PyObject*)__Pyx_PyCode_New(1, 0, 1, 0, 0, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_k_tuple_10, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_8, __pyx_n_s__event_freeze, 26, __pyx_empty_bytes); if (unlikely(!__pyx_k_codeobj_11)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 26; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":29
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_FREEZE))
+ *
+ * def __init__(self, EoDefault parent): # <<<<<<<<<<<<<<
+ * instantiateable = False
+ * if not instantiateable:
+ */
+ __pyx_k_tuple_12 = PyTuple_New(3); if (unlikely(!__pyx_k_tuple_12)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 29; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_k_tuple_12);
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__self));
+ PyTuple_SET_ITEM(__pyx_k_tuple_12, 0, ((PyObject *)__pyx_n_s__self));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__self));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__parent));
+ PyTuple_SET_ITEM(__pyx_k_tuple_12, 1, ((PyObject *)__pyx_n_s__parent));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__parent));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__instantiateable));
+ PyTuple_SET_ITEM(__pyx_k_tuple_12, 2, ((PyObject *)__pyx_n_s__instantiateable));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__instantiateable));
+ __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_12));
+ __pyx_k_codeobj_13 = (PyObject*)__Pyx_PyCode_New(2, 0, 3, 0, 0, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_k_tuple_12, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_8, __pyx_n_s____init__, 29, __pyx_empty_bytes); if (unlikely(!__pyx_k_codeobj_13)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 29; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":37
+ *
+ * @staticmethod
+ * def event_global_freeze_get(): # <<<<<<<<<<<<<<
+ * cdef int fcount
+ * eodefault.eo_class_do(eobase.eo_base_class_get(), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE_GET), &fcount)
+ */
+ __pyx_k_tuple_14 = PyTuple_New(2); if (unlikely(!__pyx_k_tuple_14)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 37; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_k_tuple_14);
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__fcount));
+ PyTuple_SET_ITEM(__pyx_k_tuple_14, 0, ((PyObject *)__pyx_n_s__fcount));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__fcount));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__fcount_));
+ PyTuple_SET_ITEM(__pyx_k_tuple_14, 1, ((PyObject *)__pyx_n_s__fcount_));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__fcount_));
+ __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_14));
+ __pyx_k_codeobj_15 = (PyObject*)__Pyx_PyCode_New(0, 0, 2, 0, 0, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_k_tuple_14, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_8, __pyx_n_s_16, 37, __pyx_empty_bytes); if (unlikely(!__pyx_k_codeobj_15)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 37; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":45
+ *
+ * @staticmethod
+ * def event_global_freeze(): # <<<<<<<<<<<<<<
+ * eodefault.eo_class_do(eobase.eo_base_class_get(), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE))
+ *
+ */
+ __pyx_k_codeobj_17 = (PyObject*)__Pyx_PyCode_New(0, 0, 0, 0, 0, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_8, __pyx_n_s__event_global_freeze, 45, __pyx_empty_bytes); if (unlikely(!__pyx_k_codeobj_17)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 45; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":49
+ *
+ *
+ * def data_get(self, object _key): # <<<<<<<<<<<<<<
+ * _key = None if _key is None else pytext_to_utf8(_key)
+ * cdef char* key = NULL if _key is None else <char*> _key
+ */
+ __pyx_k_tuple_18 = PyTuple_New(5); if (unlikely(!__pyx_k_tuple_18)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 49; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_k_tuple_18);
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__self));
+ PyTuple_SET_ITEM(__pyx_k_tuple_18, 0, ((PyObject *)__pyx_n_s__self));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__self));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s___key));
+ PyTuple_SET_ITEM(__pyx_k_tuple_18, 1, ((PyObject *)__pyx_n_s___key));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s___key));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__key));
+ PyTuple_SET_ITEM(__pyx_k_tuple_18, 2, ((PyObject *)__pyx_n_s__key));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__key));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__data));
+ PyTuple_SET_ITEM(__pyx_k_tuple_18, 3, ((PyObject *)__pyx_n_s__data));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__data));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__data_));
+ PyTuple_SET_ITEM(__pyx_k_tuple_18, 4, ((PyObject *)__pyx_n_s__data_));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__data_));
+ __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_18));
+ __pyx_k_codeobj_19 = (PyObject*)__Pyx_PyCode_New(2, 0, 5, 0, 0, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_k_tuple_18, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_8, __pyx_n_s__data_get, 49, __pyx_empty_bytes); if (unlikely(!__pyx_k_codeobj_19)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 49; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":57
+ * return (data_)
+ *
+ * def event_callback_del(self, long _desc, object _func): # <<<<<<<<<<<<<<
+ * cdef Eo_Event_Cb func = <Eo_Event_Cb> eodefault._object_callback
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_DEL), _desc, func, <void*>_func)
+ */
+ __pyx_k_tuple_20 = PyTuple_New(4); if (unlikely(!__pyx_k_tuple_20)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 57; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_k_tuple_20);
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__self));
+ PyTuple_SET_ITEM(__pyx_k_tuple_20, 0, ((PyObject *)__pyx_n_s__self));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__self));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s___desc));
+ PyTuple_SET_ITEM(__pyx_k_tuple_20, 1, ((PyObject *)__pyx_n_s___desc));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s___desc));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s___func));
+ PyTuple_SET_ITEM(__pyx_k_tuple_20, 2, ((PyObject *)__pyx_n_s___func));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s___func));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__func));
+ PyTuple_SET_ITEM(__pyx_k_tuple_20, 3, ((PyObject *)__pyx_n_s__func));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__func));
+ __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_20));
+ __pyx_k_codeobj_21 = (PyObject*)__Pyx_PyCode_New(3, 0, 4, 0, 0, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_k_tuple_20, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_8, __pyx_n_s__event_callback_del, 57, __pyx_empty_bytes); if (unlikely(!__pyx_k_codeobj_21)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 57; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":65
+ *
+ *
+ * def event_freeze_get(self): # <<<<<<<<<<<<<<
+ * cdef int fcount
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_FREEZE_GET), &fcount)
+ */
+ __pyx_k_tuple_22 = PyTuple_New(3); if (unlikely(!__pyx_k_tuple_22)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 65; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_k_tuple_22);
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__self));
+ PyTuple_SET_ITEM(__pyx_k_tuple_22, 0, ((PyObject *)__pyx_n_s__self));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__self));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__fcount));
+ PyTuple_SET_ITEM(__pyx_k_tuple_22, 1, ((PyObject *)__pyx_n_s__fcount));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__fcount));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__fcount_));
+ PyTuple_SET_ITEM(__pyx_k_tuple_22, 2, ((PyObject *)__pyx_n_s__fcount_));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__fcount_));
+ __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_22));
+ __pyx_k_codeobj_23 = (PyObject*)__Pyx_PyCode_New(1, 0, 3, 0, 0, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_k_tuple_22, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_8, __pyx_n_s__event_freeze_get, 65, __pyx_empty_bytes); if (unlikely(!__pyx_k_codeobj_23)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 65; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":72
+ *
+ * @staticmethod
+ * def event_global_thaw(): # <<<<<<<<<<<<<<
+ * eodefault.eo_class_do(eobase.eo_base_class_get(), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_GLOBAL_THAW))
+ *
+ */
+ __pyx_k_codeobj_24 = (PyObject*)__Pyx_PyCode_New(0, 0, 0, 0, 0, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_8, __pyx_n_s__event_global_thaw, 72, __pyx_empty_bytes); if (unlikely(!__pyx_k_codeobj_24)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 72; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":76
+ *
+ *
+ * def data_del(self, object _key): # <<<<<<<<<<<<<<
+ * _key = None if _key is None else pytext_to_utf8(_key)
+ * cdef char* key = NULL if _key is None else <char*> _key
+ */
+ __pyx_k_tuple_25 = PyTuple_New(3); if (unlikely(!__pyx_k_tuple_25)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 76; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_k_tuple_25);
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__self));
+ PyTuple_SET_ITEM(__pyx_k_tuple_25, 0, ((PyObject *)__pyx_n_s__self));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__self));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s___key));
+ PyTuple_SET_ITEM(__pyx_k_tuple_25, 1, ((PyObject *)__pyx_n_s___key));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s___key));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__key));
+ PyTuple_SET_ITEM(__pyx_k_tuple_25, 2, ((PyObject *)__pyx_n_s__key));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__key));
+ __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_25));
+ __pyx_k_codeobj_26 = (PyObject*)__Pyx_PyCode_New(2, 0, 3, 0, 0, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_k_tuple_25, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_8, __pyx_n_s__data_del, 76, __pyx_empty_bytes); if (unlikely(!__pyx_k_codeobj_26)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 76; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":81
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_DEL), key)
+ *
+ * def event_callback_call(self, long _desc, object _event_info): # <<<<<<<<<<<<<<
+ * cdef long desc = <long> _desc
+ * cdef void* event_info = <void*> _event_info
+ */
+ __pyx_k_tuple_27 = PyTuple_New(7); if (unlikely(!__pyx_k_tuple_27)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 81; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_k_tuple_27);
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__self));
+ PyTuple_SET_ITEM(__pyx_k_tuple_27, 0, ((PyObject *)__pyx_n_s__self));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__self));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s___desc));
+ PyTuple_SET_ITEM(__pyx_k_tuple_27, 1, ((PyObject *)__pyx_n_s___desc));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s___desc));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s___event_info));
+ PyTuple_SET_ITEM(__pyx_k_tuple_27, 2, ((PyObject *)__pyx_n_s___event_info));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s___event_info));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__desc));
+ PyTuple_SET_ITEM(__pyx_k_tuple_27, 3, ((PyObject *)__pyx_n_s__desc));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__desc));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__event_info));
+ PyTuple_SET_ITEM(__pyx_k_tuple_27, 4, ((PyObject *)__pyx_n_s__event_info));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__event_info));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__aborted));
+ PyTuple_SET_ITEM(__pyx_k_tuple_27, 5, ((PyObject *)__pyx_n_s__aborted));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__aborted));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__aborted_));
+ PyTuple_SET_ITEM(__pyx_k_tuple_27, 6, ((PyObject *)__pyx_n_s__aborted_));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__aborted_));
+ __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_27));
+ __pyx_k_codeobj_28 = (PyObject*)__Pyx_PyCode_New(3, 0, 7, 0, 0, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_k_tuple_27, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_8, __pyx_n_s__event_callback_call, 81, __pyx_empty_bytes); if (unlikely(!__pyx_k_codeobj_28)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 81; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":89
+ * return (aborted_)
+ *
+ * def event_callback_priority_add(self, long _desc, int _priority, object _cb): # <<<<<<<<<<<<<<
+ * if not callable(_cb[0]):
+ * raise TypeError("func must be callable")
+ */
+ __pyx_k_tuple_29 = PyTuple_New(5); if (unlikely(!__pyx_k_tuple_29)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 89; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_k_tuple_29);
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__self));
+ PyTuple_SET_ITEM(__pyx_k_tuple_29, 0, ((PyObject *)__pyx_n_s__self));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__self));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s___desc));
+ PyTuple_SET_ITEM(__pyx_k_tuple_29, 1, ((PyObject *)__pyx_n_s___desc));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s___desc));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s___priority));
+ PyTuple_SET_ITEM(__pyx_k_tuple_29, 2, ((PyObject *)__pyx_n_s___priority));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s___priority));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s___cb));
+ PyTuple_SET_ITEM(__pyx_k_tuple_29, 3, ((PyObject *)__pyx_n_s___cb));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s___cb));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__cb));
+ PyTuple_SET_ITEM(__pyx_k_tuple_29, 4, ((PyObject *)__pyx_n_s__cb));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__cb));
+ __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_29));
+ __pyx_k_codeobj_30 = (PyObject*)__Pyx_PyCode_New(4, 0, 5, 0, 0, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_k_tuple_29, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_8, __pyx_n_s_31, 89, __pyx_empty_bytes); if (unlikely(!__pyx_k_codeobj_30)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 89; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":97
+ *
+ *
+ * def data_set(self, object _key, object _data): # <<<<<<<<<<<<<<
+ * _key = pytext_to_utf8(_key)
+ * cdef char* key = <char*> _key
+ */
+ __pyx_k_tuple_32 = PyTuple_New(4); if (unlikely(!__pyx_k_tuple_32)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 97; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_k_tuple_32);
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__self));
+ PyTuple_SET_ITEM(__pyx_k_tuple_32, 0, ((PyObject *)__pyx_n_s__self));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__self));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s___key));
+ PyTuple_SET_ITEM(__pyx_k_tuple_32, 1, ((PyObject *)__pyx_n_s___key));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s___key));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s___data));
+ PyTuple_SET_ITEM(__pyx_k_tuple_32, 2, ((PyObject *)__pyx_n_s___data));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s___data));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__key));
+ PyTuple_SET_ITEM(__pyx_k_tuple_32, 3, ((PyObject *)__pyx_n_s__key));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__key));
+ __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_32));
+ __pyx_k_codeobj_33 = (PyObject*)__Pyx_PyCode_New(3, 0, 4, 0, 0, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_k_tuple_32, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_8, __pyx_n_s__data_set, 97, __pyx_empty_bytes); if (unlikely(!__pyx_k_codeobj_33)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 97; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":102
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_SET), key, <void*>_data, NULL)
+ *
+ * def _data_set(self, object _key, object _data): # <<<<<<<<<<<<<<
+ * _key = pytext_to_utf8(_key)
+ * cdef char* key = <char*> _key
+ */
+ __pyx_k_tuple_34 = PyTuple_New(4); if (unlikely(!__pyx_k_tuple_34)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 102; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_k_tuple_34);
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__self));
+ PyTuple_SET_ITEM(__pyx_k_tuple_34, 0, ((PyObject *)__pyx_n_s__self));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__self));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s___key));
+ PyTuple_SET_ITEM(__pyx_k_tuple_34, 1, ((PyObject *)__pyx_n_s___key));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s___key));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s___data));
+ PyTuple_SET_ITEM(__pyx_k_tuple_34, 2, ((PyObject *)__pyx_n_s___data));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s___data));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__key));
+ PyTuple_SET_ITEM(__pyx_k_tuple_34, 3, ((PyObject *)__pyx_n_s__key));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__key));
+ __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_34));
+ __pyx_k_codeobj_35 = (PyObject*)__Pyx_PyCode_New(3, 0, 4, 0, 0, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_k_tuple_34, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_8, __pyx_n_s___data_set, 102, __pyx_empty_bytes); if (unlikely(!__pyx_k_codeobj_35)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 102; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_RefNannyFinishContext();
+ return 0;
+ __pyx_L1_error:;
+ __Pyx_RefNannyFinishContext();
+ return -1;
+}
+
+static int __Pyx_InitGlobals(void) {
+ if (__Pyx_InitStrings(__pyx_string_tab) < 0) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;};
+ __pyx_int_1 = PyInt_FromLong(1); if (unlikely(!__pyx_int_1)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;};
+ return 0;
+ __pyx_L1_error:;
+ return -1;
+}
+
+#if PY_MAJOR_VERSION < 3
+PyMODINIT_FUNC initeobase(void); /*proto*/
+PyMODINIT_FUNC initeobase(void)
+#else
+PyMODINIT_FUNC PyInit_eobase(void); /*proto*/
+PyMODINIT_FUNC PyInit_eobase(void)
+#endif
+{
+ PyObject *__pyx_t_1 = NULL;
+ PyObject *__pyx_t_2 = NULL;
+ PyObject *__pyx_t_3 = NULL;
+ PyObject *__pyx_t_4 = NULL;
+ __Pyx_RefNannyDeclarations
+ #if CYTHON_REFNANNY
+ __Pyx_RefNanny = __Pyx_RefNannyImportAPI("refnanny");
+ if (!__Pyx_RefNanny) {
+ PyErr_Clear();
+ __Pyx_RefNanny = __Pyx_RefNannyImportAPI("Cython.Runtime.refnanny");
+ if (!__Pyx_RefNanny)
+ Py_FatalError("failed to import 'refnanny' module");
+ }
+ #endif
+ __Pyx_RefNannySetupContext("PyMODINIT_FUNC PyInit_eobase(void)", 0);
+ if ( __Pyx_check_binary_version() < 0) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_empty_tuple = PyTuple_New(0); if (unlikely(!__pyx_empty_tuple)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_empty_bytes = PyBytes_FromStringAndSize("", 0); if (unlikely(!__pyx_empty_bytes)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ #ifdef __Pyx_CyFunction_USED
+ if (__Pyx_CyFunction_init() < 0) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ #endif
+ #ifdef __Pyx_FusedFunction_USED
+ if (__pyx_FusedFunction_init() < 0) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ #endif
+ #ifdef __Pyx_Generator_USED
+ if (__pyx_Generator_init() < 0) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ #endif
+ /*--- Library function declarations ---*/
+ /*--- Threads initialization code ---*/
+ #if defined(__PYX_FORCE_INIT_THREADS) && __PYX_FORCE_INIT_THREADS
+ #ifdef WITH_THREAD /* Python build with threading support? */
+ PyEval_InitThreads();
+ #endif
+ #endif
+ /*--- Module creation code ---*/
+ #if PY_MAJOR_VERSION < 3
+ __pyx_m = Py_InitModule4(__Pyx_NAMESTR("eobase"), __pyx_methods, 0, 0, PYTHON_API_VERSION); Py_XINCREF(__pyx_m);
+ #else
+ __pyx_m = PyModule_Create(&__pyx_moduledef);
+ #endif
+ if (unlikely(!__pyx_m)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ #if PY_MAJOR_VERSION >= 3
+ {
+ PyObject *modules = PyImport_GetModuleDict(); if (unlikely(!modules)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ if (!PyDict_GetItemString(modules, "eorepo.eobase")) {
+ if (unlikely(PyDict_SetItemString(modules, "eorepo.eobase", __pyx_m) < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ }
+ }
+ #endif
+ __pyx_b = PyImport_AddModule(__Pyx_NAMESTR(__Pyx_BUILTIN_MODULE_NAME)); if (unlikely(!__pyx_b)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ #if CYTHON_COMPILING_IN_PYPY
+ Py_INCREF(__pyx_b);
+ #endif
+ if (__Pyx_SetAttrString(__pyx_m, "__builtins__", __pyx_b) < 0) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;};
+ /*--- Initialize various global constants etc. ---*/
+ if (unlikely(__Pyx_InitGlobals() < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ if (__pyx_module_is_main_eorepo__eobase) {
+ if (__Pyx_SetAttrString(__pyx_m, "__name__", __pyx_n_s____main__) < 0) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;};
+ }
+ /*--- Builtin init code ---*/
+ if (unlikely(__Pyx_InitCachedBuiltins() < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ /*--- Constants init code ---*/
+ if (unlikely(__Pyx_InitCachedConstants() < 0)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ /*--- Global init code ---*/
+ /*--- Variable export code ---*/
+ /*--- Function export code ---*/
+ /*--- Type init code ---*/
+ /*--- Type import code ---*/
+ __pyx_ptype_6eorepo_9eodefault_EoDefault = __Pyx_ImportType("eorepo.eodefault", "EoDefault", sizeof(struct __pyx_obj_6eorepo_9eodefault_EoDefault), 1); if (unlikely(!__pyx_ptype_6eorepo_9eodefault_EoDefault)) {__pyx_filename = __pyx_f[2]; __pyx_lineno = 73; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_vtabptr_6eorepo_9eodefault_EoDefault = (struct __pyx_vtabstruct_6eorepo_9eodefault_EoDefault*)__Pyx_GetVtable(__pyx_ptype_6eorepo_9eodefault_EoDefault->tp_dict); if (unlikely(!__pyx_vtabptr_6eorepo_9eodefault_EoDefault)) {__pyx_filename = __pyx_f[2]; __pyx_lineno = 73; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_ptype_7cpython_4type_type = __Pyx_ImportType(__Pyx_BUILTIN_MODULE_NAME, "type",
+ #if CYTHON_COMPILING_IN_PYPY
+ sizeof(PyTypeObject),
+ #else
+ sizeof(PyHeapTypeObject),
+ #endif
+ 0); if (unlikely(!__pyx_ptype_7cpython_4type_type)) {__pyx_filename = __pyx_f[3]; __pyx_lineno = 9; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_ptype_7cpython_4bool_bool = __Pyx_ImportType(__Pyx_BUILTIN_MODULE_NAME, "bool", sizeof(PyBoolObject), 0); if (unlikely(!__pyx_ptype_7cpython_4bool_bool)) {__pyx_filename = __pyx_f[4]; __pyx_lineno = 8; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_ptype_7cpython_7complex_complex = __Pyx_ImportType(__Pyx_BUILTIN_MODULE_NAME, "complex", sizeof(PyComplexObject), 0); if (unlikely(!__pyx_ptype_7cpython_7complex_complex)) {__pyx_filename = __pyx_f[5]; __pyx_lineno = 15; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ /*--- Variable import code ---*/
+ /*--- Function import code ---*/
+ __pyx_t_1 = __Pyx_ImportModule("eorepo.eodefault"); if (!__pyx_t_1) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ if (__Pyx_ImportFunction(__pyx_t_1, "_eo_instance_get", (void (**)(void))&__pyx_f_6eorepo_9eodefault__eo_instance_get, "Eo *(struct __pyx_obj_6eorepo_9eodefault_EoDefault *)") < 0) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ if (__Pyx_ImportFunction(__pyx_t_1, "_object_callback", (void (**)(void))&__pyx_f_6eorepo_9eodefault__object_callback, "Eina_Bool (void *, Eo *, Eo_Event_Description *, void *)") < 0) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ Py_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ /*--- Execution code ---*/
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":8
+ *
+ * cimport eobase as eobase
+ * from eodefault import EoDefault # <<<<<<<<<<<<<<
+ *
+ * from cpython cimport Py_INCREF, Py_DECREF
+ */
+ __pyx_t_2 = PyList_New(1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 8; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_2);
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__EoDefault));
+ PyList_SET_ITEM(__pyx_t_2, 0, ((PyObject *)__pyx_n_s__EoDefault));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__EoDefault));
+ __pyx_t_3 = __Pyx_Import(((PyObject *)__pyx_n_s__eodefault), ((PyObject *)__pyx_t_2), -1); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 8; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0;
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":12
+ * from cpython cimport Py_INCREF, Py_DECREF
+ *
+ * from eorepo.eodefault import pytext_to_utf8 # <<<<<<<<<<<<<<
+ *
+ * cdef int eobase_sub_id(int sub_id):
+ */
+ __pyx_t_3 = PyList_New(1); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 12; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__pytext_to_utf8));
+ PyList_SET_ITEM(__pyx_t_3, 0, ((PyObject *)__pyx_n_s__pytext_to_utf8));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__pytext_to_utf8));
+ __pyx_t_2 = __Pyx_Import(((PyObject *)__pyx_n_s_5), ((PyObject *)__pyx_t_3), -1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 12; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_2);
+ __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0;
+ __pyx_t_3 = PyObject_GetAttr(__pyx_t_2, __pyx_n_s__pytext_to_utf8);
+ if (__pyx_t_3 == NULL) {
+ if (PyErr_ExceptionMatches(PyExc_AttributeError)) __Pyx_RaiseImportError(__pyx_n_s__pytext_to_utf8);
+ if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 12; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ }
+ __Pyx_GOTREF(__pyx_t_3);
+ if (PyObject_SetAttr(__pyx_m, __pyx_n_s__pytext_to_utf8, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 12; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+ __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":17
+ * return eobase.EO_BASE_BASE_ID + sub_id
+ *
+ * class EoBase(EoDefault): # <<<<<<<<<<<<<<
+ *
+ * CALLBACK_DEL = <long>eobase.EO_EV_CALLBACK_DEL
+ */
+ __pyx_t_2 = PyDict_New(); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 17; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(((PyObject *)__pyx_t_2));
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":19
+ * class EoBase(EoDefault):
+ *
+ * CALLBACK_DEL = <long>eobase.EO_EV_CALLBACK_DEL # <<<<<<<<<<<<<<
+ * DEL = <long>eobase.EO_EV_DEL
+ * CALLBACK_ADD = <long>eobase.EO_EV_CALLBACK_ADD
+ */
+ __pyx_t_3 = PyInt_FromLong(((long)EO_EV_CALLBACK_DEL)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 19; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ if (PyObject_SetItem(__pyx_t_2, __pyx_n_s__CALLBACK_DEL, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 19; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":20
+ *
+ * CALLBACK_DEL = <long>eobase.EO_EV_CALLBACK_DEL
+ * DEL = <long>eobase.EO_EV_DEL # <<<<<<<<<<<<<<
+ * CALLBACK_ADD = <long>eobase.EO_EV_CALLBACK_ADD
+ *
+ */
+ __pyx_t_3 = PyInt_FromLong(((long)EO_EV_DEL)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 20; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ if (PyObject_SetItem(__pyx_t_2, __pyx_n_s__DEL, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 20; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":21
+ * CALLBACK_DEL = <long>eobase.EO_EV_CALLBACK_DEL
+ * DEL = <long>eobase.EO_EV_DEL
+ * CALLBACK_ADD = <long>eobase.EO_EV_CALLBACK_ADD # <<<<<<<<<<<<<<
+ *
+ * def event_thaw(self):
+ */
+ __pyx_t_3 = PyInt_FromLong(((long)EO_EV_CALLBACK_ADD)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 21; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ if (PyObject_SetItem(__pyx_t_2, __pyx_n_s__CALLBACK_ADD, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 21; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":23
+ * CALLBACK_ADD = <long>eobase.EO_EV_CALLBACK_ADD
+ *
+ * def event_thaw(self): # <<<<<<<<<<<<<<
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_THAW))
+ *
+ */
+ __pyx_t_3 = __Pyx_CyFunction_NewEx(&__pyx_mdef_6eorepo_6eobase_6EoBase_1event_thaw, 0, NULL, __pyx_n_s_9, ((PyObject *)__pyx_k_codeobj_7)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 23; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ if (PyObject_SetItem(__pyx_t_2, __pyx_n_s__event_thaw, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 23; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":26
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_THAW))
+ *
+ * def event_freeze(self): # <<<<<<<<<<<<<<
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_FREEZE))
+ *
+ */
+ __pyx_t_3 = __Pyx_CyFunction_NewEx(&__pyx_mdef_6eorepo_6eobase_6EoBase_3event_freeze, 0, NULL, __pyx_n_s_9, ((PyObject *)__pyx_k_codeobj_11)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 26; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ if (PyObject_SetItem(__pyx_t_2, __pyx_n_s__event_freeze, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 26; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":29
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_FREEZE))
+ *
+ * def __init__(self, EoDefault parent): # <<<<<<<<<<<<<<
+ * instantiateable = False
+ * if not instantiateable:
+ */
+ __pyx_t_3 = __Pyx_CyFunction_NewEx(&__pyx_mdef_6eorepo_6eobase_6EoBase_5__init__, 0, NULL, __pyx_n_s_9, ((PyObject *)__pyx_k_codeobj_13)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 29; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ if (PyObject_SetItem(__pyx_t_2, __pyx_n_s____init__, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 29; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":37
+ *
+ * @staticmethod
+ * def event_global_freeze_get(): # <<<<<<<<<<<<<<
+ * cdef int fcount
+ * eodefault.eo_class_do(eobase.eo_base_class_get(), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE_GET), &fcount)
+ */
+ __pyx_t_3 = __Pyx_CyFunction_NewEx(&__pyx_mdef_6eorepo_6eobase_6EoBase_7event_global_freeze_get, __Pyx_CYFUNCTION_STATICMETHOD, NULL, __pyx_n_s_9, ((PyObject *)__pyx_k_codeobj_15)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 37; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __pyx_t_4 = PyTuple_New(1); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 36; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_4);
+ PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_3);
+ __Pyx_GIVEREF(__pyx_t_3);
+ __pyx_t_3 = 0;
+ __pyx_t_3 = PyObject_Call(__pyx_builtin_staticmethod, ((PyObject *)__pyx_t_4), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 36; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __Pyx_DECREF(((PyObject *)__pyx_t_4)); __pyx_t_4 = 0;
+ if (PyObject_SetItem(__pyx_t_2, __pyx_n_s_16, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 37; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":45
+ *
+ * @staticmethod
+ * def event_global_freeze(): # <<<<<<<<<<<<<<
+ * eodefault.eo_class_do(eobase.eo_base_class_get(), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE))
+ *
+ */
+ __pyx_t_3 = __Pyx_CyFunction_NewEx(&__pyx_mdef_6eorepo_6eobase_6EoBase_9event_global_freeze, __Pyx_CYFUNCTION_STATICMETHOD, NULL, __pyx_n_s_9, ((PyObject *)__pyx_k_codeobj_17)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 45; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __pyx_t_4 = PyTuple_New(1); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 44; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_4);
+ PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_3);
+ __Pyx_GIVEREF(__pyx_t_3);
+ __pyx_t_3 = 0;
+ __pyx_t_3 = PyObject_Call(__pyx_builtin_staticmethod, ((PyObject *)__pyx_t_4), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 44; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __Pyx_DECREF(((PyObject *)__pyx_t_4)); __pyx_t_4 = 0;
+ if (PyObject_SetItem(__pyx_t_2, __pyx_n_s__event_global_freeze, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 45; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":49
+ *
+ *
+ * def data_get(self, object _key): # <<<<<<<<<<<<<<
+ * _key = None if _key is None else pytext_to_utf8(_key)
+ * cdef char* key = NULL if _key is None else <char*> _key
+ */
+ __pyx_t_3 = __Pyx_CyFunction_NewEx(&__pyx_mdef_6eorepo_6eobase_6EoBase_11data_get, 0, NULL, __pyx_n_s_9, ((PyObject *)__pyx_k_codeobj_19)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 49; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ if (PyObject_SetItem(__pyx_t_2, __pyx_n_s__data_get, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 49; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":57
+ * return (data_)
+ *
+ * def event_callback_del(self, long _desc, object _func): # <<<<<<<<<<<<<<
+ * cdef Eo_Event_Cb func = <Eo_Event_Cb> eodefault._object_callback
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_DEL), _desc, func, <void*>_func)
+ */
+ __pyx_t_3 = __Pyx_CyFunction_NewEx(&__pyx_mdef_6eorepo_6eobase_6EoBase_13event_callback_del, 0, NULL, __pyx_n_s_9, ((PyObject *)__pyx_k_codeobj_21)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 57; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ if (PyObject_SetItem(__pyx_t_2, __pyx_n_s__event_callback_del, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 57; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":65
+ *
+ *
+ * def event_freeze_get(self): # <<<<<<<<<<<<<<
+ * cdef int fcount
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_FREEZE_GET), &fcount)
+ */
+ __pyx_t_3 = __Pyx_CyFunction_NewEx(&__pyx_mdef_6eorepo_6eobase_6EoBase_15event_freeze_get, 0, NULL, __pyx_n_s_9, ((PyObject *)__pyx_k_codeobj_23)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 65; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ if (PyObject_SetItem(__pyx_t_2, __pyx_n_s__event_freeze_get, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 65; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":72
+ *
+ * @staticmethod
+ * def event_global_thaw(): # <<<<<<<<<<<<<<
+ * eodefault.eo_class_do(eobase.eo_base_class_get(), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_GLOBAL_THAW))
+ *
+ */
+ __pyx_t_3 = __Pyx_CyFunction_NewEx(&__pyx_mdef_6eorepo_6eobase_6EoBase_17event_global_thaw, __Pyx_CYFUNCTION_STATICMETHOD, NULL, __pyx_n_s_9, ((PyObject *)__pyx_k_codeobj_24)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 72; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __pyx_t_4 = PyTuple_New(1); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 71; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_4);
+ PyTuple_SET_ITEM(__pyx_t_4, 0, __pyx_t_3);
+ __Pyx_GIVEREF(__pyx_t_3);
+ __pyx_t_3 = 0;
+ __pyx_t_3 = PyObject_Call(__pyx_builtin_staticmethod, ((PyObject *)__pyx_t_4), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 71; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __Pyx_DECREF(((PyObject *)__pyx_t_4)); __pyx_t_4 = 0;
+ if (PyObject_SetItem(__pyx_t_2, __pyx_n_s__event_global_thaw, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 72; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":76
+ *
+ *
+ * def data_del(self, object _key): # <<<<<<<<<<<<<<
+ * _key = None if _key is None else pytext_to_utf8(_key)
+ * cdef char* key = NULL if _key is None else <char*> _key
+ */
+ __pyx_t_3 = __Pyx_CyFunction_NewEx(&__pyx_mdef_6eorepo_6eobase_6EoBase_19data_del, 0, NULL, __pyx_n_s_9, ((PyObject *)__pyx_k_codeobj_26)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 76; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ if (PyObject_SetItem(__pyx_t_2, __pyx_n_s__data_del, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 76; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":81
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_DEL), key)
+ *
+ * def event_callback_call(self, long _desc, object _event_info): # <<<<<<<<<<<<<<
+ * cdef long desc = <long> _desc
+ * cdef void* event_info = <void*> _event_info
+ */
+ __pyx_t_3 = __Pyx_CyFunction_NewEx(&__pyx_mdef_6eorepo_6eobase_6EoBase_21event_callback_call, 0, NULL, __pyx_n_s_9, ((PyObject *)__pyx_k_codeobj_28)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 81; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ if (PyObject_SetItem(__pyx_t_2, __pyx_n_s__event_callback_call, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 81; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":89
+ * return (aborted_)
+ *
+ * def event_callback_priority_add(self, long _desc, int _priority, object _cb): # <<<<<<<<<<<<<<
+ * if not callable(_cb[0]):
+ * raise TypeError("func must be callable")
+ */
+ __pyx_t_3 = __Pyx_CyFunction_NewEx(&__pyx_mdef_6eorepo_6eobase_6EoBase_23event_callback_priority_add, 0, NULL, __pyx_n_s_9, ((PyObject *)__pyx_k_codeobj_30)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 89; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ if (PyObject_SetItem(__pyx_t_2, __pyx_n_s_31, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 89; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":97
+ *
+ *
+ * def data_set(self, object _key, object _data): # <<<<<<<<<<<<<<
+ * _key = pytext_to_utf8(_key)
+ * cdef char* key = <char*> _key
+ */
+ __pyx_t_3 = __Pyx_CyFunction_NewEx(&__pyx_mdef_6eorepo_6eobase_6EoBase_25data_set, 0, NULL, __pyx_n_s_9, ((PyObject *)__pyx_k_codeobj_33)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 97; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ if (PyObject_SetItem(__pyx_t_2, __pyx_n_s__data_set, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 97; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":102
+ * eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_SET), key, <void*>_data, NULL)
+ *
+ * def _data_set(self, object _key, object _data): # <<<<<<<<<<<<<<
+ * _key = pytext_to_utf8(_key)
+ * cdef char* key = <char*> _key
+ */
+ __pyx_t_3 = __Pyx_CyFunction_NewEx(&__pyx_mdef_6eorepo_6eobase_6EoBase_27_data_set, 0, NULL, __pyx_n_s_9, ((PyObject *)__pyx_k_codeobj_35)); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 102; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ if (PyObject_SetItem(__pyx_t_2, __pyx_n_s___data_set, __pyx_t_3) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 102; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+
+ /* "/home/yakov/eo_bindings/eorepo/eobase.pxi":17
+ * return eobase.EO_BASE_BASE_ID + sub_id
+ *
+ * class EoBase(EoDefault): # <<<<<<<<<<<<<<
+ *
+ * CALLBACK_DEL = <long>eobase.EO_EV_CALLBACK_DEL
+ */
+ __pyx_t_3 = PyTuple_New(1); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 17; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __Pyx_INCREF(((PyObject *)((PyObject*)__pyx_ptype_6eorepo_9eodefault_EoDefault)));
+ PyTuple_SET_ITEM(__pyx_t_3, 0, ((PyObject *)((PyObject*)__pyx_ptype_6eorepo_9eodefault_EoDefault)));
+ __Pyx_GIVEREF(((PyObject *)((PyObject*)__pyx_ptype_6eorepo_9eodefault_EoDefault)));
+ __pyx_t_4 = __Pyx_CreateClass(((PyObject *)__pyx_t_3), ((PyObject *)__pyx_t_2), __pyx_n_s__EoBase, __pyx_n_s_9); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 17; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_4);
+ __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0;
+ if (PyObject_SetAttr(__pyx_m, __pyx_n_s__EoBase, __pyx_t_4) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 17; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
+ __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0;
+
+ /* "eorepo/eobase.pyx":1
+ * include "eobase.pxi" # <<<<<<<<<<<<<<
+ */
+ __pyx_t_2 = PyDict_New(); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(((PyObject *)__pyx_t_2));
+ if (PyObject_SetAttr(__pyx_m, __pyx_n_s____test__, ((PyObject *)__pyx_t_2)) < 0) {__pyx_filename = __pyx_f[1]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0;
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_XDECREF(__pyx_t_2);
+ __Pyx_XDECREF(__pyx_t_3);
+ __Pyx_XDECREF(__pyx_t_4);
+ if (__pyx_m) {
+ __Pyx_AddTraceback("init eorepo.eobase", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ Py_DECREF(__pyx_m); __pyx_m = 0;
+ } else if (!PyErr_Occurred()) {
+ PyErr_SetString(PyExc_ImportError, "init eorepo.eobase");
+ }
+ __pyx_L0:;
+ __Pyx_RefNannyFinishContext();
+ #if PY_MAJOR_VERSION < 3
+ return;
+ #else
+ return __pyx_m;
+ #endif
+}
+
+/* Runtime support code */
+#if CYTHON_REFNANNY
+static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname) {
+ PyObject *m = NULL, *p = NULL;
+ void *r = NULL;
+ m = PyImport_ImportModule((char *)modname);
+ if (!m) goto end;
+ p = PyObject_GetAttrString(m, (char *)"RefNannyAPI");
+ if (!p) goto end;
+ r = PyLong_AsVoidPtr(p);
+end:
+ Py_XDECREF(p);
+ Py_XDECREF(m);
+ return (__Pyx_RefNannyAPIStruct *)r;
+}
+#endif /* CYTHON_REFNANNY */
+
+static PyObject *__Pyx_GetName(PyObject *dict, PyObject *name) {
+ PyObject *result;
+ result = PyObject_GetAttr(dict, name);
+ if (!result) {
+ if (dict != __pyx_b) {
+ PyErr_Clear();
+ result = PyObject_GetAttr(__pyx_b, name);
+ }
+ if (!result) {
+ PyErr_SetObject(PyExc_NameError, name);
+ }
+ }
+ return result;
+}
+
+static CYTHON_INLINE int __Pyx_TypeTest(PyObject *obj, PyTypeObject *type) {
+ if (unlikely(!type)) {
+ PyErr_Format(PyExc_SystemError, "Missing type object");
+ return 0;
+ }
+ if (likely(PyObject_TypeCheck(obj, type)))
+ return 1;
+ PyErr_Format(PyExc_TypeError, "Cannot convert %.200s to %.200s",
+ Py_TYPE(obj)->tp_name, type->tp_name);
+ return 0;
+}
+
+static void __Pyx_RaiseArgtupleInvalid(
+ const char* func_name,
+ int exact,
+ Py_ssize_t num_min,
+ Py_ssize_t num_max,
+ Py_ssize_t num_found)
+{
+ Py_ssize_t num_expected;
+ const char *more_or_less;
+ if (num_found < num_min) {
+ num_expected = num_min;
+ more_or_less = "at least";
+ } else {
+ num_expected = num_max;
+ more_or_less = "at most";
+ }
+ if (exact) {
+ more_or_less = "exactly";
+ }
+ PyErr_Format(PyExc_TypeError,
+ "%s() takes %s %" CYTHON_FORMAT_SSIZE_T "d positional argument%s (%" CYTHON_FORMAT_SSIZE_T "d given)",
+ func_name, more_or_less, num_expected,
+ (num_expected == 1) ? "" : "s", num_found);
+}
+
+static void __Pyx_RaiseDoubleKeywordsError(
+ const char* func_name,
+ PyObject* kw_name)
+{
+ PyErr_Format(PyExc_TypeError,
+ #if PY_MAJOR_VERSION >= 3
+ "%s() got multiple values for keyword argument '%U'", func_name, kw_name);
+ #else
+ "%s() got multiple values for keyword argument '%s'", func_name,
+ PyString_AsString(kw_name));
+ #endif
+}
+
+static int __Pyx_ParseOptionalKeywords(
+ PyObject *kwds,
+ PyObject **argnames[],
+ PyObject *kwds2,
+ PyObject *values[],
+ Py_ssize_t num_pos_args,
+ const char* function_name)
+{
+ PyObject *key = 0, *value = 0;
+ Py_ssize_t pos = 0;
+ PyObject*** name;
+ PyObject*** first_kw_arg = argnames + num_pos_args;
+ while (PyDict_Next(kwds, &pos, &key, &value)) {
+ name = first_kw_arg;
+ while (*name && (**name != key)) name++;
+ if (*name) {
+ values[name-argnames] = value;
+ continue;
+ }
+ name = first_kw_arg;
+ #if PY_MAJOR_VERSION < 3
+ if (likely(PyString_CheckExact(key)) || likely(PyString_Check(key))) {
+ while (*name) {
+ if ((CYTHON_COMPILING_IN_PYPY || PyString_GET_SIZE(**name) == PyString_GET_SIZE(key))
+ && _PyString_Eq(**name, key)) {
+ values[name-argnames] = value;
+ break;
+ }
+ name++;
+ }
+ if (*name) continue;
+ else {
+ PyObject*** argname = argnames;
+ while (argname != first_kw_arg) {
+ if ((**argname == key) || (
+ (CYTHON_COMPILING_IN_PYPY || PyString_GET_SIZE(**argname) == PyString_GET_SIZE(key))
+ && _PyString_Eq(**argname, key))) {
+ goto arg_passed_twice;
+ }
+ argname++;
+ }
+ }
+ } else
+ #endif
+ if (likely(PyUnicode_Check(key))) {
+ while (*name) {
+ int cmp = (**name == key) ? 0 :
+ #if !CYTHON_COMPILING_IN_PYPY && PY_MAJOR_VERSION >= 3
+ (PyUnicode_GET_SIZE(**name) != PyUnicode_GET_SIZE(key)) ? 1 :
+ #endif
+ PyUnicode_Compare(**name, key);
+ if (cmp < 0 && unlikely(PyErr_Occurred())) goto bad;
+ if (cmp == 0) {
+ values[name-argnames] = value;
+ break;
+ }
+ name++;
+ }
+ if (*name) continue;
+ else {
+ PyObject*** argname = argnames;
+ while (argname != first_kw_arg) {
+ int cmp = (**argname == key) ? 0 :
+ #if !CYTHON_COMPILING_IN_PYPY && PY_MAJOR_VERSION >= 3
+ (PyUnicode_GET_SIZE(**argname) != PyUnicode_GET_SIZE(key)) ? 1 :
+ #endif
+ PyUnicode_Compare(**argname, key);
+ if (cmp < 0 && unlikely(PyErr_Occurred())) goto bad;
+ if (cmp == 0) goto arg_passed_twice;
+ argname++;
+ }
+ }
+ } else
+ goto invalid_keyword_type;
+ if (kwds2) {
+ if (unlikely(PyDict_SetItem(kwds2, key, value))) goto bad;
+ } else {
+ goto invalid_keyword;
+ }
+ }
+ return 0;
+arg_passed_twice:
+ __Pyx_RaiseDoubleKeywordsError(function_name, key);
+ goto bad;
+invalid_keyword_type:
+ PyErr_Format(PyExc_TypeError,
+ "%s() keywords must be strings", function_name);
+ goto bad;
+invalid_keyword:
+ PyErr_Format(PyExc_TypeError,
+ #if PY_MAJOR_VERSION < 3
+ "%s() got an unexpected keyword argument '%s'",
+ function_name, PyString_AsString(key));
+ #else
+ "%s() got an unexpected keyword argument '%U'",
+ function_name, key);
+ #endif
+bad:
+ return -1;
+}
+
+static int __Pyx_ArgTypeTest(PyObject *obj, PyTypeObject *type, int none_allowed,
+ const char *name, int exact)
+{
+ if (!type) {
+ PyErr_Format(PyExc_SystemError, "Missing type object");
+ return 0;
+ }
+ if (none_allowed && obj == Py_None) return 1;
+ else if (exact) {
+ if (Py_TYPE(obj) == type) return 1;
+ }
+ else {
+ if (PyObject_TypeCheck(obj, type)) return 1;
+ }
+ PyErr_Format(PyExc_TypeError,
+ "Argument '%s' has incorrect type (expected %s, got %s)",
+ name, type->tp_name, Py_TYPE(obj)->tp_name);
+ return 0;
+}
+
+static CYTHON_INLINE void __Pyx_ErrRestore(PyObject *type, PyObject *value, PyObject *tb) {
+#if CYTHON_COMPILING_IN_CPYTHON
+ PyObject *tmp_type, *tmp_value, *tmp_tb;
+ PyThreadState *tstate = PyThreadState_GET();
+ tmp_type = tstate->curexc_type;
+ tmp_value = tstate->curexc_value;
+ tmp_tb = tstate->curexc_traceback;
+ tstate->curexc_type = type;
+ tstate->curexc_value = value;
+ tstate->curexc_traceback = tb;
+ Py_XDECREF(tmp_type);
+ Py_XDECREF(tmp_value);
+ Py_XDECREF(tmp_tb);
+#else
+ PyErr_Restore(type, value, tb);
+#endif
+}
+static CYTHON_INLINE void __Pyx_ErrFetch(PyObject **type, PyObject **value, PyObject **tb) {
+#if CYTHON_COMPILING_IN_CPYTHON
+ PyThreadState *tstate = PyThreadState_GET();
+ *type = tstate->curexc_type;
+ *value = tstate->curexc_value;
+ *tb = tstate->curexc_traceback;
+ tstate->curexc_type = 0;
+ tstate->curexc_value = 0;
+ tstate->curexc_traceback = 0;
+#else
+ PyErr_Fetch(type, value, tb);
+#endif
+}
+
+#if PY_MAJOR_VERSION < 3
+static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb,
+ CYTHON_UNUSED PyObject *cause) {
+ Py_XINCREF(type);
+ if (!value || value == Py_None)
+ value = NULL;
+ else
+ Py_INCREF(value);
+ if (!tb || tb == Py_None)
+ tb = NULL;
+ else {
+ Py_INCREF(tb);
+ if (!PyTraceBack_Check(tb)) {
+ PyErr_SetString(PyExc_TypeError,
+ "raise: arg 3 must be a traceback or None");
+ goto raise_error;
+ }
+ }
+ #if PY_VERSION_HEX < 0x02050000
+ if (PyClass_Check(type)) {
+ #else
+ if (PyType_Check(type)) {
+ #endif
+#if CYTHON_COMPILING_IN_PYPY
+ if (!value) {
+ Py_INCREF(Py_None);
+ value = Py_None;
+ }
+#endif
+ PyErr_NormalizeException(&type, &value, &tb);
+ } else {
+ if (value) {
+ PyErr_SetString(PyExc_TypeError,
+ "instance exception may not have a separate value");
+ goto raise_error;
+ }
+ value = type;
+ #if PY_VERSION_HEX < 0x02050000
+ if (PyInstance_Check(type)) {
+ type = (PyObject*) ((PyInstanceObject*)type)->in_class;
+ Py_INCREF(type);
+ }
+ else {
+ type = 0;
+ PyErr_SetString(PyExc_TypeError,
+ "raise: exception must be an old-style class or instance");
+ goto raise_error;
+ }
+ #else
+ type = (PyObject*) Py_TYPE(type);
+ Py_INCREF(type);
+ if (!PyType_IsSubtype((PyTypeObject *)type, (PyTypeObject *)PyExc_BaseException)) {
+ PyErr_SetString(PyExc_TypeError,
+ "raise: exception class must be a subclass of BaseException");
+ goto raise_error;
+ }
+ #endif
+ }
+ __Pyx_ErrRestore(type, value, tb);
+ return;
+raise_error:
+ Py_XDECREF(value);
+ Py_XDECREF(type);
+ Py_XDECREF(tb);
+ return;
+}
+#else /* Python 3+ */
+static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb, PyObject *cause) {
+ PyObject* owned_instance = NULL;
+ if (tb == Py_None) {
+ tb = 0;
+ } else if (tb && !PyTraceBack_Check(tb)) {
+ PyErr_SetString(PyExc_TypeError,
+ "raise: arg 3 must be a traceback or None");
+ goto bad;
+ }
+ if (value == Py_None)
+ value = 0;
+ if (PyExceptionInstance_Check(type)) {
+ if (value) {
+ PyErr_SetString(PyExc_TypeError,
+ "instance exception may not have a separate value");
+ goto bad;
+ }
+ value = type;
+ type = (PyObject*) Py_TYPE(value);
+ } else if (PyExceptionClass_Check(type)) {
+ PyObject *args;
+ if (!value)
+ args = PyTuple_New(0);
+ else if (PyTuple_Check(value)) {
+ Py_INCREF(value);
+ args = value;
+ }
+ else
+ args = PyTuple_Pack(1, value);
+ if (!args)
+ goto bad;
+ owned_instance = PyEval_CallObject(type, args);
+ Py_DECREF(args);
+ if (!owned_instance)
+ goto bad;
+ value = owned_instance;
+ if (!PyExceptionInstance_Check(value)) {
+ PyErr_Format(PyExc_TypeError,
+ "calling %R should have returned an instance of "
+ "BaseException, not %R",
+ type, Py_TYPE(value));
+ goto bad;
+ }
+ } else {
+ PyErr_SetString(PyExc_TypeError,
+ "raise: exception class must be a subclass of BaseException");
+ goto bad;
+ }
+ if (cause && cause != Py_None) {
+ PyObject *fixed_cause;
+ if (PyExceptionClass_Check(cause)) {
+ fixed_cause = PyObject_CallObject(cause, NULL);
+ if (fixed_cause == NULL)
+ goto bad;
+ }
+ else if (PyExceptionInstance_Check(cause)) {
+ fixed_cause = cause;
+ Py_INCREF(fixed_cause);
+ }
+ else {
+ PyErr_SetString(PyExc_TypeError,
+ "exception causes must derive from "
+ "BaseException");
+ goto bad;
+ }
+ PyException_SetCause(value, fixed_cause);
+ }
+ PyErr_SetObject(type, value);
+ if (tb) {
+ PyThreadState *tstate = PyThreadState_GET();
+ PyObject* tmp_tb = tstate->curexc_traceback;
+ if (tb != tmp_tb) {
+ Py_INCREF(tb);
+ tstate->curexc_traceback = tb;
+ Py_XDECREF(tmp_tb);
+ }
+ }
+bad:
+ Py_XDECREF(owned_instance);
+ return;
+}
+#endif
+
+static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, long level) {
+ PyObject *py_import = 0;
+ PyObject *empty_list = 0;
+ PyObject *module = 0;
+ PyObject *global_dict = 0;
+ PyObject *empty_dict = 0;
+ PyObject *list;
+ py_import = __Pyx_GetAttrString(__pyx_b, "__import__");
+ if (!py_import)
+ goto bad;
+ if (from_list)
+ list = from_list;
+ else {
+ empty_list = PyList_New(0);
+ if (!empty_list)
+ goto bad;
+ list = empty_list;
+ }
+ global_dict = PyModule_GetDict(__pyx_m);
+ if (!global_dict)
+ goto bad;
+ empty_dict = PyDict_New();
+ if (!empty_dict)
+ goto bad;
+ #if PY_VERSION_HEX >= 0x02050000
+ {
+ #if PY_MAJOR_VERSION >= 3
+ if (level == -1) {
+ if (strchr(__Pyx_MODULE_NAME, '.')) {
+ /* try package relative import first */
+ PyObject *py_level = PyInt_FromLong(1);
+ if (!py_level)
+ goto bad;
+ module = PyObject_CallFunctionObjArgs(py_import,
+ name, global_dict, empty_dict, list, py_level, NULL);
+ Py_DECREF(py_level);
+ if (!module) {
+ if (!PyErr_ExceptionMatches(PyExc_ImportError))
+ goto bad;
+ PyErr_Clear();
+ }
+ }
+ level = 0; /* try absolute import on failure */
+ }
+ #endif
+ if (!module) {
+ PyObject *py_level = PyInt_FromLong(level);
+ if (!py_level)
+ goto bad;
+ module = PyObject_CallFunctionObjArgs(py_import,
+ name, global_dict, empty_dict, list, py_level, NULL);
+ Py_DECREF(py_level);
+ }
+ }
+ #else
+ if (level>0) {
+ PyErr_SetString(PyExc_RuntimeError, "Relative import is not supported for Python <=2.4.");
+ goto bad;
+ }
+ module = PyObject_CallFunctionObjArgs(py_import,
+ name, global_dict, empty_dict, list, NULL);
+ #endif
+bad:
+ Py_XDECREF(empty_list);
+ Py_XDECREF(py_import);
+ Py_XDECREF(empty_dict);
+ return module;
+}
+
+static CYTHON_INLINE void __Pyx_RaiseImportError(PyObject *name) {
+#if PY_MAJOR_VERSION < 3
+ PyErr_Format(PyExc_ImportError, "cannot import name %.230s",
+ PyString_AsString(name));
+#else
+ PyErr_Format(PyExc_ImportError, "cannot import name %S", name);
+#endif
+}
+
+static PyObject *__Pyx_FindPy2Metaclass(PyObject *bases) {
+ PyObject *metaclass;
+#if PY_MAJOR_VERSION < 3
+ if (PyTuple_Check(bases) && PyTuple_GET_SIZE(bases) > 0) {
+ PyObject *base = PyTuple_GET_ITEM(bases, 0);
+ metaclass = PyObject_GetAttrString(base, (char *)"__class__");
+ if (!metaclass) {
+ PyErr_Clear();
+ metaclass = (PyObject*) Py_TYPE(base);
+ }
+ } else {
+ metaclass = (PyObject *) &PyClass_Type;
+ }
+#else
+ if (PyTuple_Check(bases) && PyTuple_GET_SIZE(bases) > 0) {
+ PyObject *base = PyTuple_GET_ITEM(bases, 0);
+ metaclass = (PyObject*) Py_TYPE(base);
+ } else {
+ metaclass = (PyObject *) &PyType_Type;
+ }
+#endif
+ Py_INCREF(metaclass);
+ return metaclass;
+}
+
+static PyObject *__Pyx_CreateClass(PyObject *bases, PyObject *dict, PyObject *name,
+ PyObject *modname) {
+ PyObject *result;
+ PyObject *metaclass;
+ if (PyDict_SetItemString(dict, "__module__", modname) < 0)
+ return NULL;
+ metaclass = PyDict_GetItemString(dict, "__metaclass__");
+ if (metaclass) {
+ Py_INCREF(metaclass);
+ } else {
+ metaclass = __Pyx_FindPy2Metaclass(bases);
+ }
+ result = PyObject_CallFunctionObjArgs(metaclass, name, bases, dict, NULL);
+ Py_DECREF(metaclass);
+ return result;
+}
+
+static PyObject *
+__Pyx_CyFunction_get_doc(__pyx_CyFunctionObject *op, CYTHON_UNUSED void *closure)
+{
+ if (op->func_doc == NULL && op->func.m_ml->ml_doc) {
+#if PY_MAJOR_VERSION >= 3
+ op->func_doc = PyUnicode_FromString(op->func.m_ml->ml_doc);
+#else
+ op->func_doc = PyString_FromString(op->func.m_ml->ml_doc);
+#endif
+ }
+ if (op->func_doc == 0) {
+ Py_INCREF(Py_None);
+ return Py_None;
+ }
+ Py_INCREF(op->func_doc);
+ return op->func_doc;
+}
+static int
+__Pyx_CyFunction_set_doc(__pyx_CyFunctionObject *op, PyObject *value)
+{
+ PyObject *tmp = op->func_doc;
+ if (value == NULL)
+ op->func_doc = Py_None; /* Mark as deleted */
+ else
+ op->func_doc = value;
+ Py_INCREF(op->func_doc);
+ Py_XDECREF(tmp);
+ return 0;
+}
+static PyObject *
+__Pyx_CyFunction_get_name(__pyx_CyFunctionObject *op)
+{
+ if (op->func_name == NULL) {
+#if PY_MAJOR_VERSION >= 3
+ op->func_name = PyUnicode_InternFromString(op->func.m_ml->ml_name);
+#else
+ op->func_name = PyString_InternFromString(op->func.m_ml->ml_name);
+#endif
+ }
+ Py_INCREF(op->func_name);
+ return op->func_name;
+}
+static int
+__Pyx_CyFunction_set_name(__pyx_CyFunctionObject *op, PyObject *value)
+{
+ PyObject *tmp;
+#if PY_MAJOR_VERSION >= 3
+ if (value == NULL || !PyUnicode_Check(value)) {
+#else
+ if (value == NULL || !PyString_Check(value)) {
+#endif
+ PyErr_SetString(PyExc_TypeError,
+ "__name__ must be set to a string object");
+ return -1;
+ }
+ tmp = op->func_name;
+ Py_INCREF(value);
+ op->func_name = value;
+ Py_XDECREF(tmp);
+ return 0;
+}
+static PyObject *
+__Pyx_CyFunction_get_self(__pyx_CyFunctionObject *m, CYTHON_UNUSED void *closure)
+{
+ PyObject *self;
+ self = m->func_closure;
+ if (self == NULL)
+ self = Py_None;
+ Py_INCREF(self);
+ return self;
+}
+static PyObject *
+__Pyx_CyFunction_get_dict(__pyx_CyFunctionObject *op)
+{
+ if (op->func_dict == NULL) {
+ op->func_dict = PyDict_New();
+ if (op->func_dict == NULL)
+ return NULL;
+ }
+ Py_INCREF(op->func_dict);
+ return op->func_dict;
+}
+static int
+__Pyx_CyFunction_set_dict(__pyx_CyFunctionObject *op, PyObject *value)
+{
+ PyObject *tmp;
+ if (value == NULL) {
+ PyErr_SetString(PyExc_TypeError,
+ "function's dictionary may not be deleted");
+ return -1;
+ }
+ if (!PyDict_Check(value)) {
+ PyErr_SetString(PyExc_TypeError,
+ "setting function's dictionary to a non-dict");
+ return -1;
+ }
+ tmp = op->func_dict;
+ Py_INCREF(value);
+ op->func_dict = value;
+ Py_XDECREF(tmp);
+ return 0;
+}
+static PyObject *
+__Pyx_CyFunction_get_globals(CYTHON_UNUSED __pyx_CyFunctionObject *op)
+{
+ PyObject* dict = PyModule_GetDict(__pyx_m);
+ Py_XINCREF(dict);
+ return dict;
+}
+static PyObject *
+__Pyx_CyFunction_get_closure(CYTHON_UNUSED __pyx_CyFunctionObject *op)
+{
+ Py_INCREF(Py_None);
+ return Py_None;
+}
+static PyObject *
+__Pyx_CyFunction_get_code(__pyx_CyFunctionObject *op)
+{
+ PyObject* result = (op->func_code) ? op->func_code : Py_None;
+ Py_INCREF(result);
+ return result;
+}
+static PyObject *
+__Pyx_CyFunction_get_defaults(__pyx_CyFunctionObject *op)
+{
+ if (op->defaults_tuple) {
+ Py_INCREF(op->defaults_tuple);
+ return op->defaults_tuple;
+ }
+ if (op->defaults_getter) {
+ PyObject *res = op->defaults_getter((PyObject *) op);
+ if (res) {
+ Py_INCREF(res);
+ op->defaults_tuple = res;
+ }
+ return res;
+ }
+ Py_INCREF(Py_None);
+ return Py_None;
+}
+static PyGetSetDef __pyx_CyFunction_getsets[] = {
+ {(char *) "func_doc", (getter)__Pyx_CyFunction_get_doc, (setter)__Pyx_CyFunction_set_doc, 0, 0},
+ {(char *) "__doc__", (getter)__Pyx_CyFunction_get_doc, (setter)__Pyx_CyFunction_set_doc, 0, 0},
+ {(char *) "func_name", (getter)__Pyx_CyFunction_get_name, (setter)__Pyx_CyFunction_set_name, 0, 0},
+ {(char *) "__name__", (getter)__Pyx_CyFunction_get_name, (setter)__Pyx_CyFunction_set_name, 0, 0},
+ {(char *) "__self__", (getter)__Pyx_CyFunction_get_self, 0, 0, 0},
+ {(char *) "func_dict", (getter)__Pyx_CyFunction_get_dict, (setter)__Pyx_CyFunction_set_dict, 0, 0},
+ {(char *) "__dict__", (getter)__Pyx_CyFunction_get_dict, (setter)__Pyx_CyFunction_set_dict, 0, 0},
+ {(char *) "func_globals", (getter)__Pyx_CyFunction_get_globals, 0, 0, 0},
+ {(char *) "__globals__", (getter)__Pyx_CyFunction_get_globals, 0, 0, 0},
+ {(char *) "func_closure", (getter)__Pyx_CyFunction_get_closure, 0, 0, 0},
+ {(char *) "__closure__", (getter)__Pyx_CyFunction_get_closure, 0, 0, 0},
+ {(char *) "func_code", (getter)__Pyx_CyFunction_get_code, 0, 0, 0},
+ {(char *) "__code__", (getter)__Pyx_CyFunction_get_code, 0, 0, 0},
+ {(char *) "func_defaults", (getter)__Pyx_CyFunction_get_defaults, 0, 0, 0},
+ {(char *) "__defaults__", (getter)__Pyx_CyFunction_get_defaults, 0, 0, 0},
+ {0, 0, 0, 0, 0}
+};
+#ifndef PY_WRITE_RESTRICTED /* < Py2.5 */
+#define PY_WRITE_RESTRICTED WRITE_RESTRICTED
+#endif
+static PyMemberDef __pyx_CyFunction_members[] = {
+ {(char *) "__module__", T_OBJECT, offsetof(__pyx_CyFunctionObject, func.m_module), PY_WRITE_RESTRICTED, 0},
+ {0, 0, 0, 0, 0}
+};
+static PyObject *
+__Pyx_CyFunction_reduce(__pyx_CyFunctionObject *m, CYTHON_UNUSED PyObject *args)
+{
+#if PY_MAJOR_VERSION >= 3
+ return PyUnicode_FromString(m->func.m_ml->ml_name);
+#else
+ return PyString_FromString(m->func.m_ml->ml_name);
+#endif
+}
+static PyMethodDef __pyx_CyFunction_methods[] = {
+ {__Pyx_NAMESTR("__reduce__"), (PyCFunction)__Pyx_CyFunction_reduce, METH_VARARGS, 0},
+ {0, 0, 0, 0}
+};
+static PyObject *__Pyx_CyFunction_New(PyTypeObject *type, PyMethodDef *ml, int flags,
+ PyObject *closure, PyObject *module, PyObject* code) {
+ __pyx_CyFunctionObject *op = PyObject_GC_New(__pyx_CyFunctionObject, type);
+ if (op == NULL)
+ return NULL;
+ op->flags = flags;
+ op->func_weakreflist = NULL;
+ op->func.m_ml = ml;
+ op->func.m_self = (PyObject *) op;
+ Py_XINCREF(closure);
+ op->func_closure = closure;
+ Py_XINCREF(module);
+ op->func.m_module = module;
+ op->func_dict = NULL;
+ op->func_name = NULL;
+ op->func_doc = NULL;
+ op->func_classobj = NULL;
+ Py_XINCREF(code);
+ op->func_code = code;
+ op->defaults_pyobjects = 0;
+ op->defaults = NULL;
+ op->defaults_tuple = NULL;
+ op->defaults_getter = NULL;
+ PyObject_GC_Track(op);
+ return (PyObject *) op;
+}
+static int
+__Pyx_CyFunction_clear(__pyx_CyFunctionObject *m)
+{
+ Py_CLEAR(m->func_closure);
+ Py_CLEAR(m->func.m_module);
+ Py_CLEAR(m->func_dict);
+ Py_CLEAR(m->func_name);
+ Py_CLEAR(m->func_doc);
+ Py_CLEAR(m->func_code);
+ Py_CLEAR(m->func_classobj);
+ Py_CLEAR(m->defaults_tuple);
+ if (m->defaults) {
+ PyObject **pydefaults = __Pyx_CyFunction_Defaults(PyObject *, m);
+ int i;
+ for (i = 0; i < m->defaults_pyobjects; i++)
+ Py_XDECREF(pydefaults[i]);
+ PyMem_Free(m->defaults);
+ m->defaults = NULL;
+ }
+ return 0;
+}
+static void __Pyx_CyFunction_dealloc(__pyx_CyFunctionObject *m)
+{
+ PyObject_GC_UnTrack(m);
+ if (m->func_weakreflist != NULL)
+ PyObject_ClearWeakRefs((PyObject *) m);
+ __Pyx_CyFunction_clear(m);
+ PyObject_GC_Del(m);
+}
+static int __Pyx_CyFunction_traverse(__pyx_CyFunctionObject *m, visitproc visit, void *arg)
+{
+ Py_VISIT(m->func_closure);
+ Py_VISIT(m->func.m_module);
+ Py_VISIT(m->func_dict);
+ Py_VISIT(m->func_name);
+ Py_VISIT(m->func_doc);
+ Py_VISIT(m->func_code);
+ Py_VISIT(m->func_classobj);
+ Py_VISIT(m->defaults_tuple);
+ if (m->defaults) {
+ PyObject **pydefaults = __Pyx_CyFunction_Defaults(PyObject *, m);
+ int i;
+ for (i = 0; i < m->defaults_pyobjects; i++)
+ Py_VISIT(pydefaults[i]);
+ }
+ return 0;
+}
+static PyObject *__Pyx_CyFunction_descr_get(PyObject *func, PyObject *obj, PyObject *type)
+{
+ __pyx_CyFunctionObject *m = (__pyx_CyFunctionObject *) func;
+ if (m->flags & __Pyx_CYFUNCTION_STATICMETHOD) {
+ Py_INCREF(func);
+ return func;
+ }
+ if (m->flags & __Pyx_CYFUNCTION_CLASSMETHOD) {
+ if (type == NULL)
+ type = (PyObject *)(Py_TYPE(obj));
+ return PyMethod_New(func,
+ type, (PyObject *)(Py_TYPE(type)));
+ }
+ if (obj == Py_None)
+ obj = NULL;
+ return PyMethod_New(func, obj, type);
+}
+static PyObject*
+__Pyx_CyFunction_repr(__pyx_CyFunctionObject *op)
+{
+ PyObject *func_name = __Pyx_CyFunction_get_name(op);
+#if PY_MAJOR_VERSION >= 3
+ return PyUnicode_FromFormat("<cyfunction %U at %p>",
+ func_name, (void *)op);
+#else
+ return PyString_FromFormat("<cyfunction %s at %p>",
+ PyString_AsString(func_name), (void *)op);
+#endif
+}
+#if CYTHON_COMPILING_IN_PYPY
+static PyObject * __Pyx_CyFunction_Call(PyObject *func, PyObject *arg, PyObject *kw) {
+ PyCFunctionObject* f = (PyCFunctionObject*)func;
+ PyCFunction meth = PyCFunction_GET_FUNCTION(func);
+ PyObject *self = PyCFunction_GET_SELF(func);
+ Py_ssize_t size;
+ switch (PyCFunction_GET_FLAGS(func) & ~(METH_CLASS | METH_STATIC | METH_COEXIST)) {
+ case METH_VARARGS:
+ if (likely(kw == NULL) || PyDict_Size(kw) == 0)
+ return (*meth)(self, arg);
+ break;
+ case METH_VARARGS | METH_KEYWORDS:
+ return (*(PyCFunctionWithKeywords)meth)(self, arg, kw);
+ case METH_NOARGS:
+ if (likely(kw == NULL) || PyDict_Size(kw) == 0) {
+ size = PyTuple_GET_SIZE(arg);
+ if (size == 0)
+ return (*meth)(self, NULL);
+ PyErr_Format(PyExc_TypeError,
+ "%.200s() takes no arguments (%zd given)",
+ f->m_ml->ml_name, size);
+ return NULL;
+ }
+ break;
+ case METH_O:
+ if (likely(kw == NULL) || PyDict_Size(kw) == 0) {
+ size = PyTuple_GET_SIZE(arg);
+ if (size == 1)
+ return (*meth)(self, PyTuple_GET_ITEM(arg, 0));
+ PyErr_Format(PyExc_TypeError,
+ "%.200s() takes exactly one argument (%zd given)",
+ f->m_ml->ml_name, size);
+ return NULL;
+ }
+ break;
+ default:
+ PyErr_SetString(PyExc_SystemError, "Bad call flags in "
+ "__Pyx_CyFunction_Call. METH_OLDARGS is no "
+ "longer supported!");
+ return NULL;
+ }
+ PyErr_Format(PyExc_TypeError, "%.200s() takes no keyword arguments",
+ f->m_ml->ml_name);
+ return NULL;
+}
+#else
+static PyObject * __Pyx_CyFunction_Call(PyObject *func, PyObject *arg, PyObject *kw) {
+ return PyCFunction_Call(func, arg, kw);
+}
+#endif
+static PyTypeObject __pyx_CyFunctionType_type = {
+ PyVarObject_HEAD_INIT(0, 0)
+ __Pyx_NAMESTR("cython_function_or_method"), /*tp_name*/
+ sizeof(__pyx_CyFunctionObject), /*tp_basicsize*/
+ 0, /*tp_itemsize*/
+ (destructor) __Pyx_CyFunction_dealloc, /*tp_dealloc*/
+ 0, /*tp_print*/
+ 0, /*tp_getattr*/
+ 0, /*tp_setattr*/
+#if PY_MAJOR_VERSION < 3
+ 0, /*tp_compare*/
+#else
+ 0, /*reserved*/
+#endif
+ (reprfunc) __Pyx_CyFunction_repr, /*tp_repr*/
+ 0, /*tp_as_number*/
+ 0, /*tp_as_sequence*/
+ 0, /*tp_as_mapping*/
+ 0, /*tp_hash*/
+ __Pyx_CyFunction_Call, /*tp_call*/
+ 0, /*tp_str*/
+ 0, /*tp_getattro*/
+ 0, /*tp_setattro*/
+ 0, /*tp_as_buffer*/
+ Py_TPFLAGS_DEFAULT | Py_TPFLAGS_HAVE_GC, /* tp_flags*/
+ 0, /*tp_doc*/
+ (traverseproc) __Pyx_CyFunction_traverse, /*tp_traverse*/
+ (inquiry) __Pyx_CyFunction_clear, /*tp_clear*/
+ 0, /*tp_richcompare*/
+ offsetof(__pyx_CyFunctionObject, func_weakreflist), /* tp_weaklistoffse */
+ 0, /*tp_iter*/
+ 0, /*tp_iternext*/
+ __pyx_CyFunction_methods, /*tp_methods*/
+ __pyx_CyFunction_members, /*tp_members*/
+ __pyx_CyFunction_getsets, /*tp_getset*/
+ 0, /*tp_base*/
+ 0, /*tp_dict*/
+ __Pyx_CyFunction_descr_get, /*tp_descr_get*/
+ 0, /*tp_descr_set*/
+ offsetof(__pyx_CyFunctionObject, func_dict),/*tp_dictoffset*/
+ 0, /*tp_init*/
+ 0, /*tp_alloc*/
+ 0, /*tp_new*/
+ 0, /*tp_free*/
+ 0, /*tp_is_gc*/
+ 0, /*tp_bases*/
+ 0, /*tp_mro*/
+ 0, /*tp_cache*/
+ 0, /*tp_subclasses*/
+ 0, /*tp_weaklist*/
+ 0, /*tp_del*/
+#if PY_VERSION_HEX >= 0x02060000
+ 0, /*tp_version_tag*/
+#endif
+};
+static int __Pyx_CyFunction_init(void) {
+#if !CYTHON_COMPILING_IN_PYPY
+ __pyx_CyFunctionType_type.tp_call = PyCFunction_Call;
+#endif
+ if (PyType_Ready(&__pyx_CyFunctionType_type) < 0)
+ return -1;
+ __pyx_CyFunctionType = &__pyx_CyFunctionType_type;
+ return 0;
+}
+static CYTHON_INLINE void *__Pyx_CyFunction_InitDefaults(PyObject *func, size_t size, int pyobjects) {
+ __pyx_CyFunctionObject *m = (__pyx_CyFunctionObject *) func;
+ m->defaults = PyMem_Malloc(size);
+ if (!m->defaults)
+ return PyErr_NoMemory();
+ memset(m->defaults, 0, sizeof(size));
+ m->defaults_pyobjects = pyobjects;
+ return m->defaults;
+}
+static CYTHON_INLINE void __Pyx_CyFunction_SetDefaultsTuple(PyObject *func, PyObject *tuple) {
+ __pyx_CyFunctionObject *m = (__pyx_CyFunctionObject *) func;
+ m->defaults_tuple = tuple;
+ Py_INCREF(tuple);
+}
+
+#if !CYTHON_COMPILING_IN_PYPY && PY_MAJOR_VERSION < 3
+static PyObject *__Pyx_GetStdout(void) {
+ PyObject *f = PySys_GetObject((char *)"stdout");
+ if (!f) {
+ PyErr_SetString(PyExc_RuntimeError, "lost sys.stdout");
+ }
+ return f;
+}
+static int __Pyx_Print(PyObject* f, PyObject *arg_tuple, int newline) {
+ int i;
+ if (!f) {
+ if (!(f = __Pyx_GetStdout()))
+ return -1;
+ }
+ Py_INCREF(f);
+ for (i=0; i < PyTuple_GET_SIZE(arg_tuple); i++) {
+ PyObject* v;
+ if (PyFile_SoftSpace(f, 1)) {
+ if (PyFile_WriteString(" ", f) < 0)
+ goto error;
+ }
+ v = PyTuple_GET_ITEM(arg_tuple, i);
+ if (PyFile_WriteObject(v, f, Py_PRINT_RAW) < 0)
+ goto error;
+ if (PyString_Check(v)) {
+ char *s = PyString_AsString(v);
+ Py_ssize_t len = PyString_Size(v);
+ if (len > 0 &&
+ isspace(Py_CHARMASK(s[len-1])) &&
+ s[len-1] != ' ')
+ PyFile_SoftSpace(f, 0);
+ }
+ }
+ if (newline) {
+ if (PyFile_WriteString("\n", f) < 0)
+ goto error;
+ PyFile_SoftSpace(f, 0);
+ }
+ Py_DECREF(f);
+ return 0;
+error:
+ Py_DECREF(f);
+ return -1;
+}
+#else /* Python 3 has a print function */
+static int __Pyx_Print(PyObject* stream, PyObject *arg_tuple, int newline) {
+ PyObject* kwargs = 0;
+ PyObject* result = 0;
+ PyObject* end_string;
+ if (unlikely(!__pyx_print)) {
+ __pyx_print = __Pyx_GetAttrString(__pyx_b, "print");
+ if (!__pyx_print)
+ return -1;
+ }
+ if (stream) {
+ kwargs = PyDict_New();
+ if (unlikely(!kwargs))
+ return -1;
+ if (unlikely(PyDict_SetItemString(kwargs, "file", stream) < 0))
+ goto bad;
+ if (!newline) {
+ end_string = PyUnicode_FromStringAndSize(" ", 1);
+ if (unlikely(!end_string))
+ goto bad;
+ if (PyDict_SetItemString(kwargs, "end", end_string) < 0) {
+ Py_DECREF(end_string);
+ goto bad;
+ }
+ Py_DECREF(end_string);
+ }
+ } else if (!newline) {
+ if (unlikely(!__pyx_print_kwargs)) {
+ __pyx_print_kwargs = PyDict_New();
+ if (unlikely(!__pyx_print_kwargs))
+ return -1;
+ end_string = PyUnicode_FromStringAndSize(" ", 1);
+ if (unlikely(!end_string))
+ return -1;
+ if (PyDict_SetItemString(__pyx_print_kwargs, "end", end_string) < 0) {
+ Py_DECREF(end_string);
+ return -1;
+ }
+ Py_DECREF(end_string);
+ }
+ kwargs = __pyx_print_kwargs;
+ }
+ result = PyObject_Call(__pyx_print, arg_tuple, kwargs);
+ if (unlikely(kwargs) && (kwargs != __pyx_print_kwargs))
+ Py_DECREF(kwargs);
+ if (!result)
+ return -1;
+ Py_DECREF(result);
+ return 0;
+bad:
+ if (kwargs != __pyx_print_kwargs)
+ Py_XDECREF(kwargs);
+ return -1;
+}
+#endif
+
+#if !CYTHON_COMPILING_IN_PYPY && PY_MAJOR_VERSION < 3
+static int __Pyx_PrintOne(PyObject* f, PyObject *o) {
+ if (!f) {
+ if (!(f = __Pyx_GetStdout()))
+ return -1;
+ }
+ Py_INCREF(f);
+ if (PyFile_SoftSpace(f, 0)) {
+ if (PyFile_WriteString(" ", f) < 0)
+ goto error;
+ }
+ if (PyFile_WriteObject(o, f, Py_PRINT_RAW) < 0)
+ goto error;
+ if (PyFile_WriteString("\n", f) < 0)
+ goto error;
+ Py_DECREF(f);
+ return 0;
+error:
+ Py_DECREF(f);
+ return -1;
+ /* the line below is just to avoid C compiler
+ * warnings about unused functions */
+ return __Pyx_Print(f, NULL, 0);
+}
+#else /* Python 3 has a print function */
+static int __Pyx_PrintOne(PyObject* stream, PyObject *o) {
+ int res;
+ PyObject* arg_tuple = PyTuple_Pack(1, o);
+ if (unlikely(!arg_tuple))
+ return -1;
+ res = __Pyx_Print(stream, arg_tuple, 1);
+ Py_DECREF(arg_tuple);
+ return res;
+}
+#endif
+
+static CYTHON_INLINE unsigned char __Pyx_PyInt_AsUnsignedChar(PyObject* x) {
+ const unsigned char neg_one = (unsigned char)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(unsigned char) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(unsigned char)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to unsigned char" :
+ "value too large to convert to unsigned char");
+ }
+ return (unsigned char)-1;
+ }
+ return (unsigned char)val;
+ }
+ return (unsigned char)__Pyx_PyInt_AsUnsignedLong(x);
+}
+
+static CYTHON_INLINE unsigned short __Pyx_PyInt_AsUnsignedShort(PyObject* x) {
+ const unsigned short neg_one = (unsigned short)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(unsigned short) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(unsigned short)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to unsigned short" :
+ "value too large to convert to unsigned short");
+ }
+ return (unsigned short)-1;
+ }
+ return (unsigned short)val;
+ }
+ return (unsigned short)__Pyx_PyInt_AsUnsignedLong(x);
+}
+
+static CYTHON_INLINE unsigned int __Pyx_PyInt_AsUnsignedInt(PyObject* x) {
+ const unsigned int neg_one = (unsigned int)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(unsigned int) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(unsigned int)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to unsigned int" :
+ "value too large to convert to unsigned int");
+ }
+ return (unsigned int)-1;
+ }
+ return (unsigned int)val;
+ }
+ return (unsigned int)__Pyx_PyInt_AsUnsignedLong(x);
+}
+
+static CYTHON_INLINE char __Pyx_PyInt_AsChar(PyObject* x) {
+ const char neg_one = (char)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(char) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(char)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to char" :
+ "value too large to convert to char");
+ }
+ return (char)-1;
+ }
+ return (char)val;
+ }
+ return (char)__Pyx_PyInt_AsLong(x);
+}
+
+static CYTHON_INLINE short __Pyx_PyInt_AsShort(PyObject* x) {
+ const short neg_one = (short)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(short) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(short)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to short" :
+ "value too large to convert to short");
+ }
+ return (short)-1;
+ }
+ return (short)val;
+ }
+ return (short)__Pyx_PyInt_AsLong(x);
+}
+
+static CYTHON_INLINE int __Pyx_PyInt_AsInt(PyObject* x) {
+ const int neg_one = (int)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(int) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(int)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to int" :
+ "value too large to convert to int");
+ }
+ return (int)-1;
+ }
+ return (int)val;
+ }
+ return (int)__Pyx_PyInt_AsLong(x);
+}
+
+static CYTHON_INLINE signed char __Pyx_PyInt_AsSignedChar(PyObject* x) {
+ const signed char neg_one = (signed char)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(signed char) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(signed char)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to signed char" :
+ "value too large to convert to signed char");
+ }
+ return (signed char)-1;
+ }
+ return (signed char)val;
+ }
+ return (signed char)__Pyx_PyInt_AsSignedLong(x);
+}
+
+static CYTHON_INLINE signed short __Pyx_PyInt_AsSignedShort(PyObject* x) {
+ const signed short neg_one = (signed short)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(signed short) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(signed short)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to signed short" :
+ "value too large to convert to signed short");
+ }
+ return (signed short)-1;
+ }
+ return (signed short)val;
+ }
+ return (signed short)__Pyx_PyInt_AsSignedLong(x);
+}
+
+static CYTHON_INLINE signed int __Pyx_PyInt_AsSignedInt(PyObject* x) {
+ const signed int neg_one = (signed int)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(signed int) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(signed int)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to signed int" :
+ "value too large to convert to signed int");
+ }
+ return (signed int)-1;
+ }
+ return (signed int)val;
+ }
+ return (signed int)__Pyx_PyInt_AsSignedLong(x);
+}
+
+static CYTHON_INLINE int __Pyx_PyInt_AsLongDouble(PyObject* x) {
+ const int neg_one = (int)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(int) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(int)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to int" :
+ "value too large to convert to int");
+ }
+ return (int)-1;
+ }
+ return (int)val;
+ }
+ return (int)__Pyx_PyInt_AsLong(x);
+}
+
+static CYTHON_INLINE unsigned long __Pyx_PyInt_AsUnsignedLong(PyObject* x) {
+ const unsigned long neg_one = (unsigned long)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+#if PY_VERSION_HEX < 0x03000000
+ if (likely(PyInt_Check(x))) {
+ long val = PyInt_AS_LONG(x);
+ if (is_unsigned && unlikely(val < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to unsigned long");
+ return (unsigned long)-1;
+ }
+ return (unsigned long)val;
+ } else
+#endif
+ if (likely(PyLong_Check(x))) {
+ if (is_unsigned) {
+ if (unlikely(Py_SIZE(x) < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to unsigned long");
+ return (unsigned long)-1;
+ }
+ return (unsigned long)PyLong_AsUnsignedLong(x);
+ } else {
+ return (unsigned long)PyLong_AsLong(x);
+ }
+ } else {
+ unsigned long val;
+ PyObject *tmp = __Pyx_PyNumber_Int(x);
+ if (!tmp) return (unsigned long)-1;
+ val = __Pyx_PyInt_AsUnsignedLong(tmp);
+ Py_DECREF(tmp);
+ return val;
+ }
+}
+
+static CYTHON_INLINE unsigned PY_LONG_LONG __Pyx_PyInt_AsUnsignedLongLong(PyObject* x) {
+ const unsigned PY_LONG_LONG neg_one = (unsigned PY_LONG_LONG)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+#if PY_VERSION_HEX < 0x03000000
+ if (likely(PyInt_Check(x))) {
+ long val = PyInt_AS_LONG(x);
+ if (is_unsigned && unlikely(val < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to unsigned PY_LONG_LONG");
+ return (unsigned PY_LONG_LONG)-1;
+ }
+ return (unsigned PY_LONG_LONG)val;
+ } else
+#endif
+ if (likely(PyLong_Check(x))) {
+ if (is_unsigned) {
+ if (unlikely(Py_SIZE(x) < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to unsigned PY_LONG_LONG");
+ return (unsigned PY_LONG_LONG)-1;
+ }
+ return (unsigned PY_LONG_LONG)PyLong_AsUnsignedLongLong(x);
+ } else {
+ return (unsigned PY_LONG_LONG)PyLong_AsLongLong(x);
+ }
+ } else {
+ unsigned PY_LONG_LONG val;
+ PyObject *tmp = __Pyx_PyNumber_Int(x);
+ if (!tmp) return (unsigned PY_LONG_LONG)-1;
+ val = __Pyx_PyInt_AsUnsignedLongLong(tmp);
+ Py_DECREF(tmp);
+ return val;
+ }
+}
+
+static CYTHON_INLINE long __Pyx_PyInt_AsLong(PyObject* x) {
+ const long neg_one = (long)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+#if PY_VERSION_HEX < 0x03000000
+ if (likely(PyInt_Check(x))) {
+ long val = PyInt_AS_LONG(x);
+ if (is_unsigned && unlikely(val < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to long");
+ return (long)-1;
+ }
+ return (long)val;
+ } else
+#endif
+ if (likely(PyLong_Check(x))) {
+ if (is_unsigned) {
+ if (unlikely(Py_SIZE(x) < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to long");
+ return (long)-1;
+ }
+ return (long)PyLong_AsUnsignedLong(x);
+ } else {
+ return (long)PyLong_AsLong(x);
+ }
+ } else {
+ long val;
+ PyObject *tmp = __Pyx_PyNumber_Int(x);
+ if (!tmp) return (long)-1;
+ val = __Pyx_PyInt_AsLong(tmp);
+ Py_DECREF(tmp);
+ return val;
+ }
+}
+
+static CYTHON_INLINE PY_LONG_LONG __Pyx_PyInt_AsLongLong(PyObject* x) {
+ const PY_LONG_LONG neg_one = (PY_LONG_LONG)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+#if PY_VERSION_HEX < 0x03000000
+ if (likely(PyInt_Check(x))) {
+ long val = PyInt_AS_LONG(x);
+ if (is_unsigned && unlikely(val < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to PY_LONG_LONG");
+ return (PY_LONG_LONG)-1;
+ }
+ return (PY_LONG_LONG)val;
+ } else
+#endif
+ if (likely(PyLong_Check(x))) {
+ if (is_unsigned) {
+ if (unlikely(Py_SIZE(x) < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to PY_LONG_LONG");
+ return (PY_LONG_LONG)-1;
+ }
+ return (PY_LONG_LONG)PyLong_AsUnsignedLongLong(x);
+ } else {
+ return (PY_LONG_LONG)PyLong_AsLongLong(x);
+ }
+ } else {
+ PY_LONG_LONG val;
+ PyObject *tmp = __Pyx_PyNumber_Int(x);
+ if (!tmp) return (PY_LONG_LONG)-1;
+ val = __Pyx_PyInt_AsLongLong(tmp);
+ Py_DECREF(tmp);
+ return val;
+ }
+}
+
+static CYTHON_INLINE signed long __Pyx_PyInt_AsSignedLong(PyObject* x) {
+ const signed long neg_one = (signed long)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+#if PY_VERSION_HEX < 0x03000000
+ if (likely(PyInt_Check(x))) {
+ long val = PyInt_AS_LONG(x);
+ if (is_unsigned && unlikely(val < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to signed long");
+ return (signed long)-1;
+ }
+ return (signed long)val;
+ } else
+#endif
+ if (likely(PyLong_Check(x))) {
+ if (is_unsigned) {
+ if (unlikely(Py_SIZE(x) < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to signed long");
+ return (signed long)-1;
+ }
+ return (signed long)PyLong_AsUnsignedLong(x);
+ } else {
+ return (signed long)PyLong_AsLong(x);
+ }
+ } else {
+ signed long val;
+ PyObject *tmp = __Pyx_PyNumber_Int(x);
+ if (!tmp) return (signed long)-1;
+ val = __Pyx_PyInt_AsSignedLong(tmp);
+ Py_DECREF(tmp);
+ return val;
+ }
+}
+
+static CYTHON_INLINE signed PY_LONG_LONG __Pyx_PyInt_AsSignedLongLong(PyObject* x) {
+ const signed PY_LONG_LONG neg_one = (signed PY_LONG_LONG)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+#if PY_VERSION_HEX < 0x03000000
+ if (likely(PyInt_Check(x))) {
+ long val = PyInt_AS_LONG(x);
+ if (is_unsigned && unlikely(val < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to signed PY_LONG_LONG");
+ return (signed PY_LONG_LONG)-1;
+ }
+ return (signed PY_LONG_LONG)val;
+ } else
+#endif
+ if (likely(PyLong_Check(x))) {
+ if (is_unsigned) {
+ if (unlikely(Py_SIZE(x) < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to signed PY_LONG_LONG");
+ return (signed PY_LONG_LONG)-1;
+ }
+ return (signed PY_LONG_LONG)PyLong_AsUnsignedLongLong(x);
+ } else {
+ return (signed PY_LONG_LONG)PyLong_AsLongLong(x);
+ }
+ } else {
+ signed PY_LONG_LONG val;
+ PyObject *tmp = __Pyx_PyNumber_Int(x);
+ if (!tmp) return (signed PY_LONG_LONG)-1;
+ val = __Pyx_PyInt_AsSignedLongLong(tmp);
+ Py_DECREF(tmp);
+ return val;
+ }
+}
+
+static int __Pyx_check_binary_version(void) {
+ char ctversion[4], rtversion[4];
+ PyOS_snprintf(ctversion, 4, "%d.%d", PY_MAJOR_VERSION, PY_MINOR_VERSION);
+ PyOS_snprintf(rtversion, 4, "%s", Py_GetVersion());
+ if (ctversion[0] != rtversion[0] || ctversion[2] != rtversion[2]) {
+ char message[200];
+ PyOS_snprintf(message, sizeof(message),
+ "compiletime version %s of module '%.100s' "
+ "does not match runtime version %s",
+ ctversion, __Pyx_MODULE_NAME, rtversion);
+ #if PY_VERSION_HEX < 0x02050000
+ return PyErr_Warn(NULL, message);
+ #else
+ return PyErr_WarnEx(NULL, message, 1);
+ #endif
+ }
+ return 0;
+}
+
+#ifndef __PYX_HAVE_RT_ImportModule
+#define __PYX_HAVE_RT_ImportModule
+static PyObject *__Pyx_ImportModule(const char *name) {
+ PyObject *py_name = 0;
+ PyObject *py_module = 0;
+ py_name = __Pyx_PyIdentifier_FromString(name);
+ if (!py_name)
+ goto bad;
+ py_module = PyImport_Import(py_name);
+ Py_DECREF(py_name);
+ return py_module;
+bad:
+ Py_XDECREF(py_name);
+ return 0;
+}
+#endif
+
+#ifndef __PYX_HAVE_RT_ImportType
+#define __PYX_HAVE_RT_ImportType
+static PyTypeObject *__Pyx_ImportType(const char *module_name, const char *class_name,
+ size_t size, int strict)
+{
+ PyObject *py_module = 0;
+ PyObject *result = 0;
+ PyObject *py_name = 0;
+ char warning[200];
+ py_module = __Pyx_ImportModule(module_name);
+ if (!py_module)
+ goto bad;
+ py_name = __Pyx_PyIdentifier_FromString(class_name);
+ if (!py_name)
+ goto bad;
+ result = PyObject_GetAttr(py_module, py_name);
+ Py_DECREF(py_name);
+ py_name = 0;
+ Py_DECREF(py_module);
+ py_module = 0;
+ if (!result)
+ goto bad;
+ if (!PyType_Check(result)) {
+ PyErr_Format(PyExc_TypeError,
+ "%s.%s is not a type object",
+ module_name, class_name);
+ goto bad;
+ }
+ if (!strict && (size_t)((PyTypeObject *)result)->tp_basicsize > size) {
+ PyOS_snprintf(warning, sizeof(warning),
+ "%s.%s size changed, may indicate binary incompatibility",
+ module_name, class_name);
+ #if PY_VERSION_HEX < 0x02050000
+ if (PyErr_Warn(NULL, warning) < 0) goto bad;
+ #else
+ if (PyErr_WarnEx(NULL, warning, 0) < 0) goto bad;
+ #endif
+ }
+ else if ((size_t)((PyTypeObject *)result)->tp_basicsize != size) {
+ PyErr_Format(PyExc_ValueError,
+ "%s.%s has the wrong size, try recompiling",
+ module_name, class_name);
+ goto bad;
+ }
+ return (PyTypeObject *)result;
+bad:
+ Py_XDECREF(py_module);
+ Py_XDECREF(result);
+ return NULL;
+}
+#endif
+
+static void* __Pyx_GetVtable(PyObject *dict) {
+ void* ptr;
+ PyObject *ob = PyMapping_GetItemString(dict, (char *)"__pyx_vtable__");
+ if (!ob)
+ goto bad;
+#if PY_VERSION_HEX >= 0x02070000 && !(PY_MAJOR_VERSION==3&&PY_MINOR_VERSION==0)
+ ptr = PyCapsule_GetPointer(ob, 0);
+#else
+ ptr = PyCObject_AsVoidPtr(ob);
+#endif
+ if (!ptr && !PyErr_Occurred())
+ PyErr_SetString(PyExc_RuntimeError, "invalid vtable found for imported type");
+ Py_DECREF(ob);
+ return ptr;
+bad:
+ Py_XDECREF(ob);
+ return NULL;
+}
+
+#ifndef __PYX_HAVE_RT_ImportFunction
+#define __PYX_HAVE_RT_ImportFunction
+static int __Pyx_ImportFunction(PyObject *module, const char *funcname, void (**f)(void), const char *sig) {
+ PyObject *d = 0;
+ PyObject *cobj = 0;
+ union {
+ void (*fp)(void);
+ void *p;
+ } tmp;
+ d = PyObject_GetAttrString(module, (char *)"__pyx_capi__");
+ if (!d)
+ goto bad;
+ cobj = PyDict_GetItemString(d, funcname);
+ if (!cobj) {
+ PyErr_Format(PyExc_ImportError,
+ "%s does not export expected C function %s",
+ PyModule_GetName(module), funcname);
+ goto bad;
+ }
+#if PY_VERSION_HEX >= 0x02070000 && !(PY_MAJOR_VERSION==3 && PY_MINOR_VERSION==0)
+ if (!PyCapsule_IsValid(cobj, sig)) {
+ PyErr_Format(PyExc_TypeError,
+ "C function %s.%s has wrong signature (expected %s, got %s)",
+ PyModule_GetName(module), funcname, sig, PyCapsule_GetName(cobj));
+ goto bad;
+ }
+ tmp.p = PyCapsule_GetPointer(cobj, sig);
+#else
+ {const char *desc, *s1, *s2;
+ desc = (const char *)PyCObject_GetDesc(cobj);
+ if (!desc)
+ goto bad;
+ s1 = desc; s2 = sig;
+ while (*s1 != '\0' && *s1 == *s2) { s1++; s2++; }
+ if (*s1 != *s2) {
+ PyErr_Format(PyExc_TypeError,
+ "C function %s.%s has wrong signature (expected %s, got %s)",
+ PyModule_GetName(module), funcname, sig, desc);
+ goto bad;
+ }
+ tmp.p = PyCObject_AsVoidPtr(cobj);}
+#endif
+ *f = tmp.fp;
+ if (!(*f))
+ goto bad;
+ Py_DECREF(d);
+ return 0;
+bad:
+ Py_XDECREF(d);
+ return -1;
+}
+#endif
+
+static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line) {
+ int start = 0, mid = 0, end = count - 1;
+ if (end >= 0 && code_line > entries[end].code_line) {
+ return count;
+ }
+ while (start < end) {
+ mid = (start + end) / 2;
+ if (code_line < entries[mid].code_line) {
+ end = mid;
+ } else if (code_line > entries[mid].code_line) {
+ start = mid + 1;
+ } else {
+ return mid;
+ }
+ }
+ if (code_line <= entries[mid].code_line) {
+ return mid;
+ } else {
+ return mid + 1;
+ }
+}
+static PyCodeObject *__pyx_find_code_object(int code_line) {
+ PyCodeObject* code_object;
+ int pos;
+ if (unlikely(!code_line) || unlikely(!__pyx_code_cache.entries)) {
+ return NULL;
+ }
+ pos = __pyx_bisect_code_objects(__pyx_code_cache.entries, __pyx_code_cache.count, code_line);
+ if (unlikely(pos >= __pyx_code_cache.count) || unlikely(__pyx_code_cache.entries[pos].code_line != code_line)) {
+ return NULL;
+ }
+ code_object = __pyx_code_cache.entries[pos].code_object;
+ Py_INCREF(code_object);
+ return code_object;
+}
+static void __pyx_insert_code_object(int code_line, PyCodeObject* code_object) {
+ int pos, i;
+ __Pyx_CodeObjectCacheEntry* entries = __pyx_code_cache.entries;
+ if (unlikely(!code_line)) {
+ return;
+ }
+ if (unlikely(!entries)) {
+ entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Malloc(64*sizeof(__Pyx_CodeObjectCacheEntry));
+ if (likely(entries)) {
+ __pyx_code_cache.entries = entries;
+ __pyx_code_cache.max_count = 64;
+ __pyx_code_cache.count = 1;
+ entries[0].code_line = code_line;
+ entries[0].code_object = code_object;
+ Py_INCREF(code_object);
+ }
+ return;
+ }
+ pos = __pyx_bisect_code_objects(__pyx_code_cache.entries, __pyx_code_cache.count, code_line);
+ if ((pos < __pyx_code_cache.count) && unlikely(__pyx_code_cache.entries[pos].code_line == code_line)) {
+ PyCodeObject* tmp = entries[pos].code_object;
+ entries[pos].code_object = code_object;
+ Py_DECREF(tmp);
+ return;
+ }
+ if (__pyx_code_cache.count == __pyx_code_cache.max_count) {
+ int new_max = __pyx_code_cache.max_count + 64;
+ entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Realloc(
+ __pyx_code_cache.entries, new_max*sizeof(__Pyx_CodeObjectCacheEntry));
+ if (unlikely(!entries)) {
+ return;
+ }
+ __pyx_code_cache.entries = entries;
+ __pyx_code_cache.max_count = new_max;
+ }
+ for (i=__pyx_code_cache.count; i>pos; i--) {
+ entries[i] = entries[i-1];
+ }
+ entries[pos].code_line = code_line;
+ entries[pos].code_object = code_object;
+ __pyx_code_cache.count++;
+ Py_INCREF(code_object);
+}
+
+#include "compile.h"
+#include "frameobject.h"
+#include "traceback.h"
+static PyCodeObject* __Pyx_CreateCodeObjectForTraceback(
+ const char *funcname, int c_line,
+ int py_line, const char *filename) {
+ PyCodeObject *py_code = 0;
+ PyObject *py_srcfile = 0;
+ PyObject *py_funcname = 0;
+ #if PY_MAJOR_VERSION < 3
+ py_srcfile = PyString_FromString(filename);
+ #else
+ py_srcfile = PyUnicode_FromString(filename);
+ #endif
+ if (!py_srcfile) goto bad;
+ if (c_line) {
+ #if PY_MAJOR_VERSION < 3
+ py_funcname = PyString_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, c_line);
+ #else
+ py_funcname = PyUnicode_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, c_line);
+ #endif
+ }
+ else {
+ #if PY_MAJOR_VERSION < 3
+ py_funcname = PyString_FromString(funcname);
+ #else
+ py_funcname = PyUnicode_FromString(funcname);
+ #endif
+ }
+ if (!py_funcname) goto bad;
+ py_code = __Pyx_PyCode_New(
+ 0, /*int argcount,*/
+ 0, /*int kwonlyargcount,*/
+ 0, /*int nlocals,*/
+ 0, /*int stacksize,*/
+ 0, /*int flags,*/
+ __pyx_empty_bytes, /*PyObject *code,*/
+ __pyx_empty_tuple, /*PyObject *consts,*/
+ __pyx_empty_tuple, /*PyObject *names,*/
+ __pyx_empty_tuple, /*PyObject *varnames,*/
+ __pyx_empty_tuple, /*PyObject *freevars,*/
+ __pyx_empty_tuple, /*PyObject *cellvars,*/
+ py_srcfile, /*PyObject *filename,*/
+ py_funcname, /*PyObject *name,*/
+ py_line, /*int firstlineno,*/
+ __pyx_empty_bytes /*PyObject *lnotab*/
+ );
+ Py_DECREF(py_srcfile);
+ Py_DECREF(py_funcname);
+ return py_code;
+bad:
+ Py_XDECREF(py_srcfile);
+ Py_XDECREF(py_funcname);
+ return NULL;
+}
+static void __Pyx_AddTraceback(const char *funcname, int c_line,
+ int py_line, const char *filename) {
+ PyCodeObject *py_code = 0;
+ PyObject *py_globals = 0;
+ PyFrameObject *py_frame = 0;
+ py_code = __pyx_find_code_object(c_line ? c_line : py_line);
+ if (!py_code) {
+ py_code = __Pyx_CreateCodeObjectForTraceback(
+ funcname, c_line, py_line, filename);
+ if (!py_code) goto bad;
+ __pyx_insert_code_object(c_line ? c_line : py_line, py_code);
+ }
+ py_globals = PyModule_GetDict(__pyx_m);
+ if (!py_globals) goto bad;
+ py_frame = PyFrame_New(
+ PyThreadState_GET(), /*PyThreadState *tstate,*/
+ py_code, /*PyCodeObject *code,*/
+ py_globals, /*PyObject *globals,*/
+ 0 /*PyObject *locals*/
+ );
+ if (!py_frame) goto bad;
+ py_frame->f_lineno = py_line;
+ PyTraceBack_Here(py_frame);
+bad:
+ Py_XDECREF(py_code);
+ Py_XDECREF(py_frame);
+}
+
+static int __Pyx_InitStrings(__Pyx_StringTabEntry *t) {
+ while (t->p) {
+ #if PY_MAJOR_VERSION < 3
+ if (t->is_unicode) {
+ *t->p = PyUnicode_DecodeUTF8(t->s, t->n - 1, NULL);
+ } else if (t->intern) {
+ *t->p = PyString_InternFromString(t->s);
+ } else {
+ *t->p = PyString_FromStringAndSize(t->s, t->n - 1);
+ }
+ #else /* Python 3+ has unicode identifiers */
+ if (t->is_unicode | t->is_str) {
+ if (t->intern) {
+ *t->p = PyUnicode_InternFromString(t->s);
+ } else if (t->encoding) {
+ *t->p = PyUnicode_Decode(t->s, t->n - 1, t->encoding, NULL);
+ } else {
+ *t->p = PyUnicode_FromStringAndSize(t->s, t->n - 1);
+ }
+ } else {
+ *t->p = PyBytes_FromStringAndSize(t->s, t->n - 1);
+ }
+ #endif
+ if (!*t->p)
+ return -1;
+ ++t;
+ }
+ return 0;
+}
+
+
+/* Type Conversion Functions */
+
+static CYTHON_INLINE int __Pyx_PyObject_IsTrue(PyObject* x) {
+ int is_true = x == Py_True;
+ if (is_true | (x == Py_False) | (x == Py_None)) return is_true;
+ else return PyObject_IsTrue(x);
+}
+
+static CYTHON_INLINE PyObject* __Pyx_PyNumber_Int(PyObject* x) {
+ PyNumberMethods *m;
+ const char *name = NULL;
+ PyObject *res = NULL;
+#if PY_VERSION_HEX < 0x03000000
+ if (PyInt_Check(x) || PyLong_Check(x))
+#else
+ if (PyLong_Check(x))
+#endif
+ return Py_INCREF(x), x;
+ m = Py_TYPE(x)->tp_as_number;
+#if PY_VERSION_HEX < 0x03000000
+ if (m && m->nb_int) {
+ name = "int";
+ res = PyNumber_Int(x);
+ }
+ else if (m && m->nb_long) {
+ name = "long";
+ res = PyNumber_Long(x);
+ }
+#else
+ if (m && m->nb_int) {
+ name = "int";
+ res = PyNumber_Long(x);
+ }
+#endif
+ if (res) {
+#if PY_VERSION_HEX < 0x03000000
+ if (!PyInt_Check(res) && !PyLong_Check(res)) {
+#else
+ if (!PyLong_Check(res)) {
+#endif
+ PyErr_Format(PyExc_TypeError,
+ "__%s__ returned non-%s (type %.200s)",
+ name, name, Py_TYPE(res)->tp_name);
+ Py_DECREF(res);
+ return NULL;
+ }
+ }
+ else if (!PyErr_Occurred()) {
+ PyErr_SetString(PyExc_TypeError,
+ "an integer is required");
+ }
+ return res;
+}
+
+static CYTHON_INLINE Py_ssize_t __Pyx_PyIndex_AsSsize_t(PyObject* b) {
+ Py_ssize_t ival;
+ PyObject* x = PyNumber_Index(b);
+ if (!x) return -1;
+ ival = PyInt_AsSsize_t(x);
+ Py_DECREF(x);
+ return ival;
+}
+
+static CYTHON_INLINE PyObject * __Pyx_PyInt_FromSize_t(size_t ival) {
+#if PY_VERSION_HEX < 0x02050000
+ if (ival <= LONG_MAX)
+ return PyInt_FromLong((long)ival);
+ else {
+ unsigned char *bytes = (unsigned char *) &ival;
+ int one = 1; int little = (int)*(unsigned char*)&one;
+ return _PyLong_FromByteArray(bytes, sizeof(size_t), little, 0);
+ }
+#else
+ return PyInt_FromSize_t(ival);
+#endif
+}
+
+static CYTHON_INLINE size_t __Pyx_PyInt_AsSize_t(PyObject* x) {
+ unsigned PY_LONG_LONG val = __Pyx_PyInt_AsUnsignedLongLong(x);
+ if (unlikely(val == (unsigned PY_LONG_LONG)-1 && PyErr_Occurred())) {
+ return (size_t)-1;
+ } else if (unlikely(val != (unsigned PY_LONG_LONG)(size_t)val)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "value too large to convert to size_t");
+ return (size_t)-1;
+ }
+ return (size_t)val;
+}
+
+
+#endif /* Py_PYTHON_H */
diff --git a/eorepo/eobase.pxd b/eorepo/eobase.pxd
new file mode 100644
index 0000000..ade4219
--- /dev/null
+++ b/eorepo/eobase.pxd
@@ -0,0 +1,40 @@
+########################################################
+##
+## generated from ""
+##
+########################################################
+from eorepo.eodefault cimport *
+
+cimport eorepo.eodefault as eodefault
+
+cdef extern from "Eo.h":
+
+ Eo_Op EO_BASE_BASE_ID
+
+ ctypedef enum:
+ EO_BASE_SUB_ID_WREF_DEL,
+ EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE,
+ EO_BASE_SUB_ID_EVENT_CALLBACK_FORWARDER_DEL,
+ EO_BASE_SUB_ID_EVENT_GLOBAL_THAW,
+ EO_BASE_SUB_ID_EVENT_CALLBACK_DEL,
+ EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE_GET,
+ EO_BASE_SUB_ID_DATA_SET,
+ EO_BASE_SUB_ID_EVENT_THAW,
+ EO_BASE_SUB_ID_WREF_ADD,
+ EO_BASE_SUB_ID_DESTRUCTOR,
+ EO_BASE_SUB_ID_DATA_GET,
+ EO_BASE_SUB_ID_DATA_DEL,
+ EO_BASE_SUB_ID_CONSTRUCTOR,
+ EO_BASE_SUB_ID_EVENT_CALLBACK_CALL,
+ EO_BASE_SUB_ID_EVENT_FREEZE_GET,
+ EO_BASE_SUB_ID_EVENT_FREEZE,
+ EO_BASE_SUB_ID_EVENT_CALLBACK_PRIORITY_ADD,
+ EO_BASE_SUB_ID_EVENT_CALLBACK_FORWARDER_ADD
+
+
+ Eo_Class* eo_base_class_get()
+
+ Eo_Event_Description * EO_EV_CALLBACK_DEL
+ Eo_Event_Description * EO_EV_DEL
+ Eo_Event_Description * EO_EV_CALLBACK_ADD
+
diff --git a/eorepo/eobase.pxi b/eorepo/eobase.pxi
new file mode 100644
index 0000000..a09fb40
--- /dev/null
+++ b/eorepo/eobase.pxi
@@ -0,0 +1,108 @@
+########################################################
+##
+## generated from from "/home/yakov/xml/base/EoBase.xml"
+##
+########################################################
+
+cimport eobase as eobase
+from eodefault import EoDefault
+
+from cpython cimport Py_INCREF, Py_DECREF
+
+from eorepo.eodefault import pytext_to_utf8
+
+cdef int eobase_sub_id(int sub_id):
+ return eobase.EO_BASE_BASE_ID + sub_id
+
+class EoBase(EoDefault):
+
+ CALLBACK_DEL = <long>eobase.EO_EV_CALLBACK_DEL
+ DEL = <long>eobase.EO_EV_DEL
+ CALLBACK_ADD = <long>eobase.EO_EV_CALLBACK_ADD
+
+ def event_thaw(self):
+ eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_THAW))
+
+ def event_freeze(self):
+ eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_FREEZE))
+
+ def __init__(self, EoDefault parent):
+ instantiateable = False
+ if not instantiateable:
+ print "Class '%s' is not instantiate-able. Aborting."%(self.__class__.__name__)
+ exit(1)
+
+
+ @staticmethod
+ def event_global_freeze_get():
+ cdef int fcount
+ eodefault.eo_class_do(eobase.eo_base_class_get(), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE_GET), &fcount)
+ fcount_ = <object>fcount
+ return (fcount_)
+
+
+ @staticmethod
+ def event_global_freeze():
+ eodefault.eo_class_do(eobase.eo_base_class_get(), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_GLOBAL_FREEZE))
+
+
+ def data_get(self, object _key):
+ _key = None if _key is None else pytext_to_utf8(_key)
+ cdef char* key = NULL if _key is None else <char*> _key
+ cdef void* data
+ eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_GET), key, &data)
+ data_ = None if data == NULL else <object>data
+ return (data_)
+
+ def event_callback_del(self, long _desc, object _func):
+ cdef Eo_Event_Cb func = <Eo_Event_Cb> eodefault._object_callback
+ eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_DEL), _desc, func, <void*>_func)
+ Py_DECREF(_func)
+
+
+
+
+ def event_freeze_get(self):
+ cdef int fcount
+ eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_FREEZE_GET), &fcount)
+ fcount_ = <object>fcount
+ return (fcount_)
+
+ @staticmethod
+ def event_global_thaw():
+ eodefault.eo_class_do(eobase.eo_base_class_get(), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_GLOBAL_THAW))
+
+
+ def data_del(self, object _key):
+ _key = None if _key is None else pytext_to_utf8(_key)
+ cdef char* key = NULL if _key is None else <char*> _key
+ eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_DEL), key)
+
+ def event_callback_call(self, long _desc, object _event_info):
+ cdef long desc = <long> _desc
+ cdef void* event_info = <void*> _event_info
+ cdef unsigned char aborted
+ eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_CALL), desc, event_info, &aborted)
+ aborted_ = <object>aborted
+ return (aborted_)
+
+ def event_callback_priority_add(self, long _desc, int _priority, object _cb):
+ if not callable(_cb[0]):
+ raise TypeError("func must be callable")
+ cdef Eo_Event_Cb cb = <Eo_Event_Cb> eodefault._object_callback
+ Py_INCREF(_cb)
+ eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_EVENT_CALLBACK_PRIORITY_ADD), _desc, _priority, cb, <void*>_cb)
+
+
+ def data_set(self, object _key, object _data):
+ _key = pytext_to_utf8(_key)
+ cdef char* key = <char*> _key
+ eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_SET), key, <void*>_data, NULL)
+
+ def _data_set(self, object _key, object _data):
+ _key = pytext_to_utf8(_key)
+ cdef char* key = <char*> _key
+ eodefault.eo_do(eodefault._eo_instance_get(self), eobase_sub_id(eobase.EO_BASE_SUB_ID_DATA_SET), key, <void*>_data, NULL)
+
+
+
diff --git a/eorepo/eobase.pyx b/eorepo/eobase.pyx
new file mode 100644
index 0000000..489a58c
--- /dev/null
+++ b/eorepo/eobase.pyx
@@ -0,0 +1 @@
+include "eobase.pxi"
diff --git a/eorepo/eodefault.c b/eorepo/eodefault.c
new file mode 100644
index 0000000..5c71278
--- /dev/null
+++ b/eorepo/eodefault.c
@@ -0,0 +1,4095 @@
+/* Generated by Cython 0.17.2 on Thu Dec 13 18:28:03 2012 */
+
+#define PY_SSIZE_T_CLEAN
+#include "Python.h"
+#ifndef Py_PYTHON_H
+ #error Python headers needed to compile C extensions, please install development version of Python.
+#elif PY_VERSION_HEX < 0x02040000
+ #error Cython requires Python 2.4+.
+#else
+#include <stddef.h> /* For offsetof */
+#ifndef offsetof
+#define offsetof(type, member) ( (size_t) & ((type*)0) -> member )
+#endif
+#if !defined(WIN32) && !defined(MS_WINDOWS)
+ #ifndef __stdcall
+ #define __stdcall
+ #endif
+ #ifndef __cdecl
+ #define __cdecl
+ #endif
+ #ifndef __fastcall
+ #define __fastcall
+ #endif
+#endif
+#ifndef DL_IMPORT
+ #define DL_IMPORT(t) t
+#endif
+#ifndef DL_EXPORT
+ #define DL_EXPORT(t) t
+#endif
+#ifndef PY_LONG_LONG
+ #define PY_LONG_LONG LONG_LONG
+#endif
+#ifndef Py_HUGE_VAL
+ #define Py_HUGE_VAL HUGE_VAL
+#endif
+#ifdef PYPY_VERSION
+#define CYTHON_COMPILING_IN_PYPY 1
+#define CYTHON_COMPILING_IN_CPYTHON 0
+#else
+#define CYTHON_COMPILING_IN_PYPY 0
+#define CYTHON_COMPILING_IN_CPYTHON 1
+#endif
+#if PY_VERSION_HEX < 0x02050000
+ typedef int Py_ssize_t;
+ #define PY_SSIZE_T_MAX INT_MAX
+ #define PY_SSIZE_T_MIN INT_MIN
+ #define PY_FORMAT_SIZE_T ""
+ #define CYTHON_FORMAT_SSIZE_T ""
+ #define PyInt_FromSsize_t(z) PyInt_FromLong(z)
+ #define PyInt_AsSsize_t(o) __Pyx_PyInt_AsInt(o)
+ #define PyNumber_Index(o) ((PyNumber_Check(o) && !PyFloat_Check(o)) ? PyNumber_Int(o) : \
+ (PyErr_Format(PyExc_TypeError, \
+ "expected index value, got %.200s", Py_TYPE(o)->tp_name), \
+ (PyObject*)0))
+ #define __Pyx_PyIndex_Check(o) (PyNumber_Check(o) && !PyFloat_Check(o) && \
+ !PyComplex_Check(o))
+ #define PyIndex_Check __Pyx_PyIndex_Check
+ #define PyErr_WarnEx(category, message, stacklevel) PyErr_Warn(category, message)
+ #define __PYX_BUILD_PY_SSIZE_T "i"
+#else
+ #define __PYX_BUILD_PY_SSIZE_T "n"
+ #define CYTHON_FORMAT_SSIZE_T "z"
+ #define __Pyx_PyIndex_Check PyIndex_Check
+#endif
+#if PY_VERSION_HEX < 0x02060000
+ #define Py_REFCNT(ob) (((PyObject*)(ob))->ob_refcnt)
+ #define Py_TYPE(ob) (((PyObject*)(ob))->ob_type)
+ #define Py_SIZE(ob) (((PyVarObject*)(ob))->ob_size)
+ #define PyVarObject_HEAD_INIT(type, size) \
+ PyObject_HEAD_INIT(type) size,
+ #define PyType_Modified(t)
+ typedef struct {
+ void *buf;
+ PyObject *obj;
+ Py_ssize_t len;
+ Py_ssize_t itemsize;
+ int readonly;
+ int ndim;
+ char *format;
+ Py_ssize_t *shape;
+ Py_ssize_t *strides;
+ Py_ssize_t *suboffsets;
+ void *internal;
+ } Py_buffer;
+ #define PyBUF_SIMPLE 0
+ #define PyBUF_WRITABLE 0x0001
+ #define PyBUF_FORMAT 0x0004
+ #define PyBUF_ND 0x0008
+ #define PyBUF_STRIDES (0x0010 | PyBUF_ND)
+ #define PyBUF_C_CONTIGUOUS (0x0020 | PyBUF_STRIDES)
+ #define PyBUF_F_CONTIGUOUS (0x0040 | PyBUF_STRIDES)
+ #define PyBUF_ANY_CONTIGUOUS (0x0080 | PyBUF_STRIDES)
+ #define PyBUF_INDIRECT (0x0100 | PyBUF_STRIDES)
+ #define PyBUF_RECORDS (PyBUF_STRIDES | PyBUF_FORMAT | PyBUF_WRITABLE)
+ #define PyBUF_FULL (PyBUF_INDIRECT | PyBUF_FORMAT | PyBUF_WRITABLE)
+ typedef int (*getbufferproc)(PyObject *, Py_buffer *, int);
+ typedef void (*releasebufferproc)(PyObject *, Py_buffer *);
+#endif
+#if PY_MAJOR_VERSION < 3
+ #define __Pyx_BUILTIN_MODULE_NAME "__builtin__"
+ #define __Pyx_PyCode_New(a, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos) \
+ PyCode_New(a, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos)
+#else
+ #define __Pyx_BUILTIN_MODULE_NAME "builtins"
+ #define __Pyx_PyCode_New(a, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos) \
+ PyCode_New(a, k, l, s, f, code, c, n, v, fv, cell, fn, name, fline, lnos)
+#endif
+#if PY_MAJOR_VERSION < 3 && PY_MINOR_VERSION < 6
+ #define PyUnicode_FromString(s) PyUnicode_Decode(s, strlen(s), "UTF-8", "strict")
+#endif
+#if PY_MAJOR_VERSION >= 3
+ #define Py_TPFLAGS_CHECKTYPES 0
+ #define Py_TPFLAGS_HAVE_INDEX 0
+#endif
+#if (PY_VERSION_HEX < 0x02060000) || (PY_MAJOR_VERSION >= 3)
+ #define Py_TPFLAGS_HAVE_NEWBUFFER 0
+#endif
+#if PY_VERSION_HEX > 0x03030000 && defined(PyUnicode_KIND)
+ #define CYTHON_PEP393_ENABLED 1
+ #define __Pyx_PyUnicode_READY(op) (likely(PyUnicode_IS_READY(op)) ? \
+ 0 : _PyUnicode_Ready((PyObject *)(op)))
+ #define __Pyx_PyUnicode_GET_LENGTH(u) PyUnicode_GET_LENGTH(u)
+ #define __Pyx_PyUnicode_READ_CHAR(u, i) PyUnicode_READ_CHAR(u, i)
+ #define __Pyx_PyUnicode_READ(k, d, i) PyUnicode_READ(k, d, i)
+#else
+ #define CYTHON_PEP393_ENABLED 0
+ #define __Pyx_PyUnicode_READY(op) (0)
+ #define __Pyx_PyUnicode_GET_LENGTH(u) PyUnicode_GET_SIZE(u)
+ #define __Pyx_PyUnicode_READ_CHAR(u, i) ((Py_UCS4)(PyUnicode_AS_UNICODE(u)[i]))
+ #define __Pyx_PyUnicode_READ(k, d, i) ((k=k), (Py_UCS4)(((Py_UNICODE*)d)[i]))
+#endif
+#if PY_MAJOR_VERSION >= 3
+ #define PyBaseString_Type PyUnicode_Type
+ #define PyStringObject PyUnicodeObject
+ #define PyString_Type PyUnicode_Type
+ #define PyString_Check PyUnicode_Check
+ #define PyString_CheckExact PyUnicode_CheckExact
+#endif
+#if PY_VERSION_HEX < 0x02060000
+ #define PyBytesObject PyStringObject
+ #define PyBytes_Type PyString_Type
+ #define PyBytes_Check PyString_Check
+ #define PyBytes_CheckExact PyString_CheckExact
+ #define PyBytes_FromString PyString_FromString
+ #define PyBytes_FromStringAndSize PyString_FromStringAndSize
+ #define PyBytes_FromFormat PyString_FromFormat
+ #define PyBytes_DecodeEscape PyString_DecodeEscape
+ #define PyBytes_AsString PyString_AsString
+ #define PyBytes_AsStringAndSize PyString_AsStringAndSize
+ #define PyBytes_Size PyString_Size
+ #define PyBytes_AS_STRING PyString_AS_STRING
+ #define PyBytes_GET_SIZE PyString_GET_SIZE
+ #define PyBytes_Repr PyString_Repr
+ #define PyBytes_Concat PyString_Concat
+ #define PyBytes_ConcatAndDel PyString_ConcatAndDel
+#endif
+#if PY_VERSION_HEX < 0x02060000
+ #define PySet_Check(obj) PyObject_TypeCheck(obj, &PySet_Type)
+ #define PyFrozenSet_Check(obj) PyObject_TypeCheck(obj, &PyFrozenSet_Type)
+#endif
+#ifndef PySet_CheckExact
+ #define PySet_CheckExact(obj) (Py_TYPE(obj) == &PySet_Type)
+#endif
+#define __Pyx_TypeCheck(obj, type) PyObject_TypeCheck(obj, (PyTypeObject *)type)
+#if PY_MAJOR_VERSION >= 3
+ #define PyIntObject PyLongObject
+ #define PyInt_Type PyLong_Type
+ #define PyInt_Check(op) PyLong_Check(op)
+ #define PyInt_CheckExact(op) PyLong_CheckExact(op)
+ #define PyInt_FromString PyLong_FromString
+ #define PyInt_FromUnicode PyLong_FromUnicode
+ #define PyInt_FromLong PyLong_FromLong
+ #define PyInt_FromSize_t PyLong_FromSize_t
+ #define PyInt_FromSsize_t PyLong_FromSsize_t
+ #define PyInt_AsLong PyLong_AsLong
+ #define PyInt_AS_LONG PyLong_AS_LONG
+ #define PyInt_AsSsize_t PyLong_AsSsize_t
+ #define PyInt_AsUnsignedLongMask PyLong_AsUnsignedLongMask
+ #define PyInt_AsUnsignedLongLongMask PyLong_AsUnsignedLongLongMask
+#endif
+#if PY_MAJOR_VERSION >= 3
+ #define PyBoolObject PyLongObject
+#endif
+#if PY_VERSION_HEX < 0x03020000
+ typedef long Py_hash_t;
+ #define __Pyx_PyInt_FromHash_t PyInt_FromLong
+ #define __Pyx_PyInt_AsHash_t PyInt_AsLong
+#else
+ #define __Pyx_PyInt_FromHash_t PyInt_FromSsize_t
+ #define __Pyx_PyInt_AsHash_t PyInt_AsSsize_t
+#endif
+#if (PY_MAJOR_VERSION < 3) || (PY_VERSION_HEX >= 0x03010300)
+ #define __Pyx_PySequence_GetSlice(obj, a, b) PySequence_GetSlice(obj, a, b)
+ #define __Pyx_PySequence_SetSlice(obj, a, b, value) PySequence_SetSlice(obj, a, b, value)
+ #define __Pyx_PySequence_DelSlice(obj, a, b) PySequence_DelSlice(obj, a, b)
+#else
+ #define __Pyx_PySequence_GetSlice(obj, a, b) (unlikely(!(obj)) ? \
+ (PyErr_SetString(PyExc_SystemError, "null argument to internal routine"), (PyObject*)0) : \
+ (likely((obj)->ob_type->tp_as_mapping) ? (PySequence_GetSlice(obj, a, b)) : \
+ (PyErr_Format(PyExc_TypeError, "'%.200s' object is unsliceable", (obj)->ob_type->tp_name), (PyObject*)0)))
+ #define __Pyx_PySequence_SetSlice(obj, a, b, value) (unlikely(!(obj)) ? \
+ (PyErr_SetString(PyExc_SystemError, "null argument to internal routine"), -1) : \
+ (likely((obj)->ob_type->tp_as_mapping) ? (PySequence_SetSlice(obj, a, b, value)) : \
+ (PyErr_Format(PyExc_TypeError, "'%.200s' object doesn't support slice assignment", (obj)->ob_type->tp_name), -1)))
+ #define __Pyx_PySequence_DelSlice(obj, a, b) (unlikely(!(obj)) ? \
+ (PyErr_SetString(PyExc_SystemError, "null argument to internal routine"), -1) : \
+ (likely((obj)->ob_type->tp_as_mapping) ? (PySequence_DelSlice(obj, a, b)) : \
+ (PyErr_Format(PyExc_TypeError, "'%.200s' object doesn't support slice deletion", (obj)->ob_type->tp_name), -1)))
+#endif
+#if PY_MAJOR_VERSION >= 3
+ #define PyMethod_New(func, self, klass) ((self) ? PyMethod_New(func, self) : PyInstanceMethod_New(func))
+#endif
+#if PY_VERSION_HEX < 0x02050000
+ #define __Pyx_GetAttrString(o,n) PyObject_GetAttrString((o),((char *)(n)))
+ #define __Pyx_SetAttrString(o,n,a) PyObject_SetAttrString((o),((char *)(n)),(a))
+ #define __Pyx_DelAttrString(o,n) PyObject_DelAttrString((o),((char *)(n)))
+#else
+ #define __Pyx_GetAttrString(o,n) PyObject_GetAttrString((o),(n))
+ #define __Pyx_SetAttrString(o,n,a) PyObject_SetAttrString((o),(n),(a))
+ #define __Pyx_DelAttrString(o,n) PyObject_DelAttrString((o),(n))
+#endif
+#if PY_VERSION_HEX < 0x02050000
+ #define __Pyx_NAMESTR(n) ((char *)(n))
+ #define __Pyx_DOCSTR(n) ((char *)(n))
+#else
+ #define __Pyx_NAMESTR(n) (n)
+ #define __Pyx_DOCSTR(n) (n)
+#endif
+
+
+#if PY_MAJOR_VERSION >= 3
+ #define __Pyx_PyNumber_Divide(x,y) PyNumber_TrueDivide(x,y)
+ #define __Pyx_PyNumber_InPlaceDivide(x,y) PyNumber_InPlaceTrueDivide(x,y)
+#else
+ #define __Pyx_PyNumber_Divide(x,y) PyNumber_Divide(x,y)
+ #define __Pyx_PyNumber_InPlaceDivide(x,y) PyNumber_InPlaceDivide(x,y)
+#endif
+
+#ifndef __PYX_EXTERN_C
+ #ifdef __cplusplus
+ #define __PYX_EXTERN_C extern "C"
+ #else
+ #define __PYX_EXTERN_C extern
+ #endif
+#endif
+
+#if defined(WIN32) || defined(MS_WINDOWS)
+#define _USE_MATH_DEFINES
+#endif
+#include <math.h>
+#define __PYX_HAVE__eorepo__eodefault
+#define __PYX_HAVE_API__eorepo__eodefault
+#include "Eina.h"
+#include "Eo.h"
+#ifdef _OPENMP
+#include <omp.h>
+#endif /* _OPENMP */
+
+#ifdef PYREX_WITHOUT_ASSERTIONS
+#define CYTHON_WITHOUT_ASSERTIONS
+#endif
+
+
+/* inline attribute */
+#ifndef CYTHON_INLINE
+ #if defined(__GNUC__)
+ #define CYTHON_INLINE __inline__
+ #elif defined(_MSC_VER)
+ #define CYTHON_INLINE __inline
+ #elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 199901L
+ #define CYTHON_INLINE inline
+ #else
+ #define CYTHON_INLINE
+ #endif
+#endif
+
+/* unused attribute */
+#ifndef CYTHON_UNUSED
+# if defined(__GNUC__)
+# if !(defined(__cplusplus)) || (__GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 4))
+# define CYTHON_UNUSED __attribute__ ((__unused__))
+# else
+# define CYTHON_UNUSED
+# endif
+# elif defined(__ICC) || (defined(__INTEL_COMPILER) && !defined(_MSC_VER))
+# define CYTHON_UNUSED __attribute__ ((__unused__))
+# else
+# define CYTHON_UNUSED
+# endif
+#endif
+
+typedef struct {PyObject **p; char *s; const long n; const char* encoding; const char is_unicode; const char is_str; const char intern; } __Pyx_StringTabEntry; /*proto*/
+
+
+/* Type Conversion Predeclarations */
+
+#define __Pyx_PyBytes_FromUString(s) PyBytes_FromString((char*)s)
+#define __Pyx_PyBytes_AsUString(s) ((unsigned char*) PyBytes_AsString(s))
+
+#define __Pyx_Owned_Py_None(b) (Py_INCREF(Py_None), Py_None)
+#define __Pyx_PyBool_FromLong(b) ((b) ? (Py_INCREF(Py_True), Py_True) : (Py_INCREF(Py_False), Py_False))
+static CYTHON_INLINE int __Pyx_PyObject_IsTrue(PyObject*);
+static CYTHON_INLINE PyObject* __Pyx_PyNumber_Int(PyObject* x);
+
+static CYTHON_INLINE Py_ssize_t __Pyx_PyIndex_AsSsize_t(PyObject*);
+static CYTHON_INLINE PyObject * __Pyx_PyInt_FromSize_t(size_t);
+static CYTHON_INLINE size_t __Pyx_PyInt_AsSize_t(PyObject*);
+
+#if CYTHON_COMPILING_IN_CPYTHON
+#define __pyx_PyFloat_AsDouble(x) (PyFloat_CheckExact(x) ? PyFloat_AS_DOUBLE(x) : PyFloat_AsDouble(x))
+#else
+#define __pyx_PyFloat_AsDouble(x) PyFloat_AsDouble(x)
+#endif
+#define __pyx_PyFloat_AsFloat(x) ((float) __pyx_PyFloat_AsDouble(x))
+
+#ifdef __GNUC__
+ /* Test for GCC > 2.95 */
+ #if __GNUC__ > 2 || (__GNUC__ == 2 && (__GNUC_MINOR__ > 95))
+ #define likely(x) __builtin_expect(!!(x), 1)
+ #define unlikely(x) __builtin_expect(!!(x), 0)
+ #else /* __GNUC__ > 2 ... */
+ #define likely(x) (x)
+ #define unlikely(x) (x)
+ #endif /* __GNUC__ > 2 ... */
+#else /* __GNUC__ */
+ #define likely(x) (x)
+ #define unlikely(x) (x)
+#endif /* __GNUC__ */
+
+static PyObject *__pyx_m;
+static PyObject *__pyx_b;
+static PyObject *__pyx_empty_tuple;
+static PyObject *__pyx_empty_bytes;
+static int __pyx_lineno;
+static int __pyx_clineno = 0;
+static const char * __pyx_cfilenm= __FILE__;
+static const char *__pyx_filename;
+
+
+static const char *__pyx_f[] = {
+ "eodefault.pyx",
+};
+
+/*--- Type declarations ---*/
+struct __pyx_obj_6eorepo_9eodefault_EoDefault;
+
+/* "eorepo/eodefault.pxd":73
+ *
+ *
+ * cdef class EoDefault: # <<<<<<<<<<<<<<
+ * cdef Eo *eo
+ * cdef object name
+ */
+struct __pyx_obj_6eorepo_9eodefault_EoDefault {
+ PyObject_HEAD
+ struct __pyx_vtabstruct_6eorepo_9eodefault_EoDefault *__pyx_vtab;
+ Eo *eo;
+ PyObject *name;
+};
+
+
+
+/* "eorepo/eodefault.pyx":48
+ * #===========
+ *
+ * cdef class EoDefault: # <<<<<<<<<<<<<<
+ *
+ * PY_EO_NAME = "python-eo"
+ */
+
+struct __pyx_vtabstruct_6eorepo_9eodefault_EoDefault {
+ int (*print_func_name)(struct __pyx_obj_6eorepo_9eodefault_EoDefault *, PyObject *);
+ int (*_eo_instance_set)(struct __pyx_obj_6eorepo_9eodefault_EoDefault *, Eo *);
+ PyObject *(*_eo_instance_set2)(struct __pyx_obj_6eorepo_9eodefault_EoDefault *, unsigned PY_LONG_LONG, struct __pyx_obj_6eorepo_9eodefault_EoDefault *, int __pyx_skip_dispatch);
+};
+static struct __pyx_vtabstruct_6eorepo_9eodefault_EoDefault *__pyx_vtabptr_6eorepo_9eodefault_EoDefault;
+#ifndef CYTHON_REFNANNY
+ #define CYTHON_REFNANNY 0
+#endif
+#if CYTHON_REFNANNY
+ typedef struct {
+ void (*INCREF)(void*, PyObject*, int);
+ void (*DECREF)(void*, PyObject*, int);
+ void (*GOTREF)(void*, PyObject*, int);
+ void (*GIVEREF)(void*, PyObject*, int);
+ void* (*SetupContext)(const char*, int, const char*);
+ void (*FinishContext)(void**);
+ } __Pyx_RefNannyAPIStruct;
+ static __Pyx_RefNannyAPIStruct *__Pyx_RefNanny = NULL;
+ static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname); /*proto*/
+ #define __Pyx_RefNannyDeclarations void *__pyx_refnanny = NULL;
+#ifdef WITH_THREAD
+ #define __Pyx_RefNannySetupContext(name, acquire_gil) \
+ if (acquire_gil) { \
+ PyGILState_STATE __pyx_gilstate_save = PyGILState_Ensure(); \
+ __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), __LINE__, __FILE__); \
+ PyGILState_Release(__pyx_gilstate_save); \
+ } else { \
+ __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), __LINE__, __FILE__); \
+ }
+#else
+ #define __Pyx_RefNannySetupContext(name, acquire_gil) \
+ __pyx_refnanny = __Pyx_RefNanny->SetupContext((name), __LINE__, __FILE__)
+#endif
+ #define __Pyx_RefNannyFinishContext() \
+ __Pyx_RefNanny->FinishContext(&__pyx_refnanny)
+ #define __Pyx_INCREF(r) __Pyx_RefNanny->INCREF(__pyx_refnanny, (PyObject *)(r), __LINE__)
+ #define __Pyx_DECREF(r) __Pyx_RefNanny->DECREF(__pyx_refnanny, (PyObject *)(r), __LINE__)
+ #define __Pyx_GOTREF(r) __Pyx_RefNanny->GOTREF(__pyx_refnanny, (PyObject *)(r), __LINE__)
+ #define __Pyx_GIVEREF(r) __Pyx_RefNanny->GIVEREF(__pyx_refnanny, (PyObject *)(r), __LINE__)
+ #define __Pyx_XINCREF(r) do { if((r) != NULL) {__Pyx_INCREF(r); }} while(0)
+ #define __Pyx_XDECREF(r) do { if((r) != NULL) {__Pyx_DECREF(r); }} while(0)
+ #define __Pyx_XGOTREF(r) do { if((r) != NULL) {__Pyx_GOTREF(r); }} while(0)
+ #define __Pyx_XGIVEREF(r) do { if((r) != NULL) {__Pyx_GIVEREF(r);}} while(0)
+#else
+ #define __Pyx_RefNannyDeclarations
+ #define __Pyx_RefNannySetupContext(name, acquire_gil)
+ #define __Pyx_RefNannyFinishContext()
+ #define __Pyx_INCREF(r) Py_INCREF(r)
+ #define __Pyx_DECREF(r) Py_DECREF(r)
+ #define __Pyx_GOTREF(r)
+ #define __Pyx_GIVEREF(r)
+ #define __Pyx_XINCREF(r) Py_XINCREF(r)
+ #define __Pyx_XDECREF(r) Py_XDECREF(r)
+ #define __Pyx_XGOTREF(r)
+ #define __Pyx_XGIVEREF(r)
+#endif /* CYTHON_REFNANNY */
+#define __Pyx_CLEAR(r) do { PyObject* tmp = ((PyObject*)(r)); r = NULL; __Pyx_DECREF(tmp);} while(0)
+#define __Pyx_XCLEAR(r) do { if((r) != NULL) {PyObject* tmp = ((PyObject*)(r)); r = NULL; __Pyx_DECREF(tmp);}} while(0)
+
+static PyObject *__Pyx_GetName(PyObject *dict, PyObject *name); /*proto*/
+
+static CYTHON_INLINE void __Pyx_ErrRestore(PyObject *type, PyObject *value, PyObject *tb); /*proto*/
+static CYTHON_INLINE void __Pyx_ErrFetch(PyObject **type, PyObject **value, PyObject **tb); /*proto*/
+
+static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb, PyObject *cause); /*proto*/
+
+static void __Pyx_RaiseArgtupleInvalid(const char* func_name, int exact,
+ Py_ssize_t num_min, Py_ssize_t num_max, Py_ssize_t num_found); /*proto*/
+
+static CYTHON_INLINE int __Pyx_CheckKeywordStrings(PyObject *kwdict, const char* function_name, int kw_allowed); /*proto*/
+
+static void __Pyx_RaiseDoubleKeywordsError(const char* func_name, PyObject* kw_name); /*proto*/
+
+static int __Pyx_ParseOptionalKeywords(PyObject *kwds, PyObject **argnames[], \
+ PyObject *kwds2, PyObject *values[], Py_ssize_t num_pos_args, \
+ const char* function_name); /*proto*/
+
+static int __Pyx_ArgTypeTest(PyObject *obj, PyTypeObject *type, int none_allowed,
+ const char *name, int exact); /*proto*/
+
+static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Generic(PyObject *o, PyObject* j) {
+ PyObject *r;
+ if (!j) return NULL;
+ r = PyObject_GetItem(o, j);
+ Py_DECREF(j);
+ return r;
+}
+#define __Pyx_GetItemInt_List(o, i, size, to_py_func) (((size) <= sizeof(Py_ssize_t)) ? \
+ __Pyx_GetItemInt_List_Fast(o, i) : \
+ __Pyx_GetItemInt_Generic(o, to_py_func(i)))
+static CYTHON_INLINE PyObject *__Pyx_GetItemInt_List_Fast(PyObject *o, Py_ssize_t i) {
+#if CYTHON_COMPILING_IN_CPYTHON
+ if (likely((0 <= i) & (i < PyList_GET_SIZE(o)))) {
+ PyObject *r = PyList_GET_ITEM(o, i);
+ Py_INCREF(r);
+ return r;
+ }
+ else if ((-PyList_GET_SIZE(o) <= i) & (i < 0)) {
+ PyObject *r = PyList_GET_ITEM(o, PyList_GET_SIZE(o) + i);
+ Py_INCREF(r);
+ return r;
+ }
+ return __Pyx_GetItemInt_Generic(o, PyInt_FromSsize_t(i));
+#else
+ return PySequence_GetItem(o, i);
+#endif
+}
+#define __Pyx_GetItemInt_Tuple(o, i, size, to_py_func) (((size) <= sizeof(Py_ssize_t)) ? \
+ __Pyx_GetItemInt_Tuple_Fast(o, i) : \
+ __Pyx_GetItemInt_Generic(o, to_py_func(i)))
+static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Tuple_Fast(PyObject *o, Py_ssize_t i) {
+#if CYTHON_COMPILING_IN_CPYTHON
+ if (likely((0 <= i) & (i < PyTuple_GET_SIZE(o)))) {
+ PyObject *r = PyTuple_GET_ITEM(o, i);
+ Py_INCREF(r);
+ return r;
+ }
+ else if ((-PyTuple_GET_SIZE(o) <= i) & (i < 0)) {
+ PyObject *r = PyTuple_GET_ITEM(o, PyTuple_GET_SIZE(o) + i);
+ Py_INCREF(r);
+ return r;
+ }
+ return __Pyx_GetItemInt_Generic(o, PyInt_FromSsize_t(i));
+#else
+ return PySequence_GetItem(o, i);
+#endif
+}
+#define __Pyx_GetItemInt(o, i, size, to_py_func) (((size) <= sizeof(Py_ssize_t)) ? \
+ __Pyx_GetItemInt_Fast(o, i) : \
+ __Pyx_GetItemInt_Generic(o, to_py_func(i)))
+static CYTHON_INLINE PyObject *__Pyx_GetItemInt_Fast(PyObject *o, Py_ssize_t i) {
+#if CYTHON_COMPILING_IN_CPYTHON
+ if (PyList_CheckExact(o)) {
+ Py_ssize_t n = (likely(i >= 0)) ? i : i + PyList_GET_SIZE(o);
+ if (likely((n >= 0) & (n < PyList_GET_SIZE(o)))) {
+ PyObject *r = PyList_GET_ITEM(o, n);
+ Py_INCREF(r);
+ return r;
+ }
+ }
+ else if (PyTuple_CheckExact(o)) {
+ Py_ssize_t n = (likely(i >= 0)) ? i : i + PyTuple_GET_SIZE(o);
+ if (likely((n >= 0) & (n < PyTuple_GET_SIZE(o)))) {
+ PyObject *r = PyTuple_GET_ITEM(o, n);
+ Py_INCREF(r);
+ return r;
+ }
+ } else { /* inlined PySequence_GetItem() */
+ PySequenceMethods *m = Py_TYPE(o)->tp_as_sequence;
+ if (likely(m && m->sq_item)) {
+ if (unlikely(i < 0) && likely(m->sq_length)) {
+ Py_ssize_t l = m->sq_length(o);
+ if (unlikely(l < 0)) return NULL;
+ i += l;
+ }
+ return m->sq_item(o, i);
+ }
+ }
+#else
+ if (PySequence_Check(o)) {
+ return PySequence_GetItem(o, i);
+ }
+#endif
+ return __Pyx_GetItemInt_Generic(o, PyInt_FromSsize_t(i));
+}
+
+static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, long level); /*proto*/
+
+static CYTHON_INLINE PyObject *__Pyx_PyInt_to_py_Eina_Bool(Eina_Bool);
+
+static int __Pyx_Print(PyObject*, PyObject *, int); /*proto*/
+#if CYTHON_COMPILING_IN_PYPY || PY_MAJOR_VERSION >= 3
+static PyObject* __pyx_print = 0;
+static PyObject* __pyx_print_kwargs = 0;
+#endif
+
+static CYTHON_INLINE unsigned char __Pyx_PyInt_AsUnsignedChar(PyObject *);
+
+static CYTHON_INLINE unsigned short __Pyx_PyInt_AsUnsignedShort(PyObject *);
+
+static CYTHON_INLINE unsigned int __Pyx_PyInt_AsUnsignedInt(PyObject *);
+
+static CYTHON_INLINE char __Pyx_PyInt_AsChar(PyObject *);
+
+static CYTHON_INLINE short __Pyx_PyInt_AsShort(PyObject *);
+
+static CYTHON_INLINE int __Pyx_PyInt_AsInt(PyObject *);
+
+static CYTHON_INLINE signed char __Pyx_PyInt_AsSignedChar(PyObject *);
+
+static CYTHON_INLINE signed short __Pyx_PyInt_AsSignedShort(PyObject *);
+
+static CYTHON_INLINE signed int __Pyx_PyInt_AsSignedInt(PyObject *);
+
+static CYTHON_INLINE int __Pyx_PyInt_AsLongDouble(PyObject *);
+
+static CYTHON_INLINE unsigned long __Pyx_PyInt_AsUnsignedLong(PyObject *);
+
+static CYTHON_INLINE unsigned PY_LONG_LONG __Pyx_PyInt_AsUnsignedLongLong(PyObject *);
+
+static CYTHON_INLINE long __Pyx_PyInt_AsLong(PyObject *);
+
+static CYTHON_INLINE PY_LONG_LONG __Pyx_PyInt_AsLongLong(PyObject *);
+
+static CYTHON_INLINE signed long __Pyx_PyInt_AsSignedLong(PyObject *);
+
+static CYTHON_INLINE signed PY_LONG_LONG __Pyx_PyInt_AsSignedLongLong(PyObject *);
+
+static void __Pyx_WriteUnraisable(const char *name, int clineno,
+ int lineno, const char *filename); /*proto*/
+
+static int __Pyx_check_binary_version(void);
+
+static int __Pyx_ExportFunction(const char *name, void (*f)(void), const char *sig); /*proto*/
+
+static int __Pyx_SetVtable(PyObject *dict, void *vtable); /*proto*/
+
+typedef struct {
+ int code_line;
+ PyCodeObject* code_object;
+} __Pyx_CodeObjectCacheEntry;
+struct __Pyx_CodeObjectCache {
+ int count;
+ int max_count;
+ __Pyx_CodeObjectCacheEntry* entries;
+};
+static struct __Pyx_CodeObjectCache __pyx_code_cache = {0,0,NULL};
+static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line);
+static PyCodeObject *__pyx_find_code_object(int code_line);
+static void __pyx_insert_code_object(int code_line, PyCodeObject* code_object);
+
+static void __Pyx_AddTraceback(const char *funcname, int c_line,
+ int py_line, const char *filename); /*proto*/
+
+static int __Pyx_InitStrings(__Pyx_StringTabEntry *t); /*proto*/
+
+
+/* Module declarations from 'eorepo.eodefault' */
+static PyTypeObject *__pyx_ptype_6eorepo_9eodefault_EoDefault = 0;
+static Eo *__pyx_f_6eorepo_9eodefault__eo_instance_get(struct __pyx_obj_6eorepo_9eodefault_EoDefault *); /*proto*/
+#define __Pyx_MODULE_NAME "eorepo.eodefault"
+int __pyx_module_is_main_eorepo__eodefault = 0;
+
+/* Implementation of 'eorepo.eodefault' */
+static PyObject *__pyx_builtin_basestring;
+static PyObject *__pyx_builtin_TypeError;
+static PyObject *__pyx_pf_6eorepo_9eodefault_init(CYTHON_UNUSED PyObject *__pyx_self); /* proto */
+static PyObject *__pyx_pf_6eorepo_9eodefault_2pytext_to_utf8(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_text); /* proto */
+static int __pyx_pf_6eorepo_9eodefault_9EoDefault___cinit__(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self); /* proto */
+static void __pyx_pf_6eorepo_9eodefault_9EoDefault_2__dealloc__(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self); /* proto */
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_4delete(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self); /* proto */
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_6ref(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self); /* proto */
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_8unref(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self); /* proto */
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_10ref_get(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self); /* proto */
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_12parent_get(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self); /* proto */
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_14class_name_get(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self); /* proto */
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_16name_get(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self); /* proto */
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_18_eo_instance_set2(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self, unsigned PY_LONG_LONG __pyx_v__kl, struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_p); /* proto */
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_20_eo_instance_set3(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self, unsigned PY_LONG_LONG __pyx_v__eo); /* proto */
+static char __pyx_k_1[] = "Argument '%s' has incorrect type (expected %s, got %s)";
+static char __pyx_k_2[] = "";
+static char __pyx_k_3[] = "UTF-8";
+static char __pyx_k_5[] = "Object must be clean";
+static char __pyx_k_6[] = " :: ";
+static char __pyx_k_8[] = "/home/yakov/eo_bindings/eorepo/eodefault.pyx";
+static char __pyx_k_9[] = "eorepo.eodefault";
+static char __pyx_k_12[] = "python-eo";
+static char __pyx_k__p[] = "p";
+static char __pyx_k___kl[] = "_kl";
+static char __pyx_k__ref[] = "ref";
+static char __pyx_k__sys[] = "sys";
+static char __pyx_k__init[] = "init";
+static char __pyx_k__text[] = "text";
+static char __pyx_k__encode[] = "encode";
+static char __pyx_k____main__[] = "__main__";
+static char __pyx_k____name__[] = "__name__";
+static char __pyx_k____test__[] = "__test__";
+static char __pyx_k__operator[] = "operator";
+static char __pyx_k__TypeError[] = "TypeError";
+static char __pyx_k____class__[] = "__class__";
+static char __pyx_k___data_set[] = "_data_set";
+static char __pyx_k__getsizeof[] = "getsizeof";
+static char __pyx_k__utf8_data[] = "utf8_data";
+static char __pyx_k__PY_EO_NAME[] = "PY_EO_NAME";
+static char __pyx_k__basestring[] = "basestring";
+static char __pyx_k__CALLBACK_STOP[] = "CALLBACK_STOP";
+static char __pyx_k__PRIORITY_AFTER[] = "PRIORITY_AFTER";
+static char __pyx_k__pytext_to_utf8[] = "pytext_to_utf8";
+static char __pyx_k__PRIORITY_BEFORE[] = "PRIORITY_BEFORE";
+static char __pyx_k__PRIORITY_DEFAULT[] = "PRIORITY_DEFAULT";
+static char __pyx_k___eo_instance_set2[] = "_eo_instance_set2";
+static PyObject *__pyx_kp_s_1;
+static PyObject *__pyx_kp_s_12;
+static PyObject *__pyx_kp_s_2;
+static PyObject *__pyx_kp_s_3;
+static PyObject *__pyx_kp_s_5;
+static PyObject *__pyx_kp_s_6;
+static PyObject *__pyx_kp_s_8;
+static PyObject *__pyx_n_s_9;
+static PyObject *__pyx_n_s__CALLBACK_STOP;
+static PyObject *__pyx_n_s__PRIORITY_AFTER;
+static PyObject *__pyx_n_s__PRIORITY_BEFORE;
+static PyObject *__pyx_n_s__PRIORITY_DEFAULT;
+static PyObject *__pyx_n_s__PY_EO_NAME;
+static PyObject *__pyx_n_s__TypeError;
+static PyObject *__pyx_n_s____class__;
+static PyObject *__pyx_n_s____main__;
+static PyObject *__pyx_n_s____name__;
+static PyObject *__pyx_n_s____test__;
+static PyObject *__pyx_n_s___data_set;
+static PyObject *__pyx_n_s___eo_instance_set2;
+static PyObject *__pyx_n_s___kl;
+static PyObject *__pyx_n_s__basestring;
+static PyObject *__pyx_n_s__encode;
+static PyObject *__pyx_n_s__getsizeof;
+static PyObject *__pyx_n_s__init;
+static PyObject *__pyx_n_s__operator;
+static PyObject *__pyx_n_s__p;
+static PyObject *__pyx_n_s__pytext_to_utf8;
+static PyObject *__pyx_n_s__ref;
+static PyObject *__pyx_n_s__sys;
+static PyObject *__pyx_n_s__text;
+static PyObject *__pyx_n_s__utf8_data;
+static PyObject *__pyx_int_12345;
+static PyObject *__pyx_k_tuple_4;
+static PyObject *__pyx_k_tuple_10;
+static PyObject *__pyx_k_codeobj_7;
+static PyObject *__pyx_k_codeobj_11;
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_9eodefault_1init(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused); /*proto*/
+static PyMethodDef __pyx_mdef_6eorepo_9eodefault_1init = {__Pyx_NAMESTR("init"), (PyCFunction)__pyx_pw_6eorepo_9eodefault_1init, METH_NOARGS, __Pyx_DOCSTR(0)};
+static PyObject *__pyx_pw_6eorepo_9eodefault_1init(PyObject *__pyx_self, CYTHON_UNUSED PyObject *unused) {
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("init (wrapper)", 0);
+ __pyx_r = __pyx_pf_6eorepo_9eodefault_init(__pyx_self);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "eorepo/eodefault.pyx":18
+ *
+ *
+ * def init(): # <<<<<<<<<<<<<<
+ * return bool(eodefault.eo_init())
+ *
+ */
+
+static PyObject *__pyx_pf_6eorepo_9eodefault_init(CYTHON_UNUSED PyObject *__pyx_self) {
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ int __pyx_t_2;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("init", 0);
+
+ /* "eorepo/eodefault.pyx":19
+ *
+ * def init():
+ * return bool(eodefault.eo_init()) # <<<<<<<<<<<<<<
+ *
+ * #########################################################
+ */
+ __Pyx_XDECREF(__pyx_r);
+ __pyx_t_1 = __Pyx_PyInt_to_py_Eina_Bool(eo_init()); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 19; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __pyx_t_2 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_2 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 19; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ __pyx_t_1 = __Pyx_PyBool_FromLong((!(!__pyx_t_2))); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 19; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __pyx_r = __pyx_t_1;
+ __pyx_t_1 = 0;
+ goto __pyx_L0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_AddTraceback("eorepo.eodefault.init", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "eorepo/eodefault.pyx":23
+ * #########################################################
+ *
+ * cdef Eo *_eo_instance_get(EoDefault pyobj): # <<<<<<<<<<<<<<
+ * """
+ * if x is a Python object, (x is None) and (x is not None) are very efficient because they translate directly to C pointer comparisons.
+ */
+
+static Eo *__pyx_f_6eorepo_9eodefault__eo_instance_get(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_pyobj) {
+ Eo *__pyx_r;
+ __Pyx_RefNannyDeclarations
+ int __pyx_t_1;
+ __Pyx_RefNannySetupContext("_eo_instance_get", 0);
+
+ /* "eorepo/eodefault.pyx":28
+ * Whereas (x == None) and (x != None), or simply using x as a boolean value (as in if x: ...) will invoke Python operations and therefore be much slower.
+ * """
+ * if pyobj is not None: # <<<<<<<<<<<<<<
+ * return pyobj.eo
+ * else:
+ */
+ __pyx_t_1 = (((PyObject *)__pyx_v_pyobj) != Py_None);
+ if (__pyx_t_1) {
+
+ /* "eorepo/eodefault.pyx":29
+ * """
+ * if pyobj is not None:
+ * return pyobj.eo # <<<<<<<<<<<<<<
+ * else:
+ * NULL
+ */
+ __pyx_r = __pyx_v_pyobj->eo;
+ goto __pyx_L0;
+ goto __pyx_L3;
+ }
+ /*else*/ {
+
+ /* "eorepo/eodefault.pyx":31
+ * return pyobj.eo
+ * else:
+ * NULL # <<<<<<<<<<<<<<
+ *
+ * def pytext_to_utf8(text):
+ */
+ NULL;
+ }
+ __pyx_L3:;
+
+ __pyx_r = 0;
+ __pyx_L0:;
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_9eodefault_3pytext_to_utf8(PyObject *__pyx_self, PyObject *__pyx_v_text); /*proto*/
+static PyMethodDef __pyx_mdef_6eorepo_9eodefault_3pytext_to_utf8 = {__Pyx_NAMESTR("pytext_to_utf8"), (PyCFunction)__pyx_pw_6eorepo_9eodefault_3pytext_to_utf8, METH_O, __Pyx_DOCSTR(0)};
+static PyObject *__pyx_pw_6eorepo_9eodefault_3pytext_to_utf8(PyObject *__pyx_self, PyObject *__pyx_v_text) {
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("pytext_to_utf8 (wrapper)", 0);
+ __pyx_r = __pyx_pf_6eorepo_9eodefault_2pytext_to_utf8(__pyx_self, ((PyObject *)__pyx_v_text));
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "eorepo/eodefault.pyx":33
+ * NULL
+ *
+ * def pytext_to_utf8(text): # <<<<<<<<<<<<<<
+ *
+ * if not isinstance(text, basestring):
+ */
+
+static PyObject *__pyx_pf_6eorepo_9eodefault_2pytext_to_utf8(CYTHON_UNUSED PyObject *__pyx_self, PyObject *__pyx_v_text) {
+ PyObject *__pyx_v_utf8_data = NULL;
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ int __pyx_t_2;
+ int __pyx_t_3;
+ PyObject *__pyx_t_4 = NULL;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("pytext_to_utf8", 0);
+
+ /* "eorepo/eodefault.pyx":35
+ * def pytext_to_utf8(text):
+ *
+ * if not isinstance(text, basestring): # <<<<<<<<<<<<<<
+ * raise TypeError("Argument '%s' has incorrect type (expected %s, got %s)"%("text", "basestring", type(text).__name__))
+ * utf8_data = ""
+ */
+ __pyx_t_1 = __pyx_builtin_basestring;
+ __Pyx_INCREF(__pyx_t_1);
+ __pyx_t_2 = PyObject_IsInstance(__pyx_v_text, __pyx_t_1); if (unlikely(__pyx_t_2 == -1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 35; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ __pyx_t_3 = (!__pyx_t_2);
+ if (__pyx_t_3) {
+
+ /* "eorepo/eodefault.pyx":36
+ *
+ * if not isinstance(text, basestring):
+ * raise TypeError("Argument '%s' has incorrect type (expected %s, got %s)"%("text", "basestring", type(text).__name__)) # <<<<<<<<<<<<<<
+ * utf8_data = ""
+ *
+ */
+ __pyx_t_1 = PyObject_GetAttr(((PyObject *)Py_TYPE(__pyx_v_text)), __pyx_n_s____name__); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 36; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __pyx_t_4 = PyTuple_New(3); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 36; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_4);
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__text));
+ PyTuple_SET_ITEM(__pyx_t_4, 0, ((PyObject *)__pyx_n_s__text));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__text));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__basestring));
+ PyTuple_SET_ITEM(__pyx_t_4, 1, ((PyObject *)__pyx_n_s__basestring));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__basestring));
+ PyTuple_SET_ITEM(__pyx_t_4, 2, __pyx_t_1);
+ __Pyx_GIVEREF(__pyx_t_1);
+ __pyx_t_1 = 0;
+ __pyx_t_1 = PyNumber_Remainder(((PyObject *)__pyx_kp_s_1), ((PyObject *)__pyx_t_4)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 36; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(((PyObject *)__pyx_t_1));
+ __Pyx_DECREF(((PyObject *)__pyx_t_4)); __pyx_t_4 = 0;
+ __pyx_t_4 = PyTuple_New(1); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 36; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_4);
+ PyTuple_SET_ITEM(__pyx_t_4, 0, ((PyObject *)__pyx_t_1));
+ __Pyx_GIVEREF(((PyObject *)__pyx_t_1));
+ __pyx_t_1 = 0;
+ __pyx_t_1 = PyObject_Call(__pyx_builtin_TypeError, ((PyObject *)__pyx_t_4), NULL); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 36; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __Pyx_DECREF(((PyObject *)__pyx_t_4)); __pyx_t_4 = 0;
+ __Pyx_Raise(__pyx_t_1, 0, 0, 0);
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ {__pyx_filename = __pyx_f[0]; __pyx_lineno = 36; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ goto __pyx_L3;
+ }
+ __pyx_L3:;
+
+ /* "eorepo/eodefault.pyx":37
+ * if not isinstance(text, basestring):
+ * raise TypeError("Argument '%s' has incorrect type (expected %s, got %s)"%("text", "basestring", type(text).__name__))
+ * utf8_data = "" # <<<<<<<<<<<<<<
+ *
+ * if isinstance(text, unicode):
+ */
+ __Pyx_INCREF(((PyObject *)__pyx_kp_s_2));
+ __pyx_v_utf8_data = ((PyObject *)__pyx_kp_s_2);
+
+ /* "eorepo/eodefault.pyx":39
+ * utf8_data = ""
+ *
+ * if isinstance(text, unicode): # <<<<<<<<<<<<<<
+ * utf8_data = text.encode('UTF-8')
+ * elif isinstance(text, str):
+ */
+ __pyx_t_1 = ((PyObject *)((PyObject*)(&PyUnicode_Type)));
+ __Pyx_INCREF(__pyx_t_1);
+ __pyx_t_3 = __Pyx_TypeCheck(__pyx_v_text, __pyx_t_1);
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ if (__pyx_t_3) {
+
+ /* "eorepo/eodefault.pyx":40
+ *
+ * if isinstance(text, unicode):
+ * utf8_data = text.encode('UTF-8') # <<<<<<<<<<<<<<
+ * elif isinstance(text, str):
+ * utf8_data = text
+ */
+ __pyx_t_1 = PyObject_GetAttr(__pyx_v_text, __pyx_n_s__encode); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 40; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __pyx_t_4 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_k_tuple_4), NULL); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 40; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_4);
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ __Pyx_DECREF(__pyx_v_utf8_data);
+ __pyx_v_utf8_data = __pyx_t_4;
+ __pyx_t_4 = 0;
+ goto __pyx_L4;
+ }
+
+ /* "eorepo/eodefault.pyx":41
+ * if isinstance(text, unicode):
+ * utf8_data = text.encode('UTF-8')
+ * elif isinstance(text, str): # <<<<<<<<<<<<<<
+ * utf8_data = text
+ *
+ */
+ __pyx_t_4 = ((PyObject *)((PyObject*)(&PyString_Type)));
+ __Pyx_INCREF(__pyx_t_4);
+ __pyx_t_3 = __Pyx_TypeCheck(__pyx_v_text, __pyx_t_4);
+ __Pyx_DECREF(__pyx_t_4); __pyx_t_4 = 0;
+ if (__pyx_t_3) {
+
+ /* "eorepo/eodefault.pyx":42
+ * utf8_data = text.encode('UTF-8')
+ * elif isinstance(text, str):
+ * utf8_data = text # <<<<<<<<<<<<<<
+ *
+ * return utf8_data
+ */
+ __Pyx_INCREF(__pyx_v_text);
+ __Pyx_DECREF(__pyx_v_utf8_data);
+ __pyx_v_utf8_data = __pyx_v_text;
+ goto __pyx_L4;
+ }
+ __pyx_L4:;
+
+ /* "eorepo/eodefault.pyx":44
+ * utf8_data = text
+ *
+ * return utf8_data # <<<<<<<<<<<<<<
+ *
+ * #===========
+ */
+ __Pyx_XDECREF(__pyx_r);
+ __Pyx_INCREF(__pyx_v_utf8_data);
+ __pyx_r = __pyx_v_utf8_data;
+ goto __pyx_L0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_XDECREF(__pyx_t_4);
+ __Pyx_AddTraceback("eorepo.eodefault.pytext_to_utf8", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XDECREF(__pyx_v_utf8_data);
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static int __pyx_pw_6eorepo_9eodefault_9EoDefault_1__cinit__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
+static int __pyx_pw_6eorepo_9eodefault_9EoDefault_1__cinit__(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
+ int __pyx_r;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("__cinit__ (wrapper)", 0);
+ if (unlikely(PyTuple_GET_SIZE(__pyx_args) > 0)) {
+ __Pyx_RaiseArgtupleInvalid("__cinit__", 1, 0, 0, PyTuple_GET_SIZE(__pyx_args)); return -1;}
+ if (unlikely(__pyx_kwds) && unlikely(PyDict_Size(__pyx_kwds) > 0) && unlikely(!__Pyx_CheckKeywordStrings(__pyx_kwds, "__cinit__", 0))) return -1;
+ __pyx_r = __pyx_pf_6eorepo_9eodefault_9EoDefault___cinit__(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_v_self));
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "eorepo/eodefault.pyx":51
+ *
+ * PY_EO_NAME = "python-eo"
+ * def __cinit__(self): # <<<<<<<<<<<<<<
+ * self.eo = NULL
+ *
+ */
+
+static int __pyx_pf_6eorepo_9eodefault_9EoDefault___cinit__(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self) {
+ int __pyx_r;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("__cinit__", 0);
+
+ /* "eorepo/eodefault.pyx":52
+ * PY_EO_NAME = "python-eo"
+ * def __cinit__(self):
+ * self.eo = NULL # <<<<<<<<<<<<<<
+ *
+ * def __dealloc__(self):
+ */
+ __pyx_v_self->eo = NULL;
+
+ __pyx_r = 0;
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static void __pyx_pw_6eorepo_9eodefault_9EoDefault_3__dealloc__(PyObject *__pyx_v_self); /*proto*/
+static void __pyx_pw_6eorepo_9eodefault_9EoDefault_3__dealloc__(PyObject *__pyx_v_self) {
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("__dealloc__ (wrapper)", 0);
+ __pyx_pf_6eorepo_9eodefault_9EoDefault_2__dealloc__(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_v_self));
+ __Pyx_RefNannyFinishContext();
+}
+
+/* "eorepo/eodefault.pyx":54
+ * self.eo = NULL
+ *
+ * def __dealloc__(self): # <<<<<<<<<<<<<<
+ * cdef Eo *eo
+ * #self.print_func_name("__dealloc__base__")
+ */
+
+static void __pyx_pf_6eorepo_9eodefault_9EoDefault_2__dealloc__(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self) {
+ Eo *__pyx_v_eo;
+ __Pyx_RefNannyDeclarations
+ Eo *__pyx_t_1;
+ int __pyx_t_2;
+ PyObject *__pyx_t_3 = NULL;
+ const char* __pyx_t_4;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("__dealloc__", 0);
+
+ /* "eorepo/eodefault.pyx":58
+ * #self.print_func_name("__dealloc__base__")
+ *
+ * eo = self.eo # <<<<<<<<<<<<<<
+ * if eo == NULL:
+ * return
+ */
+ __pyx_t_1 = __pyx_v_self->eo;
+ __pyx_v_eo = __pyx_t_1;
+
+ /* "eorepo/eodefault.pyx":59
+ *
+ * eo = self.eo
+ * if eo == NULL: # <<<<<<<<<<<<<<
+ * return
+ * #eodefault._eo_instance_get(self)
+ */
+ __pyx_t_2 = (__pyx_v_eo == NULL);
+ if (__pyx_t_2) {
+
+ /* "eorepo/eodefault.pyx":60
+ * eo = self.eo
+ * if eo == NULL:
+ * return # <<<<<<<<<<<<<<
+ * #eodefault._eo_instance_get(self)
+ * eodefault.eo_do(eo, eodefault.EO_BASE_BASE_ID + eodefault.EO_BASE_SUB_ID_DATA_DEL, <const_char_ptr>EoDefault.PY_EO_NAME)
+ */
+ goto __pyx_L0;
+ goto __pyx_L3;
+ }
+ __pyx_L3:;
+
+ /* "eorepo/eodefault.pyx":62
+ * return
+ * #eodefault._eo_instance_get(self)
+ * eodefault.eo_do(eo, eodefault.EO_BASE_BASE_ID + eodefault.EO_BASE_SUB_ID_DATA_DEL, <const_char_ptr>EoDefault.PY_EO_NAME) # <<<<<<<<<<<<<<
+ * eodefault.eo_unref(eo)
+ * self.eo = NULL
+ */
+ __pyx_t_3 = PyObject_GetAttr(((PyObject *)((PyObject*)__pyx_ptype_6eorepo_9eodefault_EoDefault)), __pyx_n_s__PY_EO_NAME); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 62; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __pyx_t_4 = PyBytes_AsString(__pyx_t_3); if (unlikely((__pyx_t_4 == (const char*)NULL) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 62; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+ eo_do(__pyx_v_eo, (EO_BASE_BASE_ID + EO_BASE_SUB_ID_DATA_DEL), ((const char*)__pyx_t_4));
+
+ /* "eorepo/eodefault.pyx":63
+ * #eodefault._eo_instance_get(self)
+ * eodefault.eo_do(eo, eodefault.EO_BASE_BASE_ID + eodefault.EO_BASE_SUB_ID_DATA_DEL, <const_char_ptr>EoDefault.PY_EO_NAME)
+ * eodefault.eo_unref(eo) # <<<<<<<<<<<<<<
+ * self.eo = NULL
+ *
+ */
+ eo_unref(__pyx_v_eo);
+
+ /* "eorepo/eodefault.pyx":64
+ * eodefault.eo_do(eo, eodefault.EO_BASE_BASE_ID + eodefault.EO_BASE_SUB_ID_DATA_DEL, <const_char_ptr>EoDefault.PY_EO_NAME)
+ * eodefault.eo_unref(eo)
+ * self.eo = NULL # <<<<<<<<<<<<<<
+ *
+ * # eo_del()
+ */
+ __pyx_v_self->eo = NULL;
+
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_3);
+ __Pyx_AddTraceback("eorepo.eodefault.EoDefault.__dealloc__", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_L0:;
+ __Pyx_RefNannyFinishContext();
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_5delete(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_5delete(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) {
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("delete (wrapper)", 0);
+ __pyx_r = __pyx_pf_6eorepo_9eodefault_9EoDefault_4delete(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_v_self));
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "eorepo/eodefault.pyx":67
+ *
+ * # eo_del()
+ * def delete(self): # <<<<<<<<<<<<<<
+ * self.ref()
+ * eodefault.eo_del(self.eo)
+ */
+
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_4delete(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self) {
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ PyObject *__pyx_t_2 = NULL;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("delete", 0);
+
+ /* "eorepo/eodefault.pyx":68
+ * # eo_del()
+ * def delete(self):
+ * self.ref() # <<<<<<<<<<<<<<
+ * eodefault.eo_del(self.eo)
+ *
+ */
+ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s__ref); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 68; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_empty_tuple), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 68; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_2);
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+
+ /* "eorepo/eodefault.pyx":69
+ * def delete(self):
+ * self.ref()
+ * eodefault.eo_del(self.eo) # <<<<<<<<<<<<<<
+ *
+ * # eo_ref()
+ */
+ eo_del(__pyx_v_self->eo);
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_XDECREF(__pyx_t_2);
+ __Pyx_AddTraceback("eorepo.eodefault.EoDefault.delete", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_7ref(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_7ref(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) {
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("ref (wrapper)", 0);
+ __pyx_r = __pyx_pf_6eorepo_9eodefault_9EoDefault_6ref(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_v_self));
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "eorepo/eodefault.pyx":72
+ *
+ * # eo_ref()
+ * def ref(self): # <<<<<<<<<<<<<<
+ * eodefault.eo_ref(self.eo)
+ * return self
+ */
+
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_6ref(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self) {
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("ref", 0);
+
+ /* "eorepo/eodefault.pyx":73
+ * # eo_ref()
+ * def ref(self):
+ * eodefault.eo_ref(self.eo) # <<<<<<<<<<<<<<
+ * return self
+ *
+ */
+ eo_ref(__pyx_v_self->eo);
+
+ /* "eorepo/eodefault.pyx":74
+ * def ref(self):
+ * eodefault.eo_ref(self.eo)
+ * return self # <<<<<<<<<<<<<<
+ *
+ * def unref(self):
+ */
+ __Pyx_XDECREF(__pyx_r);
+ __Pyx_INCREF(((PyObject *)__pyx_v_self));
+ __pyx_r = ((PyObject *)__pyx_v_self);
+ goto __pyx_L0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ __pyx_L0:;
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_9unref(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_9unref(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) {
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("unref (wrapper)", 0);
+ __pyx_r = __pyx_pf_6eorepo_9eodefault_9EoDefault_8unref(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_v_self));
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "eorepo/eodefault.pyx":76
+ * return self
+ *
+ * def unref(self): # <<<<<<<<<<<<<<
+ * eodefault.eo_unref(self.eo)
+ *
+ */
+
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_8unref(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self) {
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("unref", 0);
+
+ /* "eorepo/eodefault.pyx":77
+ *
+ * def unref(self):
+ * eodefault.eo_unref(self.eo) # <<<<<<<<<<<<<<
+ *
+ * # eo_ref_get()
+ */
+ eo_unref(__pyx_v_self->eo);
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_11ref_get(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_11ref_get(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) {
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("ref_get (wrapper)", 0);
+ __pyx_r = __pyx_pf_6eorepo_9eodefault_9EoDefault_10ref_get(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_v_self));
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "eorepo/eodefault.pyx":80
+ *
+ * # eo_ref_get()
+ * def ref_get(self): # <<<<<<<<<<<<<<
+ * ref_count = <object>eodefault.eo_ref_get(self.eo)
+ * return ref_count
+ */
+
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_10ref_get(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self) {
+ PyObject *__pyx_v_ref_count = NULL;
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("ref_get", 0);
+
+ /* "eorepo/eodefault.pyx":81
+ * # eo_ref_get()
+ * def ref_get(self):
+ * ref_count = <object>eodefault.eo_ref_get(self.eo) # <<<<<<<<<<<<<<
+ * return ref_count
+ *
+ */
+ __pyx_t_1 = PyInt_FromLong(eo_ref_get(__pyx_v_self->eo)); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 81; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __Pyx_INCREF(((PyObject *)__pyx_t_1));
+ __pyx_v_ref_count = __pyx_t_1;
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ /* "eorepo/eodefault.pyx":82
+ * def ref_get(self):
+ * ref_count = <object>eodefault.eo_ref_get(self.eo)
+ * return ref_count # <<<<<<<<<<<<<<
+ *
+ * # eo_parent_get()
+ */
+ __Pyx_XDECREF(__pyx_r);
+ __Pyx_INCREF(__pyx_v_ref_count);
+ __pyx_r = __pyx_v_ref_count;
+ goto __pyx_L0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_AddTraceback("eorepo.eodefault.EoDefault.ref_get", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XDECREF(__pyx_v_ref_count);
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_13parent_get(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_13parent_get(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) {
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("parent_get (wrapper)", 0);
+ __pyx_r = __pyx_pf_6eorepo_9eodefault_9EoDefault_12parent_get(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_v_self));
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "eorepo/eodefault.pyx":85
+ *
+ * # eo_parent_get()
+ * def parent_get(self): # <<<<<<<<<<<<<<
+ * cdef Eo * parent
+ * cdef void * data
+ */
+
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_12parent_get(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self) {
+ Eo *__pyx_v_parent;
+ void *__pyx_v_data;
+ PyObject *__pyx_v_obj = NULL;
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ const char* __pyx_t_2;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("parent_get", 0);
+
+ /* "eorepo/eodefault.pyx":88
+ * cdef Eo * parent
+ * cdef void * data
+ * parent = eodefault.eo_parent_get(self.eo) # <<<<<<<<<<<<<<
+ * eodefault.eo_do(parent, eodefault.EO_BASE_BASE_ID+eodefault.EO_BASE_SUB_ID_DATA_GET, <const_char_ptr>EoDefault.PY_EO_NAME, &data)
+ * obj = <object>data
+ */
+ __pyx_v_parent = eo_parent_get(__pyx_v_self->eo);
+
+ /* "eorepo/eodefault.pyx":89
+ * cdef void * data
+ * parent = eodefault.eo_parent_get(self.eo)
+ * eodefault.eo_do(parent, eodefault.EO_BASE_BASE_ID+eodefault.EO_BASE_SUB_ID_DATA_GET, <const_char_ptr>EoDefault.PY_EO_NAME, &data) # <<<<<<<<<<<<<<
+ * obj = <object>data
+ * return obj
+ */
+ __pyx_t_1 = PyObject_GetAttr(((PyObject *)((PyObject*)__pyx_ptype_6eorepo_9eodefault_EoDefault)), __pyx_n_s__PY_EO_NAME); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 89; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __pyx_t_2 = PyBytes_AsString(__pyx_t_1); if (unlikely((__pyx_t_2 == (const char*)NULL) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 89; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ eo_do(__pyx_v_parent, (EO_BASE_BASE_ID + EO_BASE_SUB_ID_DATA_GET), ((const char*)__pyx_t_2), (&__pyx_v_data));
+
+ /* "eorepo/eodefault.pyx":90
+ * parent = eodefault.eo_parent_get(self.eo)
+ * eodefault.eo_do(parent, eodefault.EO_BASE_BASE_ID+eodefault.EO_BASE_SUB_ID_DATA_GET, <const_char_ptr>EoDefault.PY_EO_NAME, &data)
+ * obj = <object>data # <<<<<<<<<<<<<<
+ * return obj
+ *
+ */
+ __Pyx_INCREF(((PyObject *)__pyx_v_data));
+ __pyx_v_obj = ((PyObject *)__pyx_v_data);
+
+ /* "eorepo/eodefault.pyx":91
+ * eodefault.eo_do(parent, eodefault.EO_BASE_BASE_ID+eodefault.EO_BASE_SUB_ID_DATA_GET, <const_char_ptr>EoDefault.PY_EO_NAME, &data)
+ * obj = <object>data
+ * return obj # <<<<<<<<<<<<<<
+ *
+ * # eo_class_name_get()
+ */
+ __Pyx_XDECREF(__pyx_r);
+ __Pyx_INCREF(__pyx_v_obj);
+ __pyx_r = __pyx_v_obj;
+ goto __pyx_L0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_AddTraceback("eorepo.eodefault.EoDefault.parent_get", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XDECREF(__pyx_v_obj);
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_15class_name_get(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_15class_name_get(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) {
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("class_name_get (wrapper)", 0);
+ __pyx_r = __pyx_pf_6eorepo_9eodefault_9EoDefault_14class_name_get(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_v_self));
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "eorepo/eodefault.pyx":94
+ *
+ * # eo_class_name_get()
+ * def class_name_get(self): # <<<<<<<<<<<<<<
+ * name = eodefault.eo_class_name_get(eodefault.eo_class_get(self.eo))
+ * return name
+ */
+
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_14class_name_get(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self) {
+ char *__pyx_v_name;
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("class_name_get", 0);
+
+ /* "eorepo/eodefault.pyx":95
+ * # eo_class_name_get()
+ * def class_name_get(self):
+ * name = eodefault.eo_class_name_get(eodefault.eo_class_get(self.eo)) # <<<<<<<<<<<<<<
+ * return name
+ *
+ */
+ __pyx_v_name = eo_class_name_get(eo_class_get(__pyx_v_self->eo));
+
+ /* "eorepo/eodefault.pyx":96
+ * def class_name_get(self):
+ * name = eodefault.eo_class_name_get(eodefault.eo_class_get(self.eo))
+ * return name # <<<<<<<<<<<<<<
+ *
+ * def name_get(self):
+ */
+ __Pyx_XDECREF(__pyx_r);
+ __pyx_t_1 = PyBytes_FromString(__pyx_v_name); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 96; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(((PyObject *)__pyx_t_1));
+ __pyx_r = ((PyObject *)__pyx_t_1);
+ __pyx_t_1 = 0;
+ goto __pyx_L0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_AddTraceback("eorepo.eodefault.EoDefault.class_name_get", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_17name_get(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused); /*proto*/
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_17name_get(PyObject *__pyx_v_self, CYTHON_UNUSED PyObject *unused) {
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("name_get (wrapper)", 0);
+ __pyx_r = __pyx_pf_6eorepo_9eodefault_9EoDefault_16name_get(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_v_self));
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "eorepo/eodefault.pyx":98
+ * return name
+ *
+ * def name_get(self): # <<<<<<<<<<<<<<
+ * return self.name
+ * #this func can be called only from this (c-styled)module
+ */
+
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_16name_get(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self) {
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("name_get", 0);
+
+ /* "eorepo/eodefault.pyx":99
+ *
+ * def name_get(self):
+ * return self.name # <<<<<<<<<<<<<<
+ * #this func can be called only from this (c-styled)module
+ * cdef int _eo_instance_set(self, Eo *eo):
+ */
+ __Pyx_XDECREF(__pyx_r);
+ __Pyx_INCREF(__pyx_v_self->name);
+ __pyx_r = __pyx_v_self->name;
+ goto __pyx_L0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ __pyx_L0:;
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "eorepo/eodefault.pyx":101
+ * return self.name
+ * #this func can be called only from this (c-styled)module
+ * cdef int _eo_instance_set(self, Eo *eo): # <<<<<<<<<<<<<<
+ * assert self.eo == NULL, "Object must be clean"
+ * self.eo = eo
+ */
+
+static int __pyx_f_6eorepo_9eodefault_9EoDefault__eo_instance_set(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self, Eo *__pyx_v_eo) {
+ int __pyx_r;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ PyObject *__pyx_t_2 = NULL;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("_eo_instance_set", 0);
+
+ /* "eorepo/eodefault.pyx":102
+ * #this func can be called only from this (c-styled)module
+ * cdef int _eo_instance_set(self, Eo *eo):
+ * assert self.eo == NULL, "Object must be clean" # <<<<<<<<<<<<<<
+ * self.eo = eo
+ * self.name = self.__class__.__name__
+ */
+ #ifndef CYTHON_WITHOUT_ASSERTIONS
+ if (unlikely(!(__pyx_v_self->eo == NULL))) {
+ PyErr_SetObject(PyExc_AssertionError, ((PyObject *)__pyx_kp_s_5));
+ {__pyx_filename = __pyx_f[0]; __pyx_lineno = 102; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ }
+ #endif
+
+ /* "eorepo/eodefault.pyx":103
+ * cdef int _eo_instance_set(self, Eo *eo):
+ * assert self.eo == NULL, "Object must be clean"
+ * self.eo = eo # <<<<<<<<<<<<<<
+ * self.name = self.__class__.__name__
+ *
+ */
+ __pyx_v_self->eo = __pyx_v_eo;
+
+ /* "eorepo/eodefault.pyx":104
+ * assert self.eo == NULL, "Object must be clean"
+ * self.eo = eo
+ * self.name = self.__class__.__name__ # <<<<<<<<<<<<<<
+ *
+ * # this func is main routine to add new object
+ */
+ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s____class__); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 104; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __pyx_t_2 = PyObject_GetAttr(__pyx_t_1, __pyx_n_s____name__); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 104; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_2);
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ __Pyx_GIVEREF(__pyx_t_2);
+ __Pyx_GOTREF(__pyx_v_self->name);
+ __Pyx_DECREF(__pyx_v_self->name);
+ __pyx_v_self->name = __pyx_t_2;
+ __pyx_t_2 = 0;
+
+ __pyx_r = 0;
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_XDECREF(__pyx_t_2);
+ __Pyx_WriteUnraisable("eorepo.eodefault.EoDefault._eo_instance_set", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = 0;
+ __pyx_L0:;
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "eorepo/eodefault.pyx":109
+ * # using default constructor
+ * # and connect C and Py objects
+ * cpdef _eo_instance_set2(self, unsigned long long _kl, EoDefault p): # <<<<<<<<<<<<<<
+ * cdef Eo_Class *kl = <Eo_Class*>_kl
+ * cdef Eo *o = eodefault.eo_add(kl, eodefault._eo_instance_get(p))
+ */
+
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_19_eo_instance_set2(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
+static PyObject *__pyx_f_6eorepo_9eodefault_9EoDefault__eo_instance_set2(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self, unsigned PY_LONG_LONG __pyx_v__kl, struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_p, int __pyx_skip_dispatch) {
+ Eo_Class *__pyx_v_kl;
+ Eo *__pyx_v_o;
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ PyObject *__pyx_t_2 = NULL;
+ PyObject *__pyx_t_3 = NULL;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("_eo_instance_set2", 0);
+ /* Check if called by wrapper */
+ if (unlikely(__pyx_skip_dispatch)) ;
+ /* Check if overriden in Python */
+ else if (unlikely(Py_TYPE(((PyObject *)__pyx_v_self))->tp_dictoffset != 0)) {
+ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s___eo_instance_set2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 109; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ if (!PyCFunction_Check(__pyx_t_1) || (PyCFunction_GET_FUNCTION(__pyx_t_1) != (PyCFunction)__pyx_pw_6eorepo_9eodefault_9EoDefault_19_eo_instance_set2)) {
+ __Pyx_XDECREF(__pyx_r);
+ __pyx_t_2 = PyLong_FromUnsignedLongLong(__pyx_v__kl); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 109; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_2);
+ __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 109; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_2);
+ __Pyx_GIVEREF(__pyx_t_2);
+ __Pyx_INCREF(((PyObject *)__pyx_v_p));
+ PyTuple_SET_ITEM(__pyx_t_3, 1, ((PyObject *)__pyx_v_p));
+ __Pyx_GIVEREF(((PyObject *)__pyx_v_p));
+ __pyx_t_2 = 0;
+ __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_t_3), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 109; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_2);
+ __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0;
+ __pyx_r = __pyx_t_2;
+ __pyx_t_2 = 0;
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ goto __pyx_L0;
+ }
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ }
+
+ /* "eorepo/eodefault.pyx":110
+ * # and connect C and Py objects
+ * cpdef _eo_instance_set2(self, unsigned long long _kl, EoDefault p):
+ * cdef Eo_Class *kl = <Eo_Class*>_kl # <<<<<<<<<<<<<<
+ * cdef Eo *o = eodefault.eo_add(kl, eodefault._eo_instance_get(p))
+ * self._eo_instance_set(o)
+ */
+ __pyx_v_kl = ((Eo_Class *)__pyx_v__kl);
+
+ /* "eorepo/eodefault.pyx":111
+ * cpdef _eo_instance_set2(self, unsigned long long _kl, EoDefault p):
+ * cdef Eo_Class *kl = <Eo_Class*>_kl
+ * cdef Eo *o = eodefault.eo_add(kl, eodefault._eo_instance_get(p)) # <<<<<<<<<<<<<<
+ * self._eo_instance_set(o)
+ * self._data_set(EoDefault.PY_EO_NAME, self)
+ */
+ __pyx_v_o = eo_add(__pyx_v_kl, __pyx_f_6eorepo_9eodefault__eo_instance_get(__pyx_v_p));
+
+ /* "eorepo/eodefault.pyx":112
+ * cdef Eo_Class *kl = <Eo_Class*>_kl
+ * cdef Eo *o = eodefault.eo_add(kl, eodefault._eo_instance_get(p))
+ * self._eo_instance_set(o) # <<<<<<<<<<<<<<
+ * self._data_set(EoDefault.PY_EO_NAME, self)
+ *
+ */
+ ((struct __pyx_vtabstruct_6eorepo_9eodefault_EoDefault *)__pyx_v_self->__pyx_vtab)->_eo_instance_set(__pyx_v_self, __pyx_v_o);
+
+ /* "eorepo/eodefault.pyx":113
+ * cdef Eo *o = eodefault.eo_add(kl, eodefault._eo_instance_get(p))
+ * self._eo_instance_set(o)
+ * self._data_set(EoDefault.PY_EO_NAME, self) # <<<<<<<<<<<<<<
+ *
+ * # this func can be called outside(this c-styled module), because receives Eo* as long.
+ */
+ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s___data_set); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 113; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __pyx_t_2 = PyObject_GetAttr(((PyObject *)((PyObject*)__pyx_ptype_6eorepo_9eodefault_EoDefault)), __pyx_n_s__PY_EO_NAME); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 113; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_2);
+ __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 113; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_2);
+ __Pyx_GIVEREF(__pyx_t_2);
+ __Pyx_INCREF(((PyObject *)__pyx_v_self));
+ PyTuple_SET_ITEM(__pyx_t_3, 1, ((PyObject *)__pyx_v_self));
+ __Pyx_GIVEREF(((PyObject *)__pyx_v_self));
+ __pyx_t_2 = 0;
+ __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_t_3), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 113; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_2);
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0;
+ __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_XDECREF(__pyx_t_2);
+ __Pyx_XDECREF(__pyx_t_3);
+ __Pyx_AddTraceback("eorepo.eodefault.EoDefault._eo_instance_set2", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = 0;
+ __pyx_L0:;
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_19_eo_instance_set2(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds); /*proto*/
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_19_eo_instance_set2(PyObject *__pyx_v_self, PyObject *__pyx_args, PyObject *__pyx_kwds) {
+ unsigned PY_LONG_LONG __pyx_v__kl;
+ struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_p = 0;
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("_eo_instance_set2 (wrapper)", 0);
+ {
+ static PyObject **__pyx_pyargnames[] = {&__pyx_n_s___kl,&__pyx_n_s__p,0};
+ PyObject* values[2] = {0,0};
+ if (unlikely(__pyx_kwds)) {
+ Py_ssize_t kw_args;
+ const Py_ssize_t pos_args = PyTuple_GET_SIZE(__pyx_args);
+ switch (pos_args) {
+ case 2: values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ case 1: values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ case 0: break;
+ default: goto __pyx_L5_argtuple_error;
+ }
+ kw_args = PyDict_Size(__pyx_kwds);
+ switch (pos_args) {
+ case 0:
+ if (likely((values[0] = PyDict_GetItem(__pyx_kwds, __pyx_n_s___kl)) != 0)) kw_args--;
+ else goto __pyx_L5_argtuple_error;
+ case 1:
+ if (likely((values[1] = PyDict_GetItem(__pyx_kwds, __pyx_n_s__p)) != 0)) kw_args--;
+ else {
+ __Pyx_RaiseArgtupleInvalid("_eo_instance_set2", 1, 2, 2, 1); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 109; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ }
+ if (unlikely(kw_args > 0)) {
+ if (unlikely(__Pyx_ParseOptionalKeywords(__pyx_kwds, __pyx_pyargnames, 0, values, pos_args, "_eo_instance_set2") < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 109; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ } else if (PyTuple_GET_SIZE(__pyx_args) != 2) {
+ goto __pyx_L5_argtuple_error;
+ } else {
+ values[0] = PyTuple_GET_ITEM(__pyx_args, 0);
+ values[1] = PyTuple_GET_ITEM(__pyx_args, 1);
+ }
+ __pyx_v__kl = __Pyx_PyInt_AsUnsignedLongLong(values[0]); if (unlikely((__pyx_v__kl == (unsigned PY_LONG_LONG)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 109; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ __pyx_v_p = ((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)values[1]);
+ }
+ goto __pyx_L4_argument_unpacking_done;
+ __pyx_L5_argtuple_error:;
+ __Pyx_RaiseArgtupleInvalid("_eo_instance_set2", 1, 2, 2, PyTuple_GET_SIZE(__pyx_args)); {__pyx_filename = __pyx_f[0]; __pyx_lineno = 109; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ __pyx_L3_error:;
+ __Pyx_AddTraceback("eorepo.eodefault.EoDefault._eo_instance_set2", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __Pyx_RefNannyFinishContext();
+ return NULL;
+ __pyx_L4_argument_unpacking_done:;
+ if (unlikely(!__Pyx_ArgTypeTest(((PyObject *)__pyx_v_p), __pyx_ptype_6eorepo_9eodefault_EoDefault, 1, "p", 0))) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 109; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_r = __pyx_pf_6eorepo_9eodefault_9EoDefault_18_eo_instance_set2(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_v_self), __pyx_v__kl, __pyx_v_p);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "eorepo/eodefault.pyx":109
+ * # using default constructor
+ * # and connect C and Py objects
+ * cpdef _eo_instance_set2(self, unsigned long long _kl, EoDefault p): # <<<<<<<<<<<<<<
+ * cdef Eo_Class *kl = <Eo_Class*>_kl
+ * cdef Eo *o = eodefault.eo_add(kl, eodefault._eo_instance_get(p))
+ */
+
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_18_eo_instance_set2(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self, unsigned PY_LONG_LONG __pyx_v__kl, struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_p) {
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("_eo_instance_set2", 0);
+ __Pyx_XDECREF(__pyx_r);
+ __pyx_t_1 = ((struct __pyx_vtabstruct_6eorepo_9eodefault_EoDefault *)__pyx_v_self->__pyx_vtab)->_eo_instance_set2(__pyx_v_self, __pyx_v__kl, __pyx_v_p, 1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 109; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __pyx_r = __pyx_t_1;
+ __pyx_t_1 = 0;
+ goto __pyx_L0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_AddTraceback("eorepo.eodefault.EoDefault._eo_instance_set2", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* Python wrapper */
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_21_eo_instance_set3(PyObject *__pyx_v_self, PyObject *__pyx_arg__eo); /*proto*/
+static PyObject *__pyx_pw_6eorepo_9eodefault_9EoDefault_21_eo_instance_set3(PyObject *__pyx_v_self, PyObject *__pyx_arg__eo) {
+ unsigned PY_LONG_LONG __pyx_v__eo;
+ PyObject *__pyx_r = 0;
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("_eo_instance_set3 (wrapper)", 0);
+ assert(__pyx_arg__eo); {
+ __pyx_v__eo = __Pyx_PyInt_AsUnsignedLongLong(__pyx_arg__eo); if (unlikely((__pyx_v__eo == (unsigned PY_LONG_LONG)-1) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 118; __pyx_clineno = __LINE__; goto __pyx_L3_error;}
+ }
+ goto __pyx_L4_argument_unpacking_done;
+ __pyx_L3_error:;
+ __Pyx_AddTraceback("eorepo.eodefault.EoDefault._eo_instance_set3", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __Pyx_RefNannyFinishContext();
+ return NULL;
+ __pyx_L4_argument_unpacking_done:;
+ __pyx_r = __pyx_pf_6eorepo_9eodefault_9EoDefault_20_eo_instance_set3(((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)__pyx_v_self), ((unsigned PY_LONG_LONG)__pyx_v__eo));
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "eorepo/eodefault.pyx":118
+ * # it was added to be able to call eo_add_custom with different params
+ * # and connect C and Py objects after it
+ * def _eo_instance_set3(self, unsigned long long _eo): # <<<<<<<<<<<<<<
+ * cdef Eo *o = <Eo*>_eo
+ * self._eo_instance_set(o)
+ */
+
+static PyObject *__pyx_pf_6eorepo_9eodefault_9EoDefault_20_eo_instance_set3(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self, unsigned PY_LONG_LONG __pyx_v__eo) {
+ Eo *__pyx_v_o;
+ PyObject *__pyx_r = NULL;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ PyObject *__pyx_t_2 = NULL;
+ PyObject *__pyx_t_3 = NULL;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("_eo_instance_set3", 0);
+
+ /* "eorepo/eodefault.pyx":119
+ * # and connect C and Py objects after it
+ * def _eo_instance_set3(self, unsigned long long _eo):
+ * cdef Eo *o = <Eo*>_eo # <<<<<<<<<<<<<<
+ * self._eo_instance_set(o)
+ * self._data_set(EoDefault.PY_EO_NAME, self)
+ */
+ __pyx_v_o = ((Eo *)__pyx_v__eo);
+
+ /* "eorepo/eodefault.pyx":120
+ * def _eo_instance_set3(self, unsigned long long _eo):
+ * cdef Eo *o = <Eo*>_eo
+ * self._eo_instance_set(o) # <<<<<<<<<<<<<<
+ * self._data_set(EoDefault.PY_EO_NAME, self)
+ *
+ */
+ ((struct __pyx_vtabstruct_6eorepo_9eodefault_EoDefault *)__pyx_v_self->__pyx_vtab)->_eo_instance_set(__pyx_v_self, __pyx_v_o);
+
+ /* "eorepo/eodefault.pyx":121
+ * cdef Eo *o = <Eo*>_eo
+ * self._eo_instance_set(o)
+ * self._data_set(EoDefault.PY_EO_NAME, self) # <<<<<<<<<<<<<<
+ *
+ * cdef int print_func_name(self, f_name):
+ */
+ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s___data_set); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 121; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __pyx_t_2 = PyObject_GetAttr(((PyObject *)((PyObject*)__pyx_ptype_6eorepo_9eodefault_EoDefault)), __pyx_n_s__PY_EO_NAME); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 121; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_2);
+ __pyx_t_3 = PyTuple_New(2); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 121; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ PyTuple_SET_ITEM(__pyx_t_3, 0, __pyx_t_2);
+ __Pyx_GIVEREF(__pyx_t_2);
+ __Pyx_INCREF(((PyObject *)__pyx_v_self));
+ PyTuple_SET_ITEM(__pyx_t_3, 1, ((PyObject *)__pyx_v_self));
+ __Pyx_GIVEREF(((PyObject *)__pyx_v_self));
+ __pyx_t_2 = 0;
+ __pyx_t_2 = PyObject_Call(__pyx_t_1, ((PyObject *)__pyx_t_3), NULL); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 121; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_2);
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ __Pyx_DECREF(((PyObject *)__pyx_t_3)); __pyx_t_3 = 0;
+ __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+
+ __pyx_r = Py_None; __Pyx_INCREF(Py_None);
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_XDECREF(__pyx_t_2);
+ __Pyx_XDECREF(__pyx_t_3);
+ __Pyx_AddTraceback("eorepo.eodefault.EoDefault._eo_instance_set3", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = NULL;
+ __pyx_L0:;
+ __Pyx_XGIVEREF(__pyx_r);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "eorepo/eodefault.pyx":123
+ * self._data_set(EoDefault.PY_EO_NAME, self)
+ *
+ * cdef int print_func_name(self, f_name): # <<<<<<<<<<<<<<
+ * print self.__class__, " :: ", f_name, " :: ", sys.getsizeof(self)
+ *
+ */
+
+static int __pyx_f_6eorepo_9eodefault_9EoDefault_print_func_name(struct __pyx_obj_6eorepo_9eodefault_EoDefault *__pyx_v_self, PyObject *__pyx_v_f_name) {
+ int __pyx_r;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ PyObject *__pyx_t_2 = NULL;
+ PyObject *__pyx_t_3 = NULL;
+ PyObject *__pyx_t_4 = NULL;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("print_func_name", 0);
+
+ /* "eorepo/eodefault.pyx":124
+ *
+ * cdef int print_func_name(self, f_name):
+ * print self.__class__, " :: ", f_name, " :: ", sys.getsizeof(self) # <<<<<<<<<<<<<<
+ *
+ * #================================================================
+ */
+ __pyx_t_1 = PyObject_GetAttr(((PyObject *)__pyx_v_self), __pyx_n_s____class__); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 124; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __pyx_t_2 = __Pyx_GetName(__pyx_m, __pyx_n_s__sys); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 124; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_2);
+ __pyx_t_3 = PyObject_GetAttr(__pyx_t_2, __pyx_n_s__getsizeof); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 124; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __Pyx_DECREF(__pyx_t_2); __pyx_t_2 = 0;
+ __pyx_t_2 = PyTuple_New(1); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 124; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_2);
+ __Pyx_INCREF(((PyObject *)__pyx_v_self));
+ PyTuple_SET_ITEM(__pyx_t_2, 0, ((PyObject *)__pyx_v_self));
+ __Pyx_GIVEREF(((PyObject *)__pyx_v_self));
+ __pyx_t_4 = PyObject_Call(__pyx_t_3, ((PyObject *)__pyx_t_2), NULL); if (unlikely(!__pyx_t_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 124; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_4);
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+ __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0;
+ __pyx_t_2 = PyTuple_New(5); if (unlikely(!__pyx_t_2)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 124; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_2);
+ PyTuple_SET_ITEM(__pyx_t_2, 0, __pyx_t_1);
+ __Pyx_GIVEREF(__pyx_t_1);
+ __Pyx_INCREF(((PyObject *)__pyx_kp_s_6));
+ PyTuple_SET_ITEM(__pyx_t_2, 1, ((PyObject *)__pyx_kp_s_6));
+ __Pyx_GIVEREF(((PyObject *)__pyx_kp_s_6));
+ __Pyx_INCREF(__pyx_v_f_name);
+ PyTuple_SET_ITEM(__pyx_t_2, 2, __pyx_v_f_name);
+ __Pyx_GIVEREF(__pyx_v_f_name);
+ __Pyx_INCREF(((PyObject *)__pyx_kp_s_6));
+ PyTuple_SET_ITEM(__pyx_t_2, 3, ((PyObject *)__pyx_kp_s_6));
+ __Pyx_GIVEREF(((PyObject *)__pyx_kp_s_6));
+ PyTuple_SET_ITEM(__pyx_t_2, 4, __pyx_t_4);
+ __Pyx_GIVEREF(__pyx_t_4);
+ __pyx_t_1 = 0;
+ __pyx_t_4 = 0;
+ if (__Pyx_Print(0, ((PyObject *)__pyx_t_2), 1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 124; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(((PyObject *)__pyx_t_2)); __pyx_t_2 = 0;
+
+ __pyx_r = 0;
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_XDECREF(__pyx_t_2);
+ __Pyx_XDECREF(__pyx_t_3);
+ __Pyx_XDECREF(__pyx_t_4);
+ __Pyx_WriteUnraisable("eorepo.eodefault.EoDefault.print_func_name", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = 0;
+ __pyx_L0:;
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+
+/* "eorepo/eodefault.pyx":128
+ * #================================================================
+ *
+ * cdef Eina_Bool _object_callback(void *data, Eo *o, # <<<<<<<<<<<<<<
+ * Eo_Event_Description *desc, void *event_info):
+ * cdef EoDefault obj
+ */
+
+static Eina_Bool __pyx_f_6eorepo_9eodefault__object_callback(void *__pyx_v_data, Eo *__pyx_v_o, CYTHON_UNUSED Eo_Event_Description *__pyx_v_desc, CYTHON_UNUSED void *__pyx_v_event_info) {
+ void *__pyx_v_c_py_obj;
+ PyObject *__pyx_v_py_obj = NULL;
+ PyObject *__pyx_v_cb_struct = NULL;
+ PyObject *__pyx_v_f = NULL;
+ PyObject *__pyx_v_cb_data = NULL;
+ PyObject *__pyx_v_res = NULL;
+ Eina_Bool __pyx_r;
+ __Pyx_RefNannyDeclarations
+ PyObject *__pyx_t_1 = NULL;
+ const char* __pyx_t_2;
+ PyObject *__pyx_t_3 = NULL;
+ int __pyx_t_4;
+ int __pyx_lineno = 0;
+ const char *__pyx_filename = NULL;
+ int __pyx_clineno = 0;
+ __Pyx_RefNannySetupContext("_object_callback", 0);
+
+ /* "eorepo/eodefault.pyx":135
+ * #passing "this" object to callback function
+ * cdef void * c_py_obj
+ * eodefault.eo_do(o, eodefault.EO_BASE_BASE_ID+eodefault.EO_BASE_SUB_ID_DATA_GET, <const_char_ptr>EoDefault.PY_EO_NAME, &c_py_obj) # <<<<<<<<<<<<<<
+ * py_obj = <object>c_py_obj
+ *
+ */
+ __pyx_t_1 = PyObject_GetAttr(((PyObject *)((PyObject*)__pyx_ptype_6eorepo_9eodefault_EoDefault)), __pyx_n_s__PY_EO_NAME); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 135; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __pyx_t_2 = PyBytes_AsString(__pyx_t_1); if (unlikely((__pyx_t_2 == (const char*)NULL) && PyErr_Occurred())) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 135; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ eo_do(__pyx_v_o, (EO_BASE_BASE_ID + EO_BASE_SUB_ID_DATA_GET), ((const char*)__pyx_t_2), (&__pyx_v_c_py_obj));
+
+ /* "eorepo/eodefault.pyx":136
+ * cdef void * c_py_obj
+ * eodefault.eo_do(o, eodefault.EO_BASE_BASE_ID+eodefault.EO_BASE_SUB_ID_DATA_GET, <const_char_ptr>EoDefault.PY_EO_NAME, &c_py_obj)
+ * py_obj = <object>c_py_obj # <<<<<<<<<<<<<<
+ *
+ * #cb_struct is tuple: (func, data)
+ */
+ __Pyx_INCREF(((PyObject *)__pyx_v_c_py_obj));
+ __pyx_v_py_obj = ((PyObject *)__pyx_v_c_py_obj);
+
+ /* "eorepo/eodefault.pyx":139
+ *
+ * #cb_struct is tuple: (func, data)
+ * cb_struct = <object>data # <<<<<<<<<<<<<<
+ * f = cb_struct[0]
+ * cb_data = cb_struct[1]
+ */
+ __Pyx_INCREF(((PyObject *)__pyx_v_data));
+ __pyx_v_cb_struct = ((PyObject *)__pyx_v_data);
+
+ /* "eorepo/eodefault.pyx":140
+ * #cb_struct is tuple: (func, data)
+ * cb_struct = <object>data
+ * f = cb_struct[0] # <<<<<<<<<<<<<<
+ * cb_data = cb_struct[1]
+ * res = f(py_obj, cb_data)
+ */
+ __pyx_t_1 = __Pyx_GetItemInt(__pyx_v_cb_struct, 0, sizeof(long), PyInt_FromLong); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 140; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __pyx_v_f = __pyx_t_1;
+ __pyx_t_1 = 0;
+
+ /* "eorepo/eodefault.pyx":141
+ * cb_struct = <object>data
+ * f = cb_struct[0]
+ * cb_data = cb_struct[1] # <<<<<<<<<<<<<<
+ * res = f(py_obj, cb_data)
+ *
+ */
+ __pyx_t_1 = __Pyx_GetItemInt(__pyx_v_cb_struct, 1, sizeof(long), PyInt_FromLong); if (!__pyx_t_1) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 141; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __pyx_v_cb_data = __pyx_t_1;
+ __pyx_t_1 = 0;
+
+ /* "eorepo/eodefault.pyx":142
+ * f = cb_struct[0]
+ * cb_data = cb_struct[1]
+ * res = f(py_obj, cb_data) # <<<<<<<<<<<<<<
+ *
+ * if res == CALLBACK_STOP:
+ */
+ __pyx_t_1 = PyTuple_New(2); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 142; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ __Pyx_INCREF(__pyx_v_py_obj);
+ PyTuple_SET_ITEM(__pyx_t_1, 0, __pyx_v_py_obj);
+ __Pyx_GIVEREF(__pyx_v_py_obj);
+ __Pyx_INCREF(__pyx_v_cb_data);
+ PyTuple_SET_ITEM(__pyx_t_1, 1, __pyx_v_cb_data);
+ __Pyx_GIVEREF(__pyx_v_cb_data);
+ __pyx_t_3 = PyObject_Call(__pyx_v_f, ((PyObject *)__pyx_t_1), NULL); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 142; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
+ __pyx_v_res = __pyx_t_3;
+ __pyx_t_3 = 0;
+
+ /* "eorepo/eodefault.pyx":144
+ * res = f(py_obj, cb_data)
+ *
+ * if res == CALLBACK_STOP: # <<<<<<<<<<<<<<
+ * return EINA_FALSE
+ * else:
+ */
+ __pyx_t_3 = __Pyx_GetName(__pyx_m, __pyx_n_s__CALLBACK_STOP); if (unlikely(!__pyx_t_3)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 144; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_3);
+ __pyx_t_1 = PyObject_RichCompare(__pyx_v_res, __pyx_t_3, Py_EQ); __Pyx_XGOTREF(__pyx_t_1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 144; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_3); __pyx_t_3 = 0;
+ __pyx_t_4 = __Pyx_PyObject_IsTrue(__pyx_t_1); if (unlikely(__pyx_t_4 < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 144; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ if (__pyx_t_4) {
+
+ /* "eorepo/eodefault.pyx":145
+ *
+ * if res == CALLBACK_STOP:
+ * return EINA_FALSE # <<<<<<<<<<<<<<
+ * else:
+ * return EINA_TRUE
+ */
+ __pyx_r = EINA_FALSE;
+ goto __pyx_L0;
+ goto __pyx_L3;
+ }
+ /*else*/ {
+
+ /* "eorepo/eodefault.pyx":147
+ * return EINA_FALSE
+ * else:
+ * return EINA_TRUE # <<<<<<<<<<<<<<
+ *
+ *
+ */
+ __pyx_r = EINA_TRUE;
+ goto __pyx_L0;
+ }
+ __pyx_L3:;
+
+ __pyx_r = 0;
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ __Pyx_XDECREF(__pyx_t_3);
+ __Pyx_WriteUnraisable("eorepo.eodefault._object_callback", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ __pyx_r = 0;
+ __pyx_L0:;
+ __Pyx_XDECREF(__pyx_v_py_obj);
+ __Pyx_XDECREF(__pyx_v_cb_struct);
+ __Pyx_XDECREF(__pyx_v_f);
+ __Pyx_XDECREF(__pyx_v_cb_data);
+ __Pyx_XDECREF(__pyx_v_res);
+ __Pyx_RefNannyFinishContext();
+ return __pyx_r;
+}
+static struct __pyx_vtabstruct_6eorepo_9eodefault_EoDefault __pyx_vtable_6eorepo_9eodefault_EoDefault;
+
+static PyObject *__pyx_tp_new_6eorepo_9eodefault_EoDefault(PyTypeObject *t, CYTHON_UNUSED PyObject *a, CYTHON_UNUSED PyObject *k) {
+ struct __pyx_obj_6eorepo_9eodefault_EoDefault *p;
+ PyObject *o = (*t->tp_alloc)(t, 0);
+ if (!o) return 0;
+ p = ((struct __pyx_obj_6eorepo_9eodefault_EoDefault *)o);
+ p->__pyx_vtab = __pyx_vtabptr_6eorepo_9eodefault_EoDefault;
+ p->name = Py_None; Py_INCREF(Py_None);
+ if (__pyx_pw_6eorepo_9eodefault_9EoDefault_1__cinit__(o, __pyx_empty_tuple, NULL) < 0) {
+ Py_DECREF(o); o = 0;
+ }
+ return o;
+}
+
+static void __pyx_tp_dealloc_6eorepo_9eodefault_EoDefault(PyObject *o) {
+ struct __pyx_obj_6eorepo_9eodefault_EoDefault *p = (struct __pyx_obj_6eorepo_9eodefault_EoDefault *)o;
+ {
+ PyObject *etype, *eval, *etb;
+ PyErr_Fetch(&etype, &eval, &etb);
+ ++Py_REFCNT(o);
+ __pyx_pw_6eorepo_9eodefault_9EoDefault_3__dealloc__(o);
+ if (PyErr_Occurred()) PyErr_WriteUnraisable(o);
+ --Py_REFCNT(o);
+ PyErr_Restore(etype, eval, etb);
+ }
+ Py_CLEAR(p->name);
+ (*Py_TYPE(o)->tp_free)(o);
+}
+
+static int __pyx_tp_traverse_6eorepo_9eodefault_EoDefault(PyObject *o, visitproc v, void *a) {
+ int e;
+ struct __pyx_obj_6eorepo_9eodefault_EoDefault *p = (struct __pyx_obj_6eorepo_9eodefault_EoDefault *)o;
+ if (p->name) {
+ e = (*v)(p->name, a); if (e) return e;
+ }
+ return 0;
+}
+
+static int __pyx_tp_clear_6eorepo_9eodefault_EoDefault(PyObject *o) {
+ struct __pyx_obj_6eorepo_9eodefault_EoDefault *p = (struct __pyx_obj_6eorepo_9eodefault_EoDefault *)o;
+ PyObject* tmp;
+ tmp = ((PyObject*)p->name);
+ p->name = Py_None; Py_INCREF(Py_None);
+ Py_XDECREF(tmp);
+ return 0;
+}
+
+static PyMethodDef __pyx_methods_6eorepo_9eodefault_EoDefault[] = {
+ {__Pyx_NAMESTR("delete"), (PyCFunction)__pyx_pw_6eorepo_9eodefault_9EoDefault_5delete, METH_NOARGS, __Pyx_DOCSTR(0)},
+ {__Pyx_NAMESTR("ref"), (PyCFunction)__pyx_pw_6eorepo_9eodefault_9EoDefault_7ref, METH_NOARGS, __Pyx_DOCSTR(0)},
+ {__Pyx_NAMESTR("unref"), (PyCFunction)__pyx_pw_6eorepo_9eodefault_9EoDefault_9unref, METH_NOARGS, __Pyx_DOCSTR(0)},
+ {__Pyx_NAMESTR("ref_get"), (PyCFunction)__pyx_pw_6eorepo_9eodefault_9EoDefault_11ref_get, METH_NOARGS, __Pyx_DOCSTR(0)},
+ {__Pyx_NAMESTR("parent_get"), (PyCFunction)__pyx_pw_6eorepo_9eodefault_9EoDefault_13parent_get, METH_NOARGS, __Pyx_DOCSTR(0)},
+ {__Pyx_NAMESTR("class_name_get"), (PyCFunction)__pyx_pw_6eorepo_9eodefault_9EoDefault_15class_name_get, METH_NOARGS, __Pyx_DOCSTR(0)},
+ {__Pyx_NAMESTR("name_get"), (PyCFunction)__pyx_pw_6eorepo_9eodefault_9EoDefault_17name_get, METH_NOARGS, __Pyx_DOCSTR(0)},
+ {__Pyx_NAMESTR("_eo_instance_set2"), (PyCFunction)__pyx_pw_6eorepo_9eodefault_9EoDefault_19_eo_instance_set2, METH_VARARGS|METH_KEYWORDS, __Pyx_DOCSTR(0)},
+ {__Pyx_NAMESTR("_eo_instance_set3"), (PyCFunction)__pyx_pw_6eorepo_9eodefault_9EoDefault_21_eo_instance_set3, METH_O, __Pyx_DOCSTR(0)},
+ {0, 0, 0, 0}
+};
+
+static PyNumberMethods __pyx_tp_as_number_EoDefault = {
+ 0, /*nb_add*/
+ 0, /*nb_subtract*/
+ 0, /*nb_multiply*/
+ #if PY_MAJOR_VERSION < 3
+ 0, /*nb_divide*/
+ #endif
+ 0, /*nb_remainder*/
+ 0, /*nb_divmod*/
+ 0, /*nb_power*/
+ 0, /*nb_negative*/
+ 0, /*nb_positive*/
+ 0, /*nb_absolute*/
+ 0, /*nb_nonzero*/
+ 0, /*nb_invert*/
+ 0, /*nb_lshift*/
+ 0, /*nb_rshift*/
+ 0, /*nb_and*/
+ 0, /*nb_xor*/
+ 0, /*nb_or*/
+ #if PY_MAJOR_VERSION < 3
+ 0, /*nb_coerce*/
+ #endif
+ 0, /*nb_int*/
+ #if PY_MAJOR_VERSION < 3
+ 0, /*nb_long*/
+ #else
+ 0, /*reserved*/
+ #endif
+ 0, /*nb_float*/
+ #if PY_MAJOR_VERSION < 3
+ 0, /*nb_oct*/
+ #endif
+ #if PY_MAJOR_VERSION < 3
+ 0, /*nb_hex*/
+ #endif
+ 0, /*nb_inplace_add*/
+ 0, /*nb_inplace_subtract*/
+ 0, /*nb_inplace_multiply*/
+ #if PY_MAJOR_VERSION < 3
+ 0, /*nb_inplace_divide*/
+ #endif
+ 0, /*nb_inplace_remainder*/
+ 0, /*nb_inplace_power*/
+ 0, /*nb_inplace_lshift*/
+ 0, /*nb_inplace_rshift*/
+ 0, /*nb_inplace_and*/
+ 0, /*nb_inplace_xor*/
+ 0, /*nb_inplace_or*/
+ 0, /*nb_floor_divide*/
+ 0, /*nb_true_divide*/
+ 0, /*nb_inplace_floor_divide*/
+ 0, /*nb_inplace_true_divide*/
+ #if PY_VERSION_HEX >= 0x02050000
+ 0, /*nb_index*/
+ #endif
+};
+
+static PySequenceMethods __pyx_tp_as_sequence_EoDefault = {
+ 0, /*sq_length*/
+ 0, /*sq_concat*/
+ 0, /*sq_repeat*/
+ 0, /*sq_item*/
+ 0, /*sq_slice*/
+ 0, /*sq_ass_item*/
+ 0, /*sq_ass_slice*/
+ 0, /*sq_contains*/
+ 0, /*sq_inplace_concat*/
+ 0, /*sq_inplace_repeat*/
+};
+
+static PyMappingMethods __pyx_tp_as_mapping_EoDefault = {
+ 0, /*mp_length*/
+ 0, /*mp_subscript*/
+ 0, /*mp_ass_subscript*/
+};
+
+static PyBufferProcs __pyx_tp_as_buffer_EoDefault = {
+ #if PY_MAJOR_VERSION < 3
+ 0, /*bf_getreadbuffer*/
+ #endif
+ #if PY_MAJOR_VERSION < 3
+ 0, /*bf_getwritebuffer*/
+ #endif
+ #if PY_MAJOR_VERSION < 3
+ 0, /*bf_getsegcount*/
+ #endif
+ #if PY_MAJOR_VERSION < 3
+ 0, /*bf_getcharbuffer*/
+ #endif
+ #if PY_VERSION_HEX >= 0x02060000
+ 0, /*bf_getbuffer*/
+ #endif
+ #if PY_VERSION_HEX >= 0x02060000
+ 0, /*bf_releasebuffer*/
+ #endif
+};
+
+static PyTypeObject __pyx_type_6eorepo_9eodefault_EoDefault = {
+ PyVarObject_HEAD_INIT(0, 0)
+ __Pyx_NAMESTR("eorepo.eodefault.EoDefault"), /*tp_name*/
+ sizeof(struct __pyx_obj_6eorepo_9eodefault_EoDefault), /*tp_basicsize*/
+ 0, /*tp_itemsize*/
+ __pyx_tp_dealloc_6eorepo_9eodefault_EoDefault, /*tp_dealloc*/
+ 0, /*tp_print*/
+ 0, /*tp_getattr*/
+ 0, /*tp_setattr*/
+ #if PY_MAJOR_VERSION < 3
+ 0, /*tp_compare*/
+ #else
+ 0, /*reserved*/
+ #endif
+ 0, /*tp_repr*/
+ &__pyx_tp_as_number_EoDefault, /*tp_as_number*/
+ &__pyx_tp_as_sequence_EoDefault, /*tp_as_sequence*/
+ &__pyx_tp_as_mapping_EoDefault, /*tp_as_mapping*/
+ 0, /*tp_hash*/
+ 0, /*tp_call*/
+ 0, /*tp_str*/
+ 0, /*tp_getattro*/
+ 0, /*tp_setattro*/
+ &__pyx_tp_as_buffer_EoDefault, /*tp_as_buffer*/
+ Py_TPFLAGS_DEFAULT|Py_TPFLAGS_CHECKTYPES|Py_TPFLAGS_HAVE_NEWBUFFER|Py_TPFLAGS_BASETYPE|Py_TPFLAGS_HAVE_GC, /*tp_flags*/
+ 0, /*tp_doc*/
+ __pyx_tp_traverse_6eorepo_9eodefault_EoDefault, /*tp_traverse*/
+ __pyx_tp_clear_6eorepo_9eodefault_EoDefault, /*tp_clear*/
+ 0, /*tp_richcompare*/
+ 0, /*tp_weaklistoffset*/
+ 0, /*tp_iter*/
+ 0, /*tp_iternext*/
+ __pyx_methods_6eorepo_9eodefault_EoDefault, /*tp_methods*/
+ 0, /*tp_members*/
+ 0, /*tp_getset*/
+ 0, /*tp_base*/
+ 0, /*tp_dict*/
+ 0, /*tp_descr_get*/
+ 0, /*tp_descr_set*/
+ 0, /*tp_dictoffset*/
+ 0, /*tp_init*/
+ 0, /*tp_alloc*/
+ __pyx_tp_new_6eorepo_9eodefault_EoDefault, /*tp_new*/
+ 0, /*tp_free*/
+ 0, /*tp_is_gc*/
+ 0, /*tp_bases*/
+ 0, /*tp_mro*/
+ 0, /*tp_cache*/
+ 0, /*tp_subclasses*/
+ 0, /*tp_weaklist*/
+ 0, /*tp_del*/
+ #if PY_VERSION_HEX >= 0x02060000
+ 0, /*tp_version_tag*/
+ #endif
+};
+
+static PyMethodDef __pyx_methods[] = {
+ {0, 0, 0, 0}
+};
+
+#if PY_MAJOR_VERSION >= 3
+static struct PyModuleDef __pyx_moduledef = {
+ PyModuleDef_HEAD_INIT,
+ __Pyx_NAMESTR("eodefault"),
+ 0, /* m_doc */
+ -1, /* m_size */
+ __pyx_methods /* m_methods */,
+ NULL, /* m_reload */
+ NULL, /* m_traverse */
+ NULL, /* m_clear */
+ NULL /* m_free */
+};
+#endif
+
+static __Pyx_StringTabEntry __pyx_string_tab[] = {
+ {&__pyx_kp_s_1, __pyx_k_1, sizeof(__pyx_k_1), 0, 0, 1, 0},
+ {&__pyx_kp_s_12, __pyx_k_12, sizeof(__pyx_k_12), 0, 0, 1, 0},
+ {&__pyx_kp_s_2, __pyx_k_2, sizeof(__pyx_k_2), 0, 0, 1, 0},
+ {&__pyx_kp_s_3, __pyx_k_3, sizeof(__pyx_k_3), 0, 0, 1, 0},
+ {&__pyx_kp_s_5, __pyx_k_5, sizeof(__pyx_k_5), 0, 0, 1, 0},
+ {&__pyx_kp_s_6, __pyx_k_6, sizeof(__pyx_k_6), 0, 0, 1, 0},
+ {&__pyx_kp_s_8, __pyx_k_8, sizeof(__pyx_k_8), 0, 0, 1, 0},
+ {&__pyx_n_s_9, __pyx_k_9, sizeof(__pyx_k_9), 0, 0, 1, 1},
+ {&__pyx_n_s__CALLBACK_STOP, __pyx_k__CALLBACK_STOP, sizeof(__pyx_k__CALLBACK_STOP), 0, 0, 1, 1},
+ {&__pyx_n_s__PRIORITY_AFTER, __pyx_k__PRIORITY_AFTER, sizeof(__pyx_k__PRIORITY_AFTER), 0, 0, 1, 1},
+ {&__pyx_n_s__PRIORITY_BEFORE, __pyx_k__PRIORITY_BEFORE, sizeof(__pyx_k__PRIORITY_BEFORE), 0, 0, 1, 1},
+ {&__pyx_n_s__PRIORITY_DEFAULT, __pyx_k__PRIORITY_DEFAULT, sizeof(__pyx_k__PRIORITY_DEFAULT), 0, 0, 1, 1},
+ {&__pyx_n_s__PY_EO_NAME, __pyx_k__PY_EO_NAME, sizeof(__pyx_k__PY_EO_NAME), 0, 0, 1, 1},
+ {&__pyx_n_s__TypeError, __pyx_k__TypeError, sizeof(__pyx_k__TypeError), 0, 0, 1, 1},
+ {&__pyx_n_s____class__, __pyx_k____class__, sizeof(__pyx_k____class__), 0, 0, 1, 1},
+ {&__pyx_n_s____main__, __pyx_k____main__, sizeof(__pyx_k____main__), 0, 0, 1, 1},
+ {&__pyx_n_s____name__, __pyx_k____name__, sizeof(__pyx_k____name__), 0, 0, 1, 1},
+ {&__pyx_n_s____test__, __pyx_k____test__, sizeof(__pyx_k____test__), 0, 0, 1, 1},
+ {&__pyx_n_s___data_set, __pyx_k___data_set, sizeof(__pyx_k___data_set), 0, 0, 1, 1},
+ {&__pyx_n_s___eo_instance_set2, __pyx_k___eo_instance_set2, sizeof(__pyx_k___eo_instance_set2), 0, 0, 1, 1},
+ {&__pyx_n_s___kl, __pyx_k___kl, sizeof(__pyx_k___kl), 0, 0, 1, 1},
+ {&__pyx_n_s__basestring, __pyx_k__basestring, sizeof(__pyx_k__basestring), 0, 0, 1, 1},
+ {&__pyx_n_s__encode, __pyx_k__encode, sizeof(__pyx_k__encode), 0, 0, 1, 1},
+ {&__pyx_n_s__getsizeof, __pyx_k__getsizeof, sizeof(__pyx_k__getsizeof), 0, 0, 1, 1},
+ {&__pyx_n_s__init, __pyx_k__init, sizeof(__pyx_k__init), 0, 0, 1, 1},
+ {&__pyx_n_s__operator, __pyx_k__operator, sizeof(__pyx_k__operator), 0, 0, 1, 1},
+ {&__pyx_n_s__p, __pyx_k__p, sizeof(__pyx_k__p), 0, 0, 1, 1},
+ {&__pyx_n_s__pytext_to_utf8, __pyx_k__pytext_to_utf8, sizeof(__pyx_k__pytext_to_utf8), 0, 0, 1, 1},
+ {&__pyx_n_s__ref, __pyx_k__ref, sizeof(__pyx_k__ref), 0, 0, 1, 1},
+ {&__pyx_n_s__sys, __pyx_k__sys, sizeof(__pyx_k__sys), 0, 0, 1, 1},
+ {&__pyx_n_s__text, __pyx_k__text, sizeof(__pyx_k__text), 0, 0, 1, 1},
+ {&__pyx_n_s__utf8_data, __pyx_k__utf8_data, sizeof(__pyx_k__utf8_data), 0, 0, 1, 1},
+ {0, 0, 0, 0, 0, 0, 0}
+};
+static int __Pyx_InitCachedBuiltins(void) {
+ __pyx_builtin_basestring = __Pyx_GetName(__pyx_b, __pyx_n_s__basestring); if (!__pyx_builtin_basestring) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 35; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_builtin_TypeError = __Pyx_GetName(__pyx_b, __pyx_n_s__TypeError); if (!__pyx_builtin_TypeError) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 36; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ return 0;
+ __pyx_L1_error:;
+ return -1;
+}
+
+static int __Pyx_InitCachedConstants(void) {
+ __Pyx_RefNannyDeclarations
+ __Pyx_RefNannySetupContext("__Pyx_InitCachedConstants", 0);
+
+ /* "eorepo/eodefault.pyx":40
+ *
+ * if isinstance(text, unicode):
+ * utf8_data = text.encode('UTF-8') # <<<<<<<<<<<<<<
+ * elif isinstance(text, str):
+ * utf8_data = text
+ */
+ __pyx_k_tuple_4 = PyTuple_New(1); if (unlikely(!__pyx_k_tuple_4)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 40; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_k_tuple_4);
+ __Pyx_INCREF(((PyObject *)__pyx_kp_s_3));
+ PyTuple_SET_ITEM(__pyx_k_tuple_4, 0, ((PyObject *)__pyx_kp_s_3));
+ __Pyx_GIVEREF(((PyObject *)__pyx_kp_s_3));
+ __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_4));
+
+ /* "eorepo/eodefault.pyx":18
+ *
+ *
+ * def init(): # <<<<<<<<<<<<<<
+ * return bool(eodefault.eo_init())
+ *
+ */
+ __pyx_k_codeobj_7 = (PyObject*)__Pyx_PyCode_New(0, 0, 0, 0, 0, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_8, __pyx_n_s__init, 18, __pyx_empty_bytes); if (unlikely(!__pyx_k_codeobj_7)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 18; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+
+ /* "eorepo/eodefault.pyx":33
+ * NULL
+ *
+ * def pytext_to_utf8(text): # <<<<<<<<<<<<<<
+ *
+ * if not isinstance(text, basestring):
+ */
+ __pyx_k_tuple_10 = PyTuple_New(2); if (unlikely(!__pyx_k_tuple_10)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 33; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_k_tuple_10);
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__text));
+ PyTuple_SET_ITEM(__pyx_k_tuple_10, 0, ((PyObject *)__pyx_n_s__text));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__text));
+ __Pyx_INCREF(((PyObject *)__pyx_n_s__utf8_data));
+ PyTuple_SET_ITEM(__pyx_k_tuple_10, 1, ((PyObject *)__pyx_n_s__utf8_data));
+ __Pyx_GIVEREF(((PyObject *)__pyx_n_s__utf8_data));
+ __Pyx_GIVEREF(((PyObject *)__pyx_k_tuple_10));
+ __pyx_k_codeobj_11 = (PyObject*)__Pyx_PyCode_New(1, 0, 2, 0, 0, __pyx_empty_bytes, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_k_tuple_10, __pyx_empty_tuple, __pyx_empty_tuple, __pyx_kp_s_8, __pyx_n_s__pytext_to_utf8, 33, __pyx_empty_bytes); if (unlikely(!__pyx_k_codeobj_11)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 33; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_RefNannyFinishContext();
+ return 0;
+ __pyx_L1_error:;
+ __Pyx_RefNannyFinishContext();
+ return -1;
+}
+
+static int __Pyx_InitGlobals(void) {
+ if (__Pyx_InitStrings(__pyx_string_tab) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;};
+ __pyx_int_12345 = PyInt_FromLong(12345); if (unlikely(!__pyx_int_12345)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;};
+ return 0;
+ __pyx_L1_error:;
+ return -1;
+}
+
+#if PY_MAJOR_VERSION < 3
+PyMODINIT_FUNC initeodefault(void); /*proto*/
+PyMODINIT_FUNC initeodefault(void)
+#else
+PyMODINIT_FUNC PyInit_eodefault(void); /*proto*/
+PyMODINIT_FUNC PyInit_eodefault(void)
+#endif
+{
+ PyObject *__pyx_t_1 = NULL;
+ __Pyx_RefNannyDeclarations
+ #if CYTHON_REFNANNY
+ __Pyx_RefNanny = __Pyx_RefNannyImportAPI("refnanny");
+ if (!__Pyx_RefNanny) {
+ PyErr_Clear();
+ __Pyx_RefNanny = __Pyx_RefNannyImportAPI("Cython.Runtime.refnanny");
+ if (!__Pyx_RefNanny)
+ Py_FatalError("failed to import 'refnanny' module");
+ }
+ #endif
+ __Pyx_RefNannySetupContext("PyMODINIT_FUNC PyInit_eodefault(void)", 0);
+ if ( __Pyx_check_binary_version() < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_empty_tuple = PyTuple_New(0); if (unlikely(!__pyx_empty_tuple)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_empty_bytes = PyBytes_FromStringAndSize("", 0); if (unlikely(!__pyx_empty_bytes)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ #ifdef __Pyx_CyFunction_USED
+ if (__Pyx_CyFunction_init() < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ #endif
+ #ifdef __Pyx_FusedFunction_USED
+ if (__pyx_FusedFunction_init() < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ #endif
+ #ifdef __Pyx_Generator_USED
+ if (__pyx_Generator_init() < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ #endif
+ /*--- Library function declarations ---*/
+ /*--- Threads initialization code ---*/
+ #if defined(__PYX_FORCE_INIT_THREADS) && __PYX_FORCE_INIT_THREADS
+ #ifdef WITH_THREAD /* Python build with threading support? */
+ PyEval_InitThreads();
+ #endif
+ #endif
+ /*--- Module creation code ---*/
+ #if PY_MAJOR_VERSION < 3
+ __pyx_m = Py_InitModule4(__Pyx_NAMESTR("eodefault"), __pyx_methods, 0, 0, PYTHON_API_VERSION); Py_XINCREF(__pyx_m);
+ #else
+ __pyx_m = PyModule_Create(&__pyx_moduledef);
+ #endif
+ if (unlikely(!__pyx_m)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ #if PY_MAJOR_VERSION >= 3
+ {
+ PyObject *modules = PyImport_GetModuleDict(); if (unlikely(!modules)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ if (!PyDict_GetItemString(modules, "eorepo.eodefault")) {
+ if (unlikely(PyDict_SetItemString(modules, "eorepo.eodefault", __pyx_m) < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ }
+ }
+ #endif
+ __pyx_b = PyImport_AddModule(__Pyx_NAMESTR(__Pyx_BUILTIN_MODULE_NAME)); if (unlikely(!__pyx_b)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ #if CYTHON_COMPILING_IN_PYPY
+ Py_INCREF(__pyx_b);
+ #endif
+ if (__Pyx_SetAttrString(__pyx_m, "__builtins__", __pyx_b) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;};
+ /*--- Initialize various global constants etc. ---*/
+ if (unlikely(__Pyx_InitGlobals() < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ if (__pyx_module_is_main_eorepo__eodefault) {
+ if (__Pyx_SetAttrString(__pyx_m, "__name__", __pyx_n_s____main__) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;};
+ }
+ /*--- Builtin init code ---*/
+ if (unlikely(__Pyx_InitCachedBuiltins() < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ /*--- Constants init code ---*/
+ if (unlikely(__Pyx_InitCachedConstants() < 0)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ /*--- Global init code ---*/
+ /*--- Variable export code ---*/
+ /*--- Function export code ---*/
+ if (__Pyx_ExportFunction("_eo_instance_get", (void (*)(void))__pyx_f_6eorepo_9eodefault__eo_instance_get, "Eo *(struct __pyx_obj_6eorepo_9eodefault_EoDefault *)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ if (__Pyx_ExportFunction("_object_callback", (void (*)(void))__pyx_f_6eorepo_9eodefault__object_callback, "Eina_Bool (void *, Eo *, Eo_Event_Description *, void *)") < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ /*--- Type init code ---*/
+ __pyx_vtabptr_6eorepo_9eodefault_EoDefault = &__pyx_vtable_6eorepo_9eodefault_EoDefault;
+ __pyx_vtable_6eorepo_9eodefault_EoDefault.print_func_name = (int (*)(struct __pyx_obj_6eorepo_9eodefault_EoDefault *, PyObject *))__pyx_f_6eorepo_9eodefault_9EoDefault_print_func_name;
+ __pyx_vtable_6eorepo_9eodefault_EoDefault._eo_instance_set = (int (*)(struct __pyx_obj_6eorepo_9eodefault_EoDefault *, Eo *))__pyx_f_6eorepo_9eodefault_9EoDefault__eo_instance_set;
+ __pyx_vtable_6eorepo_9eodefault_EoDefault._eo_instance_set2 = (PyObject *(*)(struct __pyx_obj_6eorepo_9eodefault_EoDefault *, unsigned PY_LONG_LONG, struct __pyx_obj_6eorepo_9eodefault_EoDefault *, int __pyx_skip_dispatch))__pyx_f_6eorepo_9eodefault_9EoDefault__eo_instance_set2;
+ if (PyType_Ready(&__pyx_type_6eorepo_9eodefault_EoDefault) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 48; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ if (__Pyx_SetVtable(__pyx_type_6eorepo_9eodefault_EoDefault.tp_dict, __pyx_vtabptr_6eorepo_9eodefault_EoDefault) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 48; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ if (__Pyx_SetAttrString(__pyx_m, "EoDefault", (PyObject *)&__pyx_type_6eorepo_9eodefault_EoDefault) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 48; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __pyx_ptype_6eorepo_9eodefault_EoDefault = &__pyx_type_6eorepo_9eodefault_EoDefault;
+ /*--- Type import code ---*/
+ /*--- Variable import code ---*/
+ /*--- Function import code ---*/
+ /*--- Execution code ---*/
+
+ /* "eorepo/eodefault.pyx":2
+ * cimport eodefault
+ * import sys, operator # <<<<<<<<<<<<<<
+ *
+ *
+ */
+ __pyx_t_1 = __Pyx_Import(((PyObject *)__pyx_n_s__sys), 0, -1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 2; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ if (PyObject_SetAttr(__pyx_m, __pyx_n_s__sys, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 2; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+ __pyx_t_1 = __Pyx_Import(((PyObject *)__pyx_n_s__operator), 0, -1); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 2; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ if (PyObject_SetAttr(__pyx_m, __pyx_n_s__operator, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 2; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ /* "eorepo/eodefault.pyx":10
+ * ##
+ *
+ * PRIORITY_BEFORE = eodefault.EO_CALLBACK_PRIORITY_BEFORE # <<<<<<<<<<<<<<
+ * PRIORITY_DEFAULT = eodefault.EO_CALLBACK_PRIORITY_DEFAULT
+ * PRIORITY_AFTER = eodefault.EO_CALLBACK_PRIORITY_AFTER
+ */
+ __pyx_t_1 = PyInt_FromLong(EO_CALLBACK_PRIORITY_BEFORE); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 10; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ if (PyObject_SetAttr(__pyx_m, __pyx_n_s__PRIORITY_BEFORE, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 10; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ /* "eorepo/eodefault.pyx":11
+ *
+ * PRIORITY_BEFORE = eodefault.EO_CALLBACK_PRIORITY_BEFORE
+ * PRIORITY_DEFAULT = eodefault.EO_CALLBACK_PRIORITY_DEFAULT # <<<<<<<<<<<<<<
+ * PRIORITY_AFTER = eodefault.EO_CALLBACK_PRIORITY_AFTER
+ * CALLBACK_STOP = 12345
+ */
+ __pyx_t_1 = PyInt_FromLong(EO_CALLBACK_PRIORITY_DEFAULT); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 11; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ if (PyObject_SetAttr(__pyx_m, __pyx_n_s__PRIORITY_DEFAULT, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 11; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ /* "eorepo/eodefault.pyx":12
+ * PRIORITY_BEFORE = eodefault.EO_CALLBACK_PRIORITY_BEFORE
+ * PRIORITY_DEFAULT = eodefault.EO_CALLBACK_PRIORITY_DEFAULT
+ * PRIORITY_AFTER = eodefault.EO_CALLBACK_PRIORITY_AFTER # <<<<<<<<<<<<<<
+ * CALLBACK_STOP = 12345
+ *
+ */
+ __pyx_t_1 = PyInt_FromLong(EO_CALLBACK_PRIORITY_AFTER); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 12; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ if (PyObject_SetAttr(__pyx_m, __pyx_n_s__PRIORITY_AFTER, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 12; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ /* "eorepo/eodefault.pyx":13
+ * PRIORITY_DEFAULT = eodefault.EO_CALLBACK_PRIORITY_DEFAULT
+ * PRIORITY_AFTER = eodefault.EO_CALLBACK_PRIORITY_AFTER
+ * CALLBACK_STOP = 12345 # <<<<<<<<<<<<<<
+ *
+ * #cdef const_char_ptr py_eo = <const_char_ptr>"python-ej"
+ */
+ if (PyObject_SetAttr(__pyx_m, __pyx_n_s__CALLBACK_STOP, __pyx_int_12345) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 13; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+
+ /* "eorepo/eodefault.pyx":18
+ *
+ *
+ * def init(): # <<<<<<<<<<<<<<
+ * return bool(eodefault.eo_init())
+ *
+ */
+ __pyx_t_1 = PyCFunction_NewEx(&__pyx_mdef_6eorepo_9eodefault_1init, NULL, __pyx_n_s_9); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 18; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ if (PyObject_SetAttr(__pyx_m, __pyx_n_s__init, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 18; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ /* "eorepo/eodefault.pyx":33
+ * NULL
+ *
+ * def pytext_to_utf8(text): # <<<<<<<<<<<<<<
+ *
+ * if not isinstance(text, basestring):
+ */
+ __pyx_t_1 = PyCFunction_NewEx(&__pyx_mdef_6eorepo_9eodefault_3pytext_to_utf8, NULL, __pyx_n_s_9); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 33; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(__pyx_t_1);
+ if (PyObject_SetAttr(__pyx_m, __pyx_n_s__pytext_to_utf8, __pyx_t_1) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 33; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(__pyx_t_1); __pyx_t_1 = 0;
+
+ /* "eorepo/eodefault.pyx":50
+ * cdef class EoDefault:
+ *
+ * PY_EO_NAME = "python-eo" # <<<<<<<<<<<<<<
+ * def __cinit__(self):
+ * self.eo = NULL
+ */
+ if (PyDict_SetItem((PyObject *)__pyx_ptype_6eorepo_9eodefault_EoDefault->tp_dict, __pyx_n_s__PY_EO_NAME, ((PyObject *)__pyx_kp_s_12)) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 50; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ PyType_Modified(__pyx_ptype_6eorepo_9eodefault_EoDefault);
+
+ /* "eorepo/eodefault.pyx":1
+ * cimport eodefault # <<<<<<<<<<<<<<
+ * import sys, operator
+ *
+ */
+ __pyx_t_1 = PyDict_New(); if (unlikely(!__pyx_t_1)) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_GOTREF(((PyObject *)__pyx_t_1));
+ if (PyObject_SetAttr(__pyx_m, __pyx_n_s____test__, ((PyObject *)__pyx_t_1)) < 0) {__pyx_filename = __pyx_f[0]; __pyx_lineno = 1; __pyx_clineno = __LINE__; goto __pyx_L1_error;}
+ __Pyx_DECREF(((PyObject *)__pyx_t_1)); __pyx_t_1 = 0;
+ goto __pyx_L0;
+ __pyx_L1_error:;
+ __Pyx_XDECREF(__pyx_t_1);
+ if (__pyx_m) {
+ __Pyx_AddTraceback("init eorepo.eodefault", __pyx_clineno, __pyx_lineno, __pyx_filename);
+ Py_DECREF(__pyx_m); __pyx_m = 0;
+ } else if (!PyErr_Occurred()) {
+ PyErr_SetString(PyExc_ImportError, "init eorepo.eodefault");
+ }
+ __pyx_L0:;
+ __Pyx_RefNannyFinishContext();
+ #if PY_MAJOR_VERSION < 3
+ return;
+ #else
+ return __pyx_m;
+ #endif
+}
+
+/* Runtime support code */
+#if CYTHON_REFNANNY
+static __Pyx_RefNannyAPIStruct *__Pyx_RefNannyImportAPI(const char *modname) {
+ PyObject *m = NULL, *p = NULL;
+ void *r = NULL;
+ m = PyImport_ImportModule((char *)modname);
+ if (!m) goto end;
+ p = PyObject_GetAttrString(m, (char *)"RefNannyAPI");
+ if (!p) goto end;
+ r = PyLong_AsVoidPtr(p);
+end:
+ Py_XDECREF(p);
+ Py_XDECREF(m);
+ return (__Pyx_RefNannyAPIStruct *)r;
+}
+#endif /* CYTHON_REFNANNY */
+
+static PyObject *__Pyx_GetName(PyObject *dict, PyObject *name) {
+ PyObject *result;
+ result = PyObject_GetAttr(dict, name);
+ if (!result) {
+ if (dict != __pyx_b) {
+ PyErr_Clear();
+ result = PyObject_GetAttr(__pyx_b, name);
+ }
+ if (!result) {
+ PyErr_SetObject(PyExc_NameError, name);
+ }
+ }
+ return result;
+}
+
+static CYTHON_INLINE void __Pyx_ErrRestore(PyObject *type, PyObject *value, PyObject *tb) {
+#if CYTHON_COMPILING_IN_CPYTHON
+ PyObject *tmp_type, *tmp_value, *tmp_tb;
+ PyThreadState *tstate = PyThreadState_GET();
+ tmp_type = tstate->curexc_type;
+ tmp_value = tstate->curexc_value;
+ tmp_tb = tstate->curexc_traceback;
+ tstate->curexc_type = type;
+ tstate->curexc_value = value;
+ tstate->curexc_traceback = tb;
+ Py_XDECREF(tmp_type);
+ Py_XDECREF(tmp_value);
+ Py_XDECREF(tmp_tb);
+#else
+ PyErr_Restore(type, value, tb);
+#endif
+}
+static CYTHON_INLINE void __Pyx_ErrFetch(PyObject **type, PyObject **value, PyObject **tb) {
+#if CYTHON_COMPILING_IN_CPYTHON
+ PyThreadState *tstate = PyThreadState_GET();
+ *type = tstate->curexc_type;
+ *value = tstate->curexc_value;
+ *tb = tstate->curexc_traceback;
+ tstate->curexc_type = 0;
+ tstate->curexc_value = 0;
+ tstate->curexc_traceback = 0;
+#else
+ PyErr_Fetch(type, value, tb);
+#endif
+}
+
+#if PY_MAJOR_VERSION < 3
+static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb,
+ CYTHON_UNUSED PyObject *cause) {
+ Py_XINCREF(type);
+ if (!value || value == Py_None)
+ value = NULL;
+ else
+ Py_INCREF(value);
+ if (!tb || tb == Py_None)
+ tb = NULL;
+ else {
+ Py_INCREF(tb);
+ if (!PyTraceBack_Check(tb)) {
+ PyErr_SetString(PyExc_TypeError,
+ "raise: arg 3 must be a traceback or None");
+ goto raise_error;
+ }
+ }
+ #if PY_VERSION_HEX < 0x02050000
+ if (PyClass_Check(type)) {
+ #else
+ if (PyType_Check(type)) {
+ #endif
+#if CYTHON_COMPILING_IN_PYPY
+ if (!value) {
+ Py_INCREF(Py_None);
+ value = Py_None;
+ }
+#endif
+ PyErr_NormalizeException(&type, &value, &tb);
+ } else {
+ if (value) {
+ PyErr_SetString(PyExc_TypeError,
+ "instance exception may not have a separate value");
+ goto raise_error;
+ }
+ value = type;
+ #if PY_VERSION_HEX < 0x02050000
+ if (PyInstance_Check(type)) {
+ type = (PyObject*) ((PyInstanceObject*)type)->in_class;
+ Py_INCREF(type);
+ }
+ else {
+ type = 0;
+ PyErr_SetString(PyExc_TypeError,
+ "raise: exception must be an old-style class or instance");
+ goto raise_error;
+ }
+ #else
+ type = (PyObject*) Py_TYPE(type);
+ Py_INCREF(type);
+ if (!PyType_IsSubtype((PyTypeObject *)type, (PyTypeObject *)PyExc_BaseException)) {
+ PyErr_SetString(PyExc_TypeError,
+ "raise: exception class must be a subclass of BaseException");
+ goto raise_error;
+ }
+ #endif
+ }
+ __Pyx_ErrRestore(type, value, tb);
+ return;
+raise_error:
+ Py_XDECREF(value);
+ Py_XDECREF(type);
+ Py_XDECREF(tb);
+ return;
+}
+#else /* Python 3+ */
+static void __Pyx_Raise(PyObject *type, PyObject *value, PyObject *tb, PyObject *cause) {
+ PyObject* owned_instance = NULL;
+ if (tb == Py_None) {
+ tb = 0;
+ } else if (tb && !PyTraceBack_Check(tb)) {
+ PyErr_SetString(PyExc_TypeError,
+ "raise: arg 3 must be a traceback or None");
+ goto bad;
+ }
+ if (value == Py_None)
+ value = 0;
+ if (PyExceptionInstance_Check(type)) {
+ if (value) {
+ PyErr_SetString(PyExc_TypeError,
+ "instance exception may not have a separate value");
+ goto bad;
+ }
+ value = type;
+ type = (PyObject*) Py_TYPE(value);
+ } else if (PyExceptionClass_Check(type)) {
+ PyObject *args;
+ if (!value)
+ args = PyTuple_New(0);
+ else if (PyTuple_Check(value)) {
+ Py_INCREF(value);
+ args = value;
+ }
+ else
+ args = PyTuple_Pack(1, value);
+ if (!args)
+ goto bad;
+ owned_instance = PyEval_CallObject(type, args);
+ Py_DECREF(args);
+ if (!owned_instance)
+ goto bad;
+ value = owned_instance;
+ if (!PyExceptionInstance_Check(value)) {
+ PyErr_Format(PyExc_TypeError,
+ "calling %R should have returned an instance of "
+ "BaseException, not %R",
+ type, Py_TYPE(value));
+ goto bad;
+ }
+ } else {
+ PyErr_SetString(PyExc_TypeError,
+ "raise: exception class must be a subclass of BaseException");
+ goto bad;
+ }
+ if (cause && cause != Py_None) {
+ PyObject *fixed_cause;
+ if (PyExceptionClass_Check(cause)) {
+ fixed_cause = PyObject_CallObject(cause, NULL);
+ if (fixed_cause == NULL)
+ goto bad;
+ }
+ else if (PyExceptionInstance_Check(cause)) {
+ fixed_cause = cause;
+ Py_INCREF(fixed_cause);
+ }
+ else {
+ PyErr_SetString(PyExc_TypeError,
+ "exception causes must derive from "
+ "BaseException");
+ goto bad;
+ }
+ PyException_SetCause(value, fixed_cause);
+ }
+ PyErr_SetObject(type, value);
+ if (tb) {
+ PyThreadState *tstate = PyThreadState_GET();
+ PyObject* tmp_tb = tstate->curexc_traceback;
+ if (tb != tmp_tb) {
+ Py_INCREF(tb);
+ tstate->curexc_traceback = tb;
+ Py_XDECREF(tmp_tb);
+ }
+ }
+bad:
+ Py_XDECREF(owned_instance);
+ return;
+}
+#endif
+
+static void __Pyx_RaiseArgtupleInvalid(
+ const char* func_name,
+ int exact,
+ Py_ssize_t num_min,
+ Py_ssize_t num_max,
+ Py_ssize_t num_found)
+{
+ Py_ssize_t num_expected;
+ const char *more_or_less;
+ if (num_found < num_min) {
+ num_expected = num_min;
+ more_or_less = "at least";
+ } else {
+ num_expected = num_max;
+ more_or_less = "at most";
+ }
+ if (exact) {
+ more_or_less = "exactly";
+ }
+ PyErr_Format(PyExc_TypeError,
+ "%s() takes %s %" CYTHON_FORMAT_SSIZE_T "d positional argument%s (%" CYTHON_FORMAT_SSIZE_T "d given)",
+ func_name, more_or_less, num_expected,
+ (num_expected == 1) ? "" : "s", num_found);
+}
+
+static CYTHON_INLINE int __Pyx_CheckKeywordStrings(
+ PyObject *kwdict,
+ const char* function_name,
+ int kw_allowed)
+{
+ PyObject* key = 0;
+ Py_ssize_t pos = 0;
+#if CPYTHON_COMPILING_IN_PYPY
+ if (!kw_allowed && PyDict_Next(kwdict, &pos, &key, 0))
+ goto invalid_keyword;
+ return 1;
+#else
+ while (PyDict_Next(kwdict, &pos, &key, 0)) {
+ #if PY_MAJOR_VERSION < 3
+ if (unlikely(!PyString_CheckExact(key)) && unlikely(!PyString_Check(key)))
+ #endif
+ if (unlikely(!PyUnicode_Check(key)))
+ goto invalid_keyword_type;
+ }
+ if ((!kw_allowed) && unlikely(key))
+ goto invalid_keyword;
+ return 1;
+invalid_keyword_type:
+ PyErr_Format(PyExc_TypeError,
+ "%s() keywords must be strings", function_name);
+ return 0;
+#endif
+invalid_keyword:
+ PyErr_Format(PyExc_TypeError,
+ #if PY_MAJOR_VERSION < 3
+ "%s() got an unexpected keyword argument '%s'",
+ function_name, PyString_AsString(key));
+ #else
+ "%s() got an unexpected keyword argument '%U'",
+ function_name, key);
+ #endif
+ return 0;
+}
+
+static void __Pyx_RaiseDoubleKeywordsError(
+ const char* func_name,
+ PyObject* kw_name)
+{
+ PyErr_Format(PyExc_TypeError,
+ #if PY_MAJOR_VERSION >= 3
+ "%s() got multiple values for keyword argument '%U'", func_name, kw_name);
+ #else
+ "%s() got multiple values for keyword argument '%s'", func_name,
+ PyString_AsString(kw_name));
+ #endif
+}
+
+static int __Pyx_ParseOptionalKeywords(
+ PyObject *kwds,
+ PyObject **argnames[],
+ PyObject *kwds2,
+ PyObject *values[],
+ Py_ssize_t num_pos_args,
+ const char* function_name)
+{
+ PyObject *key = 0, *value = 0;
+ Py_ssize_t pos = 0;
+ PyObject*** name;
+ PyObject*** first_kw_arg = argnames + num_pos_args;
+ while (PyDict_Next(kwds, &pos, &key, &value)) {
+ name = first_kw_arg;
+ while (*name && (**name != key)) name++;
+ if (*name) {
+ values[name-argnames] = value;
+ continue;
+ }
+ name = first_kw_arg;
+ #if PY_MAJOR_VERSION < 3
+ if (likely(PyString_CheckExact(key)) || likely(PyString_Check(key))) {
+ while (*name) {
+ if ((CYTHON_COMPILING_IN_PYPY || PyString_GET_SIZE(**name) == PyString_GET_SIZE(key))
+ && _PyString_Eq(**name, key)) {
+ values[name-argnames] = value;
+ break;
+ }
+ name++;
+ }
+ if (*name) continue;
+ else {
+ PyObject*** argname = argnames;
+ while (argname != first_kw_arg) {
+ if ((**argname == key) || (
+ (CYTHON_COMPILING_IN_PYPY || PyString_GET_SIZE(**argname) == PyString_GET_SIZE(key))
+ && _PyString_Eq(**argname, key))) {
+ goto arg_passed_twice;
+ }
+ argname++;
+ }
+ }
+ } else
+ #endif
+ if (likely(PyUnicode_Check(key))) {
+ while (*name) {
+ int cmp = (**name == key) ? 0 :
+ #if !CYTHON_COMPILING_IN_PYPY && PY_MAJOR_VERSION >= 3
+ (PyUnicode_GET_SIZE(**name) != PyUnicode_GET_SIZE(key)) ? 1 :
+ #endif
+ PyUnicode_Compare(**name, key);
+ if (cmp < 0 && unlikely(PyErr_Occurred())) goto bad;
+ if (cmp == 0) {
+ values[name-argnames] = value;
+ break;
+ }
+ name++;
+ }
+ if (*name) continue;
+ else {
+ PyObject*** argname = argnames;
+ while (argname != first_kw_arg) {
+ int cmp = (**argname == key) ? 0 :
+ #if !CYTHON_COMPILING_IN_PYPY && PY_MAJOR_VERSION >= 3
+ (PyUnicode_GET_SIZE(**argname) != PyUnicode_GET_SIZE(key)) ? 1 :
+ #endif
+ PyUnicode_Compare(**argname, key);
+ if (cmp < 0 && unlikely(PyErr_Occurred())) goto bad;
+ if (cmp == 0) goto arg_passed_twice;
+ argname++;
+ }
+ }
+ } else
+ goto invalid_keyword_type;
+ if (kwds2) {
+ if (unlikely(PyDict_SetItem(kwds2, key, value))) goto bad;
+ } else {
+ goto invalid_keyword;
+ }
+ }
+ return 0;
+arg_passed_twice:
+ __Pyx_RaiseDoubleKeywordsError(function_name, key);
+ goto bad;
+invalid_keyword_type:
+ PyErr_Format(PyExc_TypeError,
+ "%s() keywords must be strings", function_name);
+ goto bad;
+invalid_keyword:
+ PyErr_Format(PyExc_TypeError,
+ #if PY_MAJOR_VERSION < 3
+ "%s() got an unexpected keyword argument '%s'",
+ function_name, PyString_AsString(key));
+ #else
+ "%s() got an unexpected keyword argument '%U'",
+ function_name, key);
+ #endif
+bad:
+ return -1;
+}
+
+static int __Pyx_ArgTypeTest(PyObject *obj, PyTypeObject *type, int none_allowed,
+ const char *name, int exact)
+{
+ if (!type) {
+ PyErr_Format(PyExc_SystemError, "Missing type object");
+ return 0;
+ }
+ if (none_allowed && obj == Py_None) return 1;
+ else if (exact) {
+ if (Py_TYPE(obj) == type) return 1;
+ }
+ else {
+ if (PyObject_TypeCheck(obj, type)) return 1;
+ }
+ PyErr_Format(PyExc_TypeError,
+ "Argument '%s' has incorrect type (expected %s, got %s)",
+ name, type->tp_name, Py_TYPE(obj)->tp_name);
+ return 0;
+}
+
+static PyObject *__Pyx_Import(PyObject *name, PyObject *from_list, long level) {
+ PyObject *py_import = 0;
+ PyObject *empty_list = 0;
+ PyObject *module = 0;
+ PyObject *global_dict = 0;
+ PyObject *empty_dict = 0;
+ PyObject *list;
+ py_import = __Pyx_GetAttrString(__pyx_b, "__import__");
+ if (!py_import)
+ goto bad;
+ if (from_list)
+ list = from_list;
+ else {
+ empty_list = PyList_New(0);
+ if (!empty_list)
+ goto bad;
+ list = empty_list;
+ }
+ global_dict = PyModule_GetDict(__pyx_m);
+ if (!global_dict)
+ goto bad;
+ empty_dict = PyDict_New();
+ if (!empty_dict)
+ goto bad;
+ #if PY_VERSION_HEX >= 0x02050000
+ {
+ #if PY_MAJOR_VERSION >= 3
+ if (level == -1) {
+ if (strchr(__Pyx_MODULE_NAME, '.')) {
+ /* try package relative import first */
+ PyObject *py_level = PyInt_FromLong(1);
+ if (!py_level)
+ goto bad;
+ module = PyObject_CallFunctionObjArgs(py_import,
+ name, global_dict, empty_dict, list, py_level, NULL);
+ Py_DECREF(py_level);
+ if (!module) {
+ if (!PyErr_ExceptionMatches(PyExc_ImportError))
+ goto bad;
+ PyErr_Clear();
+ }
+ }
+ level = 0; /* try absolute import on failure */
+ }
+ #endif
+ if (!module) {
+ PyObject *py_level = PyInt_FromLong(level);
+ if (!py_level)
+ goto bad;
+ module = PyObject_CallFunctionObjArgs(py_import,
+ name, global_dict, empty_dict, list, py_level, NULL);
+ Py_DECREF(py_level);
+ }
+ }
+ #else
+ if (level>0) {
+ PyErr_SetString(PyExc_RuntimeError, "Relative import is not supported for Python <=2.4.");
+ goto bad;
+ }
+ module = PyObject_CallFunctionObjArgs(py_import,
+ name, global_dict, empty_dict, list, NULL);
+ #endif
+bad:
+ Py_XDECREF(empty_list);
+ Py_XDECREF(py_import);
+ Py_XDECREF(empty_dict);
+ return module;
+}
+
+static CYTHON_INLINE PyObject *__Pyx_PyInt_to_py_Eina_Bool(Eina_Bool val) {
+ const Eina_Bool neg_one = (Eina_Bool)-1, const_zero = (Eina_Bool)0;
+ const int is_unsigned = const_zero < neg_one;
+ if ((sizeof(Eina_Bool) == sizeof(char)) ||
+ (sizeof(Eina_Bool) == sizeof(short))) {
+ return PyInt_FromLong((long)val);
+ } else if ((sizeof(Eina_Bool) == sizeof(int)) ||
+ (sizeof(Eina_Bool) == sizeof(long))) {
+ if (is_unsigned)
+ return PyLong_FromUnsignedLong((unsigned long)val);
+ else
+ return PyInt_FromLong((long)val);
+ } else if (sizeof(Eina_Bool) == sizeof(PY_LONG_LONG)) {
+ if (is_unsigned)
+ return PyLong_FromUnsignedLongLong((unsigned PY_LONG_LONG)val);
+ else
+ return PyLong_FromLongLong((PY_LONG_LONG)val);
+ } else {
+ int one = 1; int little = (int)*(unsigned char *)&one;
+ unsigned char *bytes = (unsigned char *)&val;
+ return _PyLong_FromByteArray(bytes, sizeof(Eina_Bool),
+ little, !is_unsigned);
+ }
+}
+
+#if !CYTHON_COMPILING_IN_PYPY && PY_MAJOR_VERSION < 3
+static PyObject *__Pyx_GetStdout(void) {
+ PyObject *f = PySys_GetObject((char *)"stdout");
+ if (!f) {
+ PyErr_SetString(PyExc_RuntimeError, "lost sys.stdout");
+ }
+ return f;
+}
+static int __Pyx_Print(PyObject* f, PyObject *arg_tuple, int newline) {
+ int i;
+ if (!f) {
+ if (!(f = __Pyx_GetStdout()))
+ return -1;
+ }
+ Py_INCREF(f);
+ for (i=0; i < PyTuple_GET_SIZE(arg_tuple); i++) {
+ PyObject* v;
+ if (PyFile_SoftSpace(f, 1)) {
+ if (PyFile_WriteString(" ", f) < 0)
+ goto error;
+ }
+ v = PyTuple_GET_ITEM(arg_tuple, i);
+ if (PyFile_WriteObject(v, f, Py_PRINT_RAW) < 0)
+ goto error;
+ if (PyString_Check(v)) {
+ char *s = PyString_AsString(v);
+ Py_ssize_t len = PyString_Size(v);
+ if (len > 0 &&
+ isspace(Py_CHARMASK(s[len-1])) &&
+ s[len-1] != ' ')
+ PyFile_SoftSpace(f, 0);
+ }
+ }
+ if (newline) {
+ if (PyFile_WriteString("\n", f) < 0)
+ goto error;
+ PyFile_SoftSpace(f, 0);
+ }
+ Py_DECREF(f);
+ return 0;
+error:
+ Py_DECREF(f);
+ return -1;
+}
+#else /* Python 3 has a print function */
+static int __Pyx_Print(PyObject* stream, PyObject *arg_tuple, int newline) {
+ PyObject* kwargs = 0;
+ PyObject* result = 0;
+ PyObject* end_string;
+ if (unlikely(!__pyx_print)) {
+ __pyx_print = __Pyx_GetAttrString(__pyx_b, "print");
+ if (!__pyx_print)
+ return -1;
+ }
+ if (stream) {
+ kwargs = PyDict_New();
+ if (unlikely(!kwargs))
+ return -1;
+ if (unlikely(PyDict_SetItemString(kwargs, "file", stream) < 0))
+ goto bad;
+ if (!newline) {
+ end_string = PyUnicode_FromStringAndSize(" ", 1);
+ if (unlikely(!end_string))
+ goto bad;
+ if (PyDict_SetItemString(kwargs, "end", end_string) < 0) {
+ Py_DECREF(end_string);
+ goto bad;
+ }
+ Py_DECREF(end_string);
+ }
+ } else if (!newline) {
+ if (unlikely(!__pyx_print_kwargs)) {
+ __pyx_print_kwargs = PyDict_New();
+ if (unlikely(!__pyx_print_kwargs))
+ return -1;
+ end_string = PyUnicode_FromStringAndSize(" ", 1);
+ if (unlikely(!end_string))
+ return -1;
+ if (PyDict_SetItemString(__pyx_print_kwargs, "end", end_string) < 0) {
+ Py_DECREF(end_string);
+ return -1;
+ }
+ Py_DECREF(end_string);
+ }
+ kwargs = __pyx_print_kwargs;
+ }
+ result = PyObject_Call(__pyx_print, arg_tuple, kwargs);
+ if (unlikely(kwargs) && (kwargs != __pyx_print_kwargs))
+ Py_DECREF(kwargs);
+ if (!result)
+ return -1;
+ Py_DECREF(result);
+ return 0;
+bad:
+ if (kwargs != __pyx_print_kwargs)
+ Py_XDECREF(kwargs);
+ return -1;
+}
+#endif
+
+static CYTHON_INLINE unsigned char __Pyx_PyInt_AsUnsignedChar(PyObject* x) {
+ const unsigned char neg_one = (unsigned char)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(unsigned char) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(unsigned char)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to unsigned char" :
+ "value too large to convert to unsigned char");
+ }
+ return (unsigned char)-1;
+ }
+ return (unsigned char)val;
+ }
+ return (unsigned char)__Pyx_PyInt_AsUnsignedLong(x);
+}
+
+static CYTHON_INLINE unsigned short __Pyx_PyInt_AsUnsignedShort(PyObject* x) {
+ const unsigned short neg_one = (unsigned short)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(unsigned short) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(unsigned short)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to unsigned short" :
+ "value too large to convert to unsigned short");
+ }
+ return (unsigned short)-1;
+ }
+ return (unsigned short)val;
+ }
+ return (unsigned short)__Pyx_PyInt_AsUnsignedLong(x);
+}
+
+static CYTHON_INLINE unsigned int __Pyx_PyInt_AsUnsignedInt(PyObject* x) {
+ const unsigned int neg_one = (unsigned int)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(unsigned int) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(unsigned int)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to unsigned int" :
+ "value too large to convert to unsigned int");
+ }
+ return (unsigned int)-1;
+ }
+ return (unsigned int)val;
+ }
+ return (unsigned int)__Pyx_PyInt_AsUnsignedLong(x);
+}
+
+static CYTHON_INLINE char __Pyx_PyInt_AsChar(PyObject* x) {
+ const char neg_one = (char)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(char) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(char)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to char" :
+ "value too large to convert to char");
+ }
+ return (char)-1;
+ }
+ return (char)val;
+ }
+ return (char)__Pyx_PyInt_AsLong(x);
+}
+
+static CYTHON_INLINE short __Pyx_PyInt_AsShort(PyObject* x) {
+ const short neg_one = (short)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(short) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(short)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to short" :
+ "value too large to convert to short");
+ }
+ return (short)-1;
+ }
+ return (short)val;
+ }
+ return (short)__Pyx_PyInt_AsLong(x);
+}
+
+static CYTHON_INLINE int __Pyx_PyInt_AsInt(PyObject* x) {
+ const int neg_one = (int)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(int) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(int)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to int" :
+ "value too large to convert to int");
+ }
+ return (int)-1;
+ }
+ return (int)val;
+ }
+ return (int)__Pyx_PyInt_AsLong(x);
+}
+
+static CYTHON_INLINE signed char __Pyx_PyInt_AsSignedChar(PyObject* x) {
+ const signed char neg_one = (signed char)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(signed char) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(signed char)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to signed char" :
+ "value too large to convert to signed char");
+ }
+ return (signed char)-1;
+ }
+ return (signed char)val;
+ }
+ return (signed char)__Pyx_PyInt_AsSignedLong(x);
+}
+
+static CYTHON_INLINE signed short __Pyx_PyInt_AsSignedShort(PyObject* x) {
+ const signed short neg_one = (signed short)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(signed short) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(signed short)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to signed short" :
+ "value too large to convert to signed short");
+ }
+ return (signed short)-1;
+ }
+ return (signed short)val;
+ }
+ return (signed short)__Pyx_PyInt_AsSignedLong(x);
+}
+
+static CYTHON_INLINE signed int __Pyx_PyInt_AsSignedInt(PyObject* x) {
+ const signed int neg_one = (signed int)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(signed int) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(signed int)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to signed int" :
+ "value too large to convert to signed int");
+ }
+ return (signed int)-1;
+ }
+ return (signed int)val;
+ }
+ return (signed int)__Pyx_PyInt_AsSignedLong(x);
+}
+
+static CYTHON_INLINE int __Pyx_PyInt_AsLongDouble(PyObject* x) {
+ const int neg_one = (int)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+ if (sizeof(int) < sizeof(long)) {
+ long val = __Pyx_PyInt_AsLong(x);
+ if (unlikely(val != (long)(int)val)) {
+ if (!unlikely(val == -1 && PyErr_Occurred())) {
+ PyErr_SetString(PyExc_OverflowError,
+ (is_unsigned && unlikely(val < 0)) ?
+ "can't convert negative value to int" :
+ "value too large to convert to int");
+ }
+ return (int)-1;
+ }
+ return (int)val;
+ }
+ return (int)__Pyx_PyInt_AsLong(x);
+}
+
+static CYTHON_INLINE unsigned long __Pyx_PyInt_AsUnsignedLong(PyObject* x) {
+ const unsigned long neg_one = (unsigned long)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+#if PY_VERSION_HEX < 0x03000000
+ if (likely(PyInt_Check(x))) {
+ long val = PyInt_AS_LONG(x);
+ if (is_unsigned && unlikely(val < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to unsigned long");
+ return (unsigned long)-1;
+ }
+ return (unsigned long)val;
+ } else
+#endif
+ if (likely(PyLong_Check(x))) {
+ if (is_unsigned) {
+ if (unlikely(Py_SIZE(x) < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to unsigned long");
+ return (unsigned long)-1;
+ }
+ return (unsigned long)PyLong_AsUnsignedLong(x);
+ } else {
+ return (unsigned long)PyLong_AsLong(x);
+ }
+ } else {
+ unsigned long val;
+ PyObject *tmp = __Pyx_PyNumber_Int(x);
+ if (!tmp) return (unsigned long)-1;
+ val = __Pyx_PyInt_AsUnsignedLong(tmp);
+ Py_DECREF(tmp);
+ return val;
+ }
+}
+
+static CYTHON_INLINE unsigned PY_LONG_LONG __Pyx_PyInt_AsUnsignedLongLong(PyObject* x) {
+ const unsigned PY_LONG_LONG neg_one = (unsigned PY_LONG_LONG)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+#if PY_VERSION_HEX < 0x03000000
+ if (likely(PyInt_Check(x))) {
+ long val = PyInt_AS_LONG(x);
+ if (is_unsigned && unlikely(val < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to unsigned PY_LONG_LONG");
+ return (unsigned PY_LONG_LONG)-1;
+ }
+ return (unsigned PY_LONG_LONG)val;
+ } else
+#endif
+ if (likely(PyLong_Check(x))) {
+ if (is_unsigned) {
+ if (unlikely(Py_SIZE(x) < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to unsigned PY_LONG_LONG");
+ return (unsigned PY_LONG_LONG)-1;
+ }
+ return (unsigned PY_LONG_LONG)PyLong_AsUnsignedLongLong(x);
+ } else {
+ return (unsigned PY_LONG_LONG)PyLong_AsLongLong(x);
+ }
+ } else {
+ unsigned PY_LONG_LONG val;
+ PyObject *tmp = __Pyx_PyNumber_Int(x);
+ if (!tmp) return (unsigned PY_LONG_LONG)-1;
+ val = __Pyx_PyInt_AsUnsignedLongLong(tmp);
+ Py_DECREF(tmp);
+ return val;
+ }
+}
+
+static CYTHON_INLINE long __Pyx_PyInt_AsLong(PyObject* x) {
+ const long neg_one = (long)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+#if PY_VERSION_HEX < 0x03000000
+ if (likely(PyInt_Check(x))) {
+ long val = PyInt_AS_LONG(x);
+ if (is_unsigned && unlikely(val < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to long");
+ return (long)-1;
+ }
+ return (long)val;
+ } else
+#endif
+ if (likely(PyLong_Check(x))) {
+ if (is_unsigned) {
+ if (unlikely(Py_SIZE(x) < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to long");
+ return (long)-1;
+ }
+ return (long)PyLong_AsUnsignedLong(x);
+ } else {
+ return (long)PyLong_AsLong(x);
+ }
+ } else {
+ long val;
+ PyObject *tmp = __Pyx_PyNumber_Int(x);
+ if (!tmp) return (long)-1;
+ val = __Pyx_PyInt_AsLong(tmp);
+ Py_DECREF(tmp);
+ return val;
+ }
+}
+
+static CYTHON_INLINE PY_LONG_LONG __Pyx_PyInt_AsLongLong(PyObject* x) {
+ const PY_LONG_LONG neg_one = (PY_LONG_LONG)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+#if PY_VERSION_HEX < 0x03000000
+ if (likely(PyInt_Check(x))) {
+ long val = PyInt_AS_LONG(x);
+ if (is_unsigned && unlikely(val < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to PY_LONG_LONG");
+ return (PY_LONG_LONG)-1;
+ }
+ return (PY_LONG_LONG)val;
+ } else
+#endif
+ if (likely(PyLong_Check(x))) {
+ if (is_unsigned) {
+ if (unlikely(Py_SIZE(x) < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to PY_LONG_LONG");
+ return (PY_LONG_LONG)-1;
+ }
+ return (PY_LONG_LONG)PyLong_AsUnsignedLongLong(x);
+ } else {
+ return (PY_LONG_LONG)PyLong_AsLongLong(x);
+ }
+ } else {
+ PY_LONG_LONG val;
+ PyObject *tmp = __Pyx_PyNumber_Int(x);
+ if (!tmp) return (PY_LONG_LONG)-1;
+ val = __Pyx_PyInt_AsLongLong(tmp);
+ Py_DECREF(tmp);
+ return val;
+ }
+}
+
+static CYTHON_INLINE signed long __Pyx_PyInt_AsSignedLong(PyObject* x) {
+ const signed long neg_one = (signed long)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+#if PY_VERSION_HEX < 0x03000000
+ if (likely(PyInt_Check(x))) {
+ long val = PyInt_AS_LONG(x);
+ if (is_unsigned && unlikely(val < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to signed long");
+ return (signed long)-1;
+ }
+ return (signed long)val;
+ } else
+#endif
+ if (likely(PyLong_Check(x))) {
+ if (is_unsigned) {
+ if (unlikely(Py_SIZE(x) < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to signed long");
+ return (signed long)-1;
+ }
+ return (signed long)PyLong_AsUnsignedLong(x);
+ } else {
+ return (signed long)PyLong_AsLong(x);
+ }
+ } else {
+ signed long val;
+ PyObject *tmp = __Pyx_PyNumber_Int(x);
+ if (!tmp) return (signed long)-1;
+ val = __Pyx_PyInt_AsSignedLong(tmp);
+ Py_DECREF(tmp);
+ return val;
+ }
+}
+
+static CYTHON_INLINE signed PY_LONG_LONG __Pyx_PyInt_AsSignedLongLong(PyObject* x) {
+ const signed PY_LONG_LONG neg_one = (signed PY_LONG_LONG)-1, const_zero = 0;
+ const int is_unsigned = neg_one > const_zero;
+#if PY_VERSION_HEX < 0x03000000
+ if (likely(PyInt_Check(x))) {
+ long val = PyInt_AS_LONG(x);
+ if (is_unsigned && unlikely(val < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to signed PY_LONG_LONG");
+ return (signed PY_LONG_LONG)-1;
+ }
+ return (signed PY_LONG_LONG)val;
+ } else
+#endif
+ if (likely(PyLong_Check(x))) {
+ if (is_unsigned) {
+ if (unlikely(Py_SIZE(x) < 0)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "can't convert negative value to signed PY_LONG_LONG");
+ return (signed PY_LONG_LONG)-1;
+ }
+ return (signed PY_LONG_LONG)PyLong_AsUnsignedLongLong(x);
+ } else {
+ return (signed PY_LONG_LONG)PyLong_AsLongLong(x);
+ }
+ } else {
+ signed PY_LONG_LONG val;
+ PyObject *tmp = __Pyx_PyNumber_Int(x);
+ if (!tmp) return (signed PY_LONG_LONG)-1;
+ val = __Pyx_PyInt_AsSignedLongLong(tmp);
+ Py_DECREF(tmp);
+ return val;
+ }
+}
+
+static void __Pyx_WriteUnraisable(const char *name, CYTHON_UNUSED int clineno,
+ CYTHON_UNUSED int lineno, CYTHON_UNUSED const char *filename) {
+ PyObject *old_exc, *old_val, *old_tb;
+ PyObject *ctx;
+ __Pyx_ErrFetch(&old_exc, &old_val, &old_tb);
+ #if PY_MAJOR_VERSION < 3
+ ctx = PyString_FromString(name);
+ #else
+ ctx = PyUnicode_FromString(name);
+ #endif
+ __Pyx_ErrRestore(old_exc, old_val, old_tb);
+ if (!ctx) {
+ PyErr_WriteUnraisable(Py_None);
+ } else {
+ PyErr_WriteUnraisable(ctx);
+ Py_DECREF(ctx);
+ }
+}
+
+static int __Pyx_check_binary_version(void) {
+ char ctversion[4], rtversion[4];
+ PyOS_snprintf(ctversion, 4, "%d.%d", PY_MAJOR_VERSION, PY_MINOR_VERSION);
+ PyOS_snprintf(rtversion, 4, "%s", Py_GetVersion());
+ if (ctversion[0] != rtversion[0] || ctversion[2] != rtversion[2]) {
+ char message[200];
+ PyOS_snprintf(message, sizeof(message),
+ "compiletime version %s of module '%.100s' "
+ "does not match runtime version %s",
+ ctversion, __Pyx_MODULE_NAME, rtversion);
+ #if PY_VERSION_HEX < 0x02050000
+ return PyErr_Warn(NULL, message);
+ #else
+ return PyErr_WarnEx(NULL, message, 1);
+ #endif
+ }
+ return 0;
+}
+
+static int __Pyx_ExportFunction(const char *name, void (*f)(void), const char *sig) {
+ PyObject *d = 0;
+ PyObject *cobj = 0;
+ union {
+ void (*fp)(void);
+ void *p;
+ } tmp;
+ d = PyObject_GetAttrString(__pyx_m, (char *)"__pyx_capi__");
+ if (!d) {
+ PyErr_Clear();
+ d = PyDict_New();
+ if (!d)
+ goto bad;
+ Py_INCREF(d);
+ if (PyModule_AddObject(__pyx_m, (char *)"__pyx_capi__", d) < 0)
+ goto bad;
+ }
+ tmp.fp = f;
+#if PY_VERSION_HEX >= 0x02070000 && !(PY_MAJOR_VERSION==3&&PY_MINOR_VERSION==0)
+ cobj = PyCapsule_New(tmp.p, sig, 0);
+#else
+ cobj = PyCObject_FromVoidPtrAndDesc(tmp.p, (void *)sig, 0);
+#endif
+ if (!cobj)
+ goto bad;
+ if (PyDict_SetItemString(d, name, cobj) < 0)
+ goto bad;
+ Py_DECREF(cobj);
+ Py_DECREF(d);
+ return 0;
+bad:
+ Py_XDECREF(cobj);
+ Py_XDECREF(d);
+ return -1;
+}
+
+static int __Pyx_SetVtable(PyObject *dict, void *vtable) {
+#if PY_VERSION_HEX >= 0x02070000 && !(PY_MAJOR_VERSION==3&&PY_MINOR_VERSION==0)
+ PyObject *ob = PyCapsule_New(vtable, 0, 0);
+#else
+ PyObject *ob = PyCObject_FromVoidPtr(vtable, 0);
+#endif
+ if (!ob)
+ goto bad;
+ if (PyDict_SetItemString(dict, "__pyx_vtable__", ob) < 0)
+ goto bad;
+ Py_DECREF(ob);
+ return 0;
+bad:
+ Py_XDECREF(ob);
+ return -1;
+}
+
+static int __pyx_bisect_code_objects(__Pyx_CodeObjectCacheEntry* entries, int count, int code_line) {
+ int start = 0, mid = 0, end = count - 1;
+ if (end >= 0 && code_line > entries[end].code_line) {
+ return count;
+ }
+ while (start < end) {
+ mid = (start + end) / 2;
+ if (code_line < entries[mid].code_line) {
+ end = mid;
+ } else if (code_line > entries[mid].code_line) {
+ start = mid + 1;
+ } else {
+ return mid;
+ }
+ }
+ if (code_line <= entries[mid].code_line) {
+ return mid;
+ } else {
+ return mid + 1;
+ }
+}
+static PyCodeObject *__pyx_find_code_object(int code_line) {
+ PyCodeObject* code_object;
+ int pos;
+ if (unlikely(!code_line) || unlikely(!__pyx_code_cache.entries)) {
+ return NULL;
+ }
+ pos = __pyx_bisect_code_objects(__pyx_code_cache.entries, __pyx_code_cache.count, code_line);
+ if (unlikely(pos >= __pyx_code_cache.count) || unlikely(__pyx_code_cache.entries[pos].code_line != code_line)) {
+ return NULL;
+ }
+ code_object = __pyx_code_cache.entries[pos].code_object;
+ Py_INCREF(code_object);
+ return code_object;
+}
+static void __pyx_insert_code_object(int code_line, PyCodeObject* code_object) {
+ int pos, i;
+ __Pyx_CodeObjectCacheEntry* entries = __pyx_code_cache.entries;
+ if (unlikely(!code_line)) {
+ return;
+ }
+ if (unlikely(!entries)) {
+ entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Malloc(64*sizeof(__Pyx_CodeObjectCacheEntry));
+ if (likely(entries)) {
+ __pyx_code_cache.entries = entries;
+ __pyx_code_cache.max_count = 64;
+ __pyx_code_cache.count = 1;
+ entries[0].code_line = code_line;
+ entries[0].code_object = code_object;
+ Py_INCREF(code_object);
+ }
+ return;
+ }
+ pos = __pyx_bisect_code_objects(__pyx_code_cache.entries, __pyx_code_cache.count, code_line);
+ if ((pos < __pyx_code_cache.count) && unlikely(__pyx_code_cache.entries[pos].code_line == code_line)) {
+ PyCodeObject* tmp = entries[pos].code_object;
+ entries[pos].code_object = code_object;
+ Py_DECREF(tmp);
+ return;
+ }
+ if (__pyx_code_cache.count == __pyx_code_cache.max_count) {
+ int new_max = __pyx_code_cache.max_count + 64;
+ entries = (__Pyx_CodeObjectCacheEntry*)PyMem_Realloc(
+ __pyx_code_cache.entries, new_max*sizeof(__Pyx_CodeObjectCacheEntry));
+ if (unlikely(!entries)) {
+ return;
+ }
+ __pyx_code_cache.entries = entries;
+ __pyx_code_cache.max_count = new_max;
+ }
+ for (i=__pyx_code_cache.count; i>pos; i--) {
+ entries[i] = entries[i-1];
+ }
+ entries[pos].code_line = code_line;
+ entries[pos].code_object = code_object;
+ __pyx_code_cache.count++;
+ Py_INCREF(code_object);
+}
+
+#include "compile.h"
+#include "frameobject.h"
+#include "traceback.h"
+static PyCodeObject* __Pyx_CreateCodeObjectForTraceback(
+ const char *funcname, int c_line,
+ int py_line, const char *filename) {
+ PyCodeObject *py_code = 0;
+ PyObject *py_srcfile = 0;
+ PyObject *py_funcname = 0;
+ #if PY_MAJOR_VERSION < 3
+ py_srcfile = PyString_FromString(filename);
+ #else
+ py_srcfile = PyUnicode_FromString(filename);
+ #endif
+ if (!py_srcfile) goto bad;
+ if (c_line) {
+ #if PY_MAJOR_VERSION < 3
+ py_funcname = PyString_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, c_line);
+ #else
+ py_funcname = PyUnicode_FromFormat( "%s (%s:%d)", funcname, __pyx_cfilenm, c_line);
+ #endif
+ }
+ else {
+ #if PY_MAJOR_VERSION < 3
+ py_funcname = PyString_FromString(funcname);
+ #else
+ py_funcname = PyUnicode_FromString(funcname);
+ #endif
+ }
+ if (!py_funcname) goto bad;
+ py_code = __Pyx_PyCode_New(
+ 0, /*int argcount,*/
+ 0, /*int kwonlyargcount,*/
+ 0, /*int nlocals,*/
+ 0, /*int stacksize,*/
+ 0, /*int flags,*/
+ __pyx_empty_bytes, /*PyObject *code,*/
+ __pyx_empty_tuple, /*PyObject *consts,*/
+ __pyx_empty_tuple, /*PyObject *names,*/
+ __pyx_empty_tuple, /*PyObject *varnames,*/
+ __pyx_empty_tuple, /*PyObject *freevars,*/
+ __pyx_empty_tuple, /*PyObject *cellvars,*/
+ py_srcfile, /*PyObject *filename,*/
+ py_funcname, /*PyObject *name,*/
+ py_line, /*int firstlineno,*/
+ __pyx_empty_bytes /*PyObject *lnotab*/
+ );
+ Py_DECREF(py_srcfile);
+ Py_DECREF(py_funcname);
+ return py_code;
+bad:
+ Py_XDECREF(py_srcfile);
+ Py_XDECREF(py_funcname);
+ return NULL;
+}
+static void __Pyx_AddTraceback(const char *funcname, int c_line,
+ int py_line, const char *filename) {
+ PyCodeObject *py_code = 0;
+ PyObject *py_globals = 0;
+ PyFrameObject *py_frame = 0;
+ py_code = __pyx_find_code_object(c_line ? c_line : py_line);
+ if (!py_code) {
+ py_code = __Pyx_CreateCodeObjectForTraceback(
+ funcname, c_line, py_line, filename);
+ if (!py_code) goto bad;
+ __pyx_insert_code_object(c_line ? c_line : py_line, py_code);
+ }
+ py_globals = PyModule_GetDict(__pyx_m);
+ if (!py_globals) goto bad;
+ py_frame = PyFrame_New(
+ PyThreadState_GET(), /*PyThreadState *tstate,*/
+ py_code, /*PyCodeObject *code,*/
+ py_globals, /*PyObject *globals,*/
+ 0 /*PyObject *locals*/
+ );
+ if (!py_frame) goto bad;
+ py_frame->f_lineno = py_line;
+ PyTraceBack_Here(py_frame);
+bad:
+ Py_XDECREF(py_code);
+ Py_XDECREF(py_frame);
+}
+
+static int __Pyx_InitStrings(__Pyx_StringTabEntry *t) {
+ while (t->p) {
+ #if PY_MAJOR_VERSION < 3
+ if (t->is_unicode) {
+ *t->p = PyUnicode_DecodeUTF8(t->s, t->n - 1, NULL);
+ } else if (t->intern) {
+ *t->p = PyString_InternFromString(t->s);
+ } else {
+ *t->p = PyString_FromStringAndSize(t->s, t->n - 1);
+ }
+ #else /* Python 3+ has unicode identifiers */
+ if (t->is_unicode | t->is_str) {
+ if (t->intern) {
+ *t->p = PyUnicode_InternFromString(t->s);
+ } else if (t->encoding) {
+ *t->p = PyUnicode_Decode(t->s, t->n - 1, t->encoding, NULL);
+ } else {
+ *t->p = PyUnicode_FromStringAndSize(t->s, t->n - 1);
+ }
+ } else {
+ *t->p = PyBytes_FromStringAndSize(t->s, t->n - 1);
+ }
+ #endif
+ if (!*t->p)
+ return -1;
+ ++t;
+ }
+ return 0;
+}
+
+
+/* Type Conversion Functions */
+
+static CYTHON_INLINE int __Pyx_PyObject_IsTrue(PyObject* x) {
+ int is_true = x == Py_True;
+ if (is_true | (x == Py_False) | (x == Py_None)) return is_true;
+ else return PyObject_IsTrue(x);
+}
+
+static CYTHON_INLINE PyObject* __Pyx_PyNumber_Int(PyObject* x) {
+ PyNumberMethods *m;
+ const char *name = NULL;
+ PyObject *res = NULL;
+#if PY_VERSION_HEX < 0x03000000
+ if (PyInt_Check(x) || PyLong_Check(x))
+#else
+ if (PyLong_Check(x))
+#endif
+ return Py_INCREF(x), x;
+ m = Py_TYPE(x)->tp_as_number;
+#if PY_VERSION_HEX < 0x03000000
+ if (m && m->nb_int) {
+ name = "int";
+ res = PyNumber_Int(x);
+ }
+ else if (m && m->nb_long) {
+ name = "long";
+ res = PyNumber_Long(x);
+ }
+#else
+ if (m && m->nb_int) {
+ name = "int";
+ res = PyNumber_Long(x);
+ }
+#endif
+ if (res) {
+#if PY_VERSION_HEX < 0x03000000
+ if (!PyInt_Check(res) && !PyLong_Check(res)) {
+#else
+ if (!PyLong_Check(res)) {
+#endif
+ PyErr_Format(PyExc_TypeError,
+ "__%s__ returned non-%s (type %.200s)",
+ name, name, Py_TYPE(res)->tp_name);
+ Py_DECREF(res);
+ return NULL;
+ }
+ }
+ else if (!PyErr_Occurred()) {
+ PyErr_SetString(PyExc_TypeError,
+ "an integer is required");
+ }
+ return res;
+}
+
+static CYTHON_INLINE Py_ssize_t __Pyx_PyIndex_AsSsize_t(PyObject* b) {
+ Py_ssize_t ival;
+ PyObject* x = PyNumber_Index(b);
+ if (!x) return -1;
+ ival = PyInt_AsSsize_t(x);
+ Py_DECREF(x);
+ return ival;
+}
+
+static CYTHON_INLINE PyObject * __Pyx_PyInt_FromSize_t(size_t ival) {
+#if PY_VERSION_HEX < 0x02050000
+ if (ival <= LONG_MAX)
+ return PyInt_FromLong((long)ival);
+ else {
+ unsigned char *bytes = (unsigned char *) &ival;
+ int one = 1; int little = (int)*(unsigned char*)&one;
+ return _PyLong_FromByteArray(bytes, sizeof(size_t), little, 0);
+ }
+#else
+ return PyInt_FromSize_t(ival);
+#endif
+}
+
+static CYTHON_INLINE size_t __Pyx_PyInt_AsSize_t(PyObject* x) {
+ unsigned PY_LONG_LONG val = __Pyx_PyInt_AsUnsignedLongLong(x);
+ if (unlikely(val == (unsigned PY_LONG_LONG)-1 && PyErr_Occurred())) {
+ return (size_t)-1;
+ } else if (unlikely(val != (unsigned PY_LONG_LONG)(size_t)val)) {
+ PyErr_SetString(PyExc_OverflowError,
+ "value too large to convert to size_t");
+ return (size_t)-1;
+ }
+ return (size_t)val;
+}
+
+
+#endif /* Py_PYTHON_H */
diff --git a/eorepo/eodefault.pxd b/eorepo/eodefault.pxd
new file mode 100644
index 0000000..2f3aadc
--- /dev/null
+++ b/eorepo/eodefault.pxd
@@ -0,0 +1,84 @@
+
+cdef extern from *:
+ ctypedef char* const_char_ptr "const char*"
+
+cdef extern from "Eina.h":
+ ctypedef unsigned char Eina_Bool
+ Eina_Bool EINA_FALSE
+ Eina_Bool EINA_TRUE
+
+cdef extern from "Eo.h":
+
+ ####################################################################
+ # Basic Types
+ #
+
+ ctypedef int Evas_Coord
+ ctypedef int Evas_Angle
+ ctypedef int Evas_Font_Size
+ ctypedef int Eo_Op
+ ctypedef short Eo_Callback_Priority
+
+ ctypedef struct Eo
+ ctypedef struct Eo_Class
+
+ ctypedef struct Eo_Event_Description:
+ char *name
+ char *type
+ char *doc
+
+ Eo_Op EO_BASE_BASE_ID
+
+ Eo_Event_Description * EO_EV_CALLBACK_ADD
+ Eo_Event_Description * EO_EV_CALLBACK_DEL
+ Eo_Event_Description * EO_EV_FREE
+ Eo_Event_Description * EO_EV_DEL
+
+ ctypedef enum:
+ EO_BASE_SUB_ID_DATA_GET
+ EO_BASE_SUB_ID_DATA_DEL
+
+ ctypedef void (*Eo_Event_Cb)(void *data, Eo *obj,
+ Eo_Event_Description *desc,
+ void *event_info)
+ ctypedef void (*eo_base_data_free_func)(void *p)
+
+ cdef short EO_CALLBACK_PRIORITY_BEFORE
+ cdef short EO_CALLBACK_PRIORITY_DEFAULT
+ cdef short EO_CALLBACK_PRIORITY_AFTER
+
+ Eina_Bool eo_init()
+ Eo_Class *eo_base_class_get()
+
+ Eo* eo_add(Eo_Class *klass, Eo *parent)
+ Eo* eo_add_custom(Eo_Class *klass, Eo *parent, ...)
+
+ Eo* eo_ref(Eo *obj)
+ void eo_unref(Eo *obj)
+ int eo_ref_get(Eo *obj)
+ void eo_del(Eo *obj)
+
+ Eo *eo_parent_get(Eo *obj)
+
+ Eo_Class *eo_class_get(Eo *obj)
+ char *eo_class_name_get(Eo_Class *klass)
+
+ void *eo_data_get(Eo *obj, Eo_Class *klass)
+
+
+ Eina_Bool eo_do(Eo *obj, ...)
+ Eina_Bool eo_class_do(Eo_Class *klass, ...)
+
+
+cdef class EoDefault:
+ cdef Eo *eo
+ cdef object name
+ cdef int print_func_name(self, f_name)
+ cdef int _eo_instance_set(self, Eo *eo)
+ cpdef _eo_instance_set2(self, unsigned long long klass, EoDefault parent)
+
+cdef Eo* _eo_instance_get(EoDefault pyobj)
+cdef Eina_Bool _object_callback(void *data, Eo *o, Eo_Event_Description *desc, void *event_info)
+
+
+
diff --git a/eorepo/eodefault.pyx b/eorepo/eodefault.pyx
new file mode 100644
index 0000000..0842514
--- /dev/null
+++ b/eorepo/eodefault.pyx
@@ -0,0 +1,149 @@
+cimport eodefault
+import sys, operator
+
+
+##########################################################
+##
+## Wrapping for Elementary functions
+##
+
+PRIORITY_BEFORE = eodefault.EO_CALLBACK_PRIORITY_BEFORE
+PRIORITY_DEFAULT = eodefault.EO_CALLBACK_PRIORITY_DEFAULT
+PRIORITY_AFTER = eodefault.EO_CALLBACK_PRIORITY_AFTER
+CALLBACK_STOP = 12345
+
+#cdef const_char_ptr py_eo = <const_char_ptr>"python-ej"
+
+
+def init():
+ return bool(eodefault.eo_init())
+
+#########################################################
+
+cdef Eo *_eo_instance_get(EoDefault pyobj):
+ """
+if x is a Python object, (x is None) and (x is not None) are very efficient because they translate directly to C pointer comparisons.
+Whereas (x == None) and (x != None), or simply using x as a boolean value (as in if x: ...) will invoke Python operations and therefore be much slower.
+"""
+ if pyobj is not None:
+ return pyobj.eo
+ else:
+ NULL
+
+def pytext_to_utf8(text):
+
+ if not isinstance(text, basestring):
+ raise TypeError("Argument '%s' has incorrect type (expected %s, got %s)"%("text", "basestring", type(text).__name__))
+ utf8_data = ""
+
+ if isinstance(text, unicode):
+ utf8_data = text.encode('UTF-8')
+ elif isinstance(text, str):
+ utf8_data = text
+
+ return utf8_data
+
+#===========
+
+cdef class EoDefault:
+
+ PY_EO_NAME = "python-eo"
+ def __cinit__(self):
+ self.eo = NULL
+
+ def __dealloc__(self):
+ cdef Eo *eo
+ #self.print_func_name("__dealloc__base__")
+
+ eo = self.eo
+ if eo == NULL:
+ return
+ #eodefault._eo_instance_get(self)
+ eodefault.eo_do(eo, eodefault.EO_BASE_BASE_ID + eodefault.EO_BASE_SUB_ID_DATA_DEL, <const_char_ptr>EoDefault.PY_EO_NAME)
+ eodefault.eo_unref(eo)
+ self.eo = NULL
+
+ # eo_del()
+ def delete(self):
+ self.ref()
+ eodefault.eo_del(self.eo)
+
+ # eo_ref()
+ def ref(self):
+ eodefault.eo_ref(self.eo)
+ return self
+
+ def unref(self):
+ eodefault.eo_unref(self.eo)
+
+ # eo_ref_get()
+ def ref_get(self):
+ ref_count = <object>eodefault.eo_ref_get(self.eo)
+ return ref_count
+
+ # eo_parent_get()
+ def parent_get(self):
+ cdef Eo * parent
+ cdef void * data
+ parent = eodefault.eo_parent_get(self.eo)
+ eodefault.eo_do(parent, eodefault.EO_BASE_BASE_ID+eodefault.EO_BASE_SUB_ID_DATA_GET, <const_char_ptr>EoDefault.PY_EO_NAME, &data)
+ obj = <object>data
+ return obj
+
+ # eo_class_name_get()
+ def class_name_get(self):
+ name = eodefault.eo_class_name_get(eodefault.eo_class_get(self.eo))
+ return name
+
+ def name_get(self):
+ return self.name
+ #this func can be called only from this (c-styled)module
+ cdef int _eo_instance_set(self, Eo *eo):
+ assert self.eo == NULL, "Object must be clean"
+ self.eo = eo
+ self.name = self.__class__.__name__
+
+ # this func is main routine to add new object
+ # using default constructor
+ # and connect C and Py objects
+ cpdef _eo_instance_set2(self, unsigned long long _kl, EoDefault p):
+ cdef Eo_Class *kl = <Eo_Class*>_kl
+ cdef Eo *o = eodefault.eo_add(kl, eodefault._eo_instance_get(p))
+ self._eo_instance_set(o)
+ self._data_set(EoDefault.PY_EO_NAME, self)
+
+ # this func can be called outside(this c-styled module), because receives Eo* as long.
+ # it was added to be able to call eo_add_custom with different params
+ # and connect C and Py objects after it
+ def _eo_instance_set3(self, unsigned long long _eo):
+ cdef Eo *o = <Eo*>_eo
+ self._eo_instance_set(o)
+ self._data_set(EoDefault.PY_EO_NAME, self)
+
+ cdef int print_func_name(self, f_name):
+ print self.__class__, " :: ", f_name, " :: ", sys.getsizeof(self)
+
+#================================================================
+
+cdef Eina_Bool _object_callback(void *data, Eo *o,
+ Eo_Event_Description *desc, void *event_info):
+ cdef EoDefault obj
+ cdef void *p
+
+#passing "this" object to callback function
+ cdef void * c_py_obj
+ eodefault.eo_do(o, eodefault.EO_BASE_BASE_ID+eodefault.EO_BASE_SUB_ID_DATA_GET, <const_char_ptr>EoDefault.PY_EO_NAME, &c_py_obj)
+ py_obj = <object>c_py_obj
+
+ #cb_struct is tuple: (func, data)
+ cb_struct = <object>data
+ f = cb_struct[0]
+ cb_data = cb_struct[1]
+ res = f(py_obj, cb_data)
+
+ if res == CALLBACK_STOP:
+ return EINA_FALSE
+ else:
+ return EINA_TRUE
+
+
diff --git a/examples/elm_elm.js b/examples/elm_elm.js
new file mode 100644
index 0000000..d8c4f8d
--- /dev/null
+++ b/examples/elm_elm.js
@@ -0,0 +1,201 @@
+//var elm = require('jse');
+var elm = require('jsevaselm');
+
+//var m = new elm.Mixin()
+
+function cb_add(par){
+ print(par.text + ": calback_added")
+}
+
+function cb_del(par){
+ print(par.text + ": calback_deleted")
+}
+
+//==============================
+var global_obj
+
+function freeze_this(par){
+ par.alert("Object: " + par.text)
+ par.alert("Freezing cb for this obj")
+ global_obj = par
+ par.event_freeze()
+ par.alert("Freeze count = " + par.event_freeze_get())
+}
+
+function thaw_cb(par){
+ par.alert("Thawing cb for global_obj")
+ global_obj.event_thaw()
+}
+//==================================
+
+function numbers_cb(par){
+ par.alert("numbers_cb")
+ par.no_par()
+
+ par.ints(0, 0)
+ print (" === Testing int ===")
+
+ o = par.ints(1, 2, 3)
+ par.alert("xx: " + o.xx)
+ par.alert("yy: " + o.yy)
+
+ par.par_by_ref(1, 2, 3)
+
+
+ print (" === Testing floats ===")
+ a = 7.32
+ b = -21474.5134
+ o = par.floats(a, b)
+
+ par.alert("bb: " + o.bb)
+ par.alert("cc: " + o.cc)
+}
+
+function cb3(par)
+{
+ print("callback called for: " + par.text)
+ /*
+ par.alert("getting size")
+
+ o = par.size
+ par.alert("W: " + o.w)
+ par.alert("H: " + o.h)
+
+ o = par.position
+ par.alert("X: " + o.x)
+ par.alert("Y: " + o.y)
+ */
+}
+
+
+var win = elm.ElmWin({
+ evas_obj_size: { w: 300, h: 350},
+ elm_obj_win_title: "My JS window",
+
+ elements: {
+ bg: elm.ElmBg({
+ // text: "Hello",
+ evas_obj_size: {w: 210, h: 60},
+ elm_obj_bg_color: {r: 0, g: 245, b: 255, a: 255},
+ }),
+ shalom_bt: elm.ElmButton({
+ // text: "Hello",
+ evas_obj_position : {x: 30, y: "asdf"},
+ evas_obj_size: {w: 210, h: 60},
+ evas_obj_color: {r: 159, g: 245, b: 255, a: 255},
+ /*
+ eo_ev_callback_add : cb_add,
+ eo_ev_callback_del : cb_del,
+ ev_clicked : cb3
+ */
+ }),
+ ba: elm.ElmButton({
+// text: "(B) ADD cb",
+ evas_obj_position : {x: 30, y: 100},
+ evas_obj_size: {w: 100, h: 50},
+ evas_obj_color: {r: 255, g: 0, b: 255, a: 255},
+// evas_obj_visibility : false,
+ // ev_clicked : cb3
+ }),
+
+ }
+
+});
+/*
+var w = elm.ElwWin({
+ size: { w: 300, h: 350},
+ elements: {
+
+
+ but1: elm.ElwButton({
+ text: "1st but in box",
+ //position : { x: 250, y: 100},
+ //size: { w: 90, h: 20},
+ color: { r: 255, g: 0, b: 255, a: 255},
+ ev_clicked : thaw_cb
+ }),
+
+ but2: elm.ElwButton({
+ text: "2nd but in box",
+ //position : { x: 270, y: 150},
+ //size: { w: 90, h: 50},
+ color: {r: 240, g: 240, b: 0, a: 255},
+ ev_clicked : freeze_this
+ }),
+
+ box : elm.ElwBox ({
+ position : {x: 140, y: 170},
+ size: {w: 100, h: 50},
+ }),
+
+ pb: elm.ElwButton({
+ text: "But in BB (num)",
+ //position : { x: 310, y: 150},
+ //size: { w: 70, h: 50},
+ color: {r: 240, g: 240, b: 245, a: 255},
+ ev_clicked : numbers_cb
+ }),
+
+ ebb: elm.ElwBoxedbutton({
+ text: "BoxedButton",
+ position : {x: 30, y: 170},
+ size: { w: 100, h: 50},
+ color: { r: 100, g: 85, b: 255, a: 255},
+ //ev_clicked : freeze_all,
+ }),
+ }
+});
+*/
+var w = elm.realise(win);
+
+print ("========= DPI ========")
+print (w.elm_obj_win_screen_dpi)
+print ("====================")
+
+print ("==== call for bitton size =====")
+var s = w.elements.ba.evas_obj_size
+print (s)
+print ("==== end call for button size =====")
+
+print ("==== Window size =====")
+print( w.evas_obj_size )
+print ("====================")
+
+//var dpi = e.elements.w.elm_obj_win_screen_dpi
+//print ("DPI: " + dpi)
+
+print ("====================")
+print (w.elm_obj_win_aspect)
+w.elm_obj_win_center(1, 1)
+
+
+
+w.elements.ba.evas_obj_visibility = false
+w.elements.ba.elm_wdg_text_part_set(null, "Button")
+w.elements.shalom_bt.elm_wdg_text_part_set(null, "Big Button")
+w.elements.ba.evas_obj_visibility = true
+var t = w.elements.ba.elm_wdg_text_part_get(null)
+print ("====================")
+print(t)
+print ("====================")
+
+/*
+
+e.elements.box.pack_end(e.elements.but1)
+
+e.elements.box.pack_end(e.elements.but2)
+e.elements.ebb.pack_end(e.elements.pb)
+
+//e.elements.shalom_bt.eo_ev_callback_add = cb_add
+e.elements.shalom_bt.ev_clicked = cb3
+
+
+
+elm.ElwWin.event_global_freeze()
+elm.ElwWin.event_global_thaw()
+
+
+
+
+
+*/
diff --git a/examples/elw_button.js b/examples/elw_button.js
new file mode 100644
index 0000000..b2eefd3
--- /dev/null
+++ b/examples/elw_button.js
@@ -0,0 +1,159 @@
+//var elm = require('jse');
+var elm = require('jse');
+
+//var m = new elm.Mixin()
+
+function cb_add(par){
+ par.alert(par.text + ": calback_added")
+}
+
+function cb_del(par){
+ par.alert(par.text + ": calback_deleted")
+}
+
+//==============================
+var global_obj
+
+function freeze_this(par){
+ par.alert("Object: " + par.text)
+ par.alert("Freezing cb for this obj")
+ global_obj = par
+ par.event_freeze()
+ par.alert("Freeze count = " + par.event_freeze_get())
+}
+
+function thaw_cb(par){
+ par.alert("Thawing cb for global_obj")
+ global_obj.event_thaw()
+}
+//==================================
+
+function numbers_cb(par){
+ par.alert("numbers_cb")
+ par.no_par()
+
+ par.ints(0, 0)
+ print (" === Testing int ===")
+
+ o = par.ints(1, 2, 3)
+ par.alert("xx: " + o.xx)
+ par.alert("yy: " + o.yy)
+
+ par.par_by_ref(1, 2, 3)
+
+
+ print (" === Testing floats ===")
+ a = 7.32
+ b = -21474.5134
+ o = par.floats(a, b)
+
+ par.alert("bb: " + o.bb)
+ par.alert("cc: " + o.cc)
+}
+
+function cb3(par)
+{
+ par.alert("callback called for: " + par.text)
+ par.alert("getting size")
+
+ o = par.size
+ par.alert("W: " + o.w)
+ par.alert("H: " + o.h)
+
+ o = par.position
+ par.alert("X: " + o.x)
+ par.alert("Y: " + o.y)
+}
+
+
+
+var w = elm.ElwWin({
+ size: { w: 300, h: 350},
+ elements: {
+ shalom_bt: elm.ElwButton({
+ text: "Hello",
+ position : {x: 30, y: 30},
+ size: {w: 210, h: 60},
+ color: {r: 159, g: 245, b: 255, a: 255},
+ eo_ev_callback_add : cb_add,
+ eo_ev_callback_del : cb_del,
+ ev_clicked : cb3
+ }),
+
+ ba: elm.ElwButton({
+ text: "(B) ADD cb",
+ position : {x: 30, y: 100},
+ size: {w: 100, h: 50},
+ color: {r: 255, g: 0, b: 255, a: 255},
+ ev_clicked : cb3
+ }),
+
+ red_bt: elm.ElwBoxedbutton({
+ text: "Red button",
+ position : {x: 140, y: 100},
+ size: {w: 100, h: 50},
+ color: {r: 255, g: 0, b: 5, a: 255},
+ ev_clicked : cb3
+
+ }),
+
+ but1: elm.ElwButton({
+ text: "1st but in box",
+ //position : { x: 250, y: 100},
+ //size: { w: 90, h: 20},
+ color: { r: 255, g: 0, b: 255, a: 255},
+ ev_clicked : thaw_cb
+ }),
+
+ but2: elm.ElwButton({
+ text: "2nd but in box",
+ //position : { x: 270, y: 150},
+ //size: { w: 90, h: 50},
+ color: {r: 240, g: 240, b: 0, a: 255},
+ ev_clicked : freeze_this
+ }),
+
+ box : elm.ElwBox ({
+ position : {x: 140, y: 170},
+ size: {w: 100, h: 50},
+ }),
+
+ pb: elm.ElwButton({
+ text: "But in BB (num)",
+ //position : { x: 310, y: 150},
+ //size: { w: 70, h: 50},
+ color: {r: 240, g: 240, b: 245, a: 255},
+ ev_clicked : numbers_cb
+ }),
+
+ ebb: elm.ElwBoxedbutton({
+ text: "BoxedButton",
+ position : {x: 30, y: 170},
+ size: { w: 100, h: 50},
+ color: { r: 100, g: 85, b: 255, a: 255},
+ //ev_clicked : freeze_all,
+ }),
+ }
+});
+
+
+var e = elm.realise(w);
+
+
+e.elements.box.pack_end(e.elements.but1)
+e.elements.box.pack_end(e.elements.but2)
+e.elements.ebb.pack_end(e.elements.pb)
+
+//e.elements.shalom_bt.eo_ev_callback_add = cb_add
+e.elements.shalom_bt.ev_clicked = cb3
+
+
+
+elm.ElwWin.event_global_freeze()
+elm.ElwWin.event_global_thaw()
+
+
+
+
+
+
diff --git a/examples/elw_button_new_names.js b/examples/elw_button_new_names.js
new file mode 100644
index 0000000..7dd40b5
--- /dev/null
+++ b/examples/elw_button_new_names.js
@@ -0,0 +1,162 @@
+//var elm = require('jse');
+var elm = require('jse');
+//var elm = require('/opt/e17/lib/elev8/linux-gnu-i686-0.1.0/libjse.so');
+
+//var m = new elm.Mixin()
+
+function cb_add(par){
+ par.elw_alert_alert(par.elw_button_text + ": calback_added")
+}
+
+function cb_del(par){
+ par.elw_alert_alert(par.elw_button_text + ": calback_deleted")
+}
+
+//==============================
+var global_obj
+
+function freeze_this(par){
+ par.elw_alert_alert("Object: " + par.elw_button_text)
+ par.elw_alert_alert("Freezing cb for this obj")
+ global_obj = par
+ par.event_freeze()
+ par.elw_alert_alert("Freeze count = " + par.event_freeze_get())
+}
+
+function thaw_cb(par){
+ par.elw_alert_alert("Thawing cb for global_obj")
+ global_obj.event_thaw()
+}
+//==================================
+
+function numbers_cb(par){
+ par.elw_alert_alert("numbers_cb")
+ par.no_par()
+
+ par.ints(0, 0)
+ print (" === Testing int ===")
+
+ o = par.ints(1, 2, 3)
+ par.elw_alert_alert("xx: " + o.xx)
+ par.elw_alert_alert("yy: " + o.yy)
+
+ par.par_by_ref(1, 2, 3)
+
+
+ print (" === Testing floats ===")
+ a = 7.32
+ b = -21474.5134
+ o = par.floats(a, b)
+
+ par.elw_alert_alert("bb: " + o.bb)
+ par.elw_alert_alert("cc: " + o.cc)
+}
+
+function cb3(par, f)
+{
+ print(par)
+ print(f)
+ par.elw_alert_alert("callback called for: " + par.elw_button_text)
+ par.elw_alert_alert("getting size")
+
+ o = par.exevas_obj_size
+ par.elw_alert_alert("W: " + o.w)
+ par.elw_alert_alert("H: " + o.h)
+
+ o = par.exevas_obj_position
+ par.elw_alert_alert("X: " + o.x)
+ par.elw_alert_alert("Y: " + o.y)
+}
+
+
+
+var w = elm.ElwWin({
+ exevas_obj_size: { w: 300, h: 350},
+ elements: {
+ shalom_bt: elm.ElwButton({
+ elw_button_text: "Hello",
+ exevas_obj_position : {x: 30, y: 30},
+ exevas_obj_size: {w: 210, h: 60},
+ exevas_obj_color: {r: 159, g: 245, b: 255, a: 255},
+ eo_ev_callback_add : cb_add,
+ eo_ev_callback_del : cb_del,
+ ev_clicked : cb3
+ }),
+
+ ba: elm.ElwButton({
+ elw_button_text: "(B) ADD cb",
+ exevas_obj_position : {x: 30, y: 100},
+ exevas_obj_size: {w: 100, h: 50},
+ exevas_obj_color: {r: 255, g: 0, b: 255, a: 255},
+ ev_clicked : cb3
+ }),
+
+ red_bt: elm.ElwBoxedbutton({
+ elw_button_text: "Red button",
+ exevas_obj_position : {x: 140, y: 100},
+ exevas_obj_size: {w: 100, h: 50},
+ exevas_obj_color: {r: 255, g: 0, b: 5, a: 255},
+ ev_clicked : cb3
+
+ }),
+
+ but1: elm.ElwButton({
+ elw_button_text: "1st but in box",
+ //exevas_obj_position : { x: 250, y: 100},
+ //exevas_obj_size: { w: 90, h: 20},
+ exevas_obj_color: { r: 255, g: 0, b: 255, a: 255},
+ ev_clicked : thaw_cb
+ }),
+
+ but2: elm.ElwButton({
+ elw_button_text: "2nd but in box",
+ //exevas_obj_position : { x: 270, y: 150},
+ //exevas_obj_size: { w: 90, h: 50},
+ exevas_obj_color: {r: 240, g: 240, b: 0, a: 255},
+ ev_clicked : freeze_this
+ }),
+
+ box : elm.ElwBox ({
+ exevas_obj_position : {x: 140, y: 170},
+ exevas_obj_size: {w: 100, h: 50},
+ }),
+
+ pb: elm.ElwButton({
+ elw_button_text: "But in BB (num)",
+ //exevas_obj_position : { x: 310, y: 150},
+ //exevas_obj_size: { w: 70, h: 50},
+ exevas_obj_color: {r: 240, g: 240, b: 245, a: 255},
+ ev_clicked : numbers_cb
+ }),
+
+ ebb: elm.ElwBoxedbutton({
+ elw_button_text: "BoxedButton",
+ exevas_obj_position : {x: 30, y: 170},
+ exevas_obj_size: { w: 100, h: 50},
+ exevas_obj_color: { r: 100, g: 85, b: 255, a: 255},
+ //ev_clicked : freeze_all,
+ }),
+ }
+});
+
+
+var e = elm.realise(w);
+
+
+e.elements.box.elw_box_pack_end(e.elements.but1)
+e.elements.box.elw_box_pack_end(e.elements.but2)
+e.elements.ebb.elw_box_pack_end(e.elements.pb)
+
+//e.elements.shalom_bt.eo_ev_callback_add = cb_add
+e.elements.shalom_bt.ev_clicked = cb3
+
+
+
+elm.ElwWin.event_global_freeze()
+elm.ElwWin.event_global_thaw()
+
+
+
+
+
+
diff --git a/examples/elw_button_old.js b/examples/elw_button_old.js
new file mode 100644
index 0000000..f71790a
--- /dev/null
+++ b/examples/elw_button_old.js
@@ -0,0 +1,247 @@
+var elm = require('elm');
+//var m = new elm.Mixin()
+
+function cb_add(par){
+ par.alert(par.text + ": calback_added")
+}
+
+function cb_del(par){
+ par.alert(par.text + ": calback_deleted")
+}
+
+//==============================
+var global_obj
+
+function freeze_this(par){
+ par.alert("Object: " + par.text)
+ par.alert("Freezing cb for this obj")
+ global_obj = par
+ par.event_freeze()
+ par.alert("Freeze count = " + par.event_freeze_get())
+}
+
+function thaw_cb(par){
+ par.alert("Thawing cb for global_obj")
+ global_obj.event_thaw()
+}
+//==================================
+
+function numbers_cb(par){
+ par.alert("numbers_cb")
+ par.no_par()
+
+ par.ints(0, 0)
+ print (" === Testing int ===")
+
+ o = par.ints(1, 2, 3)
+ par.alert("xx: " + o.xx)
+ par.alert("yy: " + o.yy)
+
+ par.par_by_ref(1, 2, 3)
+
+ // par.floats(0.6, 43.345)
+ print (" === Testing floats ===")
+ a = 7.32
+ b = -21474.5134
+ o = par.floats(a, b)
+
+ par.alert("bb: " + o.bb)
+ par.alert("cc: " + o.cc)
+
+
+}
+
+function cb3(par){
+ par.alert("callback called for: " + par.text)
+ par.alert("getting size")
+
+ o = par.size
+ par.alert("W: " + o.w)
+ par.alert("H: " + o.h)
+
+ o = par.position
+ par.alert("X: " + o.x)
+ par.alert("Y: " + o.y)
+}
+
+var w = elm.ElwWin({
+ size: { w: 300, h: 350},
+ elements: {
+ shalom_bt: elm.ElwButton({
+ text: "שלום",
+ position : { x: 30, y: 30},
+ size: { w: 210, h: 60},
+ color: { r: 159, g: 245, b: 255, a: 255},
+ eo_ev_callback_add : cb_add,
+ eo_ev_callback_del : cb_del,
+ ev_clicked : cb3
+ }),
+
+ ba: elm.ElwButton({
+ text: "(B) ADD cb",
+ position : { x: 30, y: 100},
+ size: { w: 100, h: 50},
+ color: { r: 255, g: 0, b: 255, a: 255},
+ ev_clicked : cb3
+ }),
+
+ red_bt: elm.ElwBoxedbutton({
+ text: "Красная кнопка",
+ position : { x: 140, y: 100},
+ size: { w: 100, h: 50},
+ color: { r: 255, g: 0, b: 5, a: 255},
+ //ev_clicked : cb2
+
+ }),
+
+ but1: elm.ElwButton({
+ text: "1st but in box (thaw_cb)",
+ //position : { x: 250, y: 100},
+ //size: { w: 90, h: 20},
+ color: { r: 255, g: 0, b: 255, a: 255},
+ ev_clicked : thaw_cb
+ }),
+
+ but2: elm.ElwButton({
+ text: "2nd but in box (freeze_this)",
+ //position : { x: 270, y: 150},
+ //size: { w: 90, h: 50},
+ color: { r: 240, g: 240, b: 0, a: 255},
+ ev_clicked : freeze_this
+
+ }),
+
+ box : elm.ElwBox ({
+ position : {x: 140, y: 170},
+ size: { w: 50, h: 100},
+
+ }),
+
+ pb: elm.ElwButton({
+ text: "But in BB (num)",
+ // position : { x: 310, y: 150},
+ // size: { w: 70, h: 50},
+ color: { r: 240, g: 240, b: 245, a: 255},
+ ev_clicked : numbers_cb
+
+ }),
+
+ ebb: elm.ElwBoxedbutton({
+ text: "BoxedButton",
+ position : { x: 30, y: 170},
+ size: { w: 100, h: 50},
+ color: { r: 100, g: 85, b: 255, a: 255},
+ //ev_clicked : freeze_all,
+ }),
+
+/*
+ bb2: elm.ElwBoxedbutton({
+ text: "BoxedButton",
+// mixin: "hello, שלום, привет",
+ position : { x: 180, y: 250},
+ size: { w: 100, h: 65},
+ color: { r: 0, g: 255, b: 0, a: 255},
+ ev_clicked : cb2,
+ // on_test : cb1,
+
+/*
+ disabled1: elm.Button({
+ text: "Dis1",
+ x: 10,
+ y: 160,
+ width: 100,
+ height: 15,
+ enabled: true,
+ on_click : ff,
+ }),
+
+ disabled2: elm.Button({
+ text: "Dis2",
+ x: 10,
+ y: 190,
+ width: 100,
+ height: 15,
+ enabled: true,
+ on_click : ff,
+ }),
+*/
+/*
+ bb2: elm.ElwBoxedbutton({
+ text: "BoxedButton",
+// mixin: "hello, שלום, привет",
+ position : { x: 180, y: 250},
+ size: { w: 100, h: 65},
+ color: { r: 0, g: 255, b: 0, a: 255},
+ ev_clicked : cb2,
+ // on_test : cb1,
+
+ elements : {
+ label_only: elm.ElwButton({
+ color: { r: 10, g: 20, b: 30, a: 255},
+ text: "button in the boxedbutton!",
+ size: { w: 80, h: 65},
+ }),
+ },
+ }),
+*/
+
+/*
+ disabled: elm.Button({
+ text: "Don",
+ x: 10,
+ y: 160,
+ width: 100,
+ height: 300,
+ enabled: true
+ }),
+
+ label_only: elm.Button({
+ weight: { x: 1.0, y: 1.0 },
+ style: "anchor",
+ text: "hello!",
+ x: 110,
+ y: 260,
+ width: 80,
+ height: 65
+ }),
+*/
+/*
+ hbox2 : elm.ElwBox ({
+ position : {x: 90, y: 180},
+
+ elements : {
+ label_only2: elm.ElwButton({
+ text: "button in the box! + exit()",
+ // pos : {x: 110, y: 260},
+ color: { r: 0, g: 5, b: 255, a: 255},
+ size: { w: 80, h: 65},
+ on_test: function(par){
+ par.alert("close application")
+ elm.exit()
+ }
+
+ }),
+ },
+ }),
+*/
+
+ }
+});
+
+
+var e = elm.realise(w);
+
+e.elements.box.pack_end(e.elements.but1)
+e.elements.box.pack_end(e.elements.but2)
+e.elements.ebb.pack_end(e.elements.pb)
+
+//e.elements.shalom_bt.eo_ev_callback_add = cb_add
+e.elements.shalom_bt.ev_clicked = cb3
+
+
+
+elm.ElwWin.event_global_freeze()
+elm.ElwWin.event_global_thaw()
+
+
+
diff --git a/examples/elw_eoisa.js b/examples/elw_eoisa.js
new file mode 100644
index 0000000..636f362
--- /dev/null
+++ b/examples/elw_eoisa.js
@@ -0,0 +1,24 @@
+//var elm = require('jstest');
+var elm = require('jseoisa');
+
+var so = new elm.Simple()
+
+so.a = 2
+a = so.a
+a2 = so.a_square
+a3 = so.a_power_3
+print("a = " + a + "; a^2 = " + a2 + "; a^3 = " + a3)
+
+print("*******************************\n")
+
+
+var co = new elm.Complex()
+co.a = 3
+a = co.a
+a2 = co.a_square
+a3 = co.a_power_3
+print("a = " + a + "; a^2 = " + a2 + "; a^3 = " + a3)
+
+elm.exit()
+
+
diff --git a/examples/elw_mixin.js b/examples/elw_mixin.js
new file mode 100644
index 0000000..e505714
--- /dev/null
+++ b/examples/elw_mixin.js
@@ -0,0 +1,18 @@
+var elm = require('jsmixin');
+
+var obj1 = new elm.Simple({a:5, b:5})
+
+obj1.a = 1
+obj1.b = 2
+sum = obj1.ab_sum
+
+print("Sum for obj1: " + sum)
+
+
+var obj2 = elm.Simple({a:3, b:4})
+var e = elm.realise(obj2)
+
+sum = e.ab_sum
+print("Sum for obj1: " + sum)
+
+elm.exit()
diff --git a/examples/elw_signal.js b/examples/elw_signal.js
new file mode 100644
index 0000000..ef47d46
--- /dev/null
+++ b/examples/elw_signal.js
@@ -0,0 +1,54 @@
+var elm = require('jssignal');
+
+
+function cb_add(par){
+ print("Callback on callback adding")
+}
+
+var poo = function(pa){
+ print("Callback on changing: a = " + pa.a);
+}
+
+
+var ms = new elm.Simple()
+
+print("\nSetting a...")
+ms.a = 12345678
+print("a = " + ms.a + "\n")
+
+print("\nAdding callback...")
+ms.eo_ev_callback_add = cb_add
+ms.ev_a_changed = poo
+
+print("\nSetting b(a) to 896...")
+ms.b = 896
+print("Reading \"b\" (no getter for \"b\" prop): " + ms.b)
+
+
+print("\nSetting c(a) to 123...")
+ms.c = 123
+print("Reading \"c\" (no setter for \"c\" prop, so it should be 896): " + ms.c + "\n")
+
+
+
+print("\nFreezing callback...")
+ms.event_freeze()
+ms.a = 123
+
+print("\nThawing callback...")
+ms.event_thaw()
+ms.a = 123
+
+
+
+/*
+
+var ss = elm.realise(elm.Simple({a:5, on_change:poo, b:55}))
+
+ss.ev_a_changed = cb
+ss.a = 123
+*/
+
+elm.exit()
+
+
diff --git a/examples/evas_elem_test.py b/examples/evas_elem_test.py
new file mode 100644
index 0000000..62d1a14
--- /dev/null
+++ b/examples/evas_elem_test.py
@@ -0,0 +1,66 @@
+# -*- coding: UTF-8 -*-
+import sys
+
+from eorepo.evas_elem_py import elm_init, elm_run
+#from eobase import EoBase
+#from evas_lib.py.evas_l import Evas, EvasObjectRectangle, EvasObjectLine
+from eorepo.evas_elem_py import ElmWin, ElmBg, ElmBox, ElmButton
+
+print "Initializing Elementary..."
+print "Init res:", elm_init(sys.argv)
+print ""
+
+w1 = ElmWin(None, "my win name", 0)
+w1.elm_obj_win_title_set("first_title")
+t = w1.elm_obj_win_title_get()
+print "title:", t
+w1.evas_obj_size_set(370, 350)
+xx,yy = w1.evas_obj_size_get()
+print "size : " , xx, yy
+w1.evas_obj_visibility_set(1)
+v = w1.evas_obj_visibility_get()
+print "v=", v
+
+bg = ElmBg(w1)
+bg.evas_obj_size_hint_weight_set(1.0, 1.0)
+w1.elm_obj_win_resize_object_add(bg)
+bg.evas_obj_visibility_set(1)
+
+
+box = ElmBox(w1)
+box.evas_obj_size_hint_weight_set(1.0, 1.0)
+w1.elm_obj_win_resize_object_add(box)
+box.evas_obj_visibility_set(1)
+
+but = ElmButton(w1)
+box.elm_obj_box_pack_end(but)
+but.evas_obj_visibility_set(1)
+but.evas_obj_color_set(255, 255, 0, 255)
+but.elm_wdg_text_part_set(None, "Button")
+but.evas_obj_size_set(100, 30)
+
+d = w1.elm_obj_win_screen_dpi_get()
+print d
+d = w1.elm_obj_win_role_get()
+print d
+#d = w1.fullscreen_set(1)
+
+
+elm_run()
+
+"""
+ev = Evas(None)
+rect = EvasObjectRectangle(ev)
+line = EvasObjectLine(ev)
+
+rect.color_set(255, 55, 0, 255)
+r, g, b, a = rect.color_get()
+print "%d %d %d %d"%(r, g, b, a)
+print "=================="
+
+line.xy_set(0, 0, 10, 20)
+r, g, b, a = line.xy_get()
+print "%d %d %d %d"%(r, g, b, a)
+print "=================="
+"""
+
diff --git a/examples/evas_lib_test.py b/examples/evas_lib_test.py
index 248ca86..f0f289f 100644
--- a/examples/evas_lib_test.py
+++ b/examples/evas_lib_test.py
@@ -4,7 +4,7 @@ import sys
from base.eodefault import py_elm_init, elem_run
from eobase import EoBase
#from evas_lib.py.evas_l import Evas, EvasObjectRectangle, EvasObjectLine
-from tmp2.evas_l import Evas, EvasObjectRectangle, EvasObjectLine
+from evas_lib.py.evas_l import Evas, EvasObjectRectangle, EvasObjectLine
ev = Evas(None)
rect = EvasObjectRectangle(ev)
diff --git a/examples/evas_test.py b/examples/evas_test.py
index fced191..2a15b9b 100644
--- a/examples/evas_test.py
+++ b/examples/evas_test.py
@@ -3,7 +3,7 @@ import sys
from base.eodefault import py_elm_init, elem_run
from eobase import EoBase
-from evas.py.py_evas import ElwWin, ElwBox, ElwButton, ElwBoxedbutton, EvasObject
+from evas.py.evas_py import ElwWin, ElwBox, ElwButton, ElwBoxedbutton, ExEvasObject
print "Initializing Elementary..."
@@ -41,19 +41,20 @@ def properties_cb(obj):
######################## setting data ##########################
def data_cb(obj):
- print "setting data"
+ print "setting data - int : 5"
i = 5
obj.data_set("int", i)
i = 999999
f = obj.data_get("int")
+ print "getting data"
print f, type(f)
f = obj.data_del("int")
#ebb.data_set("list", ["a", "bb", "cc", "asdfasfd", "1234124", "asdf", "123", "12"])
-#ebb.data_set("list", ["xx", "yy", "zz"])
-#f = ebb.data_get("list")
-#print f, type(f)
+ #ebb.data_set("list", ["xx", "yy", "zz"])
+ #f = ebb.data_get("list")
+ #print f, type(f)
#l = ["a", "b", "c", "asd", "123"]
#ebb.data_set("list2", l)
@@ -62,12 +63,14 @@ def data_cb(obj):
# f = obj.data_get("list2")
# print f, type(f)
+ print "setting data - char : string data"
obj.data_set("char", "string data")
f = obj.data_get("char")
print f, type(f)
obj.data_set("object",pb)
f = obj.data_get("object")
+ print "getting data"
print f, type(f)
#f.text_set("neeew name")
#f = ebb.data_del("object")
@@ -133,21 +136,21 @@ def num_cb(obj):
def cb_add(o):
- o.alert("obj: " + o.text_get() + "; Added: cb_add")
+ o.alert(" obj: " + o.text_get() + "; cb_added")
def cb_del(o):
- o.alert("obj: " + o.text_get() + "; Added: cb_del")
+ o.alert(" obj: " + o.text_get() + "; cb_deleted")
def thaw_ba(o):
- print "size:", o.size_get()
+ print " size:", o.size_get()
p_but.event_thaw()
def cb_clicked(o):
- o.alert("obj: " + o.text_get())
+ o.alert(" obj: " + o.text_get())
w1 = ElwWin(None)
-w1.size_set(270, 350)
+w1.size_set(370, 350)
w1.visibility_set(1)
@@ -160,11 +163,14 @@ bt.color_set(159, 245, 255, 255)
bt.text_set("Hello")
bt.visibility_set(1)
+print "> adding cb on CALLBACK_ADD"
bt.event_callback_priority_add(EoBase.CALLBACK_ADD, -100, cb_add)
+print "> adding cb on CALLBACK_DEL"
bt.event_callback_priority_add(EoBase.CALLBACK_DEL, 0, cb_del)
-print "adding clicked"
+print "> adding cb on CLICKED"
bt.event_callback_priority_add(ElwButton.CLICKED, -100, cb_clicked)
#bt.event_callback_priority_add(ElwButton.CLICKED, -200, thaw_ba)
+print "> adding cb on CLICKED"
bt.event_callback_priority_add(ElwButton.CLICKED, -200, properties_cb)
del w
@@ -206,7 +212,7 @@ but.visibility_set(1)
#but.position_set(250, 100)
but.size_set(90, 20)
but.color_set(255, 0, 255, 255)
-but.text_set("1st button in box")
+but.text_set("1st button in box - gl_thaw")
but.event_callback_priority_add(ElwButton.CLICKED, 0, thaw_global)
@@ -216,7 +222,7 @@ but2.visibility_set(1)
#but2.position_set(270, 150)
#but2.size_set(90, 50)
but2.color_set(255, 255, 0, 255)
-but2.text_set("2nd button in box")
+but2.text_set("2nd button in box - freeze cb")
but2.event_callback_priority_add(ElwButton.CLICKED, 0, freeze_me)
diff --git a/examples/evas_test2.py b/examples/evas_test2.py
new file mode 100644
index 0000000..900f2da
--- /dev/null
+++ b/examples/evas_test2.py
@@ -0,0 +1,154 @@
+# -*- coding: UTF-8 -*-
+import sys
+
+
+from eorepo.eobase import EoBase
+from eorepo.evas_py import ElwWin, ElwBox, ElwButton, ElwBoxedbutton, ExEvasObject
+from eorepo.evas_py import elm_run, elm_init
+
+
+lst = [56, "elm", 56.76]
+
+print "Initializing Elementary..."
+print "Init res:", elm_init(sys.argv)
+print ""
+
+global_obj = None
+
+
+def freeze_me(obj):
+ global global_obj
+ global_obj = obj
+ obj.event_freeze()
+ obj.elw_alert_alert("obl: " + obj.text_get() + "; freezing events; count: " + str(obj.event_freeze_get()))
+
+
+def thaw_global(obj):
+ global global_obj
+ if global_obj.event_freeze_get() == 0:
+ return
+ obj.alert("thawing global")
+ global_obj.event_thaw()
+
+
+######################## setting data ##########################
+def properties_cb(obj, data):
+ a,b,c,d = obj.exevas_obj_color_get()
+ print "color : ", a, b, c, d
+ ww,hh = obj.exevas_obj_size_get()
+ xx,yy = obj.exevas_obj_position_get()
+ print "size : " + str((ww, hh)) + "; pos: " + str((xx, yy))
+
+ obj.exevas_obj_size_set(ww-1, hh)
+ obj.exevas_obj_color_set(a-5, b, c-10, d)
+
+######################## setting data ##########################
+def data_cb(obj, data):
+ print "setting data - int : 5"
+ i = 5
+ obj.data_set("int", i)
+ i = 999999
+
+ f = obj.data_get("int")
+ print "getting data"
+ print f, type(f)
+ f = obj.data_del("int")
+
+#ebb.data_set("list", ["a", "bb", "cc", "asdfasfd", "1234124", "asdf", "123", "12"])
+ #ebb.data_set("list", ["xx", "yy", "zz"])
+ #f = ebb.data_get("list")
+ #print f, type(f)
+
+#l = ["a", "b", "c", "asd", "123"]
+#ebb.data_set("list2", l)
+#l[0] = "12341234124"
+#del l
+# f = obj.data_get("list2")
+# print f, type(f)
+
+ print "setting data - char : string data"
+ obj.data_set("char", "string data")
+ f = obj.data_get("char")
+ print f, type(f)
+
+ obj.data_set("object",pb)
+ f = obj.data_get("object")
+ print "getting data"
+ print f, type(f)
+#f.text_set("neeew name")
+#f = ebb.data_del("object")
+
+
+
+
+def cb_add(o, data):
+ o.elw_alert_alert(" obj: " + o.elw_button_text_get() + "; cb_added")
+
+def cb_del(o, data):
+ o.elw_alert_alert(" obj: " + o.elw_button_text_get() + "; cb_deleted")
+
+def thaw_ba(o, data):
+ print " size:", o.size_get()
+ p_but.event_thaw()
+
+def cb_clicked(o, data):
+ print o
+ o.elw_alert_alert(" obj: " + o.elw_button_text_get())
+ print "=== data ==="
+ d = data
+ print d
+ print "======"
+ lst.append("!")
+
+
+w1 = ElwWin(None)
+w1.exevas_obj_size_set(370, 350)
+w1.exevas_obj_visibility_set(1)
+
+
+w = w1
+
+bt = ElwButton(w)
+bt.exevas_obj_position_set(30, 30)
+bt.exevas_obj_size_set(210, 60)
+bt.exevas_obj_color_set(159, 245, 255, 255)
+bt.elw_button_text_set("Hello")
+bt.exevas_obj_visibility_set(1)
+
+print "\n> adding cb on CALLBACK_ADD"
+cb_obj1 = (cb_add, None)
+bt.event_callback_priority_add(EoBase.CALLBACK_ADD, -100, cb_obj1)
+print "\n> adding cb on CALLBACK_DEL"
+cb_obj2 = (cb_del, None)
+bt.event_callback_priority_add(EoBase.CALLBACK_DEL, 0, cb_obj2)
+print "\n> adding cb on CLICKED"
+
+cb_obj3 = (cb_clicked, None)
+bt.event_callback_priority_add(ElwButton.CLICKED, -100, cb_obj3)
+#bt.event_callback_priority_add(ElwButton.CLICKED, -200, thaw_ba)
+print "\n> adding cb on CLICKED"
+cb_obj4 = (properties_cb, None)
+bt.event_callback_priority_add(ElwButton.CLICKED, -200, cb_obj4)
+
+del w
+w = bt.parent_get()
+print type(w)
+
+ba = ElwButton(w);
+ba.exevas_obj_visibility_set(1)
+ba.exevas_obj_position_set(30, 100)
+ba.elw_button_text_set("(B) ADD cb")
+ba.exevas_obj_size_set(100, 50)
+ba.exevas_obj_color_set(255, 0, 255, 255)
+
+
+
+cb_obj5 = (cb_clicked, lst)
+print cb_obj5
+ba.event_callback_priority_add(ElwButton.CLICKED, 0, cb_obj5)
+#ba.event_callback_del(ElwButton.CLICKED, cb_obj5)
+
+print "Running Elementary..."
+
+elm_run()
+
diff --git a/examples/mixin_test.py b/examples/mixin_test.py
index 869dc49..e7b44fd 100644
--- a/examples/mixin_test.py
+++ b/examples/mixin_test.py
@@ -4,20 +4,23 @@
import sys
from base.eodefault import *
-from mixin.mixin_py import Simple
+from mixin.py.mixin_py import Simple
sobj = Simple(None)
-print "ref: ", sobj.ref_get()
sobj.a_set(1)
sobj.b_set(2)
-sobj.a_get()
-sobj.b_get()
-sobj.ab_sum_get()
+a = sobj.a_get()
+b = sobj.b_get()
+s = sobj.ab_sum_get()
+print a + b + 2 == s
+"""
sobj.ab_sum_get()
sobj.ab_sum_get()
+"""
+print "suuuuper..."
super(Simple,sobj).ab_sum_get()
print "end"
diff --git a/examples/signal_test.py b/examples/signal_test.py
index 0f3dc9c..e86b3c3 100644
--- a/examples/signal_test.py
+++ b/examples/signal_test.py
@@ -1,52 +1,63 @@
# -*- coding: UTF-8 -*-
-from base.eodefault import *
-from eobase import EoBase
-from signals.signals_py import Simple
+from eoeoeo.eodefault import *#for CALLBACK_STOP
+from eoeoeo.eobase import EoBase
+from eoeoeo.signals_py import Simple
-def cb_del(o):
+def cb_del(o, d):
print "OBJECT DELETED"
-def cb_free(o):
+_o_cb_del = (cb_del, None)
+
+def cb_free(o, d):
print "OBJECT FREED"
-def cb_a_changed(o):
+_o_cb_free = (cb_free, None)
+
+def cb_a_changed(o, d):
print "A_CHANGED"
-def cb_a_changed_stop(o):
+_o_cb_a_changed = (cb_a_changed, None)
+
+def cb_a_changed_stop(o, d):
print "A_CHANGED_STOP"
return CALLBACK_STOP
+_o_cb_a_changed_stop = (cb_a_changed_stop, None)
-def cb_add(o):
+def cb_add(o, d):
print "CALBACK_ADD"
-def cb_del(o):
+
+_o_cb_add = (cb_add, None)
+
+def cb_del(o, d):
print "CALBACK_DEL"
+_o_cb_del = (cb_del, None)
+
print "Creating Simple object"
sobj = Simple(None)
-
print "adding event on EV_DELETING"
-sobj.event_callback_priority_add(EoBase.DEL, 0, cb_del)
+sobj.event_callback_priority_add(EoBase.DEL, 0, _o_cb_del)
print "adding event on CHANGING"
-sobj.event_callback_priority_add(Simple.A_CHANGED, 0, cb_a_changed)
+sobj.event_callback_priority_add(Simple.A_CHANGED, 0, _o_cb_a_changed)
print "adding event on EV_ADDING"
-sobj.event_callback_priority_add(EoBase.CALLBACK_ADD, 0, cb_add)
+sobj.event_callback_priority_add(EoBase.CALLBACK_ADD, 0, _o_cb_add)
print "adding 2 events on EV_DELETING"
-sobj.event_callback_priority_add(EoBase.CALLBACK_DEL, 0, cb_del)
-sobj.event_callback_priority_add(EoBase.CALLBACK_DEL, 0, cb_del)
+sobj.event_callback_priority_add(EoBase.CALLBACK_DEL, 0, _o_cb_del)
+sobj.event_callback_priority_add(EoBase.CALLBACK_DEL, 0, _o_cb_del)
print "adding event on CHANGING"
-sobj.event_callback_priority_add(Simple.A_CHANGED, 0, cb_a_changed)
+sobj.event_callback_priority_add(Simple.A_CHANGED, 0, _o_cb_a_changed)
print "adding 2nd event on ADDING"
-sobj.event_callback_priority_add(EoBase.CALLBACK_ADD, 0, cb_add)
+sobj.event_callback_priority_add(EoBase.CALLBACK_ADD, 0, _o_cb_add)
-sobj.a_set(4)
+sobj.simple_a_set(4)
print "deleting event on EV_ADDING"
sobj.event_callback_del(EoBase.CALLBACK_ADD, cb_add)
@@ -55,16 +66,15 @@ print "deleting event on EV_DELETING"
sobj.event_callback_del(EoBase.CALLBACK_DEL, cb_del)
print "adding 4 events on CHANGING, second is STOP"
-sobj.event_callback_priority_add(Simple.A_CHANGED, 0, cb_a_changed)
-sobj.event_callback_priority_add(Simple.A_CHANGED, 0, cb_a_changed_stop)
-sobj.event_callback_priority_add(Simple.A_CHANGED, 0, cb_a_changed)
-sobj.event_callback_priority_add(Simple.A_CHANGED, 0, cb_a_changed)
-
-sobj.a_set(5)
+sobj.event_callback_priority_add(Simple.A_CHANGED, 0, _o_cb_a_changed)
+sobj.event_callback_priority_add(Simple.A_CHANGED, 0, _o_cb_a_changed_stop)
+sobj.event_callback_priority_add(Simple.A_CHANGED, 0, _o_cb_a_changed)
+sobj.event_callback_priority_add(Simple.A_CHANGED, 0, _o_cb_a_changed)
+sobj.simple_a_set(5)
print "deleting event on CHANGING"
-res = sobj.event_callback_del(Simple.A_CHANGED, cb_a_changed)
+res = sobj.event_callback_del(Simple.A_CHANGED, _o_cb_a_changed)
print "Res:", res
print "explicitly calling ON_CHANGE"
@@ -74,7 +84,7 @@ print "Res:", res
sobj.event_global_freeze()
-sobj.a_set(89)
+sobj.simple_a_set(89)
#sobj.b_set(8)
#res = sobj.c_get()
diff --git a/examples/simple_test.py b/examples/simple_test.py
new file mode 100644
index 0000000..7d1e98a
--- /dev/null
+++ b/examples/simple_test.py
@@ -0,0 +1,14 @@
+# -*- coding: UTF-8 -*-
+
+from simple.py.simple_py import Simple, Mixin, Interface
+
+so = Simple(None)
+
+so.a_set(4)
+
+a = so.a_get()
+a2 = so.a_square_get()
+a3 = so.a_power_3_get()
+
+print "a = %d; a^2 = %d; a^3 = %d " %(a, a2, a3)
+
diff --git a/setup.py b/setup.py
new file mode 100644
index 0000000..237f12f
--- /dev/null
+++ b/setup.py
@@ -0,0 +1,91 @@
+from distutils.core import setup
+from distutils.extension import Extension
+
+#True, False, 'auto'
+USE_CYTHON = 'auto'
+
+import sys, commands
+
+def pkgconfig(_libs):
+ cf = commands.getoutput("pkg-config --cflags %s"%_libs).split()
+ ldf = commands.getoutput("pkg-config --libs %s"%_libs).split()
+ return (cf, ldf)
+
+(e_compile_args, e_link_args) = pkgconfig("eo")
+
+e_include_dirs = ["."]
+e_library_dirs = []
+e_libraries = []
+
+cmdclass = {}
+ext_modules = []
+
+
+if USE_CYTHON:
+ try:
+ from Cython.Distutils import build_ext
+ except ImportError:
+ if USE_CYTHON=='auto':
+ USE_CYTHON=False
+ else:
+ raise
+
+if USE_CYTHON:
+ print "Using Cython"
+ ext_modules += [
+ Extension("eorepo.eodefault", ['eorepo/eodefault.pyx'], include_dirs = e_include_dirs, library_dirs = e_library_dirs, libraries = e_libraries, extra_compile_args = e_compile_args, extra_link_args = e_link_args),
+ ]
+ ext_modules += [
+ Extension("eorepo.eobase", ['eorepo/eobase.pyx'], include_dirs = e_include_dirs, library_dirs = e_library_dirs, libraries = e_libraries, extra_compile_args = e_compile_args, extra_link_args = e_link_args),
+ ]
+
+ #cmdclass = {'build_ext' : build_ext}
+ cmdclass.update({'build_ext' : build_ext})
+else:
+ print "Not using Cython"
+ ext_modules += [
+ Extension("eorepo.eodefault", ['eorepo/eodefault.c'], include_dirs = e_include_dirs, library_dirs = e_library_dirs, libraries = e_libraries, extra_compile_args = e_compile_args, extra_link_args = e_link_args),
+ ]
+ ext_modules += [
+ Extension("eorepo.eobase", ['eorepo/eobase.c'], include_dirs = e_include_dirs, library_dirs = e_library_dirs, libraries = e_libraries, extra_compile_args = e_compile_args, extra_link_args = e_link_args),
+ ]
+
+
+setup(
+ cmdclass = cmdclass,
+ name='eoparser_eorepo',
+ version='0.1dev',
+ author='Yakov Goldberg',
+ author_email='yakov.goldberg@gmail.com',
+ packages=['eoparser', 'eorepo'],
+ package_data={'eoparser': ['data/types.xml'],
+ 'eorepo': ['EoBase.xml',
+ 'eodefault.pxd', 'eobase.pxd',
+ 'eodefault.c', 'eobase.c']
+ },
+ ext_modules = ext_modules,
+
+ data_files=[('/usr/local/share/eoparser/examples', ['examples/evas_elem_test.py',
+ 'examples/elm_elm.js',
+ 'examples/elw_button.js',
+ 'examples/elw_button_new_names.js',
+ 'examples/elw_button_old.js',
+ 'examples/elw_eoisa.js',
+ 'examples/elw_mixin.js',
+ 'examples/elw_signal.js',
+ 'examples/eoisa_test.py',
+ 'examples/evas_lib_test.py',
+ 'examples/evas_test.py',
+ 'examples/evas_test2.py',
+ 'examples/mixin_test.py',
+ 'examples/signal_test.py',
+ 'examples/simple_test.py'
+ ])],
+ scripts=['bin/eo_xml_gen.py', 'bin/eo_graph_gen.py',
+ 'bin/eo_py_gen.py', 'bin/eo_js_gen.py'],
+ license='GPL',
+ long_description=open('README').read(),
+ )
+
+
+
diff --git a/tests/test_data.in b/tests/test_data.in
new file mode 100644
index 0000000..d2512e2
--- /dev/null
+++ b/tests/test_data.in
@@ -0,0 +1,28 @@
+
+#define MY_TEST_CLASS_NAME "test_class_name"
+
+static const Eo_Op_Description _elm_pan_op_desc[] = {
+ EO_OP_DESCRIPTION(ELM_OBJ_PAN_SUB_ID_POS_SET, "description here"),
+ EO_OP_DESCRIPTION(ELM_OBJ_PAN_SUB_ID_POS_GET, "description here"),
+ EO_OP_DESCRIPTION_SENTINEL
+};
+
+static const Eo_Event_Description *event_desc[] = {
+ EO_EV_CALLBACK_ADD,
+ EO_EV_CALLBACK_DEL,
+ EO_EV_DEL,
+ NULL
+};
+
+static const Eo_Class_Description test_class_desc = {
+ EO_VERSION,
+ MY_TEST_CLASS_NAME,
+ EO_CLASS_TYPE_REGULAR,
+ EO_CLASS_DESCRIPTION_OPS(&ELM_OBJ_PAN_BASE_ID, _elm_pan_op_desc, ELM_OBJ_PAN_SUB_ID_LAST),
+ event_desc,
+ sizeof(Elm_Pan_Smart_Data),
+ _elm_pan_class_constructor,
+ NULL
+};
+
+EO_DEFINE_CLASS(class_get, &test_class_desc, parent, brother, NULL)
diff --git a/tests/tests.py b/tests/tests.py
new file mode 100644
index 0000000..35e0f66
--- /dev/null
+++ b/tests/tests.py
@@ -0,0 +1,98 @@
+import unittest
+import os
+from eoparser.xmlparser import XMLparser
+from eoparser.cparser import Cparser
+from eoparser.helper import dir_files_get, abs_path_get, isC, isH, isXML, normalize_names
+
+class testP(unittest.TestCase):
+
+ def setUp(self):
+ self.c_parser = Cparser(False)
+
+ def test_fetch_data(self):
+ f = open('test_data.in', 'r')
+ s = f.read()
+ f.close()
+
+ class_def_answer = {"class_get" : ["parent",
+ ["brother"],
+ "test_class_name",
+ "EO_CLASS_TYPE_REGULAR",
+ ["ELM_OBJ_PAN_BASE_ID",
+ [("ELM_OBJ_PAN_SUB_ID_POS_SET", "pos_set"),
+ ("ELM_OBJ_PAN_SUB_ID_POS_GET", "pos_get")],
+ "ELM_OBJ_PAN_SUB_ID_LAST"],
+ ["EO_EV_CALLBACK_ADD", "EO_EV_CALLBACK_DEL", "EO_EV_DEL"]
+ ]}
+ answer = class_def_answer
+
+ ret = self.c_parser.fetch_data(s)
+ self.assertEqual(ret, answer)
+
+ def test_isC(self):
+ self.assertTrue(isC("abc.c"))
+ self.assertTrue(isC("abc.cc"))
+ self.assertTrue(isC("abc.cpp"))
+ self.assertFalse(isC("abc.cp"))
+ self.assertFalse(isC("abc.def.c"))
+ self.assertTrue(isC("/abc/def/file.c"))
+ self.assertTrue(isC("/abc/def2.7/file.c"))
+
+ def test_isH(self):
+ self.assertTrue(isH("abc.h"))
+ self.assertFalse(isH("abc.c"))
+ self.assertFalse(isH("abc.def.h"))
+ self.assertTrue(isH("/abc/def/file.h"))
+ self.assertTrue(isH("/abc/def2.7/file.h"))
+
+ def test_isXML(self):
+ self.assertTrue(isXML("abc.xml"))
+ self.assertFalse(isXML("abc.h"))
+ self.assertFalse(isXML("abc.qwe.xml"))
+ self.assertTrue(isXML("/abc/def/abc.xml"))
+ self.assertTrue(isXML("/abc/py2.7/abc.xml"))
+
+ def test_abs_path_get(self):
+ _in = "test_data.in"
+ _in_list = [_in]
+ _out = _in
+ _out = os.path.expanduser(_out)
+ _out = os.path.abspath(_out)
+
+ self.assertEqual(abs_path_get(_in_list), [_out])
+
+ def test_normalize_names(self):
+ _in = ["hello world", "elm_Box", "evas Object-SmaRt", "EvAs-common InTeRface"]
+ _out = ["HelloWorld", "ElmBox", "EvasObjectSmart", "EvasCommonInterface"]
+
+ self.assertEqual(normalize_names(_in), _out)
+
+
+ def test_get_param_dir_from_comment(self):
+ s = """
+ @param[in,out] a
+ @param[in] a
+ @param[out] a
+ parem[in]
+ @param [in] a
+ @param [out] a
+ @param[in, out] a
+ @param in
+ @param [ in ]
+ @param [ out, in ]
+ @param sdf [ out ]
+ """
+ _out = ["in,out", "in", "out", "in", "out", "in,out", "in,out", "in", "in,out", "in,out"]
+ ret = self.c_parser.get_param_dir_from_comment(s)
+ self.assertEqual(ret, _out)
+
+
+
+def suite():
+ suite = unittest.TestSuite()
+ suite.addTest(unittest.makeSuite(testP))
+ return suite
+
+if __name__ == '__main__':
+
+ unittest.main()