....................................../////.===Shadow-Here===./////................................................ > < > < > < > < > < > < > < > < > < > < > < > < > < > < > < > < > < > < > < > < > < > < > < > < > < > < > < > < > < ------------------------------------------------------------------------------------------------------------------- /////////////////////////////////////////////////////////////////////////////////////////////////////////////////// RIFF¤ WEBPVP8 ˜ ðÑ *ôô>‘HŸK¥¤"§£±¨àð enü¹%½_F‘åè¿2ºQú³íªú`N¿­3ÿƒügµJžaÿ¯ÿ°~¼ÎùnúîÞÖô•òíôÁÉß®Sm¥Ü/ ‡ó˜f£Ùà<˜„xëJ¢Ù€SO3x<ªÔ©4¿+ç¶A`q@Ì“Úñè™ÍÿJÌ´ª-˜ÆtÊÛL]Ïq*‘Ý”ì#ŸÌÏãY]@ê`¿ /ªfkØB4·®£ó z—Üw¥Pxù–ÞLШKÇN¾AkÙTf½è'‰g gÆv›Øuh~ a˜Z— ïj*á¥t d£“uÒ ¨`K˜¹ßþ]b>˜]_ÏÔ6W—è2r4x•íÖ…"ƒÖNîä!¦å Ú}ýxGøÌ —@ ;ÆÚŠ=ɾ1ý8lªË¥ô ^yf®Œ¢u&2©nÙÇ›ñÂñŒ³ aPo['½»øFùà­+4ê“$!lövlüÞ=;N®3ð‚õ›DÉKòÞ>ÄÍ ¥ˆuߤ#ˆ$6ù™¥îЇy’ÍB¼ çxÛ;X"WL£R÷͝*ó-¶Zu}º.s¸sšXqù–DþÿvªhüïwyŸ ¯é³lÀ:KCûÄ£Ëá\…­ ~—ýóî ¼ûûÜTÓüÇy…ŽÆvc»¾×U ñ¸žþоP÷¦ó:Ò¨¨5;Ð#&#ÖúñläÿÁœ GxÉ­/ñ‡áQðìYÉtÒw޼GÔ´zàÒò ð*ëzƒ•4~H]Ø‹f ñÓÈñ`NåWçs'ÆÏW^ø¹!XžµmQ5ÃËoLœÎ: ÞËÍ¥J ù…î èo£ßPÎñ¶ž8.Œ]ʵ~5›ÙË-ù*8ÙÖß±~ ©¹rÓê‚j¶d¸{^Q'˜±Crß ÚH—#¥¥QlÀ×ëã‡DÜ«èî þ&Çæžî;ŽÏºò6ÒLÃXy&ZŒ'j‚¢Ù€IßÚù+–MGi‰*jE€‘JcÜ ÓÌ EÏÚj]o˜ Þr <¾U ûŪæÍ/šÝH¥˜b”¼ ÁñßX GP›ï2›4WŠÏà×£…íÓk†¦H·ÅíMh–*nó÷à]ÁjCº€b7<ب‹¨5車bp2:Á[UªM„QŒçiNMa#<5›áËó¸HýÊ"…×Éw¹¦ì2º–x<›»a±¸3Weü®FÝ⑱ö–î–³|LPÈ~çð~Çå‡|º kD¢µÏàÆAI %1À% ¹Ò – ”ϝS¦‰4&¶£°à Öý”û_Ò Áw°A«Å€?mÇÛgHÉ/8)á¾ÛìáöŽP í¨PŸNÙµº¦‡§Ùš"ÿ«>+ªÕ`Ê÷‡‚ß Õû˜þãÇ-PÍ.¾XV‘€ dÜ"þ4¹ ±Oú‘©t¥¦FªÄÃÄ•b‚znýu½—#cDs˜ÃiÑOˆñ×QO=*IAÊ,¶ŽZƒ;‡wøXè%EÐk:F±Ú” .Ѽ+Áu&Ç`."pÈÉw o&¿dE6‘’EqTuK@Ì¥ã™À(Êk(h‰,H}RÀIXÛš3µ1©_OqÚÒJAñ$ÊÙÜ;D3çŒ[þùœh¬Ã³™ö6ç†NY".Ú‰ï[ªŸŒ '²Ð öø_¨ÂÉ9ué¶³ÒŠõTàîMØ#û¯gN‡bÙ놚X„ö …ÉeüÌ^J ‹€.œ$Æ)βÄeæW#óüßĺŸ€ ÀzwV 9oä»f4V*uB «Ë†¹ì¯žR霓æHXa=&“I4K;¯ç‹h×·"UŠ~<•╪Vêª&ÍSÃÆÅ?ÔqÎ*mTM ˜›µwêd#[C¡©§‘D<©àb†–ÁœøvH/,í:¯( ²£|4-„Æövv„Yͼ™^Á$ˆ„¢Û[6yB.åH*V¨æ?$=˜Ñ€•ñ·­(VlŸ‘ nÀt8W÷´Bûba?q9ú¶Xƒl«ÿ\ù¶’þòUÐj/õ¢Ìµ³g$ƒÎR!¸»|Oߍë’BhîÚÑ¢ñåŒJ„®„£2Ð3•ô02Nt…!£Í]Ïc½Qÿ?ˆ<&ÃA¾Ú,JˆijÌ#5yz„‰Î|ÊŽ5QÏ:‹ÐaóVÔxW—CpeÏzÐïíçôÿÅ_[hãsÐ_/ŽTÝ?BîˆííV$<¿i>²F¬_Eß¿ †bÊŒº­ÿ®Z H“C}”¬,Mp ý/Bá£w>˜YV°aƒúh+cŠ- r/[%|üUMHäQ°X»|û/@|°¥Ð !BÔ Ç¢Ä©š+Õì D«7ìN¶ŽðÔ " ƶ’ÖçtA‰Û×}{tþz­¾GÍ›k¹OEJR$ Â׃ «ëÁ"oÉôž$oUK(Ä)Ãz³Ê-‹êN[Ò3Œñbï8P 4ƒ×q¢bo|?<ÛX¬òÄͰL–±›(™ûG?ýË©ÚÄ–ÂDØÐ_Ç¡ô ¾–ÄÏø ×e8Ë©$ÄF¹Å‹ì[©óìl:F¾f´‹‹Xì²ï®\¬ôùƒ ÿat¥óèÒùHß0äe‚;ü×h:ÆWðHž=Ã8骣"kœ'Y?³}Tûè€>?0l›e1Lòñ„aæKÆw…hÖŠùW…ÈÆÄ0ši·›[pcwËþñiêíY/~-Á5˜!¿†A›™Mÿþ(±“t@â“ö2­´TG5yé]çå僳 .·ÍïçÝ7UÚ±Ð/Nè»,_Ï ùdj7\ï Wì4›„»c¸àešg#ÒÊ⥭áØo5‘?ÌdÝô¯ ¹kzsƒ=´#ëÉK›Ø´±-¥eW?‡çßtòTã…$Ý+qÿ±ƒ÷_3Ô¥í÷:æ–ž<·Ö‡‰Å¢ š‡%Ô—utÌÈìðžgÖÀz²À—ï÷Óîäõ{K'´È÷³yaÏÁjƒô}ž§®æÊydÕÈë5¯èˆõvÕ©ã*çD„ “z„Ó‡^^xÂ3M§A´JG‚öï 3W'ˆ.OvXè¡ÊÕª?5º7†˜(˜Ç¶#çê’¶!ÌdZK§æ 0fãaN]òY³RV ™î$®K2R¨`W!1Ôó\;Ý ýB%qæK•&ÓÈe9È0êI±žeŸß -ú@žQr¦ ö4»M¼Áè¹µmw 9 EÆE_°2ó„ŸXKWÁ×Hóì^´²GѝF©óäR†¦‰ç"V»eØ<3ùd3ÿÚ¤Žú“Gi" —‘_ÙËÎ~Üö¯¥½Î»üŸEÚŽåmÞþí ;ÞólËΦMzA"Âf(´òá;Éï(/7½ûñÌ­cïÕçлþÝz¾-ÍvÑ“pH­–ðÓj$¸Äû¤‚‘ãUBË-n“2åPkS5&‹Â|+g^œ®Ì͆d!OïäîU«c;{Û!ÅŽ«ëZ9Ókóˆ]¯ƒ›né `ÇÒ+tÆš (ØKá¾—=3œ®•vuMñg²\ï Ec€ 05±d™‡×iÇ×›UúvÌ¢£Èþ¡ÕØô¶ßÎA"ß±#Ö²ˆÊŸ¦*Ä~ij|àø.-¼'»Ú¥£h ofº¦‡VsR=N½„Î v˜Z*SÌ{=jÑB‹tê…;’HžH¯8–îDù8ñ¢|Q•bÛçš–‹m³“ê¨ åÏ^m¬Žãþ©ïêO‡½6] µÆ„Ooòü ²x}N¦Ë3ïé¿»€›HA˜m%çÞ/¿í7Fø“‹léUk)É°Œµ8Q8›:ÀŠeT*šõ~ôڝG6 ¢}`ùH­–”¡k ‰P1>š†®9z11!X wKfmÁ¦xÑ,N1Q”–æB¶M…ÒÃv6SMˆhU¬ÊPŽï‘öj=·CŒ¯u¹ƒVIЃsx4’ömÛýcå¡¶7ßŠß 57^\wÒÐÆ k§h,Œý î«q^R½3]J¸ÇðN ‚çU¬ôº^Áì} ³f©Õœ§ˆã:FÄÈ‚é(€™?àýÓüè1Gô£¼éj‚OÅñ  #>×—ßtà 0G¥Åa뀐kßhc™À_ÉñÞ#±)GD" YîäË-ÿÙ̪ ¹™a¯´¢E\ÝÒö‚;™„ë]_ p8‰o¡ñ+^÷ 3‘'dT4œŽ ðVë½° :¬víÑ«£tßÚS-3¶“þ2 †üüʨòrš¹M{É_¤`Û¨0ìjœøJ‡:÷ÃáZ˜†@GP&œÑDGÏs¡þ¦þDGú‘1Yá9Ôþ¼ ûø…§÷8&–ÜÑnÄ_m®^üÆ`;ÉVÁJ£?â€-ßê}suÍ2sõA NÌúA磸‘îÿÚ»ƒìö·á¿±tÑÐ"Tÿü˜[@/äj¬€uüªìù¥Ý˜á8Ý´sõj 8@rˆð äþZÇD®ÿUÏ2ùôõrBzÆÏÞž>Ì™xœ“ wiÎ×7_… ¸ \#€MɁV¶¥üÕÿPÔ9Z‡ø§É8#H:ƒ5ÀÝå9ÍIŒ5åKÙŠ÷qÄ>1AÈøžj"µÂд/ªnÀ qªã}"iŸBå˜ÓÛŽ¦…&ݧ;G@—³b¯“•"´4í¨ôM¨åñC‹ïùÉó¯ÓsSH2Ý@ßáM‡ˆKÀªÛUeø/4\gnm¥‹ŸŒ qÄ b9ÞwÒNÏ_4Ég³ú=܆‚´ •â¥õeíþkjz>éÚyU«Íӝ݃6"8/ø{=Ô¢»G¥ äUw°W«,ô—¿ãㆅү¢³xŠUû™yŒ (øSópÐ 9\åTâ»—*oG$/×ÍT†Y¿1¤Þ¢_‡ ¼ „±ÍçèSaÓ 3ÛMÁBkxs‰’R/¡¤ˆÙçª(*õ„üXÌ´ƒ E§´¬EF"Ù”R/ÐNyÆÂ^°?™6¡œïJ·±$§?º>ÖüœcNÌù¯G ‹ñ2ЁBB„^·úìaz¨k:#¨Æ¨8LÎõލ£^§S&cŒÐU€ü(‡F±Š¼&P>8ÙÁ ‰ p5?0ÊÆƒZl¸aô š¼¡}gÿ¶zÆC²¹¬ÎÖG*HB¡O<º2#ñŒAƒ–¡B˜´É$¥›É:FÀÔx¾u?XÜÏÓvN©RS{2ʈãk9rmP¼Qq̳ è¼ÐFׄ^¡Öì fE“F4A…!ì/…¦Lƒ… … $%´¾yã@CI¬ á—3PþBÏNÿ<ý°4Ü ËÃ#ØÍ~âW«rEñw‹eùMMHß²`¬Öó½íf³:‹k˜¯÷}Z!ã¿<¥,\#öµÀ¯aÒNÆIé,Ћ–lŽ#Àæ9ÀÒS·I’½-Ïp Äz¤Š Â* ­íÄ9­< h>׍3ZkËU¹§˜ŒŠ±f­’¤º³Q ÏB?‹#µíÃ¥®@(Gs«†vI¥Mµ‹Á©e~2ú³ÁP4ìÕi‚²Ê^ö@-DþÓàlÜOÍ]n"µã:žpsŽ¢:! Aõ.ç~ÓBûH÷JCÌ]õVƒd «ú´QÙEA–¯¯Œ!.ˆˆëQ±ù œ·Ì!Õâ )ùL„ÅÀlÚè5@B…o´Æ¸XÓ&Û…O«˜”_#‡ƒ„ûÈt!¤ÁÏ›ÎÝŠ?c9 â\>lÓÁVÄÑ™£eØY]:fÝ–—ù+p{™ðè û³”g±OƒÚSù£áÁÊ„ä,ï7š²G ÕÌBk)~ÑiCµ|h#u¤¶îK¨² #²vݯGãeÖ϶ú…¾múÀ¶þÔñ‚Š9'^($¤§ò “š½{éúp÷J›ušS¹áªCÂubÃH9™D™/ZöØÁ‡¦ÝÙŸ·kð*_”.C‹{áXó€‡c¡c€§/šò/&éš÷,àéJþ‰X›fµ“C¨œ®r¬"kL‰Â_q…Z–.ÉL~O µ›zn‚¹À¦Öª7\àHµšÖ %»ÇníV[¥*Õ;ƒ#½¾HK-ÖIÊdÏEÚ#=o÷Óò³´Š: Ç?{¾+9›–‘OEáU·S€˜j"ÄaÜ ŒÛWt› á–c#a»pÔZÞdŽtWê=9éöÊ¢µ~ ë ;Öe‡Œ®:bî3±ýê¢wà¼îpêñ¹¾4 zc¾ðÖÿzdêŒÑÒŝÀ‰s6¤í³ÎÙB¿OZ”+F¤á‡3@Ñëäg©·Ž ˆèª<ù@É{&S„œÕúÀA)‰h:YÀ5^ÂÓŒ°õäU\ ùËÍû#²?Xe¬tu‰^zÒÔãë¼ÛWtEtû …‚g¶Úüâî*moGè¨7%u!]PhÏd™Ý%Îx: VÒ¦ôÊD3ÀŽKÛËãvÆî…N¯ä>Eró–ð`5 Œ%u5XkñÌ*NU%¶áœÊ:Qÿú»“úzyÏ6å-၇¾ ´ ÒÊ]y žO‘w2Äøæ…H’²f±ÎÇ.ª|¥'gîV•Ü .̘¯€šòü¤U~Ù†*¢!?ò wý,}´°ÔÞnïoKq5µb!áÓ3"vAßH¡³¡·G(ÐÎ0Îò¼MG!/ài®@—¬04*`…«é8ªøøló“ˆÊ”èù¤…ßÊoÿé'ËuÌÖ5×È¡§ˆˆfŽë9}hìâ_!!¯  B&Ëö¶‰ÀAÙNVŸ Wh›¸®XÑJì¨ú“¿÷3uj²˜¨ÍÎìë±aúŠÝå¯ð*Ó¨ôJ“yºØ)m°WýOè68†ŸÏ2—‰Ïüꪫٚ¥‹l1 ø ÏÄFjêµvÌbü¦èÝx:X±¢H=MÐß—,ˆÉÇ´(9ú¾^ÅÚ4¿m‡$âX‘å%(AlZo@½¨UOÌÕ”1ø¸jÎÀÃÃ_ µ‘Ü.œº¦Ut: Æï’!=¯uwû#,“pþÇúŒø(é@?³ü¥‘Mo §—s@Œ#)§ŒùkL}NOÆêA›¸~r½¼ÙA—HJ«eˆÖ´*¡ÓpÌŸö.m<-"³ûÈ$¬_6­åf£ïÚâj1y§ÕJ½@dÞÁr&Í\Z%D£Íñ·AZ Û³øüd/ªAi†/Й~  ‡âĮҮÏh§°b—›Û«mJžòG'[ÈYýŒ¦9psl ýÁ ®±f¦x,‰½tN ‚Xª9 ÙÖH.«Lo0×?͹m¡å†Ѽ+›2ƒF ±Ê8 7Hցϓ²Æ–m9…òŸï]Â1äN†VLâCˆU .ÿ‰Ts +ÅÎx(%¦u]6AF Š ØF鈄‘ |¢¶c±soŒ/t[a¾–û:s·`i햍ê›ËchÈ…8ßÀUÜewŒðNOƒõD%q#éû\9¤x¹&UE×G¥ Í—™$ð E6-‡¼!ýpãÔM˜ Âsìe¯ñµK¢Ç¡ùôléœ4Ö£”À Š®Ðc ^¨À}ÙËŸ§›ºê{ÊuÉC ×Sr€¤’fÉ*j!úÓ’Gsùìoîßîn%ò· àc Wp÷$¨˜)û»H ×8ŽÒ€Zj¤3ÀÙºY'Ql¦py{-6íÔCeiØp‘‡XÊîÆUߢ܂ž£Xé¼Y8þ©ëgñß}é.ÎógÒ„ÃØËø¯»™§Xýy M%@NŠ À(~áÐvu7&•,Ù˜ó€uP‡^^®=_E„jt’ 403WebShell
403Webshell
Server IP : 198.54.126.4  /  Your IP : 216.73.216.24
Web Server : Apache
System : Linux host55.registrar-servers.com 4.18.0-513.18.1.lve.2.el8.x86_64 #1 SMP Sat Mar 30 15:36:11 UTC 2024 x86_64
User : aeaw ( 7508)
PHP Version : 8.1.33
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /opt/alt/python312/lib64/python3.12/__pycache__/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /opt/alt/python312/lib64/python3.12/__pycache__/trace.cpython-312.opt-1.pyc
�

