<liclass="toctree-l4"><aclass="reference internal"href="../UsersGuide/Installation.html#building-the-devel-branch">Building the Devel Branch</a></li>
<liclass="toctree-l4"><aclass="reference internal"href="../UsersGuide/Installation.html#additionnal-requirement-under-macos">Additionnal Requirement under <spanclass="sc">MacOS</span></a></li>
<liclass="toctree-l3"><aclass="reference internal"href="../UsersGuide/Installation.html#hooking-up-into-alliance">Hooking up into <spanclass="sc">Alliance</span></a></li>
<liclass="toctree-l3"><aclass="reference internal"href="../UsersGuide/Installation.html#setting-up-the-environment-coriolisenv-py">Setting up the Environment (coriolisEnv.py)</a></li>
</ul>
</li>
<liclass="toctree-l2"><aclass="reference internal"href="../UsersGuide/Configuration.html">Coriolis Configuration & Initialisation</a><ul>
<liclass="toctree-l3"><aclass="reference internal"href="../UsersGuide/Configuration.html#hacking-the-configuration-files">Hacking the Configuration Files</a></li>
</ul>
</li>
<liclass="toctree-l2"><aclass="reference internal"href="../UsersGuide/ViewerTools.html">CGT - The Graphical Interface</a><ul>
<liclass="toctree-l3"><aclass="reference internal"href="../UsersGuide/ViewerTools.html#viewer-tools">Viewer & Tools</a><ul>
<liclass="toctree-l4"><aclass="reference internal"href="../UsersGuide/ViewerTools.html#synthetizing-and-loading-a-design">Synthetizing and loading a design</a></li>
<liclass="toctree-l4"><aclass="reference internal"href="../UsersGuide/ViewerTools.html#executing-python-scripts-in-cgt">Executing Python Scripts in Cgt</a></li>
<liclass="toctree-l4"><aclass="reference internal"href="../UsersGuide/ViewerTools.html#printing-snapshots">Printing & Snapshots</a></li>
<liclass="toctree-l4"><aclass="reference internal"href="../UsersGuide/ViewerTools.html#memento-of-shortcuts-in-graphic-mode">Memento of Shortcuts in Graphic Mode</a></li>
<liclass="toctree-l4"><aclass="reference internal"href="../UsersGuide/ViewerTools.html#cgt-command-line-options">Cgt Command Line Options</a></li>
<li><ahref="index.html">Hurricane Python/C++ API Tutorial</a>»</li>
<li>1. Introduction</li>
<liclass="wy-breadcrumbs-aside">
</li>
</ul>
<hr/>
</div>
<divrole="main"class="document">
<divclass="section"id="introduction">
<h1>1. Introduction<aclass="headerlink"href="#introduction"title="Permalink to this headline">¶</a></h1>
<ulclass="simple">
<li>This document is written for people already familiar with the
<aclass="reference external"href="https://docs.python.org/2/c-api/index.html">Python/C API Reference Manual</a>.</li>
<li>The macros provided by the Hurricane Python/C API are written using
the standard Python C/API. That is, you may not use them and write
directly your functions with the original API or any mix between.
You only have to respect some naming convention.</li>
<li>Coriolis is build against Python 2.7.</li>
</ul>
<divclass="section"id="first-a-disclaimer">
<h2>1.1 First, A Disclaimer<aclass="headerlink"href="#first-a-disclaimer"title="Permalink to this headline">¶</a></h2>
<p>The Hurricane Python/C++ API has been written about ten years ago, at a time
my mastering of template programming was less than complete. This is why this
interface is build with old fashioned C macro instead of C++ template.</p>
<p>It is my hope that at some point in the future I will have time to completly
rewrite it, borrowing the interface from <ttclass="docutils literal"><spanclass="pre">boost::python</span></tt>.</p>
</div>
<divclass="section"id="about-technical-choices">
<h2>1.2 About Technical Choices<aclass="headerlink"href="#about-technical-choices"title="Permalink to this headline">¶</a></h2>
<p>Some would say, why not use <em>off the shelf</em> wrappers like <ttclass="docutils literal"><spanclass="pre">swig</span></tt>
or <ttclass="docutils literal"><spanclass="pre">boost::python</span></tt>, here are some clues.</p>
<olclass="arabic">
<li><pclass="first"><strong>Partial exposure of the C++ class tree.</strong> We expose at Python level
C++ base classes, only if they provides common methods that we want
to see. Otherwise, we just show them as base classes under Python.
For instance <ttclass="docutils literal"><spanclass="pre">Library</span></tt> is derived from <ttclass="docutils literal"><spanclass="pre">DBo</span></tt>, but we won’t see
it under Python.</p>
</li>
<li><pclass="first"><strong>Bi-directional communication.</strong> When a Python object is deleted, the
wrapper obviously has a pointer toward the underlying C++ object and
is able to delete it. But, the reverse case can occurs, meaning that
you have a C++ object wrapped in Python and the database delete the
underlying object. The wrapped Python object <em>must</em> be informed that
it no longer refer a valid C++ one. Moreover, as we do not control
when Python objects gets deleteds (that is, when their reference count
reaches zero), we can have valid Python object with a dangling
C++ pointer. So our Python objects can be warned by the C++ objects
that they are no longer valid and any other operation than the
deletion should result in a severe non-blocking error.</p>
<p>To be precise, this apply to persistent object in the C++ database,
like <ttclass="docutils literal"><spanclass="pre">Cell</span></tt>, <ttclass="docutils literal"><spanclass="pre">Net</span></tt>, <ttclass="docutils literal"><spanclass="pre">Instance</span></tt> or <ttclass="docutils literal"><spanclass="pre">Component</span></tt>. Short lived
objects like <ttclass="docutils literal"><spanclass="pre">Box</span></tt> or <ttclass="docutils literal"><spanclass="pre">Point</span></tt> retains the classic Python behavior.</p>
<p>Another aspect is that, for all derived <ttclass="docutils literal"><spanclass="pre">DBo</span></tt> objects, one and only
one Python object is associated. For one given <ttclass="docutils literal"><spanclass="pre">Instance</span></tt> object we
will always return the <em>same</em><ttclass="docutils literal"><spanclass="pre">PyInstance</span></tt> object, thanks to the
bi-directional link. Obviously, the <em>reference count</em> of the
<ttclass="docutils literal"><spanclass="pre">PyInstance</span></tt> is managed accordingly. This mechanism is implemented
by the <ttclass="docutils literal"><spanclass="pre">PyInstance_Link()</span></tt> function.</p>
</li>
<li><pclass="first"><strong>Linking accross modules.</strong> As far as I understand, the wrappers
are for monolithic libraries. That is, you wrap the entire library
in one go. But Hurricane has a modular design, the core database
then various tools. We do not, and cannot, have one gigantic wrapper
that would encompass all the libraries in one go. We do one Python
module for one C++ library.</p>
<p>This brings another issue, at Python level this time. The Python
modules for the libraries have to share some functions. Python
provides a mechanism to pass C function pointers accross modules,
but I did found it cumbersome. Instead, all our modules are split
in two:</p>
<ulclass="simple">
<li>The first part contains the classic Python module code.</li>
<li>The second part is to be put in a separate dynamic library that
will hold the shared functions. The Python module is dynamically linked
against that library like any other. And any other Python module
requiring the functions will link against the associated shared
library.</li>
</ul>
<p>Each module file will be compiled <em>twice</em>, once to build the Python
module (<ttclass="docutils literal"><spanclass="pre">__PYTHON_MODULE</span></tt> is defined) and once to build the supporting
shared library (<ttclass="docutils literal"><spanclass="pre">__PYTHON_MODULE__</span></tt><strong>not</strong> defined). This tricky
double compilation is taken care of though the <ttclass="docutils literal"><spanclass="pre">add_python_module</span></tt>
<p>This way, we do not rely upon a pointer transmission through Python
modules, but directly uses linker capabilities.</p>
</li>
</ol>
</div>
<divclass="section"id="botched-design">
<h2>1.3 Botched Design<aclass="headerlink"href="#botched-design"title="Permalink to this headline">¶</a></h2>
<p>The mechanism to compute the signature of a call to a Python function,
the <ttclass="docutils literal"><spanclass="pre">__cs</span></tt> object, is much too complex and, in fact, not needed.
At some point I may root it out, but it is used in so many places...</p>
<p>What I should have used the <ttclass="docutils literal"><spanclass="pre">"O!"</span></tt> capablity of <ttclass="docutils literal"><spanclass="pre">PyArg_ParseTuple()</span></tt>,