From 7296dcd6fb4f618573ae90159dfe407ca0a9e392 Mon Sep 17 00:00:00 2001
From: Jean-Paul Chaput
q)0%8e7cl-G@y+3^r{{A)g|lMm+^D7Ja*g>&mKK*>pW!%A&|dMnLi2 zBef{8Kk3^JnagecwsV$z8&I^?dxR^sk8aMS0tP16!5FI{Ue?LTkq4_xlqtu~=#U;gW_ctJX}q zpG00<9si+EfuM4`$J~DCc;)N4wqa(Ox10iTX;I@>!Ld=pvJ<^_5x-s4h_scuF0sM) z>V$?z_0*!G+!CYfwx@IJalOKYaUNSWc2@R$q@W~M9BPQx&Kw=>(s*~}`I#yKJx$aj z8)6$D7hWDOsd@cE(IKCp4X=ZITA!KiHvug|z{c=($sz%5BP{2b51RStb^LL?lOpoT z!iNpY7r?Bl2#ojnHPSJI6Q7@o*4C1mjbod}&fGlmX|+aEQdkl>Fl3CPrWE~BPkPH1 z=7NK{r_bObu@zwCk|hs@`d#-MF2|JRC#NdEXnl6fBnCr1ENQ=W?V9?H#OeW?i>KRy z6)+wfq!zx^qM%*g#pqCcTNGUnrynFH`46)q@vm4ik|XQFTaLiYcesQ)Y}$oi(xhXY zUT{F!@b+5IO@0#U^BLX2x9QmPo3 6?o?S?^h2UBaQ9++ &*N%%Ui8pv3px4 }DU+QCKYU$78yIQ7CjJ2w(~UZ>BGc zW2ik;QKb#A7>3%eI0}-&Gh_O(ti$ K=;3 ;RS!KqE*96dZ-o1AO?<^(%zS4**aIyf(y=&+yTAf|@|z8A3BdZ9k!qrw@W5At8tm z41&w|1yLjt2}GhnG#U TDbP*YC(In`rIFD{6c&!e!_g#X6jmRF)<>b%BhmUuqyhLROvvRBsTuUX3wr &@NLZhpV9I!I+#KKp(Zbg&z?>Q2Gj^(GsPMS zARnV3JsEU;A1*(T28A$Aj7rG$CYT5Q;@@vH`RxWC__!@^reHu!Y|TY?e5E^w~6y zuc3A*oWb;=1+j(NWHT ZG0kkCW-PmHGt#f*Qj` T_VGPf9dn@G5VtzLtRBf?GSOP{Y!uGr=IR?>CpMR%ApH2iNrRBd@IgJ9dmtg zG9&S55(*1-3B`G=jYMigXi&cY4-98 _ycfeVFV%?>g)dsLn9%oKfzE$EY!{X z6%UCNH*tT3p@`_e;Gt2tzrrwRsCo7)EgEWC{{@D}LM_N&@i0itUtnl7=5P4n{{}|- zD-4hPi+&i4_?^SAa`6}>)ODSO3HdarDaeQZ#Q^}RtZ?Xs3K0OExLoK>2h?tL0zey% z4;Pqu?P6mNxEqj6NJx^2nF$GFVPS5HAz?9Sb2O5OB$=a3&}cI(`F~@0ieI7#gfzZz S+Tlbb9{P_9O$!H0*#7}sE<-s0 literal 0 HcmV?d00001 diff --git a/documentation/UsersGuide/images/Coriolis-Soft-Schema.png b/documentation/UsersGuide/images/Coriolis-Soft-Schema.png new file mode 100644 index 0000000000000000000000000000000000000000..dd128ec61f20ff17eb90eccec9f784f421897c9a GIT binary patch literal 11847 zcmeHtXH-+&)@~31rHEJnk*25^L2BsDhCrx-fYgZeUP2M6uS!wrQX~*TN{|wY7$9^( zKq*05K&q4^K K^^*`f+GI;3l81`XgT>PY2%s z8y|a+hJlWthLb1U7jEn0?By#cFD579EB`151QG;k-MjtpY3A~Tq|dBk L zGMH*N$1`qy>^%KCy7uCa%X*X6%^5{{OwnyuYj|~s^6X@NjHiD2&7IAR5&u2r^zO1f z^q7{xUTBePBnq666d(GWcKnO+0E8KokTjKSm=7kYvSynSim>c9vRE98MK^}h{|@Vq zPA 3Co#8aQaY=V@l1`mF@0{8KgO`g$M^$aNAkfBd8BV~ z{uG<2W=LD*pm>|i4#M`kZ {_XN1>$S)A4Wtj?rkMwIMW>pj(;9 zj1j+E9ZD7;tP+i}F7CsPkNGAEU0k22{trf4xW3xQf4bne%o%u<@a9bz_J-;9gb^Ck zkZE<@?NWS_fRey =??51l*L*v9wJ!hz-^cP789 z`csCxGU_obW(m>G>T9E=LqUj`4Y#yHe@xf})F?8`{ccqnmk~c9tX?mv&%&19v^Z>^ z7UayT9v|4}%6}!en1ZBiVo#T{YJ~ho6&YiuzFC;ol2y~EA0>_sWu4-?UAk%5wls|! zg3;FZA0k%Iu5S5NQ^%HX_9=_!C?N2$S@~IHR}N~P@Jd*6bG|i4#36CIY5rRm)w!kf zZXN^d;<|`{Y5a}f7YT|}2=o@FRV{O=ZFR!)0^aZxmvwyxHL8W?J^IG$7K!hHXJhDr zPte850>4Qm7nnj$py-ynFfsRshP88N{dYK$9auAWlMOM&aHRI?SlL!kVvLE&ce5xj z0_x{=s)LcJL=0%jtNEl>Tf!e*tJmC@3g`@fJ#mhFQ^#Z zvaK|)GqC(9b^g#LD$Hs3xAIMEi};iXJZYWQA ynS_vC-?dpJC7>c}HKkZ8Euuk<(fR4Lh{;F} z{P9MpK`QE@33^#Ecs)c29cxkGLa4yvHi^TUP&2T_9<(|vdoY*E(^Ov3|0dOSVz=WX z@~!Xtjr#c_X9V7WP7v%#8rLJJF$nSD@`w%JK0+MY`#WrhC6a2)(?;gZO;zqP!qEi^ zSDNZXmStvn+z_!_Zx+&X^l9sh9m?r%E|q=8$G8gS;=kE%6(WNy(R -XiEwIf zV;1jX+)Hi`=BZ18pM~*j-KKBGh{Qg?6V3HabZO@R-}GEiraaicbDJKN40Xeu27EW! z&}9I^#K^*l_dwjQN`GwP3fv4`=inuJ+MoqY(_9<)o3?I4=$kVvT?M|7vjdh)J0}=# zklGu$kKEgX8o_emj@*}9iuavB&Elakm0Q_VhoMInN{jCTftDs;&LXt)Wp$;86AgZV z!sqI@5mA=CdwUy2$$LK3t1~MdPL%^I1Y@wD94+qj#8eaQz_U6mgL<9#WvT4!7(|zx zv#dilTX{^);0dma#fyG^5Yy)%Yzxg#wqG# ZjWAFq5tv6 z*s6BBRX$R+ IfIV(>R8<=`(rP1u*NKL zhCKYh5Yc;51P2h(j+0nElj&^rNa@ShU8<_U@VJ?aJp9TAx4ZwMC`_XELbGc6VrAJ2 z fAL#p^ILgFK Xi^-9A z} zq6tJ=W4V8-)#2v!ZSeVk)s8BKCx9!QIoRFU81Bv5tkMFmn9AxVmfU@KPJ==Vk*+tp z`>z3x*0fI^tH!s8x}WI*t#xIIi=!jVMz0{~esRIh#Xa&?{h)i~9G_jjJm~Bxz#KJ` zar6 #AIvN+w%t0f5q6UUYVFVGO^{dAcVgPp-jP7Cl+vTilvr zQHk9975-8^vxZ5??AGnvw{t!uw}XhA%-gOi2lm 1_Y(;sd;CX_3hg>gVsC{ky@5iX1-5{S-=XK9IRM>bO$-lS6e0MQfNO&fs)@ z)0IB~_6F&kB=WsF5VcDlKhoVX4_vO49}axibtdqWw+kVzT*?|@7`M}`LNOmJrYKVJ zZrVmGP0%wlw=|`mxpvRGY{yT9iN}7Jmn b*8vM@1Gfo>b5uEa1n*ZLt+3K7G9FjYFAFij;< G!LYqGi}$ek8f@70B>_j-=M~1q#;&@Kw_n6<#-y75 z01}Axyh-ii0*nymSjrC9eha5zRH7qK+-mAQkC1*%T$O6+4(#&bc>a}TSX7?N3ilYW zLM_P{Oa^K<>u|rIJoOG-k@KhP4yh)2>*@rUv~H+G9WI2}7e_y+QydN~-82vIJ=8Y3 zQS5^hQToWj>z@-cKRbignx4B^HY~cI=9@o=cZ*5`2lI-5{xq$GqcYe}*EP3ltMtEG zQFe@eb5E?mv#_s36}6e5lbFalEiVl_TT`x?BqQXqlBHYQt%3+zD zHw}foW;2EUiX`>ypPx*^SyZM-J80z_KDBxFl&+R5E@5oSnn7Pf%!bm`<9p3)se=P5 zpv-G_LXe@D7}8REDUw~v;;Yx^#LtYHF_(UJ-H*GGC+J;q4G6=+pRwWA(#jXgFWC}_ zs+=Gp^SKkT#aHPi2A}lW9OI65vVI34bAx7bvg!Wobn~yFLdg1~%3RXSM3)}eFCd7^ zyQwbCG=FenISs#8KoVf5$Z-S=l8EG f_t3 zt!gQT`aw)<6Uku`u&d!$-vvI)O-oD5s#q F>b#K@BI$3UXE%)b3)AUpuqhePI|@V0bm1kBpnoJDeUzY+riy^(f=Q18IM zzOEF97 bi3J4w4DdV(_Y?Q2; IQXhA?RXqAjDglx`EK;>r8s|dd?+IV!8@m zU56%zD#5c~-2HiPkvb(GmLeXDJ9qk7kJwH5zQavhTIalC`60A}DBHPdjxLo$&{fP^ zPU=tVkYBx-JqH2B GJxOTP&a8Zyi-m7#I(L8Na|BYUXz_?R zlCxsamXCB1nEi#dbolQp-}c&%nc{TArV?6PHd8}hKv2p-_aXGr;sh6;f);Z>uZQ0W zF~EE?fJ=HZ$9M+PTh8jUL64wChup}55k7i%)vLM3XDZ>3J+Z-3WQNoy0BqLz_&;!j z?B5^XP1+N)pMwa7+rQ0D#-ZY|mgJ=a*!YBd>;q^BwyqA_q*i%wPfSwyXkz?5s1;rh z6igN5CJFuk0+Kz1zdZBNF~#}4XPg5j^G$VD*ChVkNwLV4n1xI1TgDsZjiOyfDCwgS zW9RZJsb*|%umZik6*x}X_9m%<9UPk|0 yWIHu!N-O&(xLJ`KwQL)&nLB_(Y$ywG`h3?mDzU!9XMyB;`SBSLG-_g-7t9uQ& z=k3jJ&{Lf~?bpFA-I6chwSA)LWZ{u5qZrPrgm0;td?Sc^fy*w=vctPFy+y1#*<~ ucAU#2$546P0wo&iJAH X*jY+&LEF@Qh)-Yv?-BnC#X&wWZx8VcGrgMOzu zXij@l1o$~I@i&t033psG_JesQwvxvtJw?Y}Vi5EJV;kbys7j2LNIt)5ymuB$KbQSS zGXXHm7Tf9fHS%7`=NM&*+tlHNqHe!TiijJ> +f`n24$8i(Vh3Z|e;RtDhw@e+?p&tCV2Ke4lJSc4 z$*`!r3gVy^{femnu+;FHc~a*s#a+WJp2H89?Rg6y{$|gRu+A5&n1Y=W;on%JS7!~> z>Rr;98dp2F6Aw3UK0b3wMk%|z>cll^sB&^dcWy5)&)xG?-^MLC6rLz*zevJq#ZH~5 zd_*JYz9-jLwu)#pX5kuVE}hS?B<0^=f4Ta{Bt)$DV*%aWN-m~UCrJRv-p?+IC< Ao!JT@p z2ioYHQQgP#ptiR0-05mPDaM7}odbM9<);GQ(EN32mYzqiou90)o%8tKIB?4Ht31I* zbTw|YF|_D1n?wSxhB-1jUn>q>hWfA%ihmo4_%@$*F0$~K)D
t>3fY0%*B?gKULYIF{Tu^kh@xAr%GMfBR#u5emSuE zy?SB#)2g`klmfA`#n{|QtoXfB`L}nmV0POfUU=7fe=>cLacgzG@~l Cr!QAVs)x6+y? bD02$ z3#LvBcb?(h9xt+ext-pLrLR`xJqZMg=ebEDU%tR?#G*nR1Fg5q>%uke-KM{F96hpF zkHQ_^_%eOLdO34-khD6mp&QnG4~UYd(nL=kr!2L6+K4GQ4h8~g?)jRKU6DfM=r4sr z)0bAn?UK7P0AlsML=ukoZf_@MbVs^wjK~EmZ~_d)JNOy8GHuj;JRMK|^{cgyCtosO za_qZ^1Q5 6!wDUClr9m*47<-8Yad^Q8O-yba-uU6T2oa zS)IIguEB?9PNE;1o1NNNJnkb@YLcFR3df`utZb{kN$XBvXJ>~N3R4Ho4<~{TX9q8a zs4DLpfww xcpd>in()#7A zoZYc%Pjm#gJFOT4668pMS9UY|N?v vHs<_k5ClfR}Wz z7c`;VjTrbegI@}e30(K(l~uo;YYdAs^zax;1Iy8CCH{O4P+G_SZ&Qw=$-eK`JLByB z?*<5#Lw-W0Sm+p2h0acujKfS&be`wd^ZWmh+$4Om1SrutD~`-n-TlbEpdNEF@xbtz zZA`3ps0q2mS$5SuH8ou_{2`|H`^}K^>=H2P@CUr7>>uc=Vl1}c@j^p3!0K4Xco ==}Q4gvom_1gtHmmSgI&zc>fe@mvxC^V~IEC&T5 4kV*8sS*xGSeKQ%?{opa>{E7f z>qacNqyg6uKmE~hOBOso)TmxOw0&PX-0s1Vtn=Scf`N`|;yg9ntpG7N=chux-SQ&( z=N_9B(q2(%_g4#Ewud<94|;4CN0x~)8&??cUS9N?h5ML+Qx-&rcNK1en$I8&f2?_9 z)tJHvH(JhV0-DTtRJeZTnVv@R@kRMG)RnY9w%lU@rG&OlUCo#L>WhdgmSHKB))X5q zJyi@Sel3W|k5 ngHGLT^wWl_w&L%k!UUY;BMg*~IMND|| zhE{*`t*UZ0o1(0#8oGyBs=TK`!kft+l-e<495}ymd}3mJ%F*1>yf?(sVDYolsa>bk z??hz#yOxo?3 ;2QzGufd sfGMxr~WAjJMy!N^}^J`a3Lq;bBD)^oFA4hUYxpS^KfJ)lQ;1XUqiO& zv5k|#q-uXZ8 E2!w(Hc)Z(7a)UXb@44Ds@{m5oj$sNd5SdtgXJ>|=oKlYSp`t-st(S@bAlF+UW z=D(wM@S((&t8nCSt%-mJC$rXM`JFQ;FW5KEsx^)!GA$pxc?~uu)8@o_FGRuK(TZ(; zw#H}Z59Ttp;Q+n!Bb2n(=GXlj6;LD9Qhp$laTFY)%CDHb?<~uUX%xW37i%o=v8#pd zK3-G9mjav|N;;TxeCb+QCzx&As0S{FCbxb@sq@eJ47>xPbr 3`9wD09;&)@9qi};yirT}4?|TnIXl5@XSPDbG?dev6-KMJ(=h%7+ zBZFAelq}vIC>;;qL?cjO-9XGL>5*_x%a;jl$;tDIHLUrP5tv~tWg2SR?zA(mttU7; za&E}_m$~}k32>}UBN483@P{SiX^sXWoKNXIBPjUwkxukaiZe$p`A;f1^;RGG0+^%! zPMe3#54ZNWybdMo>`gPuj^I!{i2ZQgD-6ETnNcPO+ZnAtbJyV~qr{u3!4uN^s>;gO z^WQHSxgG>;9>h0LU;39Wxol=Z3kw?V9(Z)B;U1j?o#e^SUf Qm6OxkjJE3L}?AVfKzr3 zzS7|g3*7{IvhlceCBD{~$4s_;r1Z<>j_P!o9%4gJztl;_aP0>?0}3DYVtqfzf-JH9 z+}QrS@|_A-x5#%Z0M!c5oKf1@bBhPQ>euS3Du0~mTT+w3MNoqCGCYvT!2=2pNymo} zh#f a zJyM`7Fz^7JK4#@^Q_W#&I6nYd??(SfM=$`=B%i8oZ|*lu)?MLPs^mq#;WjY9Z?jwR z-1&olQ&+tbHcm>RTjx?xMU?3apK|dsV4$t7XA{fT0ZOm>-r6b-JR5*WDdV`1a;tB@ z*yDz97)ECRO(ZlOb=bpx(@rR)2bM~c0h$WlTi+iKEFQSG53t3xSp9c_aZZd0Ie>)Q zh>a 39yvBAaXU $>&r~*JMWa}fyp@yBaDxZ0>W?8cA_5~fcKd$HNC_{=LWUMv$tNo z06uRZZ?r@EQ4=X}Y5> `>F6FC0?#aY zjxq)K`2xCFFtYeF?tsUY#TM$y0=S%u+H&61{i i>AP~Z%z9w%%f@~3_&fKhEUh!L S~Yn>j+X#k8x3%UGKj`G!Wn( SVbAJF(aWuA6h(xfJve)<1fOQAS|98TUp*Pc<^v0H&HMnQtiY1X2RyODS(GsR!cQ ztJ$ws8#TmMm^6Dm{R^g3i_C1UMHKG6PupG^H8LY0(#Rp1HO%IqX1g^j(cEz%I64U^ z<*qrU_Bo^9DlDSkjf_RHl`;JcbL*Nmx=SBFt>UQWwzgm~Q9WSZT(Pe(wAQx8MW*&B z&JGT%oM=9P%k*MA6FW*12x9Ww+RT<--hSDm=4t|a ^fk4QMlUZ+o@+?`2aYe;M9$v0jN= t#JY*P ziMh2DkXH{5IXMroNa5=HOyM7KvBU`vE`mG=G-*~qhlB$l+PsT ^1<++h6#(SyJAo+Fwb1uBK|1`AUi{xM5A@aN8KnBpBBWsI*<5Vp zCxG~Ya^% dP@p_y?uw=iYY4vz>p9CtFW=F&gCON&b`Dwc zP^f`~`Zvomz1pr5ke+c3I^Qv#T%c$f5C9L$az^$=X|gvEt82>*1l|mO`U56}aW*^E zg-36r84s-U<|c}6XT%4yFL)h2G75^hv{=YY& zG%UP?=*}LVt(TaFE7wmpnJR^Cu_qd0V5;SfL(k7)T451gsxotzXdO7&0|D12 D3;?7xl+HOMuA{eDdyHq?!|Seex!WiAjWs7s|e*&N<^FEJ*2ZRq!=Q+sQm zJ)9zsE#lX~)X%5CEp}mMC&KJwrupN!h+$b-UEe!)kFfr0(AUP|XrjquWZ=ag+gP zA> ssozQ6Yd)r35L NQo*^Z8v3l@ZS6$18Rv~@Qtvs5BM5~i)-SxH9ldwn=}e@ z#s-;kh 3fPPivwrE#2zBXywBDD+gu9UEc)3=| z!)4Xg)o_6}WrwDSo-Mi9?b6`J!$bB|?#%XRA^cfjV;o3JUGHA$oyX5#{r}!t$LRO> zt#yNvbRa?2W{Kt|(z k3Wupr>Zix8h{z=N|p%^q(pC&nozjBm5^8 Z{3jg#j}XB!>IEYbc8LezbN>hH{ukp+Hq-zB literal 0 HcmV?d00001 diff --git a/documentation/examples/AM2901/design.py b/documentation/examples/AM2901/design.py index 7ee53f77..1405d2ec 100755 --- a/documentation/examples/AM2901/design.py +++ b/documentation/examples/AM2901/design.py @@ -10,6 +10,8 @@ try: from Hurricane import DbU from Hurricane import UpdateSession from Hurricane import Breakpoint + from Hurricane import Transformation + from Hurricane import Instance import Viewer import CRL from helpers import ErrorMessage @@ -37,7 +39,7 @@ except Exception, e: def checkForUnplaceds ( cell ): unplaceds = [] for instance in cell.getInstances(): - if instance.getPlacementStatus() == Hurricane.PlacementStatusUNPLACED: + if instance.getPlacementStatus() == Instance.PlacementStatus.UNPLACED: unplaceds += [ instance ] if unplaceds: message = [ 'Some instances are still unplaceds:' ] @@ -125,8 +127,8 @@ def ScriptMain ( cell=None ): instanceCoeur = amd2901.getInstance( 'core' ) instanceCoeur.setTransformation(Hurricane.Transformation( (chipSide-coreSide)/2 , (chipSide-coreSide)/2 - , Hurricane.OrientationID ) ) - instanceCoeur.setPlacementStatus( Hurricane.PlacementStatusPLACED ) + , Transformation.Orientation.ID ) ) + instanceCoeur.setPlacementStatus( Instance.PlacementStatus.PLACED ) # Placing Pads southPads = [ 'p_a3' , 'p_a2', 'p_a1', 'p_r0', 'p_vddick0', 'p_vssick0', 'p_a0' , 'p_i6', 'p_i8' , 'p_i7' , 'p_r3' ] @@ -144,27 +146,27 @@ def ScriptMain ( cell=None ): if key == 'south' : xpad = abutmentBoxChip.getXMin() + padHeight + ipad*(padWidth) ypad = abutmentBoxChip.getYMin() + padHeight - pad.setTransformation( Hurricane.Transformation( xpad, ypad, Hurricane.OrientationMY) ) + pad.setTransformation( Hurricane.Transformation( xpad, ypad, Transformation.Orientation.MY) ) # east if key == 'east' : xpad = abutmentBoxChip.getXMax() - padHeight ypad = padHeight + padWidth + ipad*(padWidth) - pad.setTransformation( Hurricane.Transformation( xpad, ypad, Hurricane.OrientationR3) ) + pad.setTransformation( Hurricane.Transformation( xpad, ypad, Transformation.Orientation.R3) ) # north if key == 'north' : xpad = padHeight + ipad*(padWidth) ypad = abutmentBoxChip.getYMax() - padHeight - pad.setTransformation( Hurricane.Transformation( xpad, ypad, Hurricane.OrientationID) ) + pad.setTransformation( Hurricane.Transformation( xpad, ypad, Transformation.Orientation.ID) ) # west if key == 'west' : xpad = padHeight ypad = padHeight + ipad*(padWidth) - pad.setTransformation( Hurricane.Transformation( xpad, ypad, Hurricane.OrientationR1) ) + pad.setTransformation( Hurricane.Transformation( xpad, ypad, Transformation.Orientation.R1) ) - pad.setPlacementStatus( Hurricane.PlacementStatusPLACED ) + pad.setPlacementStatus( Instance.PlacementStatus.PLACED ) except ErrorMessage, e: print e; errorCode = e.code diff --git a/hurricane/src/isobar/CMakeLists.txt b/hurricane/src/isobar/CMakeLists.txt index af04e9ae..1a2e22c7 100644 --- a/hurricane/src/isobar/CMakeLists.txt +++ b/hurricane/src/isobar/CMakeLists.txt @@ -20,6 +20,7 @@ PyHorizontal.cpp PyHurricane.cpp PyHyperNet.cpp + PyPlacementStatus.cpp PyInstance.cpp PyInstanceCollection.cpp PyMaterial.cpp @@ -37,6 +38,8 @@ PyViaLayerCollection.cpp PyLibrary.cpp PyNet.cpp + PyNetType.cpp + PyNetDirection.cpp PyNetCollection.cpp PyNetExternalComponents.cpp PyOccurrence.cpp @@ -46,6 +49,8 @@ PyPad.cpp PyPath.cpp PyPin.cpp + PyPinPlacementStatus.cpp + PyPinDirection.cpp PyPinCollection.cpp PyPlug.cpp PyPlugCollection.cpp @@ -57,6 +62,7 @@ PySegmentCollection.cpp PyTechnology.cpp PyTransformation.cpp + PyOrientation.cpp PyDbU.cpp PyUpdateSession.cpp PyVertical.cpp @@ -76,6 +82,7 @@ hurricane/isobar/PyHorizontal.h hurricane/isobar/PyHurricane.h hurricane/isobar/PyHyperNet.h + hurricane/isobar/PyPlacementStatus.h hurricane/isobar/PyInstance.h hurricane/isobar/PyInstanceCollection.h hurricane/isobar/PyMaterial.h @@ -93,6 +100,8 @@ hurricane/isobar/PyViaLayer.h hurricane/isobar/PyLibrary.h hurricane/isobar/PyNet.h + hurricane/isobar/PyNetType.h + hurricane/isobar/PyNetDirection.h hurricane/isobar/PyNetCollection.h hurricane/isobar/PyNetExternalComponents.h hurricane/isobar/PyOccurrence.h @@ -102,6 +111,8 @@ hurricane/isobar/PyPad.h hurricane/isobar/PyPath.h hurricane/isobar/PyPin.h + hurricane/isobar/PyPinPlacementStatus.h + hurricane/isobar/PyPinDirection.h hurricane/isobar/PyPinCollection.h hurricane/isobar/PyPlug.h hurricane/isobar/PyPlugCollection.h @@ -113,6 +124,7 @@ hurricane/isobar/PySegmentCollection.h hurricane/isobar/PyTechnology.h hurricane/isobar/PyTransformation.h + hurricane/isobar/PyOrientation.h hurricane/isobar/PyDbU.h hurricane/isobar/PyUpdateSession.h hurricane/isobar/PyVertical.h diff --git a/hurricane/src/isobar/PyBasicLayer.cpp b/hurricane/src/isobar/PyBasicLayer.cpp index 80ac60e5..aee67189 100644 --- a/hurricane/src/isobar/PyBasicLayer.cpp +++ b/hurricane/src/isobar/PyBasicLayer.cpp @@ -1,36 +1,7 @@ - // -*- C++ -*- // -// This file is part of the Coriolis Project. -// Copyright (C) Laboratoire LIP6 - Departement ASIM -// Universite Pierre et Marie Curie -// -// Main contributors : -// Christophe Alexandre -// Sophie Belloeil -// Hugo Clément -// Jean-Paul Chaput -// Damien Dupuis -// Christian Masson -// Marek Sroka -// -// 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 +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2008-2014, All Rights Reserved // // +-----------------------------------------------------------------+ // | C O R I O L I S | diff --git a/hurricane/src/isobar/PyBox.cpp b/hurricane/src/isobar/PyBox.cpp index 75f6a591..a1c3a465 100644 --- a/hurricane/src/isobar/PyBox.cpp +++ b/hurricane/src/isobar/PyBox.cpp @@ -14,8 +14,6 @@ // +-----------------------------------------------------------------+ - - #include "hurricane/isobar/PyPoint.h" #include "hurricane/isobar/PyBox.h" @@ -58,6 +56,59 @@ extern "C" { // Standart Destroy (Attribute). DirectDestroyAttribute(PyBox_destroy, PyBox) + + + // --------------------------------------------------------------- + // Class Method : "PyBox_NEW ()" + + static PyObject* PyBox_NEW (PyObject *module, PyObject *args) { + trace << "PyBox_NEW()" << endl; + + Box* box = NULL; + PyBox* pyBox = NULL; + + HTRY + PyObject* arg0; + PyObject* arg1; + PyObject* arg2; + PyObject* arg3; + __cs.init ("Box.Box"); + + if (! PyArg_ParseTuple(args,"|O&O&O&O&:Box.Box", + Converter, &arg0, + Converter, &arg1, + Converter, &arg2, + Converter, &arg3)) { + return NULL; + } + + if (__cs.getObjectIds() == NO_ARG) { box = new Box (); } + else if ( __cs.getObjectIds() == POINT_ARG ) { box = new Box ( *PYPOINT_O(arg0) ); } + else if ( __cs.getObjectIds() == BOX_ARG ) { box = new Box ( *PYBOX_O(arg0) ); } + else if ( __cs.getObjectIds() == POINTS2_ARG ) { box = new Box ( *PYPOINT_O(arg0) , *PYPOINT_O(arg1) ); } + else if ( __cs.getObjectIds() == INTS2_ARG ) { box = new Box ( PyInt_AsLong(arg0) , PyInt_AsLong(arg1) ); } + else if ( __cs.getObjectIds() == INTS4_ARG ) { + box = new Box ( PyInt_AsLong(arg0), PyInt_AsLong(arg1), PyInt_AsLong(arg2) , PyInt_AsLong(arg3) ); + } else { + PyErr_SetString(ConstructorError, "invalid number of parameters for Box constructor." ); + return NULL; + } + + pyBox = PyObject_NEW(PyBox, &PyTypeBox); + if (pyBox == NULL) return NULL; + + pyBox->_object = box; + HCATCH + + return ( (PyObject*)pyBox ); + } + + + static int PyBox_Init ( PyBox* self, PyObject* args, PyObject* kwargs ) + { + trace << "PyBox_Init(): " << (void*)self << endl; + return 0; + } static PyObject* PyBox_getCenter ( PyBox *self ) { @@ -370,7 +421,8 @@ extern "C" { DirectDeleteMethod(PyBox_DeAlloc,PyBox) - PyTypeObjectLinkPyType(Box) + PyTypeObjectLinkPyTypeNewInit(Box) +//PyTypeObjectLinkPyType(Box) #else // End of Python Module Code Part. @@ -378,52 +430,6 @@ extern "C" { // x=================================================================x // | "PyBox" Shared Library Code Part | // x=================================================================x - - - // --------------------------------------------------------------- - // Attribute Method : "PyBox_create ()" - - PyObject* PyBox_create (PyObject *module, PyObject *args) { - trace << "PyBox_create()" << endl; - - Box* box = NULL; - PyBox* pyBox = NULL; - - HTRY - PyObject* arg0; - PyObject* arg1; - PyObject* arg2; - PyObject* arg3; - __cs.init ("Box.create"); - - if (! PyArg_ParseTuple(args,"|O&O&O&O&:Box.create", - Converter, &arg0, - Converter, &arg1, - Converter, &arg2, - Converter, &arg3)) { - return NULL; - } - - if (__cs.getObjectIds() == NO_ARG) { box = new Box (); } - else if ( __cs.getObjectIds() == POINT_ARG ) { box = new Box ( *PYPOINT_O(arg0) ); } - else if ( __cs.getObjectIds() == BOX_ARG ) { box = new Box ( *PYBOX_O(arg0) ); } - else if ( __cs.getObjectIds() == POINTS2_ARG ) { box = new Box ( *PYPOINT_O(arg0) , *PYPOINT_O(arg1) ); } - else if ( __cs.getObjectIds() == INTS2_ARG ) { box = new Box ( PyInt_AsLong(arg0) , PyInt_AsLong(arg1) ); } - else if ( __cs.getObjectIds() == INTS4_ARG ) { - box = new Box ( PyInt_AsLong(arg0), PyInt_AsLong(arg1), PyInt_AsLong(arg2) , PyInt_AsLong(arg3) ); - } else { - PyErr_SetString(ConstructorError, "invalid number of parameters for Box constructor." ); - return NULL; - } - - pyBox = PyObject_NEW(PyBox, &PyTypeBox); - if (pyBox == NULL) return NULL; - - pyBox->_object = box; - HCATCH - - return ( (PyObject*)pyBox ); - } diff --git a/hurricane/src/isobar/PyCell.cpp b/hurricane/src/isobar/PyCell.cpp index 13347137..2085db15 100644 --- a/hurricane/src/isobar/PyCell.cpp +++ b/hurricane/src/isobar/PyCell.cpp @@ -1,17 +1,16 @@ - // -*- C++ -*- // // This file is part of the Coriolis Software. -// Copyright (c) UPMC/LIP6 2008-2013, All Rights Reserved +// Copyright (c) UPMC 2006-2014, All Rights Reserved // // +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | // | Author : Jean-Paul CHAPUT | -// | E-mail : Jean-Paul.Chaput@asim.lip6.fr | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Module : "./PyCell.cpp" | +// | C++ Module : "./PyCell.cpp" | // +-----------------------------------------------------------------+ @@ -61,6 +60,29 @@ extern "C" { // Standart Delete (Attribute). DBoDestroyAttribute(PyCell_destroy,PyCell) + + // --------------------------------------------------------------- + // Attribute Method : "PyCell_create ()" + + PyObject* PyCell_create ( PyObject*, PyObject *args ) { + trace << "PyCell_create()" << endl; + + char* name = NULL; + PyLibrary* pyLibrary = NULL; + Cell* cell = NULL; + + HTRY + if (PyArg_ParseTuple(args,"O!s:Cell.create", &PyTypeLibrary, &pyLibrary, &name)) { + cell = Cell::create(PYLIBRARY_O(pyLibrary), Name(name)); + } else { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Cell constructor."); + return NULL; + } + HCATCH + + return PyCell_Link(cell); + } + // --------------------------------------------------------------- // Attribute Method : "PyCell_getLibrary ()" @@ -642,7 +664,9 @@ extern "C" { // PyCell Attribute Method table. PyMethodDef PyCell_Methods[] = - { { "getLibrary" , (PyCFunction)PyCell_getLibrary , METH_NOARGS , "Returns the library owning the cell." } + { { "create" , (PyCFunction)PyCell_create , METH_VARARGS|METH_STATIC + , "Create a new cell." } + , { "getLibrary" , (PyCFunction)PyCell_getLibrary , METH_NOARGS , "Returns the library owning the cell." } , { "getName" , (PyCFunction)PyCell_getName , METH_NOARGS , "Returns the name of the cell." } , { "getInstance" , (PyCFunction)PyCell_getInstance , METH_VARARGS, "Returns the instance of name if it exists, else NULL." } , { "getInstances" , (PyCFunction)PyCell_getInstances , METH_NOARGS , "Returns the locator of the collection of all instances called by the cell." } // getInstances @@ -693,33 +717,8 @@ extern "C" { // | "PyCell" Shared Library Code Part | // x=================================================================x - // --------------------------------------------------------------- - // Attribute Method : "PyCell_create ()" - PyObject* PyCell_create ( PyObject *module, PyObject *args ) { - trace << "PyCell_create()" << endl; - - char* name = NULL; - PyLibrary* pyLibrary = NULL; - Cell* cell = NULL; - - HTRY - if (PyArg_ParseTuple(args,"O!s:Cell.create", &PyTypeLibrary, &pyLibrary, &name)) { - cell = Cell::create(PYLIBRARY_O(pyLibrary), Name(name)); - } else { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Cell constructor."); - return NULL; - } - HCATCH - - return PyCell_Link(cell); - } - // Link/Creation Method. DBoLinkCreateMethod(Cell) - - - // --------------------------------------------------------------- - // PyCell Object Definitions. PyTypeInheritedObjectDefinitions(Cell, Entity) diff --git a/hurricane/src/isobar/PyContact.cpp b/hurricane/src/isobar/PyContact.cpp index d67c919a..f24a0bd4 100644 --- a/hurricane/src/isobar/PyContact.cpp +++ b/hurricane/src/isobar/PyContact.cpp @@ -61,58 +61,9 @@ extern "C" { // Standart destroy (Attribute). DBoDestroyAttribute(PyContact_destroy, PyContact) - - - static PyObject* PyContact_translate ( PyContact *self, PyObject* args ) { - trace << "PyContact_translate ()" << endl; - - HTRY - METHOD_HEAD ( "Contact.translate()" ) - DbU::Unit dx=0, dy=0; - if (PyArg_ParseTuple(args,"ll:Contact.translate", &dx, &dy)) { - contact->translate(dx, dy); - } else { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Contact.translate()" ); - return NULL; - } - HCATCH - - Py_RETURN_NONE; - } - - - PyMethodDef PyContact_Methods[] = - { { "destroy" , (PyCFunction)PyContact_destroy , METH_NOARGS - , "Destroy associated hurricane object, the python object remains." } - , { "getAnchorHook" , (PyCFunction)PyContact_getAnchorHook , METH_NOARGS , "Return the contact anchor hook." } - , { "getWidth" , (PyCFunction)PyContact_getWidth , METH_NOARGS , "Return the contact width." } - , { "getHalfWidth" , (PyCFunction)PyContact_getHalfWidth , METH_NOARGS , "Return the contact half width." } - , { "getHeight" , (PyCFunction)PyContact_getHeight , METH_NOARGS , "Return the contact height." } - , { "getHalfHeight" , (PyCFunction)PyContact_getHalfHeight , METH_NOARGS , "Return the contact half height." } - , { "getDx" , (PyCFunction)PyContact_getDx , METH_NOARGS , "Return the contact dx value." } - , { "getDy" , (PyCFunction)PyContact_getDy , METH_NOARGS , "Return the contact dy value." } - , { "translate" , (PyCFunction)PyContact_translate , METH_VARARGS, "Translates the Contact of dx and dy." } - , { "setX" , (PyCFunction)PyContact_setX , METH_VARARGS, "Sets the contact X value." } - , { "setY" , (PyCFunction)PyContact_setY , METH_VARARGS, "Sets the contact Y value." } - , { "setDx" , (PyCFunction)PyContact_setDx , METH_VARARGS, "Sets the contact dx value." } - , { "setDy" , (PyCFunction)PyContact_setDy , METH_VARARGS, "Sets the contact dy value." } - , {NULL, NULL, 0, NULL} /* sentinel */ - }; - - - DBoDeleteMethod(Contact) - PyTypeObjectLinkPyType(Contact) - - -#else // End of Python Module Code Part. - - -// +=================================================================+ -// | "PyContact" Shared Library Code Part | -// +=================================================================+ - PyObject* PyContact_create ( PyObject *module, PyObject *args ) { + static PyObject* PyContact_create ( PyObject*, PyObject *args ) { trace << "PyContact_create()" << endl; Contact* contact = NULL; @@ -145,6 +96,57 @@ extern "C" { } + static PyObject* PyContact_translate ( PyContact *self, PyObject* args ) { + trace << "PyContact_translate ()" << endl; + + HTRY + METHOD_HEAD ( "Contact.translate()" ) + DbU::Unit dx=0, dy=0; + if (PyArg_ParseTuple(args,"ll:Contact.translate", &dx, &dy)) { + contact->translate(dx, dy); + } else { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Contact.translate()" ); + return NULL; + } + HCATCH + + Py_RETURN_NONE; + } + + + PyMethodDef PyContact_Methods[] = + { { "create" , (PyCFunction)PyContact_create , METH_VARARGS|METH_STATIC + , "Create a new Contact." } + , { "destroy" , (PyCFunction)PyContact_destroy , METH_NOARGS + , "Destroy associated hurricane object, the python object remains." } + , { "getAnchorHook" , (PyCFunction)PyContact_getAnchorHook , METH_NOARGS , "Return the contact anchor hook." } + , { "getWidth" , (PyCFunction)PyContact_getWidth , METH_NOARGS , "Return the contact width." } + , { "getHalfWidth" , (PyCFunction)PyContact_getHalfWidth , METH_NOARGS , "Return the contact half width." } + , { "getHeight" , (PyCFunction)PyContact_getHeight , METH_NOARGS , "Return the contact height." } + , { "getHalfHeight" , (PyCFunction)PyContact_getHalfHeight , METH_NOARGS , "Return the contact half height." } + , { "getDx" , (PyCFunction)PyContact_getDx , METH_NOARGS , "Return the contact dx value." } + , { "getDy" , (PyCFunction)PyContact_getDy , METH_NOARGS , "Return the contact dy value." } + , { "translate" , (PyCFunction)PyContact_translate , METH_VARARGS, "Translates the Contact of dx and dy." } + , { "setX" , (PyCFunction)PyContact_setX , METH_VARARGS, "Sets the contact X value." } + , { "setY" , (PyCFunction)PyContact_setY , METH_VARARGS, "Sets the contact Y value." } + , { "setDx" , (PyCFunction)PyContact_setDx , METH_VARARGS, "Sets the contact dx value." } + , { "setDy" , (PyCFunction)PyContact_setDy , METH_VARARGS, "Sets the contact dy value." } + , {NULL, NULL, 0, NULL} /* sentinel */ + }; + + + DBoDeleteMethod(Contact) + PyTypeObjectLinkPyType(Contact) + + +#else // End of Python Module Code Part. + + +// +=================================================================+ +// | "PyContact" Shared Library Code Part | +// +=================================================================+ + + // Link/Creation Method. DBoLinkCreateMethod(Contact) diff --git a/hurricane/src/isobar/PyDataBase.cpp b/hurricane/src/isobar/PyDataBase.cpp index 2382208f..366faca8 100644 --- a/hurricane/src/isobar/PyDataBase.cpp +++ b/hurricane/src/isobar/PyDataBase.cpp @@ -1,8 +1,7 @@ - // -*- C++ -*- // // This file is part of the Coriolis Software. -// Copyright (c) UPMC/LIP6 2008-2013, All Rights Reserved +// Copyright (c) UPMC 2008-2014, All Rights Reserved // // +-----------------------------------------------------------------+ // | C O R I O L I S | @@ -38,18 +37,31 @@ extern "C" { #if defined(__PYTHON_MODULE__) - PyObject* PyDataBase_getDB ( PyObject* module ) { + static PyObject* PyDataBase_create ( PyObject* ) { + trace << "PyDataBase_create()" << endl; + + DataBase* db = NULL; + + HTRY + db = DataBase::create(); + HCATCH + + return PyDataBase_Link(db); + } + + + static PyObject* PyDataBase_getDB ( PyObject* ) { trace << "PyDataBase_getDB()" << endl; DataBase* db = NULL; HTRY - db = DataBase::getDB (); - if ( db == NULL ) - PyErr_SetString ( HurricaneError, "DataBase has not been created yet" ); + db = DataBase::getDB(); + if (db == NULL) + PyErr_SetString( HurricaneError, "DataBase.getDB(): DataBase has not been created yet" ); HCATCH - return PyDataBase_Link ( db ); + return PyDataBase_Link( db ); } @@ -94,7 +106,11 @@ extern "C" { // PyDataBase Attribute Method table. PyMethodDef PyDataBase_Methods[] = - { { "getTechnology" , (PyCFunction)PyDataBase_getTechnology , METH_NOARGS, "Return the Technology" } + { { "create" , (PyCFunction)PyDataBase_create , METH_NOARGS|METH_STATIC + , "Create the DataBase (only the first call created it)" } + , { "getDB" , (PyCFunction)PyDataBase_getDB , METH_NOARGS|METH_STATIC + , "Get the DataBase" } + , { "getTechnology" , (PyCFunction)PyDataBase_getTechnology , METH_NOARGS, "Return the Technology" } , { "getRootLibrary", (PyCFunction)PyDataBase_getRootLibrary, METH_NOARGS, "Return the root library" } , { "destroy" , (PyCFunction)PyDataBase_destroy , METH_NOARGS , "Destroy associated hurricane object The python object remains." } @@ -113,23 +129,8 @@ extern "C" { // +=================================================================+ - PyObject* PyDataBase_create ( PyObject *module ) { - trace << "PyDataBase_create()" << endl; - - DataBase* db = NULL; - - HTRY - db = DataBase::create (); - HCATCH - - return PyDataBase_Link(db); - } - - // Link/Creation Method. DBoLinkCreateMethod(DataBase) - - PyTypeObjectDefinitions(DataBase) #endif // End of Shared Library Code Part. diff --git a/hurricane/src/isobar/PyHorizontal.cpp b/hurricane/src/isobar/PyHorizontal.cpp index e2083510..60b8bb1a 100644 --- a/hurricane/src/isobar/PyHorizontal.cpp +++ b/hurricane/src/isobar/PyHorizontal.cpp @@ -1,18 +1,17 @@ -// x-----------------------------------------------------------------x -// | | +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2007-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | -// | Author : Sophie BELLOEIL | -// | E-mail : Sophie.Belloeil@asim.lip6.fr | +// | Author : Sophie BELLOEIL | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Module : "./PyHorizontal.cpp" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x - - +// | C++ Module : "./PyHorizontal.cpp" | +// +-----------------------------------------------------------------+ #include "hurricane/isobar/PyNet.h" @@ -22,7 +21,6 @@ namespace Isobar { - using namespace Hurricane; @@ -59,66 +57,10 @@ extern "C" { DBoDestroyAttribute(PyHorizontal_destroy, PyHorizontal) - // --------------------------------------------------------------- - // Attribute Method : "PyHorizontal_translate ()" - - static PyObject* PyHorizontal_translate ( PyHorizontal *self, PyObject* args ) { - trace << "PyHorizontal_translate ()" << endl; - - HTRY - METHOD_HEAD ( "Horizontal.translate()" ) - DbU::Unit dx=0, dy=0; - if (PyArg_ParseTuple(args,"ll:Horizontal.translate", &dx, &dy)) { - horizontal->translate(dx, dy); - } else { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Horizontal.translate()" ); - return NULL; - } - HCATCH - - Py_RETURN_NONE; - } - - - // --------------------------------------------------------------- - // PyHorizontal Attribute Method table. - - PyMethodDef PyHorizontal_Methods[] = - { { "getY" , (PyCFunction)PyHorizontal_getY , METH_NOARGS , "Get the segment Y position." } - , { "getDxSource", (PyCFunction)PyHorizontal_getDxSource, METH_NOARGS , "Get the segment source X offset." } - , { "getDxTarget", (PyCFunction)PyHorizontal_getDxTarget, METH_NOARGS , "Get the segment target X offset." } - , { "setY" , (PyCFunction)PyHorizontal_setY , METH_VARARGS, "Modify the segment Y position." } - , { "setDxSource", (PyCFunction)PyHorizontal_setDxSource, METH_VARARGS, "Modify the segment source X offset." } - , { "setDxTarget", (PyCFunction)PyHorizontal_setDxTarget, METH_VARARGS, "Modify the segment target X offset." } - , { "translate" , (PyCFunction)PyHorizontal_translate , METH_VARARGS, "Translates the Horizontal segment of dx and dy." } - , { "destroy" , (PyCFunction)PyHorizontal_destroy , METH_NOARGS - , "destroy associated hurricane object, the python object remains." } - , {NULL, NULL, 0, NULL} /* sentinel */ - }; - - - - - // x-------------------------------------------------------------x - // | "PyHorizontal" Object Methods | - // x-------------------------------------------------------------x - - - DBoDeleteMethod(Horizontal) - PyTypeObjectLinkPyType(Horizontal) - - -#else // End of Python Module Code Part. - - -// x=================================================================x -// | "PyHorizontal" Shared Library Code Part | -// x=================================================================x - // --------------------------------------------------------------- // Attribute Method : "PyHorizontal_create ()" - PyObject* PyHorizontal_create ( PyObject *module, PyObject *args ) { + static PyObject* PyHorizontal_create ( PyObject*, PyObject *args ) { trace << "PyHorizontal_create()" << endl; PyObject* arg0; @@ -206,6 +148,65 @@ extern "C" { } + // --------------------------------------------------------------- + // Attribute Method : "PyHorizontal_translate ()" + + static PyObject* PyHorizontal_translate ( PyHorizontal *self, PyObject* args ) { + trace << "PyHorizontal_translate ()" << endl; + + HTRY + METHOD_HEAD ( "Horizontal.translate()" ) + DbU::Unit dx=0, dy=0; + if (PyArg_ParseTuple(args,"ll:Horizontal.translate", &dx, &dy)) { + horizontal->translate(dx, dy); + } else { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Horizontal.translate()" ); + return NULL; + } + HCATCH + + Py_RETURN_NONE; + } + + + // --------------------------------------------------------------- + // PyHorizontal Attribute Method table. + + PyMethodDef PyHorizontal_Methods[] = + { { "create" , (PyCFunction)PyHorizontal_create , METH_VARARGS|METH_STATIC + , "Create a new Horizontal." } + , { "getY" , (PyCFunction)PyHorizontal_getY , METH_NOARGS , "Get the segment Y position." } + , { "getDxSource", (PyCFunction)PyHorizontal_getDxSource, METH_NOARGS , "Get the segment source X offset." } + , { "getDxTarget", (PyCFunction)PyHorizontal_getDxTarget, METH_NOARGS , "Get the segment target X offset." } + , { "setY" , (PyCFunction)PyHorizontal_setY , METH_VARARGS, "Modify the segment Y position." } + , { "setDxSource", (PyCFunction)PyHorizontal_setDxSource, METH_VARARGS, "Modify the segment source X offset." } + , { "setDxTarget", (PyCFunction)PyHorizontal_setDxTarget, METH_VARARGS, "Modify the segment target X offset." } + , { "translate" , (PyCFunction)PyHorizontal_translate , METH_VARARGS, "Translates the Horizontal segment of dx and dy." } + , { "destroy" , (PyCFunction)PyHorizontal_destroy , METH_NOARGS + , "destroy associated hurricane object, the python object remains." } + , {NULL, NULL, 0, NULL} /* sentinel */ + }; + + + + + // x-------------------------------------------------------------x + // | "PyHorizontal" Object Methods | + // x-------------------------------------------------------------x + + + DBoDeleteMethod(Horizontal) + PyTypeObjectLinkPyType(Horizontal) + + +#else // End of Python Module Code Part. + + +// x=================================================================x +// | "PyHorizontal" Shared Library Code Part | +// x=================================================================x + + // Link/Creation Method. DBoLinkCreateMethod(Horizontal) diff --git a/hurricane/src/isobar/PyHurricane.cpp b/hurricane/src/isobar/PyHurricane.cpp index 0e28b9dd..67134736 100644 --- a/hurricane/src/isobar/PyHurricane.cpp +++ b/hurricane/src/isobar/PyHurricane.cpp @@ -1,4 +1,3 @@ - // -*- C++ -*- // // This file is part of the Coriolis Software. @@ -22,6 +21,7 @@ #include "hurricane/isobar/PyPoint.h" #include "hurricane/isobar/PyBox.h" #include "hurricane/isobar/PyTransformation.h" +#include "hurricane/isobar/PyOrientation.h" #include "hurricane/isobar/PyDataBase.h" #include "hurricane/isobar/PyLibrary.h" #include "hurricane/isobar/PyEntity.h" @@ -41,12 +41,17 @@ #include "hurricane/isobar/PyRegularLayerCollection.h" #include "hurricane/isobar/PyViaLayerCollection.h" #include "hurricane/isobar/PyPin.h" +#include "hurricane/isobar/PyPinPlacementStatus.h" +#include "hurricane/isobar/PyPinDirection.h" #include "hurricane/isobar/PyPinCollection.h" +#include "hurricane/isobar/PyPlacementStatus.h" #include "hurricane/isobar/PyInstance.h" #include "hurricane/isobar/PyInstanceCollection.h" #include "hurricane/isobar/PyReference.h" #include "hurricane/isobar/PyReferenceCollection.h" #include "hurricane/isobar/PyNet.h" +#include "hurricane/isobar/PyNetType.h" +#include "hurricane/isobar/PyNetDirection.h" #include "hurricane/isobar/PyNetCollection.h" #include "hurricane/isobar/PyNetExternalComponents.h" #include "hurricane/isobar/PyHyperNet.h" @@ -472,36 +477,16 @@ extern "C" { } static PyMethodDef PyHurricane_Methods[] = - { { "trace" , PyCommons_trace , METH_VARARGS, "Switch on/off the trace mode (for debugging)." } - , { "DbU_db" , PyDbU_fromDb , METH_VARARGS, "Converts an integer to DbU::Unit (no scale factor)." } - , { "DbU_grid" , PyDbU_fromGrid , METH_VARARGS, "Converts a founder grid to DbU::Unit." } - , { "DbU_lambda" , PyDbU_fromLambda , METH_VARARGS, "Converts a symbolic (lambda) to DbU::Unit." } - , { "DbU_getDb" , PyDbU_toDb , METH_VARARGS, "Converts a DbU::Unit to an integer value (no scale factor)." } - , { "DbU_getGrid" , PyDbU_toGrid , METH_VARARGS, "Converts a DbU::Unit to a to grid founder." } - , { "DbU_getLambda" , PyDbU_toLambda , METH_VARARGS, "Converts a DbU::Unit to a symbolic value (to lambda)." } - , { "DbU_getPhysical" , PyDbU_toPhysical , METH_VARARGS, "Converts a DbU::Unit to a physical value." } - , { "DbU_getOnPhysicalGrid" , PyDbU_getOnPhysicalGrid , METH_VARARGS, "Adjusts a DbU::Unit to physical grid." } - , { "Point" , PyPoint_create , METH_VARARGS, "Creates a new Point." } - , { "Box" , PyBox_create , METH_VARARGS, "Creates a new Box." } - , { "Transformation" , PyTransformation_create , METH_VARARGS, "Creates a new Transformation." } - , { "DataBase" , (PyCFunction)PyDataBase_create , METH_NOARGS , "Creates the DataBase." } - , { "getDB" , (PyCFunction)PyDataBase_getDB , METH_NOARGS , "Gets the current DataBase." } - , { "getDataBase" , (PyCFunction)PyDataBase_getDB , METH_NOARGS , "Gets the current DataBase." } - , { "Library" , (PyCFunction)PyLibrary_create , METH_VARARGS, "Creates a new Library." } -// , { "getLibrary" , (PyCFunction)PyLibrary_getLibrary , METH_NOARGS , "Gets the current Library." } - , { "Reference" , (PyCFunction)PyReference_create , METH_VARARGS, "Creates a new Reference." } - , { "Cell" , (PyCFunction)PyCell_create , METH_VARARGS, "Creates a new Cell." } - , { "Instance" , (PyCFunction)PyInstance_create , METH_VARARGS, "Creates a new Instance." } - , { "Net" , (PyCFunction)PyNet_create , METH_VARARGS, "Creates a new Net." } - , { "HyperNet" , (PyCFunction)PyHyperNet_create , METH_VARARGS, "Creates a new HyperNet." } - , { "Horizontal" , (PyCFunction)PyHorizontal_create , METH_VARARGS, "Creates a new Horizontal." } - , { "Vertical" , (PyCFunction)PyVertical_create , METH_VARARGS, "Creates a new Vertical." } - , { "Contact" , (PyCFunction)PyContact_create , METH_VARARGS, "Creates a new Contact." } - , { "Pin" , (PyCFunction)PyPin_create , METH_VARARGS, "Creates a new Pin." } - , { "Pad" , (PyCFunction)PyPad_create , METH_VARARGS, "Creates a new Pad." } - , { "Path" , (PyCFunction)PyPath_create , METH_VARARGS, "Creates a new Path." } - , { "Occurrence" , (PyCFunction)PyOccurrence_create , METH_VARARGS, "Creates a new Occurrence." } - , {NULL, NULL, 0, NULL} /* sentinel */ + { { "trace" , PyCommons_trace , METH_VARARGS, "Switch on/off the trace mode (for debugging)." } + , { "DbU_db" , PyDbU_fromDb , METH_VARARGS, "Converts an integer to DbU::Unit (no scale factor)." } + , { "DbU_grid" , PyDbU_fromGrid , METH_VARARGS, "Converts a founder grid to DbU::Unit." } + , { "DbU_lambda" , PyDbU_fromLambda , METH_VARARGS, "Converts a symbolic (lambda) to DbU::Unit." } + , { "DbU_getDb" , PyDbU_toDb , METH_VARARGS, "Converts a DbU::Unit to an integer value (no scale factor)." } + , { "DbU_getGrid" , PyDbU_toGrid , METH_VARARGS, "Converts a DbU::Unit to a to grid founder." } + , { "DbU_getLambda" , PyDbU_toLambda , METH_VARARGS, "Converts a DbU::Unit to a symbolic value (to lambda)." } + , { "DbU_getPhysical" , PyDbU_toPhysical , METH_VARARGS, "Converts a DbU::Unit to a physical value." } + , { "DbU_getOnPhysicalGrid", PyDbU_getOnPhysicalGrid, METH_VARARGS, "Adjusts a DbU::Unit to physical grid." } + , {NULL, NULL, 0, NULL} /* sentinel */ }; @@ -516,6 +501,7 @@ extern "C" { PyPoint_LinkPyType (); PyBox_LinkPyType (); PyTransformation_LinkPyType (); + PyOrientation_LinkPyType (); PyDataBase_LinkPyType (); PyTechnology_LinkPyType (); PyLibrary_LinkPyType (); @@ -540,6 +526,8 @@ extern "C" { PyNetCollection_LinkPyType (); PyNetExternalComponents_LinkPyType (); PyCellCollection_LinkPyType (); + PyPinPlacementStatus_LinkPyType (); + PyPinDirection_LinkPyType (); PyPinCollection_LinkPyType (); PySegmentCollection_LinkPyType (); PyOccurrenceCollection_LinkPyType (); @@ -547,8 +535,11 @@ extern "C" { PyReferenceCollection_LinkPyType (); PyCell_LinkPyType (); PyInstance_LinkPyType (); + PyPlacementStatus_LinkPyType (); PyReference_LinkPyType (); PyNet_LinkPyType (); + PyNetType_LinkPyType (); + PyNetDirection_LinkPyType (); PyHyperNet_LinkPyType (); PyHook_LinkPyType (); PyHookCollection_LinkPyType (); @@ -570,6 +561,7 @@ extern "C" { PYTYPE_READY ( DbU ) PYTYPE_READY ( Box ) PYTYPE_READY ( Transformation ) + PYTYPE_READY ( Orientation ) PYTYPE_READY ( DataBase ) PYTYPE_READY ( Technology ) PYTYPE_READY ( Library ) @@ -589,14 +581,19 @@ extern "C" { PYTYPE_READY ( ViaLayerCollectionLocator ) PYTYPE_READY ( Path ) PYTYPE_READY ( Occurrence ) + PYTYPE_READY ( PlacementStatus ) PYTYPE_READY ( InstanceCollection ) PYTYPE_READY ( InstanceCollectionLocator ) PYTYPE_READY ( PlugCollection ) PYTYPE_READY ( PlugCollectionLocator ) + PYTYPE_READY ( NetType ) + PYTYPE_READY ( NetDirection ) PYTYPE_READY ( NetCollection ) PYTYPE_READY ( NetCollectionLocator ) PYTYPE_READY ( CellCollection ) PYTYPE_READY ( CellCollectionLocator ) + PYTYPE_READY ( PinPlacementStatus ) + PYTYPE_READY ( PinDirection ) PYTYPE_READY ( PinCollection ) PYTYPE_READY ( PinCollectionLocator ) PYTYPE_READY ( SegmentCollection ) @@ -687,6 +684,7 @@ extern "C" { __cs.addType ( "db" , &PyTypeDataBase , " " , false ); __cs.addType ( "techno" , &PyTypeTechnology , " " , false ); __cs.addType ( "transfo" , &PyTypeTransformation , " " , false ); + __cs.addType ( "orient" , &PyTypeOrientation , " " , false ); __cs.addType ( "vert" , &PyTypeVertical , " " , false, "segment" ); __cs.addType ( "path" , &PyTypePath , " " , false ); __cs.addType ( "occur" , &PyTypeOccurrence , " " , false ); @@ -704,6 +702,29 @@ extern "C" { Py_INCREF ( &PyTypeDbU ); PyModule_AddObject ( module, "DbU" , (PyObject*)&PyTypeDbU ); + Py_INCREF ( &PyTypePoint ); + PyModule_AddObject ( module, "Box" , (PyObject*)&PyTypeBox ); + Py_INCREF ( &PyTypePoint ); + PyModule_AddObject ( module, "Point" , (PyObject*)&PyTypePoint ); + Py_INCREF ( &PyTypeTransformation ); + PyModule_AddObject ( module, "Transformation" , (PyObject*)&PyTypeTransformation ); + Py_INCREF ( &PyTypePath ); + PyModule_AddObject ( module, "Path" , (PyObject*)&PyTypePath ); + Py_INCREF ( &PyTypeOccurrence ); + PyModule_AddObject ( module, "Occurrence" , (PyObject*)&PyTypeOccurrence ); + + Py_INCREF ( &PyTypeDataBase ); + PyModule_AddObject ( module, "DataBase" , (PyObject*)&PyTypeDataBase ); + Py_INCREF ( &PyTypeLibrary ); + PyModule_AddObject ( module, "Library" , (PyObject*)&PyTypeLibrary ); + Py_INCREF ( &PyTypeNet ); + PyModule_AddObject ( module, "Net" , (PyObject*)&PyTypeNet ); + Py_INCREF ( &PyTypeHyperNet ); + PyModule_AddObject ( module, "HyperNet" , (PyObject*)&PyTypeHyperNet ); + Py_INCREF ( &PyTypeInstance ); + PyModule_AddObject ( module, "Cell" , (PyObject*)&PyTypeCell ); + Py_INCREF ( &PyTypeInstance ); + PyModule_AddObject ( module, "Instance" , (PyObject*)&PyTypeInstance ); Py_INCREF ( &PyTypeTechnology ); PyModule_AddObject ( module, "Technology" , (PyObject*)&PyTypeTechnology ); Py_INCREF ( &PyTypeLayer ); @@ -730,23 +751,27 @@ extern "C" { PyModule_AddObject ( module, "Breakpoint" , (PyObject*)&PyTypeBreakpoint ); Py_INCREF ( &PyTypeQuery ); PyModule_AddObject ( module, "Query" , (PyObject*)&PyTypeQuery ); + Py_INCREF ( &PyTypeReference ); + PyModule_AddObject ( module, "Reference" , (PyObject*)&PyTypeReference ); Py_INCREF ( &PyTypeHook ); PyModule_AddObject ( module, "Hook" , (PyObject*)&PyTypeHook ); Py_INCREF ( &PyTypeHookCollection ); PyModule_AddObject ( module, "HookCollection" , (PyObject*)&PyTypeHookCollection ); + Py_INCREF ( &PyTypePlug ); + PyModule_AddObject ( module, "PyPlug" , (PyObject*)&PyTypePlug ); Py_INCREF ( &PyTypeRoutingPad ); PyModule_AddObject ( module, "RoutingPad" , (PyObject*)&PyTypeRoutingPad ); Py_INCREF ( &PyTypeVertical ); - PyModule_AddObject ( module, "PyVertical" , (PyObject*)&PyTypeVertical ); + PyModule_AddObject ( module, "Vertical" , (PyObject*)&PyTypeVertical ); Py_INCREF ( &PyTypeHorizontal ); - PyModule_AddObject ( module, "PyHorizontal" , (PyObject*)&PyTypeHorizontal ); + PyModule_AddObject ( module, "Horizontal" , (PyObject*)&PyTypeHorizontal ); Py_INCREF ( &PyTypeContact ); - PyModule_AddObject ( module, "PyContact" , (PyObject*)&PyTypeContact ); - Py_INCREF ( &PyTypePlug ); - PyModule_AddObject ( module, "PyPlug" , (PyObject*)&PyTypePlug ); + PyModule_AddObject ( module, "Contact" , (PyObject*)&PyTypeContact ); + Py_INCREF ( &PyTypePin ); + PyModule_AddObject ( module, "Pin" , (PyObject*)&PyTypePin ); Py_INCREF ( &PyTypePad ); - PyModule_AddObject ( module, "PyPad" , (PyObject*)&PyTypePad ); + PyModule_AddObject ( module, "Pad" , (PyObject*)&PyTypePad ); PyObject* dictionnary = PyModule_GetDict ( module ); @@ -760,16 +785,16 @@ extern "C" { PyDict_SetItemString ( dictionnary, "ProxyError" , ProxyError ); PyDict_SetItemString ( dictionnary, "HurricaneError" , HurricaneError ); - DbULoadConstants ( dictionnary ); - TransformationLoadConstants( dictionnary ); - NetLoadConstants ( dictionnary ); - InstanceLoadConstants ( dictionnary ); - PinLoadConstants ( dictionnary ); + DbULoadConstants( dictionnary ); PyDbU_postModuleInit(); + PyTransformation_postModuleInit(); PyLayer_postModuleInit(); PyBasicLayer_postModuleInit(); + PyPin_postModuleInit(); PyRoutingPad_postModuleInit(); + PyNet_postModuleInit(); + PyInstance_postModuleInit(); trace << "Hurricane.so loaded " << (void*)&typeid(string) << endl; } diff --git a/hurricane/src/isobar/PyHyperNet.cpp b/hurricane/src/isobar/PyHyperNet.cpp index 51ff8fc2..18eb4008 100644 --- a/hurricane/src/isobar/PyHyperNet.cpp +++ b/hurricane/src/isobar/PyHyperNet.cpp @@ -1,14 +1,13 @@ - // -*- C++ -*- // // This file is part of the Coriolis Software. -// Copyright (c) UPMC/LIP6 2007-2013, All Rights Reserved +// Copyright (c) UPMC 2007-2014, All Rights Reserved // // +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | -// | Author : Jean-Paul CHAPUT | +// | Author : Damien DUPUIS | // | E-mail : Jean-Paul.Chaput@asim.lip6.fr | // | =============================================================== | // | C++ Module : "./PyHyperNet.cpp" | @@ -19,7 +18,6 @@ #include "hurricane/isobar/PyCell.h" #include "hurricane/isobar/PyOccurrence.h" #include "hurricane/isobar/PyOccurrenceCollection.h" - using namespace Hurricane; @@ -44,6 +42,31 @@ extern "C" { DirectDestroyAttribute(PyHyperNet_destroy, PyHyperNet) + static PyObject* PyHyperNet_create ( PyObject*, PyObject *args ) { + trace << "PyHyperNet_create()" << endl; + + HyperNet* hyperNet = NULL; + PyObject* arg0; + + if (! ParseOneArg ( "HyperNet.create()", args, ":occur", &arg0 )) { + PyErr_SetString(ConstructorError, "invalid number of parameters for HyperNet constructor." ); + return ( NULL ); + } + + hyperNet = new HyperNet ( *PYOCCURRENCE_O(arg0) ); + + PyHyperNet* pyHyperNet; + pyHyperNet = PyObject_NEW(PyHyperNet, &PyTypeHyperNet); + if (pyHyperNet == NULL) return NULL; + + HTRY + pyHyperNet->_object = hyperNet; + HCATCH + + return ( (PyObject*)pyHyperNet ); + } + + static PyObject* PyHyperNet_getNetOccurrences(PyHyperNet *self) { trace << "PyHyperNet_getNetOccurrences()" << endl; @@ -106,7 +129,9 @@ extern "C" { PyMethodDef PyHyperNet_Methods[] = - { { "getCell" , (PyCFunction)PyHyperNet_getCell , METH_NOARGS , "Returns the hyperNet cell." } + { { "create" , (PyCFunction)PyHyperNet_create , METH_VARARGS|METH_STATIC + , "Create a new HyperNet." } + , { "getCell" , (PyCFunction)PyHyperNet_getCell , METH_NOARGS , "Returns the hyperNet cell." } , { "isValid" , (PyCFunction)PyHyperNet_isValid , METH_NOARGS , "Returns trus if the HyperNet isValid." } , { "getNetOccurrences" , (PyCFunction)PyHyperNet_getNetOccurrences , METH_NOARGS , "Returns the collection of Net occurrences" } @@ -122,7 +147,7 @@ extern "C" { PyTypeObjectLinkPyType(HyperNet) -#else // End of Python Module Code Part. +#else // Python Module Code Part. // +=================================================================+ @@ -130,36 +155,10 @@ extern "C" { // +=================================================================+ - PyObject* PyHyperNet_create ( PyObject *module, PyObject *args ) { - trace << "PyHyperNet_create()" << endl; - - HyperNet* hyperNet = NULL; - PyObject* arg0; - - if (! ParseOneArg ( "HyperNet.create()", args, ":occur", &arg0 )) { - PyErr_SetString(ConstructorError, "invalid number of parameters for HyperNet constructor." ); - return ( NULL ); - } - - hyperNet = new HyperNet ( *PYOCCURRENCE_O(arg0) ); - - PyHyperNet* pyHyperNet; - pyHyperNet = PyObject_NEW(PyHyperNet, &PyTypeHyperNet); - if (pyHyperNet == NULL) return NULL; - - HTRY - pyHyperNet->_object = hyperNet; - HCATCH - - return ( (PyObject*)pyHyperNet ); - } - - PyTypeObjectDefinitions(HyperNet) -#endif // End of Shared Library Code Part. - +#endif // Shared Library Code Part. } // extern "C". diff --git a/hurricane/src/isobar/PyInstance.cpp b/hurricane/src/isobar/PyInstance.cpp index d6e4d1ff..b016dcdc 100644 --- a/hurricane/src/isobar/PyInstance.cpp +++ b/hurricane/src/isobar/PyInstance.cpp @@ -1,22 +1,25 @@ -// x-----------------------------------------------------------------x -// | | +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | // | Author : Jean-Paul CHAPUT | -// | E-mail : Jean-Paul.Chaput@asim.lip6.fr | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Module : "./PyInstance.cpp" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Module : "./PyInstance.cpp" | +// +-----------------------------------------------------------------+ + #include "hurricane/isobar/PyBox.h" #include "hurricane/isobar/PyTransformation.h" #include "hurricane/isobar/PyLibrary.h" #include "hurricane/isobar/PyCell.h" #include "hurricane/isobar/PyInstance.h" +#include "hurricane/isobar/PyPlacementStatus.h" #include "hurricane/isobar/PyNet.h" #include "hurricane/isobar/PyPlug.h" #include "hurricane/isobar/PyPlugCollection.h" @@ -48,23 +51,6 @@ extern "C" { #if defined(__PYTHON_MODULE__) - // x-------------------------------------------------------------x - // | Global Constants Loading | - // x-------------------------------------------------------------x - - - extern void InstanceLoadConstants ( PyObject* dictionnary ) - { - PyObject* constant; - - LOAD_CONSTANT ( Instance::PlacementStatus::UNPLACED, "PlacementStatusUNPLACED" ) - LOAD_CONSTANT ( Instance::PlacementStatus::PLACED , "PlacementStatusPLACED" ) - LOAD_CONSTANT ( Instance::PlacementStatus::FIXED , "PlacementStatusFIXED" ) - } - - - - // x-------------------------------------------------------------x // | "PyInstance" Local Functions | // x-------------------------------------------------------------x @@ -93,18 +79,59 @@ extern "C" { // Standart Accessors (Attributes). - // Standart destroy (Attribute). DBoDestroyAttribute(PyInstance_destroy,PyInstance) - - - // --------------------------------------------------------------- // Attribute Method : "PyInstance_getName ()" GetNameMethod(Instance, instance) + // --------------------------------------------------------------- + // Attribute Method : "PyInstance_create ()" + + PyObject* PyInstance_create ( PyObject*, PyObject *args ) { + trace << "PyInstance_create ()" << endl; + + Instance* instance = NULL; + PyObject* arg0; + PyObject* arg1; + PyObject* arg2; + PyObject* arg3; + + HTRY + __cs.init ("Instance.create"); + if ( ! PyArg_ParseTuple(args,"O&O&O&|O&:Instance.new" + ,Converter,&arg0 + ,Converter,&arg1 + ,Converter,&arg2 + ,Converter,&arg3 + )) { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Instance constructor." ); + return NULL; + } + + if ( __cs.getObjectIds() == ":ent:string:ent") { + instance = Instance::create( + PYCELL_O(arg0), + Name(PyString_AsString(arg1)), + PYCELL_O(arg2) ); + } else if ( __cs.getObjectIds() == ":ent:string:ent:transfo") { + instance = Instance::create( + PYCELL_O(arg0), + Name(PyString_AsString(arg1)), + PYCELL_O(arg2), + *PYTRANSFORMATION_O(arg3), + Instance::PlacementStatus::PLACED); + } else { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Instance constructor." ); + return NULL; + } + HCATCH + + return PyInstance_Link ( instance ); + } + // --------------------------------------------------------------- // Attribute Method : "PyInstance_getMasterCell ()" @@ -341,24 +368,25 @@ extern "C" { // PyInstance Attribute Method table. PyMethodDef PyInstance_Methods[] = - { { "getName" , (PyCFunction)PyInstance_getName , METH_NOARGS , "Returns the instance name." } + { { "create" , (PyCFunction)PyInstance_create , METH_VARARGS|METH_STATIC + , "Create a new Instance." } + , { "getName" , (PyCFunction)PyInstance_getName , METH_NOARGS , "Returns the instance name." } , { "getMasterCell" , (PyCFunction)PyInstance_getMasterCell , METH_NOARGS , "Returns the cell model referenced by the instance." } , { "getTransformation" , (PyCFunction)PyInstance_getTransformation , METH_NOARGS , "Returns the transformation associated to the instance." } , { "getPlacementStatus" , (PyCFunction)PyInstance_getPlacementStatus , METH_NOARGS , "Returns the placement status of the instance." } , { "getPlug" , (PyCFunction)PyInstance_getPlug , METH_VARARGS, "Returns the plug associated to the if it exists or else NULL (if the net is not external)." } - , { "getPlugs" , (PyCFunction)PyInstance_getPlugs , METH_NOARGS , "Returns the collection of instance plugs." } - , { "getConnectedPlugs" , (PyCFunction)PyInstance_getConnectedPlugs , METH_NOARGS , "Returns the collection of instance plugs which are effectively connected." } - , { "getUnconnectedPlugs", (PyCFunction)PyInstance_getUnconnectedPlugs, METH_NOARGS , "Returns the collection of instance plugs which are not connected." } + , { "getPlugs" , (PyCFunction)PyInstance_getPlugs , METH_NOARGS , "Returns the collection of instance plugs." } + , { "getConnectedPlugs" , (PyCFunction)PyInstance_getConnectedPlugs , METH_NOARGS , "Returns the collection of instance plugs which are effectively connected." } + , { "getUnconnectedPlugs" , (PyCFunction)PyInstance_getUnconnectedPlugs , METH_NOARGS , "Returns the collection of instance plugs which are not connected." } , { "getAbutmentBox" , (PyCFunction)PyInstance_getAbutmentBox , METH_NOARGS , "Returns the abutment box of the instance, that is the abutment box of the master cell to which has been applied the instance transformation." } , { "isTerminal" , (PyCFunction)PyInstance_isTerminal , METH_NOARGS , "Returns true if the instance is a terminal instance." } , { "isLeaf" , (PyCFunction)PyInstance_isLeaf , METH_NOARGS , "Returns true if the instance is a leaf instance." } - , { "isBound" , (PyCFunction)PyInstance_isPyBound , METH_NOARGS, "Returns true if the instance is bounded to the hurricane instance" } + , { "isBound" , (PyCFunction)PyInstance_isPyBound , METH_NOARGS , "Returns true if the instance is bounded to the hurricane instance" } , { "setName" , (PyCFunction)PyInstance_setName , METH_VARARGS, "Allows to change the instance name." } , { "setTransformation" , (PyCFunction)PyInstance_setTransformation , METH_VARARGS, "Allows to modify the instance transformation." } , { "setPlacementStatus" , (PyCFunction)PyInstance_setPlacementStatus , METH_VARARGS, "Allows to modify the instance placement status." } , { "setMasterCell" , (PyCFunction)PyInstance_setMasterCell , METH_VARARGS, "Allows to change the cell referenced by this instance." } - , { "destroy" , (PyCFunction)PyInstance_destroy , METH_NOARGS - , "Destroy associated hurricane object The python object remains." } + , { "destroy" , (PyCFunction)PyInstance_destroy , METH_NOARGS , "Destroy associated hurricane object The python object remains." } , {NULL, NULL, 0, NULL} /* sentinel */ }; @@ -380,50 +408,6 @@ extern "C" { // | "PyInstance" Shared Library Code Part | // x=================================================================x - // --------------------------------------------------------------- - // Attribute Method : "PyInstance_new ()" - - PyObject* PyInstance_create ( PyObject *module, PyObject *args ) { - trace << "PyInstance_create ()" << endl; - - Instance* instance = NULL; - PyObject* arg0; - PyObject* arg1; - PyObject* arg2; - PyObject* arg3; - - HTRY - __cs.init ("Instance.create"); - if ( ! PyArg_ParseTuple(args,"O&O&O&|O&:Instance.new" - ,Converter,&arg0 - ,Converter,&arg1 - ,Converter,&arg2 - ,Converter,&arg3 - )) { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Instance constructor." ); - return NULL; - } - - if ( __cs.getObjectIds() == ":ent:string:ent") { - instance = Instance::create( - PYCELL_O(arg0), - Name(PyString_AsString(arg1)), - PYCELL_O(arg2) ); - } else if ( __cs.getObjectIds() == ":ent:string:ent:transfo") { - instance = Instance::create( - PYCELL_O(arg0), - Name(PyString_AsString(arg1)), - PYCELL_O(arg2), - *PYTRANSFORMATION_O(arg3), - Instance::PlacementStatus::PLACED); - } else { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Instance constructor." ); - return NULL; - } - HCATCH - - return PyInstance_Link ( instance ); - } // Link/Creation Method. @@ -436,6 +420,14 @@ extern "C" { PyTypeInheritedObjectDefinitions(Instance, Entity) + extern void PyInstance_postModuleInit () + { + PyPlacementStatus_postModuleInit(); + + PyDict_SetItemString( PyTypeInstance.tp_dict, "PlacementStatus", (PyObject*)&PyTypePlacementStatus ); + } + + #endif // End of Shared Library Code Part. diff --git a/hurricane/src/isobar/PyLibrary.cpp b/hurricane/src/isobar/PyLibrary.cpp index 4773e96c..37d2ccdd 100644 --- a/hurricane/src/isobar/PyLibrary.cpp +++ b/hurricane/src/isobar/PyLibrary.cpp @@ -1,8 +1,7 @@ - // -*- C++ -*- // // This file is part of the Coriolis Software. -// Copyright (c) UPMC/LIP6 2008-2013, All Rights Reserved +// Copyright (c) UPMC 2008-2014, All Rights Reserved // // +-----------------------------------------------------------------+ // | C O R I O L I S | @@ -40,6 +39,35 @@ extern "C" { GetNameMethod(Library, lib) + static PyObject* PyLibrary_create ( PyObject *, PyObject *args ) { + trace << "PyLibrary_create()" << endl; + + PyObject* arg0; + PyObject* arg1; + Library* library = NULL; + + HTRY + __cs.init ("Library.create"); + if (!PyArg_ParseTuple(args,"O&O&:Library.create", Converter, &arg0, Converter, &arg1)) { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Library constructor." ); + return NULL; + } + if (__cs.getObjectIds() == ":db:string") { + DataBase* db = PYDATABASE_O(arg0); + library = Library::create(db, Name(PyString_AsString(arg1))); + } else if (__cs.getObjectIds() == ":library:string") { + Library* masterLibrary = PYLIBRARY_O(arg0); + library = Library::create(masterLibrary, Name(PyString_AsString(arg1))); + } else { + PyErr_SetString( ConstructorError, "invalid number of parameters for Library constructor." ); + return NULL; + } + HCATCH + + return PyLibrary_Link( library ); + } + + static PyObject* PyLibrary_getSubLibrary ( PyLibrary *self, PyObject* args ) { trace << "PyLibrary_getLibrary ()" << endl; @@ -107,8 +135,9 @@ extern "C" { PyMethodDef PyLibrary_Methods[] = - { - { "getName" , (PyCFunction)PyLibrary_getName , METH_NOARGS , "Returns the name of the library." } + { { "create" , (PyCFunction)PyLibrary_create , METH_NOARGS|METH_STATIC + , "Creates a new library." } + , { "getName" , (PyCFunction)PyLibrary_getName , METH_NOARGS , "Returns the name of the library." } , { "getLibrary", (PyCFunction)PyLibrary_getSubLibrary, METH_VARARGS, "Get the sub-library named " } , { "getCell" , (PyCFunction)PyLibrary_getCell , METH_VARARGS, "Get the cell of name " } , { "getCells" , (PyCFunction)PyLibrary_getCells , METH_NOARGS , "Returns the collection of all cells of the library." } @@ -130,39 +159,8 @@ extern "C" { // +=================================================================+ - PyObject* PyLibrary_create ( PyObject *module, PyObject *args ) { - trace << "PyLibrary_create()" << endl; - - PyObject* arg0; - PyObject* arg1; - Library* library = NULL; - - HTRY - __cs.init ("Library.create"); - if (!PyArg_ParseTuple(args,"O&O&:Library.create", Converter, &arg0, Converter, &arg1)) { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Library constructor." ); - return NULL; - } - if (__cs.getObjectIds() == ":db:string") { - DataBase* db = PYDATABASE_O(arg0); - library = Library::create(db, Name(PyString_AsString(arg1))); - } else if (__cs.getObjectIds() == ":library:string") { - Library* masterLibrary = PYLIBRARY_O(arg0); - library = Library::create(masterLibrary, Name(PyString_AsString(arg1))); - } else { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Library constructor." ); - return NULL; - } - HCATCH - - return PyLibrary_Link ( library ); - } - - // Link/Creation Method. DBoLinkCreateMethod(Library) - - PyTypeObjectDefinitions(Library) diff --git a/hurricane/src/isobar/PyNet.cpp b/hurricane/src/isobar/PyNet.cpp index fae4db73..8fce246a 100644 --- a/hurricane/src/isobar/PyNet.cpp +++ b/hurricane/src/isobar/PyNet.cpp @@ -1,34 +1,33 @@ -// x-----------------------------------------------------------------x -// | | +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | -// | Author : Sophie BELLOEIL | -// | E-mail : Sophie.Belloeil@asim.lip6.fr | +// | Author : Sophie BELLOEIL | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Module : "./PyNet.cpp" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x - - +// | C++ Module : "./PyNet.cpp" | +// +-----------------------------------------------------------------+ #include "hurricane/isobar/PyNet.h" +#include "hurricane/isobar/PyNetType.h" +#include "hurricane/isobar/PyNetDirection.h" #include "hurricane/isobar/PyCell.h" #include "hurricane/isobar/PyPoint.h" #include "hurricane/isobar/PyPlugCollection.h" #include "hurricane/isobar/PySegmentCollection.h" #include "hurricane/isobar/PyComponentCollection.h" #include "hurricane/isobar/PyPinCollection.h" - #include "hurricane/Cell.h" #include "hurricane/NetExternalComponents.h" using namespace Hurricane; - namespace Isobar { @@ -93,35 +92,11 @@ extern "C" { } - - - // x-------------------------------------------------------------x - // | Global Constants Loading | - // x-------------------------------------------------------------x - - extern void NetLoadConstants ( PyObject* dictionnary ) { - PyObject* constant; - - LOAD_CONSTANT ( Net::Type::UNDEFINED , "TypeUNDEFINED" ) - LOAD_CONSTANT ( Net::Type::LOGICAL , "TypeLOGICAL" ) - LOAD_CONSTANT ( Net::Type::CLOCK , "TypeCLOCK" ) - LOAD_CONSTANT ( Net::Type::POWER , "TypePOWER" ) - LOAD_CONSTANT ( Net::Type::GROUND , "TypeGROUND" ) - LOAD_CONSTANT ( Net::Direction::UNDEFINED , "DirectionUNDEFINED" ) - LOAD_CONSTANT ( Net::Direction::IN , "DirectionIN" ) - LOAD_CONSTANT ( Net::Direction::OUT , "DirectionOUT" ) - LOAD_CONSTANT ( Net::Direction::INOUT , "DirectionINOUT" ) - LOAD_CONSTANT ( Net::Direction::TRISTATE , "DirectionTRISTATE" ) - } - - - // x-------------------------------------------------------------x // | "PyNet" Attribute Methods | // x-------------------------------------------------------------x - // Standart Accessors (Attributes). DirectGetLongAttribute(PyNet_getX,getX,PyNet,Net) DirectGetLongAttribute(PyNet_getY,getY,PyNet,Net) @@ -141,11 +116,33 @@ extern "C" { DBoDestroyAttribute(PyNet_destroy, PyNet) + // --------------------------------------------------------------- + // Attribute Method : "PyNet_getName ()" + + GetNameMethod(Net, net) // --------------------------------------------------------------- - // Attribute Method : "PyNet_getName ()" - GetNameMethod(Net, net) + // Attribute Method : "PyNet_create ()" + + static PyObject* PyNet_create ( PyObject*, PyObject *args ) { + trace << "PyNet_create()" << endl; + + char* name = NULL; + PyCell* pyCell = NULL; + Net* net = NULL; + + HTRY + if (PyArg_ParseTuple(args,"O!s:Net.create", &PyTypeCell, &pyCell, &name)) { + net = Net::create(PYCELL_O(pyCell), Name(name)); + } else { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Net constructor." ); + return NULL; + } + HCATCH + + return PyNet_Link(net); + } // --------------------------------------------------------------- @@ -449,7 +446,9 @@ extern "C" { // PyNet Attribute Method table. PyMethodDef PyNet_Methods[] = - { { "getName" , (PyCFunction)PyNet_getName , METH_NOARGS , "Returns the net name." } + { { "create" , (PyCFunction)PyNet_create , METH_VARARGS|METH_STATIC + , "Create a new Net." } + , { "getName" , (PyCFunction)PyNet_getName , METH_NOARGS , "Returns the net name." } , { "getType" , (PyCFunction)PyNet_getType , METH_NOARGS , "Returns the signal type (by default set to UNDEFINED)." } , { "getDirection" , (PyCFunction)PyNet_getDirection , METH_NOARGS , "Returns the signal direction (by default set to UNDEFINED)." } , { "getX" , (PyCFunction)PyNet_getX , METH_NOARGS , "Returns net abscissa." } @@ -497,48 +496,22 @@ extern "C" { // x=================================================================x - // --------------------------------------------------------------- - // Attribute Method : "PyNet_create ()" - - PyObject* PyNet_create ( PyObject *module, PyObject *args ) { - trace << "PyNet_create()" << endl; - - char* name = NULL; - PyCell* pyCell = NULL; - Net* net = NULL; - - HTRY - if (PyArg_ParseTuple(args,"O!s:Net.create", &PyTypeCell, &pyCell, &name)) { - net = Net::create(PYCELL_O(pyCell), Name(name)); - } else { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Net constructor." ); - return NULL; - } - HCATCH - - return PyNet_Link(net); - } - - - - // Link/Creation Method. DBoLinkCreateMethod(Net) - - - - - // --------------------------------------------------------------- - // PyNet Object Definitions. - PyTypeInheritedObjectDefinitions(Net, Entity) -# endif // End of Shared Library Code Part. + extern void PyNet_postModuleInit () + { + PyNetType_postModuleInit(); + PyNetDirection_postModuleInit(); + + PyDict_SetItemString( PyTypeNet.tp_dict, "Type" , (PyObject*)&PyTypeNetType ); + PyDict_SetItemString( PyTypeNet.tp_dict, "Direction", (PyObject*)&PyTypeNetDirection ); + } -} // End of extern "C". +# endif // Shared Library Code Part. +} // extern "C". - - -} // End of Isobar namespace. +} // Isobar namespace. diff --git a/hurricane/src/isobar/PyNetDirection.cpp b/hurricane/src/isobar/PyNetDirection.cpp new file mode 100644 index 00000000..7fa93829 --- /dev/null +++ b/hurricane/src/isobar/PyNetDirection.cpp @@ -0,0 +1,110 @@ +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2014-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ +// | C O R I O L I S | +// | I s o b a r - Hurricane / Python Interface | +// | | +// | Author : Jean-Paul CHAPUT | +// | E-mail : Jean-Paul.Chaput@lip6.fr | +// | =============================================================== | +// | C++ Module : "./PyNetDirection.h" | +// +-----------------------------------------------------------------+ + + +#include "hurricane/isobar/PyNetDirection.h" + + +namespace Isobar { + + using std::cerr; + using std::endl; + using std::hex; + using std::ostringstream; + using Hurricane::tab; + using Hurricane::in_trace; + using Hurricane::Error; + using Hurricane::Warning; + using Isobar::ProxyProperty; + using Isobar::ProxyError; + using Isobar::ConstructorError; + using Isobar::HurricaneError; + using Isobar::HurricaneWarning; + using Isobar::ParseOneArg; + using Isobar::ParseTwoArg; + + +extern "C" { + + +#define METHOD_HEAD(function) GENERIC_METHOD_HEAD(NetDirection,netDirection,function) + + +// +=================================================================+ +// | "PyNetDirection" Python Module Code Part | +// +=================================================================+ + +#if defined(__PYTHON_MODULE__) + + + // Standart Accessors (Attributes). + + + // Standart Destroy (Attribute). + // DBoDestroyAttribute(PyNetDirection_destroy,PyNetDirection) + + + PyMethodDef PyNetDirection_Methods[] = + { {NULL, NULL, 0, NULL} /* sentinel */ + }; +//PyTypeObjectLinkPyType(Transformation::NetDirection) + + + PythonOnlyDeleteMethod(NetDirection) + DirectReprMethod(PyNetDirection_Repr, PyNetDirection, Net::Direction) + DirectStrMethod (PyNetDirection_Str, PyNetDirection, Net::Direction) + DirectCmpMethod (PyNetDirection_Cmp, IsPyNetDirection, PyNetDirection) + DirectHashMethod(PyNetDirection_Hash, PyNetDirection) + + extern void PyNetDirection_LinkPyType() { + trace << "PyNetDirection_LinkType()" << endl; + PyTypeNetDirection.tp_dealloc = (destructor) PyNetDirection_DeAlloc; + PyTypeNetDirection.tp_compare = (cmpfunc) PyNetDirection_Cmp; + PyTypeNetDirection.tp_repr = (reprfunc) PyNetDirection_Repr; + PyTypeNetDirection.tp_str = (reprfunc) PyNetDirection_Str; + PyTypeNetDirection.tp_hash = (hashfunc) PyNetDirection_Hash; + PyTypeNetDirection.tp_methods = PyNetDirection_Methods; + } + + +#else // End of Python Module Code Part. + + +// +=================================================================+ +// | "PyNetDirection" Shared Library Code Part | +// +=================================================================+ + + // Link/Creation Method. + PyTypeObjectDefinitions(NetDirection) + + + extern void PyNetDirection_postModuleInit () + { + PyObject* constant; + + LoadObjectConstant(PyTypeNetDirection.tp_dict,Net::Direction::UNDEFINED,"UNDEFINED"); + LoadObjectConstant(PyTypeNetDirection.tp_dict,Net::Direction::IN ,"IN"); + LoadObjectConstant(PyTypeNetDirection.tp_dict,Net::Direction::OUT ,"OUT"); + LoadObjectConstant(PyTypeNetDirection.tp_dict,Net::Direction::INOUT ,"INOUT"); + LoadObjectConstant(PyTypeNetDirection.tp_dict,Net::Direction::TRISTATE ,"TRISTATE"); + } + + +#endif // Shared Library Code Part. + +} // extern "C". + +} // Isobar namespace. + diff --git a/hurricane/src/isobar/PyNetType.cpp b/hurricane/src/isobar/PyNetType.cpp new file mode 100644 index 00000000..6b2e9f3c --- /dev/null +++ b/hurricane/src/isobar/PyNetType.cpp @@ -0,0 +1,109 @@ +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2014-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ +// | C O R I O L I S | +// | I s o b a r - Hurricane / Python Interface | +// | | +// | Author : Jean-Paul CHAPUT | +// | E-mail : Jean-Paul.Chaput@lip6.fr | +// | =============================================================== | +// | C++ Module : "./PyNetType.h" | +// +-----------------------------------------------------------------+ + + +#include "hurricane/isobar/PyNetType.h" + + +namespace Isobar { + + using std::cerr; + using std::endl; + using std::hex; + using std::ostringstream; + using Hurricane::tab; + using Hurricane::in_trace; + using Hurricane::Error; + using Hurricane::Warning; + using Isobar::ProxyProperty; + using Isobar::ProxyError; + using Isobar::ConstructorError; + using Isobar::HurricaneError; + using Isobar::HurricaneWarning; + using Isobar::ParseOneArg; + using Isobar::ParseTwoArg; + + +extern "C" { + + +#define METHOD_HEAD(function) GENERIC_METHOD_HEAD(NetType,catalog,function) + + +// +=================================================================+ +// | "PyNetType" Python Module Code Part | +// +=================================================================+ + +#if defined(__PYTHON_MODULE__) + + + // Standart Accessors (Attributes). + + + // Standart Destroy (Attribute). + // DBoDestroyAttribute(PyNetType_destroy,PyNetType) + + + PyMethodDef PyNetType_Methods[] = + { {NULL, NULL, 0, NULL} /* sentinel */ + }; + + + PythonOnlyDeleteMethod(NetType) + DirectReprMethod(PyNetType_Repr, PyNetType, Net::Type) + DirectStrMethod (PyNetType_Str, PyNetType, Net::Type) + DirectCmpMethod (PyNetType_Cmp, IsPyNetType, PyNetType) + DirectHashMethod(PyNetType_Hash, PyNetType) + + extern void PyNetType_LinkPyType() { + trace << "PyNetType_LinkType()" << endl; + PyTypeNetType.tp_dealloc = (destructor) PyNetType_DeAlloc; + PyTypeNetType.tp_compare = (cmpfunc) PyNetType_Cmp; + PyTypeNetType.tp_repr = (reprfunc) PyNetType_Repr; + PyTypeNetType.tp_str = (reprfunc) PyNetType_Str; + PyTypeNetType.tp_hash = (hashfunc) PyNetType_Hash; + PyTypeNetType.tp_methods = PyNetType_Methods; + } + + +#else // End of Python Module Code Part. + + +// +=================================================================+ +// | "PyNetType" Shared Library Code Part | +// +=================================================================+ + + // Link/Creation Method. + PyTypeObjectDefinitions(NetType) + + + extern void PyNetType_postModuleInit () + { + PyObject* constant; + + LoadObjectConstant(PyTypeNetType.tp_dict,Net::Type::UNDEFINED,"UNDEFINED"); + LoadObjectConstant(PyTypeNetType.tp_dict,Net::Type::LOGICAL ,"LOGICAL" ); + LoadObjectConstant(PyTypeNetType.tp_dict,Net::Type::CLOCK ,"CLOCK" ); + LoadObjectConstant(PyTypeNetType.tp_dict,Net::Type::POWER ,"POWER" ); + LoadObjectConstant(PyTypeNetType.tp_dict,Net::Type::GROUND ,"GROUND" ); + } + + +#endif // Shared Library Code Part. + +} // extern "C". + +} // Isobar namespace. + diff --git a/hurricane/src/isobar/PyOccurrence.cpp b/hurricane/src/isobar/PyOccurrence.cpp index 04cdf908..d218b7f2 100644 --- a/hurricane/src/isobar/PyOccurrence.cpp +++ b/hurricane/src/isobar/PyOccurrence.cpp @@ -58,6 +58,53 @@ extern "C" { DirectDestroyAttribute(PyOccurrence_destroy, PyOccurrence) + // --------------------------------------------------------------- + // Attribute Method : "PyOccurrence_NEW ()" + + PyObject* PyOccurrence_NEW ( PyObject *module, PyObject *args ) { + trace << "PyOccurrence_NEW()" << endl; + + Occurrence* occurrence; + PyObject* arg0; + PyObject* arg1; + + __cs.init ("Occurrence.Occurrence"); + if ( ! PyArg_ParseTuple(args,"|O&O&:Occurrence.Occurrence" + ,Converter,&arg0 + ,Converter,&arg1 + )) { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Occurrence constructor. " ); + return NULL; + } + + PyOccurrence* pyOccurrence = NULL; + HTRY + if ( __cs.getObjectIds() == NO_ARG ) { occurrence = new Occurrence (); } + else if ( __cs.getObjectIds() == ENT_ARG ) { occurrence = new Occurrence ( PYENTITY_O(arg0) ); } + else if ( __cs.getObjectIds() == COMP_PATH_ARG) { occurrence = new Occurrence ( PYSEGMENT_O(arg0) + , *PYPATH_O(arg1) ); } + else if ( __cs.getObjectIds() == ENT_PATH_ARG ) { occurrence = new Occurrence ( PYENTITY_O(arg0) + , *PYPATH_O(arg1) ); } + else { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Occurrence constructor. " ); + return ( NULL ); + } + + pyOccurrence = PyObject_NEW(PyOccurrence, &PyTypeOccurrence); + if (pyOccurrence == NULL) return NULL; + + pyOccurrence->_object = occurrence; + HCATCH + + return ( (PyObject*)pyOccurrence ); + } + + + static int PyOccurrence_Init ( PyOccurrence* self, PyObject* args, PyObject* kwargs ) + { + trace << "PyOccurrence_Init(): " << (void*)self << endl; + return 0; + } // --------------------------------------------------------------- @@ -195,7 +242,8 @@ extern "C" { DirectDeleteMethod(PyOccurrence_DeAlloc,PyOccurrence) - PyTypeObjectLinkPyType(Occurrence) + PyTypeObjectLinkPyTypeNewInit(Occurrence) +//PyTypeObjectLinkPyType(Occurrence) #else // End of Python Module Code Part. @@ -205,47 +253,6 @@ extern "C" { // | "PyOccurrence" Shared Library Code Part | // x=================================================================x - // --------------------------------------------------------------- - // Attribute Method : "PyOccurrence_create ()" - - PyObject* PyOccurrence_create ( PyObject *module, PyObject *args ) { - trace << "PyOccurrence_create()" << endl; - - Occurrence* occurrence; - PyObject* arg0; - PyObject* arg1; - - __cs.init ("Occurrence.create"); - if ( ! PyArg_ParseTuple(args,"|O&O&:Occurrence.create" - ,Converter,&arg0 - ,Converter,&arg1 - )) { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Occurrence constructor. " ); - return NULL; - } - - PyOccurrence* pyOccurrence = NULL; - HTRY - if ( __cs.getObjectIds() == NO_ARG ) { occurrence = new Occurrence (); } - else if ( __cs.getObjectIds() == ENT_ARG ) { occurrence = new Occurrence ( PYENTITY_O(arg0) ); } - else if ( __cs.getObjectIds() == COMP_PATH_ARG) { occurrence = new Occurrence ( PYSEGMENT_O(arg0) - , *PYPATH_O(arg1) ); } - else if ( __cs.getObjectIds() == ENT_PATH_ARG ) { occurrence = new Occurrence ( PYENTITY_O(arg0) - , *PYPATH_O(arg1) ); } - else { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Occurrence constructor. " ); - return ( NULL ); - } - - pyOccurrence = PyObject_NEW(PyOccurrence, &PyTypeOccurrence); - if (pyOccurrence == NULL) return NULL; - - pyOccurrence->_object = occurrence; - HCATCH - - return ( (PyObject*)pyOccurrence ); - } - // --------------------------------------------------------------- diff --git a/hurricane/src/isobar/PyOrientation.cpp b/hurricane/src/isobar/PyOrientation.cpp new file mode 100644 index 00000000..ef121364 --- /dev/null +++ b/hurricane/src/isobar/PyOrientation.cpp @@ -0,0 +1,117 @@ +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2014-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ +// | C O R I O L I S | +// | I s o b a r - Hurricane / Python Interface | +// | | +// | Author : Jean-Paul CHAPUT | +// | E-mail : Jean-Paul.Chaput@lip6.fr | +// | =============================================================== | +// | C++ Module : "./PyOrientation.h" | +// +-----------------------------------------------------------------+ + + +#include "hurricane/isobar/PyOrientation.h" + + +namespace Isobar { + + using std::cerr; + using std::endl; + using std::hex; + using std::ostringstream; + using Hurricane::tab; + using Hurricane::in_trace; + using Hurricane::Error; + using Hurricane::Warning; + using Isobar::ProxyProperty; + using Isobar::ProxyError; + using Isobar::ConstructorError; + using Isobar::HurricaneError; + using Isobar::HurricaneWarning; + using Isobar::ParseOneArg; + using Isobar::ParseTwoArg; + + +extern "C" { + + +#define METHOD_HEAD(function) GENERIC_METHOD_HEAD(Orientation,catalog,function) + + +// +=================================================================+ +// | "PyOrientation" Python Module Code Part | +// +=================================================================+ + +#if defined(__PYTHON_MODULE__) + + + // Standart Accessors (Attributes). + + + // Standart Destroy (Attribute). + // DBoDestroyAttribute(PyOrientation_destroy,PyOrientation) + + + PyMethodDef PyOrientation_Methods[] = + { {NULL, NULL, 0, NULL} /* sentinel */ + }; + + +//PythonOnlyDeleteMethod(Transformation::Orientation) +//PyTypeObjectLinkPyType(Transformation::Orientation) + + + PythonOnlyDeleteMethod(Orientation) + + DirectReprMethod(PyOrientation_Repr, PyOrientation, Transformation::Orientation) + DirectStrMethod (PyOrientation_Str, PyOrientation, Transformation::Orientation) + DirectCmpMethod (PyOrientation_Cmp, IsPyOrientation, PyOrientation) + DirectHashMethod(PyOrientation_Hash, PyOrientation) + + extern void PyOrientation_LinkPyType() { + trace << "PyOrientation_LinkType()" << endl; + PyTypeOrientation.tp_dealloc = (destructor) PyOrientation_DeAlloc; + PyTypeOrientation.tp_compare = (cmpfunc) PyOrientation_Cmp; + PyTypeOrientation.tp_repr = (reprfunc) PyOrientation_Repr; + PyTypeOrientation.tp_str = (reprfunc) PyOrientation_Str; + PyTypeOrientation.tp_hash = (hashfunc) PyOrientation_Hash; + PyTypeOrientation.tp_methods = PyOrientation_Methods; + } + + +#else // End of Python Module Code Part. + + +// +=================================================================+ +// | "PyOrientation" Shared Library Code Part | +// +=================================================================+ + + // Link/Creation Method. + PyTypeObjectDefinitions(Orientation) + + + extern void PyOrientation_postModuleInit () + { + PyObject* constant; + + LoadObjectConstant(PyTypeOrientation.tp_dict,Transformation::Orientation::ID,"ID"); + LoadObjectConstant(PyTypeOrientation.tp_dict,Transformation::Orientation::R1,"R1"); + LoadObjectConstant(PyTypeOrientation.tp_dict,Transformation::Orientation::R2,"R2"); + LoadObjectConstant(PyTypeOrientation.tp_dict,Transformation::Orientation::R3,"R3"); + LoadObjectConstant(PyTypeOrientation.tp_dict,Transformation::Orientation::MX,"MX"); + LoadObjectConstant(PyTypeOrientation.tp_dict,Transformation::Orientation::XR,"XR"); + LoadObjectConstant(PyTypeOrientation.tp_dict,Transformation::Orientation::MY,"MY"); + LoadObjectConstant(PyTypeOrientation.tp_dict,Transformation::Orientation::YR,"YR"); + } + + +#endif // Shared Library Code Part. + +} // extern "C". + +} // Isobar namespace. + diff --git a/hurricane/src/isobar/PyPad.cpp b/hurricane/src/isobar/PyPad.cpp index db1f6b79..1e904c0b 100644 --- a/hurricane/src/isobar/PyPad.cpp +++ b/hurricane/src/isobar/PyPad.cpp @@ -1,3 +1,19 @@ +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ +// | C O R I O L I S | +// | I s o b a r - Hurricane / Python Interface | +// | | +// | Author : Jean-Paul CHAPUT | +// | E-mail : Jean-Paul.Chaput@lip6.fr | +// | =============================================================== | +// | C++ Module : "./PyPad.cpp" | +// +-----------------------------------------------------------------+ + + #include "hurricane/isobar/PyNet.h" #include "hurricane/isobar/PyLayer.h" #include "hurricane/isobar/PyBox.h" @@ -26,7 +42,7 @@ extern "C" { // x-------------------------------------------------------------x - // | "PyPad" Attribute Methods | + // | "PyPad" Attribute Methods | // x-------------------------------------------------------------x @@ -37,6 +53,40 @@ extern "C" { // Standard Destroy (Attribute). DBoDestroyAttribute(PyPad_destroy, PyPad) + // --------------------------------------------------------------- + // Attribute Method : "PyPad_create ()" + + static PyObject* PyPad_create ( PyObject*, PyObject *args ) { + trace << "PyPad_create()" << endl; + + PyObject* arg0; + PyObject* arg1; + PyObject* arg2; + Pad* pad = NULL; + + HTRY + __cs.init ("Pad.create"); + if (!PyArg_ParseTuple(args,"O&O&O&:Pad.create" + ,Converter,&arg0 + ,Converter,&arg1 + ,Converter,&arg2 + )) { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Pad constructor." ); + return NULL; + } + + if ( __cs.getObjectIds() == ":ent:layer:box") { + pad = Pad::create(PYNET_O(arg0), PYLAYER_O(arg1), *PYBOX_O(arg2)); + } else { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Pad constructor." ); + return NULL; + } + + HCATCH + + return PyPad_Link(pad); + } + // --------------------------------------------------------------- // Attribute Method : "PyPad_getBoundingBox ()" @@ -100,14 +150,16 @@ extern "C" { // PyPad Attribute Method table. PyMethodDef PyPad_Methods[] = - { { "getX" , (PyCFunction)PyPad_getX , METH_NOARGS, "Return the Pad X value." } - , { "getY" , (PyCFunction)PyPad_getY , METH_NOARGS, "Return the Pad Y value." } - , { "getBoundingBox" , (PyCFunction)PyPad_getBoundingBox, METH_NOARGS, "Return the Pad Bounding Box." } - , { "setBoundingBox" , (PyCFunction)PyPad_setBoundingBox, METH_VARARGS, "Sets the Pad Bounding Box." } - , { "translate" , (PyCFunction)PyPad_translate , METH_VARARGS, "Translates the Pad of dx and dy." } - , { "destroy" , (PyCFunction)PyPad_destroy , METH_NOARGS - , "Destroy associated hurricane object, the python object remains." } - , {NULL, NULL, 0, NULL} /* sentinel */ + { { "create" , (PyCFunction)PyPad_create , METH_VARARGS|METH_STATIC + , "Create a new Pad." } + , { "getX" , (PyCFunction)PyPad_getX , METH_NOARGS, "Return the Pad X value." } + , { "getY" , (PyCFunction)PyPad_getY , METH_NOARGS, "Return the Pad Y value." } + , { "getBoundingBox", (PyCFunction)PyPad_getBoundingBox, METH_NOARGS, "Return the Pad Bounding Box." } + , { "setBoundingBox", (PyCFunction)PyPad_setBoundingBox, METH_VARARGS, "Sets the Pad Bounding Box." } + , { "translate" , (PyCFunction)PyPad_translate , METH_VARARGS, "Translates the Pad of dx and dy." } + , { "destroy" , (PyCFunction)PyPad_destroy , METH_NOARGS + , "Destroy associated hurricane object, the python object remains." } + , {NULL, NULL, 0, NULL} /* sentinel */ }; @@ -127,55 +179,14 @@ extern "C" { // | "PyPad" Shared Library Code Part | // x=================================================================x - // --------------------------------------------------------------- - // Attribute Method : "PyPad_new ()" - - PyObject* PyPad_create ( PyObject *module, PyObject *args ) { - trace << "PyPad_create()" << endl; - - PyObject* arg0; - PyObject* arg1; - PyObject* arg2; - Pad* pad = NULL; - - HTRY - __cs.init ("Pad.create"); - if (!PyArg_ParseTuple(args,"O&O&O&:Pad.create" - ,Converter,&arg0 - ,Converter,&arg1 - ,Converter,&arg2 - )) { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Pad constructor." ); - return NULL; - } - - if ( __cs.getObjectIds() == ":ent:layer:box") { - pad = Pad::create(PYNET_O(arg0), PYLAYER_O(arg1), *PYBOX_O(arg2)); - } else { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Pad constructor." ); - return NULL; - } - - HCATCH - - return PyPad_Link(pad); - } - // Link/Creation Method. DBoLinkCreateMethod(Pad) - - - // --------------------------------------------------------------- - // PyPad Object Definitions. - - PyTypeInheritedObjectDefinitions(Pad, Component) -#endif // End of Shared Library Code Part. +#endif // Shared Library Code Part. - -} // End of extern "C". +} // extern "C". diff --git a/hurricane/src/isobar/PyPath.cpp b/hurricane/src/isobar/PyPath.cpp index b8ff9e76..1b43ea97 100644 --- a/hurricane/src/isobar/PyPath.cpp +++ b/hurricane/src/isobar/PyPath.cpp @@ -1,16 +1,18 @@ -// x-----------------------------------------------------------------x -// | | +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | // | Author : Jean-Paul CHAPUT | -// | E-mail : Jean-Paul.Chaput@asim.lip6.fr | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Module : "./PyPath.cpp" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Module : "./PyPath.cpp" | +// +-----------------------------------------------------------------+ + #include "hurricane/isobar/PyTransformation.h" #include "hurricane/isobar/PyPath.h" @@ -52,6 +54,57 @@ extern "C" { DirectDestroyAttribute(PyPath_destroy, PyPath) + // --------------------------------------------------------------- + // Attribute Method : "PyPath_NEW ()" + + static PyObject* PyPath_NEW ( PyObject *module, PyObject *args ) { + trace << "PyPath_NEW()" << endl; + + Path* path = NULL; + PyObject* arg0 = NULL; + PyObject* arg1 = NULL; + PyPath* pyPath = NULL; + + __cs.init ("Path.Path"); + if ( ! PyArg_ParseTuple(args,"|O&O&:Path.Path" + ,Converter,&arg0 + ,Converter,&arg1 + )) { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Path constructor." ); + return NULL; + } + + HTRY + + if ( __cs.getObjectIds() == NO_ARG ) { path = new Path (); } + else if ( __cs.getObjectIds() == INST_ARG ) { path = new Path ( PYINSTANCE_O(arg0) ); } + else if ( __cs.getObjectIds() == INST_PATH_ARG ) { path = new Path ( PYINSTANCE_O(arg0) + , *PYPATH_O(arg1) ); } + else if ( __cs.getObjectIds() == PATH_INST_ARG ) { path = new Path ( *PYPATH_O(arg0) + , PYINSTANCE_O(arg1) ); } + else if ( __cs.getObjectIds() == CELL_STRING_ARG ) { path = new Path ( PYCELL_O(arg0) + , PyString_AsString(arg1) ); } + else { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Path constructor." ); + return ( NULL ); + } + + pyPath = PyObject_NEW(PyPath, &PyTypePath); + if (pyPath == NULL) return NULL; + + pyPath->_object = path; + + HCATCH + + return ( (PyObject*)pyPath ); + } + + + static int PyPath_Init ( PyPath* self, PyObject* args, PyObject* kwargs ) + { + trace << "PyPath_Init(): " << (void*)self << endl; + return 0; + } // --------------------------------------------------------------- @@ -260,7 +313,8 @@ extern "C" { // x-------------------------------------------------------------x DirectDeleteMethod(PyPath_DeAlloc,PyPath) - PyTypeObjectLinkPyType(Path) + PyTypeObjectLinkPyTypeNewInit(Path) +//PyTypeObjectLinkPyType(Path) # else // End of Python Module Code Part. @@ -270,51 +324,6 @@ extern "C" { // | "PyPath" Shared Library Code Part | // x=================================================================x - // --------------------------------------------------------------- - // Attribute Method : "PyPath_create ()" - - PyObject* PyPath_create ( PyObject *module, PyObject *args ) { - trace << "PyPath_create()" << endl; - - Path* path = NULL; - PyObject* arg0 = NULL; - PyObject* arg1 = NULL; - PyPath* pyPath = NULL; - - __cs.init ("Path.create"); - if ( ! PyArg_ParseTuple(args,"|O&O&:Path.create" - ,Converter,&arg0 - ,Converter,&arg1 - )) { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Path constructor." ); - return NULL; - } - - HTRY - - if ( __cs.getObjectIds() == NO_ARG ) { path = new Path (); } - else if ( __cs.getObjectIds() == INST_ARG ) { path = new Path ( PYINSTANCE_O(arg0) ); } - else if ( __cs.getObjectIds() == INST_PATH_ARG ) { path = new Path ( PYINSTANCE_O(arg0) - , *PYPATH_O(arg1) ); } - else if ( __cs.getObjectIds() == PATH_INST_ARG ) { path = new Path ( *PYPATH_O(arg0) - , PYINSTANCE_O(arg1) ); } - else if ( __cs.getObjectIds() == CELL_STRING_ARG ) { path = new Path ( PYCELL_O(arg0) - , PyString_AsString(arg1) ); } - else { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Path constructor." ); - return ( NULL ); - } - - pyPath = PyObject_NEW(PyPath, &PyTypePath); - if (pyPath == NULL) return NULL; - - pyPath->_object = path; - - HCATCH - - return ( (PyObject*)pyPath ); - } - // --------------------------------------------------------------- // PyPath Object Definitions. diff --git a/hurricane/src/isobar/PyPin.cpp b/hurricane/src/isobar/PyPin.cpp index c0b8739f..66af029f 100644 --- a/hurricane/src/isobar/PyPin.cpp +++ b/hurricane/src/isobar/PyPin.cpp @@ -1,25 +1,28 @@ -// x-----------------------------------------------------------------x -// | | +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | // | Author : Damien DUPUIS | -// | E-mail : Damien.Dupuis@asim.lip6.fr | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Module : "./PyPin.cpp" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Module : "./PyPin.cpp" | +// +-----------------------------------------------------------------+ + #include "hurricane/isobar/PyPin.h" +#include "hurricane/isobar/PyPinPlacementStatus.h" +#include "hurricane/isobar/PyPinDirection.h" #include "hurricane/isobar/PyNet.h" #include "hurricane/isobar/PyLayer.h" namespace Isobar { - using namespace Hurricane; extern "C" { @@ -37,71 +40,12 @@ extern "C" { // x=================================================================x #if defined(__PYTHON_MODULE__) - - // x-------------------------------------------------------------x - // | Global Constants Loading | - // x-------------------------------------------------------------x - - - extern void PinLoadConstants ( PyObject* dictionnary ) { - PyObject* constant; - - LOAD_CONSTANT ( Pin::PlacementStatus::UNPLACED , "PinPlacementStatusUNPLACED" ) - LOAD_CONSTANT ( Pin::PlacementStatus::PLACED , "PinPlacementStatusPLACED" ) - LOAD_CONSTANT ( Pin::PlacementStatus::FIXED , "PinPlacementStatusFIXED" ) - LOAD_CONSTANT ( Pin::AccessDirection::UNDEFINED, "PinAccessDirectionUNDEFINED" ) - LOAD_CONSTANT ( Pin::AccessDirection::NORTH , "PinAccessDirectionNORTH" ) - LOAD_CONSTANT ( Pin::AccessDirection::SOUTH , "PinAccessDirectionSOUTH" ) - LOAD_CONSTANT ( Pin::AccessDirection::EAST , "PinAccessDirectionEAST" ) - LOAD_CONSTANT ( Pin::AccessDirection::WEST , "PinAccessDirectionWEST" ) - } - // x-------------------------------------------------------------x // | "PyPin" Attribute Methods | // x-------------------------------------------------------------x - - // Standart Accessors (Attributes). - - PyObject* PyPin_getAccessDirection( PyPin* self ) { - trace << "PyNet_getAccessDirection ()" << endl; - - METHOD_HEAD ( "Net.getAccessDirection()" ) - - return (PyObject *)Py_BuildValue("l", pin->getAccessDirection().getCode() ); - - } - - - // --------------------------------------------------------------- - // PyPin Attribute Method table. - - PyMethodDef PyPin_Methods[] = - { { "getAccessDirection" , (PyCFunction)PyPin_getAccessDirection , METH_NOARGS - , "Returns the pin accessdirection (by default set to UNDEFINED) ." } - , {NULL, NULL, 0, NULL} /* sentinel */ - }; - - - - - // x-------------------------------------------------------------x - // | "PyPin" Object Methods | - // x-------------------------------------------------------------x - - - DBoDeleteMethod(Pin) - PyTypeObjectLinkPyType(Pin) - - -#else // End of Python Module Code Part. - - -// x=================================================================x -// | "PyPin" Shared Library Code Part | -// x=================================================================x static Pin::PlacementStatus PyInt_AsPlacementStatus ( PyObject* object ) { switch ( PyInt_AsLong(object) ) { @@ -113,6 +57,7 @@ extern "C" { return ( Pin::PlacementStatus(Pin::PlacementStatus::UNPLACED) ); } + static Pin::AccessDirection PyInt_AsAccessDirection ( PyObject* object ) { switch ( PyInt_AsLong(object) ) { case Pin::AccessDirection::UNDEFINED : return ( Pin::AccessDirection(Pin::AccessDirection::UNDEFINED) ); @@ -125,10 +70,11 @@ extern "C" { return ( Pin::AccessDirection(Pin::AccessDirection::UNDEFINED) ); } + // --------------------------------------------------------------- // Attribute Method : "PyPin_create ()" - PyObject* PyPin_create ( PyObject *module, PyObject *args ) { + static PyObject* PyPin_create ( PyObject*, PyObject *args ) { Pin* pin = NULL; HTRY @@ -201,20 +147,67 @@ extern "C" { return PyPin_Link ( pin ); } + + + // Standart Accessors (Attributes). + + PyObject* PyPin_getAccessDirection( PyPin* self ) { + trace << "PyNet_getAccessDirection ()" << endl; + + METHOD_HEAD ( "Net.getAccessDirection()" ) + + return (PyObject *)Py_BuildValue("l", pin->getAccessDirection().getCode() ); + + } + + + // --------------------------------------------------------------- + // PyPin Attribute Method table. + + PyMethodDef PyPin_Methods[] = + { { "create" , (PyCFunction)PyPin_create , METH_VARARGS|METH_STATIC + , "Create a new Pin." } + , { "getAccessDirection" , (PyCFunction)PyPin_getAccessDirection , METH_NOARGS + , "Returns the pin accessdirection (by default set to UNDEFINED) ." } + , {NULL, NULL, 0, NULL} /* sentinel */ + }; + + + + + // x-------------------------------------------------------------x + // | "PyPin" Object Methods | + // x-------------------------------------------------------------x + + + DBoDeleteMethod(Pin) + PyTypeObjectLinkPyType(Pin) + + +#else // End of Python Module Code Part. + + +// x=================================================================x +// | "PyPin" Shared Library Code Part | +// x=================================================================x // Link/Creation Method. DBoLinkCreateMethod(Pin) - - - - - // --------------------------------------------------------------- - // PyPin Object Definitions. - PyTypeInheritedObjectDefinitions(Pin, Contact) + + extern void PyPin_postModuleInit () + { + PyPinPlacementStatus_postModuleInit(); + PyPinDirection_postModuleInit(); + + PyDict_SetItemString( PyTypePin.tp_dict, "PlacementStatus", (PyObject*)&PyTypePinPlacementStatus ); + PyDict_SetItemString( PyTypePin.tp_dict, "Direction" , (PyObject*)&PyTypePinDirection ); + } + + #endif // End of Shared Library Code Part. diff --git a/hurricane/src/isobar/PyPinDirection.cpp b/hurricane/src/isobar/PyPinDirection.cpp new file mode 100644 index 00000000..b1179753 --- /dev/null +++ b/hurricane/src/isobar/PyPinDirection.cpp @@ -0,0 +1,110 @@ +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2014-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ +// | C O R I O L I S | +// | I s o b a r - Hurricane / Python Interface | +// | | +// | Author : Jean-Paul CHAPUT | +// | E-mail : Jean-Paul.Chaput@lip6.fr | +// | =============================================================== | +// | C++ Module : "./PyPinDirection.h" | +// +-----------------------------------------------------------------+ + + +#include "hurricane/isobar/PyPinDirection.h" + + +namespace Isobar { + + using std::cerr; + using std::endl; + using std::hex; + using std::ostringstream; + using Hurricane::tab; + using Hurricane::in_trace; + using Hurricane::Error; + using Hurricane::Warning; + using Isobar::ProxyProperty; + using Isobar::ProxyError; + using Isobar::ConstructorError; + using Isobar::HurricaneError; + using Isobar::HurricaneWarning; + using Isobar::ParseOneArg; + using Isobar::ParseTwoArg; + + +extern "C" { + + +#define METHOD_HEAD(function) GENERIC_METHOD_HEAD(PinDirection,netDirection,function) + + +// +=================================================================+ +// | "PyPinDirection" Python Module Code Part | +// +=================================================================+ + +#if defined(__PYTHON_MODULE__) + + + // Standart Accessors (Attributes). + + + // Standart Destroy (Attribute). + // DBoDestroyAttribute(PyPinDirection_destroy,PyPinDirection) + + + PyMethodDef PyPinDirection_Methods[] = + { {NULL, NULL, 0, NULL} /* sentinel */ + }; +//PyTypeObjectLinkPyType(Transformation::PinDirection) + + + PythonOnlyDeleteMethod(PinDirection) + DirectReprMethod(PyPinDirection_Repr, PyPinDirection, Pin::AccessDirection) + DirectStrMethod (PyPinDirection_Str, PyPinDirection, Pin::AccessDirection) + DirectCmpMethod (PyPinDirection_Cmp, IsPyPinDirection, PyPinDirection) + DirectHashMethod(PyPinDirection_Hash, PyPinDirection) + + extern void PyPinDirection_LinkPyType() { + trace << "PyPinDirection_LinkType()" << endl; + PyTypePinDirection.tp_dealloc = (destructor) PyPinDirection_DeAlloc; + PyTypePinDirection.tp_compare = (cmpfunc) PyPinDirection_Cmp; + PyTypePinDirection.tp_repr = (reprfunc) PyPinDirection_Repr; + PyTypePinDirection.tp_str = (reprfunc) PyPinDirection_Str; + PyTypePinDirection.tp_hash = (hashfunc) PyPinDirection_Hash; + PyTypePinDirection.tp_methods = PyPinDirection_Methods; + } + + +#else // End of Python Module Code Part. + + +// +=================================================================+ +// | "PyPinDirection" Shared Library Code Part | +// +=================================================================+ + + // Link/Creation Method. + PyTypeObjectDefinitions(PinDirection) + + + extern void PyPinDirection_postModuleInit () + { + PyObject* constant; + + LoadObjectConstant(PyTypePinDirection.tp_dict,Pin::AccessDirection::UNDEFINED,"UNDEFINED"); + LoadObjectConstant(PyTypePinDirection.tp_dict,Pin::AccessDirection::NORTH ,"NORTH"); + LoadObjectConstant(PyTypePinDirection.tp_dict,Pin::AccessDirection::SOUTH ,"SOUTH"); + LoadObjectConstant(PyTypePinDirection.tp_dict,Pin::AccessDirection::EAST ,"EAST"); + LoadObjectConstant(PyTypePinDirection.tp_dict,Pin::AccessDirection::WEST ,"WEST"); + } + + +#endif // Shared Library Code Part. + +} // extern "C". + +} // Isobar namespace. + diff --git a/hurricane/src/isobar/PyPinPlacementStatus.cpp b/hurricane/src/isobar/PyPinPlacementStatus.cpp new file mode 100644 index 00000000..120fd6c4 --- /dev/null +++ b/hurricane/src/isobar/PyPinPlacementStatus.cpp @@ -0,0 +1,108 @@ +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2014-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ +// | C O R I O L I S | +// | I s o b a r - Hurricane / Python Interface | +// | | +// | Author : Jean-Paul CHAPUT | +// | E-mail : Jean-Paul.Chaput@lip6.fr | +// | =============================================================== | +// | C++ Module : "./PyPinPlacementStatus.h" | +// +-----------------------------------------------------------------+ + + +#include "hurricane/isobar/PyPinPlacementStatus.h" + + +namespace Isobar { + + using std::cerr; + using std::endl; + using std::hex; + using std::ostringstream; + using Hurricane::tab; + using Hurricane::in_trace; + using Hurricane::Error; + using Hurricane::Warning; + using Isobar::ProxyProperty; + using Isobar::ProxyError; + using Isobar::ConstructorError; + using Isobar::HurricaneError; + using Isobar::HurricaneWarning; + using Isobar::ParseOneArg; + using Isobar::ParseTwoArg; + + +extern "C" { + + +#define METHOD_HEAD(function) GENERIC_METHOD_HEAD(PinPlacementStatus,netPlacementStatus,function) + + +// +=================================================================+ +// | "PyPinPlacementStatus" Python Module Code Part | +// +=================================================================+ + +#if defined(__PYTHON_MODULE__) + + + // Standart Accessors (Attributes). + + + // Standart Destroy (Attribute). + // DBoDestroyAttribute(PyPinPlacementStatus_destroy,PyPinPlacementStatus) + + + PyMethodDef PyPinPlacementStatus_Methods[] = + { {NULL, NULL, 0, NULL} /* sentinel */ + }; +//PyTypeObjectLinkPyType(Transformation::PinPlacementStatus) + + + PythonOnlyDeleteMethod(PinPlacementStatus) + DirectReprMethod(PyPinPlacementStatus_Repr, PyPinPlacementStatus, Pin::PlacementStatus) + DirectStrMethod (PyPinPlacementStatus_Str, PyPinPlacementStatus, Pin::PlacementStatus) + DirectCmpMethod (PyPinPlacementStatus_Cmp, IsPyPinPlacementStatus, PyPinPlacementStatus) + DirectHashMethod(PyPinPlacementStatus_Hash, PyPinPlacementStatus) + + extern void PyPinPlacementStatus_LinkPyType() { + trace << "PyPinPlacementStatus_LinkType()" << endl; + PyTypePinPlacementStatus.tp_dealloc = (destructor) PyPinPlacementStatus_DeAlloc; + PyTypePinPlacementStatus.tp_compare = (cmpfunc) PyPinPlacementStatus_Cmp; + PyTypePinPlacementStatus.tp_repr = (reprfunc) PyPinPlacementStatus_Repr; + PyTypePinPlacementStatus.tp_str = (reprfunc) PyPinPlacementStatus_Str; + PyTypePinPlacementStatus.tp_hash = (hashfunc) PyPinPlacementStatus_Hash; + PyTypePinPlacementStatus.tp_methods = PyPinPlacementStatus_Methods; + } + + +#else // End of Python Module Code Part. + + +// +=================================================================+ +// | "PyPinPlacementStatus" Shared Library Code Part | +// +=================================================================+ + + // Link/Creation Method. + PyTypeObjectDefinitions(PinPlacementStatus) + + + extern void PyPinPlacementStatus_postModuleInit () + { + PyObject* constant; + + LoadObjectConstant(PyTypePinPlacementStatus.tp_dict,Pin::PlacementStatus::UNPLACED,"UNPLACED"); + LoadObjectConstant(PyTypePinPlacementStatus.tp_dict,Pin::PlacementStatus::PLACED ,"PLACED"); + LoadObjectConstant(PyTypePinPlacementStatus.tp_dict,Pin::PlacementStatus::FIXED ,"FIXED"); + } + + +#endif // Shared Library Code Part. + +} // extern "C". + +} // Isobar namespace. + diff --git a/hurricane/src/isobar/PyPlacementStatus.cpp b/hurricane/src/isobar/PyPlacementStatus.cpp new file mode 100644 index 00000000..3aee2c5a --- /dev/null +++ b/hurricane/src/isobar/PyPlacementStatus.cpp @@ -0,0 +1,112 @@ +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2014-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ +// | C O R I O L I S | +// | I s o b a r - Hurricane / Python Interface | +// | | +// | Author : Jean-Paul CHAPUT | +// | E-mail : Jean-Paul.Chaput@lip6.fr | +// | =============================================================== | +// | C++ Module : "./PyPlacementStatus.h" | +// +-----------------------------------------------------------------+ + + +#include "hurricane/isobar/PyPlacementStatus.h" + + +namespace Isobar { + + using std::cerr; + using std::endl; + using std::hex; + using std::ostringstream; + using Hurricane::tab; + using Hurricane::in_trace; + using Hurricane::Error; + using Hurricane::Warning; + using Isobar::ProxyProperty; + using Isobar::ProxyError; + using Isobar::ConstructorError; + using Isobar::HurricaneError; + using Isobar::HurricaneWarning; + using Isobar::ParseOneArg; + using Isobar::ParseTwoArg; + + +extern "C" { + + +#define METHOD_HEAD(function) GENERIC_METHOD_HEAD(PlacementStatus,status,function) + + +// +=================================================================+ +// | "PyPlacementStatus" Python Module Code Part | +// +=================================================================+ + +#if defined(__PYTHON_MODULE__) + + + // Standart Accessors (Attributes). + + + // Standart Destroy (Attribute). + // DBoDestroyAttribute(PyPlacementStatus_destroy,PyPlacementStatus) + + + PyMethodDef PyPlacementStatus_Methods[] = + { {NULL, NULL, 0, NULL} /* sentinel */ + }; + + +//PythonOnlyDeleteMethod(Transformation::PlacementStatus) +//PyTypeObjectLinkPyType(Transformation::PlacementStatus) + + + PythonOnlyDeleteMethod(PlacementStatus) + + DirectReprMethod(PyPlacementStatus_Repr, PyPlacementStatus, Instance::PlacementStatus) + DirectStrMethod (PyPlacementStatus_Str, PyPlacementStatus, Instance::PlacementStatus) + DirectCmpMethod (PyPlacementStatus_Cmp, IsPyPlacementStatus, PyPlacementStatus) + DirectHashMethod(PyPlacementStatus_Hash, PyPlacementStatus) + + extern void PyPlacementStatus_LinkPyType() { + trace << "PyPlacementStatus_LinkType()" << endl; + PyTypePlacementStatus.tp_dealloc = (destructor) PyPlacementStatus_DeAlloc; + PyTypePlacementStatus.tp_compare = (cmpfunc) PyPlacementStatus_Cmp; + PyTypePlacementStatus.tp_repr = (reprfunc) PyPlacementStatus_Repr; + PyTypePlacementStatus.tp_str = (reprfunc) PyPlacementStatus_Str; + PyTypePlacementStatus.tp_hash = (hashfunc) PyPlacementStatus_Hash; + PyTypePlacementStatus.tp_methods = PyPlacementStatus_Methods; + } + + +#else // End of Python Module Code Part. + + +// +=================================================================+ +// | "PyPlacementStatus" Shared Library Code Part | +// +=================================================================+ + + // Link/Creation Method. + PyTypeObjectDefinitions(PlacementStatus) + + + extern void PyPlacementStatus_postModuleInit () + { + PyObject* constant; + + LoadObjectConstant(PyTypePlacementStatus.tp_dict,Instance::PlacementStatus::UNPLACED,"UNPLACED"); + LoadObjectConstant(PyTypePlacementStatus.tp_dict,Instance::PlacementStatus::PLACED ,"PLACED"); + LoadObjectConstant(PyTypePlacementStatus.tp_dict,Instance::PlacementStatus::FIXED ,"FIXED"); + } + + +#endif // Shared Library Code Part. + +} // extern "C". + +} // Isobar namespace. + diff --git a/hurricane/src/isobar/PyPoint.cpp b/hurricane/src/isobar/PyPoint.cpp index c72a954a..37cc4b30 100644 --- a/hurricane/src/isobar/PyPoint.cpp +++ b/hurricane/src/isobar/PyPoint.cpp @@ -1,61 +1,22 @@ - // -*- C++ -*- // -// This file is part of the Coriolis Project. -// Copyright (C) Laboratoire LIP6 - Departement ASIM -// Universite Pierre et Marie Curie +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved // -// Main contributors : -// Christophe Alexandre -// Sophie Belloeil -// Hugo Clément -// Jean-Paul Chaput -// Damien Dupuis -// Christian Masson -// Marek Sroka -// -// 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: PyPoint.cpp,v 1.17 2006/09/22 11:27:32 tsunami Exp $ -// -// x-----------------------------------------------------------------x -// | | +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | // | Author : Jean-Paul CHAPUT | -// | E-mail : Jean-Paul.Chaput@asim.lip6.fr | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Module : "./PyPoint.cpp" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x - - +// | C++ Module : "./PyPoint.cpp" | +// +-----------------------------------------------------------------+ #include "hurricane/isobar/PyPoint.h" - namespace Isobar { using namespace Hurricane; @@ -78,6 +39,53 @@ extern "C" { // x-------------------------------------------------------------x + // --------------------------------------------------------------- + // Attribute Method : "PyPoint_NEW ()" + + static PyObject* PyPoint_NEW ( PyObject* module, PyObject *args ) + { + trace << "PyPoint_NEW()" << endl; + + Point* point; + PyObject* arg0; + PyObject* arg1; + + __cs.init ("Point.Point"); + if ( ! PyArg_ParseTuple(args,"|O&O&:Point.Point" + ,Converter,&arg0 + ,Converter,&arg1 + )) { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Point constructor." ); + return NULL; + } + + if ( __cs.getObjectIds() == NO_ARG ) { point = new Point (); } + else if ( __cs.getObjectIds() == POINT_ARG ) { point = new Point ( *PYPOINT_O(arg0) ); } + else if ( __cs.getObjectIds() == INTS2_ARG ) { point = new Point ( PyInt_AsLong(arg0) + , PyInt_AsLong(arg1) ); } + else { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Point constructor." ); + return NULL; + } + + PyPoint* pyPoint = PyObject_NEW(PyPoint, &PyTypePoint); + if (pyPoint == NULL) { return NULL; } + + HTRY + pyPoint->_object = point; + HCATCH + + return ( (PyObject*)pyPoint ); + } + + + static int PyPoint_Init ( PyPoint* self, PyObject* args, PyObject* kwargs ) + { + trace << "PyPoint_Init(): " << (void*)self << endl; + return 0; + } + + // --------------------------------------------------------------- // Attribute Method : "PyPoint_Translate ()" @@ -140,7 +148,8 @@ extern "C" { DirectDeleteMethod(PyPoint_DeAlloc,PyPoint) - PyTypeObjectLinkPyType(Point) + PyTypeObjectLinkPyTypeNewInit(Point) +//PyTypeObjectLinkPyType(Point) #else // End of Python Module Code Part. @@ -148,61 +157,14 @@ extern "C" { // x=================================================================x // | "PyPoint" Shared Library Code Part | // x=================================================================x - - - // --------------------------------------------------------------- - // Attribute Method : "PyPoint_create ()" - - PyObject* PyPoint_create ( PyObject* module, PyObject *args ) - { - trace << "PyPoint_create()" << endl; - - Point* point; - PyObject* arg0; - PyObject* arg1; - - __cs.init ("Point.create"); - if ( ! PyArg_ParseTuple(args,"|O&O&:Point.create" - ,Converter,&arg0 - ,Converter,&arg1 - )) { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Point constructor." ); - return NULL; - } - - if ( __cs.getObjectIds() == NO_ARG ) { point = new Point (); } - else if ( __cs.getObjectIds() == POINT_ARG ) { point = new Point ( *PYPOINT_O(arg0) ); } - else if ( __cs.getObjectIds() == INTS2_ARG ) { point = new Point ( PyInt_AsLong(arg0) - , PyInt_AsLong(arg1) ); } - else { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Point constructor." ); - return NULL; - } - - PyPoint* pyPoint = PyObject_NEW(PyPoint, &PyTypePoint); - if (pyPoint == NULL) { return NULL; } - - HTRY - pyPoint->_object = point; - HCATCH - - return ( (PyObject*)pyPoint ); - } - // --------------------------------------------------------------- - // PyPoint Object Definitions. + PyTypeObjectDefinitions(Point) -#endif // End of Shared Library Code Part. +#endif // Shared Library Code Part. +} // extern "C". - - -} // End of extern "C". - - - - -} // End of Isobar namespace. +} // Isobar namespace. diff --git a/hurricane/src/isobar/PyReference.cpp b/hurricane/src/isobar/PyReference.cpp index f23b85f2..e622a89b 100644 --- a/hurricane/src/isobar/PyReference.cpp +++ b/hurricane/src/isobar/PyReference.cpp @@ -1,17 +1,17 @@ -// x-----------------------------------------------------------------x -// | | +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2008-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | -// | Author : Jean-Paul Chaput | -// | E-mail : Jean-Paul.Chaput@asim.lip6.fr | +// | Author : Jean-Paul CHAPUT | +// | E-mail : Jean-Paul.Chaput@asim.lip6.fr | // | =============================================================== | // | C++ Module : "./PyReference.cpp" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x - +// +-----------------------------------------------------------------+ #include "hurricane/isobar/PyReference.h" @@ -51,6 +51,49 @@ extern "C" { GetNameMethod(Reference, reference) + // --------------------------------------------------------------- + // Attribute Method : "PyReference_create ()" + + PyObject* PyReference_create ( PyObject*, PyObject *args ) { + trace << "PyReference_create()" << endl; + Reference* reference = NULL; + + PyObject* arg0; + PyObject* arg1; + PyObject* arg2; + PyObject* arg3; + + HTRY + + __cs.init ("Reference.create"); + if ( ! PyArg_ParseTuple(args,"O&O&O&|O&:Reference.create" + ,Converter,&arg0 + ,Converter,&arg1 + ,Converter,&arg2 + ,Converter,&arg3 + )) { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Reference constructor." ); + return NULL; + } + + if ( __cs.getObjectIds() == ":ent:string:int:int" ) + reference = Reference::create ( PYCELL_O(arg0) + , Name(PyString_AsString(arg1)) + , PyInt_AsLong(arg2) + , PyInt_AsLong(arg3) ); + else if ( __cs.getObjectIds() == ":ent:name:point" ) + reference = Reference::create ( PYCELL_O(arg0) + , Name(PyString_AsString(arg1)) + , *PYPOINT_O(arg2) ); + else { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Reference constructor." ); + return NULL; + } + + HCATCH + return PyReference_Link ( reference ); + } + // --------------------------------------------------------------- // Attribute Method : "PyReference_getPoint ()" @@ -120,7 +163,9 @@ extern "C" { // PyReference Attribute Method table. PyMethodDef PyReference_Methods[] = - { { "destroy" , (PyCFunction)PyReference_destroy , METH_NOARGS + { { "create" , (PyCFunction)PyReference_create , METH_NOARGS|METH_STATIC + , "Create a new Reference." } + , { "destroy" , (PyCFunction)PyReference_destroy , METH_NOARGS , "destroy associated hurricane object, the python object remains." } , { "getName" , (PyCFunction)PyReference_getName , METH_NOARGS , "Returns the name of the reference." } , { "getPoint" , (PyCFunction)PyReference_getPoint , METH_NOARGS , "Return the reference point." } @@ -146,50 +191,6 @@ extern "C" { // x=================================================================x // | "PyReference" Shared Library Code Part | // x=================================================================x - - - // --------------------------------------------------------------- - // Attribute Method : "PyReference_create ()" - - PyObject* PyReference_create ( PyObject *module, PyObject *args ) { - trace << "PyReference_create()" << endl; - Reference* reference = NULL; - - PyObject* arg0; - PyObject* arg1; - PyObject* arg2; - PyObject* arg3; - - HTRY - - __cs.init ("Reference.create"); - if ( ! PyArg_ParseTuple(args,"O&O&O&|O&:Reference.create" - ,Converter,&arg0 - ,Converter,&arg1 - ,Converter,&arg2 - ,Converter,&arg3 - )) { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Reference constructor." ); - return NULL; - } - - if ( __cs.getObjectIds() == ":ent:string:int:int" ) - reference = Reference::create ( PYCELL_O(arg0) - , Name(PyString_AsString(arg1)) - , PyInt_AsLong(arg2) - , PyInt_AsLong(arg3) ); - else if ( __cs.getObjectIds() == ":ent:name:point" ) - reference = Reference::create ( PYCELL_O(arg0) - , Name(PyString_AsString(arg1)) - , *PYPOINT_O(arg2) ); - else { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Reference constructor." ); - return NULL; - } - - HCATCH - return PyReference_Link ( reference ); - } diff --git a/hurricane/src/isobar/PyTransformation.cpp b/hurricane/src/isobar/PyTransformation.cpp index 9d47d582..c4e4656a 100644 --- a/hurricane/src/isobar/PyTransformation.cpp +++ b/hurricane/src/isobar/PyTransformation.cpp @@ -1,26 +1,23 @@ +// -*- C++ -*- // -// $Id: PyTransformation.cpp,v 1.17 2007/01/30 14:47:24 cobell Exp $ +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved // -// x-----------------------------------------------------------------x -// | | +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | // | Author : Jean-Paul CHAPUT | -// | E-mail : Jean-Paul.Chaput@asim.lip6.fr | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Module : "./PyTransformation.cpp" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x - - +// | C++ Module : "./PyTransformation.cpp" | +// +-----------------------------------------------------------------+ #include "hurricane/isobar/PyPoint.h" #include "hurricane/isobar/PyBox.h" #include "hurricane/isobar/PyTransformation.h" +#include "hurricane/isobar/PyOrientation.h" namespace Isobar { @@ -40,27 +37,6 @@ extern "C" { #if defined(__PYTHON_MODULE__) - // x-------------------------------------------------------------x - // | Global Constants Loading | - // x-------------------------------------------------------------x - - extern void TransformationLoadConstants ( PyObject* dictionnary ) - { - PyObject* constant; - - LOAD_CONSTANT ( Transformation::Orientation::ID, "OrientationID" ) - LOAD_CONSTANT ( Transformation::Orientation::R1, "OrientationR1" ) - LOAD_CONSTANT ( Transformation::Orientation::R2, "OrientationR2" ) - LOAD_CONSTANT ( Transformation::Orientation::R3, "OrientationR3" ) - LOAD_CONSTANT ( Transformation::Orientation::MX, "OrientationMX" ) - LOAD_CONSTANT ( Transformation::Orientation::XR, "OrientationXR" ) - LOAD_CONSTANT ( Transformation::Orientation::MY, "OrientationMY" ) - LOAD_CONSTANT ( Transformation::Orientation::YR, "OrientationYR" ) - } - - - - // x-------------------------------------------------------------x // | "PyTransformation" Attribute Methods | // x-------------------------------------------------------------x @@ -73,8 +49,82 @@ extern "C" { // Standard destroy (Attribute). DirectDestroyAttribute(PyTransformation_destroy, PyTransformation) + + + static Transformation::Orientation PyInt_AsOrientation ( PyObject* object ) { + switch ( PyInt_AsLong(object) ) { + case Transformation::Orientation::ID : return ( Transformation::Orientation(Transformation::Orientation::ID) ); + case Transformation::Orientation::R1 : return ( Transformation::Orientation(Transformation::Orientation::R1) ); + case Transformation::Orientation::R2 : return ( Transformation::Orientation(Transformation::Orientation::R2) ); + case Transformation::Orientation::R3 : return ( Transformation::Orientation(Transformation::Orientation::R3) ); + case Transformation::Orientation::MX : return ( Transformation::Orientation(Transformation::Orientation::MX) ); + case Transformation::Orientation::XR : return ( Transformation::Orientation(Transformation::Orientation::XR) ); + case Transformation::Orientation::MY : return ( Transformation::Orientation(Transformation::Orientation::MY) ); + case Transformation::Orientation::YR : return ( Transformation::Orientation(Transformation::Orientation::YR) ); + } + + return ( Transformation::Orientation(Transformation::Orientation::ID) ); + } + // --------------------------------------------------------------- + // Attribute Method : "PyTransformation_NEW ()" + + static PyObject* PyTransformation_NEW (PyObject *module, PyObject *args) { + trace << "PyTransformation_NEW()" << endl; + + Transformation* transf; + PyObject* arg0; + PyObject* arg1; + PyObject* arg2; + + __cs.init ("Transformation.Transformation"); + if ( ! PyArg_ParseTuple(args,"|O&O&O&:Transformation.Transformation" + ,Converter,&arg0 + ,Converter,&arg1 + ,Converter,&arg2 + )) { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Transformation constructor." ); + return NULL; + } + + if ( __cs.getObjectIds() == NO_ARG ) { transf = new Transformation (); } + else if ( __cs.getObjectIds() == POINT_ARG ) { transf = new Transformation ( *PYPOINT_O(arg0) ); } + else if ( __cs.getObjectIds() == TRANS_ARG ) { transf = new Transformation ( *PYTRANSFORMATION_O(arg0) ); } + else if ( __cs.getObjectIds() == INTS2_ARG ) { transf = new Transformation ( PyInt_AsLong(arg0) + , PyInt_AsLong(arg1) ); } + else if ( __cs.getObjectIds() == POINT_INT_ARG ) { transf = new Transformation ( *PYPOINT_O(arg0) + , PyInt_AsOrientation(arg1) ); } + else if ( __cs.getObjectIds() == INTS3_ARG ) { transf = new Transformation ( PyInt_AsLong(arg0) + , PyInt_AsLong(arg1) + , PyInt_AsOrientation(arg2) ); } + else { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Transformation constructor." ); + return NULL; + } + + PyTransformation* pyTransformation = PyObject_NEW(PyTransformation, &PyTypeTransformation); + if (pyTransformation == NULL) { return NULL; } + + trace_in (); + trace << "new PyTransformation [" << hex << pyTransformation << "]" << endl; + trace_out (); + + HTRY + + pyTransformation->_object = transf; + + HCATCH + + return (PyObject*)pyTransformation; + } + + + static int PyTransformation_Init ( PyTransformation* self, PyObject* args, PyObject* kwargs ) + { + trace << "PyTransformation_Init(): " << (void*)self << endl; + return 0; + } // --------------------------------------------------------------- @@ -459,8 +509,6 @@ extern "C" { } - - // --------------------------------------------------------------- // PyTransformation Attribute Method table. @@ -487,14 +535,13 @@ extern "C" { }; - - // x-------------------------------------------------------------x // | "PyTransformation" Object Methods | // x-------------------------------------------------------------x DirectDeleteMethod(PyTransformation_DeAlloc,PyTransformation) - PyTypeObjectLinkPyType(Transformation) + PyTypeObjectLinkPyTypeNewInit(Transformation) +//PyTypeObjectLinkPyType(Transformation) #else // End of Python Module Code Part. @@ -503,84 +550,21 @@ extern "C" { // x=================================================================x // | "PyTransformation" Shared Library Code Part | // x=================================================================x - - static Transformation::Orientation PyInt_AsOrientation ( PyObject* object ) { - switch ( PyInt_AsLong(object) ) { - case Transformation::Orientation::ID : return ( Transformation::Orientation(Transformation::Orientation::ID) ); - case Transformation::Orientation::R1 : return ( Transformation::Orientation(Transformation::Orientation::R1) ); - case Transformation::Orientation::R2 : return ( Transformation::Orientation(Transformation::Orientation::R2) ); - case Transformation::Orientation::R3 : return ( Transformation::Orientation(Transformation::Orientation::R3) ); - case Transformation::Orientation::MX : return ( Transformation::Orientation(Transformation::Orientation::MX) ); - case Transformation::Orientation::XR : return ( Transformation::Orientation(Transformation::Orientation::XR) ); - case Transformation::Orientation::MY : return ( Transformation::Orientation(Transformation::Orientation::MY) ); - case Transformation::Orientation::YR : return ( Transformation::Orientation(Transformation::Orientation::YR) ); - } - return ( Transformation::Orientation(Transformation::Orientation::ID) ); - } - - // --------------------------------------------------------------- - // Attribute Method : "PyTransformation_create ()" - - PyObject* PyTransformation_create (PyObject *module, PyObject *args) { - trace << "PyTransformation_create()" << endl; - - Transformation* transf; - PyObject* arg0; - PyObject* arg1; - PyObject* arg2; - - __cs.init ("Transformation.create"); - if ( ! PyArg_ParseTuple(args,"|O&O&O&:Transformation.create" - ,Converter,&arg0 - ,Converter,&arg1 - ,Converter,&arg2 - )) { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Transformation constructor." ); - return NULL; - } - - if ( __cs.getObjectIds() == NO_ARG ) { transf = new Transformation (); } - else if ( __cs.getObjectIds() == POINT_ARG ) { transf = new Transformation ( *PYPOINT_O(arg0) ); } - else if ( __cs.getObjectIds() == TRANS_ARG ) { transf = new Transformation ( *PYTRANSFORMATION_O(arg0) ); } - else if ( __cs.getObjectIds() == INTS2_ARG ) { transf = new Transformation ( PyInt_AsLong(arg0) - , PyInt_AsLong(arg1) ); } - else if ( __cs.getObjectIds() == POINT_INT_ARG ) { transf = new Transformation ( *PYPOINT_O(arg0) - , PyInt_AsOrientation(arg1) ); } - else if ( __cs.getObjectIds() == INTS3_ARG ) { transf = new Transformation ( PyInt_AsLong(arg0) - , PyInt_AsLong(arg1) - , PyInt_AsOrientation(arg2) ); } - else { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Transformation constructor." ); - return NULL; - } - - PyTransformation* pyTransformation = PyObject_NEW(PyTransformation, &PyTypeTransformation); - if (pyTransformation == NULL) { return NULL; } - - trace_in (); - trace << "new PyTransformation [" << hex << pyTransformation << "]" << endl; - trace_out (); - - HTRY - - pyTransformation->_object = transf; - - HCATCH - - return (PyObject*)pyTransformation; - } - - - // x-------------------------------------------------------------x - // | "PyTransformation" Local Functions | - // x-------------------------------------------------------------x // --------------------------------------------------------------- // PyTransformation Object Definitions. PyTypeObjectDefinitions(Transformation) + extern void PyTransformation_postModuleInit () + { + PyOrientation_postModuleInit(); + + PyDict_SetItemString( PyTypeTransformation.tp_dict, "Orientation", (PyObject*)&PyTypeOrientation ); + } + + #endif // End of Shared Library Code Part. diff --git a/hurricane/src/isobar/PyVertical.cpp b/hurricane/src/isobar/PyVertical.cpp index 470e01f2..cfc54be4 100644 --- a/hurricane/src/isobar/PyVertical.cpp +++ b/hurricane/src/isobar/PyVertical.cpp @@ -1,18 +1,17 @@ -// x-----------------------------------------------------------------x -// | | +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2007-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | -// | Author : Sophie BELLOEIL | -// | E-mail : Sophie.Belloeil@asim.lip6.fr | +// | Author : Sophie BELLOEIL | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Module : "./PyVertical.cpp" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x - - +// | C++ Module : "./PyCell.cpp" | +// +-----------------------------------------------------------------+ #include "hurricane/isobar/PyNet.h" @@ -56,65 +55,10 @@ extern "C" { DBoDestroyAttribute(PyVertical_destroy, PyVertical) - // --------------------------------------------------------------- - // Attribute Method : "PyVertical_translate ()" - - static PyObject* PyVertical_translate ( PyVertical *self, PyObject* args ) { - trace << "PyVertical_translate ()" << endl; - - HTRY - METHOD_HEAD ( "Vertical.translate()" ) - DbU::Unit dx=0, dy=0; - if (PyArg_ParseTuple(args,"ll:Vertical.translate", &dx, &dy)) { - vertical->translate(dx, dy); - } else { - PyErr_SetString ( ConstructorError, "invalid number of parameters for Vertical.translate()" ); - return NULL; - } - HCATCH - - Py_RETURN_NONE; - } - - - // --------------------------------------------------------------- - // PyVertical Attribute Method table. - - PyMethodDef PyVertical_Methods[] = - { { "getX" , (PyCFunction)PyVertical_getX , METH_NOARGS , "Get the segment X position." } - , { "getDySource", (PyCFunction)PyVertical_getDySource, METH_NOARGS , "Get the segment source Y offset." } - , { "getDyTarget", (PyCFunction)PyVertical_getDyTarget, METH_NOARGS , "Get the segment target Y offset." } - , { "setX" , (PyCFunction)PyVertical_setX , METH_VARARGS, "Modify the segment X position." } - , { "setDySource", (PyCFunction)PyVertical_setDySource, METH_VARARGS, "Modify the segment source Y offset." } - , { "setDyTarget", (PyCFunction)PyVertical_setDyTarget, METH_VARARGS, "Modify the segment target Y offset." } - , { "translate" , (PyCFunction)PyVertical_translate , METH_VARARGS, "Translates the Vertical segment of dx and dy." } - , { "destroy" , (PyCFunction)PyVertical_destroy , METH_NOARGS - , "Destroy associated hurricane object, the python object remains." } - , {NULL, NULL, 0, NULL} /* sentinel */ - }; - - - - - // x-------------------------------------------------------------x - // | "PyVertical" Object Methods | - // x-------------------------------------------------------------x - - DBoDeleteMethod(Vertical) - PyTypeObjectLinkPyType(Vertical) - - -#else // End of Python Module Code Part. - - -// x=================================================================x -// | "PyVertical" Shared Library Code Part | -// x=================================================================x - // --------------------------------------------------------------- // Attribute Method : "PyVertical_create ()" - PyObject* PyVertical_create ( PyObject *module, PyObject *args ) { + static PyObject* PyVertical_create ( PyObject*, PyObject *args ) { trace << "PyVertical_create()" << endl; PyObject* arg0; @@ -201,6 +145,64 @@ extern "C" { } + // --------------------------------------------------------------- + // Attribute Method : "PyVertical_translate ()" + + static PyObject* PyVertical_translate ( PyVertical *self, PyObject* args ) { + trace << "PyVertical_translate ()" << endl; + + HTRY + METHOD_HEAD ( "Vertical.translate()" ) + DbU::Unit dx=0, dy=0; + if (PyArg_ParseTuple(args,"ll:Vertical.translate", &dx, &dy)) { + vertical->translate(dx, dy); + } else { + PyErr_SetString ( ConstructorError, "invalid number of parameters for Vertical.translate()" ); + return NULL; + } + HCATCH + + Py_RETURN_NONE; + } + + + // --------------------------------------------------------------- + // PyVertical Attribute Method table. + + PyMethodDef PyVertical_Methods[] = + { { "create" , (PyCFunction)PyVertical_create , METH_VARARGS|METH_STATIC + , "Create a new Vertical." } + , { "getX" , (PyCFunction)PyVertical_getX , METH_NOARGS , "Get the segment X position." } + , { "getDySource", (PyCFunction)PyVertical_getDySource, METH_NOARGS , "Get the segment source Y offset." } + , { "getDyTarget", (PyCFunction)PyVertical_getDyTarget, METH_NOARGS , "Get the segment target Y offset." } + , { "setX" , (PyCFunction)PyVertical_setX , METH_VARARGS, "Modify the segment X position." } + , { "setDySource", (PyCFunction)PyVertical_setDySource, METH_VARARGS, "Modify the segment source Y offset." } + , { "setDyTarget", (PyCFunction)PyVertical_setDyTarget, METH_VARARGS, "Modify the segment target Y offset." } + , { "translate" , (PyCFunction)PyVertical_translate , METH_VARARGS, "Translates the Vertical segment of dx and dy." } + , { "destroy" , (PyCFunction)PyVertical_destroy , METH_NOARGS + , "Destroy associated hurricane object, the python object remains." } + , {NULL, NULL, 0, NULL} /* sentinel */ + }; + + + + + // x-------------------------------------------------------------x + // | "PyVertical" Object Methods | + // x-------------------------------------------------------------x + + DBoDeleteMethod(Vertical) + PyTypeObjectLinkPyType(Vertical) + + +#else // End of Python Module Code Part. + + +// x=================================================================x +// | "PyVertical" Shared Library Code Part | +// x=================================================================x + + // Link/Creation Method. DBoLinkCreateMethod(Vertical) diff --git a/hurricane/src/isobar/hurricane/isobar/PyBox.h b/hurricane/src/isobar/hurricane/isobar/PyBox.h index dae9a8be..9e71b08f 100644 --- a/hurricane/src/isobar/hurricane/isobar/PyBox.h +++ b/hurricane/src/isobar/hurricane/isobar/PyBox.h @@ -1,91 +1,46 @@ - // -*- C++ -*- // -// This file is part of the Coriolis Project. -// Copyright (C) Laboratoire LIP6 - Departement ASIM -// Universite Pierre et Marie Curie +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved // -// Main contributors : -// Christophe Alexandre -// Sophie Belloeil -// Hugo Clément -// Jean-Paul Chaput -// Damien Dupuis -// Christian Masson -// Marek Sroka -// -// 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: PyBox.h,v 1.7 2006/05/03 14:00:01 jpc Exp $ -// -// x-----------------------------------------------------------------x -// | | +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | // | Author : Jean-Paul CHAPUT | -// | E-mail : Jean-Paul.Chaput@asim.lip6.fr | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Header : "./PyBox.h" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Header : "./hurricane/isobar/PyBox.h" | +// +-----------------------------------------------------------------+ - - - -# ifndef __PYBOX__ -# define __PYBOX__ - +#ifndef PY_BOX_H +#define PY_BOX_H #include "hurricane/isobar/PyHurricane.h" - #include "hurricane/Box.h" namespace Isobar { - -extern "C" { + extern "C" { // ------------------------------------------------------------------- // Python Object : "PyBox". - typedef struct { - PyObject_HEAD - Hurricane::Box* _object; - } PyBox; - - + typedef struct { + PyObject_HEAD + Hurricane::Box* _object; + } PyBox; // ------------------------------------------------------------------- // Functions & Types exported to "PyHurricane.cpp". - extern PyTypeObject PyTypeBox; - extern PyMethodDef PyBox_Methods[]; + extern PyTypeObject PyTypeBox; + extern PyMethodDef PyBox_Methods[]; - extern PyObject* PyBox_create ( PyObject* self, PyObject* args ); - extern void PyBox_LinkPyType (); + extern void PyBox_LinkPyType (); #define IsPyBox(v) ( (v)->ob_type == &PyTypeBox ) @@ -93,13 +48,8 @@ extern "C" { #define PYBOX_O(v) ( PYBOX(v)->_object ) -} // End of extern "C". + } // extern "C". +} // Isobar namespace. - -} // End of Isobar namespace. - - - - -# endif +#endif // PY_BOX_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyCell.h b/hurricane/src/isobar/hurricane/isobar/PyCell.h index 3fb14881..e432547a 100644 --- a/hurricane/src/isobar/hurricane/isobar/PyCell.h +++ b/hurricane/src/isobar/hurricane/isobar/PyCell.h @@ -1,60 +1,21 @@ - // -*- C++ -*- // -// This file is part of the Coriolis Project. -// Copyright (C) Laboratoire LIP6 - Departement ASIM -// Universite Pierre et Marie Curie +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved // -// Main contributors : -// Christophe Alexandre -// Sophie Belloeil -// Hugo Clément -// Jean-Paul Chaput -// Damien Dupuis -// Christian Masson -// Marek Sroka -// -// 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: PyCell.h,v 1.9 2006/05/03 14:00:01 jpc Exp $ -// -// x-----------------------------------------------------------------x -// | | +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | // | Author : Jean-Paul CHAPUT | -// | E-mail : Jean-Paul.Chaput@asim.lip6.fr | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Header : "./PyCell.h" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Header : "./hurricane/isobar/PyCell.h" | +// +-----------------------------------------------------------------+ - - - -#ifndef __PYCELL__ -#define __PYCELL__ +#ifndef PY_CELL_H +#define PY_CELL_H #include "hurricane/isobar/PyEntity.h" #include "hurricane/Cell.h" @@ -62,26 +23,25 @@ namespace Isobar { -extern "C" { + extern "C" { // ------------------------------------------------------------------- // Python Object : "PyCell". - typedef struct { - PyEntity _baseObject; - } PyCell; + typedef struct { + PyEntity _baseObject; + } PyCell; // ------------------------------------------------------------------- // Functions & Types exported to "PyHurricane.ccp". - extern PyTypeObject PyTypeCell; - extern PyMethodDef PyCell_Methods[]; + extern PyTypeObject PyTypeCell; + extern PyMethodDef PyCell_Methods[]; - extern PyObject* PyCell_create ( PyObject* module, PyObject* args ); - extern PyObject* PyCell_Link ( Hurricane::Cell* object ); - extern void PyCell_LinkPyType (); + extern PyObject* PyCell_Link ( Hurricane::Cell* object ); + extern void PyCell_LinkPyType (); #define IsPyCell(v) ((v)->ob_type == &PyTypeCell) @@ -89,11 +49,8 @@ extern "C" { #define PYCELL_O(v) (static_cast (PYCELL(v)->_baseObject._object)) -} // End of extern "C". + } // extern "C". - - - -} // End of Isobar namespace. +} // Isobar namespace. -#endif +#endif // PY_CELL_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyContact.h b/hurricane/src/isobar/hurricane/isobar/PyContact.h index aadee437..c45e3cfa 100644 --- a/hurricane/src/isobar/hurricane/isobar/PyContact.h +++ b/hurricane/src/isobar/hurricane/isobar/PyContact.h @@ -1,92 +1,46 @@ - // -*- C++ -*- // -// This file is part of the Coriolis Project. -// Copyright (C) Laboratoire LIP6 - Departement ASIM -// Universite Pierre et Marie Curie +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved // -// Main contributors : -// Christophe Alexandre | -// Sophie Belloeil -// Hugo Clément -// Jean-Paul Chaput -// Damien Dupuis -// Christian Masson -// Marek Sroka -// -// 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: PyContact.h,v 1.6 2006/05/03 14:00:02 jpc Exp $ -// -// x-----------------------------------------------------------------x -// | | +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | -// | Author : Jean-Paul Chaput | -// | E-mail : Jean-Paul.Chaput@asim.lip6.fr | +// | Author : Jean-Paul CHAPUT | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Header : "./PyContact.h" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Header : "./hurricane/isobar/PyContact.h" | +// +-----------------------------------------------------------------+ - - - -#ifndef __PYCONTACT__ -#define __PYCONTACT__ - +#ifndef PY_CONTACT_H +#define PY_CONTACT_H #include "hurricane/isobar/PyComponent.h" - #include "hurricane/Contact.h" namespace Isobar { -extern "C" { - + extern "C" { // ------------------------------------------------------------------- // Python Object : "PyContact". - typedef struct { - PyComponent _baseObject; - } PyContact; - - + typedef struct { + PyComponent _baseObject; + } PyContact; // ------------------------------------------------------------------- // Functions & Types exported to "PyHurricane.ccp". - extern PyTypeObject PyTypeContact; - extern PyMethodDef PyContact_Methods[]; + extern PyTypeObject PyTypeContact; + extern PyMethodDef PyContact_Methods[]; - extern PyObject* PyContact_create ( PyObject* module, PyObject* args ); - extern PyObject* PyContact_Link ( Hurricane::Contact* object ); - extern void PyContact_LinkPyType (); - + extern PyObject* PyContact_Link ( Hurricane::Contact* object ); + extern void PyContact_LinkPyType (); #define IsPyContact(v) ( (v)->ob_type == &PyTypeContact ) @@ -94,14 +48,8 @@ extern "C" { #define PYCONTACT_O(v) ( PYCONTACT(v)->_baseObject._baseObject._object ) -} // End of extern "C". + } // extern "C". +} // Isobar namespace. - - -} // End of Isobar namespace. - - - - -#endif +#endif // PY_CONTACT_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyDataBase.h b/hurricane/src/isobar/hurricane/isobar/PyDataBase.h index 86222488..eaf3863d 100644 --- a/hurricane/src/isobar/hurricane/isobar/PyDataBase.h +++ b/hurricane/src/isobar/hurricane/isobar/PyDataBase.h @@ -1,95 +1,47 @@ - // -*- C++ -*- // -// This file is part of the Coriolis Project. -// Copyright (C) Laboratoire LIP6 - Departement ASIM -// Universite Pierre et Marie Curie +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2008-2014, All Rights Reserved // -// Main contributors : -// Christophe Alexandre -// Sophie Belloeil -// Hugo Clément -// Jean-Paul Chaput -// Damien Dupuis -// Christian Masson -// Marek Sroka -// -// 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: PyDataBase.h,v 1.1 2008/02/07 19:09:58 xtof Exp $ -// -// x-----------------------------------------------------------------x -// | | +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | // | Author : Jean-Paul CHAPUT | // | E-mail : Jean-Paul.Chaput@asim.lip6.fr | // | =============================================================== | -// | C++ Header : "./PyDataBase.h" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Header : "./hurricane/isobar/PyDataBase.h" | +// +-----------------------------------------------------------------+ - - - -#ifndef __PYDATABASE__ -#define __PYDATABASE__ - +#ifndef PY_DATABASE_H +#define PY_DATABASE_H #include "hurricane/isobar/PyHurricane.h" - #include "hurricane/DataBase.h" namespace Isobar { - -extern "C" { - + extern "C" { // ------------------------------------------------------------------- // Python Object : "PyDataBase". - typedef struct { - PyObject_HEAD - Hurricane::DataBase* _object; - } PyDataBase; - - + typedef struct { + PyObject_HEAD + Hurricane::DataBase* _object; + } PyDataBase; // ------------------------------------------------------------------- // Functions & Types exported to "PyHurricane.ccp". - extern PyTypeObject PyTypeDataBase; - extern PyMethodDef PyDataBase_Methods[]; + extern PyTypeObject PyTypeDataBase; + extern PyMethodDef PyDataBase_Methods[]; - extern PyObject* PyDataBase_create ( PyObject* module ); - extern PyObject* PyDataBase_getDB ( PyObject* module ); - extern PyObject* PyDataBase_getDataBase ( PyObject* module ); - extern PyObject* PyDataBase_Link ( Hurricane::DataBase* db ); - extern void PyDataBase_LinkPyType (); + extern PyObject* PyDataBase_Link ( Hurricane::DataBase* db ); + extern void PyDataBase_LinkPyType (); #define IsPyDataBase(v) ( (v)->ob_type == &PyTypeDataBase ) @@ -97,14 +49,8 @@ extern "C" { #define PYDATABASE_O(v) ( PYDATABASE(v)->_object ) -} // End of extern "C". + } // extern "C". +} // Isobar namespace. - - -} // End of Isobar namespace. - - - - -# endif +#endif // PY_DATABASE_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyHorizontal.h b/hurricane/src/isobar/hurricane/isobar/PyHorizontal.h index a3646d6b..b8267f5d 100644 --- a/hurricane/src/isobar/hurricane/isobar/PyHorizontal.h +++ b/hurricane/src/isobar/hurricane/isobar/PyHorizontal.h @@ -1,92 +1,46 @@ - // -*- C++ -*- // -// This file is part of the Coriolis Project. -// Copyright (C) Laboratoire LIP6 - Departement ASIM -// Universite Pierre et Marie Curie +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2007-2014, All Rights Reserved // -// Main contributors : -// Christophe Alexandre -// Sophie Belloeil -// Hugo Clément -// Jean-Paul Chaput -// Damien Dupuis -// Christian Masson -// Marek Sroka -// -// 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: PyHorizontal.h,v 1.6 2007/01/30 14:47:24 cobell Exp $ -// -// x-----------------------------------------------------------------x -// | | +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | -// | Author : Sophie BELLOEIL | -// | E-mail : Sophie.Belloeil@asim.lip6.fr | +// | Author : Sophie BELLOEIL | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Header : "./PyHorizontal.h" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Header : "./hurricane/isobar/PyCell.h" | +// +-----------------------------------------------------------------+ - - - -#ifndef __PYHORIZONTAL__ -#define __PYHORIZONTAL__ - +#ifndef PY_HORIZONTAL_H +#define PY_HORIZONTAL_H #include "hurricane/isobar/PySegment.h" - #include "hurricane/Horizontal.h" namespace Isobar { - -extern "C" { - + extern "C" { // ------------------------------------------------------------------- // Python Object : "PyHorizontal". - typedef struct { - PySegment _baseObject; - } PyHorizontal; - - + typedef struct { + PySegment _baseObject; + } PyHorizontal; // ------------------------------------------------------------------- // Functions & Types exported to "PyHurricane.ccp". - extern PyTypeObject PyTypeHorizontal; - extern PyMethodDef PyHorizontal_Methods[]; + extern PyTypeObject PyTypeHorizontal; + extern PyMethodDef PyHorizontal_Methods[]; - extern PyObject* PyHorizontal_create ( PyObject* module, PyObject* args ); - extern PyObject* PyHorizontal_Link ( Hurricane::Horizontal* object ); - extern void PyHorizontal_LinkPyType (); + extern PyObject* PyHorizontal_Link ( Hurricane::Horizontal* object ); + extern void PyHorizontal_LinkPyType (); @@ -95,14 +49,8 @@ extern "C" { #define PYHORIZONTAL_O(v) ( PYHORIZONTAL(v)->_baseObject._baseObject._baseObject._object ) -} // End of extern "C". + } // extern "C". +} // Isobar namespace. - - -} // End of Isobar namespace. - - - - -#endif +#endif // PY_HORIZONTAL_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyHyperNet.h b/hurricane/src/isobar/hurricane/isobar/PyHyperNet.h index 8e027c78..18a1f007 100644 --- a/hurricane/src/isobar/hurricane/isobar/PyHyperNet.h +++ b/hurricane/src/isobar/hurricane/isobar/PyHyperNet.h @@ -1,88 +1,47 @@ - // -*- C++ -*- // -// This file is part of the Coriolis Project. -// Copyright (C) Laboratoire LIP6 - Departement ASIM -// Universite Pierre et Marie Curie +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2007-2014, All Rights Reserved // -// Main contributors : -// Christophe Alexandre -// Sophie Belloeil -// Hugo Clément -// Jean-Paul Chaput -// Damien Dupuis -// Christian Masson -// Marek Sroka -// -// 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: PyHyperNet.h,v 1.2 2007/05/10 11:15:56 d2 Exp $ -// -// x-----------------------------------------------------------------x -// | | +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | -// | Author : Damien DUPUIS | -// | E-mail : Damien.Dupuis@lip6.fr | +// | Author : Damien DUPUIS | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Header : "./PyHyperNet.h" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Header : "./hurricane/isobar/PyHyperNet.h" | +// +-----------------------------------------------------------------+ -#ifndef __PYHYPERNET__ -#define __PYHYPERNET__ +#ifndef PY_HYPERNET_H +#define PY_HYPERNET_H #include "hurricane/isobar/PyHurricane.h" - #include "hurricane/HyperNet.h" namespace Isobar { - -extern "C" { + extern "C" { // ------------------------------------------------------------------- // Python Object : "PyHyperNet". - typedef struct { - PyObject_HEAD - Hurricane::HyperNet* _object; - } PyHyperNet; - - + typedef struct { + PyObject_HEAD + Hurricane::HyperNet* _object; + } PyHyperNet; // ------------------------------------------------------------------- // Functions & Types exported to "PyHurricane.ccp". - extern PyTypeObject PyTypeHyperNet; - extern PyMethodDef PyHyperNet_Methods[]; + extern PyTypeObject PyTypeHyperNet; + extern PyMethodDef PyHyperNet_Methods[]; - extern PyObject* PyHyperNet_create ( PyObject* module, PyObject* args ); - extern void PyHyperNet_LinkPyType(); + extern void PyHyperNet_LinkPyType(); #define IsPyHyperNet(v) ( (v)->ob_type == &PyTypeHyperNet ) @@ -90,14 +49,8 @@ extern "C" { #define PYHYPERNET_O(v) ( PYHYPERNET(v)->_object ) -} // End of extern "C". + } // extern "C". +} // Isobar namespace. - - -} // End of Isobar namespace. - - - - -# endif +#endif // PY_HYPERNET_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyInstance.h b/hurricane/src/isobar/hurricane/isobar/PyInstance.h index 8ab47c96..878939fe 100644 --- a/hurricane/src/isobar/hurricane/isobar/PyInstance.h +++ b/hurricane/src/isobar/hurricane/isobar/PyInstance.h @@ -1,84 +1,40 @@ - // -*- C++ -*- // -// This file is part of the Coriolis Project. -// Copyright (C) Laboratoire LIP6 - Departement ASIM -// Universite Pierre et Marie Curie +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved // -// Main contributors : -// Christophe Alexandre -// Sophie Belloeil -// Hugo Clément -// Jean-Paul Chaput -// Damien Dupuis -// Christian Masson -// Marek Sroka -// -// 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: PyInstance.h,v 1.9 2006/05/03 14:00:03 jpc Exp $ -// -// x-----------------------------------------------------------------x -// | | +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | // | Author : Jean-Paul CHAPUT | -// | E-mail : Jean-Paul.Chaput@asim.lip6.fr | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Header : "./PyInstance.h" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Header : "./hurricane/isobar/PyInstance.h" | +// +-----------------------------------------------------------------+ - - - -#ifndef __PYINSTANCE__ -#define __PYINSTANCE__ +#ifndef PY_INSTANCE_H +#define PY_INSTANCE_H #include "hurricane/isobar/PyEntity.h" - #include "hurricane/Instance.h" namespace Isobar { - -using namespace Hurricane; + using namespace Hurricane; -extern "C" { - + extern "C" { // ------------------------------------------------------------------- // Python Object : "PyInstance". - typedef struct { - PyEntity _baseObject; - } PyInstance; - - + typedef struct { + PyEntity _baseObject; + } PyInstance; // ------------------------------------------------------------------- @@ -87,11 +43,9 @@ extern "C" { extern PyTypeObject PyTypeInstance; extern PyMethodDef PyInstance_Methods[]; - extern PyObject* PyInstance_create ( PyObject* module, PyObject* args ); - extern PyObject* PyInstance_Link ( Hurricane::Instance* object); - extern void InstanceLoadConstants ( PyObject* dictionnary ); - extern void PyInstance_LinkPyType (); - + extern PyObject* PyInstance_Link ( Hurricane::Instance* object); + extern void PyInstance_LinkPyType (); + extern void PyInstance_postModuleInit (); #define IsPyInstance(v) ((v)->ob_type == &PyTypeInstance ) @@ -99,14 +53,8 @@ extern "C" { #define PYINSTANCE_O(v) (static_cast (PYINSTANCE(v)->_baseObject._object)) -} // End of extern "C". + } // extern "C". +} // Isobar namespace. - - -} // End of Isobar namespace. - - - - -#endif +#endif // PY_INSTANCE_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyLibrary.h b/hurricane/src/isobar/hurricane/isobar/PyLibrary.h index 11a19632..8f4c7bce 100644 --- a/hurricane/src/isobar/hurricane/isobar/PyLibrary.h +++ b/hurricane/src/isobar/hurricane/isobar/PyLibrary.h @@ -1,93 +1,50 @@ - // -*- C++ -*- // -// This file is part of the Coriolis Project. -// Copyright (C) Laboratoire LIP6 - Departement ASIM -// Universite Pierre et Marie Curie +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2008-2014, All Rights Reserved // -// Main contributors : -// Christophe Alexandre -// Sophie Belloeil -// Hugo Clément -// Jean-Paul Chaput -// Damien Dupuis -// Christian Masson -// Marek Sroka -// -// 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: PyLibrary.h,v 1.7 2006/05/03 14:00:03 jpc Exp $ -// -// x-----------------------------------------------------------------x -// | | +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | // | Author : Jean-Paul CHAPUT | // | E-mail : Jean-Paul.Chaput@asim.lip6.fr | // | =============================================================== | -// | C++ Header : "./PyLibrary.h" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Module : "./PyLibrary.cpp" | +// +-----------------------------------------------------------------+ -#ifndef __PYLIBRARY__ -#define __PYLIBRARY__ +#ifndef PY_LIBRARY_H +#define PY_LIBRARY_H #include "hurricane/isobar/PyHurricane.h" - #include "hurricane/Library.h" namespace Isobar { - -using namespace Hurricane; + using namespace Hurricane; -extern "C" { - + extern "C" { // ------------------------------------------------------------------- // Python Object : "PyLibrary". - typedef struct { - PyObject_HEAD - Library* _object; - } PyLibrary; - - + typedef struct { + PyObject_HEAD + Library* _object; + } PyLibrary; // ------------------------------------------------------------------- // Functions & Types exported to "PyHurricane.ccp". - extern PyTypeObject PyTypeLibrary; - extern PyMethodDef PyLibrary_Methods[]; + extern PyTypeObject PyTypeLibrary; + extern PyMethodDef PyLibrary_Methods[]; - extern PyObject* PyLibrary_create ( PyObject* module, PyObject* args ); - extern PyObject* PyLibrary_getLibrary ( PyObject* module ); - extern PyObject* PyLibrary_Link ( Hurricane::Library* lib ); - extern void PyLibrary_LinkPyType (); + extern PyObject* PyLibrary_Link ( Hurricane::Library* lib ); + extern void PyLibrary_LinkPyType (); #define IsPyLibrary(v) ( (v)->ob_type == &PyTypeLibrary ) @@ -95,11 +52,8 @@ extern "C" { #define PYLIBRARY_O(v) ( PYLIBRARY(v)->_object ) -} // End of extern "C". +} // extern "C". - - - -} // End of Isobar namespace. +} // Isobar namespace. -# endif +# endif // PY_LIBRARY_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyNet.h b/hurricane/src/isobar/hurricane/isobar/PyNet.h index a1d64eb3..d102b649 100644 --- a/hurricane/src/isobar/hurricane/isobar/PyNet.h +++ b/hurricane/src/isobar/hurricane/isobar/PyNet.h @@ -1,56 +1,48 @@ -// x-----------------------------------------------------------------x -// | | +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | -// | Author : Sophie BELLOEIL | -// | E-mail : Sophie.Belloeil@asim.lip6.fr | +// | Author : Sophie BELLOEIL | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Header : "./PyNet.h" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Header : "./hurricane/isobar/PyNet.h" | +// +-----------------------------------------------------------------+ - - - -#ifndef __PYNET__ -#define __PYNET__ - +#ifndef PY_NET_H +#define PY_NET_H #include "hurricane/isobar/PyEntity.h" - #include "hurricane/Net.h" namespace Isobar { - -extern "C" { + extern "C" { // ------------------------------------------------------------------- // Python Object : "PyNet". - typedef struct { - PyEntity _baseObject; - } PyNet; - - + typedef struct { + PyEntity _baseObject; + } PyNet; // ------------------------------------------------------------------- // Functions & Types exported to "PyHurricane.ccp". - extern PyTypeObject PyTypeNet; - extern PyMethodDef PyNet_Methods[]; + extern PyTypeObject PyTypeNet; + extern PyMethodDef PyNet_Methods[]; - extern PyObject* PyNet_create ( PyObject* module, PyObject* args ); - extern PyObject* PyNet_Link ( Hurricane::Net* object ); - extern void NetLoadConstants ( PyObject* dictionnary ); - extern void PyNet_LinkPyType (); + extern PyObject* PyNet_Link ( Hurricane::Net* object ); + extern void PyNet_LinkPyType (); + extern void PyNet_postModuleInit (); @@ -59,14 +51,8 @@ extern "C" { #define PYNET_O(v) (dynamic_cast (PYNET(v)->_baseObject._object)) -} // End of extern "C". + } // extern "C". +} // Isobar namespace. - - -} // End of Isobar namespace. - - - - -#endif +#endif // PY_NET_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyNetDirection.h b/hurricane/src/isobar/hurricane/isobar/PyNetDirection.h new file mode 100644 index 00000000..aa874117 --- /dev/null +++ b/hurricane/src/isobar/hurricane/isobar/PyNetDirection.h @@ -0,0 +1,59 @@ +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2014-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ +// | C O R I O L I S | +// | I s o b a r - Hurricane / Python Interface | +// | | +// | Author : Jean-Paul CHAPUT | +// | E-mail : Jean-Paul.Chaput@lip6.fr | +// | =============================================================== | +// | C++ Header : "./hurricane/isobar/PyNetDirection.h" | +// +-----------------------------------------------------------------+ + + +#ifndef PY_NET_DIRECTION_H +#define PY_NET_DIRECTION_H + + +#include "hurricane/isobar/PyHurricane.h" +#include "hurricane/Net.h" + + +namespace Isobar { + + extern "C" { + + +// ------------------------------------------------------------------- +// Python Object : "PyNetDirection". + + typedef struct { + PyObject_HEAD + Hurricane::Net::Direction* _object; + } PyNetDirection; + + +// ------------------------------------------------------------------- +// Functions & Types exported to "PyHurricane.ccp". + + extern PyTypeObject PyTypeNetDirection; + extern PyMethodDef PyNetDirection_Methods[]; + + extern PyObject* PyNetDirection_Link ( Hurricane::Net::Direction* ); + extern void PyNetDirection_LinkPyType (); + extern void PyNetDirection_postModuleInit (); + + +# define IsPyNetDirection(v) ( (v)->ob_type == &PyTypeNetDirection ) +# define PYNETDIRECTION(v) ( (PyNetDirection*)(v) ) +# define PYNETDIRECTION_O(v) ( PYNETDIRECTION(v)->_object ) + + + } // extern "C". + +} // Isobar namespace. + +#endif // PY_NET_DIRECTION_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyNetType.h b/hurricane/src/isobar/hurricane/isobar/PyNetType.h new file mode 100644 index 00000000..fee7d659 --- /dev/null +++ b/hurricane/src/isobar/hurricane/isobar/PyNetType.h @@ -0,0 +1,59 @@ +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2014-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ +// | C O R I O L I S | +// | I s o b a r - Hurricane / Python Interface | +// | | +// | Author : Jean-Paul CHAPUT | +// | E-mail : Jean-Paul.Chaput@lip6.fr | +// | =============================================================== | +// | C++ Header : "./hurricane/isobar/PyNetType.h" | +// +-----------------------------------------------------------------+ + + +#ifndef PY_NET_TYPE_H +#define PY_NET_TYPE_H + + +#include "hurricane/isobar/PyHurricane.h" +#include "hurricane/Net.h" + + +namespace Isobar { + + extern "C" { + + +// ------------------------------------------------------------------- +// Python Object : "PyTransformation". + + typedef struct { + PyObject_HEAD + Hurricane::Net::Type* _object; + } PyNetType; + + +// ------------------------------------------------------------------- +// Functions & Types exported to "PyHurricane.ccp". + + extern PyTypeObject PyTypeNetType; + extern PyMethodDef PyNetType_Methods[]; + + extern PyObject* PyNetType_Link ( Hurricane::Net::Type* ); + extern void PyNetType_LinkPyType (); + extern void PyNetType_postModuleInit (); + + +# define IsPyNetType(v) ( (v)->ob_type == &PyTypeNetType ) +# define PYNETTYPE(v) ( (PyNetType*)(v) ) +# define PYNETTYPE_O(v) ( PYNETTYPE(v)->_object ) + + + } // extern "C". + +} // Isobar namespace. + +#endif // PY_NET_TYPE_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyOccurrence.h b/hurricane/src/isobar/hurricane/isobar/PyOccurrence.h index be5d8d51..8c344b12 100644 --- a/hurricane/src/isobar/hurricane/isobar/PyOccurrence.h +++ b/hurricane/src/isobar/hurricane/isobar/PyOccurrence.h @@ -1,91 +1,46 @@ - // -*- C++ -*- // -// This file is part of the Coriolis Project. -// Copyright (C) Laboratoire LIP6 - Departement ASIM -// Universite Pierre et Marie Curie +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved // -// Main contributors : -// Christophe Alexandre -// Sophie Belloeil -// Hugo Clément -// Jean-Paul Chaput -// Damien Dupuis -// Christian Masson -// Marek Sroka -// -// 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: PyOccurrence.h,v 1.2 2006/05/03 14:00:03 jpc Exp $ -// -// x-----------------------------------------------------------------x -// | | +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | // | Author : Jean-Paul CHAPUT | -// | E-mail : Jean-Paul.Chaput@asim.lip6.fr | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Header : "./PyOccurrence.h" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Header : "./hurricane/isobar/PyOccurrence.h" | +// +-----------------------------------------------------------------+ - - - -# ifndef __PYOCCURRENCE__ -# define __PYOCCURRENCE__ - +#ifndef PY_OCCURRENCE_H +#define PY_OCCURRENCE_H #include "hurricane/isobar/PyHurricane.h" - #include "hurricane/Occurrence.h" namespace Isobar { - -extern "C" { + extern "C" { // ------------------------------------------------------------------- // Python Object : "PyOccurrence". - typedef struct { - PyObject_HEAD - Hurricane::Occurrence* _object; - } PyOccurrence; - - + typedef struct { + PyObject_HEAD + Hurricane::Occurrence* _object; + } PyOccurrence; // ------------------------------------------------------------------- // Functions & Types exported to "PyHurricane.cpp". - extern PyTypeObject PyTypeOccurrence; - extern PyMethodDef PyOccurrence_Methods[]; + extern PyTypeObject PyTypeOccurrence; + extern PyMethodDef PyOccurrence_Methods[]; - extern PyObject* PyOccurrence_create ( PyObject* module, PyObject* args ); - extern void PyOccurrence_LinkPyType (); + extern void PyOccurrence_LinkPyType (); #define IsPyOccurrence(v) ( (v)->ob_type == &PyTypeOccurrence ) @@ -93,14 +48,8 @@ extern "C" { #define PYOCCURRENCE_O(v) ( PYOCCURRENCE(v)->_object ) -} // End of extern "C". + } // extern "C". +} // Isobar namespace. - - -} // End of Isobar namespace. - - - - -# endif +#endif // PY_OCCURRENCE_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyOrientation.h b/hurricane/src/isobar/hurricane/isobar/PyOrientation.h new file mode 100644 index 00000000..a5262298 --- /dev/null +++ b/hurricane/src/isobar/hurricane/isobar/PyOrientation.h @@ -0,0 +1,57 @@ +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2014-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ +// | C O R I O L I S | +// | I s o b a r - Hurricane / Python Interface | +// | | +// | Author : Jean-Paul CHAPUT | +// | E-mail : Jean-Paul.Chaput@lip6.fr | +// | =============================================================== | +// | C++ Header : "./hurricane/isobar/PyOrientation.h" | +// +-----------------------------------------------------------------+ + + +#ifndef PY_ORIENTATION_H +#define PY_ORIENTATION_H + +#include "hurricane/isobar/PyHurricane.h" +#include "hurricane/Transformation.h" + + +namespace Isobar { + + extern "C" { + +// ------------------------------------------------------------------- +// Python Object : "PyOrientation". + + typedef struct { + PyObject_HEAD + Hurricane::Transformation::Orientation* _object; + } PyOrientation; + + +// ------------------------------------------------------------------- +// Functions & Types exported to "PyHurricane.ccp". + + extern PyTypeObject PyTypeOrientation; + extern PyMethodDef PyOrientation_Methods[]; + + extern PyObject* PyOrientation_Link ( Hurricane::Transformation::Orientation* ); + extern void PyOrientation_LinkPyType (); + extern void PyOrientation_postModuleInit (); + + +#define IsPyOrientation(v) ( (v)->ob_type == &PyTypeOrientation ) +#define PYORIENTATION(v) ( (PyOrientation*)(v) ) +#define PYORIENTATION_O(v) ( PYORIENTATION(v)->_object ) + + + } // End of extern "C". + +} // End of Isobar namespace. + +#endif // PY_ORIENTATION_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyPad.h b/hurricane/src/isobar/hurricane/isobar/PyPad.h index a17072a4..fc4df9b3 100644 --- a/hurricane/src/isobar/hurricane/isobar/PyPad.h +++ b/hurricane/src/isobar/hurricane/isobar/PyPad.h @@ -1,37 +1,47 @@ -#ifndef __PYPAD_H -#define __PYPAD_H +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ +// | C O R I O L I S | +// | I s o b a r - Hurricane / Python Interface | +// | | +// | Author : Jean-Paul CHAPUT | +// | E-mail : Jean-Paul.Chaput@lip6.fr | +// | =============================================================== | +// | C++ Header : "./hurricane/isobar/PyPad.h" | +// +-----------------------------------------------------------------+ +#ifndef PY_PAD_H +#define PY_PAD_H + #include "hurricane/isobar/PyComponent.h" - #include "hurricane/Pad.h" namespace Isobar { - -extern "C" { + extern "C" { // ------------------------------------------------------------------- // Python Object : "PyPad". - typedef struct { - PyComponent _baseObject; - } PyPad; - - + typedef struct { + PyComponent _baseObject; + } PyPad; // ------------------------------------------------------------------- // Functions & Types exported to "PyHurricane.ccp". - extern PyTypeObject PyTypePad; - extern PyMethodDef PyPad_Methods[]; + extern PyTypeObject PyTypePad; + extern PyMethodDef PyPad_Methods[]; - extern PyObject* PyPad_create ( PyObject* module, PyObject* args ); - extern PyObject* PyPad_Link ( Hurricane::Pad* object ); - extern void PyPad_LinkPyType (); + extern PyObject* PyPad_Link ( Hurricane::Pad* object ); + extern void PyPad_LinkPyType (); #define IsPyPad(v) ( (v)->ob_type == &PyTypePad ) @@ -39,14 +49,8 @@ extern "C" { #define PYPAD_O(v) ( PYPAD(v)->_baseObject._baseObject._object ) -} // End of extern "C". + } // extern "C". +} // Isobar namespace. - - -} // End of Isobar namespace. - - - - -#endif /* __PYPAD_H */ +#endif // PY_PAD_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyPath.h b/hurricane/src/isobar/hurricane/isobar/PyPath.h index 0327c031..b24e3644 100644 --- a/hurricane/src/isobar/hurricane/isobar/PyPath.h +++ b/hurricane/src/isobar/hurricane/isobar/PyPath.h @@ -1,91 +1,46 @@ - // -*- C++ -*- // -// This file is part of the Coriolis Project. -// Copyright (C) Laboratoire LIP6 - Departement ASIM -// Universite Pierre et Marie Curie +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved // -// Main contributors : -// Christophe Alexandre -// Sophie Belloeil -// Hugo Clément -// Jean-Paul Chaput -// Damien Dupuis -// Christian Masson -// Marek Sroka -// -// 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: PyPath.h,v 1.2 2006/05/03 14:00:04 jpc Exp $ -// -// x-----------------------------------------------------------------x -// | | +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | // | Author : Jean-Paul CHAPUT | -// | E-mail : Jean-Paul.Chaput@asim.lip6.fr | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Header : "./PyPath.h" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Header : "./hurricane/isobar/PyPath.h" | +// +-----------------------------------------------------------------+ - - - -#ifndef __PYPATH__ -#define __PYPATH__ - +#ifndef PY_PATH_H +#define PY_PATH_H #include "hurricane/isobar/PyHurricane.h" - #include "hurricane/Path.h" namespace Isobar { - -extern "C" { + extern "C" { // ------------------------------------------------------------------- // Python Object : "PyPath". - typedef struct { - PyObject_HEAD - Hurricane::Path* _object; - } PyPath; - - + typedef struct { + PyObject_HEAD + Hurricane::Path* _object; + } PyPath; // ------------------------------------------------------------------- // Functions & Types exported to "PyHurricane.cpp". - extern PyTypeObject PyTypePath; - extern PyMethodDef PyPath_Methods[]; + extern PyTypeObject PyTypePath; + extern PyMethodDef PyPath_Methods[]; - extern PyObject* PyPath_create ( PyObject* module, PyObject* args ); - extern void PyPath_LinkPyType (); + extern void PyPath_LinkPyType (); #define IsPyPath(v) ( (v)->ob_type == &PyTypePath ) @@ -93,14 +48,8 @@ extern "C" { #define PYPATH_O(v) ( PYPATH(v)->_object ) -} // End of extern "C". + } // extern "C". +} // Isobar namespace. - - -} // End of Isobar namespace. - - - - -#endif +#endif // PY_PATH_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyPin.h b/hurricane/src/isobar/hurricane/isobar/PyPin.h index ec70838b..f7095cad 100644 --- a/hurricane/src/isobar/hurricane/isobar/PyPin.h +++ b/hurricane/src/isobar/hurricane/isobar/PyPin.h @@ -1,93 +1,56 @@ - // -*- C++ -*- // -// This file is part of the Coriolis Project. -// Copyright (C) Laboratoire LIP6 - Departement ASIM -// Universite Pierre et Marie Curie +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved // -// Main contributors : -// Christophe Alexandre -// Sophie Belloeil -// Hugo Clément -// Jean-Paul Chaput -// Damien Dupuis -// Christian Masson -// Marek Sroka -// -// 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: PyPin.h,v 1.9 2006/11/29 10:40:25 d2 Exp $ -// -// x-----------------------------------------------------------------x -// | | +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | // | Author : Damien DUPUIS | -// | E-mail : Damien.Dupuis@asim.lip6.fr | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Header : "./PyPin.h" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Header : "./hurricane/isobar/PyPin.h" | +// +-----------------------------------------------------------------+ -#ifndef __PYPIN__ -#define __PYPIN__ + +#ifndef PY_PIN_H +#define PY_PIN_H #include "hurricane/isobar/PyContact.h" #include "hurricane/Pin.h" namespace Isobar { - -using namespace Hurricane; -extern "C" { + extern "C" { // ------------------------------------------------------------------- // Python Object : "PyPin". - typedef struct { - PyContact _baseObject; - } PyPin; + typedef struct { + PyContact _baseObject; + } PyPin; // ------------------------------------------------------------------- // Functions & Types exported to "PyHurricane.ccp". - extern PyTypeObject PyTypePin; - extern PyMethodDef PyPin_Methods[]; + extern PyTypeObject PyTypePin; + extern PyMethodDef PyPin_Methods[]; - extern PyObject* PyPin_create ( PyObject* module, PyObject* args ); - extern PyObject* PyPin_Link (Hurricane::Pin* object ); - extern void PinLoadConstants ( PyObject* dictionnary ); - extern void PyPin_LinkPyType (); + extern PyObject* PyPin_Link (Hurricane::Pin* object ); + extern void PyPin_LinkPyType (); + extern void PyPin_postModuleInit (); # define IsPyPin(v) ( (v)->ob_type == &PyTypePin ) # define PYPIN(v) ( (PyPin*)(v) ) # define PYPIN_O(v) ( PYPIN(v)->_baseObject._baseObject._baseObject._object ) -} // End of extern "C". -} // End of Isobar namespace. + } // extern "C". -# endif +} // Isobar namespace. + +#endif // PY_PIN_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyPinDirection.h b/hurricane/src/isobar/hurricane/isobar/PyPinDirection.h new file mode 100644 index 00000000..2bb54bd1 --- /dev/null +++ b/hurricane/src/isobar/hurricane/isobar/PyPinDirection.h @@ -0,0 +1,59 @@ +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2014-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ +// | C O R I O L I S | +// | I s o b a r - Hurricane / Python Interface | +// | | +// | Author : Jean-Paul CHAPUT | +// | E-mail : Jean-Paul.Chaput@lip6.fr | +// | =============================================================== | +// | C++ Header : "./hurricane/isobar/PyPinDirection.h" | +// +-----------------------------------------------------------------+ + + +#ifndef PY_PIN_DIRECTION_H +#define PY_PIN_DIRECTION_H + + +#include "hurricane/isobar/PyHurricane.h" +#include "hurricane/Pin.h" + + +namespace Isobar { + + extern "C" { + + +// ------------------------------------------------------------------- +// Python Object : "PyPinDirection". + + typedef struct { + PyObject_HEAD + Hurricane::Pin::AccessDirection* _object; + } PyPinDirection; + + +// ------------------------------------------------------------------- +// Functions & Types exported to "PyHurricane.ccp". + + extern PyTypeObject PyTypePinDirection; + extern PyMethodDef PyPinDirection_Methods[]; + + extern PyObject* PyPinDirection_Link ( Hurricane::Pin::AccessDirection* ); + extern void PyPinDirection_LinkPyType (); + extern void PyPinDirection_postModuleInit (); + + +# define IsPyPinDirection(v) ( (v)->ob_type == &PyTypePinDirection ) +# define PYPINDIRECTION(v) ( (PyPinDirection*)(v) ) +# define PYPINDIRECTION_O(v) ( PYPINDIRECTION(v)->_object ) + + + } // extern "C". + +} // Isobar namespace. + +#endif // PY_PIN_DIRECTION_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyPinPlacementStatus.h b/hurricane/src/isobar/hurricane/isobar/PyPinPlacementStatus.h new file mode 100644 index 00000000..c2b617e0 --- /dev/null +++ b/hurricane/src/isobar/hurricane/isobar/PyPinPlacementStatus.h @@ -0,0 +1,59 @@ +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2014-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ +// | C O R I O L I S | +// | I s o b a r - Hurricane / Python Interface | +// | | +// | Author : Jean-Paul CHAPUT | +// | E-mail : Jean-Paul.Chaput@lip6.fr | +// | =============================================================== | +// | C++ Header : "./hurricane/isobar/PyPinPlacementStatus.h" | +// +-----------------------------------------------------------------+ + + +#ifndef PY_PIN_PLACEMENTSTATUS_H +#define PY_PIN_PLACEMENTSTATUS_H + + +#include "hurricane/isobar/PyHurricane.h" +#include "hurricane/Pin.h" + + +namespace Isobar { + + extern "C" { + + +// ------------------------------------------------------------------- +// Python Object : "PyPinPlacementStatus". + + typedef struct { + PyObject_HEAD + Hurricane::Pin::PlacementStatus* _object; + } PyPinPlacementStatus; + + +// ------------------------------------------------------------------- +// Functions & Types exported to "PyHurricane.ccp". + + extern PyTypeObject PyTypePinPlacementStatus; + extern PyMethodDef PyPinPlacementStatus_Methods[]; + + extern PyObject* PyPinPlacementStatus_Link ( Hurricane::Pin::PlacementStatus* ); + extern void PyPinPlacementStatus_LinkPyType (); + extern void PyPinPlacementStatus_postModuleInit (); + + +# define IsPyPinPlacementStatus(v) ( (v)->ob_type == &PyTypePinPlacementStatus ) +# define PYPINPLACEMENTSTATUS(v) ( (PyPinPlacementStatus*)(v) ) +# define PYPINPLACEMENTSTATUS_O(v) ( PYPINPLACEMENTSTATUS(v)->_object ) + + + } // extern "C". + +} // Isobar namespace. + +#endif // PY_PIN_PLACEMENTSTATUS_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyPlacementStatus.h b/hurricane/src/isobar/hurricane/isobar/PyPlacementStatus.h new file mode 100644 index 00000000..af1d9d0e --- /dev/null +++ b/hurricane/src/isobar/hurricane/isobar/PyPlacementStatus.h @@ -0,0 +1,57 @@ +// -*- C++ -*- +// +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2014-2014, All Rights Reserved +// +// +-----------------------------------------------------------------+ +// | C O R I O L I S | +// | I s o b a r - Hurricane / Python Interface | +// | | +// | Author : Jean-Paul CHAPUT | +// | E-mail : Jean-Paul.Chaput@lip6.fr | +// | =============================================================== | +// | C++ Header : "./hurricane/isobar/PyPlacementStatus.h" | +// +-----------------------------------------------------------------+ + + +#ifndef PY_PLACEMENTSTATUS_H +#define PY_PLACEMENTSTATUS_H + +#include "hurricane/isobar/PyHurricane.h" +#include "hurricane/Instance.h" + + +namespace Isobar { + + extern "C" { + +// ------------------------------------------------------------------- +// Python Object : "PyPlacementStatus". + + typedef struct { + PyObject_HEAD + Hurricane::Instance::PlacementStatus* _object; + } PyPlacementStatus; + + +// ------------------------------------------------------------------- +// Functions & Types exported to "PyHurricane.ccp". + + extern PyTypeObject PyTypePlacementStatus; + extern PyMethodDef PyPlacementStatus_Methods[]; + + extern PyObject* PyPlacementStatus_Link ( Hurricane::Instance::PlacementStatus* ); + extern void PyPlacementStatus_LinkPyType (); + extern void PyPlacementStatus_postModuleInit (); + + +#define IsPyPlacementStatus(v) ( (v)->ob_type == &PyTypePlacementStatus ) +#define PYPLACEMENTSTATUS(v) ( (PyPlacementStatus*)(v) ) +#define PYPLACEMENTSTATUS_O(v) ( PYPLACEMENTSTATUS(v)->_object ) + + + } // End of extern "C". + +} // End of Isobar namespace. + +#endif // PY_PLACEMENTSTATUS_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyPoint.h b/hurricane/src/isobar/hurricane/isobar/PyPoint.h index 71f5e0dd..9c8adad4 100644 --- a/hurricane/src/isobar/hurricane/isobar/PyPoint.h +++ b/hurricane/src/isobar/hurricane/isobar/PyPoint.h @@ -1,92 +1,46 @@ - // -*- C++ -*- // -// This file is part of the Coriolis Project. -// Copyright (C) Laboratoire LIP6 - Departement ASIM -// Universite Pierre et Marie Curie +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved // -// Main contributors : -// Christophe Alexandre -// Sophie Belloeil -// Hugo Clément -// Jean-Paul Chaput -// Damien Dupuis -// Christian Masson -// Marek Sroka -// -// 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: PyPoint.h,v 1.6 2006/05/03 14:00:04 jpc Exp $ -// -// x-----------------------------------------------------------------x -// | | +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | // | Author : Jean-Paul CHAPUT | -// | E-mail : Jean-Paul.Chaput@asim.lip6.fr | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Header : "./PyPoint.h" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Header : "./hurricane/isobar/PyPoint.h" | +// +-----------------------------------------------------------------+ - - - -# ifndef __PYPOINT__ -# define __PYPOINT__ - +#ifndef PY_POINT_H +#define PY_POINT_H #include "hurricane/isobar/PyHurricane.h" - #include "hurricane/Point.h" namespace Isobar { - -extern "C" { - + extern "C" { // ------------------------------------------------------------------- // Python Object : "PyPoint". - typedef struct { - PyObject_HEAD - Hurricane::Point* _object; - } PyPoint; - - + typedef struct { + PyObject_HEAD + Hurricane::Point* _object; + } PyPoint; // ------------------------------------------------------------------- // Functions & Types exported to "PyHurricane.ccp". - extern PyTypeObject PyTypePoint; - extern PyMethodDef PyPoint_Methods[]; + extern PyTypeObject PyTypePoint; + extern PyMethodDef PyPoint_Methods[]; - extern PyObject* PyPoint_create ( PyObject* self, PyObject* args ); - extern void PyPoint_LinkPyType(); + extern void PyPoint_LinkPyType(); # define IsPyPoint(v) ( (v)->ob_type == &PyTypePoint ) @@ -94,14 +48,8 @@ extern "C" { # define PYPOINT_O(v) ( PYPOINT(v)->_object ) -} // End of extern "C". + } // extern "C". +} // Isobar namespace. - - -} // End of Isobar namespace. - - - - -# endif +#endif // PY_POINT_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyReference.h b/hurricane/src/isobar/hurricane/isobar/PyReference.h index 47c09079..971eda08 100644 --- a/hurricane/src/isobar/hurricane/isobar/PyReference.h +++ b/hurricane/src/isobar/hurricane/isobar/PyReference.h @@ -1,91 +1,47 @@ - // -*- C++ -*- // -// This file is part of the Coriolis Project. -// Copyright (C) Laboratoire LIP6 - Departement ASIM -// Universite Pierre et Marie Curie +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2008-2014, All Rights Reserved // -// Main contributors : -// Christophe Alexandre -// Sophie Belloeil -// Hugo Clément -// Jean-Paul Chaput -// Damien Dupuis -// Christian Masson -// Marek Sroka -// -// 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: PyReference.h,v 1.2 2006/05/03 14:00:04 jpc Exp $ -// -// x-----------------------------------------------------------------x -// | | +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | -// | Author : Jean-Paul Chaput | -// | E-mail : Jean-Paul.Chaput@asim.lip6.fr | +// | Author : Jean-Paul CHAPUT | +// | E-mail : Jean-Paul.Chaput@asim.lip6.fr | // | =============================================================== | -// | C++ Header : "./PyReference.h" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Header : "./hurricane/isobar/PyReference.cpp" | +// +-----------------------------------------------------------------+ - - - -#ifndef __PYREFERENCE__ -#define __PYREFERENCE__ - +#ifndef PY_REFERENCE_H +#define PY_REFERENCE_H #include "hurricane/isobar/PyEntity.h" - #include "hurricane/Reference.h" namespace Isobar { -extern "C" { + extern "C" { // ------------------------------------------------------------------- // Python Object : "PyReference". - typedef struct { - PyEntity _baseObject; - } PyReference; - - + typedef struct { + PyEntity _baseObject; + } PyReference; // ------------------------------------------------------------------- // Functions & Types exported to "PyHurricane.ccp". - extern PyTypeObject PyTypeReference; - extern PyMethodDef PyReference_Methods[]; + extern PyTypeObject PyTypeReference; + extern PyMethodDef PyReference_Methods[]; - extern PyObject* PyReference_create ( PyObject* module, PyObject* args ); - extern PyObject* PyReference_Link ( Hurricane::Reference* object ); - extern void PyReference_LinkPyType (); + extern PyObject* PyReference_Link ( Hurricane::Reference* object ); + extern void PyReference_LinkPyType (); @@ -94,14 +50,8 @@ extern "C" { #define PYREFERENCE_O(v) (PYREFERENCE(v)->_baseObject._object) -} // End of extern "C". - - - - -} // End of Isobar namespace. - - + } // extern "C". +} // Isobar namespace. #endif diff --git a/hurricane/src/isobar/hurricane/isobar/PyTransformation.h b/hurricane/src/isobar/hurricane/isobar/PyTransformation.h index 4c1ff05f..7ef7d8ae 100644 --- a/hurricane/src/isobar/hurricane/isobar/PyTransformation.h +++ b/hurricane/src/isobar/hurricane/isobar/PyTransformation.h @@ -1,93 +1,49 @@ - // -*- C++ -*- // -// This file is part of the Coriolis Project. -// Copyright (C) Laboratoire LIP6 - Departement ASIM -// Universite Pierre et Marie Curie +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2006-2014, All Rights Reserved // -// Main contributors : -// Christophe Alexandre -// Sophie Belloeil -// Hugo Clément -// Jean-Paul Chaput -// Damien Dupuis -// Christian Masson -// Marek Sroka -// -// 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: PyTransformation.h,v 1.6 2006/05/03 14:00:05 jpc Exp $ -// -// x-----------------------------------------------------------------x -// | | +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | // | Author : Jean-Paul CHAPUT | -// | E-mail : Jean-Paul.Chaput@asim.lip6.fr | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Header : "./PyTransformation.h" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Header : "./hurricane/isobar/PyTransformation.h" | +// +-----------------------------------------------------------------+ - - - -#ifndef __PYTRANSFORMATION__ -#define __PYTRANSFORMATION__ +#ifndef PY_TRANSFORMATION_H +#define PY_TRANSFORMATION_H #include "hurricane/isobar/PyHurricane.h" - #include "hurricane/Transformation.h" namespace Isobar { - -extern "C" { + extern "C" { // ------------------------------------------------------------------- // Python Object : "PyTransformation". - typedef struct { - PyObject_HEAD - Hurricane::Transformation* _object; - } PyTransformation; - - + typedef struct { + PyObject_HEAD + Hurricane::Transformation* _object; + } PyTransformation; // ------------------------------------------------------------------- // Functions & Types exported to "PyHurricane.ccp". - extern PyTypeObject PyTypeTransformation; - extern PyMethodDef PyTransformation_Methods[]; + extern PyTypeObject PyTypeTransformation; + extern PyMethodDef PyTransformation_Methods[]; - extern PyObject* PyTransformation_create (PyObject* self, PyObject* args); - extern void TransformationLoadConstants (PyObject* dictionnary); - extern void PyTransformation_LinkPyType (); + extern void PyTransformation_LinkPyType (); + extern void PyTransformation_postModuleInit (); # define IsPyTransformation(v) ( (v)->ob_type == &PyTypeTransformation ) @@ -95,8 +51,8 @@ extern "C" { # define PYTRANSFORMATION_O(v) ( PYTRANSFORMATION(v)->_object ) -} // End of extern "C". + } // extern "C". -} // End of Isobar namespace. +} // Isobar namespace. -#endif +#endif // PY_TRANSFORMATION_H diff --git a/hurricane/src/isobar/hurricane/isobar/PyVertical.h b/hurricane/src/isobar/hurricane/isobar/PyVertical.h index 0f86d265..b8870c35 100644 --- a/hurricane/src/isobar/hurricane/isobar/PyVertical.h +++ b/hurricane/src/isobar/hurricane/isobar/PyVertical.h @@ -1,108 +1,55 @@ - // -*- C++ -*- // -// This file is part of the Coriolis Project. -// Copyright (C) Laboratoire LIP6 - Departement ASIM -// Universite Pierre et Marie Curie +// This file is part of the Coriolis Software. +// Copyright (c) UPMC 2007-2014, All Rights Reserved // -// Main contributors : -// Christophe Alexandre -// Sophie Belloeil -// Hugo Clément -// Jean-Paul Chaput -// Damien Dupuis -// Christian Masson -// Marek Sroka -// -// 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: PyVertical.h,v 1.6 2007/01/30 14:47:25 cobell Exp $ -// -// x-----------------------------------------------------------------x -// | | +// +-----------------------------------------------------------------+ // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | -// | Author : Sophie BELLOEIL | -// | E-mail : Sophie.Belloeil@asim.lip6.fr | +// | Author : Sophie BELLOEIL | +// | E-mail : Jean-Paul.Chaput@lip6.fr | // | =============================================================== | -// | C++ Header : "./PyVertical.h" | -// | *************************************************************** | -// | U p d a t e s | -// | | -// x-----------------------------------------------------------------x +// | C++ Header : "./hurricane/isobar/PyVertical.h" | +// +-----------------------------------------------------------------+ - - - -#ifndef __PYVERTICAL__ -#define __PYVERTICAL__ - +#ifndef PY_VERTICAL_H +#define PY_VERTICAL_H #include "hurricane/isobar/PySegment.h" - #include "hurricane/Vertical.h" namespace Isobar { - -extern "C" { - + extern "C" { // ------------------------------------------------------------------- // Python Object : "PyVertical". - typedef struct { - PySegment _baseObject; - } PyVertical; - - + typedef struct { + PySegment _baseObject; + } PyVertical; // ------------------------------------------------------------------- // Functions & Types exported to "PyHurricane.ccp". - extern PyTypeObject PyTypeVertical; - extern PyMethodDef PyVertical_Methods[]; - - extern PyObject* PyVertical_create ( PyObject* module, PyObject* args ); - extern PyObject* PyVertical_Link ( Hurricane::Vertical* object ); - extern void PyVertical_LinkPyType (); + extern PyTypeObject PyTypeVertical; + extern PyMethodDef PyVertical_Methods[]; + extern PyObject* PyVertical_Link ( Hurricane::Vertical* object ); + extern void PyVertical_LinkPyType (); #define IsPyVertical(v) ((v)->ob_type == &PyTypeVertical) #define PYVERTICAL(v) ((PyVertical*)(v)) #define PYVERTICAL_O(v) (PYVERTICAL(v)->_baseObject._baseObject._baseObject._object) + + } // extern "C". + +} // Isobar namespace. -} // End of extern "C". - - - - -} // End of Isobar namespace. - - - - -#endif +#endif // PY_VERTICAL_H diff --git a/stratus1/src/stratus/st_instance.py b/stratus1/src/stratus/st_instance.py index b8114fd3..e0dbbd8b 100644 --- a/stratus1/src/stratus/st_instance.py +++ b/stratus1/src/stratus/st_instance.py @@ -208,10 +208,10 @@ class Inst : err = "\n[Stratus ERROR] HurricanePlug : Problem of hurricane cell.\nTry to contact Coriolis team.\n" raise Exception ( err ) - inst = Instance ( self._st_cell._hur_cell - , self._name - , self._hur_masterCell - ) + inst = Instance.create ( self._st_cell._hur_cell + , self._name + , self._hur_masterCell + ) # The hurricane instance is connected to the stratus instance self._hur_instance = inst diff --git a/stratus1/src/stratus/st_net.py b/stratus1/src/stratus/st_net.py index a292e178..f32c37fb 100644 --- a/stratus1/src/stratus/st_net.py +++ b/stratus1/src/stratus/st_net.py @@ -934,24 +934,24 @@ class net : self._hur_net += [cat[0]._hur_net[cat[1]]] return - net = Net ( self._st_cell._hur_cell, name ) + net = Net.create ( self._st_cell._hur_cell, name ) - net.setType ( TypeLOGICAL ) + net.setType ( Net.Type.LOGICAL ) if self._ext : net.setExternal ( True ) else : net.setExternal ( False ) if self._ext : - if self._direct == "IN" : net.setDirection ( DirectionIN ) - elif self._direct == "OUT" : net.setDirection ( DirectionOUT ) - elif self._direct == "INOUT" : net.setDirection ( DirectionINOUT ) - elif self._direct == "TRISTATE" : net.setDirection ( DirectionTRISTATE ) - elif self._direct == "UNKNOWN" : net.setDirection ( DirectionUNDEFINED ) + if self._direct == "IN" : net.setDirection ( Net.Direction.IN ) + elif self._direct == "OUT" : net.setDirection ( Net.Direction.OUT ) + elif self._direct == "INOUT" : net.setDirection ( Net.Direction.INOUT ) + elif self._direct == "TRISTATE" : net.setDirection ( Net.Direction.TRISTATE ) + elif self._direct == "UNKNOWN" : net.setDirection ( Net.Direction.UNDEFINED ) if '_h_type' in self.__dict__ : - if self._h_type == "POWER" : net.setType ( TypePOWER ) - elif self._h_type == "GROUND" : net.setType ( TypeGROUND ) - elif self._h_type == "CLOCK" : net.setType ( TypeCLOCK ) + if self._h_type == "POWER" : net.setType ( Net.Type.POWER ) + elif self._h_type == "GROUND" : net.setType ( Net.Type.GROUND ) + elif self._h_type == "CLOCK" : net.setType ( Net.Type.CLOCK ) self._hur_net += [net] @@ -1015,15 +1015,15 @@ class net : else : self._ext = False if hur_net.isExternal() : - if hur_net.getDirection() == DirectionIN : self._direct = "IN" - elif hur_net.getDirection() == DirectionOUT : self._direct = "OUT" - elif hur_net.getDirection() == DirectionINOUT : self._direct = "INOUT" - elif hur_net.getDirection() == DirectionTRISTATE : self._direct = "TRISTATE" - elif hur_net.getDirection() == DirectionUNDEFINED : self._direct = "UNDEFINED" + if hur_net.getDirection() == Net.Direction.IN : self._direct = "IN" + elif hur_net.getDirection() == Net.Direction.OUT : self._direct = "OUT" + elif hur_net.getDirection() == Net.Direction.INOUT : self._direct = "INOUT" + elif hur_net.getDirection() == Net.Direction.TRISTATE : self._direct = "TRISTATE" + elif hur_net.getDirection() == Net.Direction.UNDEFINED : self._direct = "UNDEFINED" - if hur_net.getType() == TypePOWER : self._h_type = "POWER" - elif hur_net.getType() == TypeGROUND : self._h_type = "GROUND" - elif hur_net.getType() == TypeCLOCK : self._h_type = "CLOCK" + if hur_net.getType() == Net.Type.POWER : self._h_type = "POWER" + elif hur_net.getType() == Net.Type.GROUND : self._h_type = "GROUND" + elif hur_net.getType() == Net.Type.CLOCK : self._h_type = "CLOCK" self._hur_net = [hur_net] diff --git a/stratus1/src/stratus/st_placement.py b/stratus1/src/stratus/st_placement.py index 052e973f..3a861da1 100644 --- a/stratus1/src/stratus/st_placement.py +++ b/stratus1/src/stratus/st_placement.py @@ -390,7 +390,7 @@ def placement ( st_inst, sym, x, y, plac = FIXED, cell = None, fonction = None ) raise Exception ( err ) # Error : if the instance is already placed - if hur_inst.getPlacementStatus() == PlacementStatusFIXED : + if hur_inst.getPlacementStatus() == Instance.PlacementStatus.FIXED : err = "\n[Stratus ERROR] Placement : the instance " + st_inst._name + " is already placed.\n" raise Exception ( err ) @@ -409,45 +409,45 @@ def placement ( st_inst, sym, x, y, plac = FIXED, cell = None, fonction = None ) cell._insref = st_inst ##### Placement ##### - if st_inst._sym == OrientationID : + if st_inst._sym == Transformation.Orientation.ID : st_inst._x = x st_inst._y = y - elif st_inst._sym == OrientationMX : + elif st_inst._sym == Transformation.Orientation.MX : abtemp = ab ( st_inst, cell ) st_inst._x = x + abtemp.getWidth () st_inst._y = y - elif st_inst._sym == OrientationMY : + elif st_inst._sym == Transformation.Orientation.MY : abtemp = ab ( st_inst, cell ) st_inst._x = x st_inst._y = y + abtemp.getHeight () - elif st_inst._sym == OrientationR2 : + elif st_inst._sym == Transformation.Orientation.R2 : abtemp = ab ( st_inst, cell ) st_inst._x = x + abtemp.getWidth () st_inst._y = y + abtemp.getHeight () - elif st_inst._sym == OrientationR1 : + elif st_inst._sym == Transformation.Orientation.R1 : abtemp = ab ( st_inst, cell ) st_inst._x = x + abtemp.getHeight () st_inst._y = y - elif st_inst._sym == OrientationR3 : + elif st_inst._sym == Transformation.Orientation.R3 : abtemp = ab ( st_inst, cell ) st_inst._x = x st_inst._y = y + abtemp.getWidth () - elif st_inst._sym == OrientationYR : + elif st_inst._sym == Transformation.Orientation.YR : st_inst._x = x st_inst._y = y - elif st_inst._sym == OrientationXR : + elif st_inst._sym == Transformation.Orientation.XR : abtemp = ab ( st_inst, cell ) st_inst._x = x + abtemp.getHeight () @@ -457,7 +457,7 @@ def placement ( st_inst, sym, x, y, plac = FIXED, cell = None, fonction = None ) raise Exception ( "\n[Stratus ERROR] Placement : wrong transformation.\n" ) # if the abutment box is not at 0 0 FIXME - if st_inst._sym == OrientationMY : + if st_inst._sym == Transformation.Orientation.MY : x = st_inst._x + hur_inst.getAbutmentBox().getXMin() y = st_inst._y + hur_inst.getAbutmentBox().getYMin() else : @@ -470,12 +470,12 @@ def placement ( st_inst, sym, x, y, plac = FIXED, cell = None, fonction = None ) if plac == PLACED : cell._hur_cell.setAbutmentBox ( cell._hur_cell.getAbutmentBox ().merge ( hur_inst.getAbutmentBox () ) ) - hur_inst.setPlacementStatus ( PlacementStatusPLACED ) + hur_inst.setPlacementStatus ( Instance.PlacementStatus.PLACED ) elif plac == FIXED : cell._hur_cell.setAbutmentBox ( cell._hur_cell.getAbutmentBox ().merge ( hur_inst.getAbutmentBox () ) ) - hur_inst.setPlacementStatus ( PlacementStatusFIXED ) + hur_inst.setPlacementStatus ( Instance.PlacementStatus.FIXED ) elif plac == UNPLACED : - hur_inst.setPlacementStatus ( PlacementStatusUNPLACED ) + hur_inst.setPlacementStatus ( Instance.PlacementStatus.UNPLACED ) else : raise Exception ( "\n[Stratus ERROR] Placement : wrong argument for type of placement.\n" ) @@ -486,14 +486,14 @@ def placement ( st_inst, sym, x, y, plac = FIXED, cell = None, fonction = None ) ## Two names for the symetry ## def transformation ( symetry ) : - if symetry == NOSYM or symetry == OrientationID : transf = OrientationID - elif symetry == SYM_X or symetry == OrientationMX : transf = OrientationMX - elif symetry == SYM_Y or symetry == OrientationMY : transf = OrientationMY - elif symetry == SYMXY or symetry == OrientationR2 : transf = OrientationR2 - elif symetry == ROT_P or symetry == OrientationR1 : transf = OrientationR1 - elif symetry == ROT_M or symetry == OrientationR3 : transf = OrientationR3 - elif symetry == SY_RP or symetry == OrientationYR : transf = OrientationYR - elif symetry == SY_RM or symetry == OrientationXR : transf = OrientationXR + if symetry == NOSYM or symetry == Transformation.Orientation.ID : transf = Transformation.Orientation.ID + elif symetry == SYM_X or symetry == Transformation.Orientation.MX : transf = Transformation.Orientation.MX + elif symetry == SYM_Y or symetry == Transformation.Orientation.MY : transf = Transformation.Orientation.MY + elif symetry == SYMXY or symetry == Transformation.Orientation.R2 : transf = Transformation.Orientation.R2 + elif symetry == ROT_P or symetry == Transformation.Orientation.R1 : transf = Transformation.Orientation.R1 + elif symetry == ROT_M or symetry == Transformation.Orientation.R3 : transf = Transformation.Orientation.R3 + elif symetry == SY_RP or symetry == Transformation.Orientation.YR : transf = Transformation.Orientation.YR + elif symetry == SY_RM or symetry == Transformation.Orientation.XR : transf = Transformation.Orientation.XR else : err = "\n[Stratus ERROR] Placement :Illegal transformation.\n" raise Exception ( err ) @@ -519,19 +519,19 @@ def width ( ins ) : ## Test of symetry ## def vertical ( sym ) : - return sym == OrientationID or sym == OrientationMX or sym == OrientationMY or sym == OrientationR2 + return sym == Transformation.Orientation.ID or sym == Transformation.Orientation.MX or sym == Transformation.Orientation.MY or sym == Transformation.Orientation.R2 def horizontal ( sym ) : - return sym == OrientationR1 or sym == OrientationR3 or sym == OrientationYR or sym == OrientationXR + return sym == Transformation.Orientation.R1 or sym == Transformation.Orientation.R3 or sym == Transformation.Orientation.YR or sym == Transformation.Orientation.XR def bas ( sym ) : - return sym == OrientationID or sym == OrientationMX or sym == OrientationR1 or sym == OrientationYR + return sym == Transformation.Orientation.ID or sym == Transformation.Orientation.MX or sym == Transformation.Orientation.R1 or sym == Transformation.Orientation.YR def haut ( sym ) : - return sym == OrientationR2 or sym == OrientationMY or sym == OrientationR3 or sym == OrientationXR + return sym == Transformation.Orientation.R2 or sym == Transformation.Orientation.MY or sym == Transformation.Orientation.R3 or sym == Transformation.Orientation.XR def gauche ( sym ) : - return sym == OrientationID or sym == OrientationMY or sym == OrientationR3 or sym == OrientationYR + return sym == Transformation.Orientation.ID or sym == Transformation.Orientation.MY or sym == Transformation.Orientation.R3 or sym == Transformation.Orientation.YR def droite ( sym ) : - return sym == OrientationR2 or sym == OrientationMX or sym == OrientationR1 or sym == OrientationXR + return sym == Transformation.Orientation.R2 or sym == Transformation.Orientation.MX or sym == Transformation.Orientation.R1 or sym == Transformation.Orientation.XR