4[Yh�r���dZddgZddlZddlZddlZddlZddlZddlZddlZddl	Z	ddl
Z
ddlZddlZddl
mZddlZdZGd�d�Zd	�Zd
�ZGd�d�Zd�Zd
�Zdd�Zd�ZGd�d�Zd�Zedk(re�yy)a�program/module to trace Python program or function execution

Sample use, command line:
  trace.py -c -f counts --ignore-dir '$prefix' spam.py eggs
  trace.py -t --ignore-dir '$prefix' spam.py eggs
  trace.py --trackcalls spam.py eggs

Sample use, programmatically
  import sys

  # create a Trace object, telling it what to ignore, and whether to
  # do tracing or line-counting or both.
  tracer = trace.Trace(ignoredirs=[sys.base_prefix, sys.base_exec_prefix,],
                       trace=0, count=1)
  # run the new command using the given tracer
  tracer.run('main()')
  # make a report, placing output in /tmp
  r = tracer.results()
  r.write_results(show_missing=True, coverdir="/tmp")
�Trace�CoverageResults�N)�	monotonicz#pragma NO COVERc��eZdZdd�Zd�Zy)�_IgnoreNc���|s
t�n
t|�|_|sgn,|D�cgc]!}tjj	|���#c}|_ddi|_ycc}w)Nz<string>�)�set�_mods�os�path�normpath�_dirs�_ignore)�self�modules�dirs�ds    �,/opt/alt/python312/lib64/python3.12/trace.py�__init__z_Ignore.__init__FsW��")�S�U�s�7�|��
�#�R�37�*9�37�a�+-�'�'�*:�*:�1�*=�37�*9��
�#�Q�(����*9s�&Ac��||jvr|j|S||jvrd|j|<y|jD]'}|j|dz�s�d|j|<y|�d|j|<y|jD]5}|j|tj
z�s�&d|j|<yd|j|<y)Nr	�.r)rr�
startswithrr�sep)r�filename�
modulename�modrs     r�namesz
_Ignore.namesLs�������%��<�<�
�+�+�����#�'(�D�L�L��$���:�:�C��$�$�S�3�Y�/�+,����Z�(��
���'(�D�L�L��$�����A��"�"�1�r�v�v�:�.�+,����Z�(���$%����Z� ���NN)�__name__�
__module__�__qualname__rr�rrrrEs��)�)rrc��tjj|�}tjj|�\}}|S)�,Return a plausible module name for the path.)rr
�basename�splitext)r
�baser�exts    r�_modnamer+ws5���7�7���D�!�D��G�G�$�$�T�*�M�H�c��Orc��tjj|�}d}tjD]m}tjj|�}|j	|�s�4|t|�tjk(s�Tt|�t|�kDs�l|}�o|r|t|�dzd}n|}tjj|�\}}|jtjd�}tjr |jtjd�}tjj|�\}}|jd�S)r&�r	Nr)rr
�normcase�sysr�lenr�
splitdrive�replace�altsepr(�lstrip)r
�comparepath�longest�dirr)�driverr*s        r�_fullmodnamer9~s���'�'�"�"�4�(�K��G��x�x���g�g���s�#���!�!�#�&�;�s�3�x�+@�B�F�F�+J��3�x�#�g�,�&���	���C��L�1�$�%�&�����'�'�$�$�T�*�K�E�4��<�<�����$�D�	�y�y��|�|�B�I�I�s�+���G�G�$�$�T�*�M�H�c��?�?�3��rc�4�eZdZ		dd�Zd�Zd�Zdd�Zd	d�Zy)
rNc��||_|j�i|_|jj�|_||_|j�i|_|jj�|_||_|j�i|_|jj�|_||_||_|j
r]	t|j
d�5}tj|�\}}}ddd�|j|j|||���yy#1swY�.xYw#tttf$r5}td|j
�d|��t j"��Yd}~yd}~wwxYw)N�rb)�callerszSkipping counts file �: ��file)�counts�copy�counter�calledfuncsr=�infile�outfile�open�pickle�load�update�	__class__�OSError�EOFError�
ValueError�printr/�stderr)rrArDrEr=rF�f�errs        rrzCoverageResults.__init__�s8������;�;���D�K��{�{�'�'�)���&������#�!�D���+�+�0�0�2�������<�<���D�L��|�|�(�(�*����������;�;�
N��$�+�+�t�,��39�;�;�q�>�0�F�K��-����D�N�N�6�;��N�P�Q��-�,���X�z�2�
N��)-���c�;�BE�*�*�N�N��
N�s0�D0�D$�7+D0�$D-�)D0�0E9�+E4�4E9c�J�|jd�xr|jd�S)z_Return True if the filename does not refer to a file
        we want to have reported.
        �<�>)r�endswith)rrs  r�is_ignored_filenamez#CoverageResults.is_ignored_filename�s%���"�"�3�'�B�H�,=�,=�c�,B�Brc��|j}|j}|j}|j}|j}|j}|D]}|j|d�||z||<�|D]}d||<�	|D]}d||<�	y)z.Merge in the data from another CoverageResultsrr	N)rArDr=�get)	r�otherrArDr=�other_counts�other_calledfuncs�
