Compliance with Clang 3.4 (RHEL7, MacOS).
* New: In Bootstrap, added support for RHEL7 in ccb.py & coriolisEnv.py. In coriolisEnv.py, under RHEL6, directly launch a shell under devtoolset-2 (do not put it in .bashrc). * Change: All tools, compliance with Clang 3.2. - Call using namespace std *after* at least one include of std has been used. - In Utilities.h define both const and non-cont overload for operator<< of mstream (this was the true cause of the Banner display problem). - No longer use defaults arguments in templates, instead create two separated overloads. - Put template static attributes allocation outside of namespaces (this one I'm not sure how to justify). - Protect by NDEBUG variables that are only needed in assert(). - In PyInterval getUnion() & getIntersection() we where silently overwriting the "self" object (interval). - In Mauka, *do no* overload _postCreate() and add an argument, breaks the virtual function mechanism. Rename it into _maukaPostCreate(). Idem for SubRow(). - In Katabatic::GCell(), invalidate() overload a Go funtion but is used for different purpose at this level. Rename it invalidateCt() (invalidate *ConTents*). - Miscellaneous small cleanup.
This commit is contained in:
parent
37c8498962
commit
978315c017
|
@ -121,6 +121,7 @@ class Configuration ( object ):
|
||||||
|
|
||||||
def _guessOs ( self ):
|
def _guessOs ( self ):
|
||||||
self._libSuffix = None
|
self._libSuffix = None
|
||||||
|
self._osSlsoc7x_64 = re.compile (".*Linux.*(el7|slsoc7).*x86_64.*")
|
||||||
self._osSlsoc6x_64 = re.compile (".*Linux.*(el6|slsoc6).*x86_64.*")
|
self._osSlsoc6x_64 = re.compile (".*Linux.*(el6|slsoc6).*x86_64.*")
|
||||||
self._osSlsoc6x = re.compile (".*Linux.*(el6|slsoc6).*")
|
self._osSlsoc6x = re.compile (".*Linux.*(el6|slsoc6).*")
|
||||||
self._osSLSoC5x_64 = re.compile (".*Linux.*el5.*x86_64.*")
|
self._osSLSoC5x_64 = re.compile (".*Linux.*el5.*x86_64.*")
|
||||||
|
@ -139,7 +140,10 @@ class Configuration ( object ):
|
||||||
uname = subprocess.Popen ( ["uname", "-srm"], stdout=subprocess.PIPE )
|
uname = subprocess.Popen ( ["uname", "-srm"], stdout=subprocess.PIPE )
|
||||||
lines = uname.stdout.readlines()
|
lines = uname.stdout.readlines()
|
||||||
|
|
||||||
if self._osSlsoc6x_64.match(lines[0]):
|
if self._osSlsoc7x_64.match(lines[0]):
|
||||||
|
self._osType = "Linux.el7"
|
||||||
|
self._libSuffix = "64"
|
||||||
|
elif self._osSlsoc6x_64.match(lines[0]):
|
||||||
self._osType = "Linux.slsoc6x_64"
|
self._osType = "Linux.slsoc6x_64"
|
||||||
self._libSuffix = "64"
|
self._libSuffix = "64"
|
||||||
elif self._osSlsoc6x .match(lines[0]): self._osType = "Linux.slsoc6x"
|
elif self._osSlsoc6x .match(lines[0]): self._osType = "Linux.slsoc6x"
|
||||||
|
|
|
@ -54,6 +54,7 @@ def safeImport ( moduleName, symbol=None ):
|
||||||
|
|
||||||
def guessOs ():
|
def guessOs ():
|
||||||
libDir = 'lib'
|
libDir = 'lib'
|
||||||
|
osSlsoc7x_64 = re.compile (".*Linux.*(el7|slsoc7).*x86_64.*")
|
||||||
osSlsoc6x_64 = re.compile (".*Linux.*(el6|slsoc6).*x86_64.*")
|
osSlsoc6x_64 = re.compile (".*Linux.*(el6|slsoc6).*x86_64.*")
|
||||||
osSlsoc6x = re.compile (".*Linux.*(el6|slsoc6).*")
|
osSlsoc6x = re.compile (".*Linux.*(el6|slsoc6).*")
|
||||||
osSLSoC5x_64 = re.compile (".*Linux.*el5.*x86_64.*")
|
osSLSoC5x_64 = re.compile (".*Linux.*el5.*x86_64.*")
|
||||||
|
@ -72,7 +73,10 @@ def guessOs ():
|
||||||
uname = subprocess.Popen ( ["uname", "-srm"], stdout=subprocess.PIPE )
|
uname = subprocess.Popen ( ["uname", "-srm"], stdout=subprocess.PIPE )
|
||||||
lines = uname.stdout.readlines()
|
lines = uname.stdout.readlines()
|
||||||
|
|
||||||
if osSlsoc6x_64.match(lines[0]):
|
if osSlsoc7x_64.match(lines[0]):
|
||||||
|
osType = "Linux.el7_64"
|
||||||
|
libDir = "lib64"
|
||||||
|
elif osSlsoc6x_64.match(lines[0]):
|
||||||
osType = "Linux.slsoc6x_64"
|
osType = "Linux.slsoc6x_64"
|
||||||
libDir = "lib64"
|
libDir = "lib64"
|
||||||
elif osSlsoc6x.match(lines[0]):
|
elif osSlsoc6x.match(lines[0]):
|
||||||
|
|
|
@ -33,6 +33,7 @@ def stripPath ( pathName ):
|
||||||
|
|
||||||
def guessOs ():
|
def guessOs ():
|
||||||
useDevtoolset2 = False
|
useDevtoolset2 = False
|
||||||
|
osSlsoc7x_64 = re.compile (".*Linux.*el7.*x86_64.*")
|
||||||
osSlsoc6x_64 = re.compile (".*Linux.*el6.*x86_64.*")
|
osSlsoc6x_64 = re.compile (".*Linux.*el6.*x86_64.*")
|
||||||
osSlsoc6x = re.compile (".*Linux.*(el|slsoc)6.*")
|
osSlsoc6x = re.compile (".*Linux.*(el|slsoc)6.*")
|
||||||
osSLSoC5x_64 = re.compile (".*Linux.*el5.*x86_64.*")
|
osSLSoC5x_64 = re.compile (".*Linux.*el5.*x86_64.*")
|
||||||
|
@ -54,7 +55,10 @@ def guessOs ():
|
||||||
lines = uname.stdout.readlines()
|
lines = uname.stdout.readlines()
|
||||||
|
|
||||||
libDir="lib"
|
libDir="lib"
|
||||||
if osSlsoc6x_64.match(lines[0]):
|
if osSlsoc7x_64.match(lines[0]):
|
||||||
|
osType = "Linux.el7_64"
|
||||||
|
libDir = "lib64"
|
||||||
|
elif osSlsoc6x_64.match(lines[0]):
|
||||||
osType = "Linux.slsoc6x_64"
|
osType = "Linux.slsoc6x_64"
|
||||||
libDir = "lib64"
|
libDir = "lib64"
|
||||||
useDevtoolset2 = True
|
useDevtoolset2 = True
|
||||||
|
@ -100,8 +104,8 @@ def guessOs ():
|
||||||
uname = subprocess.Popen ( ["uname", "-sr"], stdout=subprocess.PIPE )
|
uname = subprocess.Popen ( ["uname", "-sr"], stdout=subprocess.PIPE )
|
||||||
osType = uname.stdout.readlines()[0][:-1]
|
osType = uname.stdout.readlines()[0][:-1]
|
||||||
|
|
||||||
#print "[WARNING] Unrecognized OS: \"%s\"." % lines[0][:-1]
|
print "[WARNING] Unrecognized OS: \"%s\"." % lines[0][:-1]
|
||||||
#print " (using: \"%s\")" % osType
|
print " (using: \"%s\")" % osType
|
||||||
|
|
||||||
return (osType,libDir,useDevtoolset2)
|
return (osType,libDir,useDevtoolset2)
|
||||||
|
|
||||||
|
|
|
@ -1,74 +1,34 @@
|
||||||
|
|
||||||
|
|
||||||
// This file is part of the Coriolis Project.
|
|
||||||
// Copyright (C) Laboratoire LIP6 - Departement ASIM
|
|
||||||
// Universite Pierre et Marie Curie
|
|
||||||
//
|
|
||||||
// Main contributors :
|
|
||||||
// Christophe Alexandre <Christophe.Alexandre@lip6.fr>
|
|
||||||
// Sophie Belloeil <Sophie.Belloeil@lip6.fr>
|
|
||||||
// Hugo Clément <Hugo.Clement@lip6.fr>
|
|
||||||
// Jean-Paul Chaput <Jean-Paul.Chaput@lip6.fr>
|
|
||||||
// Damien Dupuis <Damien.Dupuis@lip6.fr>
|
|
||||||
// Christian Masson <Christian.Masson@lip6.fr>
|
|
||||||
// Marek Sroka <Marek.Sroka@lip6.fr>
|
|
||||||
//
|
|
||||||
// The Coriolis Project is free software; you can redistribute it
|
|
||||||
// and/or modify it under the terms of the GNU General Public License
|
|
||||||
// as published by the Free Software Foundation; either version 2 of
|
|
||||||
// the License, or (at your option) any later version.
|
|
||||||
//
|
|
||||||
// The Coriolis Project is distributed in the hope that it will be
|
|
||||||
// useful, but WITHOUT ANY WARRANTY; without even the implied warranty
|
|
||||||
// of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
// GNU General Public License for more details.
|
|
||||||
//
|
|
||||||
// You should have received a copy of the GNU General Public License
|
|
||||||
// along with the Coriolis Project; if not, write to the Free Software
|
|
||||||
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
|
|
||||||
// USA
|
|
||||||
//
|
|
||||||
// License-Tag
|
|
||||||
// Authors-Tag
|
|
||||||
// ===================================================================
|
|
||||||
|
|
||||||
|
|
||||||
// -*- C++ -*-
|
// -*- C++ -*-
|
||||||
//
|
//
|
||||||
// $Id$
|
// This file is part of the Coriolis Software.
|
||||||
|
// Copyright (c) UPMC 2008-2014, All Rights Reserved
|
||||||
//
|
//
|
||||||
// x-----------------------------------------------------------------x
|
// +-----------------------------------------------------------------+
|
||||||
// | |
|
|
||||||
// | C O R I O L I S |
|
// | C O R I O L I S |
|
||||||
// | Alliance / Hurricane Interface |
|
// | Alliance / Hurricane Interface |
|
||||||
// | |
|
// | |
|
||||||
// | Author : Jean-Paul CHAPUT |
|
// | Author : Jean-Paul CHAPUT |
|
||||||
// | E-mail : Jean-Paul.Chaput@asim.lip6.fr |
|
// | E-mail : Jean-Paul.Chaput@asim.lip6.fr |
|
||||||
// | =============================================================== |
|
// | =============================================================== |
|
||||||
// | C++ Header : "./Banner.cpp" |
|
// | C++ Module : "./Banner.cpp" |
|
||||||
// | *************************************************************** |
|
// +-----------------------------------------------------------------+
|
||||||
// | U p d a t e s |
|
|
||||||
// | |
|
|
||||||
// x-----------------------------------------------------------------x
|
|
||||||
|
|
||||||
|
|
||||||
|
# include <time.h>
|
||||||
# include <time.h>
|
# include <cstring>
|
||||||
# include <cstring>
|
# include <cstdlib>
|
||||||
# include <cstdlib>
|
# include <iomanip>
|
||||||
|
# include "hurricane/Error.h"
|
||||||
# include <iomanip>
|
# include "crlcore/Banner.h"
|
||||||
|
|
||||||
# include "crlcore/Banner.h"
|
|
||||||
|
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
|
|
||||||
using std::make_pair;
|
using std::make_pair;
|
||||||
using std::cerr;
|
using std::cerr;
|
||||||
using std::endl;
|
using std::endl;
|
||||||
using std::setw;
|
using std::setw;
|
||||||
|
using Hurricane::Error;
|
||||||
|
|
||||||
|
|
||||||
const char* badChar =
|
const char* badChar =
|
||||||
|
|
|
@ -15,7 +15,6 @@
|
||||||
|
|
||||||
|
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
#include "hurricane/Pin.h"
|
#include "hurricane/Pin.h"
|
||||||
#include "hurricane/Instance.h"
|
#include "hurricane/Instance.h"
|
||||||
|
@ -33,6 +32,8 @@ using namespace std;
|
||||||
#include "Ap.h"
|
#include "Ap.h"
|
||||||
#include "crlcore/Catalog.h"
|
#include "crlcore/Catalog.h"
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
// -*- C++ -*-
|
// -*- C++ -*-
|
||||||
//
|
//
|
||||||
// This file is part of the Coriolis Software.
|
// This file is part of the Coriolis Software.
|
||||||
// Copyright (c) UPMC/LIP6 2008-2014, All Rights Reserved
|
// Copyright (c) UPMC 2008-2014, All Rights Reserved
|
||||||
//
|
//
|
||||||
// +-----------------------------------------------------------------+
|
// +-----------------------------------------------------------------+
|
||||||
// | C O R I O L I S |
|
// | C O R I O L I S |
|
||||||
|
@ -478,7 +478,7 @@ namespace {
|
||||||
orientation = fields[5];
|
orientation = fields[5];
|
||||||
|
|
||||||
index = -1;
|
index = -1;
|
||||||
if (fields[4] != '\0') index = atoi( fields[4] );
|
if (fields[4][0] != '\0') index = atoi( fields[4] );
|
||||||
|
|
||||||
size_t length = strlen( fields[3] );
|
size_t length = strlen( fields[3] );
|
||||||
if (length > 1000) {
|
if (length > 1000) {
|
||||||
|
|
|
@ -34,16 +34,15 @@
|
||||||
// Authors-Tag
|
// Authors-Tag
|
||||||
|
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
using namespace std;
|
#include "hurricane/Pin.h"
|
||||||
|
#include "hurricane/Cell.h"
|
||||||
#include "hurricane/Pin.h"
|
#include "hurricane/Instance.h"
|
||||||
#include "hurricane/Cell.h"
|
#include "hurricane/Net.h"
|
||||||
#include "hurricane/Instance.h"
|
#include "hurricane/Horizontal.h"
|
||||||
#include "hurricane/Net.h"
|
#include "hurricane/Vertical.h"
|
||||||
#include "hurricane/Horizontal.h"
|
#include "hurricane/Warning.h"
|
||||||
#include "hurricane/Vertical.h"
|
|
||||||
#include "hurricane/Warning.h"
|
|
||||||
using namespace Hurricane;
|
using namespace Hurricane;
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
|
@ -45,22 +45,17 @@
|
||||||
|
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
|
|
||||||
#include <regex.h>
|
#include <regex.h>
|
||||||
|
#include "hurricane/DataBase.h"
|
||||||
#include "hurricane/DataBase.h"
|
#include "hurricane/Horizontal.h"
|
||||||
#include "hurricane/Horizontal.h"
|
#include "hurricane/Vertical.h"
|
||||||
#include "hurricane/Vertical.h"
|
#include "hurricane/UpdateSession.h"
|
||||||
#include "hurricane/UpdateSession.h"
|
|
||||||
using namespace Hurricane;
|
using namespace Hurricane;
|
||||||
|
|
||||||
|
|
||||||
#include "crlcore/Utilities.h"
|
#include "crlcore/Utilities.h"
|
||||||
#include "crlcore/AllianceFramework.h"
|
#include "crlcore/AllianceFramework.h"
|
||||||
|
#include "Bookshelf.h"
|
||||||
#include "Bookshelf.h"
|
|
||||||
|
|
||||||
|
|
||||||
const char* badRegex =
|
const char* badRegex =
|
||||||
|
@ -77,13 +72,13 @@ namespace {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
char* lower ( char* str )
|
// char* lower ( char* str )
|
||||||
{
|
// {
|
||||||
for ( char* ptr = str; *ptr != '\0' ; ptr++ )
|
// for ( char* ptr = str; *ptr != '\0' ; ptr++ )
|
||||||
*ptr = (char)tolower ( *ptr );
|
// *ptr = (char)tolower ( *ptr );
|
||||||
|
//
|
||||||
return str;
|
// return str;
|
||||||
}
|
// }
|
||||||
|
|
||||||
// CParsAP should read this code :
|
// CParsAP should read this code :
|
||||||
// *******************************
|
// *******************************
|
||||||
|
@ -297,24 +292,24 @@ Name BKParser::getNewNetName()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Net* MergeNets ( Net* net1, Net* net2 )
|
// Net* MergeNets ( Net* net1, Net* net2 )
|
||||||
// ************************************
|
// // ************************************
|
||||||
{
|
// {
|
||||||
if ( net2->getName()[0] != '~' ) {
|
// if ( net2->getName()[0] != '~' ) {
|
||||||
if ( ( net1->getName()[0] == '~' ) ||
|
// if ( ( net1->getName()[0] == '~' ) ||
|
||||||
( net2->isGlobal() && !net1->isGlobal() ) ||
|
// ( net2->isGlobal() && !net1->isGlobal() ) ||
|
||||||
( net2->isExternal() && !net1->isExternal() ) ) {
|
// ( net2->isExternal() && !net1->isExternal() ) ) {
|
||||||
Net* tmpNet = net1;
|
// Net* tmpNet = net1;
|
||||||
net1 = net2;
|
// net1 = net2;
|
||||||
net2 = tmpNet;
|
// net2 = tmpNet;
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
net1->setExternal ( net1->isExternal() || net2->isExternal() );
|
// net1->setExternal ( net1->isExternal() || net2->isExternal() );
|
||||||
net1->setGlobal ( net1->isGlobal() || net2->isGlobal() );
|
// net1->setGlobal ( net1->isGlobal() || net2->isGlobal() );
|
||||||
|
//
|
||||||
net1->merge ( net2 ); // Caution : net2 will be deleted
|
// net1->merge ( net2 ); // Caution : net2 will be deleted
|
||||||
return net1;
|
// return net1;
|
||||||
}
|
// }
|
||||||
|
|
||||||
|
|
||||||
// ************************************************************************************
|
// ************************************************************************************
|
||||||
|
@ -734,28 +729,28 @@ Transformation getTransformation ( const Box& abox, const DbU::Unit& x, const Db
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void UpdateSizes ( Contact* contact )
|
// void UpdateSizes ( Contact* contact )
|
||||||
// **********************************
|
// // **********************************
|
||||||
{
|
// {
|
||||||
DbU::Unit width = 0;
|
// DbU::Unit width = 0;
|
||||||
DbU::Unit height = 0;
|
// DbU::Unit height = 0;
|
||||||
const Layer* layer = contact->getLayer();
|
// const Layer* layer = contact->getLayer();
|
||||||
//if ( layer->getType() == CompositeLayer::Type::VIA ) {
|
// //if ( layer->getType() == CompositeLayer::Type::VIA ) {
|
||||||
width = max ( contact->getWidth(), layer->getMinimalSize() );
|
// width = max ( contact->getWidth(), layer->getMinimalSize() );
|
||||||
height = max ( contact->getHeight(), layer->getMinimalSize() );
|
// height = max ( contact->getHeight(), layer->getMinimalSize() );
|
||||||
//}
|
// //}
|
||||||
|
//
|
||||||
for_each_hook ( hook, contact->getBodyHook()->getSlaveHooks() ) {
|
// for_each_hook ( hook, contact->getBodyHook()->getSlaveHooks() ) {
|
||||||
Component* component = hook->getComponent();
|
// Component* component = hook->getComponent();
|
||||||
if ( Vertical* vertical = dynamic_cast<Vertical*> ( component ) ) {
|
// if ( Vertical* vertical = dynamic_cast<Vertical*> ( component ) ) {
|
||||||
width = max ( width, vertical->getWidth() );
|
// width = max ( width, vertical->getWidth() );
|
||||||
} else if ( Horizontal* horizontal = dynamic_cast<Horizontal*> ( component ) ) {
|
// } else if ( Horizontal* horizontal = dynamic_cast<Horizontal*> ( component ) ) {
|
||||||
height = max ( height, horizontal->getWidth() );
|
// height = max ( height, horizontal->getWidth() );
|
||||||
}
|
// }
|
||||||
end_for;
|
// end_for;
|
||||||
}
|
// }
|
||||||
contact->setSizes ( width, height );
|
// contact->setSizes ( width, height );
|
||||||
}
|
// }
|
||||||
|
|
||||||
|
|
||||||
// ***************************************************************************************
|
// ***************************************************************************************
|
||||||
|
|
|
@ -1,78 +1,37 @@
|
||||||
|
|
||||||
|
|
||||||
// -*- C++ -*-
|
// -*- C++ -*-
|
||||||
//
|
//
|
||||||
// This file is part of the Coriolis Project.
|
// This file is part of the Coriolis Software.
|
||||||
// Copyright (C) Laboratoire LIP6 - Departement ASIM
|
// Copyright (c) UPMC 2008-2014, All Rights Reserved
|
||||||
// Universite Pierre et Marie Curie
|
|
||||||
//
|
//
|
||||||
// Main contributors :
|
// +-----------------------------------------------------------------+
|
||||||
// Christophe Alexandre <Christophe.Alexandre@lip6.fr>
|
|
||||||
// Sophie Belloeil <Sophie.Belloeil@lip6.fr>
|
|
||||||
// Hugo Clément <Hugo.Clement@lip6.fr>
|
|
||||||
// Jean-Paul Chaput <Jean-Paul.Chaput@lip6.fr>
|
|
||||||
// Damien Dupuis <Damien.Dupuis@lip6.fr>
|
|
||||||
// Christian Masson <Christian.Masson@lip6.fr>
|
|
||||||
// Marek Sroka <Marek.Sroka@lip6.fr>
|
|
||||||
//
|
|
||||||
// The Coriolis Project is free software; you can redistribute it
|
|
||||||
// and/or modify it under the terms of the GNU General Public License
|
|
||||||
// as published by the Free Software Foundation; either version 2 of
|
|
||||||
// the License, or (at your option) any later version.
|
|
||||||
//
|
|
||||||
// The Coriolis Project is distributed in the hope that it will be
|
|
||||||
// useful, but WITHOUT ANY WARRANTY; without even the implied warranty
|
|
||||||
// of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
// GNU General Public License for more details.
|
|
||||||
//
|
|
||||||
// You should have received a copy of the GNU General Public License
|
|
||||||
// along with the Coriolis Project; if not, write to the Free Software
|
|
||||||
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
|
|
||||||
// USA
|
|
||||||
//
|
|
||||||
// License-Tag
|
|
||||||
// Authors-Tag
|
|
||||||
// ===================================================================
|
|
||||||
//
|
|
||||||
// $Id$
|
|
||||||
//
|
|
||||||
// x-----------------------------------------------------------------x
|
|
||||||
// | |
|
|
||||||
// | C O R I O L I S |
|
// | C O R I O L I S |
|
||||||
// | Alliance / Hurricane Interface |
|
// | Alliance / Hurricane Interface |
|
||||||
// | |
|
// | |
|
||||||
// | Author : Jean-Paul CHAPUT |
|
// | Author : Jean-Paul CHAPUT |
|
||||||
// | E-mail : Jean-Paul.Chaput@asim.lip6.fr |
|
// | E-mail : Jean-Paul.Chaput@asim.lip6.fr |
|
||||||
// | =============================================================== |
|
// | =============================================================== |
|
||||||
// | C++ Header : "./Banner.h" |
|
// | C++ Header : "./crlcore/Banner.h" |
|
||||||
// | *************************************************************** |
|
// +-----------------------------------------------------------------+
|
||||||
// | U p d a t e s |
|
|
||||||
// | |
|
|
||||||
// x-----------------------------------------------------------------x
|
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef CRL_BANNER_H
|
||||||
|
#define CRL_BANNER_H
|
||||||
|
|
||||||
|
#include <map>
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
#include <ostream>
|
||||||
|
#include <sstream>
|
||||||
|
|
||||||
|
#ifdef __CCORE_INTERNAL__
|
||||||
|
# include "hurricane/CConfig.h"
|
||||||
# ifndef __CRL_BANNER_H__
|
#endif
|
||||||
# define __CRL_BANNER_H__
|
#include "crlcore/Utilities.h"
|
||||||
|
|
||||||
# include <map>
|
|
||||||
# include <string>
|
|
||||||
# include <vector>
|
|
||||||
# include <ostream>
|
|
||||||
# include <sstream>
|
|
||||||
|
|
||||||
# ifdef __CCORE_INTERNAL__
|
|
||||||
# include "hurricane/CConfig.h"
|
|
||||||
# endif
|
|
||||||
# include "crlcore/Utilities.h"
|
|
||||||
|
|
||||||
|
|
||||||
namespace CRL {
|
namespace CRL {
|
||||||
|
|
||||||
|
using std::string;
|
||||||
using std::map;
|
using std::map;
|
||||||
using std::vector;
|
using std::vector;
|
||||||
using std::ostream;
|
using std::ostream;
|
||||||
|
@ -220,7 +179,7 @@ namespace CRL {
|
||||||
inline unsigned int Banner::getScreenWidth () const { return _screenWidth; }
|
inline unsigned int Banner::getScreenWidth () const { return _screenWidth; }
|
||||||
|
|
||||||
|
|
||||||
} // End of CRL namespace.
|
} // CRL namespace.
|
||||||
|
|
||||||
|
|
||||||
// Hurricane Management.
|
// Hurricane Management.
|
||||||
|
@ -233,4 +192,4 @@ inline std::ostream& operator<< ( std::ostream& o, const CRL::Banner& b ) { retu
|
||||||
MSTREAM_R_SUPPORT(CRL::Banner);
|
MSTREAM_R_SUPPORT(CRL::Banner);
|
||||||
|
|
||||||
|
|
||||||
# endif
|
#endif // CRL_BANNER_H
|
||||||
|
|
|
@ -180,11 +180,9 @@ namespace CRL {
|
||||||
inline bool Catalog::State::isLogical () const { return (_flags&Logical )?1:0; }
|
inline bool Catalog::State::isLogical () const { return (_flags&Logical )?1:0; }
|
||||||
inline unsigned int Catalog::State::getFlags ( unsigned int mask ) const { return ( _flags & mask ); }
|
inline unsigned int Catalog::State::getFlags ( unsigned int mask ) const { return ( _flags & mask ); }
|
||||||
inline bool Catalog::State::setFlags ( unsigned int mask, bool value ) {
|
inline bool Catalog::State::setFlags ( unsigned int mask, bool value ) {
|
||||||
switch ( value ) {
|
if (value) { _flags |= mask; }
|
||||||
case true: _flags |= mask; break;
|
else { _flags &= ~mask; }
|
||||||
case false: _flags &= ~mask; break;
|
return ((_flags&mask) ? true : false);
|
||||||
}
|
|
||||||
return ( (_flags&mask) ? true : false );
|
|
||||||
}
|
}
|
||||||
inline bool Catalog::State::setFlattenLeaf ( bool value ) { return setFlags(FlattenLeaf,value); }
|
inline bool Catalog::State::setFlattenLeaf ( bool value ) { return setFlags(FlattenLeaf,value); }
|
||||||
inline bool Catalog::State::setFeed ( bool value ) { return setFlags(Feed ,value); }
|
inline bool Catalog::State::setFeed ( bool value ) { return setFlags(Feed ,value); }
|
||||||
|
|
|
@ -1,15 +1,9 @@
|
||||||
|
|
||||||
// -*- C++ -*-
|
// -*- C++ -*-
|
||||||
//
|
//
|
||||||
// This file is part of the Coriolis Software.
|
// This file is part of the Coriolis Software.
|
||||||
// Copyright (c) UPMC/LIP6 2008-2008, All Rights Reserved
|
// Copyright (c) UPMC 2008-2014, All Rights Reserved
|
||||||
//
|
//
|
||||||
// ===================================================================
|
// +-----------------------------------------------------------------+
|
||||||
//
|
|
||||||
// $Id$
|
|
||||||
//
|
|
||||||
// x-----------------------------------------------------------------x
|
|
||||||
// | |
|
|
||||||
// | C O R I O L I S |
|
// | C O R I O L I S |
|
||||||
// | Alliance / Hurricane Interface |
|
// | Alliance / Hurricane Interface |
|
||||||
// | |
|
// | |
|
||||||
|
@ -17,19 +11,15 @@
|
||||||
// | E-mail : Jean-Paul.Chaput@lip6.fr |
|
// | E-mail : Jean-Paul.Chaput@lip6.fr |
|
||||||
// | =============================================================== |
|
// | =============================================================== |
|
||||||
// | C++ Header : "./LefDefExtension.h" |
|
// | C++ Header : "./LefDefExtension.h" |
|
||||||
// | *************************************************************** |
|
// +-----------------------------------------------------------------+
|
||||||
// | U p d a t e s |
|
|
||||||
// | |
|
|
||||||
// x-----------------------------------------------------------------x
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef __LEFDEF_EXTENSION__
|
#ifndef CRL_LEFDEF_EXTENSION_H
|
||||||
#define __LEFDEF_EXTENSION__
|
#define CRL_LEFDEF_EXTENSION_H
|
||||||
|
|
||||||
#include <list>
|
#include <list>
|
||||||
|
#include "hurricane/Box.h"
|
||||||
#include "hurricane/Box.h"
|
#include "hurricane/Property.h"
|
||||||
#include "hurricane/Property.h"
|
|
||||||
|
|
||||||
namespace Hurricane {
|
namespace Hurricane {
|
||||||
class Cell;
|
class Cell;
|
||||||
|
@ -91,7 +81,6 @@ namespace CRL {
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
} // End of CRL namespace.
|
} // CRL namespace.
|
||||||
|
|
||||||
|
#endif // CRL_LEFDEF_EXTENSION_H
|
||||||
#endif // __LEFDEF_EXTENSION__
|
|
||||||
|
|
|
@ -147,7 +147,8 @@ namespace CRL {
|
||||||
public:
|
public:
|
||||||
typedef StandardPrivateProperty<MeasuresDatas> Extension;
|
typedef StandardPrivateProperty<MeasuresDatas> Extension;
|
||||||
public:
|
public:
|
||||||
template<typename Data> friend inline void addMeasure ( DBo*, const Name&, const Data&, unsigned int width=8 );
|
template<typename Data> friend inline void addMeasure ( DBo*, const Name&, const Data&, unsigned int width );
|
||||||
|
template<typename Data> friend inline void addMeasure ( DBo*, const Name&, const Data& );
|
||||||
template<typename Data> friend inline void addMeasure ( DBo*, const Name&, Data* );
|
template<typename Data> friend inline void addMeasure ( DBo*, const Name&, Data* );
|
||||||
template<typename Data> friend inline const Measure<Data>* getMeasure ( DBo*, const Name& );
|
template<typename Data> friend inline const Measure<Data>* getMeasure ( DBo*, const Name& );
|
||||||
static const MeasuresSet* get ( const DBo* );
|
static const MeasuresSet* get ( const DBo* );
|
||||||
|
@ -170,6 +171,11 @@ namespace CRL {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
template<typename Data>
|
||||||
|
inline void addMeasure ( DBo* object, const Name& name, const Data& data )
|
||||||
|
{ return addMeasure(object,name,data,8); }
|
||||||
|
|
||||||
|
|
||||||
template<typename Data>
|
template<typename Data>
|
||||||
inline void addMeasure ( DBo* object, const Name& name, Data* data )
|
inline void addMeasure ( DBo* object, const Name& name, Data* data )
|
||||||
{
|
{
|
||||||
|
|
|
@ -1,15 +1,9 @@
|
||||||
|
|
||||||
// -*- C++ -*-
|
// -*- C++ -*-
|
||||||
//
|
//
|
||||||
// This file is part of the Coriolis Software.
|
// This file is part of the Coriolis Software.
|
||||||
// Copyright (c) UPMC/LIP6 2008-2010, All Rights Reserved
|
// Copyright (c) UPMC 2008-2014, All Rights Reserved
|
||||||
//
|
//
|
||||||
// ===================================================================
|
// +-----------------------------------------------------------------+
|
||||||
//
|
|
||||||
// $Id$
|
|
||||||
//
|
|
||||||
// x-----------------------------------------------------------------x
|
|
||||||
// | |
|
|
||||||
// | C O R I O L I S |
|
// | C O R I O L I S |
|
||||||
// | Alliance / Hurricane Interface |
|
// | Alliance / Hurricane Interface |
|
||||||
// | |
|
// | |
|
||||||
|
@ -17,18 +11,14 @@
|
||||||
// | E-mail : Jean-Paul.Chaput@lip6.fr |
|
// | E-mail : Jean-Paul.Chaput@lip6.fr |
|
||||||
// | =============================================================== |
|
// | =============================================================== |
|
||||||
// | C++ Header : "./NetExtension.h" |
|
// | C++ Header : "./NetExtension.h" |
|
||||||
// | *************************************************************** |
|
// +-----------------------------------------------------------------+
|
||||||
// | U p d a t e s |
|
|
||||||
// | |
|
|
||||||
// x-----------------------------------------------------------------x
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef __NET_EXTENSION__
|
#ifndef CRL_NET_EXTENSION_H
|
||||||
#define __NET_EXTENSION__
|
#define CRL_NET_EXTENSION_H
|
||||||
|
|
||||||
#include <set>
|
#include <set>
|
||||||
|
#include "hurricane/Property.h"
|
||||||
#include "hurricane/Property.h"
|
|
||||||
|
|
||||||
namespace Hurricane {
|
namespace Hurricane {
|
||||||
class Net;
|
class Net;
|
||||||
|
@ -79,7 +69,6 @@ namespace CRL {
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
} // End of CRL namespace.
|
} // CRL namespace.
|
||||||
|
|
||||||
|
#endif // CRL_NET_EXTENSION_H
|
||||||
#endif // __NET_EXTENSION__
|
|
||||||
|
|
|
@ -31,7 +31,6 @@
|
||||||
|
|
||||||
namespace CRL {
|
namespace CRL {
|
||||||
|
|
||||||
|
|
||||||
using Hurricane::_TName;
|
using Hurricane::_TName;
|
||||||
using Hurricane::Record;
|
using Hurricane::Record;
|
||||||
using Hurricane::Error;
|
using Hurricane::Error;
|
||||||
|
@ -152,12 +151,9 @@ namespace CRL {
|
||||||
} // End of CRL namespace.
|
} // End of CRL namespace.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// -------------------------------------------------------------------
|
// -------------------------------------------------------------------
|
||||||
// Class : "::tty()".
|
// Class : "::tty()".
|
||||||
|
|
||||||
|
|
||||||
class tty {
|
class tty {
|
||||||
public:
|
public:
|
||||||
enum Flags { Black = 0
|
enum Flags { Black = 0
|
||||||
|
@ -253,7 +249,6 @@ inline std::string tty::bgcolor ( unsigned int mask )
|
||||||
// Wrapper around the STL ostream which uses a verbose level to choose
|
// Wrapper around the STL ostream which uses a verbose level to choose
|
||||||
// wether to print or not.
|
// wether to print or not.
|
||||||
|
|
||||||
|
|
||||||
class mstream : public std::ostream {
|
class mstream : public std::ostream {
|
||||||
public:
|
public:
|
||||||
enum StreamMasks { PassThrough = 0x00000001
|
enum StreamMasks { PassThrough = 0x00000001
|
||||||
|
@ -298,46 +293,57 @@ inline std::string tty::bgcolor ( unsigned int mask )
|
||||||
inline mstream& mstream::flush () { if (enabled()) static_cast<std::ostream*>(this)->flush(); return *this; }
|
inline mstream& mstream::flush () { if (enabled()) static_cast<std::ostream*>(this)->flush(); return *this; }
|
||||||
inline mstream& mstream::operator<< ( std::ostream& (*pf)(std::ostream&) ) { if (enabled()) (*pf)(*this); return *this; }
|
inline mstream& mstream::operator<< ( std::ostream& (*pf)(std::ostream&) ) { if (enabled()) (*pf)(*this); return *this; }
|
||||||
|
|
||||||
|
// For POD Types.
|
||||||
template<typename T>
|
template<typename T>
|
||||||
inline mstream& mstream::operator<< ( T& t )
|
inline mstream& mstream::operator<< ( T& t )
|
||||||
{ if (enabled()) { *(static_cast<std::ostream*>(this)) << t; } return *this; };
|
{ if (enabled()) { *(static_cast<std::ostream*>(this)) << t; } return *this; };
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
inline mstream& mstream::operator<< ( T* t )
|
inline mstream& mstream::operator<< ( T* t )
|
||||||
{ if (enabled()) { *(static_cast<std::ostream*>(this)) << t; } return *this; };
|
{ if (enabled()) { *(static_cast<std::ostream*>(this)) << t; } return *this; };
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
inline mstream& mstream::operator<< ( const T& t )
|
inline mstream& mstream::operator<< ( const T& t )
|
||||||
{ if (enabled()) { *(static_cast<std::ostream*>(this)) << t; } return *this; };
|
{ if (enabled()) { *(static_cast<std::ostream*>(this)) << t; } return *this; };
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
inline mstream& mstream::operator<< ( const T* t )
|
inline mstream& mstream::operator<< ( const T* t )
|
||||||
{ if (enabled()) { *(static_cast<std::ostream*>(this)) << t; } return *this; };
|
{ if (enabled()) { *(static_cast<std::ostream*>(this)) << t; } return *this; };
|
||||||
|
|
||||||
|
// For STL Types.
|
||||||
|
inline mstream& operator<< ( mstream& o, const std::string& s )
|
||||||
|
{ if (o.enabled()) { static_cast<std::ostream&>(o) << s; } return o; };
|
||||||
|
|
||||||
// Specific non-member operator overload. Must be one for each type.
|
// Specific non-member operator overload. Must be one for each type.
|
||||||
#define MSTREAM_V_SUPPORT(Type) \
|
#define MSTREAM_V_SUPPORT(Type) \
|
||||||
inline mstream& operator<< ( mstream& o, const Type s ) \
|
inline mstream& operator<< ( mstream& o, Type t ) \
|
||||||
{ if (o.enabled()) { static_cast<std::ostream&>(o) << s; } return o; };
|
{ if (o.enabled()) { static_cast<std::ostream&>(o) << t; } return o; }; \
|
||||||
|
\
|
||||||
|
inline mstream& operator<< ( mstream& o, const Type t ) \
|
||||||
|
{ if (o.enabled()) { static_cast<std::ostream&>(o) << t; } return o; };
|
||||||
|
|
||||||
#define MSTREAM_R_SUPPORT(Type) \
|
#define MSTREAM_R_SUPPORT(Type) \
|
||||||
inline mstream& operator<< ( mstream& o, const Type& s ) \
|
inline mstream& operator<< ( mstream& o, const Type& t ) \
|
||||||
{ if (o.enabled()) { static_cast<std::ostream&>(o) << s; } return o; };
|
{ if (o.enabled()) { static_cast<std::ostream&>(o) << t; } return o; }; \
|
||||||
|
\
|
||||||
|
inline mstream& operator<< ( mstream& o, Type& t ) \
|
||||||
|
{ if (o.enabled()) { static_cast<std::ostream&>(o) << t; } return o; };
|
||||||
|
|
||||||
#define MSTREAM_P_SUPPORT(Type) \
|
#define MSTREAM_P_SUPPORT(Type) \
|
||||||
inline mstream& operator<< ( mstream& o, const Type* s ) \
|
inline mstream& operator<< ( mstream& o, const Type* t ) \
|
||||||
{ if (o.enabled()) { static_cast<std::ostream&>(o) << s; } return o; };
|
{ if (o.enabled()) { static_cast<std::ostream&>(o) << t; } return o; }; \
|
||||||
|
\
|
||||||
|
inline mstream& operator<< ( mstream& o, Type* t ) \
|
||||||
|
{ if (o.enabled()) { static_cast<std::ostream&>(o) << t; } return o; };
|
||||||
|
|
||||||
#define MSTREAM_PR_SUPPORT(Type) \
|
#define MSTREAM_PR_SUPPORT(Type) \
|
||||||
MSTREAM_P_SUPPORT(Type) \
|
MSTREAM_P_SUPPORT(Type) \
|
||||||
MSTREAM_R_SUPPORT(Type)
|
MSTREAM_R_SUPPORT(Type)
|
||||||
|
|
||||||
MSTREAM_PR_SUPPORT(std::string);
|
|
||||||
|
|
||||||
|
|
||||||
// -------------------------------------------------------------------
|
// -------------------------------------------------------------------
|
||||||
// Shared objects.
|
// Shared objects.
|
||||||
|
|
||||||
|
|
||||||
extern mstream cmess0;
|
extern mstream cmess0;
|
||||||
extern mstream cmess1;
|
extern mstream cmess1;
|
||||||
extern mstream cmess2;
|
extern mstream cmess2;
|
||||||
|
@ -346,39 +352,12 @@ extern mstream cparanoid;
|
||||||
extern mstream cbug;
|
extern mstream cbug;
|
||||||
|
|
||||||
|
|
||||||
// -------------------------------------------------------------------
|
|
||||||
// Class : "::Dots".
|
|
||||||
|
|
||||||
|
|
||||||
class Dots {
|
|
||||||
public:
|
|
||||||
static Dots asPercentage ( const std::string& left, float );
|
|
||||||
static Dots asBool ( const std::string& left, bool );
|
|
||||||
static Dots asInt ( const std::string& left, int );
|
|
||||||
static Dots asUInt ( const std::string& left, unsigned int );
|
|
||||||
static Dots asULong ( const std::string& left, unsigned long );
|
|
||||||
static Dots asSizet ( const std::string& left, size_t );
|
|
||||||
static Dots asDouble ( const std::string& left, double );
|
|
||||||
static Dots asLambda ( const std::string& left, Hurricane::DbU::Unit );
|
|
||||||
static Dots asLambda ( const std::string& left, double );
|
|
||||||
static Dots asIdentifier ( const std::string& left, const std::string& );
|
|
||||||
static Dots asString ( const std::string& left, const std::string& );
|
|
||||||
private:
|
|
||||||
Dots ( const std::string& left, const std::string& right );
|
|
||||||
friend std::ostream& operator<< ( std::ostream&, const Dots& );
|
|
||||||
private:
|
|
||||||
const std::string _left;
|
|
||||||
const std::string _right;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
// -------------------------------------------------------------------
|
// -------------------------------------------------------------------
|
||||||
// Class : "::linefill()".
|
// Class : "::linefill()".
|
||||||
//
|
//
|
||||||
// Wrapper around the STL ostream which try print unbufferized filed
|
// Wrapper around the STL ostream which try print unbufferized filed
|
||||||
// lines.
|
// lines.
|
||||||
|
|
||||||
|
|
||||||
class linefill : public std::ostream {
|
class linefill : public std::ostream {
|
||||||
public:
|
public:
|
||||||
inline linefill ( const std::string& header, mstream &s );
|
inline linefill ( const std::string& header, mstream &s );
|
||||||
|
@ -460,4 +439,29 @@ inline linefill& linefill::operator<< ( const T* t )
|
||||||
LINEFILL_PR_SUPPORT(std::string);
|
LINEFILL_PR_SUPPORT(std::string);
|
||||||
|
|
||||||
|
|
||||||
|
// -------------------------------------------------------------------
|
||||||
|
// Class : "::Dots".
|
||||||
|
|
||||||
|
class Dots {
|
||||||
|
public:
|
||||||
|
static Dots asPercentage ( const std::string& left, float );
|
||||||
|
static Dots asBool ( const std::string& left, bool );
|
||||||
|
static Dots asInt ( const std::string& left, int );
|
||||||
|
static Dots asUInt ( const std::string& left, unsigned int );
|
||||||
|
static Dots asULong ( const std::string& left, unsigned long );
|
||||||
|
static Dots asSizet ( const std::string& left, size_t );
|
||||||
|
static Dots asDouble ( const std::string& left, double );
|
||||||
|
static Dots asLambda ( const std::string& left, Hurricane::DbU::Unit );
|
||||||
|
static Dots asLambda ( const std::string& left, double );
|
||||||
|
static Dots asIdentifier ( const std::string& left, const std::string& );
|
||||||
|
static Dots asString ( const std::string& left, const std::string& );
|
||||||
|
private:
|
||||||
|
Dots ( const std::string& left, const std::string& right );
|
||||||
|
friend std::ostream& operator<< ( std::ostream&, const Dots& );
|
||||||
|
private:
|
||||||
|
const std::string _left;
|
||||||
|
const std::string _right;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
#endif // CRL_UTILITIES
|
#endif // CRL_UTILITIES
|
||||||
|
|
|
@ -2,7 +2,6 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
#include "hurricane/DataBase.h"
|
#include "hurricane/DataBase.h"
|
||||||
#include "hurricane/Technology.h"
|
#include "hurricane/Technology.h"
|
||||||
|
@ -15,6 +14,7 @@ using namespace Hurricane;
|
||||||
#include "crlcore/LefDefExtension.h"
|
#include "crlcore/LefDefExtension.h"
|
||||||
#include "crlcore/NetExtension.h"
|
#include "crlcore/NetExtension.h"
|
||||||
using namespace CRL;
|
using namespace CRL;
|
||||||
|
using namespace std;
|
||||||
#include "crlcore/Ioc.h"
|
#include "crlcore/Ioc.h"
|
||||||
|
|
||||||
#define yyin Iocin
|
#define yyin Iocin
|
||||||
|
|
|
@ -1,15 +1,9 @@
|
||||||
|
|
||||||
// -*- C++ -*-
|
// -*- C++ -*-
|
||||||
//
|
//
|
||||||
// This file is part of the Coriolis Software.
|
// This file is part of the Coriolis Software.
|
||||||
// Copyright (c) UPMC/LIP6 2008-2008, All Rights Reserved
|
// Copyright (c) UPMC 2008-2014, All Rights Reserved
|
||||||
//
|
//
|
||||||
// ===================================================================
|
// +-----------------------------------------------------------------+
|
||||||
//
|
|
||||||
// $Id$
|
|
||||||
//
|
|
||||||
// x-----------------------------------------------------------------x
|
|
||||||
// | |
|
|
||||||
// | C O R I O L I S |
|
// | C O R I O L I S |
|
||||||
// | Alliance / Hurricane Interface |
|
// | Alliance / Hurricane Interface |
|
||||||
// | |
|
// | |
|
||||||
|
@ -17,16 +11,16 @@
|
||||||
// | E-mail : Jean-Paul.Chaput@lip6.fr |
|
// | E-mail : Jean-Paul.Chaput@lip6.fr |
|
||||||
// | =============================================================== |
|
// | =============================================================== |
|
||||||
// | C++ Module : "./LefDefExtension.cpp" |
|
// | C++ Module : "./LefDefExtension.cpp" |
|
||||||
// | *************************************************************** |
|
// +-----------------------------------------------------------------+
|
||||||
// | U p d a t e s |
|
|
||||||
// | |
|
|
||||||
// x-----------------------------------------------------------------x
|
|
||||||
|
|
||||||
|
|
||||||
#include "hurricane/Error.h"
|
#include "hurricane/Error.h"
|
||||||
#include "hurricane/Cell.h"
|
#include "hurricane/Cell.h"
|
||||||
|
#include "crlcore/LefDefExtension.h"
|
||||||
|
|
||||||
#include "crlcore/LefDefExtension.h"
|
|
||||||
|
template<>
|
||||||
|
Hurricane::Name CRL::LefDefExtension::Extension::_name = "CRL::LefDefExtension";
|
||||||
|
|
||||||
|
|
||||||
namespace CRL {
|
namespace CRL {
|
||||||
|
@ -37,10 +31,6 @@ namespace CRL {
|
||||||
|
|
||||||
const char* MissingLefDefExtension = "LefDefExtension::%s(): %s missing the LEF/DEF extension.";
|
const char* MissingLefDefExtension = "LefDefExtension::%s(): %s missing the LEF/DEF extension.";
|
||||||
|
|
||||||
|
|
||||||
template<>
|
|
||||||
Name LefDefExtension::Extension::_name = "CRL::LefDefExtension";
|
|
||||||
|
|
||||||
|
|
||||||
// -------------------------------------------------------------------
|
// -------------------------------------------------------------------
|
||||||
// Class : "CRL::LefDefExtensionDatas".
|
// Class : "CRL::LefDefExtensionDatas".
|
||||||
|
|
|
@ -1,15 +1,9 @@
|
||||||
|
|
||||||
// -*- C++ -*-
|
// -*- C++ -*-
|
||||||
//
|
//
|
||||||
// This file is part of the Coriolis Software.
|
// This file is part of the Coriolis Software.
|
||||||
// Copyright (c) UPMC/LIP6 2008-2010, All Rights Reserved
|
// Copyright (c) UPMC 2008-2014, All Rights Reserved
|
||||||
//
|
//
|
||||||
// ===================================================================
|
// +-----------------------------------------------------------------+
|
||||||
//
|
|
||||||
// $Id$
|
|
||||||
//
|
|
||||||
// x-----------------------------------------------------------------x
|
|
||||||
// | |
|
|
||||||
// | C O R I O L I S |
|
// | C O R I O L I S |
|
||||||
// | Alliance / Hurricane Interface |
|
// | Alliance / Hurricane Interface |
|
||||||
// | |
|
// | |
|
||||||
|
@ -17,20 +11,19 @@
|
||||||
// | E-mail : Jean-Paul.Chaput@lip6.fr |
|
// | E-mail : Jean-Paul.Chaput@lip6.fr |
|
||||||
// | =============================================================== |
|
// | =============================================================== |
|
||||||
// | C++ Module : "./Measures.cpp" |
|
// | C++ Module : "./Measures.cpp" |
|
||||||
// | *************************************************************** |
|
// +-----------------------------------------------------------------+
|
||||||
// | U p d a t e s |
|
|
||||||
// | |
|
|
||||||
// x-----------------------------------------------------------------x
|
|
||||||
|
|
||||||
|
|
||||||
#include <iomanip>
|
#include <iomanip>
|
||||||
|
|
||||||
#include "hurricane/Error.h"
|
#include "hurricane/Error.h"
|
||||||
#include "hurricane/DBo.h"
|
#include "hurricane/DBo.h"
|
||||||
|
|
||||||
#include "crlcore/Measures.h"
|
#include "crlcore/Measures.h"
|
||||||
|
|
||||||
|
|
||||||
|
template<>
|
||||||
|
Hurricane::Name Hurricane::StandardPrivateProperty<CRL::MeasuresDatas>::_name = "CRL::Measures";
|
||||||
|
|
||||||
|
|
||||||
namespace CRL {
|
namespace CRL {
|
||||||
|
|
||||||
|
|
||||||
|
@ -60,10 +53,6 @@ namespace CRL {
|
||||||
// Class : "CRL::MeasuresSet".
|
// Class : "CRL::MeasuresSet".
|
||||||
|
|
||||||
|
|
||||||
template<>
|
|
||||||
Name StandardPrivateProperty<MeasuresDatas>::_name = "CRL::Measures";
|
|
||||||
|
|
||||||
|
|
||||||
MeasuresSet::~MeasuresSet ()
|
MeasuresSet::~MeasuresSet ()
|
||||||
{
|
{
|
||||||
iterator imeasure = begin();
|
iterator imeasure = begin();
|
||||||
|
|
|
@ -1,15 +1,9 @@
|
||||||
|
|
||||||
// -*- C++ -*-
|
// -*- C++ -*-
|
||||||
//
|
//
|
||||||
// This file is part of the Coriolis Software.
|
// This file is part of the Coriolis Software.
|
||||||
// Copyright (c) UPMC/LIP6 2008-2010, All Rights Reserved
|
// Copyright (c) UPMC 2008-2014, All Rights Reserved
|
||||||
//
|
//
|
||||||
// ===================================================================
|
// +-----------------------------------------------------------------+
|
||||||
//
|
|
||||||
// $Id$
|
|
||||||
//
|
|
||||||
// x-----------------------------------------------------------------x
|
|
||||||
// | |
|
|
||||||
// | C O R I O L I S |
|
// | C O R I O L I S |
|
||||||
// | Alliance / Hurricane Interface |
|
// | Alliance / Hurricane Interface |
|
||||||
// | |
|
// | |
|
||||||
|
@ -17,17 +11,17 @@
|
||||||
// | E-mail : Jean-Paul.Chaput@lip6.fr |
|
// | E-mail : Jean-Paul.Chaput@lip6.fr |
|
||||||
// | =============================================================== |
|
// | =============================================================== |
|
||||||
// | C++ Module : "./NetExtension.cpp" |
|
// | C++ Module : "./NetExtension.cpp" |
|
||||||
// | *************************************************************** |
|
// +-----------------------------------------------------------------+
|
||||||
// | U p d a t e s |
|
|
||||||
// | |
|
|
||||||
// x-----------------------------------------------------------------x
|
|
||||||
|
|
||||||
|
|
||||||
#include "hurricane/Error.h"
|
#include "hurricane/Error.h"
|
||||||
#include "hurricane/Net.h"
|
#include "hurricane/Net.h"
|
||||||
#include "hurricane/Cell.h"
|
#include "hurricane/Cell.h"
|
||||||
|
#include "crlcore/NetExtension.h"
|
||||||
|
|
||||||
#include "crlcore/NetExtension.h"
|
|
||||||
|
template<>
|
||||||
|
Hurricane::Name Hurricane::StandardPrivateProperty<CRL::NetExtensionDatas>::_name = "CRL::NetExtension";
|
||||||
|
|
||||||
|
|
||||||
namespace CRL {
|
namespace CRL {
|
||||||
|
@ -39,10 +33,6 @@ namespace CRL {
|
||||||
|
|
||||||
const char* MissingNetExtension = "NetExtension::%s(): %s missing the Net extension.";
|
const char* MissingNetExtension = "NetExtension::%s(): %s missing the Net extension.";
|
||||||
|
|
||||||
|
|
||||||
template<>
|
|
||||||
Name StandardPrivateProperty<NetExtensionDatas>::_name = "CRL::NetExtension";
|
|
||||||
|
|
||||||
|
|
||||||
// -------------------------------------------------------------------
|
// -------------------------------------------------------------------
|
||||||
// Class : "CRL::NetExtensionDatas".
|
// Class : "CRL::NetExtensionDatas".
|
||||||
|
|
|
@ -551,10 +551,12 @@ END_IF
|
||||||
list<string>::iterator it6_begin = (*it5_begin).second.begin(),
|
list<string>::iterator it6_begin = (*it5_begin).second.begin(),
|
||||||
it6_end = (*it5_begin).second.end(); // signal index list iterator
|
it6_end = (*it5_begin).second.end(); // signal index list iterator
|
||||||
|
|
||||||
list<Net*>::iterator it7_begin = // masterModel port list iterator
|
list<Net*>::iterator it7_begin = // masterModel port list iterator
|
||||||
modelNameToPortListMap[getString(masterModel->getName())].begin(),
|
modelNameToPortListMap[getString(masterModel->getName())].begin();
|
||||||
it7_end =
|
#ifndef NDEBUG
|
||||||
modelNameToPortListMap[getString(masterModel->getName())].end();
|
list<Net*>::iterator it7_end =
|
||||||
|
modelNameToPortListMap[getString(masterModel->getName())].end();
|
||||||
|
#endif
|
||||||
|
|
||||||
while(it6_begin!=it6_end){ // For all port<=> signals to branch.
|
while(it6_begin!=it6_end){ // For all port<=> signals to branch.
|
||||||
ins->getPlug(*it7_begin)->setNet(_model->getNet((*_indexToNetNameMap)[*it6_begin]));
|
ins->getPlug(*it7_begin)->setNet(_model->getNet((*_indexToNetNameMap)[*it6_begin]));
|
||||||
|
|
|
@ -45,6 +45,7 @@ using namespace Hurricane;
|
||||||
|
|
||||||
#include "DemoGo.h"
|
#include "DemoGo.h"
|
||||||
#include "Cyclop.h"
|
#include "Cyclop.h"
|
||||||
|
#include "crlcore/Utilities.h"
|
||||||
using namespace CRL;
|
using namespace CRL;
|
||||||
|
|
||||||
|
|
||||||
|
@ -54,23 +55,23 @@ namespace {
|
||||||
// -------------------------------------------------------------------
|
// -------------------------------------------------------------------
|
||||||
// Function : "printHelp()".
|
// Function : "printHelp()".
|
||||||
|
|
||||||
void printHelp ()
|
// void printHelp ()
|
||||||
{
|
// {
|
||||||
cout << endl;
|
// cout << endl;
|
||||||
cout << "Usage: cyclop [-v|--verbose] [-V|--very-verbose] [-D|--core-dump] \\\n"
|
// cout << "Usage: cyclop [-v|--verbose] [-V|--very-verbose] [-D|--core-dump] \\\n"
|
||||||
<< " [-l|--trace-level <traceLevel>] [-c|--cell <cellName>] \\\n"
|
// << " [-l|--trace-level <traceLevel>] [-c|--cell <cellName>] \\\n"
|
||||||
<< endl;
|
// << endl;
|
||||||
cout << "Options:\n"
|
// cout << "Options:\n"
|
||||||
<< " o [-v|--verbose] : First level of verbosity.\n"
|
// << " o [-v|--verbose] : First level of verbosity.\n"
|
||||||
<< " o [-V|--very-verbose] : Second level of verbosity (very talkative).\n"
|
// << " o [-V|--very-verbose] : Second level of verbosity (very talkative).\n"
|
||||||
<< " o [-D|--core-dump] : Enable core dumping.\n"
|
// << " o [-D|--core-dump] : Enable core dumping.\n"
|
||||||
<< " o [-l|--trace-level <traceLevel>] :\n"
|
// << " o [-l|--trace-level <traceLevel>] :\n"
|
||||||
<< " Sets the level of trace, trace messages with a level superior to\n"
|
// << " Sets the level of trace, trace messages with a level superior to\n"
|
||||||
<< " <traceLevel> will be printed on <stderr>.\n"
|
// << " <traceLevel> will be printed on <stderr>.\n"
|
||||||
<< " o [-c|--cell <cellName>] :\n"
|
// << " o [-c|--cell <cellName>] :\n"
|
||||||
<< " The name of the Cell to load, without extention.\n"
|
// << " The name of the Cell to load, without extention.\n"
|
||||||
<< endl;
|
// << endl;
|
||||||
}
|
// }
|
||||||
|
|
||||||
|
|
||||||
} // End of anonymous namespace.
|
} // End of anonymous namespace.
|
||||||
|
|
|
@ -14,9 +14,9 @@
|
||||||
// +-----------------------------------------------------------------+
|
// +-----------------------------------------------------------------+
|
||||||
|
|
||||||
|
|
||||||
#include "crlcore/Ispd05Bookshelf.h"
|
|
||||||
#include "crlcore/PyIspd05.h"
|
#include "crlcore/PyIspd05.h"
|
||||||
#include "hurricane/isobar/PyCell.h"
|
#include "hurricane/isobar/PyCell.h"
|
||||||
|
#include "crlcore/Ispd05Bookshelf.h"
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
|
|
||||||
|
|
|
@ -89,10 +89,10 @@ namespace Equinox {
|
||||||
/**/ Record* _getRecord () const;
|
/**/ Record* _getRecord () const;
|
||||||
/**/ string _getString () const;
|
/**/ string _getString () const;
|
||||||
/**/ Box getBoundingBox () const;
|
/**/ Box getBoundingBox () const;
|
||||||
/**/ void run ( vector < ITEM >* _itemsByXmin,
|
/**/ void run ( vector < ITEM >* _itemsByXmin
|
||||||
vector < ITEM >* _itemsByXmax,
|
, vector < ITEM >* _itemsByXmax
|
||||||
bool stopToMax,
|
, bool stopToMax = false
|
||||||
int max);
|
, int max = 0 );
|
||||||
|
|
||||||
/**/ void initIntervalSets () ;
|
/**/ void initIntervalSets () ;
|
||||||
/**/inline void insertInterval (ITEM newitem);
|
/**/inline void insertInterval (ITEM newitem);
|
||||||
|
@ -346,7 +346,7 @@ inline void SweepLine<ITEM,ENGINE>::insertInterval(ITEM item)
|
||||||
|
|
||||||
|
|
||||||
template < typename ITEM, typename ENGINE >
|
template < typename ITEM, typename ENGINE >
|
||||||
void SweepLine<ITEM,ENGINE>::run (vector < ITEM >* _itemsByXmin, vector < ITEM >* _itemsByXmax,bool stopAtMax = false,int max = 0)
|
void SweepLine<ITEM,ENGINE>::run (vector < ITEM >* _itemsByXmin, vector < ITEM >* _itemsByXmax,bool stopAtMax, int max )
|
||||||
{
|
{
|
||||||
|
|
||||||
///*DEBUG*/ cmess1 << " o SweepLine :: run : " << endl;
|
///*DEBUG*/ cmess1 << " o SweepLine :: run : " << endl;
|
||||||
|
|
|
@ -50,6 +50,7 @@ namespace {
|
||||||
using namespace Hurricane;
|
using namespace Hurricane;
|
||||||
|
|
||||||
|
|
||||||
|
#if HAVE_COLOQUINTE
|
||||||
string extractInstanceName ( const RoutingPad* rp )
|
string extractInstanceName ( const RoutingPad* rp )
|
||||||
{
|
{
|
||||||
ostringstream name;
|
ostringstream name;
|
||||||
|
@ -101,7 +102,6 @@ namespace {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#if HAVE_COLOQUINTE
|
|
||||||
Coloquinte::cell::pin::pin_dir extractDirection ( const RoutingPad* rp )
|
Coloquinte::cell::pin::pin_dir extractDirection ( const RoutingPad* rp )
|
||||||
{
|
{
|
||||||
switch ( rp->_getEntityAsComponent()->getNet()->getDirection() ) {
|
switch ( rp->_getEntityAsComponent()->getNet()->getDirection() ) {
|
||||||
|
@ -114,7 +114,6 @@ namespace {
|
||||||
|
|
||||||
return Coloquinte::cell::pin::O;
|
return Coloquinte::cell::pin::O;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
Point extractRpOffset ( const RoutingPad* rp )
|
Point extractRpOffset ( const RoutingPad* rp )
|
||||||
|
@ -130,6 +129,7 @@ namespace {
|
||||||
|
|
||||||
return offset;
|
return offset;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
} // Anonymous namespace.
|
} // Anonymous namespace.
|
||||||
|
|
|
@ -60,15 +60,15 @@ extern "C" {
|
||||||
#if defined(__PYTHON_MODULE__)
|
#if defined(__PYTHON_MODULE__)
|
||||||
|
|
||||||
|
|
||||||
static DbU::SnapMode PyInt_AsSnapMode ( PyObject* object ) {
|
// static DbU::SnapMode PyInt_AsSnapMode ( PyObject* object ) {
|
||||||
switch ( PyAny_AsLong(object) ) {
|
// switch ( PyAny_AsLong(object) ) {
|
||||||
case DbU::Inferior : return ( DbU::Inferior );
|
// case DbU::Inferior : return ( DbU::Inferior );
|
||||||
case DbU::Superior : return ( DbU::Superior );
|
// case DbU::Superior : return ( DbU::Superior );
|
||||||
case DbU::Nearest : return ( DbU::Nearest );
|
// case DbU::Nearest : return ( DbU::Nearest );
|
||||||
}
|
// }
|
||||||
|
|
||||||
return ( DbU::Superior );
|
// return ( DbU::Superior );
|
||||||
}
|
// }
|
||||||
|
|
||||||
static DbU::UnitPower PyInt_AsUnitPower ( PyObject* object ) {
|
static DbU::UnitPower PyInt_AsUnitPower ( PyObject* object ) {
|
||||||
switch ( PyAny_AsLong(object) ) {
|
switch ( PyAny_AsLong(object) ) {
|
||||||
|
|
|
@ -95,12 +95,13 @@ extern "C" {
|
||||||
|
|
||||||
METHOD_HEAD ( "Interval.getUnion()" )
|
METHOD_HEAD ( "Interval.getUnion()" )
|
||||||
|
|
||||||
PyInterval* otherPyInterval;
|
Interval* uinterval = NULL;
|
||||||
|
PyInterval* otherPyInterval = NULL;
|
||||||
if (PyArg_ParseTuple(args,"O!:Interval.getUnion", &PyTypeInterval, &otherPyInterval)) {
|
if (PyArg_ParseTuple(args,"O!:Interval.getUnion", &PyTypeInterval, &otherPyInterval)) {
|
||||||
HTRY
|
HTRY
|
||||||
Interval* interval = new Interval ( interval->getUnion(*PYINTERVAL_O(otherPyInterval)));
|
uinterval = new Interval ( interval->getUnion(*PYINTERVAL_O(otherPyInterval)));
|
||||||
HCATCH
|
HCATCH
|
||||||
return PyInterval_Link( interval );
|
return PyInterval_Link( uinterval );
|
||||||
} else {
|
} else {
|
||||||
PyErr_SetString ( ConstructorError, "invalid number of parameters for Interval.getUnion.");
|
PyErr_SetString ( ConstructorError, "invalid number of parameters for Interval.getUnion.");
|
||||||
}
|
}
|
||||||
|
@ -113,12 +114,13 @@ extern "C" {
|
||||||
|
|
||||||
METHOD_HEAD ( "Interval.getIntersection()" )
|
METHOD_HEAD ( "Interval.getIntersection()" )
|
||||||
|
|
||||||
|
Interval* iinterval = NULL;
|
||||||
PyInterval* otherPyInterval = NULL;
|
PyInterval* otherPyInterval = NULL;
|
||||||
if (PyArg_ParseTuple(args,"O!:Interval.getIntersection", &PyTypeInterval, &otherPyInterval)) {
|
if (PyArg_ParseTuple(args,"O!:Interval.getIntersection", &PyTypeInterval, &otherPyInterval)) {
|
||||||
HTRY
|
HTRY
|
||||||
Interval* interval = new Interval(interval->getIntersection(*PYINTERVAL_O(otherPyInterval)));
|
iinterval = new Interval(interval->getIntersection(*PYINTERVAL_O(otherPyInterval)));
|
||||||
HCATCH
|
HCATCH
|
||||||
return PyInterval_Link( interval );
|
return PyInterval_Link( iinterval );
|
||||||
} else {
|
} else {
|
||||||
PyErr_SetString(ConstructorError, "invalid number of parameters for Interval.getIntersection.");
|
PyErr_SetString(ConstructorError, "invalid number of parameters for Interval.getIntersection.");
|
||||||
}
|
}
|
||||||
|
|
|
@ -682,9 +682,8 @@ namespace Hurricane {
|
||||||
list< shared_ptr<CellWidget::State> >::iterator istate = _cellHistory.begin();
|
list< shared_ptr<CellWidget::State> >::iterator istate = _cellHistory.begin();
|
||||||
size_t index = historyAction->data().toUInt();
|
size_t index = historyAction->data().toUInt();
|
||||||
|
|
||||||
for ( ; index>0 ; index--, istate++ );
|
//for ( ; index>0 ; index--, istate++ )
|
||||||
|
// cerr << "History: " << (*istate)->getName() << endl;
|
||||||
//cerr << "History: " << (*istate)->getName() << endl;
|
|
||||||
emit stateChanged ( *istate );
|
emit stateChanged ( *istate );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,12 +29,12 @@ namespace {
|
||||||
using std::istringstream;
|
using std::istringstream;
|
||||||
|
|
||||||
|
|
||||||
void parseInt ( const char* s, int& value )
|
// void parseInt ( const char* s, int& value )
|
||||||
{ istringstream is ( s ); is >> value; }
|
// { istringstream is ( s ); is >> value; }
|
||||||
|
|
||||||
|
|
||||||
void parseFloat ( const char* s, float& value )
|
// void parseFloat ( const char* s, float& value )
|
||||||
{ istringstream is ( s ); is >> value; }
|
// { istringstream is ( s ); is >> value; }
|
||||||
|
|
||||||
|
|
||||||
void parseRgbColor ( const char* color, int& red, int& green, int& blue )
|
void parseRgbColor ( const char* color, int& red, int& green, int& blue )
|
||||||
|
@ -46,7 +46,6 @@ namespace {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
} // Anonymous namespace.
|
} // Anonymous namespace.
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
// -*- C++ -*-
|
// -*- C++ -*-
|
||||||
//
|
//
|
||||||
// This file is part of the Coriolis Software.
|
// This file is part of the Coriolis Software.
|
||||||
// Copyright (c) UPMC/LIP6 2012-2012, All Rights Reserved
|
// Copyright (c) UPMC 2012-2014, All Rights Reserved
|
||||||
//
|
//
|
||||||
// +-----------------------------------------------------------------+
|
// +-----------------------------------------------------------------+
|
||||||
// | C O R I O L I S |
|
// | C O R I O L I S |
|
||||||
|
@ -26,12 +26,12 @@ namespace {
|
||||||
using std::istringstream;
|
using std::istringstream;
|
||||||
|
|
||||||
|
|
||||||
void parseInt ( const char* s, int& value )
|
// void parseInt ( const char* s, int& value )
|
||||||
{ istringstream is ( s ); is >> value; }
|
// { istringstream is ( s ); is >> value; }
|
||||||
|
|
||||||
|
|
||||||
void parseFloat ( const char* s, float& value )
|
// void parseFloat ( const char* s, float& value )
|
||||||
{ istringstream is ( s ); is >> value; }
|
// { istringstream is ( s ); is >> value; }
|
||||||
|
|
||||||
|
|
||||||
void parseRgbColor ( const char* color, int& red, int& green, int& blue )
|
void parseRgbColor ( const char* color, int& red, int& green, int& blue )
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include "hurricane/Warning.h"
|
#include "hurricane/Warning.h"
|
||||||
#include "hurricane/Bug.h"
|
#include "hurricane/Bug.h"
|
||||||
|
#include "hurricane/Torus.h"
|
||||||
#include "hurricane/DataBase.h"
|
#include "hurricane/DataBase.h"
|
||||||
#include "hurricane/Technology.h"
|
#include "hurricane/Technology.h"
|
||||||
#include "hurricane/Horizontal.h"
|
#include "hurricane/Horizontal.h"
|
||||||
|
|
|
@ -611,14 +611,12 @@ namespace Katabatic {
|
||||||
if ( (i%2) and (_densities[i] > density) ) density = _densities[i];
|
if ( (i%2) and (_densities[i] > density) ) density = _densities[i];
|
||||||
}
|
}
|
||||||
//density = roundfp(density);
|
//density = roundfp(density);
|
||||||
density = density;
|
|
||||||
} else if (getGCellGrid()->getDensityMode() == GCellGrid::MaxVDensity) {
|
} else if (getGCellGrid()->getDensityMode() == GCellGrid::MaxVDensity) {
|
||||||
// Density of the most saturated vertical layer.
|
// Density of the most saturated vertical layer.
|
||||||
for ( size_t i=_pinDepth ; i<_depth ; i++ ) {
|
for ( size_t i=_pinDepth ; i<_depth ; i++ ) {
|
||||||
if ( (i%2 == 0) and (_densities[i] > density) ) density = _densities[i];
|
if ( (i%2 == 0) and (_densities[i] > density) ) density = _densities[i];
|
||||||
}
|
}
|
||||||
//density = roundfp(density);
|
//density = roundfp(density);
|
||||||
density = density;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return density;
|
return density;
|
||||||
|
@ -758,18 +756,18 @@ namespace Katabatic {
|
||||||
sort ( _hsegments.begin(), _hsegments.end(), AutoSegment::CompareByDepthLength() );
|
sort ( _hsegments.begin(), _hsegments.end(), AutoSegment::CompareByDepthLength() );
|
||||||
sort ( _vsegments.begin(), _vsegments.end(), AutoSegment::CompareByDepthLength() );
|
sort ( _vsegments.begin(), _vsegments.end(), AutoSegment::CompareByDepthLength() );
|
||||||
|
|
||||||
float hcapacity = getHCapacity ();
|
float hcapacity = getHCapacity ();
|
||||||
float vcapacity = getVCapacity ();
|
float vcapacity = getVCapacity ();
|
||||||
float ccapacity = hcapacity * vcapacity * 4;
|
float ccapacity = hcapacity * vcapacity * 4;
|
||||||
DbU::Unit hpenalty = 0 /*_box.getWidth () / 3*/;
|
DbU::Unit hpenalty = 0 /*_box.getWidth () / 3*/;
|
||||||
DbU::Unit vpenalty = 0 /*_box.getHeight() / 3*/;
|
DbU::Unit vpenalty = 0 /*_box.getHeight() / 3*/;
|
||||||
DbU::Unit uLengths1 [ _depth ];
|
DbU::Unit uLengths1 [ _depth ];
|
||||||
DbU::Unit uLengths2 [ _depth ];
|
DbU::Unit uLengths2 [ _depth ];
|
||||||
float localCounts [ _depth ];
|
float localCounts [ _depth ];
|
||||||
UsedFragments ufragments [ _depth ];
|
vector<UsedFragments> ufragments ( _depth );
|
||||||
|
|
||||||
for ( size_t i=0 ; i<_depth ; i++ ) {
|
for ( size_t i=0 ; i<_depth ; i++ ) {
|
||||||
ufragments [i].setPitch ( Session::getPitch(i) );
|
ufragments[i].setPitch ( Session::getPitch(i) );
|
||||||
_feedthroughs[i] = 0.0;
|
_feedthroughs[i] = 0.0;
|
||||||
uLengths2 [i] = 0;
|
uLengths2 [i] = 0;
|
||||||
localCounts [i] = 0.0;
|
localCounts [i] = 0.0;
|
||||||
|
@ -809,7 +807,7 @@ namespace Katabatic {
|
||||||
size_t count = 0;
|
size_t count = 0;
|
||||||
for ( size_t i=0 ; i<_hsegments.size() ; i++ ) {
|
for ( size_t i=0 ; i<_hsegments.size() ; i++ ) {
|
||||||
_globalsCount[depth] += 1.0;
|
_globalsCount[depth] += 1.0;
|
||||||
ufragments [depth].incGlobals();
|
ufragments[depth].incGlobals();
|
||||||
|
|
||||||
if ( layer != _hsegments[i]->getLayer() ) {
|
if ( layer != _hsegments[i]->getLayer() ) {
|
||||||
uLengths2[depth] += count * _box.getWidth();
|
uLengths2[depth] += count * _box.getWidth();
|
||||||
|
@ -833,7 +831,7 @@ namespace Katabatic {
|
||||||
size_t count = 0;
|
size_t count = 0;
|
||||||
for ( size_t i=0 ; i<_vsegments.size() ; i++ ) {
|
for ( size_t i=0 ; i<_vsegments.size() ; i++ ) {
|
||||||
_globalsCount[depth] += 1.0;
|
_globalsCount[depth] += 1.0;
|
||||||
ufragments [depth].incGlobals();
|
ufragments[depth].incGlobals();
|
||||||
|
|
||||||
if ( layer != _vsegments[i]->getLayer() ) {
|
if ( layer != _vsegments[i]->getLayer() ) {
|
||||||
uLengths2[depth] += count * _box.getHeight();
|
uLengths2[depth] += count * _box.getHeight();
|
||||||
|
|
|
@ -43,6 +43,7 @@ namespace {
|
||||||
using namespace Hurricane;
|
using namespace Hurricane;
|
||||||
|
|
||||||
|
|
||||||
|
#if 0
|
||||||
bool isTopAndBottomConnected ( Segment* segment, set<const Layer*>& layers )
|
bool isTopAndBottomConnected ( Segment* segment, set<const Layer*>& layers )
|
||||||
{
|
{
|
||||||
ltrace(88) << "* Potential Null Length: " << segment << endl;
|
ltrace(88) << "* Potential Null Length: " << segment << endl;
|
||||||
|
@ -77,6 +78,7 @@ namespace {
|
||||||
|
|
||||||
return layers.size()+supplemental > 2;
|
return layers.size()+supplemental > 2;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
} // End of anonymous namespace.
|
} // End of anonymous namespace.
|
||||||
|
|
|
@ -178,7 +178,7 @@ namespace Katabatic {
|
||||||
bool stepNetDesaturate ( unsigned int depth
|
bool stepNetDesaturate ( unsigned int depth
|
||||||
, set<Net*>& globalNets
|
, set<Net*>& globalNets
|
||||||
, SetIndex& invalidateds );
|
, SetIndex& invalidateds );
|
||||||
inline void invalidate ();
|
inline void invalidateCt ();
|
||||||
inline void setUnderIoPad ();
|
inline void setUnderIoPad ();
|
||||||
// Inspector Management.
|
// Inspector Management.
|
||||||
Record* _getRecord () const;
|
Record* _getRecord () const;
|
||||||
|
@ -246,7 +246,7 @@ namespace Katabatic {
|
||||||
inline const vector<AutoSegment*>& GCell::getHSegments () const { return _hsegments; }
|
inline const vector<AutoSegment*>& GCell::getHSegments () const { return _hsegments; }
|
||||||
inline const vector<AutoContact*>& GCell::getContacts () const { return _contacts; }
|
inline const vector<AutoContact*>& GCell::getContacts () const { return _contacts; }
|
||||||
inline string GCell::_getTypeName () const { return _TName("GCell"); }
|
inline string GCell::_getTypeName () const { return _TName("GCell"); }
|
||||||
inline void GCell::invalidate () { _flags |= GCellInvalidated; }
|
inline void GCell::invalidateCt () { _flags |= GCellInvalidated; }
|
||||||
inline void GCell::setUnderIoPad() { _flags |= GCellUnderIoPad; }
|
inline void GCell::setUnderIoPad() { _flags |= GCellUnderIoPad; }
|
||||||
inline const GCell::Key& GCell::getKey () const { return _key; }
|
inline const GCell::Key& GCell::getKey () const { return _key; }
|
||||||
inline void GCell::updateKey ( unsigned int depth ) { _key.update(depth); }
|
inline void GCell::updateKey ( unsigned int depth ) { _key.update(depth); }
|
||||||
|
@ -276,13 +276,13 @@ namespace Katabatic {
|
||||||
{ return (depth<_depth) ? _blockages[depth] : 0; }
|
{ return (depth<_depth) ? _blockages[depth] : 0; }
|
||||||
|
|
||||||
inline void GCell::addVSegment ( AutoSegment* segment )
|
inline void GCell::addVSegment ( AutoSegment* segment )
|
||||||
{ invalidate(); _vsegments.push_back(segment); }
|
{ invalidateCt(); _vsegments.push_back(segment); }
|
||||||
|
|
||||||
inline void GCell::addHSegment ( AutoSegment* segment )
|
inline void GCell::addHSegment ( AutoSegment* segment )
|
||||||
{ invalidate(); _hsegments.push_back(segment); }
|
{ invalidateCt(); _hsegments.push_back(segment); }
|
||||||
|
|
||||||
inline void GCell::addContact ( AutoContact* contact )
|
inline void GCell::addContact ( AutoContact* contact )
|
||||||
{ invalidate(); _contacts.push_back(contact); }
|
{ invalidateCt(); _contacts.push_back(contact); }
|
||||||
|
|
||||||
|
|
||||||
// GCell::CompareByIndex Inline Functions.
|
// GCell::CompareByIndex Inline Functions.
|
||||||
|
|
|
@ -417,7 +417,6 @@ namespace {
|
||||||
DbU::Unit _axis;
|
DbU::Unit _axis;
|
||||||
DbU::Unit _width;
|
DbU::Unit _width;
|
||||||
list<Interval> _chunks;
|
list<Interval> _chunks;
|
||||||
Net* _net;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
|
@ -40,8 +40,8 @@ namespace {
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
DbU::Unit getPositionByIterator ( const vector<TrackElement*>& v, size_t i )
|
// DbU::Unit getPositionByIterator ( const vector<TrackElement*>& v, size_t i )
|
||||||
{ return (*(v.begin()+i))->getSourceU(); }
|
// { return (*(v.begin()+i))->getSourceU(); }
|
||||||
|
|
||||||
|
|
||||||
} // Anonymous namespace.
|
} // Anonymous namespace.
|
||||||
|
|
|
@ -56,8 +56,8 @@ Edge::Edge ( Vertex* from, Vertex* to, unsigned capacity )
|
||||||
//cerr << " Edge::Edge() capacity:" << _capacity << endl;
|
//cerr << " Edge::Edge() capacity:" << _capacity << endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Edge::_postCreate ( bool capacity )
|
void Edge::_postCreate ()
|
||||||
// *************************************
|
// **********************
|
||||||
{
|
{
|
||||||
Inherit::_postCreate();
|
Inherit::_postCreate();
|
||||||
|
|
||||||
|
|
|
@ -858,7 +858,9 @@ void Graph::addToSTuplePQ ( STuple* stuple )
|
||||||
STuple::CostProperty* costProperty = stuple->getCostProperty();
|
STuple::CostProperty* costProperty = stuple->getCostProperty();
|
||||||
assert( costProperty );
|
assert( costProperty );
|
||||||
costProperty->setPQIter ( _stuplePriorityQueue.insert( stuple ) );
|
costProperty->setPQIter ( _stuplePriorityQueue.insert( stuple ) );
|
||||||
|
#ifndef NDEBUG
|
||||||
STuple::STuplePQIter pqit = costProperty->getPQIter();
|
STuple::STuplePQIter pqit = costProperty->getPQIter();
|
||||||
|
#endif
|
||||||
assert( (*pqit) == stuple );
|
assert( (*pqit) == stuple );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2068,7 +2070,7 @@ unsigned Graph::analyseRouting ( set<Segment*>& segmentsToUnroute )
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
STuple* topSTuple = getMaxFromSTuplePQ();
|
STuple* topSTuple = getMaxFromSTuplePQ();
|
||||||
float maxCost = topSTuple->getCost();
|
//float maxCost = topSTuple->getCost();
|
||||||
//cmess1 << " - Maximum segment cost : " << maxCost << endl;
|
//cmess1 << " - Maximum segment cost : " << maxCost << endl;
|
||||||
float minCost = 0.20;
|
float minCost = 0.20;
|
||||||
if (_stuplePriorityQueue.size() <= 100)
|
if (_stuplePriorityQueue.size() <= 100)
|
||||||
|
|
|
@ -36,7 +36,7 @@ HEdge* HEdge::create ( Vertex* from, Vertex* to )
|
||||||
|
|
||||||
HEdge* hEdge = new HEdge ( from, to );
|
HEdge* hEdge = new HEdge ( from, to );
|
||||||
|
|
||||||
hEdge->_postCreate(true);
|
hEdge->_postCreate();
|
||||||
|
|
||||||
return hEdge;
|
return hEdge;
|
||||||
}
|
}
|
||||||
|
@ -49,15 +49,15 @@ HEdge* HEdge::create ( Vertex* from, Vertex* to, unsigned capacity )
|
||||||
|
|
||||||
HEdge* hEdge = new HEdge ( from, to, capacity );
|
HEdge* hEdge = new HEdge ( from, to, capacity );
|
||||||
|
|
||||||
hEdge->_postCreate(false);
|
hEdge->_postCreate();
|
||||||
|
|
||||||
return hEdge;
|
return hEdge;
|
||||||
}
|
}
|
||||||
|
|
||||||
void HEdge::_postCreate ( bool fenceCapacity )
|
void HEdge::_postCreate ()
|
||||||
// *******************************************
|
// ***********************
|
||||||
{
|
{
|
||||||
Inherit::_postCreate ( fenceCapacity );
|
Inherit::_postCreate();
|
||||||
}
|
}
|
||||||
|
|
||||||
HEdge::~HEdge()
|
HEdge::~HEdge()
|
||||||
|
|
|
@ -308,7 +308,7 @@ unsigned int MatrixVertex::getLineIndex ( DbU::Unit y )
|
||||||
}
|
}
|
||||||
|
|
||||||
assert(is_sorted(_linesIndexes.begin(), _linesIndexes.end()));
|
assert(is_sorted(_linesIndexes.begin(), _linesIndexes.end()));
|
||||||
if ( _linesIndexes.empty() );
|
if ( _linesIndexes.empty() )
|
||||||
throw Error ( "MatrixVertex::getLineIndex(): Indexes map is empty." );
|
throw Error ( "MatrixVertex::getLineIndex(): Indexes map is empty." );
|
||||||
|
|
||||||
pair<pairIterator,pairIterator> result = equal_range (_linesIndexes.begin(), _linesIndexes.end()
|
pair<pairIterator,pairIterator> result = equal_range (_linesIndexes.begin(), _linesIndexes.end()
|
||||||
|
@ -346,7 +346,7 @@ unsigned int MatrixVertex::getColumnIndex ( DbU::Unit x )
|
||||||
}
|
}
|
||||||
|
|
||||||
assert(is_sorted(_columnsIndexes.begin(),_columnsIndexes.end()));
|
assert(is_sorted(_columnsIndexes.begin(),_columnsIndexes.end()));
|
||||||
if ( _columnsIndexes.empty() );
|
if ( _columnsIndexes.empty() )
|
||||||
throw Error ( "MatrixVertex::getColumnIndex(): Indexes map is empty." );
|
throw Error ( "MatrixVertex::getColumnIndex(): Indexes map is empty." );
|
||||||
|
|
||||||
pair<pairIterator,pairIterator> result = equal_range (_columnsIndexes.begin(), _columnsIndexes.end()
|
pair<pairIterator,pairIterator> result = equal_range (_columnsIndexes.begin(), _columnsIndexes.end()
|
||||||
|
|
|
@ -1,15 +1,9 @@
|
||||||
|
|
||||||
// -*- C++ -*-
|
// -*- C++ -*-
|
||||||
//
|
//
|
||||||
// This file is part of the Coriolis Software.
|
// This file is part of the Coriolis Software.
|
||||||
// Copyright (c) UPMC/LIP6 2008-2008, All Rights Reserved
|
// Copyright (c) UPMC 2008-2014, All Rights Reserved
|
||||||
//
|
//
|
||||||
// ===================================================================
|
// +-----------------------------------------------------------------+
|
||||||
//
|
|
||||||
// $Id$
|
|
||||||
//
|
|
||||||
// x-----------------------------------------------------------------x
|
|
||||||
// | |
|
|
||||||
// | C O R I O L I S |
|
// | C O R I O L I S |
|
||||||
// | K n i k - Global Router |
|
// | K n i k - Global Router |
|
||||||
// | |
|
// | |
|
||||||
|
@ -17,32 +11,27 @@
|
||||||
// | E-mail : Jean-Paul.Chaput@lip6.fr |
|
// | E-mail : Jean-Paul.Chaput@lip6.fr |
|
||||||
// | =============================================================== |
|
// | =============================================================== |
|
||||||
// | C++ Module : "./NetExtension.cpp" |
|
// | C++ Module : "./NetExtension.cpp" |
|
||||||
// | *************************************************************** |
|
// +-----------------------------------------------------------------+
|
||||||
// | U p d a t e s |
|
|
||||||
// | |
|
|
||||||
// x-----------------------------------------------------------------x
|
|
||||||
|
|
||||||
|
|
||||||
#include "hurricane/Error.h"
|
#include "hurricane/Error.h"
|
||||||
#include "hurricane/Net.h"
|
#include "hurricane/Net.h"
|
||||||
#include "hurricane/Cell.h"
|
#include "hurricane/Cell.h"
|
||||||
|
#include "knik/NetExtension.h"
|
||||||
|
|
||||||
#include "knik/NetExtension.h"
|
|
||||||
|
template<>
|
||||||
|
Hurricane::Name Hurricane::StandardPrivateProperty<Knik::NetExtensionDatas>::_name = "Knik::NetExtension";
|
||||||
|
|
||||||
|
|
||||||
namespace Knik {
|
namespace Knik {
|
||||||
|
|
||||||
|
|
||||||
using Hurricane::Error;
|
using Hurricane::Error;
|
||||||
using Hurricane::ForEachIterator;
|
using Hurricane::ForEachIterator;
|
||||||
|
|
||||||
|
|
||||||
const char* MissingNetExtension = "NetExtension::%s(): %s missing the Knik::Net extension.";
|
const char* MissingNetExtension = "NetExtension::%s(): %s missing the Knik::Net extension.";
|
||||||
|
|
||||||
|
|
||||||
template<>
|
|
||||||
Name StandardPrivateProperty<NetExtensionDatas>::_name = "Knik::NetExtension";
|
|
||||||
|
|
||||||
|
|
||||||
// -------------------------------------------------------------------
|
// -------------------------------------------------------------------
|
||||||
// Class : "Knik::NetExtensionDatas".
|
// Class : "Knik::NetExtensionDatas".
|
||||||
|
|
|
@ -36,7 +36,7 @@ VEdge* VEdge::create ( Vertex* from, Vertex* to )
|
||||||
|
|
||||||
VEdge* vEdge = new VEdge ( from, to );
|
VEdge* vEdge = new VEdge ( from, to );
|
||||||
|
|
||||||
vEdge->_postCreate(true);
|
vEdge->_postCreate();
|
||||||
|
|
||||||
return vEdge;
|
return vEdge;
|
||||||
}
|
}
|
||||||
|
@ -49,15 +49,15 @@ VEdge* VEdge::create ( Vertex* from, Vertex* to, unsigned capacity )
|
||||||
|
|
||||||
VEdge* vEdge = new VEdge ( from, to, capacity );
|
VEdge* vEdge = new VEdge ( from, to, capacity );
|
||||||
|
|
||||||
vEdge->_postCreate(false);
|
vEdge->_postCreate();
|
||||||
|
|
||||||
return vEdge;
|
return vEdge;
|
||||||
}
|
}
|
||||||
|
|
||||||
void VEdge::_postCreate( bool fenceCapacity )
|
void VEdge::_postCreate()
|
||||||
// ******************************************
|
// **********************
|
||||||
{
|
{
|
||||||
Inherit::_postCreate ( fenceCapacity );
|
Inherit::_postCreate ();
|
||||||
}
|
}
|
||||||
|
|
||||||
VEdge::~VEdge()
|
VEdge::~VEdge()
|
||||||
|
|
|
@ -55,7 +55,7 @@ namespace Knik {
|
||||||
public:
|
public:
|
||||||
//static Edge* create ( Fence* fence, Vertex* from, Vertex* to );
|
//static Edge* create ( Fence* fence, Vertex* from, Vertex* to );
|
||||||
void destroy();
|
void destroy();
|
||||||
void _postCreate ( bool capacity );
|
void _postCreate();
|
||||||
void _preDestroy();
|
void _preDestroy();
|
||||||
|
|
||||||
// Modifiers
|
// Modifiers
|
||||||
|
|
|
@ -23,7 +23,7 @@ namespace Knik {
|
||||||
static HEdge* create ( Vertex* from, Vertex* to );
|
static HEdge* create ( Vertex* from, Vertex* to );
|
||||||
static HEdge* create ( Vertex* from, Vertex* to, unsigned capacity );
|
static HEdge* create ( Vertex* from, Vertex* to, unsigned capacity );
|
||||||
//void destroy();
|
//void destroy();
|
||||||
void _postCreate ( bool fenceCapacity );
|
void _postCreate ();
|
||||||
//void _preDestroy();
|
//void _preDestroy();
|
||||||
|
|
||||||
// Others
|
// Others
|
||||||
|
|
|
@ -44,7 +44,7 @@ namespace Knik {
|
||||||
// Predicates
|
// Predicates
|
||||||
// **********
|
// **********
|
||||||
public:
|
public:
|
||||||
virtual bool isTerminal() { return false; };
|
virtual bool isTerminal() const { return false; };
|
||||||
|
|
||||||
virtual bool isVertical() const = 0;
|
virtual bool isVertical() const = 0;
|
||||||
virtual bool isHorizontal() const = 0;
|
virtual bool isHorizontal() const = 0;
|
||||||
|
|
|
@ -23,7 +23,7 @@ namespace Knik {
|
||||||
static VEdge* create ( Vertex* from, Vertex* to );
|
static VEdge* create ( Vertex* from, Vertex* to );
|
||||||
static VEdge* create ( Vertex* from, Vertex* to, unsigned capacity );
|
static VEdge* create ( Vertex* from, Vertex* to, unsigned capacity );
|
||||||
//void destroy();
|
//void destroy();
|
||||||
void _postCreate ( bool fenceCapacity );
|
void _postCreate ();
|
||||||
//void _preDestroy();
|
//void _preDestroy();
|
||||||
|
|
||||||
// Others
|
// Others
|
||||||
|
|
|
@ -94,13 +94,13 @@ MaukaEngine* MaukaEngine::create(Cell* cell, Box placementbox)
|
||||||
{
|
{
|
||||||
MaukaEngine* mauka = new MaukaEngine(cell);
|
MaukaEngine* mauka = new MaukaEngine(cell);
|
||||||
|
|
||||||
mauka->_postCreate(placementbox);
|
mauka->_maukaPostCreate(placementbox);
|
||||||
|
|
||||||
return mauka;
|
return mauka;
|
||||||
}
|
}
|
||||||
|
|
||||||
void MaukaEngine::_postCreate(Box& placementbox)
|
void MaukaEngine::_maukaPostCreate(Box& placementbox)
|
||||||
// *********************************************
|
// **************************************************
|
||||||
{
|
{
|
||||||
Inherit::_postCreate();
|
Inherit::_postCreate();
|
||||||
|
|
||||||
|
@ -109,17 +109,11 @@ void MaukaEngine::_postCreate(Box& placementbox)
|
||||||
addFeed ( AllianceFramework::get()->getCell("rowend_x0",Catalog::State::Views) );
|
addFeed ( AllianceFramework::get()->getCell("rowend_x0",Catalog::State::Views) );
|
||||||
|
|
||||||
Construct();
|
Construct();
|
||||||
|
|
||||||
//_simAnnealingPlacer = new SimAnnealingPlacer(this, 1, 0.0, 0.0);
|
//_simAnnealingPlacer = new SimAnnealingPlacer(this, 1, 0.0, 0.0);
|
||||||
_simAnnealingPlacer = new SimAnnealingPlacer(this);
|
_simAnnealingPlacer = new SimAnnealingPlacer(this);
|
||||||
|
|
||||||
//_displaySlot = DisplaySlot::create(getCell(),,139,0,139);
|
//_displaySlot = DisplaySlot::create(getCell(),,139,0,139);
|
||||||
|
|
||||||
_surface = Surface::create(this, placementbox);
|
_surface = Surface::create(this, placementbox);
|
||||||
|
|
||||||
|
|
||||||
_simAnnealingPlacer->init();
|
_simAnnealingPlacer->init();
|
||||||
|
|
||||||
//Plot();
|
//Plot();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -162,22 +156,22 @@ void MaukaEngine::Run()
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
void VerifyPathCellBox(const Occurrence& occurrence)
|
// void VerifyPathCellBox(const Occurrence& occurrence)
|
||||||
//On occurrence Path set all cells Abox to (0,0,0,0) if Box is empty
|
// //On occurrence Path set all cells Abox to (0,0,0,0) if Box is empty
|
||||||
//This avoids bad Transfos on Path
|
// //This avoids bad Transfos on Path
|
||||||
{
|
// {
|
||||||
Path path = occurrence.getPath();
|
// Path path = occurrence.getPath();
|
||||||
while (!path.isEmpty())
|
// while (!path.isEmpty())
|
||||||
{
|
// {
|
||||||
Instance* instance = path.getHeadInstance();
|
// Instance* instance = path.getHeadInstance();
|
||||||
Cell* model = instance->getMasterCell();
|
// Cell* model = instance->getMasterCell();
|
||||||
if (model->getAbutmentBox().isEmpty())
|
// if (model->getAbutmentBox().isEmpty())
|
||||||
{
|
// {
|
||||||
model->setAbutmentBox(Box(Point(0,0), Point(0,0)));
|
// model->setAbutmentBox(Box(Point(0,0), Point(0,0)));
|
||||||
}
|
// }
|
||||||
path = path.getTailPath();
|
// path = path.getTailPath();
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
}
|
}
|
||||||
|
|
||||||
void MaukaEngine::Construct()
|
void MaukaEngine::Construct()
|
||||||
|
|
|
@ -53,18 +53,18 @@ namespace {
|
||||||
|
|
||||||
using Hurricane::DbU;
|
using Hurricane::DbU;
|
||||||
|
|
||||||
DbU::Unit PositionRand(const DbU::Unit position, const double distance, const DbU::Unit min, const DbU::Unit max)
|
// DbU::Unit PositionRand(const DbU::Unit position, const double distance, const DbU::Unit min, const DbU::Unit max)
|
||||||
{
|
// {
|
||||||
DbU::Unit borneInf, borneSup;
|
// DbU::Unit borneInf, borneSup;
|
||||||
|
|
||||||
if ((borneSup = position + DbU::lambda((int)(distance * DbU::getLambda(max) + 0.5)) ) > max )
|
// if ((borneSup = position + DbU::lambda((int)(distance * DbU::getLambda(max) + 0.5)) ) > max )
|
||||||
borneSup = max;
|
// borneSup = max;
|
||||||
|
|
||||||
if ((borneInf = position - DbU::lambda((int)(distance * DbU::getLambda(max) + 0.5)) ) < min )
|
// if ((borneInf = position - DbU::lambda((int)(distance * DbU::getLambda(max) + 0.5)) ) < min )
|
||||||
borneInf = min;
|
// borneInf = min;
|
||||||
|
|
||||||
return borneInf + DbU::lambda((int)(DbU::getLambda(borneSup - borneInf) * rand() / (RAND_MAX+1.0)));
|
// return borneInf + DbU::lambda((int)(DbU::getLambda(borneSup - borneInf) * rand() / (RAND_MAX+1.0)));
|
||||||
}
|
// }
|
||||||
|
|
||||||
} // End of anonymous namespace.
|
} // End of anonymous namespace.
|
||||||
|
|
||||||
|
|
|
@ -56,11 +56,11 @@ SubRow::SubRow(Cell* cell, Surface* surface, const Box& box)
|
||||||
SubRow* SubRow::create(Cell* cell, Surface* surface, const Box& box, bool orientation)
|
SubRow* SubRow::create(Cell* cell, Surface* surface, const Box& box, bool orientation)
|
||||||
{
|
{
|
||||||
SubRow* subRow = new SubRow(cell, surface, box);
|
SubRow* subRow = new SubRow(cell, surface, box);
|
||||||
subRow->_postCreate(orientation);
|
subRow->_subRowPostCreate(orientation);
|
||||||
return subRow;
|
return subRow;
|
||||||
}
|
}
|
||||||
|
|
||||||
void SubRow::_postCreate(bool orientation)
|
void SubRow::_subRowPostCreate(bool orientation)
|
||||||
{
|
{
|
||||||
_row = _surface->InsertSubRowInRow(this, orientation);
|
_row = _surface->InsertSubRowInRow(this, orientation);
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
// -*- C++ -*-
|
// -*- C++ -*-
|
||||||
//
|
//
|
||||||
// This file is part of the Coriolis Software.
|
// This file is part of the Coriolis Software.
|
||||||
// Copyright (c) UPMC/LIP6 2006-2014, All Rights Reserved
|
// Copyright (c) UPMC 2006-2014, All Rights Reserved
|
||||||
//
|
//
|
||||||
// +-----------------------------------------------------------------+
|
// +-----------------------------------------------------------------+
|
||||||
// | C O R I O L I S |
|
// | C O R I O L I S |
|
||||||
|
@ -134,7 +134,7 @@ namespace Mauka {
|
||||||
private:
|
private:
|
||||||
// Internals.
|
// Internals.
|
||||||
MaukaEngine ( Cell* );
|
MaukaEngine ( Cell* );
|
||||||
void _postCreate ( Box& placementbox );
|
void _maukaPostCreate ( Box& placementbox );
|
||||||
void _preDestroy ();
|
void _preDestroy ();
|
||||||
inline Surface* _getSurface () const { return _surface; }
|
inline Surface* _getSurface () const { return _surface; }
|
||||||
Box PlotFixedPointsLabels ( std::ofstream& ) const;
|
Box PlotFixedPointsLabels ( std::ofstream& ) const;
|
||||||
|
|
|
@ -100,7 +100,7 @@ class SubRow : public Container {
|
||||||
private: void _computeCapacity(double margin);
|
private: void _computeCapacity(double margin);
|
||||||
private: bool _MergeBins();
|
private: bool _MergeBins();
|
||||||
public: void DisplayBinHits() const;
|
public: void DisplayBinHits() const;
|
||||||
protected: virtual void _postCreate(bool orientation);
|
protected: virtual void _subRowPostCreate(bool orientation);
|
||||||
protected: virtual void _preDestroy();
|
protected: virtual void _preDestroy();
|
||||||
public: double getBinCost() const;
|
public: double getBinCost() const;
|
||||||
public: DbU::Unit getBinsSize() const;
|
public: DbU::Unit getBinsSize() const;
|
||||||
|
|
|
@ -64,8 +64,10 @@ namespace Metis {
|
||||||
: Inherit (cell)
|
: Inherit (cell)
|
||||||
, _configuration(new Configuration())
|
, _configuration(new Configuration())
|
||||||
, _step (0)
|
, _step (0)
|
||||||
|
#ifdef HAVE_HMETIS_LIB
|
||||||
, _actualGraphs ()
|
, _actualGraphs ()
|
||||||
, _newGraphs ()
|
, _newGraphs ()
|
||||||
|
#endif
|
||||||
, _globalEdgeCut(0)
|
, _globalEdgeCut(0)
|
||||||
{
|
{
|
||||||
#ifdef HAVE_HMETIS_LIB
|
#ifdef HAVE_HMETIS_LIB
|
||||||
|
|
|
@ -89,8 +89,10 @@ namespace Metis {
|
||||||
static const Name _toolName;
|
static const Name _toolName;
|
||||||
Configuration* _configuration;
|
Configuration* _configuration;
|
||||||
unsigned _step;
|
unsigned _step;
|
||||||
|
#ifdef HAVE_HMETIS_LIB
|
||||||
MetisGraphs* _actualGraphs;
|
MetisGraphs* _actualGraphs;
|
||||||
MetisGraphs* _newGraphs;
|
MetisGraphs* _newGraphs;
|
||||||
|
#endif
|
||||||
int _globalEdgeCut;
|
int _globalEdgeCut;
|
||||||
private:
|
private:
|
||||||
// Internals.
|
// Internals.
|
||||||
|
|
|
@ -12,10 +12,10 @@
|
||||||
#include "nimbus/FenceProperty.h"
|
#include "nimbus/FenceProperty.h"
|
||||||
#include "nimbus/Fence.h"
|
#include "nimbus/Fence.h"
|
||||||
|
|
||||||
namespace Nimbus {
|
template<>
|
||||||
|
Hurricane::Name Hurricane::StandardPrivateProperty<Nimbus::Fence*>::_name = "ComponentFencePropName";
|
||||||
|
|
||||||
template<>
|
namespace Nimbus {
|
||||||
Name StandardPrivateProperty<Fence*>::_name = "ComponentFencePropName";
|
|
||||||
|
|
||||||
|
|
||||||
Fence* getFence ( const Component& component )
|
Fence* getFence ( const Component& component )
|
||||||
|
|
|
@ -768,7 +768,9 @@ GCell* GCell::getSubUpperLeft () const
|
||||||
assert (col != _pavement.end());
|
assert (col != _pavement.end());
|
||||||
|
|
||||||
RBMap::const_reverse_iterator rbit = ((*col).second)->rbegin();
|
RBMap::const_reverse_iterator rbit = ((*col).second)->rbegin();
|
||||||
|
#ifndef NDEBUG
|
||||||
RBMap::const_reverse_iterator rbend = ((*col).second)->rend();
|
RBMap::const_reverse_iterator rbend = ((*col).second)->rend();
|
||||||
|
#endif
|
||||||
assert (rbit != rbend);
|
assert (rbit != rbend);
|
||||||
|
|
||||||
return (*rbit).second;
|
return (*rbit).second;
|
||||||
|
@ -783,7 +785,9 @@ GCell* GCell::getSubUpperRight () const
|
||||||
assert (col != _pavement.rend());
|
assert (col != _pavement.rend());
|
||||||
|
|
||||||
RBMap::const_reverse_iterator rbit = ((*col).second)->rbegin();
|
RBMap::const_reverse_iterator rbit = ((*col).second)->rbegin();
|
||||||
|
#ifndef NDEBUG
|
||||||
RBMap::const_reverse_iterator rbend = ((*col).second)->rend();
|
RBMap::const_reverse_iterator rbend = ((*col).second)->rend();
|
||||||
|
#endif
|
||||||
assert (rbit != rbend);
|
assert (rbit != rbend);
|
||||||
|
|
||||||
return (*rbit).second;
|
return (*rbit).second;
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
|
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
|
|
||||||
|
#include "hurricane/Box.h"
|
||||||
#include "hurricane/DataBase.h"
|
#include "hurricane/DataBase.h"
|
||||||
#include "hurricane/Technology.h"
|
#include "hurricane/Technology.h"
|
||||||
#include "hurricane/UpdateSession.h"
|
#include "hurricane/UpdateSession.h"
|
||||||
|
|
|
@ -46,9 +46,13 @@ namespace Nimbus {
|
||||||
|
|
||||||
typedef StandardPrivateProperty<unsigned> InstanceProperty;
|
typedef StandardPrivateProperty<unsigned> InstanceProperty;
|
||||||
|
|
||||||
template<>
|
}
|
||||||
Name InstanceProperty::_name = "Nimbus::InstanceProperty";
|
|
||||||
|
|
||||||
|
template<>
|
||||||
|
Hurricane::Name Nimbus::InstanceProperty::_name = "Nimbus::InstanceProperty";
|
||||||
|
|
||||||
|
|
||||||
|
namespace Nimbus {
|
||||||
|
|
||||||
unsigned getStep(const Instance& instance)
|
unsigned getStep(const Instance& instance)
|
||||||
{
|
{
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
#include "hurricane/viewer/Script.h"
|
#include "hurricane/viewer/Script.h"
|
||||||
#include "hurricane/viewer/CellViewer.h"
|
#include "hurricane/viewer/CellViewer.h"
|
||||||
#include "hurricane/viewer/PyCellViewer.h"
|
#include "hurricane/viewer/PyCellViewer.h"
|
||||||
|
#include "crlcore/Utilities.h"
|
||||||
#include "crlcore/Catalog.h"
|
#include "crlcore/Catalog.h"
|
||||||
#include "crlcore/AllianceFramework.h"
|
#include "crlcore/AllianceFramework.h"
|
||||||
#include "crlcore/GraphicToolEngine.h"
|
#include "crlcore/GraphicToolEngine.h"
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
// -*- C++ -*-
|
// -*- C++ -*-
|
||||||
//
|
//
|
||||||
// This file is part of the Coriolis Software.
|
// This file is part of the Coriolis Software.
|
||||||
// Copyright (c) UPMC/LIP6 2008-2014, All Rights Reserved
|
// Copyright (c) UPMC 2008-2014, All Rights Reserved
|
||||||
//
|
//
|
||||||
// +-----------------------------------------------------------------+
|
// +-----------------------------------------------------------------+
|
||||||
// | C O R I O L I S |
|
// | C O R I O L I S |
|
||||||
|
@ -24,7 +24,6 @@
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
#include "hurricane/viewer/CellViewer.h"
|
#include "hurricane/viewer/CellViewer.h"
|
||||||
|
|
||||||
#include "crlcore/Banner.h"
|
#include "crlcore/Banner.h"
|
||||||
namespace CRL {
|
namespace CRL {
|
||||||
class GraphicTool;
|
class GraphicTool;
|
||||||
|
|
|
@ -29,7 +29,7 @@ bool Library::writeToFile(string filename) {
|
||||||
tm now = *localtime(&curtime);
|
tm now = *localtime(&curtime);
|
||||||
char date[BUFSIZ]={0};
|
char date[BUFSIZ]={0};
|
||||||
const char format[]="%y-%m-%d %H:%M:%S";
|
const char format[]="%y-%m-%d %H:%M:%S";
|
||||||
if (!strftime(date, sizeof(date)-1, format, &now)>0)
|
if (strftime(date, sizeof(date)-1, format, &now) == 0)
|
||||||
cerr << "[GDS DRIVE ERROR]: cannot build current date." << endl;
|
cerr << "[GDS DRIVE ERROR]: cannot build current date." << endl;
|
||||||
|
|
||||||
ofstream file;
|
ofstream file;
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
#include <boost/python.hpp>
|
#include <boost/python.hpp>
|
||||||
using namespace boost::python;
|
using namespace boost::python;
|
||||||
|
@ -7,6 +6,7 @@ using namespace boost::python;
|
||||||
#include "vlsisapd/agds/Structure.h"
|
#include "vlsisapd/agds/Structure.h"
|
||||||
#include "vlsisapd/agds/Element.h"
|
#include "vlsisapd/agds/Element.h"
|
||||||
#include "vlsisapd/agds/Rectangle.h"
|
#include "vlsisapd/agds/Rectangle.h"
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
namespace AGDS {
|
namespace AGDS {
|
||||||
BOOST_PYTHON_MODULE(AGDS) {
|
BOOST_PYTHON_MODULE(AGDS) {
|
||||||
|
|
|
@ -25,7 +25,7 @@ bool Structure::write(ofstream &file) {
|
||||||
tm now = *localtime(&curtime);
|
tm now = *localtime(&curtime);
|
||||||
char date[BUFSIZ]={0};
|
char date[BUFSIZ]={0};
|
||||||
const char format[]="%y-%m-%d %H:%M:%S";
|
const char format[]="%y-%m-%d %H:%M:%S";
|
||||||
if (!strftime(date, sizeof(date)-1, format, &now)>0)
|
if (strftime(date, sizeof(date)-1, format, &now) == 0)
|
||||||
cerr << "[GDS DRIVE ERROR]: cannot build current date." << endl;
|
cerr << "[GDS DRIVE ERROR]: cannot build current date." << endl;
|
||||||
|
|
||||||
// Header
|
// Header
|
||||||
|
|
|
@ -57,7 +57,7 @@ void doFindMegaCells ( Circuit* circuit )
|
||||||
Node* node = (*inode).second;
|
Node* node = (*inode).second;
|
||||||
|
|
||||||
map<size_t,Pin*>& pins = node->getPins();
|
map<size_t,Pin*>& pins = node->getPins();
|
||||||
map<size_t,Pin*>::iterator ipin = pins.begin();
|
//map<size_t,Pin*>::iterator ipin = pins.begin();
|
||||||
if ( (double)pins.size() > node->getWidth() ) {
|
if ( (double)pins.size() > node->getWidth() ) {
|
||||||
cout << setw(4) << right << megacellsNb
|
cout << setw(4) << right << megacellsNb
|
||||||
<< ":megacell:" << node->getName()
|
<< ":megacell:" << node->getName()
|
||||||
|
|
|
@ -25,7 +25,7 @@ bool Circuit::writeToFile(string filename) {
|
||||||
tm now = *localtime(&curtime);
|
tm now = *localtime(&curtime);
|
||||||
char date[BUFSIZ]={0};
|
char date[BUFSIZ]={0};
|
||||||
const char format[]="%d-%b-%Y %H:%M:%S";
|
const char format[]="%d-%b-%Y %H:%M:%S";
|
||||||
if (!strftime(date, sizeof(date)-1, format, &now)>0)
|
if (strftime(date, sizeof(date)-1, format, &now) == 0)
|
||||||
cerr << "[CIF DRIVE ERROR]: cannot build current date." << endl;
|
cerr << "[CIF DRIVE ERROR]: cannot build current date." << endl;
|
||||||
|
|
||||||
ofstream file;
|
ofstream file;
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
#include <boost/python.hpp>
|
#include <boost/python.hpp>
|
||||||
using namespace boost::python;
|
using namespace boost::python;
|
||||||
|
|
||||||
#include "vlsisapd/cif/Polygon.h"
|
#include "vlsisapd/cif/Polygon.h"
|
||||||
#include "vlsisapd/cif/Circuit.h"
|
#include "vlsisapd/cif/Circuit.h"
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
namespace CIF {
|
namespace CIF {
|
||||||
BOOST_PYTHON_MODULE(CIF) {
|
BOOST_PYTHON_MODULE(CIF) {
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
#define __CIF_CIRCUIT_H
|
#define __CIF_CIRCUIT_H
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
namespace CIF {
|
namespace CIF {
|
||||||
class Polygon;
|
class Polygon;
|
||||||
|
@ -13,8 +14,8 @@ class Circuit {
|
||||||
bool writeToFile ( std::string );
|
bool writeToFile ( std::string );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
string _name;
|
std::string _name;
|
||||||
string _unit;
|
std::string _unit;
|
||||||
double _scale;
|
double _scale;
|
||||||
|
|
||||||
std::vector<Polygon*> _polygons;
|
std::vector<Polygon*> _polygons;
|
||||||
|
|
|
@ -10,7 +10,7 @@ class Polygon {
|
||||||
Polygon(long);
|
Polygon(long);
|
||||||
|
|
||||||
void addPoint (long, long);
|
void addPoint (long, long);
|
||||||
void write ( ofstream& );
|
void write ( std::ofstream& );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
long _layer;
|
long _layer;
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
#include <boost/python.hpp>
|
#include <boost/python.hpp>
|
||||||
using namespace boost::python;
|
using namespace boost::python;
|
||||||
|
@ -7,6 +6,7 @@ using namespace boost::python;
|
||||||
#include "vlsisapd/dtr/Techno.h"
|
#include "vlsisapd/dtr/Techno.h"
|
||||||
#include "vlsisapd/dtr/Rules.h"
|
#include "vlsisapd/dtr/Rules.h"
|
||||||
#include "vlsisapd/dtr/DTRException.h"
|
#include "vlsisapd/dtr/DTRException.h"
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
|
|
||||||
namespace DTR {
|
namespace DTR {
|
||||||
|
|
|
@ -244,7 +244,7 @@ bool Library::writeToFile(string filename) {
|
||||||
tm now = *localtime(&curtime);
|
tm now = *localtime(&curtime);
|
||||||
char date[BUFSIZ]={0};
|
char date[BUFSIZ]={0};
|
||||||
const char format[]="%y-%m-%d %H:%M:%S";
|
const char format[]="%y-%m-%d %H:%M:%S";
|
||||||
if (!strftime(date, sizeof(date)-1, format, &now)>0)
|
if (strftime(date, sizeof(date)-1, format, &now) == 0)
|
||||||
cerr << "[Liberty DRIVE ERROR]: cannot build current date." << endl;
|
cerr << "[Liberty DRIVE ERROR]: cannot build current date." << endl;
|
||||||
|
|
||||||
ofstream file;
|
ofstream file;
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
#include "vlsisapd/liberty/Name.h"
|
#include "vlsisapd/liberty/Name.h"
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
namespace LIB {
|
namespace LIB {
|
||||||
unsigned long Name::_globalId = 0;
|
unsigned long Name::_globalId = 0;
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
#include <boost/python.hpp>
|
#include <boost/python.hpp>
|
||||||
#include <boost/python/suite/indexing/vector_indexing_suite.hpp>
|
#include <boost/python/suite/indexing/vector_indexing_suite.hpp>
|
||||||
|
@ -14,8 +13,8 @@ using namespace boost::python;
|
||||||
#include "vlsisapd/liberty/Timing.h"
|
#include "vlsisapd/liberty/Timing.h"
|
||||||
#include "vlsisapd/liberty/FlipFlop.h"
|
#include "vlsisapd/liberty/FlipFlop.h"
|
||||||
#include "vlsisapd/liberty/Library.h"
|
#include "vlsisapd/liberty/Library.h"
|
||||||
|
|
||||||
#include "vlsisapd/liberty/PySTLMapWrapper.h"
|
#include "vlsisapd/liberty/PySTLMapWrapper.h"
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
namespace LIB {
|
namespace LIB {
|
||||||
//void translator(LibertyException const& e) {
|
//void translator(LibertyException const& e) {
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
#include <boost/python.hpp>
|
#include <boost/python.hpp>
|
||||||
#include <boost/python/suite/indexing/vector_indexing_suite.hpp>
|
#include <boost/python/suite/indexing/vector_indexing_suite.hpp>
|
||||||
|
@ -20,8 +19,8 @@ using namespace boost::python;
|
||||||
#include "vlsisapd/openChams/Port.h"
|
#include "vlsisapd/openChams/Port.h"
|
||||||
#include "vlsisapd/openChams/Wire.h"
|
#include "vlsisapd/openChams/Wire.h"
|
||||||
#include "vlsisapd/openChams/OpenChamsException.h"
|
#include "vlsisapd/openChams/OpenChamsException.h"
|
||||||
|
|
||||||
#include "vlsisapd/openChams/PySTLMapWrapper.h"
|
#include "vlsisapd/openChams/PySTLMapWrapper.h"
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
namespace OpenChams {
|
namespace OpenChams {
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
// -*- C++ -*-
|
// -*- C++ -*-
|
||||||
//
|
//
|
||||||
// This file is part of the VLSI SAPD Software.
|
// This file is part of the VLSI SAPD Software.
|
||||||
// Copyright (c) UPMC/LIP6 2010-2012, All Rights Reserved
|
// Copyright (c) UPMC 2010-2014, All Rights Reserved
|
||||||
//
|
//
|
||||||
// +-----------------------------------------------------------------+
|
// +-----------------------------------------------------------------+
|
||||||
// | V L S I S A P D |
|
// | V L S I S A P D |
|
||||||
|
|
|
@ -7,7 +7,6 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
#include "vlsisapd/openChams/SimulModel.h"
|
#include "vlsisapd/openChams/SimulModel.h"
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
// -*- C++ -*-
|
// -*- C++ -*-
|
||||||
//
|
//
|
||||||
// This file is part of the VLSI SAPD Software.
|
// This file is part of the VLSI SAPD Software.
|
||||||
// Copyright (c) UPMC/LIP6 2010-2012, All Rights Reserved
|
// Copyright (c) UPMC 2010-2014, All Rights Reserved
|
||||||
//
|
//
|
||||||
// +-----------------------------------------------------------------+
|
// +-----------------------------------------------------------------+
|
||||||
// | V L S I S A P D |
|
// | V L S I S A P D |
|
||||||
|
@ -15,8 +15,8 @@
|
||||||
// +-----------------------------------------------------------------+
|
// +-----------------------------------------------------------------+
|
||||||
|
|
||||||
|
|
||||||
#ifndef __OPENCHAMS_SCHEMATIC_H__
|
#ifndef VLSISAPD_OPENCHAMS_SCHEMATIC_H
|
||||||
#define __OPENCHAMS_SCHEMATIC_H__
|
#define VLSISAPD_OPENCHAMS_SCHEMATIC_H
|
||||||
|
|
||||||
#include <map>
|
#include <map>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
#include <boost/python.hpp>
|
#include <boost/python.hpp>
|
||||||
#include <boost/python/suite/indexing/vector_indexing_suite.hpp>
|
#include <boost/python/suite/indexing/vector_indexing_suite.hpp>
|
||||||
|
@ -9,8 +8,8 @@ using namespace boost::python;
|
||||||
#include "vlsisapd/spice/Subckt.h"
|
#include "vlsisapd/spice/Subckt.h"
|
||||||
#include "vlsisapd/spice/Circuit.h"
|
#include "vlsisapd/spice/Circuit.h"
|
||||||
#include "vlsisapd/spice/SpiceException.h"
|
#include "vlsisapd/spice/SpiceException.h"
|
||||||
|
|
||||||
#include "vlsisapd/spice/PySTLMapWrapper.h"
|
#include "vlsisapd/spice/PySTLMapWrapper.h"
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
namespace SPICE {
|
namespace SPICE {
|
||||||
void translator(SpiceException const& e) {
|
void translator(SpiceException const& e) {
|
||||||
|
|
|
@ -43,7 +43,6 @@ class Circuit {
|
||||||
typedef std::vector<std::string> string_vector;
|
typedef std::vector<std::string> string_vector;
|
||||||
typedef std::map<std::string, std::string> strings_map;
|
typedef std::map<std::string, std::string> strings_map;
|
||||||
private:
|
private:
|
||||||
unsigned _line;
|
|
||||||
std::string _title;
|
std::string _title;
|
||||||
string_vector _includes;
|
string_vector _includes;
|
||||||
strpair_vector _libraries;
|
strpair_vector _libraries;
|
||||||
|
@ -54,7 +53,7 @@ class Circuit {
|
||||||
std::vector<Source*> _sources;
|
std::vector<Source*> _sources;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Circuit(): _line(0), _title(""), _includes(), _libraries(), _options(), _parameters(), _subckts(), _instances() {};
|
Circuit(): _title(""), _includes(), _libraries(), _options(), _parameters(), _subckts(), _instances() {};
|
||||||
~Circuit() {};
|
~Circuit() {};
|
||||||
|
|
||||||
inline std::string getTitle();
|
inline std::string getTitle();
|
||||||
|
|
|
@ -243,7 +243,7 @@ namespace Utilities {
|
||||||
|
|
||||||
Path& Path::operator= ( const Path& other )
|
Path& Path::operator= ( const Path& other )
|
||||||
{
|
{
|
||||||
_elements.swap( vector<std::string>() );
|
vector<std::string>().swap( _elements );
|
||||||
_elements = other._elements;
|
_elements = other._elements;
|
||||||
_flags = other._flags;
|
_flags = other._flags;
|
||||||
_pathcache = other._pathcache;
|
_pathcache = other._pathcache;
|
||||||
|
|
Loading…
Reference in New Issue