coriolis/knik/src
Jean-Paul Chaput 02777e127e Migration towards Python3, first stage: still based on C-Macros.
* New: Python/C++ API level:
  * Write a new C++/template wrapper to get rid of boost::python
  * The int & long Python type are now merged. So a C/C++ level,
    it became "PyLong_X" (remove "PyInt_X") and at Python code
    level, it became "int" (remove "long").
* Change: VLSISAPD finally defunct.
  * Configuration is now integrated as a Hurricane component,
    makes use of the new C++/template wrapper.
  * vlsisapd is now defunct. Keep it in the source for now as
    some remaining non essential code may have to be ported in
    the future.
* Note: Python code (copy of the migration howto):
  * New print function syntax print().
  * Changed "dict.has_key(k)" for "k" in dict.
  * Changed "except Exception, e" for "except Exception as e".
  * The division "/" is now the floating point division, even if
    both operand are integers. So 3/2 now gives 1.5 and no longer 1.
    The integer division is now "//" : 1 = 3//2. So have to carefully
    review the code to update. Most of the time we want to use "//".
    We must never change to float for long that, in fact, represents
    DbU (exposed as Python int type).
  * execfile() must be replaced by exec(open("file").read()).
  * iter().__next__() becomes iter(x).__next__().
  * __getslice__() has been removed, integrated to __getitem__().
  * The formating used for str(type(o)) has changed, so In Stratus,
    have to update them ("<class 'MyClass'>" instead of "MyClass").
  * the "types" module no longer supply values for default types
    like str (types.StringType) or list (types.StringType).
    Must use "isinstance()" where they were occuring.
  * Remove the 'L' to indicate "long integer" (like "12L"), now
    all Python integer are long.
* Change in bootstrap:
  * Ported Coriolis builder (ccb) to Python3.
  * Ported Coriolis socInstaller.py to Python3.
  * Note: In PyQt4+Python3, QVariant no longer exists. Use None or
    directly convert using the python syntax: bool(x), int(x), ...
    By default, it is a string (str).
* Note: PyQt4 bindings & Python3 under SL7.
  * In order to compile user's must upgrade to my own rebuild of
    PyQt 4 & 5 bindings 4.19.21-1.el7.soc.
* Bug: In cumulus/plugins.block.htree.HTree.splitNet(), set the root
    buffer of the H-Tree to the original signal (mainly: top clock).
      Strangely, it was only done when working in full chip mode.
2021-09-19 19:41:24 +02:00
..
knik Various typos correction (courtesy of G. Gouvine). 2019-07-30 13:13:57 +02:00
CMakeLists.txt Corrections to build under MacOS X. 2019-12-11 22:13:47 +01:00
Configuration.cpp * ./hurricane/src/hviewer, 2010-03-09 15:23:58 +00:00
Edge.cpp Argh. cdebug was slowing down the program too much. 2016-06-11 21:56:12 +02:00
Graph.cpp Added Python for FLUTE (for fast RSMT in HFNS). 2020-09-30 11:52:22 +02:00
GraphicKnikEngine.cpp Happy New Year 2018 ! Update license years... 2018-01-06 17:55:44 +01:00
HEdge.cpp Compliance with Clang 3.4 (RHEL7, MacOS). 2014-12-09 23:49:46 +01:00
KnikEngine.cpp Groudwork for routing density driven placement. Compliance with clang 5.0.1. 2019-12-09 01:57:44 +01:00
LoadSolution.cpp Groudwork for routing density driven placement. Compliance with clang 5.0.1. 2019-12-09 01:57:44 +01:00
MatrixVertex.cpp Migration towards Python3, first stage: still based on C-Macros. 2021-09-19 19:41:24 +02:00
NetExtension.cpp Happy New Year 2018 ! Update license years... 2018-01-06 17:55:44 +01:00
SlicingTree.cpp * ./hurricane/src/hviewer, 2010-03-09 15:23:58 +00:00
VEdge.cpp Compliance with Clang 3.4 (RHEL7, MacOS). 2014-12-09 23:49:46 +01:00
Vertex.cpp In Knik::Vertex, the _flags member was uninitialized. 2016-04-22 22:55:26 +02:00
knikRefactor.conf * ./hurricane/src/hviewer, 2010-03-09 15:23:58 +00:00