other_callers�keys	         rrJzCoverageResults.update�s��������&�&���,�,���|�|��!�-�-���
�
�
��C� �*�*�S�!�,�|�C�/@�@�F�3�K� �%�C� �K���%�!�C��G�C�L�!rc��|jrIt�td�|j}t|�D]\}}}td|�d|�d|����|jr�t�td�dx}}	t|j�D]\\\}
}}\}
}}|
|k7rt�td|
d�|
}d}	|
|
k7r|	|
k7rtd|
�|
}	td	|�d
|�d|�d
|����^i}|jD]0\}}|j|i�x}||<|j||f||<�2i}|j
�D�]U\}}|j|�r�|jd�r|d
d}|�Htjjtjj|��}t|�}n$|}tj|d��t|�}|rt!|�}ni}t#j$|�}tjj'||dz�}t)|d�5}t+j,|j.�\}}d
d
d
�|j1||||�\}}|s��8|s��<t3d|z|z�}||||f||<��X|r8|r6td�t|�D]}||\}}}}td||z��|j4rY	t)|j4d�5} t7j8|j|j|jf| d�d
d
d
�y
y
#1swY��xYw#1swYy
xYw#t:$r(}!td|!zt<j>��Yd
}!~!y
d
}!~!wwxYw)af
        Write the coverage results.

        :param show_missing: Show lines that had no hits.
        :param summary: Include coverage summary per module.
        :param coverdir: If None, the results of each module are placed in its
                         directory, otherwise it is included in the directory
                         specified.
        zfunctions called:z
filename: z, modulename: �, funcname: zcalling relationships:r-z***z  -->z    rz -> z.pycN���T)�exist_okz.coverr<�dzlines   cov%   module   (path)z%5d   %3d%%   %s   (%s)�wbr	z"Can't save counts files because %sr?) rDrO�sortedr=rArY�itemsrWrVrr
�dirname�abspathr+�makedirsr9�_find_executable_linenos�	linecache�getlines�joinrG�tokenize�detect_encoding�readline�write_results_file�intrFrH�dumprLr/rP)"r�show_missing�summary�coverdir�callsrr�funcname�lastfile�	lastcfile�pfile�pmod�pfunc�cfile�cmod�cfunc�per_file�lineno�	lines_hit�sums�countr7�lnotab�source�	coverpath�fp�encoding�_�n_hits�n_lines�percent�mrQrRs"                                  r�
write_resultszCoverageResults.write_results�sL������G��%�&��$�$�E�28��-�.��*�h��"�J��:�<�3@��<�<��G��*�+�#%�%�H�y��d�l�l�+�=�%�%��u�';��t�U��H�$��G��%���.�$�H� "�I��E�>�i�5�&8��'�5�)� %�I��d�E�4��G�H�,��� $����H�f�-5�\�\�(�B�-G�G�I���*� $���X�v�,>� ?�I�f��!,�
��'�~�~�/�O�H�e��'�'��1��� � ��(�#�C�R�=�����g�g�o�o�b�g�g�o�o�h�&?�@��%�h�/�
������C�$�/�)�(�3�
��1�(�;�����'�'��1�F������S�*�x�*?�@�I��h��%��&�6�6�r�{�{�C���!�&�"�5�5�i��6<�e�X�O�O�F�G��7��c�F�l�W�4�5��#*�G�Z��#I��Z� �; 0�@�t��2�3��D�\��9=�a��6���*�h��/�$�q�'�9�:�"��<�<�
S��$�,�,��-���K�K����d�.>�.>���� M� !�1�&�.�-��&�%��$.�-���
S��:�S�@�s�z�z�R�R��
S�sB�3#L;�"M�89M�1M�;M	�M�M�M�	N�M?�?Nc���	t|d|��}d	}d	}	|5t|d
�D]\}
}|
|vr"|j
d||
z�|	d
z
}	|d
z
}n4|
|vrt|vr|j
d�|d
z
}n|j
d
�|j
|jd����	ddd�|	|fS#t$r,}td|�d|�d�tj��Yd}~yd}~wwxYw#1swY|	|fSxYw)z'Return a coverage results file in path.�w�r�ztrace: Could not open z for writing: z - skippingr?N)rrrr	z%5d: z>>>>>> z       �)	rGrLrOr/rP�	enumerate�write�PRAGMA_NOCOVER�
expandtabs)rr
�linesr�r�r�rFrRr�r�r��lines            rrqz"CoverageResults.write_results_file(s��	��4��x�8�G�����
� )�%�� 3�����Y�&��M�M�'�I�f�,=�"=�>��a�K�F��q�L�G��v�%�n��.D��M�M�)�,��q�L�G��M�M�)�,��
�
�d�o�o�a�0�1�!4��"�w����1�	��26��=�DG�J�J�
P���	���"�w���s#�B2�BC*�2	C'�;"C"�"C'�*C6)NNNNN)TFN�N)r!r"r#rrWrJr�rqr$rrrr�s&��=A�'+�N�4C��$YS�vrc�X�i}tj|�D]\}}||vs�d||<�|S)z:Return dict where keys are lines in the line number table.r	)�dis�findlinestarts)�code�strs�linenosr�r�s     r�_find_lines_from_coder�Hs8���G��'�'��-�	��6�����G�F�O�.��Nrc��t||�}|jD]3}tj|�s�|j	t||���5|S)z<Return lineno dict for all code objects reachable from code.)r��	co_consts�inspect�iscoderJ�_find_lines)r�r�r��cs    rr�r�RsF��$�D�$�/�G��^�^���>�>�!���N�N�;�q�$�/�0���Nrc�`�i}tj}t||��5}tj|j
�}|D]S\}}}}	}
|tjk(r6|tjk(r#|\}}|	\}
}t||
dz�D]}d||<�	|}�U	ddd�|S#1swY|SxYw)z�Return a dict of possible docstring positions.

    The dict maps line numbers to strings.  There is an entry for
    line that contains only a string or a part of a triple-quoted
    string.
    r�r	N)�token�INDENTrGrn�generate_tokensrp�STRING�range)rr�r�
prev_ttyperQ�tok�ttype�tstr�start�endr��sline�scol�eline�ecol�is                r�
_find_stringsr�^s���	�A����J�	
�h��	*�a��&�&�q�z�z�2��-0�)�E�4���T�����$�����-�"'�K�E�4�"%�K�E�4�"�5�%�!�)�4�� ��!��5��J�.1�
+�
�H�
+�
�H�s�A8B#�#B-c�L�	tj|�5}|j�}|j}ddd�t|d�}t|�}t||�S#1swY�.xYw#t$r-}td|�d|��tj��icYd}~Sd}~wwxYw)zAReturn dict where keys are line numbers in the line number table.NzNot printing coverage data for r>r?�exec)rnrG�readr�rLrOr/rP�compiler�r�)rrQ�progr�rRr�r�s       rrjrjus����
�]�]�8�
$���6�6�8�D��z�z�H�%��4��6�*�D���8�,�D��t�T�"�"�%�
$����
�!)�3�0�7:�z�z�	C��	���s3�A-�A!�A-�!A*�&A-�-	B#�6"B�B#�B#c�^�eZdZ			dd�Zd�Zdd�Zd�Zd�Zd�Zd�Z	d	�Z
d
�Zd�Zd�Z
d
�Zy)rNc
��||_||_t||�|_i|_i|_d|_||_i|_i|_	i|_
d|_|	rt�|_|r|j|_y|r|j|_y|r%|r#|j |_|j"|_y|r#|j |_|j&|_y|r#|j |_|j(|_yd|_y)ax
        @param count true iff it should count number of times each
                     line is executed
        @param trace true iff it should print out each line that is
                     being counted
        @param countfuncs true iff it should just output a list of
                     (filename, modulename, funcname,) for functions
                     that were called at least once;  This overrides
                     `count' and `trace'
        @param ignoremods a list of the names of modules to ignore
        @param ignoredirs a list of the names of directories to ignore
                     all of the (recursive) contents of
        @param infile file from which to read stored counts to be
                     added into the results
        @param outfile file in which to write the results
        @param timing true iff timing information be displayed
        rNr	)rErFr�ignorerA�pathtobasename�	donothing�trace�_calledfuncs�_callers�
_caller_cache�
start_time�_time�globaltrace_trackcallers�globaltrace�globaltrace_countfuncs�globaltrace_lt�localtrace_trace_and_count�
localtrace�localtrace_trace�localtrace_count)
rr�r��
countfuncs�countcallers�
ignoremods�
ignoredirsrErF�timings
          rrzTrace.__init__�s���(�������j�*�5������ ��������
������
��������#�g�D�O��#�<�<�D��
�#�:�:�D��
�u�#�2�2�D��"�=�=�D�O�
�#�2�2�D��"�3�3�D�O�
�#�2�2�D��"�3�3�D�O��D�Nrc�J�ddl}|j}|j|||�y)Nr)�__main__�__dict__�runctx)r�cmdr��dicts    r�runz	Trace.run�s ���� � �����C��t�$rc��|�i}|�i}|js>tj|j�t	j|j�	t|||�|js+t	jd�tjd�yy#|js+t	jd�tjd�wwxYwr�)r��	threading�settracer�r/r�)rr��globals�localss    rr�zTrace.runctx�s����?�b�G��>�B�6��~�~����t�/�/�0��L�L��)�)�*�	)���g�v�&��>�>����T�"��"�"�4�(�"��4�>�>����T�"��"�"�4�(�"�s�
B�9Cc��d}|jstj|j�	||i|��}|jstjd�|S#|jstjd�wwxYwr�)r�r/r�r�)r�func�args�kw�results     r�runfuncz
Trace.runfunc�sh�����~�~��L�L��)�)�*�	#��4�&�2�&�F��>�>����T�"��
���>�>����T�"�"�s�A�$A>c���|j}|j}|rt|�}nd}|j}d}||jvr |j|��|j|}n�d|j|<tj|�D�cgc]}tj|�r|��}}t|�dk(r�tj|d�D�	cgc]}	t|	t�r|	��}
}	t|
�dk(r]tj|
d�D�cgc]}t|d�r|��}}t|�dk(r|dj}||j|<|�|�d|��}|||fScc}wcc}	wcc}w)Nr	r�	__bases__r)�f_code�co_filenamer+�co_namer��gc�
get_referrersr��
isfunctionr0�
isinstancer��hasattrr!)
r�framer�rrrx�clsnamerQ�funcsr�dictsr��classess
             r�file_module_function_ofzTrace.file_module_function_of�s����|�|���#�#���!�(�+�J��J��<�<�����4�%�%�%��!�!�$�'�3��,�,�T�2��'+�D���t�$�!#� 0� 0�� 6�3� 6�1�#�.�.�q�1�� 6�E�3�
�5�z�Q��$&�$4�$4�U�1�X�$>�5�$>�q� *�1�d� 3��$>��5��u�:��?�*,�*:�*:�5��8�*D�?�*D�Q�&-�a��&=� !�*D�G�?��7�|�q�(�")�!�*�"5�"5��
4;��*�*�4�0���")�8�4�H���X�-�-��-3��5��?s�E'�E,�E1c��|dk(r>|j|�}|j|j�}d|j||f<yy)zkHandler for call events.

        Adds information about who called who to the self._callers dict.
        �callr	N)r��f_backr�)rr��why�arg�	this_func�parent_funcs      rr�zTrace.globaltrace_trackcallers�sG��
�&�=��4�4�U�;�I��6�6�u�|�|�D�K�67�D�M�M�;�	�2�3�	rc�P�|dk(r!|j|�}d|j|<yy)zoHandler for call events.

        Adds (filename, modulename, funcname) to the self._calledfuncs dict.
        r�r	N)r�r�)rr�r�r�r�s     rr�zTrace.globaltrace_countfuncss0��
�&�=��4�4�U�;�I�+,�D���i�(�rc�$�|dk(r�|j}|jjdd�}|r`t|�}|�R|jj||�}|s3|jrtd|�d|j���|jSyyyy)z�Handler for call events.

        If the code block being entered is to be ignored, returns `None',
        else returns self.localtrace.
        r��__file__Nz --- modulename: r`)
r��	f_globalsrYr+r�rr�rOr�r�)rr�r�r�r�rr�	ignore_its        rr�zTrace.globaltrace_lts����&�=��<�<�D����*�*�:�t�<�H��&�h�/�
��)� $��� 1� 1�(�J� G�I�$��:�:�!�&0�$�,�,�$@�B�#���.�	%�*��rc��|dk(r�|jj}|j}||f}|jj	|d�dz|j|<|j
r%t
dt�|j
z
zd��tjj|�}tj||�}t
d||fzd��|rt
d	|d��|jSt
�|jS)
Nr�rr	�%.2f� �r��%s(%d)r-r>)r�r��f_linenorArYr�rOr�rr
r'rk�getliner�)	rr�r�r�rr�r^�bnamer�s	         rr�z Trace.localtrace_trace_and_count's����&�=��|�|�/�/�H��^�^�F��F�"�C�#�{�{���s�A�6��:�D�K�K�������f���$�/�/� 9�:��D��G�G�$�$�X�.�E��$�$�X�v�6�D��(�e�V�_�,�"�5���d�D�b�)����������rc��|dk(r�|jj}|j}|jr%t	dt�|jz
zd��tjj|�}tj||�}t	d||fzd��|rt	d|d��|jSt	�|jS)Nr�rrr	r
r-r>)r�r�rr�rOr�rr
r'rkrr�)rr�r�r�rr�r
r�s        rr�zTrace.localtrace_trace:s����&�=��|�|�/�/�H��^�^�F�����f���$�/�/� 9�:��D��G�G�$�$�X�.�E��$�$�X�v�6�D��(�e�V�_�,�"�5���d�D�b�)����������rc���|dk(rR|jj}|j}||f}|jj	|d�dz|j|<|j
S)Nr�rr	)r�r�rrArYr�)rr�r�r�rr�r^s       rr�zTrace.localtrace_countKsW���&�=��|�|�/�/�H��^�^�F��F�"�C�#�{�{���s�A�6��:�D�K�K������rc��t|j|j|j|j|j
��S)N)rErFrDr=)rrArErFr�r�)rs r�resultsz
Trace.resultsSs2���t�{�{�4�;�;�'+�|�|�+/�+<�+<�'+�}�}�6�	6r)	r	r	rrr$r$NNFr )r!r"r#rr�r�r�r�r�r�r�r�r�r�rr$rrrr�sI��DE�DH��0�d%�
)�	�'.�R	8�-��.�&�"�6rc����ddl}|j�}|jddd��|jdd�}|jdd	d
d��|jd
dd
d��|jddd
d��|jddd
d��|jd�}|j	�}|jddd
d��|jddd
d��|jddd� �|jd!d"d#� �|jd$d%d
d&��|jd'd(d
d)��|jd*d+d
d,��|jd-d.�}|jd/d0gd1�2�|jd3d0gd4�2�|jd5d
d6d7�2�|jd8d9d:�;�|jd<|j
d=�;�|j
�}|jr*tjd>��tjd?����fd@�}|jD��cgc](}|jdA�D]}|j����*c}}|_
|jD��cgc].}|jtj�D]
}||����0c}}|_|jro|j s|j#dB�t%|j |j �C�}	|	j'|j(|j*|j,�St/|j0|j2|j4|j6g�s|j#dD�|j4r)|j2s|j0r|j#dE�|j*r|j2s|j#dF�|j8�|j#dG�t;|j2|j0|j4|j6|j|j|j |j |j<�H�	}
	|j>roddl }|j8}|jC|�\}
}}|jDg|jF�tH_%dI|jD|jL|jN|ddJ�}n�|j8g|jF�tH_%tjPjS|j8�tHjPd<tUjV|j8�5}tY|j[�|j8dK�}ddd�|j8dIdddL�}|
j]||�|
je�}	|jfs2|	j'|j(|j*|j,�yycc}}wcc}}w#1swY��xYw#t^$r6}tIj`dMtHjJd�dN|���Yd}~��d}~wtb$rY��wxYw)ONrz	--version�versionz	trace 2.0)�actionrzMain optionsz(One of these (or --report) must be givenz-cz--count�
store_truez�Count the number of times each line is executed and write the counts to <module>.cover for each module executed, in the module's directory. See also --coverdir, --file, --no-report below.)r�helpz-tz--tracez3Print each line to sys.stdout before it is executedz-lz--listfuncsz�Keep track of which functions are executed at least once and write the results to sys.stdout after the program exits. Cannot be specified alongside --trace or --count.z-Tz--trackcallsz^Keep track of caller/called pairs and write the results to sys.stdout after the program exits.�	Modifiersz-rz--reportz�Generate a report from a counts file; does not execute any code. --file must specify the results file to read, which must have been created in a previous run with --count --file=FILEz-Rz--no-reportz^Do not generate the coverage report files. Useful if you want to accumulate over several runs.z-fz--filez+File to accumulate counts over several runs)rz-Cz
--coverdirz�Directory where the report files go. The coverage report for <package>.<module> will be written to file <dir>/<package>/<module>.coverz-mz	--missingz?Annotate executable lines that were not executed with ">>>>>> "z-sz	--summaryz\Write a brief summary for each file to sys.stdout. Can only be used with --count or --reportz-gz--timingzQPrefix each line with the time since the program started. Only used while tracing�FilterszCan be specified multiple timesz--ignore-module�appendzqIgnore the given module(s) and its submodules (if it is a package). Accepts comma separated list of module names.)r�defaultrz--ignore-dirzWIgnore files in the given directory (multiple directories can be joined by os.pathsep).z--moduleFzTrace a module. �progname�?zfile to run as main program)�nargsr�	argumentszarguments to the program�stdlib�
platstdlibc���tjjtjj|��}|j	d��j	d��}tjj|�S)Nz$prefixz$exec_prefix)rr
�
expanduser�
expandvarsr2r)�s�_exec_prefix�_prefixs ��r�parse_ignore_dirzmain.<locals>.parse_ignore_dir�sX����G�G���r�w�w�1�1�!�4�5��
�I�I�i��)�1�1�.�,�O���w�w����"�"r�,z-r/--report requires -f/--file)rErFzLmust specify one of --trace, --count, --report, --listfuncs, or --trackcallsz8cannot specify both --listfuncs and (--trace or --count)z3--summary can only be used with --count or --reportz3progname is missing: required with the main options)r�r�r�r�rErFr�r�)r!r�__package__�
__loader__�__spec__�
__cached__r�)rr!r)r,zCannot run file z
 because: )4�argparse�ArgumentParser�add_argument�add_argument_group�add_mutually_exclusive_group�	REMAINDER�
parse_args�
ignore_dir�	sysconfig�get_path�
ignore_module�split�stripr�pathsep�reportr@�errorrr��missingrurv�anyr�r��	listfuncs�
trackcallsrrr��module�runpy�_get_module_detailsr�rr/�argv�parent�loaderr
rg�io�	open_coder�r�r�rL�exit�
SystemExitr�	no_report)r-�parser�grp�_grp�optsr'r�rr$r�trB�module_name�mod_name�mod_specr��globsr�rRr%r&s                   @@r�mainrUYs�����
�
$�
$�
&�F�
����I�{��K�
�
#�
#�N�6�8�C����T�9�\�&��'�
���T�9�\�F��H����T�=��E��F����T�>�,�7��8��
#�
#�K�
0�C��+�+�-�D����d�J�|��� �
	���d�M�,�G��H����T�8�>��@����T�<�2��3����T�;�|�������T�;�|�=��>����T�:�l�+��,��
#�
#�I�-�/�C����&�x��!��"����^�H�b�G��H����
�<��/��1�
���
�#�.��0�
����8�+=�+=�+��-�����D�����$�$�X�.�� �)�)�,�7��#�$(�#5�#5�O�#5�a������#��)�)�+�AM�&�#5�O�D��!%���N� /�1�������9L�A�(��*�9L�+� /�N�D�O��{�{��y�y��L�L�9�:�!����D�I�I�F���$�$�T�\�\�4�<�<����O�O���
�
�D�J�J�������H�I����4�	5��~�~�4�:�:�������O�P��|�|�D�J�J����J�K��}�}�����J�K�
�d�j�j�$�*�*�����?�?�t�7I�7I��������i�i����	5�A�
��;�;���-�-�K�',�'@�'@��'M�$�H�h���(�(�:�4�>�>�:�C�H�&� �,�,�'���&�o�o�$�"�
�E��
�
�7����7�C�H��'�'�/�/�$�-�-�8�C�H�H�Q�K����d�m�m�,���r�w�w�y�$�-�-��@��-�!�M�M�&�#�"�	�E�	
����u�e�$��i�i�k�G��>�>����d�l�l�D�L�L�$�-�-�H���O��N�X-�,���H����S�X�X�a�[�#�F�G�G���
��
�sC�!-W&�&3W,�C6W>�&W2�+,W>�2W;�7W>�>	Y�,X8�8Y�Yr�r�)�__doc__�__all__rGrkrr/r5r�rnr�r�r�rH�timerr�r�r�rr+r9rr�r�r�rjrrUr!r$rr�<module>rYs���<�(�%�
&��	��	�
�����	�
�
�#��#��0�0�d� �8l�l�\�
�
�.#�T6�T6�lPI�d�Z���F�r

Youez - 2016 - github.com/yon3zu
LinuXploit