index.html 192 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001
  1. <!DOCTYPE html>
  2. <html lang="en" class="h-full">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width,initial-scale=1">
  6. <meta name="color-scheme" content="light dark">
  7. <meta name="turbo-cache-control" content="no-cache" data-turbo-track="reload" data-track-token="4.1.0.825921057143">
  8. <!-- See retype.com -->
  9. <meta name="generator" content="Retype 4.1.0">
  10. <!-- Primary Meta Tags -->
  11. <title>Functions | Portable Python 3.x Interpreter in Modern C</title>
  12. <meta name="title" content="Functions | Portable Python 3.x Interpreter in Modern C">
  13. <!-- Canonical -->
  14. <link rel="canonical" href="https://pocketpy.dev/c-api/functions/">
  15. <!-- Open Graph -->
  16. <meta property="og:type" content="website">
  17. <meta property="og:url" content="https://pocketpy.dev/c-api/functions/">
  18. <meta property="og:title" content="Functions | Portable Python 3.x Interpreter in Modern C">
  19. <meta property="og:site_name" content="pocketpy">
  20. <meta property="og:locale" content="en_US">
  21. <script data-cfasync="false">(function(){var cl=document.documentElement.classList,ls=localStorage.getItem("retype_scheme"),hd=cl.contains("dark"),hl=cl.contains("light"),wm=window.matchMedia&&window.matchMedia("(prefers-color-scheme: dark)").matches;if(ls==="dark"||(!ls&&wm&&!hd&&!hl)){cl.remove("light");cl.add("dark")}else if(ls==="light"||(!ls&&!wm&&!hd&&!hl)){cl.remove("dark");cl.add("light")}})();</script>
  22. <link id="retype-favicon" rel="icon" href="../../static/logo.png" />
  23. <link href="../../resources/css/retype.css?v=4.1.0.825921057143" rel="stylesheet">
  24. <script data-cfasync="false" src="../../resources/js/config.js?v=4.1.0.825921057143" data-turbo-eval="false" defer></script>
  25. <script data-cfasync="false" src="../../resources/js/retype.js?v=4.1.0" data-turbo-eval="false" defer></script>
  26. <script id="lunr-js" data-cfasync="false" src="../../resources/js/lunr.js?v=4.1.0.825921057143" data-turbo-eval="false" defer></script>
  27. <script id="prism-js" data-cfasync="false" src="../../resources/js/prism.js?v=4.1.0.825921057143" defer></script>
  28. </head>
  29. <body>
  30. <div id="retype-app" class="relative text-base antialiased text-base-text bg-base-bg font-body">
  31. <div class="absolute bottom-0 left-0" style="top: 5rem; right: 50%"></div>
  32. <header id="retype-header" class="sticky top-0 z-30 flex w-full h-16 bg-header-bg border-b border-header-border md:h-20">
  33. <div class="container relative flex items-center justify-between pr-6 grow md:justify-start">
  34. <!-- Mobile menu button skeleton -->
  35. <button v-cloak class="skeleton retype-mobile-menu-button flex items-center justify-center shrink-0 overflow-hidden dark:text-white focus:outline-hidden rounded-full w-10 h-10 ml-3.5 md:hidden"><svg xmlns="http://www.w3.org/2000/svg" class="mb-px shrink-0" width="24" height="24" viewBox="0 0 24 24" role="presentation" style="margin-bottom: 0px;"><g fill="currentColor"><path d="M2 4h20v2H2zM2 11h20v2H2zM2 18h20v2H2z"></path></g></svg></button>
  36. <div v-cloak id="retype-sidebar-left-toggle-button"></div>
  37. <!-- Logo -->
  38. <div class="flex items-center justify-between h-full py-2 md:w-75">
  39. <div class="flex items-center px-2 md:px-6">
  40. <a id="retype-branding-logo" href="../../" class="flex items-center leading-snug text-2xl">
  41. <span class="w-10 mr-2 grow-0 shrink-0 overflow-hidden">
  42. <img class="max-h-10 dark:hidden md:inline-block" src="../../static/logo.png">
  43. <img class="max-h-10 hidden dark:inline-block" src="../../static/logo.png">
  44. </span>
  45. <span class="dark:text-white font-bold line-clamp-1 md:line-clamp-2">pocketpy</span>
  46. </a><span id="retype-branding-label" class="inline-flex mt-1 px-2 py-1 ml-4 text-xs font-medium leading-none items-center rounded-md bg-branding-label-bg text-branding-label-text ring-1 ring-branding-label-border ring-inset md:inline-block">v2.1.8</span>
  47. </div>
  48. <span class="hidden h-8 border-r md:inline-block border-base-border"></span>
  49. </div>
  50. <div class="flex justify-between md:grow">
  51. <!-- Top Nav -->
  52. <nav id="retype-header-nav" class="hidden md:flex">
  53. <ul class="flex flex-col mb-4 md:pl-16 md:mb-0 md:flex-row md:items-center">
  54. <li class="mr-6">
  55. <a class="py-2 md:mb-0 inline-flex items-center text-sm whitespace-nowrap transition-colors duration-200 ease-linear md:text-header-text font-header-text hover:text-header-text-hover" href="">
  56. <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1" width="18" height="18" viewBox="0 0 24 24" role="presentation">
  57. <g fill="currentColor">
  58. <path d="M11.03 2.59a1.501 1.501 0 0 1 1.94 0l7.5 6.363a1.5 1.5 0 0 1 .53 1.144V19.5a1.5 1.5 0 0 1-1.5 1.5h-5.75a.75.75 0 0 1-.75-.75V14h-2v6.25a.75.75 0 0 1-.75.75H4.5A1.5 1.5 0 0 1 3 19.5v-9.403c0-.44.194-.859.53-1.144ZM12 3.734l-7.5 6.363V19.5h5v-6.25a.75.75 0 0 1 .75-.75h3.5a.75.75 0 0 1 .75.75v6.25h5v-9.403Z"/>
  59. </g>
  60. </svg>
  61. <span>Home</span>
  62. </a>
  63. </li>
  64. <li class="mr-6">
  65. <a class="py-2 md:mb-0 inline-flex items-center text-sm whitespace-nowrap transition-colors duration-200 ease-linear md:text-header-text font-header-text hover:text-header-text-hover" href="https://pocketpy.dev/static/web/" target="_blank">
  66. <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1" width="18" height="18" viewBox="0 0 24 24" role="presentation">
  67. <g fill="currentColor">
  68. <path d="M9.5 15.584V8.416a.5.5 0 0 1 .77-.42l5.576 3.583a.5.5 0 0 1 0 .842l-5.576 3.584a.5.5 0 0 1-.77-.42Z"/><path d="M1 12C1 5.925 5.925 1 12 1s11 4.925 11 11-4.925 11-11 11S1 18.075 1 12Zm11-9.5A9.5 9.5 0 0 0 2.5 12a9.5 9.5 0 0 0 9.5 9.5 9.5 9.5 0 0 0 9.5-9.5A9.5 9.5 0 0 0 12 2.5Z"/>
  69. </g>
  70. </svg>
  71. <span>Live Demo</span>
  72. </a>
  73. </li>
  74. <li class="mr-6">
  75. <a class="py-2 md:mb-0 inline-flex items-center text-sm whitespace-nowrap transition-colors duration-200 ease-linear md:text-header-text font-header-text hover:text-header-text-hover" href="https://pocketpy.github.io/examples/" target="_blank">
  76. <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1" width="18" height="18" viewBox="0 0 24 24" role="presentation">
  77. <g fill="currentColor">
  78. <path d="M15.22 4.97a.75.75 0 0 1 1.06 0l6.5 6.5a.75.75 0 0 1 0 1.06l-6.5 6.5a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734L21.19 12l-5.97-5.97a.75.75 0 0 1 0-1.06Zm-6.44 0a.75.75 0 0 1 0 1.06L2.81 12l5.97 5.97a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215l-6.5-6.5a.75.75 0 0 1 0-1.06l6.5-6.5a.75.75 0 0 1 1.06 0Z"/>
  79. </g>
  80. </svg>
  81. <span>Live Examples</span>
  82. </a>
  83. </li>
  84. <li class="mr-6">
  85. <a class="py-2 md:mb-0 inline-flex items-center text-sm whitespace-nowrap transition-colors duration-200 ease-linear md:text-header-text font-header-text hover:text-header-text-hover" href="https://github.com/blueloveth/pocketpy" target="_blank">
  86. <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1" width="18" height="18" viewBox="0 0 24 24" role="presentation">
  87. <g fill="currentColor">
  88. <path d="M10.303 16.652c-2.837-.344-4.835-2.385-4.835-5.028 0-1.074.387-2.235 1.031-3.008-.279-.709-.236-2.214.086-2.837.86-.107 2.02.344 2.708.967.816-.258 1.676-.386 2.728-.386 1.053 0 1.913.128 2.686.365.666-.602 1.848-1.053 2.708-.946.3.581.344 2.085.064 2.815.688.817 1.053 1.913 1.053 3.03 0 2.643-1.998 4.641-4.877 5.006.73.473 1.224 1.504 1.224 2.686v2.235c0 .644.537 1.01 1.182.752 3.889-1.483 6.94-5.372 6.94-10.185 0-6.081-4.942-11.044-11.022-11.044-6.081 0-10.98 4.963-10.98 11.044a10.84 10.84 0 0 0 7.112 10.206c.58.215 1.139-.172 1.139-.752v-1.719a2.768 2.768 0 0 1-1.032.215c-1.418 0-2.256-.773-2.857-2.213-.237-.58-.495-.924-.989-.988-.258-.022-.344-.129-.344-.258 0-.258.43-.451.86-.451.623 0 1.16.386 1.719 1.181.43.623.881.903 1.418.903.537 0 .881-.194 1.375-.688.365-.365.645-.687.903-.902Z"/>
  89. </g>
  90. </svg>
  91. <span>Github</span>
  92. </a>
  93. </li>
  94. <li class="mr-6">
  95. <a class="py-2 md:mb-0 inline-flex items-center text-sm whitespace-nowrap transition-colors duration-200 ease-linear md:text-header-text font-header-text hover:text-header-text-hover" href="https://discord.gg/WWaq72GzXv" target="_blank">
  96. <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1" width="18" height="18" viewBox="0 0 24 24" role="presentation">
  97. <g fill="currentColor">
  98. <path d="M1.75 1h12.5c.966 0 1.75.784 1.75 1.75v9.5A1.75 1.75 0 0 1 14.25 14H8.061l-2.574 2.573A1.458 1.458 0 0 1 3 15.543V14H1.75A1.75 1.75 0 0 1 0 12.25v-9.5C0 1.784.784 1 1.75 1ZM1.5 2.75v9.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h6.5a.25.25 0 0 0 .25-.25v-9.5a.25.25 0 0 0-.25-.25H1.75a.25.25 0 0 0-.25.25Z"/><path d="M22.5 8.75a.25.25 0 0 0-.25-.25h-3.5a.75.75 0 0 1 0-1.5h3.5c.966 0 1.75.784 1.75 1.75v9.5A1.75 1.75 0 0 1 22.25 20H21v1.543a1.457 1.457 0 0 1-2.487 1.03L15.939 20H10.75A1.75 1.75 0 0 1 9 18.25v-1.465a.75.75 0 0 1 1.5 0v1.465c0 .138.112.25.25.25h5.5a.75.75 0 0 1 .53.22l2.72 2.72v-2.19a.75.75 0 0 1 .75-.75h2a.25.25 0 0 0 .25-.25v-9.5Z"/>
  99. </g>
  100. </svg>
  101. <span>Discord</span>
  102. </a>
  103. </li>
  104. </ul>
  105. </nav>
  106. <div v-cloak class="flex justify-end grow">
  107. <div id="retype-mobile-search-button"></div>
  108. <doc-search-desktop></doc-search-desktop>
  109. <doc-theme-switch class="lg:ml-2"></doc-theme-switch>
  110. <doc-history></doc-history>
  111. </div>
  112. </div>
  113. </div>
  114. </header>
  115. <div id="retype-container" class="container relative flex bg-white">
  116. <!-- Sidebar Skeleton -->
  117. <div v-cloak class="fixed flex flex-col shrink-0 duration-300 ease-in-out bg-sidebar-left-bg border-sidebar-left-border sidebar top-20 w-75 border-r h-screen md:sticky transition-transform skeleton">
  118. <div class="flex items-center h-16 px-6">
  119. <input id="retype-filter-input-mock" class="w-full h-10 pl-8 px-3 py-2 transition-colors duration-200 ease-linear bg-filter-bg border border-filter-border rounded-lg shadow-none md:text-sm hover:border-filter-border-hover focus:outline-hidden focus:border-filter-border-focus placeholder-filter-placeholder" type="text">
  120. </div>
  121. <div class="pl-6 mt-1 mb-4">
  122. <div class="w-32 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
  123. <div class="w-48 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
  124. <div class="w-40 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
  125. <div class="w-32 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
  126. <div class="w-48 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
  127. <div class="w-40 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
  128. </div>
  129. <div class="shrink-0 mt-auto bg-transparent dark:border-base-border">
  130. <a class="flex items-center justify-center flex-nowrap h-16 text-gray-350 dark:text-dark-400 hover:text-gray-600 dark:hover:text-dark-300 transition-colors duration-150 ease-in docs-powered-by" target="_blank" href="https://retype.com/" rel="noopener">
  131. <span class="text-xs whitespace-nowrap">Powered by</span>
  132. <svg xmlns="http://www.w3.org/2000/svg" class="ml-2" fill="currentColor" width="96" height="20" overflow="visible"><path d="M0 0v20h13.59V0H0zm11.15 17.54H2.44V2.46h8.71v15.08zM15.8 20h2.44V4.67L15.8 2.22zM20.45 6.89V20h2.44V9.34z"/><g><path d="M40.16 8.44c0 1.49-.59 2.45-1.75 2.88l2.34 3.32h-2.53l-2.04-2.96h-1.43v2.96h-2.06V5.36h3.5c1.43 0 2.46.24 3.07.73s.9 1.27.9 2.35zm-2.48 1.1c.26-.23.38-.59.38-1.09 0-.5-.13-.84-.4-1.03s-.73-.28-1.39-.28h-1.54v2.75h1.5c.72 0 1.2-.12 1.45-.35zM51.56 5.36V7.2h-4.59v1.91h4.13v1.76h-4.13v1.92h4.74v1.83h-6.79V5.36h6.64zM60.09 7.15v7.48h-2.06V7.15h-2.61V5.36h7.28v1.79h-2.61zM70.81 14.64h-2.06v-3.66l-3.19-5.61h2.23l1.99 3.45 1.99-3.45H74l-3.19 5.61v3.66zM83.99 6.19c.65.55.97 1.4.97 2.55s-.33 1.98-1 2.51-1.68.8-3.04.8h-1.23v2.59h-2.06V5.36h3.26c1.42 0 2.45.28 3.1.83zm-1.51 3.65c.25-.28.37-.69.37-1.22s-.16-.92-.48-1.14c-.32-.23-.82-.34-1.5-.34H79.7v3.12h1.38c.68 0 1.15-.14 1.4-.42zM95.85 5.36V7.2h-4.59v1.91h4.13v1.76h-4.13v1.92H96v1.83h-6.79V5.36h6.64z"/></g></svg>
  133. </a>
  134. </div>
  135. </div>
  136. <!-- Sidebar component -->
  137. <doc-sidebar v-cloak>
  138. <template #sidebar-footer>
  139. <div class="shrink-0 mt-auto border-t md:bg-transparent md:border-none dark:border-base-border">
  140. <div class="py-3 px-6 md:hidden border-b dark:border-base-border">
  141. <nav>
  142. <ul class="flex flex-wrap justify-center items-center">
  143. <li class="mr-6">
  144. <a class="block py-1 inline-flex items-center text-sm whitespace-nowrap transition-colors duration-200 ease-linear md:text-header-text font-header-text hover:text-header-text-hover" href="">
  145. <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1" width="18" height="18" viewBox="0 0 24 24" role="presentation">
  146. <g fill="currentColor">
  147. <path d="M11.03 2.59a1.501 1.501 0 0 1 1.94 0l7.5 6.363a1.5 1.5 0 0 1 .53 1.144V19.5a1.5 1.5 0 0 1-1.5 1.5h-5.75a.75.75 0 0 1-.75-.75V14h-2v6.25a.75.75 0 0 1-.75.75H4.5A1.5 1.5 0 0 1 3 19.5v-9.403c0-.44.194-.859.53-1.144ZM12 3.734l-7.5 6.363V19.5h5v-6.25a.75.75 0 0 1 .75-.75h3.5a.75.75 0 0 1 .75.75v6.25h5v-9.403Z"/>
  148. </g>
  149. </svg>
  150. <span>Home</span>
  151. </a>
  152. </li>
  153. <li class="mr-6">
  154. <a class="block py-1 inline-flex items-center text-sm whitespace-nowrap transition-colors duration-200 ease-linear md:text-header-text font-header-text hover:text-header-text-hover" href="https://pocketpy.dev/static/web/" target="_blank">
  155. <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1" width="18" height="18" viewBox="0 0 24 24" role="presentation">
  156. <g fill="currentColor">
  157. <path d="M9.5 15.584V8.416a.5.5 0 0 1 .77-.42l5.576 3.583a.5.5 0 0 1 0 .842l-5.576 3.584a.5.5 0 0 1-.77-.42Z"/><path d="M1 12C1 5.925 5.925 1 12 1s11 4.925 11 11-4.925 11-11 11S1 18.075 1 12Zm11-9.5A9.5 9.5 0 0 0 2.5 12a9.5 9.5 0 0 0 9.5 9.5 9.5 9.5 0 0 0 9.5-9.5A9.5 9.5 0 0 0 12 2.5Z"/>
  158. </g>
  159. </svg>
  160. <span>Live Demo</span>
  161. </a>
  162. </li>
  163. <li class="mr-6">
  164. <a class="block py-1 inline-flex items-center text-sm whitespace-nowrap transition-colors duration-200 ease-linear md:text-header-text font-header-text hover:text-header-text-hover" href="https://pocketpy.github.io/examples/" target="_blank">
  165. <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1" width="18" height="18" viewBox="0 0 24 24" role="presentation">
  166. <g fill="currentColor">
  167. <path d="M15.22 4.97a.75.75 0 0 1 1.06 0l6.5 6.5a.75.75 0 0 1 0 1.06l-6.5 6.5a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734L21.19 12l-5.97-5.97a.75.75 0 0 1 0-1.06Zm-6.44 0a.75.75 0 0 1 0 1.06L2.81 12l5.97 5.97a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215l-6.5-6.5a.75.75 0 0 1 0-1.06l6.5-6.5a.75.75 0 0 1 1.06 0Z"/>
  168. </g>
  169. </svg>
  170. <span>Live Examples</span>
  171. </a>
  172. </li>
  173. <li class="mr-6">
  174. <a class="block py-1 inline-flex items-center text-sm whitespace-nowrap transition-colors duration-200 ease-linear md:text-header-text font-header-text hover:text-header-text-hover" href="https://github.com/blueloveth/pocketpy" target="_blank">
  175. <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1" width="18" height="18" viewBox="0 0 24 24" role="presentation">
  176. <g fill="currentColor">
  177. <path d="M10.303 16.652c-2.837-.344-4.835-2.385-4.835-5.028 0-1.074.387-2.235 1.031-3.008-.279-.709-.236-2.214.086-2.837.86-.107 2.02.344 2.708.967.816-.258 1.676-.386 2.728-.386 1.053 0 1.913.128 2.686.365.666-.602 1.848-1.053 2.708-.946.3.581.344 2.085.064 2.815.688.817 1.053 1.913 1.053 3.03 0 2.643-1.998 4.641-4.877 5.006.73.473 1.224 1.504 1.224 2.686v2.235c0 .644.537 1.01 1.182.752 3.889-1.483 6.94-5.372 6.94-10.185 0-6.081-4.942-11.044-11.022-11.044-6.081 0-10.98 4.963-10.98 11.044a10.84 10.84 0 0 0 7.112 10.206c.58.215 1.139-.172 1.139-.752v-1.719a2.768 2.768 0 0 1-1.032.215c-1.418 0-2.256-.773-2.857-2.213-.237-.58-.495-.924-.989-.988-.258-.022-.344-.129-.344-.258 0-.258.43-.451.86-.451.623 0 1.16.386 1.719 1.181.43.623.881.903 1.418.903.537 0 .881-.194 1.375-.688.365-.365.645-.687.903-.902Z"/>
  178. </g>
  179. </svg>
  180. <span>Github</span>
  181. </a>
  182. </li>
  183. <li class="mr-6">
  184. <a class="block py-1 inline-flex items-center text-sm whitespace-nowrap transition-colors duration-200 ease-linear md:text-header-text font-header-text hover:text-header-text-hover" href="https://discord.gg/WWaq72GzXv" target="_blank">
  185. <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1" width="18" height="18" viewBox="0 0 24 24" role="presentation">
  186. <g fill="currentColor">
  187. <path d="M1.75 1h12.5c.966 0 1.75.784 1.75 1.75v9.5A1.75 1.75 0 0 1 14.25 14H8.061l-2.574 2.573A1.458 1.458 0 0 1 3 15.543V14H1.75A1.75 1.75 0 0 1 0 12.25v-9.5C0 1.784.784 1 1.75 1ZM1.5 2.75v9.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h6.5a.25.25 0 0 0 .25-.25v-9.5a.25.25 0 0 0-.25-.25H1.75a.25.25 0 0 0-.25.25Z"/><path d="M22.5 8.75a.25.25 0 0 0-.25-.25h-3.5a.75.75 0 0 1 0-1.5h3.5c.966 0 1.75.784 1.75 1.75v9.5A1.75 1.75 0 0 1 22.25 20H21v1.543a1.457 1.457 0 0 1-2.487 1.03L15.939 20H10.75A1.75 1.75 0 0 1 9 18.25v-1.465a.75.75 0 0 1 1.5 0v1.465c0 .138.112.25.25.25h5.5a.75.75 0 0 1 .53.22l2.72 2.72v-2.19a.75.75 0 0 1 .75-.75h2a.25.25 0 0 0 .25-.25v-9.5Z"/>
  188. </g>
  189. </svg>
  190. <span>Discord</span>
  191. </a>
  192. </li>
  193. </ul>
  194. </nav>
  195. </div>
  196. <a class="flex items-center justify-center flex-nowrap h-16 text-gray-350 dark:text-dark-400 hover:text-gray-600 dark:hover:text-dark-300 transition-colors duration-150 ease-in docs-powered-by" target="_blank" href="https://retype.com/" rel="noopener">
  197. <span class="text-xs whitespace-nowrap">Powered by</span>
  198. <svg xmlns="http://www.w3.org/2000/svg" class="ml-2" fill="currentColor" width="96" height="20" overflow="visible"><path d="M0 0v20h13.59V0H0zm11.15 17.54H2.44V2.46h8.71v15.08zM15.8 20h2.44V4.67L15.8 2.22zM20.45 6.89V20h2.44V9.34z"/><g><path d="M40.16 8.44c0 1.49-.59 2.45-1.75 2.88l2.34 3.32h-2.53l-2.04-2.96h-1.43v2.96h-2.06V5.36h3.5c1.43 0 2.46.24 3.07.73s.9 1.27.9 2.35zm-2.48 1.1c.26-.23.38-.59.38-1.09 0-.5-.13-.84-.4-1.03s-.73-.28-1.39-.28h-1.54v2.75h1.5c.72 0 1.2-.12 1.45-.35zM51.56 5.36V7.2h-4.59v1.91h4.13v1.76h-4.13v1.92h4.74v1.83h-6.79V5.36h6.64zM60.09 7.15v7.48h-2.06V7.15h-2.61V5.36h7.28v1.79h-2.61zM70.81 14.64h-2.06v-3.66l-3.19-5.61h2.23l1.99 3.45 1.99-3.45H74l-3.19 5.61v3.66zM83.99 6.19c.65.55.97 1.4.97 2.55s-.33 1.98-1 2.51-1.68.8-3.04.8h-1.23v2.59h-2.06V5.36h3.26c1.42 0 2.45.28 3.1.83zm-1.51 3.65c.25-.28.37-.69.37-1.22s-.16-.92-.48-1.14c-.32-.23-.82-.34-1.5-.34H79.7v3.12h1.38c.68 0 1.15-.14 1.4-.42zM95.85 5.36V7.2h-4.59v1.91h4.13v1.76h-4.13v1.92H96v1.83h-6.79V5.36h6.64z"/></g></svg>
  199. </a>
  200. </div>
  201. </template>
  202. </doc-sidebar>
  203. <div class="grow min-w-0 bg-body-bg">
  204. <!-- Render "toolbar" template here on api pages --><!-- Render page content -->
  205. <div class="flex">
  206. <div id="retype-main" class="min-w-0 p-4 grow md:px-16">
  207. <main class="relative pb-12 lg:pt-2">
  208. <div class="retype-markdown" id="retype-content">
  209. <!-- Rendered if sidebar right is enabled -->
  210. <div id="retype-sidebar-right-toggle"></div>
  211. <!-- Page content -->
  212. <doc-anchor-target id="functions" class="break-words">
  213. <h1>
  214. <doc-anchor-trigger class="header-anchor-trigger" to="#functions">#</doc-anchor-trigger>
  215. <span>Functions</span>
  216. </h1>
  217. </doc-anchor-target>
  218. <doc-anchor-target id="py_initialize">
  219. <h3>
  220. <doc-anchor-trigger class="header-anchor-trigger" to="#py_initialize">#</doc-anchor-trigger>
  221. <span>py_initialize</span>
  222. </h3>
  223. </doc-anchor-target>
  224. <div id="py_initialize-code-1" class="codeblock-wrapper"><doc-codeblock>
  225. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Initialize pocketpy and the default VM.
  226. PK_API void py_initialize();</code></pre>
  227. </doc-codeblock></div>
  228. <doc-anchor-target id="py_finalize">
  229. <h3>
  230. <doc-anchor-trigger class="header-anchor-trigger" to="#py_finalize">#</doc-anchor-trigger>
  231. <span>py_finalize</span>
  232. </h3>
  233. </doc-anchor-target>
  234. <div id="py_finalize-code-1" class="codeblock-wrapper"><doc-codeblock>
  235. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Finalize pocketpy and free all VMs. This opearation is irreversible.
  236. /// After this call, you cannot use any function from this header anymore.
  237. PK_API void py_finalize();</code></pre>
  238. </doc-codeblock></div>
  239. <doc-anchor-target id="py_currentvm">
  240. <h3>
  241. <doc-anchor-trigger class="header-anchor-trigger" to="#py_currentvm">#</doc-anchor-trigger>
  242. <span>py_currentvm</span>
  243. </h3>
  244. </doc-anchor-target>
  245. <div id="py_currentvm-code-1" class="codeblock-wrapper"><doc-codeblock>
  246. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the current VM index.
  247. PK_API int py_currentvm();</code></pre>
  248. </doc-codeblock></div>
  249. <doc-anchor-target id="py_switchvm">
  250. <h3>
  251. <doc-anchor-trigger class="header-anchor-trigger" to="#py_switchvm">#</doc-anchor-trigger>
  252. <span>py_switchvm</span>
  253. </h3>
  254. </doc-anchor-target>
  255. <div id="py_switchvm-code-1" class="codeblock-wrapper"><doc-codeblock>
  256. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Switch to a VM.
  257. /// @param index index of the VM ranging from 0 to 16 (exclusive). `0` is the default VM.
  258. PK_API void py_switchvm(int index);</code></pre>
  259. </doc-codeblock></div>
  260. <doc-anchor-target id="py_resetvm">
  261. <h3>
  262. <doc-anchor-trigger class="header-anchor-trigger" to="#py_resetvm">#</doc-anchor-trigger>
  263. <span>py_resetvm</span>
  264. </h3>
  265. </doc-anchor-target>
  266. <div id="py_resetvm-code-1" class="codeblock-wrapper"><doc-codeblock>
  267. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Reset the current VM.
  268. PK_API void py_resetvm();</code></pre>
  269. </doc-codeblock></div>
  270. <doc-anchor-target id="py_resetallvm">
  271. <h3>
  272. <doc-anchor-trigger class="header-anchor-trigger" to="#py_resetallvm">#</doc-anchor-trigger>
  273. <span>py_resetallvm</span>
  274. </h3>
  275. </doc-anchor-target>
  276. <div id="py_resetallvm-code-1" class="codeblock-wrapper"><doc-codeblock>
  277. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Reset All VMs.
  278. PK_API void py_resetallvm();</code></pre>
  279. </doc-codeblock></div>
  280. <doc-anchor-target id="py_getvmctx">
  281. <h3>
  282. <doc-anchor-trigger class="header-anchor-trigger" to="#py_getvmctx">#</doc-anchor-trigger>
  283. <span>py_getvmctx</span>
  284. </h3>
  285. </doc-anchor-target>
  286. <div id="py_getvmctx-code-1" class="codeblock-wrapper"><doc-codeblock>
  287. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the current VM context. This is used for user-defined data.
  288. PK_API void* py_getvmctx();</code></pre>
  289. </doc-codeblock></div>
  290. <doc-anchor-target id="py_setvmctx">
  291. <h3>
  292. <doc-anchor-trigger class="header-anchor-trigger" to="#py_setvmctx">#</doc-anchor-trigger>
  293. <span>py_setvmctx</span>
  294. </h3>
  295. </doc-anchor-target>
  296. <div id="py_setvmctx-code-1" class="codeblock-wrapper"><doc-codeblock>
  297. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Set the current VM context. This is used for user-defined data.
  298. PK_API void py_setvmctx(void* ctx);</code></pre>
  299. </doc-codeblock></div>
  300. <doc-anchor-target id="py_callbacks">
  301. <h3>
  302. <doc-anchor-trigger class="header-anchor-trigger" to="#py_callbacks">#</doc-anchor-trigger>
  303. <span>py_callbacks</span>
  304. </h3>
  305. </doc-anchor-target>
  306. <div id="py_callbacks-code-1" class="codeblock-wrapper"><doc-codeblock>
  307. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Setup the callbacks for the current VM.
  308. PK_API py_Callbacks* py_callbacks();</code></pre>
  309. </doc-codeblock></div>
  310. <doc-anchor-target id="py_appcallbacks">
  311. <h3>
  312. <doc-anchor-trigger class="header-anchor-trigger" to="#py_appcallbacks">#</doc-anchor-trigger>
  313. <span>py_appcallbacks</span>
  314. </h3>
  315. </doc-anchor-target>
  316. <div id="py_appcallbacks-code-1" class="codeblock-wrapper"><doc-codeblock>
  317. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Setup the application callbacks
  318. PK_API py_AppCallbacks* py_appcallbacks();</code></pre>
  319. </doc-codeblock></div>
  320. <doc-anchor-target id="py_sys_setargv">
  321. <h3>
  322. <doc-anchor-trigger class="header-anchor-trigger" to="#py_sys_setargv">#</doc-anchor-trigger>
  323. <span>py_sys_setargv</span>
  324. </h3>
  325. </doc-anchor-target>
  326. <div id="py_sys_setargv-code-1" class="codeblock-wrapper"><doc-codeblock>
  327. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Set `sys.argv`. Used for storing command-line arguments.
  328. PK_API void py_sys_setargv(int argc, char** argv);</code></pre>
  329. </doc-codeblock></div>
  330. <doc-anchor-target id="py_sys_settrace">
  331. <h3>
  332. <doc-anchor-trigger class="header-anchor-trigger" to="#py_sys_settrace">#</doc-anchor-trigger>
  333. <span>py_sys_settrace</span>
  334. </h3>
  335. </doc-anchor-target>
  336. <div id="py_sys_settrace-code-1" class="codeblock-wrapper"><doc-codeblock>
  337. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Set the trace function for the current VM.
  338. PK_API void py_sys_settrace(py_TraceFunc func, bool reset);</code></pre>
  339. </doc-codeblock></div>
  340. <doc-anchor-target id="py_gc_collect">
  341. <h3>
  342. <doc-anchor-trigger class="header-anchor-trigger" to="#py_gc_collect">#</doc-anchor-trigger>
  343. <span>py_gc_collect</span>
  344. </h3>
  345. </doc-anchor-target>
  346. <div id="py_gc_collect-code-1" class="codeblock-wrapper"><doc-codeblock>
  347. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Invoke the garbage collector.
  348. PK_API int py_gc_collect();</code></pre>
  349. </doc-codeblock></div>
  350. <doc-anchor-target id="py_malloc">
  351. <h3>
  352. <doc-anchor-trigger class="header-anchor-trigger" to="#py_malloc">#</doc-anchor-trigger>
  353. <span>py_malloc</span>
  354. </h3>
  355. </doc-anchor-target>
  356. <div id="py_malloc-code-1" class="codeblock-wrapper"><doc-codeblock>
  357. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Wrapper for `PK_MALLOC(size)`.
  358. PK_API void* py_malloc(size_t size);</code></pre>
  359. </doc-codeblock></div>
  360. <doc-anchor-target id="py_realloc">
  361. <h3>
  362. <doc-anchor-trigger class="header-anchor-trigger" to="#py_realloc">#</doc-anchor-trigger>
  363. <span>py_realloc</span>
  364. </h3>
  365. </doc-anchor-target>
  366. <div id="py_realloc-code-1" class="codeblock-wrapper"><doc-codeblock>
  367. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Wrapper for `PK_REALLOC(ptr, size)`.
  368. PK_API void* py_realloc(void* ptr, size_t size);</code></pre>
  369. </doc-codeblock></div>
  370. <doc-anchor-target id="py_free">
  371. <h3>
  372. <doc-anchor-trigger class="header-anchor-trigger" to="#py_free">#</doc-anchor-trigger>
  373. <span>py_free</span>
  374. </h3>
  375. </doc-anchor-target>
  376. <div id="py_free-code-1" class="codeblock-wrapper"><doc-codeblock>
  377. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Wrapper for `PK_FREE(ptr)`.
  378. PK_API void py_free(void* ptr);</code></pre>
  379. </doc-codeblock></div>
  380. <doc-anchor-target id="py_true">
  381. <h3>
  382. <doc-anchor-trigger class="header-anchor-trigger" to="#py_true">#</doc-anchor-trigger>
  383. <span>py_True</span>
  384. </h3>
  385. </doc-anchor-target>
  386. <div id="py_true-code-1" class="codeblock-wrapper"><doc-codeblock>
  387. <pre translate="no" class="language-c"><code v-pre class="language-c">/// A shorthand for `True`.
  388. PK_API py_GlobalRef py_True();</code></pre>
  389. </doc-codeblock></div>
  390. <doc-anchor-target id="py_false">
  391. <h3>
  392. <doc-anchor-trigger class="header-anchor-trigger" to="#py_false">#</doc-anchor-trigger>
  393. <span>py_False</span>
  394. </h3>
  395. </doc-anchor-target>
  396. <div id="py_false-code-1" class="codeblock-wrapper"><doc-codeblock>
  397. <pre translate="no" class="language-c"><code v-pre class="language-c">/// A shorthand for `False`.
  398. PK_API py_GlobalRef py_False();</code></pre>
  399. </doc-codeblock></div>
  400. <doc-anchor-target id="py_none">
  401. <h3>
  402. <doc-anchor-trigger class="header-anchor-trigger" to="#py_none">#</doc-anchor-trigger>
  403. <span>py_None</span>
  404. </h3>
  405. </doc-anchor-target>
  406. <div id="py_none-code-1" class="codeblock-wrapper"><doc-codeblock>
  407. <pre translate="no" class="language-c"><code v-pre class="language-c">/// A shorthand for `None`.
  408. PK_API py_GlobalRef py_None();</code></pre>
  409. </doc-codeblock></div>
  410. <doc-anchor-target id="py_nil">
  411. <h3>
  412. <doc-anchor-trigger class="header-anchor-trigger" to="#py_nil">#</doc-anchor-trigger>
  413. <span>py_NIL</span>
  414. </h3>
  415. </doc-anchor-target>
  416. <div id="py_nil-code-1" class="codeblock-wrapper"><doc-codeblock>
  417. <pre translate="no" class="language-c"><code v-pre class="language-c">/// A shorthand for `nil`. `nil` is not a valid python object.
  418. PK_API py_GlobalRef py_NIL();</code></pre>
  419. </doc-codeblock></div>
  420. <doc-anchor-target id="py_frame_newglobals">
  421. <h3>
  422. <doc-anchor-trigger class="header-anchor-trigger" to="#py_frame_newglobals">#</doc-anchor-trigger>
  423. <span>py_Frame_newglobals</span>
  424. </h3>
  425. </doc-anchor-target>
  426. <div id="py_frame_newglobals-code-1" class="codeblock-wrapper"><doc-codeblock>
  427. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `globals()` with respect to the given frame.
  428. PK_API void py_Frame_newglobals(py_Frame* frame, py_OutRef out);</code></pre>
  429. </doc-codeblock></div>
  430. <doc-anchor-target id="py_frame_newlocals">
  431. <h3>
  432. <doc-anchor-trigger class="header-anchor-trigger" to="#py_frame_newlocals">#</doc-anchor-trigger>
  433. <span>py_Frame_newlocals</span>
  434. </h3>
  435. </doc-anchor-target>
  436. <div id="py_frame_newlocals-code-1" class="codeblock-wrapper"><doc-codeblock>
  437. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `locals()` with respect to the given frame.
  438. PK_API void py_Frame_newlocals(py_Frame* frame, py_OutRef out);</code></pre>
  439. </doc-codeblock></div>
  440. <doc-anchor-target id="py_frame_function">
  441. <h3>
  442. <doc-anchor-trigger class="header-anchor-trigger" to="#py_frame_function">#</doc-anchor-trigger>
  443. <span>py_Frame_function</span>
  444. </h3>
  445. </doc-anchor-target>
  446. <div id="py_frame_function-code-1" class="codeblock-wrapper"><doc-codeblock>
  447. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the function object of the frame.
  448. /// Returns `NULL` if not available.
  449. PK_API py_StackRef py_Frame_function(py_Frame* frame);</code></pre>
  450. </doc-codeblock></div>
  451. <doc-anchor-target id="py_compile">
  452. <h3>
  453. <doc-anchor-trigger class="header-anchor-trigger" to="#py_compile">#</doc-anchor-trigger>
  454. <span>py_compile <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  455. <span>raise</span>
  456. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  457. <span>return</span>
  458. </a></span>
  459. </h3>
  460. </doc-anchor-target>
  461. <div id="py_compile-code-1" class="codeblock-wrapper"><doc-codeblock>
  462. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Compile a source string into a code object.
  463. /// Use python's `exec()` or `eval()` to execute it.
  464. PK_API bool py_compile(const char* source,
  465. const char* filename,
  466. enum py_CompileMode mode,
  467. bool is_dynamic);</code></pre>
  468. </doc-codeblock></div>
  469. <doc-anchor-target id="py_compilefile">
  470. <h3>
  471. <doc-anchor-trigger class="header-anchor-trigger" to="#py_compilefile">#</doc-anchor-trigger>
  472. <span>py_compilefile <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  473. <span>raise</span>
  474. </a></span>
  475. </h3>
  476. </doc-anchor-target>
  477. <div id="py_compilefile-code-1" class="codeblock-wrapper"><doc-codeblock>
  478. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Compile a `.py` file into a `.pyc` file.
  479. PK_API bool py_compilefile(const char* src_path,
  480. const char* dst_path);</code></pre>
  481. </doc-codeblock></div>
  482. <doc-anchor-target id="py_execo">
  483. <h3>
  484. <doc-anchor-trigger class="header-anchor-trigger" to="#py_execo">#</doc-anchor-trigger>
  485. <span>py_execo <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  486. <span>raise</span>
  487. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  488. <span>return</span>
  489. </a></span>
  490. </h3>
  491. </doc-anchor-target>
  492. <div id="py_execo-code-1" class="codeblock-wrapper"><doc-codeblock>
  493. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Run a compiled code object.
  494. PK_API bool py_execo(const void* data, int size, const char* filename, py_Ref module);</code></pre>
  495. </doc-codeblock></div>
  496. <doc-anchor-target id="py_exec">
  497. <h3>
  498. <doc-anchor-trigger class="header-anchor-trigger" to="#py_exec">#</doc-anchor-trigger>
  499. <span>py_exec <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  500. <span>raise</span>
  501. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  502. <span>return</span>
  503. </a></span>
  504. </h3>
  505. </doc-anchor-target>
  506. <div id="py_exec-code-1" class="codeblock-wrapper"><doc-codeblock>
  507. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Run a source string.
  508. /// @param source source string.
  509. /// @param filename filename (for error messages).
  510. /// @param mode compile mode. Use `EXEC_MODE` for statements `EVAL_MODE` for expressions.
  511. /// @param module target module. Use NULL for the main module.
  512. /// @return `true` if the execution is successful or `false` if an exception is raised.
  513. PK_API bool py_exec(const char* source,
  514. const char* filename,
  515. enum py_CompileMode mode,
  516. py_Ref module);</code></pre>
  517. </doc-codeblock></div>
  518. <doc-anchor-target id="py_eval">
  519. <h3>
  520. <doc-anchor-trigger class="header-anchor-trigger" to="#py_eval">#</doc-anchor-trigger>
  521. <span>py_eval <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  522. <span>raise</span>
  523. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  524. <span>return</span>
  525. </a></span>
  526. </h3>
  527. </doc-anchor-target>
  528. <div id="py_eval-code-1" class="codeblock-wrapper"><doc-codeblock>
  529. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Evaluate a source string. Equivalent to `py_exec(source, &quot;&lt;string&gt;&quot;, EVAL_MODE, module)`.
  530. PK_API bool py_eval(const char* source, py_Ref module);</code></pre>
  531. </doc-codeblock></div>
  532. <doc-anchor-target id="py_smartexec">
  533. <h3>
  534. <doc-anchor-trigger class="header-anchor-trigger" to="#py_smartexec">#</doc-anchor-trigger>
  535. <span>py_smartexec <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  536. <span>raise</span>
  537. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  538. <span>return</span>
  539. </a></span>
  540. </h3>
  541. </doc-anchor-target>
  542. <div id="py_smartexec-code-1" class="codeblock-wrapper"><doc-codeblock>
  543. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Run a source string with smart interpretation.
  544. /// Example:
  545. /// `py_newstr(py_r0(), &quot;abc&quot;);`
  546. /// `py_newint(py_r1(), 123);`
  547. /// `py_smartexec(&quot;print(_0, _1)&quot;, NULL, py_r0(), py_r1());`
  548. /// `// &quot;abc 123&quot; will be printed`.
  549. PK_API bool py_smartexec(const char* source, py_Ref module, ...);</code></pre>
  550. </doc-codeblock></div>
  551. <doc-anchor-target id="py_smarteval">
  552. <h3>
  553. <doc-anchor-trigger class="header-anchor-trigger" to="#py_smarteval">#</doc-anchor-trigger>
  554. <span>py_smarteval <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  555. <span>raise</span>
  556. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  557. <span>return</span>
  558. </a></span>
  559. </h3>
  560. </doc-anchor-target>
  561. <div id="py_smarteval-code-1" class="codeblock-wrapper"><doc-codeblock>
  562. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Evaluate a source string with smart interpretation.
  563. /// Example:
  564. /// `py_newstr(py_r0(), &quot;abc&quot;);`
  565. /// `py_smarteval(&quot;len(_)&quot;, NULL, py_r0());`
  566. /// `int res = py_toint(py_retval());`
  567. /// `// res will be 3`.
  568. PK_API bool py_smarteval(const char* source, py_Ref module, ...);</code></pre>
  569. </doc-codeblock></div>
  570. <doc-anchor-target id="py_newint">
  571. <h3>
  572. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newint">#</doc-anchor-trigger>
  573. <span>py_newint</span>
  574. </h3>
  575. </doc-anchor-target>
  576. <div id="py_newint-code-1" class="codeblock-wrapper"><doc-codeblock>
  577. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create an `int` object.
  578. PK_API void py_newint(py_OutRef, py_i64);</code></pre>
  579. </doc-codeblock></div>
  580. <doc-anchor-target id="py_newtrivial">
  581. <h3>
  582. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newtrivial">#</doc-anchor-trigger>
  583. <span>py_newtrivial</span>
  584. </h3>
  585. </doc-anchor-target>
  586. <div id="py_newtrivial-code-1" class="codeblock-wrapper"><doc-codeblock>
  587. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a trivial value object.
  588. PK_API void py_newtrivial(py_OutRef out, py_Type type, void* data, int size);</code></pre>
  589. </doc-codeblock></div>
  590. <doc-anchor-target id="py_newfloat">
  591. <h3>
  592. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newfloat">#</doc-anchor-trigger>
  593. <span>py_newfloat</span>
  594. </h3>
  595. </doc-anchor-target>
  596. <div id="py_newfloat-code-1" class="codeblock-wrapper"><doc-codeblock>
  597. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `float` object.
  598. PK_API void py_newfloat(py_OutRef, py_f64);</code></pre>
  599. </doc-codeblock></div>
  600. <doc-anchor-target id="py_newbool">
  601. <h3>
  602. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newbool">#</doc-anchor-trigger>
  603. <span>py_newbool</span>
  604. </h3>
  605. </doc-anchor-target>
  606. <div id="py_newbool-code-1" class="codeblock-wrapper"><doc-codeblock>
  607. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `bool` object.
  608. PK_API void py_newbool(py_OutRef, bool);</code></pre>
  609. </doc-codeblock></div>
  610. <doc-anchor-target id="py_newstr">
  611. <h3>
  612. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newstr">#</doc-anchor-trigger>
  613. <span>py_newstr</span>
  614. </h3>
  615. </doc-anchor-target>
  616. <div id="py_newstr-code-1" class="codeblock-wrapper"><doc-codeblock>
  617. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `str` object from a null-terminated string (utf-8).
  618. PK_API void py_newstr(py_OutRef, const char*);</code></pre>
  619. </doc-codeblock></div>
  620. <doc-anchor-target id="py_newstrn">
  621. <h3>
  622. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newstrn">#</doc-anchor-trigger>
  623. <span>py_newstrn</span>
  624. </h3>
  625. </doc-anchor-target>
  626. <div id="py_newstrn-code-1" class="codeblock-wrapper"><doc-codeblock>
  627. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `str` object with `n` UNINITIALIZED bytes plus `'\0'`.
  628. PK_API char* py_newstrn(py_OutRef, int);</code></pre>
  629. </doc-codeblock></div>
  630. <doc-anchor-target id="py_newstrv">
  631. <h3>
  632. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newstrv">#</doc-anchor-trigger>
  633. <span>py_newstrv</span>
  634. </h3>
  635. </doc-anchor-target>
  636. <div id="py_newstrv-code-1" class="codeblock-wrapper"><doc-codeblock>
  637. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `str` object from a `c11_sv`.
  638. PK_API void py_newstrv(py_OutRef, c11_sv);</code></pre>
  639. </doc-codeblock></div>
  640. <doc-anchor-target id="py_newfstr">
  641. <h3>
  642. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newfstr">#</doc-anchor-trigger>
  643. <span>py_newfstr</span>
  644. </h3>
  645. </doc-anchor-target>
  646. <div id="py_newfstr-code-1" class="codeblock-wrapper"><doc-codeblock>
  647. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a formatted `str` object.
  648. PK_API void py_newfstr(py_OutRef, const char*, ...);</code></pre>
  649. </doc-codeblock></div>
  650. <doc-anchor-target id="py_newnone">
  651. <h3>
  652. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newnone">#</doc-anchor-trigger>
  653. <span>py_newnone</span>
  654. </h3>
  655. </doc-anchor-target>
  656. <div id="py_newnone-code-1" class="codeblock-wrapper"><doc-codeblock>
  657. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `None` object.
  658. PK_API void py_newnone(py_OutRef);</code></pre>
  659. </doc-codeblock></div>
  660. <doc-anchor-target id="py_newnotimplemented">
  661. <h3>
  662. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newnotimplemented">#</doc-anchor-trigger>
  663. <span>py_newnotimplemented</span>
  664. </h3>
  665. </doc-anchor-target>
  666. <div id="py_newnotimplemented-code-1" class="codeblock-wrapper"><doc-codeblock>
  667. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `NotImplemented` object.
  668. PK_API void py_newnotimplemented(py_OutRef);</code></pre>
  669. </doc-codeblock></div>
  670. <doc-anchor-target id="py_newellipsis">
  671. <h3>
  672. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newellipsis">#</doc-anchor-trigger>
  673. <span>py_newellipsis</span>
  674. </h3>
  675. </doc-anchor-target>
  676. <div id="py_newellipsis-code-1" class="codeblock-wrapper"><doc-codeblock>
  677. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `...` object.
  678. PK_API void py_newellipsis(py_OutRef);</code></pre>
  679. </doc-codeblock></div>
  680. <doc-anchor-target id="py_newnil">
  681. <h3>
  682. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newnil">#</doc-anchor-trigger>
  683. <span>py_newnil</span>
  684. </h3>
  685. </doc-anchor-target>
  686. <div id="py_newnil-code-1" class="codeblock-wrapper"><doc-codeblock>
  687. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `nil` object. `nil` is an invalid representation of an object.
  688. /// Don't use it unless you know what you are doing.
  689. PK_API void py_newnil(py_OutRef);</code></pre>
  690. </doc-codeblock></div>
  691. <doc-anchor-target id="py_newnativefunc">
  692. <h3>
  693. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newnativefunc">#</doc-anchor-trigger>
  694. <span>py_newnativefunc</span>
  695. </h3>
  696. </doc-anchor-target>
  697. <div id="py_newnativefunc-code-1" class="codeblock-wrapper"><doc-codeblock>
  698. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `nativefunc` object.
  699. PK_API void py_newnativefunc(py_OutRef, py_CFunction);</code></pre>
  700. </doc-codeblock></div>
  701. <doc-anchor-target id="py_newfunction">
  702. <h3>
  703. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newfunction">#</doc-anchor-trigger>
  704. <span>py_newfunction</span>
  705. </h3>
  706. </doc-anchor-target>
  707. <div id="py_newfunction-code-1" class="codeblock-wrapper"><doc-codeblock>
  708. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `function` object.
  709. PK_API py_Name py_newfunction(py_OutRef out,
  710. const char* sig,
  711. py_CFunction f,
  712. const char* docstring,
  713. int slots);</code></pre>
  714. </doc-codeblock></div>
  715. <doc-anchor-target id="py_newboundmethod">
  716. <h3>
  717. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newboundmethod">#</doc-anchor-trigger>
  718. <span>py_newboundmethod</span>
  719. </h3>
  720. </doc-anchor-target>
  721. <div id="py_newboundmethod-code-1" class="codeblock-wrapper"><doc-codeblock>
  722. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `boundmethod` object.
  723. PK_API void py_newboundmethod(py_OutRef out, py_Ref self, py_Ref func);</code></pre>
  724. </doc-codeblock></div>
  725. <doc-anchor-target id="py_newobject">
  726. <h3>
  727. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newobject">#</doc-anchor-trigger>
  728. <span>py_newobject</span>
  729. </h3>
  730. </doc-anchor-target>
  731. <div id="py_newobject-code-1" class="codeblock-wrapper"><doc-codeblock>
  732. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a new object.
  733. /// @param out output reference.
  734. /// @param type type of the object.
  735. /// @param slots number of slots. Use `-1` to create a `__dict__`.
  736. /// @param udsize size of your userdata.
  737. /// @return pointer to the userdata.
  738. PK_API void* py_newobject(py_OutRef out, py_Type type, int slots, int udsize);</code></pre>
  739. </doc-codeblock></div>
  740. <doc-anchor-target id="py_name">
  741. <h3>
  742. <doc-anchor-trigger class="header-anchor-trigger" to="#py_name">#</doc-anchor-trigger>
  743. <span>py_name</span>
  744. </h3>
  745. </doc-anchor-target>
  746. <div id="py_name-code-1" class="codeblock-wrapper"><doc-codeblock>
  747. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a null-terminated string to a name.
  748. PK_API py_Name py_name(const char*);</code></pre>
  749. </doc-codeblock></div>
  750. <doc-anchor-target id="py_name2ref">
  751. <h3>
  752. <doc-anchor-trigger class="header-anchor-trigger" to="#py_name2ref">#</doc-anchor-trigger>
  753. <span>py_name2ref</span>
  754. </h3>
  755. </doc-anchor-target>
  756. <div id="py_name2ref-code-1" class="codeblock-wrapper"><doc-codeblock>
  757. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a name to a python `str` object with cache.
  758. PK_API py_GlobalRef py_name2ref(py_Name);</code></pre>
  759. </doc-codeblock></div>
  760. <doc-anchor-target id="py_namev">
  761. <h3>
  762. <doc-anchor-trigger class="header-anchor-trigger" to="#py_namev">#</doc-anchor-trigger>
  763. <span>py_namev</span>
  764. </h3>
  765. </doc-anchor-target>
  766. <div id="py_namev-code-1" class="codeblock-wrapper"><doc-codeblock>
  767. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a `c11_sv` to a name.
  768. PK_API py_Name py_namev(c11_sv);</code></pre>
  769. </doc-codeblock></div>
  770. <doc-anchor-target id="py_name2sv">
  771. <h3>
  772. <doc-anchor-trigger class="header-anchor-trigger" to="#py_name2sv">#</doc-anchor-trigger>
  773. <span>py_name2sv</span>
  774. </h3>
  775. </doc-anchor-target>
  776. <div id="py_name2sv-code-1" class="codeblock-wrapper"><doc-codeblock>
  777. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a name to a `c11_sv`.
  778. PK_API c11_sv py_name2sv(py_Name);</code></pre>
  779. </doc-codeblock></div>
  780. <doc-anchor-target id="py_bind">
  781. <h3>
  782. <doc-anchor-trigger class="header-anchor-trigger" to="#py_bind">#</doc-anchor-trigger>
  783. <span>py_bind</span>
  784. </h3>
  785. </doc-anchor-target>
  786. <div id="py_bind-code-1" class="codeblock-wrapper"><doc-codeblock>
  787. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Bind a function to the object via &quot;decl-based&quot; style.
  788. /// @param obj the target object.
  789. /// @param sig signature of the function. e.g. `add(x, y)`.
  790. /// @param f function to bind.
  791. PK_API void py_bind(py_Ref obj, const char* sig, py_CFunction f);</code></pre>
  792. </doc-codeblock></div>
  793. <doc-anchor-target id="py_bindmethod">
  794. <h3>
  795. <doc-anchor-trigger class="header-anchor-trigger" to="#py_bindmethod">#</doc-anchor-trigger>
  796. <span>py_bindmethod</span>
  797. </h3>
  798. </doc-anchor-target>
  799. <div id="py_bindmethod-code-1" class="codeblock-wrapper"><doc-codeblock>
  800. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Bind a method to type via &quot;argc-based&quot; style.
  801. /// @param type the target type.
  802. /// @param name name of the method.
  803. /// @param f function to bind.
  804. PK_API void py_bindmethod(py_Type type, const char* name, py_CFunction f);</code></pre>
  805. </doc-codeblock></div>
  806. <doc-anchor-target id="py_bindstaticmethod">
  807. <h3>
  808. <doc-anchor-trigger class="header-anchor-trigger" to="#py_bindstaticmethod">#</doc-anchor-trigger>
  809. <span>py_bindstaticmethod</span>
  810. </h3>
  811. </doc-anchor-target>
  812. <div id="py_bindstaticmethod-code-1" class="codeblock-wrapper"><doc-codeblock>
  813. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Bind a static method to type via &quot;argc-based&quot; style.
  814. /// @param type the target type.
  815. /// @param name name of the method.
  816. /// @param f function to bind.
  817. PK_API void py_bindstaticmethod(py_Type type, const char* name, py_CFunction f);</code></pre>
  818. </doc-codeblock></div>
  819. <doc-anchor-target id="py_bindfunc">
  820. <h3>
  821. <doc-anchor-trigger class="header-anchor-trigger" to="#py_bindfunc">#</doc-anchor-trigger>
  822. <span>py_bindfunc</span>
  823. </h3>
  824. </doc-anchor-target>
  825. <div id="py_bindfunc-code-1" class="codeblock-wrapper"><doc-codeblock>
  826. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Bind a function to the object via &quot;argc-based&quot; style.
  827. /// @param obj the target object.
  828. /// @param name name of the function.
  829. /// @param f function to bind.
  830. PK_API void py_bindfunc(py_Ref obj, const char* name, py_CFunction f);</code></pre>
  831. </doc-codeblock></div>
  832. <doc-anchor-target id="py_bindproperty">
  833. <h3>
  834. <doc-anchor-trigger class="header-anchor-trigger" to="#py_bindproperty">#</doc-anchor-trigger>
  835. <span>py_bindproperty</span>
  836. </h3>
  837. </doc-anchor-target>
  838. <div id="py_bindproperty-code-1" class="codeblock-wrapper"><doc-codeblock>
  839. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Bind a property to type.
  840. /// @param type the target type.
  841. /// @param name name of the property.
  842. /// @param getter getter function.
  843. /// @param setter setter function. Use `NULL` if not needed.
  844. PK_API void py_bindproperty(py_Type type, const char* name, py_CFunction getter, py_CFunction setter);</code></pre>
  845. </doc-codeblock></div>
  846. <doc-anchor-target id="py_bindmagic">
  847. <h3>
  848. <doc-anchor-trigger class="header-anchor-trigger" to="#py_bindmagic">#</doc-anchor-trigger>
  849. <span>py_bindmagic</span>
  850. </h3>
  851. </doc-anchor-target>
  852. <div id="py_bindmagic-code-1" class="codeblock-wrapper"><doc-codeblock>
  853. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Bind a magic method to type.
  854. PK_API void py_bindmagic(py_Type type, py_Name name, py_CFunction f);</code></pre>
  855. </doc-codeblock></div>
  856. <doc-anchor-target id="py_toint">
  857. <h3>
  858. <doc-anchor-trigger class="header-anchor-trigger" to="#py_toint">#</doc-anchor-trigger>
  859. <span>py_toint</span>
  860. </h3>
  861. </doc-anchor-target>
  862. <div id="py_toint-code-1" class="codeblock-wrapper"><doc-codeblock>
  863. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert an `int` object in python to `int64_t`.
  864. PK_API py_i64 py_toint(py_Ref);</code></pre>
  865. </doc-codeblock></div>
  866. <doc-anchor-target id="py_totrivial">
  867. <h3>
  868. <doc-anchor-trigger class="header-anchor-trigger" to="#py_totrivial">#</doc-anchor-trigger>
  869. <span>py_totrivial</span>
  870. </h3>
  871. </doc-anchor-target>
  872. <div id="py_totrivial-code-1" class="codeblock-wrapper"><doc-codeblock>
  873. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the address of the trivial value object (16 bytes).
  874. PK_API void* py_totrivial(py_Ref);</code></pre>
  875. </doc-codeblock></div>
  876. <doc-anchor-target id="py_tofloat">
  877. <h3>
  878. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tofloat">#</doc-anchor-trigger>
  879. <span>py_tofloat</span>
  880. </h3>
  881. </doc-anchor-target>
  882. <div id="py_tofloat-code-1" class="codeblock-wrapper"><doc-codeblock>
  883. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a `float` object in python to `double`.
  884. PK_API py_f64 py_tofloat(py_Ref);</code></pre>
  885. </doc-codeblock></div>
  886. <doc-anchor-target id="py_castfloat">
  887. <h3>
  888. <doc-anchor-trigger class="header-anchor-trigger" to="#py_castfloat">#</doc-anchor-trigger>
  889. <span>py_castfloat <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  890. <span>raise</span>
  891. </a></span>
  892. </h3>
  893. </doc-anchor-target>
  894. <div id="py_castfloat-code-1" class="codeblock-wrapper"><doc-codeblock>
  895. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Cast a `int` or `float` object in python to `double`.
  896. /// If successful, return true and set the value to `out`.
  897. /// Otherwise, return false and raise `TypeError`.
  898. PK_API bool py_castfloat(py_Ref, py_f64* out);</code></pre>
  899. </doc-codeblock></div>
  900. <doc-anchor-target id="py_castfloat32">
  901. <h3>
  902. <doc-anchor-trigger class="header-anchor-trigger" to="#py_castfloat32">#</doc-anchor-trigger>
  903. <span>py_castfloat32 <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  904. <span>raise</span>
  905. </a></span>
  906. </h3>
  907. </doc-anchor-target>
  908. <div id="py_castfloat32-code-1" class="codeblock-wrapper"><doc-codeblock>
  909. <pre translate="no" class="language-c"><code v-pre class="language-c">/// 32-bit version of `py_castfloat`.
  910. PK_API bool py_castfloat32(py_Ref, float* out);</code></pre>
  911. </doc-codeblock></div>
  912. <doc-anchor-target id="py_castint">
  913. <h3>
  914. <doc-anchor-trigger class="header-anchor-trigger" to="#py_castint">#</doc-anchor-trigger>
  915. <span>py_castint <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  916. <span>raise</span>
  917. </a></span>
  918. </h3>
  919. </doc-anchor-target>
  920. <div id="py_castint-code-1" class="codeblock-wrapper"><doc-codeblock>
  921. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Cast a `int` object in python to `int64_t`.
  922. PK_API bool py_castint(py_Ref, py_i64* out);</code></pre>
  923. </doc-codeblock></div>
  924. <doc-anchor-target id="py_tobool">
  925. <h3>
  926. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tobool">#</doc-anchor-trigger>
  927. <span>py_tobool</span>
  928. </h3>
  929. </doc-anchor-target>
  930. <div id="py_tobool-code-1" class="codeblock-wrapper"><doc-codeblock>
  931. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a `bool` object in python to `bool`.
  932. PK_API bool py_tobool(py_Ref);</code></pre>
  933. </doc-codeblock></div>
  934. <doc-anchor-target id="py_totype">
  935. <h3>
  936. <doc-anchor-trigger class="header-anchor-trigger" to="#py_totype">#</doc-anchor-trigger>
  937. <span>py_totype</span>
  938. </h3>
  939. </doc-anchor-target>
  940. <div id="py_totype-code-1" class="codeblock-wrapper"><doc-codeblock>
  941. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a `type` object in python to `py_Type`.
  942. PK_API py_Type py_totype(py_Ref);</code></pre>
  943. </doc-codeblock></div>
  944. <doc-anchor-target id="py_touserdata">
  945. <h3>
  946. <doc-anchor-trigger class="header-anchor-trigger" to="#py_touserdata">#</doc-anchor-trigger>
  947. <span>py_touserdata</span>
  948. </h3>
  949. </doc-anchor-target>
  950. <div id="py_touserdata-code-1" class="codeblock-wrapper"><doc-codeblock>
  951. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a user-defined object to its userdata.
  952. PK_API void* py_touserdata(py_Ref);</code></pre>
  953. </doc-codeblock></div>
  954. <doc-anchor-target id="py_tosv">
  955. <h3>
  956. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tosv">#</doc-anchor-trigger>
  957. <span>py_tosv</span>
  958. </h3>
  959. </doc-anchor-target>
  960. <div id="py_tosv-code-1" class="codeblock-wrapper"><doc-codeblock>
  961. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a `str` object in python to `c11_sv`.
  962. PK_API c11_sv py_tosv(py_Ref);</code></pre>
  963. </doc-codeblock></div>
  964. <doc-anchor-target id="py_bytes_resize">
  965. <h3>
  966. <doc-anchor-trigger class="header-anchor-trigger" to="#py_bytes_resize">#</doc-anchor-trigger>
  967. <span>py_bytes_resize</span>
  968. </h3>
  969. </doc-anchor-target>
  970. <div id="py_bytes_resize-code-1" class="codeblock-wrapper"><doc-codeblock>
  971. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Resize a `bytes` object. It can only be resized down.
  972. PK_API void py_bytes_resize(py_Ref, int size);</code></pre>
  973. </doc-codeblock></div>
  974. <doc-anchor-target id="py_newtype">
  975. <h3>
  976. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newtype">#</doc-anchor-trigger>
  977. <span>py_newtype</span>
  978. </h3>
  979. </doc-anchor-target>
  980. <div id="py_newtype-code-1" class="codeblock-wrapper"><doc-codeblock>
  981. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a new type.
  982. /// @param name name of the type.
  983. /// @param base base type.
  984. /// @param module module where the type is defined. Use `NULL` for built-in types.
  985. /// @param dtor destructor function. Use `NULL` if not needed.
  986. PK_API py_Type py_newtype(const char* name, py_Type base, const py_GlobalRef module, py_Dtor dtor);</code></pre>
  987. </doc-codeblock></div>
  988. <doc-anchor-target id="py_istype">
  989. <h3>
  990. <doc-anchor-trigger class="header-anchor-trigger" to="#py_istype">#</doc-anchor-trigger>
  991. <span>py_istype</span>
  992. </h3>
  993. </doc-anchor-target>
  994. <div id="py_istype-code-1" class="codeblock-wrapper"><doc-codeblock>
  995. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Check if the object is exactly the given type.
  996. PK_API bool py_istype(py_Ref, py_Type);</code></pre>
  997. </doc-codeblock></div>
  998. <doc-anchor-target id="py_typeof">
  999. <h3>
  1000. <doc-anchor-trigger class="header-anchor-trigger" to="#py_typeof">#</doc-anchor-trigger>
  1001. <span>py_typeof</span>
  1002. </h3>
  1003. </doc-anchor-target>
  1004. <div id="py_typeof-code-1" class="codeblock-wrapper"><doc-codeblock>
  1005. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the type of the object.
  1006. PK_API py_Type py_typeof(py_Ref self);</code></pre>
  1007. </doc-codeblock></div>
  1008. <doc-anchor-target id="py_isinstance">
  1009. <h3>
  1010. <doc-anchor-trigger class="header-anchor-trigger" to="#py_isinstance">#</doc-anchor-trigger>
  1011. <span>py_isinstance</span>
  1012. </h3>
  1013. </doc-anchor-target>
  1014. <div id="py_isinstance-code-1" class="codeblock-wrapper"><doc-codeblock>
  1015. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Check if the object is an instance of the given type.
  1016. PK_API bool py_isinstance(py_Ref obj, py_Type type);</code></pre>
  1017. </doc-codeblock></div>
  1018. <doc-anchor-target id="py_issubclass">
  1019. <h3>
  1020. <doc-anchor-trigger class="header-anchor-trigger" to="#py_issubclass">#</doc-anchor-trigger>
  1021. <span>py_issubclass</span>
  1022. </h3>
  1023. </doc-anchor-target>
  1024. <div id="py_issubclass-code-1" class="codeblock-wrapper"><doc-codeblock>
  1025. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Check if the derived type is a subclass of the base type.
  1026. PK_API bool py_issubclass(py_Type derived, py_Type base);</code></pre>
  1027. </doc-codeblock></div>
  1028. <doc-anchor-target id="py_gettype">
  1029. <h3>
  1030. <doc-anchor-trigger class="header-anchor-trigger" to="#py_gettype">#</doc-anchor-trigger>
  1031. <span>py_gettype</span>
  1032. </h3>
  1033. </doc-anchor-target>
  1034. <div id="py_gettype-code-1" class="codeblock-wrapper"><doc-codeblock>
  1035. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get type by module and name. e.g. `py_gettype(&quot;time&quot;, py_name(&quot;struct_time&quot;))`.
  1036. /// Return `0` if not found.
  1037. PK_API py_Type py_gettype(const char* module, py_Name name);</code></pre>
  1038. </doc-codeblock></div>
  1039. <doc-anchor-target id="py_checktype">
  1040. <h3>
  1041. <doc-anchor-trigger class="header-anchor-trigger" to="#py_checktype">#</doc-anchor-trigger>
  1042. <span>py_checktype <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1043. <span>raise</span>
  1044. </a></span>
  1045. </h3>
  1046. </doc-anchor-target>
  1047. <div id="py_checktype-code-1" class="codeblock-wrapper"><doc-codeblock>
  1048. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Check if the object is an instance of the given type exactly.
  1049. /// Raise `TypeError` if the check fails.
  1050. PK_API bool py_checktype(py_Ref self, py_Type type);</code></pre>
  1051. </doc-codeblock></div>
  1052. <doc-anchor-target id="py_checkinstance">
  1053. <h3>
  1054. <doc-anchor-trigger class="header-anchor-trigger" to="#py_checkinstance">#</doc-anchor-trigger>
  1055. <span>py_checkinstance <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1056. <span>raise</span>
  1057. </a></span>
  1058. </h3>
  1059. </doc-anchor-target>
  1060. <div id="py_checkinstance-code-1" class="codeblock-wrapper"><doc-codeblock>
  1061. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Check if the object is an instance of the given type or its subclass.
  1062. /// Raise `TypeError` if the check fails.
  1063. PK_API bool py_checkinstance(py_Ref self, py_Type type);</code></pre>
  1064. </doc-codeblock></div>
  1065. <doc-anchor-target id="py_tpfindmagic">
  1066. <h3>
  1067. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tpfindmagic">#</doc-anchor-trigger>
  1068. <span>py_tpfindmagic</span>
  1069. </h3>
  1070. </doc-anchor-target>
  1071. <div id="py_tpfindmagic-code-1" class="codeblock-wrapper"><doc-codeblock>
  1072. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Search the magic method from the given type to the base type.
  1073. /// Return `NULL` if not found.
  1074. PK_API py_GlobalRef py_tpfindmagic(py_Type, py_Name name);</code></pre>
  1075. </doc-codeblock></div>
  1076. <doc-anchor-target id="py_tpfindname">
  1077. <h3>
  1078. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tpfindname">#</doc-anchor-trigger>
  1079. <span>py_tpfindname</span>
  1080. </h3>
  1081. </doc-anchor-target>
  1082. <div id="py_tpfindname-code-1" class="codeblock-wrapper"><doc-codeblock>
  1083. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Search the name from the given type to the base type.
  1084. /// Return `NULL` if not found.
  1085. PK_API py_ItemRef py_tpfindname(py_Type, py_Name name);</code></pre>
  1086. </doc-codeblock></div>
  1087. <doc-anchor-target id="py_tpbase">
  1088. <h3>
  1089. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tpbase">#</doc-anchor-trigger>
  1090. <span>py_tpbase</span>
  1091. </h3>
  1092. </doc-anchor-target>
  1093. <div id="py_tpbase-code-1" class="codeblock-wrapper"><doc-codeblock>
  1094. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the base type of the given type.
  1095. PK_API py_Type py_tpbase(py_Type type);</code></pre>
  1096. </doc-codeblock></div>
  1097. <doc-anchor-target id="py_tpobject">
  1098. <h3>
  1099. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tpobject">#</doc-anchor-trigger>
  1100. <span>py_tpobject</span>
  1101. </h3>
  1102. </doc-anchor-target>
  1103. <div id="py_tpobject-code-1" class="codeblock-wrapper"><doc-codeblock>
  1104. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the type object of the given type.
  1105. PK_API py_GlobalRef py_tpobject(py_Type type);</code></pre>
  1106. </doc-codeblock></div>
  1107. <doc-anchor-target id="py_tpsetfinal">
  1108. <h3>
  1109. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tpsetfinal">#</doc-anchor-trigger>
  1110. <span>py_tpsetfinal</span>
  1111. </h3>
  1112. </doc-anchor-target>
  1113. <div id="py_tpsetfinal-code-1" class="codeblock-wrapper"><doc-codeblock>
  1114. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Disable the type for subclassing.
  1115. PK_API void py_tpsetfinal(py_Type type);</code></pre>
  1116. </doc-codeblock></div>
  1117. <doc-anchor-target id="py_tphookattributes">
  1118. <h3>
  1119. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tphookattributes">#</doc-anchor-trigger>
  1120. <span>py_tphookattributes</span>
  1121. </h3>
  1122. </doc-anchor-target>
  1123. <div id="py_tphookattributes-code-1" class="codeblock-wrapper"><doc-codeblock>
  1124. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Set attribute hooks for the given type.
  1125. PK_API void py_tphookattributes(py_Type type,
  1126. bool (*getattribute)(py_Ref self, py_Name name) PY_RAISE PY_RETURN,
  1127. bool (*setattribute)(py_Ref self, py_Name name, py_Ref val)
  1128. PY_RAISE PY_RETURN,
  1129. bool (*delattribute)(py_Ref self, py_Name name) PY_RAISE,
  1130. bool (*getunboundmethod)(py_Ref self, py_Name name) PY_RETURN);</code></pre>
  1131. </doc-codeblock></div>
  1132. <doc-anchor-target id="py_inspect_currentfunction">
  1133. <h3>
  1134. <doc-anchor-trigger class="header-anchor-trigger" to="#py_inspect_currentfunction">#</doc-anchor-trigger>
  1135. <span>py_inspect_currentfunction</span>
  1136. </h3>
  1137. </doc-anchor-target>
  1138. <div id="py_inspect_currentfunction-code-1" class="codeblock-wrapper"><doc-codeblock>
  1139. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the current `function` object on the stack.
  1140. /// Return `NULL` if not available.
  1141. /// NOTE: This function should be placed at the beginning of your decl-based bindings.
  1142. PK_API py_StackRef py_inspect_currentfunction();</code></pre>
  1143. </doc-codeblock></div>
  1144. <doc-anchor-target id="py_inspect_currentmodule">
  1145. <h3>
  1146. <doc-anchor-trigger class="header-anchor-trigger" to="#py_inspect_currentmodule">#</doc-anchor-trigger>
  1147. <span>py_inspect_currentmodule</span>
  1148. </h3>
  1149. </doc-anchor-target>
  1150. <div id="py_inspect_currentmodule-code-1" class="codeblock-wrapper"><doc-codeblock>
  1151. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the current `module` object where the code is executed.
  1152. /// Return `NULL` if not available.
  1153. PK_API py_GlobalRef py_inspect_currentmodule();</code></pre>
  1154. </doc-codeblock></div>
  1155. <doc-anchor-target id="py_inspect_currentframe">
  1156. <h3>
  1157. <doc-anchor-trigger class="header-anchor-trigger" to="#py_inspect_currentframe">#</doc-anchor-trigger>
  1158. <span>py_inspect_currentframe</span>
  1159. </h3>
  1160. </doc-anchor-target>
  1161. <div id="py_inspect_currentframe-code-1" class="codeblock-wrapper"><doc-codeblock>
  1162. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the current frame object.
  1163. /// Return `NULL` if not available.
  1164. PK_API py_Frame* py_inspect_currentframe();</code></pre>
  1165. </doc-codeblock></div>
  1166. <doc-anchor-target id="py_newglobals">
  1167. <h3>
  1168. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newglobals">#</doc-anchor-trigger>
  1169. <span>py_newglobals</span>
  1170. </h3>
  1171. </doc-anchor-target>
  1172. <div id="py_newglobals-code-1" class="codeblock-wrapper"><doc-codeblock>
  1173. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `globals()`.
  1174. PK_API void py_newglobals(py_OutRef);</code></pre>
  1175. </doc-codeblock></div>
  1176. <doc-anchor-target id="py_newlocals">
  1177. <h3>
  1178. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newlocals">#</doc-anchor-trigger>
  1179. <span>py_newlocals</span>
  1180. </h3>
  1181. </doc-anchor-target>
  1182. <div id="py_newlocals-code-1" class="codeblock-wrapper"><doc-codeblock>
  1183. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `locals()`.
  1184. PK_API void py_newlocals(py_OutRef);</code></pre>
  1185. </doc-codeblock></div>
  1186. <doc-anchor-target id="py_getreg">
  1187. <h3>
  1188. <doc-anchor-trigger class="header-anchor-trigger" to="#py_getreg">#</doc-anchor-trigger>
  1189. <span>py_getreg</span>
  1190. </h3>
  1191. </doc-anchor-target>
  1192. <div id="py_getreg-code-1" class="codeblock-wrapper"><doc-codeblock>
  1193. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the i-th register.
  1194. /// All registers are located in a contiguous memory.
  1195. PK_API py_GlobalRef py_getreg(int i);</code></pre>
  1196. </doc-codeblock></div>
  1197. <doc-anchor-target id="py_setreg">
  1198. <h3>
  1199. <doc-anchor-trigger class="header-anchor-trigger" to="#py_setreg">#</doc-anchor-trigger>
  1200. <span>py_setreg</span>
  1201. </h3>
  1202. </doc-anchor-target>
  1203. <div id="py_setreg-code-1" class="codeblock-wrapper"><doc-codeblock>
  1204. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Set the i-th register.
  1205. PK_API void py_setreg(int i, py_Ref val);</code></pre>
  1206. </doc-codeblock></div>
  1207. <doc-anchor-target id="py_retval">
  1208. <h3>
  1209. <doc-anchor-trigger class="header-anchor-trigger" to="#py_retval">#</doc-anchor-trigger>
  1210. <span>py_retval</span>
  1211. </h3>
  1212. </doc-anchor-target>
  1213. <div id="py_retval-code-1" class="codeblock-wrapper"><doc-codeblock>
  1214. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the last return value.
  1215. /// Please note that `py_retval()` cannot be used as input argument.
  1216. PK_API py_GlobalRef py_retval();</code></pre>
  1217. </doc-codeblock></div>
  1218. <doc-anchor-target id="py_getdict">
  1219. <h3>
  1220. <doc-anchor-trigger class="header-anchor-trigger" to="#py_getdict">#</doc-anchor-trigger>
  1221. <span>py_getdict</span>
  1222. </h3>
  1223. </doc-anchor-target>
  1224. <div id="py_getdict-code-1" class="codeblock-wrapper"><doc-codeblock>
  1225. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get an item from the object's `__dict__`.
  1226. /// Return `NULL` if not found.
  1227. PK_API py_ItemRef py_getdict(py_Ref self, py_Name name);</code></pre>
  1228. </doc-codeblock></div>
  1229. <doc-anchor-target id="py_setdict">
  1230. <h3>
  1231. <doc-anchor-trigger class="header-anchor-trigger" to="#py_setdict">#</doc-anchor-trigger>
  1232. <span>py_setdict</span>
  1233. </h3>
  1234. </doc-anchor-target>
  1235. <div id="py_setdict-code-1" class="codeblock-wrapper"><doc-codeblock>
  1236. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Set an item to the object's `__dict__`.
  1237. PK_API void py_setdict(py_Ref self, py_Name name, py_Ref val);</code></pre>
  1238. </doc-codeblock></div>
  1239. <doc-anchor-target id="py_deldict">
  1240. <h3>
  1241. <doc-anchor-trigger class="header-anchor-trigger" to="#py_deldict">#</doc-anchor-trigger>
  1242. <span>py_deldict</span>
  1243. </h3>
  1244. </doc-anchor-target>
  1245. <div id="py_deldict-code-1" class="codeblock-wrapper"><doc-codeblock>
  1246. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Delete an item from the object's `__dict__`.
  1247. /// Return `true` if the deletion is successful.
  1248. PK_API bool py_deldict(py_Ref self, py_Name name);</code></pre>
  1249. </doc-codeblock></div>
  1250. <doc-anchor-target id="py_emplacedict">
  1251. <h3>
  1252. <doc-anchor-trigger class="header-anchor-trigger" to="#py_emplacedict">#</doc-anchor-trigger>
  1253. <span>py_emplacedict</span>
  1254. </h3>
  1255. </doc-anchor-target>
  1256. <div id="py_emplacedict-code-1" class="codeblock-wrapper"><doc-codeblock>
  1257. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Prepare an insertion to the object's `__dict__`.
  1258. PK_API py_ItemRef py_emplacedict(py_Ref self, py_Name name);</code></pre>
  1259. </doc-codeblock></div>
  1260. <doc-anchor-target id="py_applydict">
  1261. <h3>
  1262. <doc-anchor-trigger class="header-anchor-trigger" to="#py_applydict">#</doc-anchor-trigger>
  1263. <span>py_applydict <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1264. <span>raise</span>
  1265. </a></span>
  1266. </h3>
  1267. </doc-anchor-target>
  1268. <div id="py_applydict-code-1" class="codeblock-wrapper"><doc-codeblock>
  1269. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Apply a function to all items in the object's `__dict__`.
  1270. /// Return `true` if the function is successful for all items.
  1271. /// NOTE: Be careful if `f` modifies the object's `__dict__`.
  1272. PK_API bool py_applydict(py_Ref self, bool (*f)(py_Name name, py_Ref val, void* ctx), void* ctx);</code></pre>
  1273. </doc-codeblock></div>
  1274. <doc-anchor-target id="py_cleardict">
  1275. <h3>
  1276. <doc-anchor-trigger class="header-anchor-trigger" to="#py_cleardict">#</doc-anchor-trigger>
  1277. <span>py_cleardict</span>
  1278. </h3>
  1279. </doc-anchor-target>
  1280. <div id="py_cleardict-code-1" class="codeblock-wrapper"><doc-codeblock>
  1281. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Clear the object's `__dict__`. This function is dangerous.
  1282. PK_API void py_cleardict(py_Ref self);</code></pre>
  1283. </doc-codeblock></div>
  1284. <doc-anchor-target id="py_getslot">
  1285. <h3>
  1286. <doc-anchor-trigger class="header-anchor-trigger" to="#py_getslot">#</doc-anchor-trigger>
  1287. <span>py_getslot</span>
  1288. </h3>
  1289. </doc-anchor-target>
  1290. <div id="py_getslot-code-1" class="codeblock-wrapper"><doc-codeblock>
  1291. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the i-th slot of the object.
  1292. /// The object must have slots and `i` must be in valid range.
  1293. PK_API py_ObjectRef py_getslot(py_Ref self, int i);</code></pre>
  1294. </doc-codeblock></div>
  1295. <doc-anchor-target id="py_setslot">
  1296. <h3>
  1297. <doc-anchor-trigger class="header-anchor-trigger" to="#py_setslot">#</doc-anchor-trigger>
  1298. <span>py_setslot</span>
  1299. </h3>
  1300. </doc-anchor-target>
  1301. <div id="py_setslot-code-1" class="codeblock-wrapper"><doc-codeblock>
  1302. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Set the i-th slot of the object.
  1303. PK_API void py_setslot(py_Ref self, int i, py_Ref val);</code></pre>
  1304. </doc-codeblock></div>
  1305. <doc-anchor-target id="py_getbuiltin">
  1306. <h3>
  1307. <doc-anchor-trigger class="header-anchor-trigger" to="#py_getbuiltin">#</doc-anchor-trigger>
  1308. <span>py_getbuiltin</span>
  1309. </h3>
  1310. </doc-anchor-target>
  1311. <div id="py_getbuiltin-code-1" class="codeblock-wrapper"><doc-codeblock>
  1312. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get variable in the `builtins` module.
  1313. PK_API py_ItemRef py_getbuiltin(py_Name name);</code></pre>
  1314. </doc-codeblock></div>
  1315. <doc-anchor-target id="py_getglobal">
  1316. <h3>
  1317. <doc-anchor-trigger class="header-anchor-trigger" to="#py_getglobal">#</doc-anchor-trigger>
  1318. <span>py_getglobal</span>
  1319. </h3>
  1320. </doc-anchor-target>
  1321. <div id="py_getglobal-code-1" class="codeblock-wrapper"><doc-codeblock>
  1322. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get variable in the `__main__` module.
  1323. PK_API py_ItemRef py_getglobal(py_Name name);</code></pre>
  1324. </doc-codeblock></div>
  1325. <doc-anchor-target id="py_setglobal">
  1326. <h3>
  1327. <doc-anchor-trigger class="header-anchor-trigger" to="#py_setglobal">#</doc-anchor-trigger>
  1328. <span>py_setglobal</span>
  1329. </h3>
  1330. </doc-anchor-target>
  1331. <div id="py_setglobal-code-1" class="codeblock-wrapper"><doc-codeblock>
  1332. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Set variable in the `__main__` module.
  1333. PK_API void py_setglobal(py_Name name, py_Ref val);</code></pre>
  1334. </doc-codeblock></div>
  1335. <doc-anchor-target id="py_peek">
  1336. <h3>
  1337. <doc-anchor-trigger class="header-anchor-trigger" to="#py_peek">#</doc-anchor-trigger>
  1338. <span>py_peek</span>
  1339. </h3>
  1340. </doc-anchor-target>
  1341. <div id="py_peek-code-1" class="codeblock-wrapper"><doc-codeblock>
  1342. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the i-th object from the top of the stack.
  1343. /// `i` should be negative, e.g. (-1) means TOS.
  1344. PK_API py_StackRef py_peek(int i);</code></pre>
  1345. </doc-codeblock></div>
  1346. <doc-anchor-target id="py_push">
  1347. <h3>
  1348. <doc-anchor-trigger class="header-anchor-trigger" to="#py_push">#</doc-anchor-trigger>
  1349. <span>py_push</span>
  1350. </h3>
  1351. </doc-anchor-target>
  1352. <div id="py_push-code-1" class="codeblock-wrapper"><doc-codeblock>
  1353. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Push the object to the stack.
  1354. PK_API void py_push(py_Ref src);</code></pre>
  1355. </doc-codeblock></div>
  1356. <doc-anchor-target id="py_pushnil">
  1357. <h3>
  1358. <doc-anchor-trigger class="header-anchor-trigger" to="#py_pushnil">#</doc-anchor-trigger>
  1359. <span>py_pushnil</span>
  1360. </h3>
  1361. </doc-anchor-target>
  1362. <div id="py_pushnil-code-1" class="codeblock-wrapper"><doc-codeblock>
  1363. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Push a `nil` object to the stack.
  1364. PK_API void py_pushnil();</code></pre>
  1365. </doc-codeblock></div>
  1366. <doc-anchor-target id="py_pushnone">
  1367. <h3>
  1368. <doc-anchor-trigger class="header-anchor-trigger" to="#py_pushnone">#</doc-anchor-trigger>
  1369. <span>py_pushnone</span>
  1370. </h3>
  1371. </doc-anchor-target>
  1372. <div id="py_pushnone-code-1" class="codeblock-wrapper"><doc-codeblock>
  1373. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Push a `None` object to the stack.
  1374. PK_API void py_pushnone();</code></pre>
  1375. </doc-codeblock></div>
  1376. <doc-anchor-target id="py_pushname">
  1377. <h3>
  1378. <doc-anchor-trigger class="header-anchor-trigger" to="#py_pushname">#</doc-anchor-trigger>
  1379. <span>py_pushname</span>
  1380. </h3>
  1381. </doc-anchor-target>
  1382. <div id="py_pushname-code-1" class="codeblock-wrapper"><doc-codeblock>
  1383. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Push a `py_Name` to the stack. This is used for keyword arguments.
  1384. PK_API void py_pushname(py_Name name);</code></pre>
  1385. </doc-codeblock></div>
  1386. <doc-anchor-target id="py_pop">
  1387. <h3>
  1388. <doc-anchor-trigger class="header-anchor-trigger" to="#py_pop">#</doc-anchor-trigger>
  1389. <span>py_pop</span>
  1390. </h3>
  1391. </doc-anchor-target>
  1392. <div id="py_pop-code-1" class="codeblock-wrapper"><doc-codeblock>
  1393. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Pop an object from the stack.
  1394. PK_API void py_pop();</code></pre>
  1395. </doc-codeblock></div>
  1396. <doc-anchor-target id="py_shrink">
  1397. <h3>
  1398. <doc-anchor-trigger class="header-anchor-trigger" to="#py_shrink">#</doc-anchor-trigger>
  1399. <span>py_shrink</span>
  1400. </h3>
  1401. </doc-anchor-target>
  1402. <div id="py_shrink-code-1" class="codeblock-wrapper"><doc-codeblock>
  1403. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Shrink the stack by n.
  1404. PK_API void py_shrink(int n);</code></pre>
  1405. </doc-codeblock></div>
  1406. <doc-anchor-target id="py_pushtmp">
  1407. <h3>
  1408. <doc-anchor-trigger class="header-anchor-trigger" to="#py_pushtmp">#</doc-anchor-trigger>
  1409. <span>py_pushtmp</span>
  1410. </h3>
  1411. </doc-anchor-target>
  1412. <div id="py_pushtmp-code-1" class="codeblock-wrapper"><doc-codeblock>
  1413. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get a temporary variable from the stack.
  1414. PK_API py_StackRef py_pushtmp();</code></pre>
  1415. </doc-codeblock></div>
  1416. <doc-anchor-target id="py_pushmethod">
  1417. <h3>
  1418. <doc-anchor-trigger class="header-anchor-trigger" to="#py_pushmethod">#</doc-anchor-trigger>
  1419. <span>py_pushmethod</span>
  1420. </h3>
  1421. </doc-anchor-target>
  1422. <div id="py_pushmethod-code-1" class="codeblock-wrapper"><doc-codeblock>
  1423. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the unbound method of the object.
  1424. /// Assume the object is located at the top of the stack.
  1425. /// If return true: `[self] -&gt; [unbound, self]`.
  1426. /// If return false: `[self] -&gt; [self]` (no change).
  1427. PK_API bool py_pushmethod(py_Name name);</code></pre>
  1428. </doc-codeblock></div>
  1429. <doc-anchor-target id="py_pusheval">
  1430. <h3>
  1431. <doc-anchor-trigger class="header-anchor-trigger" to="#py_pusheval">#</doc-anchor-trigger>
  1432. <span>py_pusheval <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1433. <span>raise</span>
  1434. </a></span>
  1435. </h3>
  1436. </doc-anchor-target>
  1437. <div id="py_pusheval-code-1" class="codeblock-wrapper"><doc-codeblock>
  1438. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Evaluate an expression and push the result to the stack.
  1439. /// This function is used for testing.
  1440. PK_API bool py_pusheval(const char* expr, py_GlobalRef module);</code></pre>
  1441. </doc-codeblock></div>
  1442. <doc-anchor-target id="py_vectorcall">
  1443. <h3>
  1444. <doc-anchor-trigger class="header-anchor-trigger" to="#py_vectorcall">#</doc-anchor-trigger>
  1445. <span>py_vectorcall <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1446. <span>raise</span>
  1447. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1448. <span>return</span>
  1449. </a></span>
  1450. </h3>
  1451. </doc-anchor-target>
  1452. <div id="py_vectorcall-code-1" class="codeblock-wrapper"><doc-codeblock>
  1453. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Call a callable object via pocketpy's calling convention.
  1454. /// You need to prepare the stack using the following format:
  1455. /// `callable, self/nil, arg1, arg2, ..., k1, v1, k2, v2, ...`.
  1456. /// `argc` is the number of positional arguments excluding `self`.
  1457. /// `kwargc` is the number of keyword arguments.
  1458. /// The result will be set to `py_retval()`.
  1459. /// The stack size will be reduced by `2 + argc + kwargc * 2`.
  1460. PK_API bool py_vectorcall(uint16_t argc, uint16_t kwargc);</code></pre>
  1461. </doc-codeblock></div>
  1462. <doc-anchor-target id="py_call">
  1463. <h3>
  1464. <doc-anchor-trigger class="header-anchor-trigger" to="#py_call">#</doc-anchor-trigger>
  1465. <span>py_call <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1466. <span>raise</span>
  1467. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1468. <span>return</span>
  1469. </a></span>
  1470. </h3>
  1471. </doc-anchor-target>
  1472. <div id="py_call-code-1" class="codeblock-wrapper"><doc-codeblock>
  1473. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Call a function.
  1474. /// It prepares the stack and then performs a `vectorcall(argc, 0, false)`.
  1475. /// The result will be set to `py_retval()`.
  1476. /// The stack remains unchanged if successful.
  1477. PK_API bool py_call(py_Ref f, int argc, py_Ref argv);</code></pre>
  1478. </doc-codeblock></div>
  1479. <doc-anchor-target id="py_tpcall">
  1480. <h3>
  1481. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tpcall">#</doc-anchor-trigger>
  1482. <span>py_tpcall <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1483. <span>raise</span>
  1484. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1485. <span>return</span>
  1486. </a></span>
  1487. </h3>
  1488. </doc-anchor-target>
  1489. <div id="py_tpcall-code-1" class="codeblock-wrapper"><doc-codeblock>
  1490. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Call a type to create a new instance.
  1491. PK_API bool py_tpcall(py_Type type, int argc, py_Ref argv);</code></pre>
  1492. </doc-codeblock></div>
  1493. <doc-anchor-target id="py_callcfunc">
  1494. <h3>
  1495. <doc-anchor-trigger class="header-anchor-trigger" to="#py_callcfunc">#</doc-anchor-trigger>
  1496. <span>py_callcfunc <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1497. <span>raise</span>
  1498. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1499. <span>return</span>
  1500. </a></span>
  1501. </h3>
  1502. </doc-anchor-target>
  1503. <div id="py_callcfunc-code-1" class="codeblock-wrapper"><doc-codeblock>
  1504. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Call a `py_CFunction` in a safe way.
  1505. /// This function does extra checks to help you debug `py_CFunction`.
  1506. PK_API bool py_callcfunc(py_CFunction f, int argc, py_Ref argv);</code></pre>
  1507. </doc-codeblock></div>
  1508. <doc-anchor-target id="py_binaryop">
  1509. <h3>
  1510. <doc-anchor-trigger class="header-anchor-trigger" to="#py_binaryop">#</doc-anchor-trigger>
  1511. <span>py_binaryop <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1512. <span>raise</span>
  1513. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1514. <span>return</span>
  1515. </a></span>
  1516. </h3>
  1517. </doc-anchor-target>
  1518. <div id="py_binaryop-code-1" class="codeblock-wrapper"><doc-codeblock>
  1519. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Perform a binary operation.
  1520. /// The result will be set to `py_retval()`.
  1521. /// The stack remains unchanged after the operation.
  1522. PK_API bool py_binaryop(py_Ref lhs, py_Ref rhs, py_Name op, py_Name rop);</code></pre>
  1523. </doc-codeblock></div>
  1524. <doc-anchor-target id="py_binaryadd">
  1525. <h3>
  1526. <doc-anchor-trigger class="header-anchor-trigger" to="#py_binaryadd">#</doc-anchor-trigger>
  1527. <span>py_binaryadd <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1528. <span>raise</span>
  1529. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1530. <span>return</span>
  1531. </a></span>
  1532. </h3>
  1533. </doc-anchor-target>
  1534. <div id="py_binaryadd-code-1" class="codeblock-wrapper"><doc-codeblock>
  1535. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs + rhs
  1536. PK_API bool py_binaryadd(py_Ref lhs, py_Ref rhs);</code></pre>
  1537. </doc-codeblock></div>
  1538. <doc-anchor-target id="py_binarysub">
  1539. <h3>
  1540. <doc-anchor-trigger class="header-anchor-trigger" to="#py_binarysub">#</doc-anchor-trigger>
  1541. <span>py_binarysub <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1542. <span>raise</span>
  1543. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1544. <span>return</span>
  1545. </a></span>
  1546. </h3>
  1547. </doc-anchor-target>
  1548. <div id="py_binarysub-code-1" class="codeblock-wrapper"><doc-codeblock>
  1549. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs - rhs
  1550. PK_API bool py_binarysub(py_Ref lhs, py_Ref rhs);</code></pre>
  1551. </doc-codeblock></div>
  1552. <doc-anchor-target id="py_binarymul">
  1553. <h3>
  1554. <doc-anchor-trigger class="header-anchor-trigger" to="#py_binarymul">#</doc-anchor-trigger>
  1555. <span>py_binarymul <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1556. <span>raise</span>
  1557. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1558. <span>return</span>
  1559. </a></span>
  1560. </h3>
  1561. </doc-anchor-target>
  1562. <div id="py_binarymul-code-1" class="codeblock-wrapper"><doc-codeblock>
  1563. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs * rhs
  1564. PK_API bool py_binarymul(py_Ref lhs, py_Ref rhs);</code></pre>
  1565. </doc-codeblock></div>
  1566. <doc-anchor-target id="py_binarytruediv">
  1567. <h3>
  1568. <doc-anchor-trigger class="header-anchor-trigger" to="#py_binarytruediv">#</doc-anchor-trigger>
  1569. <span>py_binarytruediv <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1570. <span>raise</span>
  1571. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1572. <span>return</span>
  1573. </a></span>
  1574. </h3>
  1575. </doc-anchor-target>
  1576. <div id="py_binarytruediv-code-1" class="codeblock-wrapper"><doc-codeblock>
  1577. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs / rhs
  1578. PK_API bool py_binarytruediv(py_Ref lhs, py_Ref rhs);</code></pre>
  1579. </doc-codeblock></div>
  1580. <doc-anchor-target id="py_binaryfloordiv">
  1581. <h3>
  1582. <doc-anchor-trigger class="header-anchor-trigger" to="#py_binaryfloordiv">#</doc-anchor-trigger>
  1583. <span>py_binaryfloordiv <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1584. <span>raise</span>
  1585. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1586. <span>return</span>
  1587. </a></span>
  1588. </h3>
  1589. </doc-anchor-target>
  1590. <div id="py_binaryfloordiv-code-1" class="codeblock-wrapper"><doc-codeblock>
  1591. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs // rhs
  1592. PK_API bool py_binaryfloordiv(py_Ref lhs, py_Ref rhs);</code></pre>
  1593. </doc-codeblock></div>
  1594. <doc-anchor-target id="py_binarymod">
  1595. <h3>
  1596. <doc-anchor-trigger class="header-anchor-trigger" to="#py_binarymod">#</doc-anchor-trigger>
  1597. <span>py_binarymod <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1598. <span>raise</span>
  1599. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1600. <span>return</span>
  1601. </a></span>
  1602. </h3>
  1603. </doc-anchor-target>
  1604. <div id="py_binarymod-code-1" class="codeblock-wrapper"><doc-codeblock>
  1605. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs % rhs
  1606. PK_API bool py_binarymod(py_Ref lhs, py_Ref rhs);</code></pre>
  1607. </doc-codeblock></div>
  1608. <doc-anchor-target id="py_binarypow">
  1609. <h3>
  1610. <doc-anchor-trigger class="header-anchor-trigger" to="#py_binarypow">#</doc-anchor-trigger>
  1611. <span>py_binarypow <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1612. <span>raise</span>
  1613. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1614. <span>return</span>
  1615. </a></span>
  1616. </h3>
  1617. </doc-anchor-target>
  1618. <div id="py_binarypow-code-1" class="codeblock-wrapper"><doc-codeblock>
  1619. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs ** rhs
  1620. PK_API bool py_binarypow(py_Ref lhs, py_Ref rhs);</code></pre>
  1621. </doc-codeblock></div>
  1622. <doc-anchor-target id="py_binarylshift">
  1623. <h3>
  1624. <doc-anchor-trigger class="header-anchor-trigger" to="#py_binarylshift">#</doc-anchor-trigger>
  1625. <span>py_binarylshift <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1626. <span>raise</span>
  1627. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1628. <span>return</span>
  1629. </a></span>
  1630. </h3>
  1631. </doc-anchor-target>
  1632. <div id="py_binarylshift-code-1" class="codeblock-wrapper"><doc-codeblock>
  1633. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs &lt;&lt; rhs
  1634. PK_API bool py_binarylshift(py_Ref lhs, py_Ref rhs);</code></pre>
  1635. </doc-codeblock></div>
  1636. <doc-anchor-target id="py_binaryrshift">
  1637. <h3>
  1638. <doc-anchor-trigger class="header-anchor-trigger" to="#py_binaryrshift">#</doc-anchor-trigger>
  1639. <span>py_binaryrshift <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1640. <span>raise</span>
  1641. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1642. <span>return</span>
  1643. </a></span>
  1644. </h3>
  1645. </doc-anchor-target>
  1646. <div id="py_binaryrshift-code-1" class="codeblock-wrapper"><doc-codeblock>
  1647. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs &gt;&gt; rhs
  1648. PK_API bool py_binaryrshift(py_Ref lhs, py_Ref rhs);</code></pre>
  1649. </doc-codeblock></div>
  1650. <doc-anchor-target id="py_binaryand">
  1651. <h3>
  1652. <doc-anchor-trigger class="header-anchor-trigger" to="#py_binaryand">#</doc-anchor-trigger>
  1653. <span>py_binaryand <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1654. <span>raise</span>
  1655. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1656. <span>return</span>
  1657. </a></span>
  1658. </h3>
  1659. </doc-anchor-target>
  1660. <div id="py_binaryand-code-1" class="codeblock-wrapper"><doc-codeblock>
  1661. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs &amp; rhs
  1662. PK_API bool py_binaryand(py_Ref lhs, py_Ref rhs);</code></pre>
  1663. </doc-codeblock></div>
  1664. <doc-anchor-target id="py_binaryor">
  1665. <h3>
  1666. <doc-anchor-trigger class="header-anchor-trigger" to="#py_binaryor">#</doc-anchor-trigger>
  1667. <span>py_binaryor <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1668. <span>raise</span>
  1669. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1670. <span>return</span>
  1671. </a></span>
  1672. </h3>
  1673. </doc-anchor-target>
  1674. <div id="py_binaryor-code-1" class="codeblock-wrapper"><doc-codeblock>
  1675. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs | rhs
  1676. PK_API bool py_binaryor(py_Ref lhs, py_Ref rhs);</code></pre>
  1677. </doc-codeblock></div>
  1678. <doc-anchor-target id="py_binaryxor">
  1679. <h3>
  1680. <doc-anchor-trigger class="header-anchor-trigger" to="#py_binaryxor">#</doc-anchor-trigger>
  1681. <span>py_binaryxor <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1682. <span>raise</span>
  1683. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1684. <span>return</span>
  1685. </a></span>
  1686. </h3>
  1687. </doc-anchor-target>
  1688. <div id="py_binaryxor-code-1" class="codeblock-wrapper"><doc-codeblock>
  1689. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs ^ rhs
  1690. PK_API bool py_binaryxor(py_Ref lhs, py_Ref rhs);</code></pre>
  1691. </doc-codeblock></div>
  1692. <doc-anchor-target id="py_binarymatmul">
  1693. <h3>
  1694. <doc-anchor-trigger class="header-anchor-trigger" to="#py_binarymatmul">#</doc-anchor-trigger>
  1695. <span>py_binarymatmul <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1696. <span>raise</span>
  1697. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1698. <span>return</span>
  1699. </a></span>
  1700. </h3>
  1701. </doc-anchor-target>
  1702. <div id="py_binarymatmul-code-1" class="codeblock-wrapper"><doc-codeblock>
  1703. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs @ rhs
  1704. PK_API bool py_binarymatmul(py_Ref lhs, py_Ref rhs);</code></pre>
  1705. </doc-codeblock></div>
  1706. <doc-anchor-target id="py_eq">
  1707. <h3>
  1708. <doc-anchor-trigger class="header-anchor-trigger" to="#py_eq">#</doc-anchor-trigger>
  1709. <span>py_eq <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1710. <span>raise</span>
  1711. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1712. <span>return</span>
  1713. </a></span>
  1714. </h3>
  1715. </doc-anchor-target>
  1716. <div id="py_eq-code-1" class="codeblock-wrapper"><doc-codeblock>
  1717. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs == rhs
  1718. PK_API bool py_eq(py_Ref lhs, py_Ref rhs);</code></pre>
  1719. </doc-codeblock></div>
  1720. <doc-anchor-target id="py_ne">
  1721. <h3>
  1722. <doc-anchor-trigger class="header-anchor-trigger" to="#py_ne">#</doc-anchor-trigger>
  1723. <span>py_ne <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1724. <span>raise</span>
  1725. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1726. <span>return</span>
  1727. </a></span>
  1728. </h3>
  1729. </doc-anchor-target>
  1730. <div id="py_ne-code-1" class="codeblock-wrapper"><doc-codeblock>
  1731. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs != rhs
  1732. PK_API bool py_ne(py_Ref lhs, py_Ref rhs);</code></pre>
  1733. </doc-codeblock></div>
  1734. <doc-anchor-target id="py_lt">
  1735. <h3>
  1736. <doc-anchor-trigger class="header-anchor-trigger" to="#py_lt">#</doc-anchor-trigger>
  1737. <span>py_lt <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1738. <span>raise</span>
  1739. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1740. <span>return</span>
  1741. </a></span>
  1742. </h3>
  1743. </doc-anchor-target>
  1744. <div id="py_lt-code-1" class="codeblock-wrapper"><doc-codeblock>
  1745. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs &lt; rhs
  1746. PK_API bool py_lt(py_Ref lhs, py_Ref rhs);</code></pre>
  1747. </doc-codeblock></div>
  1748. <doc-anchor-target id="py_le">
  1749. <h3>
  1750. <doc-anchor-trigger class="header-anchor-trigger" to="#py_le">#</doc-anchor-trigger>
  1751. <span>py_le <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1752. <span>raise</span>
  1753. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1754. <span>return</span>
  1755. </a></span>
  1756. </h3>
  1757. </doc-anchor-target>
  1758. <div id="py_le-code-1" class="codeblock-wrapper"><doc-codeblock>
  1759. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs &lt;= rhs
  1760. PK_API bool py_le(py_Ref lhs, py_Ref rhs);</code></pre>
  1761. </doc-codeblock></div>
  1762. <doc-anchor-target id="py_gt">
  1763. <h3>
  1764. <doc-anchor-trigger class="header-anchor-trigger" to="#py_gt">#</doc-anchor-trigger>
  1765. <span>py_gt <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1766. <span>raise</span>
  1767. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1768. <span>return</span>
  1769. </a></span>
  1770. </h3>
  1771. </doc-anchor-target>
  1772. <div id="py_gt-code-1" class="codeblock-wrapper"><doc-codeblock>
  1773. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs &gt; rhs
  1774. PK_API bool py_gt(py_Ref lhs, py_Ref rhs);</code></pre>
  1775. </doc-codeblock></div>
  1776. <doc-anchor-target id="py_ge">
  1777. <h3>
  1778. <doc-anchor-trigger class="header-anchor-trigger" to="#py_ge">#</doc-anchor-trigger>
  1779. <span>py_ge <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1780. <span>raise</span>
  1781. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1782. <span>return</span>
  1783. </a></span>
  1784. </h3>
  1785. </doc-anchor-target>
  1786. <div id="py_ge-code-1" class="codeblock-wrapper"><doc-codeblock>
  1787. <pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs &gt;= rhs
  1788. PK_API bool py_ge(py_Ref lhs, py_Ref rhs);</code></pre>
  1789. </doc-codeblock></div>
  1790. <doc-anchor-target id="py_isidentical">
  1791. <h3>
  1792. <doc-anchor-trigger class="header-anchor-trigger" to="#py_isidentical">#</doc-anchor-trigger>
  1793. <span>py_isidentical</span>
  1794. </h3>
  1795. </doc-anchor-target>
  1796. <div id="py_isidentical-code-1" class="codeblock-wrapper"><doc-codeblock>
  1797. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `lhs is rhs`.
  1798. PK_API bool py_isidentical(py_Ref, py_Ref);</code></pre>
  1799. </doc-codeblock></div>
  1800. <doc-anchor-target id="py_bool">
  1801. <h3>
  1802. <doc-anchor-trigger class="header-anchor-trigger" to="#py_bool">#</doc-anchor-trigger>
  1803. <span>py_bool <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1804. <span>raise</span>
  1805. </a></span>
  1806. </h3>
  1807. </doc-anchor-target>
  1808. <div id="py_bool-code-1" class="codeblock-wrapper"><doc-codeblock>
  1809. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `bool(val)`.
  1810. /// 1: true, 0: false, -1: error
  1811. PK_API int py_bool(py_Ref val);</code></pre>
  1812. </doc-codeblock></div>
  1813. <doc-anchor-target id="py_equal">
  1814. <h3>
  1815. <doc-anchor-trigger class="header-anchor-trigger" to="#py_equal">#</doc-anchor-trigger>
  1816. <span>py_equal <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1817. <span>raise</span>
  1818. </a></span>
  1819. </h3>
  1820. </doc-anchor-target>
  1821. <div id="py_equal-code-1" class="codeblock-wrapper"><doc-codeblock>
  1822. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Compare two objects.
  1823. /// 1: lhs == rhs, 0: lhs != rhs, -1: error
  1824. PK_API int py_equal(py_Ref lhs, py_Ref rhs);</code></pre>
  1825. </doc-codeblock></div>
  1826. <doc-anchor-target id="py_less">
  1827. <h3>
  1828. <doc-anchor-trigger class="header-anchor-trigger" to="#py_less">#</doc-anchor-trigger>
  1829. <span>py_less <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1830. <span>raise</span>
  1831. </a></span>
  1832. </h3>
  1833. </doc-anchor-target>
  1834. <div id="py_less-code-1" class="codeblock-wrapper"><doc-codeblock>
  1835. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Compare two objects.
  1836. /// 1: lhs &lt; rhs, 0: lhs &gt;= rhs, -1: error
  1837. PK_API int py_less(py_Ref lhs, py_Ref rhs);</code></pre>
  1838. </doc-codeblock></div>
  1839. <doc-anchor-target id="py_callable">
  1840. <h3>
  1841. <doc-anchor-trigger class="header-anchor-trigger" to="#py_callable">#</doc-anchor-trigger>
  1842. <span>py_callable</span>
  1843. </h3>
  1844. </doc-anchor-target>
  1845. <div id="py_callable-code-1" class="codeblock-wrapper"><doc-codeblock>
  1846. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `callable(val)`.
  1847. PK_API bool py_callable(py_Ref val);</code></pre>
  1848. </doc-codeblock></div>
  1849. <doc-anchor-target id="py_hash">
  1850. <h3>
  1851. <doc-anchor-trigger class="header-anchor-trigger" to="#py_hash">#</doc-anchor-trigger>
  1852. <span>py_hash <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1853. <span>raise</span>
  1854. </a></span>
  1855. </h3>
  1856. </doc-anchor-target>
  1857. <div id="py_hash-code-1" class="codeblock-wrapper"><doc-codeblock>
  1858. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the hash value of the object.
  1859. PK_API bool py_hash(py_Ref, py_i64* out);</code></pre>
  1860. </doc-codeblock></div>
  1861. <doc-anchor-target id="py_iter">
  1862. <h3>
  1863. <doc-anchor-trigger class="header-anchor-trigger" to="#py_iter">#</doc-anchor-trigger>
  1864. <span>py_iter <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1865. <span>raise</span>
  1866. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1867. <span>return</span>
  1868. </a></span>
  1869. </h3>
  1870. </doc-anchor-target>
  1871. <div id="py_iter-code-1" class="codeblock-wrapper"><doc-codeblock>
  1872. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the iterator of the object.
  1873. PK_API bool py_iter(py_Ref);</code></pre>
  1874. </doc-codeblock></div>
  1875. <doc-anchor-target id="py_next">
  1876. <h3>
  1877. <doc-anchor-trigger class="header-anchor-trigger" to="#py_next">#</doc-anchor-trigger>
  1878. <span>py_next <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1879. <span>raise</span>
  1880. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1881. <span>return</span>
  1882. </a></span>
  1883. </h3>
  1884. </doc-anchor-target>
  1885. <div id="py_next-code-1" class="codeblock-wrapper"><doc-codeblock>
  1886. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the next element from the iterator.
  1887. /// 1: success, 0: StopIteration, -1: error
  1888. PK_API int py_next(py_Ref);</code></pre>
  1889. </doc-codeblock></div>
  1890. <doc-anchor-target id="py_str">
  1891. <h3>
  1892. <doc-anchor-trigger class="header-anchor-trigger" to="#py_str">#</doc-anchor-trigger>
  1893. <span>py_str <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1894. <span>raise</span>
  1895. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1896. <span>return</span>
  1897. </a></span>
  1898. </h3>
  1899. </doc-anchor-target>
  1900. <div id="py_str-code-1" class="codeblock-wrapper"><doc-codeblock>
  1901. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `str(val)`.
  1902. PK_API bool py_str(py_Ref val);</code></pre>
  1903. </doc-codeblock></div>
  1904. <doc-anchor-target id="py_repr">
  1905. <h3>
  1906. <doc-anchor-trigger class="header-anchor-trigger" to="#py_repr">#</doc-anchor-trigger>
  1907. <span>py_repr <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1908. <span>raise</span>
  1909. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1910. <span>return</span>
  1911. </a></span>
  1912. </h3>
  1913. </doc-anchor-target>
  1914. <div id="py_repr-code-1" class="codeblock-wrapper"><doc-codeblock>
  1915. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `repr(val)`.
  1916. PK_API bool py_repr(py_Ref val);</code></pre>
  1917. </doc-codeblock></div>
  1918. <doc-anchor-target id="py_len">
  1919. <h3>
  1920. <doc-anchor-trigger class="header-anchor-trigger" to="#py_len">#</doc-anchor-trigger>
  1921. <span>py_len <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1922. <span>raise</span>
  1923. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1924. <span>return</span>
  1925. </a></span>
  1926. </h3>
  1927. </doc-anchor-target>
  1928. <div id="py_len-code-1" class="codeblock-wrapper"><doc-codeblock>
  1929. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `len(val)`.
  1930. PK_API bool py_len(py_Ref val);</code></pre>
  1931. </doc-codeblock></div>
  1932. <doc-anchor-target id="py_getattr">
  1933. <h3>
  1934. <doc-anchor-trigger class="header-anchor-trigger" to="#py_getattr">#</doc-anchor-trigger>
  1935. <span>py_getattr <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1936. <span>raise</span>
  1937. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1938. <span>return</span>
  1939. </a></span>
  1940. </h3>
  1941. </doc-anchor-target>
  1942. <div id="py_getattr-code-1" class="codeblock-wrapper"><doc-codeblock>
  1943. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `getattr(self, name)`.
  1944. PK_API bool py_getattr(py_Ref self, py_Name name);</code></pre>
  1945. </doc-codeblock></div>
  1946. <doc-anchor-target id="py_setattr">
  1947. <h3>
  1948. <doc-anchor-trigger class="header-anchor-trigger" to="#py_setattr">#</doc-anchor-trigger>
  1949. <span>py_setattr <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1950. <span>raise</span>
  1951. </a></span>
  1952. </h3>
  1953. </doc-anchor-target>
  1954. <div id="py_setattr-code-1" class="codeblock-wrapper"><doc-codeblock>
  1955. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `setattr(self, name, val)`.
  1956. PK_API bool py_setattr(py_Ref self, py_Name name, py_Ref val);</code></pre>
  1957. </doc-codeblock></div>
  1958. <doc-anchor-target id="py_delattr">
  1959. <h3>
  1960. <doc-anchor-trigger class="header-anchor-trigger" to="#py_delattr">#</doc-anchor-trigger>
  1961. <span>py_delattr <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1962. <span>raise</span>
  1963. </a></span>
  1964. </h3>
  1965. </doc-anchor-target>
  1966. <div id="py_delattr-code-1" class="codeblock-wrapper"><doc-codeblock>
  1967. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `delattr(self, name)`.
  1968. PK_API bool py_delattr(py_Ref self, py_Name name);</code></pre>
  1969. </doc-codeblock></div>
  1970. <doc-anchor-target id="py_getitem">
  1971. <h3>
  1972. <doc-anchor-trigger class="header-anchor-trigger" to="#py_getitem">#</doc-anchor-trigger>
  1973. <span>py_getitem <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1974. <span>raise</span>
  1975. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1976. <span>return</span>
  1977. </a></span>
  1978. </h3>
  1979. </doc-anchor-target>
  1980. <div id="py_getitem-code-1" class="codeblock-wrapper"><doc-codeblock>
  1981. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `self[key]`.
  1982. PK_API bool py_getitem(py_Ref self, py_Ref key);</code></pre>
  1983. </doc-codeblock></div>
  1984. <doc-anchor-target id="py_setitem">
  1985. <h3>
  1986. <doc-anchor-trigger class="header-anchor-trigger" to="#py_setitem">#</doc-anchor-trigger>
  1987. <span>py_setitem <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  1988. <span>raise</span>
  1989. </a></span>
  1990. </h3>
  1991. </doc-anchor-target>
  1992. <div id="py_setitem-code-1" class="codeblock-wrapper"><doc-codeblock>
  1993. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `self[key] = val`.
  1994. PK_API bool py_setitem(py_Ref self, py_Ref key, py_Ref val);</code></pre>
  1995. </doc-codeblock></div>
  1996. <doc-anchor-target id="py_delitem">
  1997. <h3>
  1998. <doc-anchor-trigger class="header-anchor-trigger" to="#py_delitem">#</doc-anchor-trigger>
  1999. <span>py_delitem <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2000. <span>raise</span>
  2001. </a></span>
  2002. </h3>
  2003. </doc-anchor-target>
  2004. <div id="py_delitem-code-1" class="codeblock-wrapper"><doc-codeblock>
  2005. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `del self[key]`.
  2006. PK_API bool py_delitem(py_Ref self, py_Ref key);</code></pre>
  2007. </doc-codeblock></div>
  2008. <doc-anchor-target id="py_getmodule">
  2009. <h3>
  2010. <doc-anchor-trigger class="header-anchor-trigger" to="#py_getmodule">#</doc-anchor-trigger>
  2011. <span>py_getmodule</span>
  2012. </h3>
  2013. </doc-anchor-target>
  2014. <div id="py_getmodule-code-1" class="codeblock-wrapper"><doc-codeblock>
  2015. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Get a module by path.
  2016. PK_API py_GlobalRef py_getmodule(const char* path);</code></pre>
  2017. </doc-codeblock></div>
  2018. <doc-anchor-target id="py_newmodule">
  2019. <h3>
  2020. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newmodule">#</doc-anchor-trigger>
  2021. <span>py_newmodule</span>
  2022. </h3>
  2023. </doc-anchor-target>
  2024. <div id="py_newmodule-code-1" class="codeblock-wrapper"><doc-codeblock>
  2025. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a new module.
  2026. PK_API py_GlobalRef py_newmodule(const char* path);</code></pre>
  2027. </doc-codeblock></div>
  2028. <doc-anchor-target id="py_importlib_reload">
  2029. <h3>
  2030. <doc-anchor-trigger class="header-anchor-trigger" to="#py_importlib_reload">#</doc-anchor-trigger>
  2031. <span>py_importlib_reload <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2032. <span>raise</span>
  2033. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2034. <span>return</span>
  2035. </a></span>
  2036. </h3>
  2037. </doc-anchor-target>
  2038. <div id="py_importlib_reload-code-1" class="codeblock-wrapper"><doc-codeblock>
  2039. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Reload an existing module.
  2040. PK_API bool py_importlib_reload(py_Ref module);</code></pre>
  2041. </doc-codeblock></div>
  2042. <doc-anchor-target id="py_import">
  2043. <h3>
  2044. <doc-anchor-trigger class="header-anchor-trigger" to="#py_import">#</doc-anchor-trigger>
  2045. <span>py_import <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2046. <span>raise</span>
  2047. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2048. <span>return</span>
  2049. </a></span>
  2050. </h3>
  2051. </doc-anchor-target>
  2052. <div id="py_import-code-1" class="codeblock-wrapper"><doc-codeblock>
  2053. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Import a module.
  2054. /// The result will be set to `py_retval()`.
  2055. /// -1: error, 0: not found, 1: success
  2056. PK_API int py_import(const char* path);</code></pre>
  2057. </doc-codeblock></div>
  2058. <doc-anchor-target id="py_checkexc">
  2059. <h3>
  2060. <doc-anchor-trigger class="header-anchor-trigger" to="#py_checkexc">#</doc-anchor-trigger>
  2061. <span>py_checkexc</span>
  2062. </h3>
  2063. </doc-anchor-target>
  2064. <div id="py_checkexc-code-1" class="codeblock-wrapper"><doc-codeblock>
  2065. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Check if there is an unhandled exception.
  2066. PK_API bool py_checkexc();</code></pre>
  2067. </doc-codeblock></div>
  2068. <doc-anchor-target id="py_matchexc">
  2069. <h3>
  2070. <doc-anchor-trigger class="header-anchor-trigger" to="#py_matchexc">#</doc-anchor-trigger>
  2071. <span>py_matchexc <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2072. <span>return</span>
  2073. </a></span>
  2074. </h3>
  2075. </doc-anchor-target>
  2076. <div id="py_matchexc-code-1" class="codeblock-wrapper"><doc-codeblock>
  2077. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Check if the unhandled exception is an instance of the given type.
  2078. /// If match, the exception will be stored in `py_retval()`.
  2079. PK_API bool py_matchexc(py_Type type);</code></pre>
  2080. </doc-codeblock></div>
  2081. <doc-anchor-target id="py_clearexc">
  2082. <h3>
  2083. <doc-anchor-trigger class="header-anchor-trigger" to="#py_clearexc">#</doc-anchor-trigger>
  2084. <span>py_clearexc</span>
  2085. </h3>
  2086. </doc-anchor-target>
  2087. <div id="py_clearexc-code-1" class="codeblock-wrapper"><doc-codeblock>
  2088. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Clear the unhandled exception.
  2089. /// @param p0 the unwinding point. Use `NULL` if not needed.
  2090. PK_API void py_clearexc(py_StackRef p0);</code></pre>
  2091. </doc-codeblock></div>
  2092. <doc-anchor-target id="py_printexc">
  2093. <h3>
  2094. <doc-anchor-trigger class="header-anchor-trigger" to="#py_printexc">#</doc-anchor-trigger>
  2095. <span>py_printexc</span>
  2096. </h3>
  2097. </doc-anchor-target>
  2098. <div id="py_printexc-code-1" class="codeblock-wrapper"><doc-codeblock>
  2099. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Print the unhandled exception.
  2100. PK_API void py_printexc();</code></pre>
  2101. </doc-codeblock></div>
  2102. <doc-anchor-target id="py_formatexc">
  2103. <h3>
  2104. <doc-anchor-trigger class="header-anchor-trigger" to="#py_formatexc">#</doc-anchor-trigger>
  2105. <span>py_formatexc</span>
  2106. </h3>
  2107. </doc-anchor-target>
  2108. <div id="py_formatexc-code-1" class="codeblock-wrapper"><doc-codeblock>
  2109. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Format the unhandled exception and return a null-terminated string.
  2110. /// The returned string should be freed by the caller.
  2111. PK_API char* py_formatexc();</code></pre>
  2112. </doc-codeblock></div>
  2113. <doc-anchor-target id="py_exception">
  2114. <h3>
  2115. <doc-anchor-trigger class="header-anchor-trigger" to="#py_exception">#</doc-anchor-trigger>
  2116. <span>py_exception <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2117. <span>raise</span>
  2118. </a></span>
  2119. </h3>
  2120. </doc-anchor-target>
  2121. <div id="py_exception-code-1" class="codeblock-wrapper"><doc-codeblock>
  2122. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Raise an exception by type and message. Always return false.
  2123. PK_API bool py_exception(py_Type type, const char* fmt, ...);</code></pre>
  2124. </doc-codeblock></div>
  2125. <doc-anchor-target id="py_raise">
  2126. <h3>
  2127. <doc-anchor-trigger class="header-anchor-trigger" to="#py_raise">#</doc-anchor-trigger>
  2128. <span>py_raise <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2129. <span>raise</span>
  2130. </a></span>
  2131. </h3>
  2132. </doc-anchor-target>
  2133. <div id="py_raise-code-1" class="codeblock-wrapper"><doc-codeblock>
  2134. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Raise an exception object. Always return false.
  2135. PK_API bool py_raise(py_Ref);</code></pre>
  2136. </doc-codeblock></div>
  2137. <doc-anchor-target id="keyerror">
  2138. <h3>
  2139. <doc-anchor-trigger class="header-anchor-trigger" to="#keyerror">#</doc-anchor-trigger>
  2140. <span>KeyError <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2141. <span>raise</span>
  2142. </a></span>
  2143. </h3>
  2144. </doc-anchor-target>
  2145. <div id="keyerror-code-1" class="codeblock-wrapper"><doc-codeblock>
  2146. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2147. PK_API bool KeyError(py_Ref key);</code></pre>
  2148. </doc-codeblock></div>
  2149. <doc-anchor-target id="stopiteration">
  2150. <h3>
  2151. <doc-anchor-trigger class="header-anchor-trigger" to="#stopiteration">#</doc-anchor-trigger>
  2152. <span>StopIteration <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2153. <span>raise</span>
  2154. </a></span>
  2155. </h3>
  2156. </doc-anchor-target>
  2157. <div id="stopiteration-code-1" class="codeblock-wrapper"><doc-codeblock>
  2158. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2159. PK_API bool StopIteration();</code></pre>
  2160. </doc-codeblock></div>
  2161. <doc-anchor-target id="py_debugger_waitforattach">
  2162. <h3>
  2163. <doc-anchor-trigger class="header-anchor-trigger" to="#py_debugger_waitforattach">#</doc-anchor-trigger>
  2164. <span>py_debugger_waitforattach</span>
  2165. </h3>
  2166. </doc-anchor-target>
  2167. <div id="py_debugger_waitforattach-code-1" class="codeblock-wrapper"><doc-codeblock>
  2168. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2169. PK_API void py_debugger_waitforattach(const char* hostname, unsigned short port);</code></pre>
  2170. </doc-codeblock></div>
  2171. <doc-anchor-target id="py_debugger_status">
  2172. <h3>
  2173. <doc-anchor-trigger class="header-anchor-trigger" to="#py_debugger_status">#</doc-anchor-trigger>
  2174. <span>py_debugger_status</span>
  2175. </h3>
  2176. </doc-anchor-target>
  2177. <div id="py_debugger_status-code-1" class="codeblock-wrapper"><doc-codeblock>
  2178. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2179. PK_API int py_debugger_status();</code></pre>
  2180. </doc-codeblock></div>
  2181. <doc-anchor-target id="py_debugger_exceptionbreakpoint">
  2182. <h3>
  2183. <doc-anchor-trigger class="header-anchor-trigger" to="#py_debugger_exceptionbreakpoint">#</doc-anchor-trigger>
  2184. <span>py_debugger_exceptionbreakpoint</span>
  2185. </h3>
  2186. </doc-anchor-target>
  2187. <div id="py_debugger_exceptionbreakpoint-code-1" class="codeblock-wrapper"><doc-codeblock>
  2188. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2189. PK_API void py_debugger_exceptionbreakpoint(py_Ref exc);</code></pre>
  2190. </doc-codeblock></div>
  2191. <doc-anchor-target id="py_debugger_exit">
  2192. <h3>
  2193. <doc-anchor-trigger class="header-anchor-trigger" to="#py_debugger_exit">#</doc-anchor-trigger>
  2194. <span>py_debugger_exit</span>
  2195. </h3>
  2196. </doc-anchor-target>
  2197. <div id="py_debugger_exit-code-1" class="codeblock-wrapper"><doc-codeblock>
  2198. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2199. PK_API void py_debugger_exit(int code);</code></pre>
  2200. </doc-codeblock></div>
  2201. <doc-anchor-target id="py_newtuple">
  2202. <h3>
  2203. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newtuple">#</doc-anchor-trigger>
  2204. <span>py_newtuple</span>
  2205. </h3>
  2206. </doc-anchor-target>
  2207. <div id="py_newtuple-code-1" class="codeblock-wrapper"><doc-codeblock>
  2208. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `tuple` with `n` UNINITIALIZED elements.
  2209. /// You should initialize all elements before using it.
  2210. PK_API py_ObjectRef py_newtuple(py_OutRef, int n);</code></pre>
  2211. </doc-codeblock></div>
  2212. <doc-anchor-target id="py_tuple_data">
  2213. <h3>
  2214. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tuple_data">#</doc-anchor-trigger>
  2215. <span>py_tuple_data</span>
  2216. </h3>
  2217. </doc-anchor-target>
  2218. <div id="py_tuple_data-code-1" class="codeblock-wrapper"><doc-codeblock>
  2219. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2220. PK_API py_ObjectRef py_tuple_data(py_Ref self);</code></pre>
  2221. </doc-codeblock></div>
  2222. <doc-anchor-target id="py_tuple_getitem">
  2223. <h3>
  2224. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tuple_getitem">#</doc-anchor-trigger>
  2225. <span>py_tuple_getitem</span>
  2226. </h3>
  2227. </doc-anchor-target>
  2228. <div id="py_tuple_getitem-code-1" class="codeblock-wrapper"><doc-codeblock>
  2229. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2230. PK_API py_ObjectRef py_tuple_getitem(py_Ref self, int i);</code></pre>
  2231. </doc-codeblock></div>
  2232. <doc-anchor-target id="py_tuple_setitem">
  2233. <h3>
  2234. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tuple_setitem">#</doc-anchor-trigger>
  2235. <span>py_tuple_setitem</span>
  2236. </h3>
  2237. </doc-anchor-target>
  2238. <div id="py_tuple_setitem-code-1" class="codeblock-wrapper"><doc-codeblock>
  2239. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2240. PK_API void py_tuple_setitem(py_Ref self, int i, py_Ref val);</code></pre>
  2241. </doc-codeblock></div>
  2242. <doc-anchor-target id="py_tuple_len">
  2243. <h3>
  2244. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tuple_len">#</doc-anchor-trigger>
  2245. <span>py_tuple_len</span>
  2246. </h3>
  2247. </doc-anchor-target>
  2248. <div id="py_tuple_len-code-1" class="codeblock-wrapper"><doc-codeblock>
  2249. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2250. PK_API int py_tuple_len(py_Ref self);</code></pre>
  2251. </doc-codeblock></div>
  2252. <doc-anchor-target id="py_newlist">
  2253. <h3>
  2254. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newlist">#</doc-anchor-trigger>
  2255. <span>py_newlist</span>
  2256. </h3>
  2257. </doc-anchor-target>
  2258. <div id="py_newlist-code-1" class="codeblock-wrapper"><doc-codeblock>
  2259. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create an empty `list`.
  2260. PK_API void py_newlist(py_OutRef);</code></pre>
  2261. </doc-codeblock></div>
  2262. <doc-anchor-target id="py_newlistn">
  2263. <h3>
  2264. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newlistn">#</doc-anchor-trigger>
  2265. <span>py_newlistn</span>
  2266. </h3>
  2267. </doc-anchor-target>
  2268. <div id="py_newlistn-code-1" class="codeblock-wrapper"><doc-codeblock>
  2269. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `list` with `n` UNINITIALIZED elements.
  2270. /// You should initialize all elements before using it.
  2271. PK_API void py_newlistn(py_OutRef, int n);</code></pre>
  2272. </doc-codeblock></div>
  2273. <doc-anchor-target id="py_list_data">
  2274. <h3>
  2275. <doc-anchor-trigger class="header-anchor-trigger" to="#py_list_data">#</doc-anchor-trigger>
  2276. <span>py_list_data</span>
  2277. </h3>
  2278. </doc-anchor-target>
  2279. <div id="py_list_data-code-1" class="codeblock-wrapper"><doc-codeblock>
  2280. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2281. PK_API py_ItemRef py_list_data(py_Ref self);</code></pre>
  2282. </doc-codeblock></div>
  2283. <doc-anchor-target id="py_list_getitem">
  2284. <h3>
  2285. <doc-anchor-trigger class="header-anchor-trigger" to="#py_list_getitem">#</doc-anchor-trigger>
  2286. <span>py_list_getitem</span>
  2287. </h3>
  2288. </doc-anchor-target>
  2289. <div id="py_list_getitem-code-1" class="codeblock-wrapper"><doc-codeblock>
  2290. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2291. PK_API py_ItemRef py_list_getitem(py_Ref self, int i);</code></pre>
  2292. </doc-codeblock></div>
  2293. <doc-anchor-target id="py_list_setitem">
  2294. <h3>
  2295. <doc-anchor-trigger class="header-anchor-trigger" to="#py_list_setitem">#</doc-anchor-trigger>
  2296. <span>py_list_setitem</span>
  2297. </h3>
  2298. </doc-anchor-target>
  2299. <div id="py_list_setitem-code-1" class="codeblock-wrapper"><doc-codeblock>
  2300. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2301. PK_API void py_list_setitem(py_Ref self, int i, py_Ref val);</code></pre>
  2302. </doc-codeblock></div>
  2303. <doc-anchor-target id="py_list_delitem">
  2304. <h3>
  2305. <doc-anchor-trigger class="header-anchor-trigger" to="#py_list_delitem">#</doc-anchor-trigger>
  2306. <span>py_list_delitem</span>
  2307. </h3>
  2308. </doc-anchor-target>
  2309. <div id="py_list_delitem-code-1" class="codeblock-wrapper"><doc-codeblock>
  2310. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2311. PK_API void py_list_delitem(py_Ref self, int i);</code></pre>
  2312. </doc-codeblock></div>
  2313. <doc-anchor-target id="py_list_len">
  2314. <h3>
  2315. <doc-anchor-trigger class="header-anchor-trigger" to="#py_list_len">#</doc-anchor-trigger>
  2316. <span>py_list_len</span>
  2317. </h3>
  2318. </doc-anchor-target>
  2319. <div id="py_list_len-code-1" class="codeblock-wrapper"><doc-codeblock>
  2320. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2321. PK_API int py_list_len(py_Ref self);</code></pre>
  2322. </doc-codeblock></div>
  2323. <doc-anchor-target id="py_list_swap">
  2324. <h3>
  2325. <doc-anchor-trigger class="header-anchor-trigger" to="#py_list_swap">#</doc-anchor-trigger>
  2326. <span>py_list_swap</span>
  2327. </h3>
  2328. </doc-anchor-target>
  2329. <div id="py_list_swap-code-1" class="codeblock-wrapper"><doc-codeblock>
  2330. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2331. PK_API void py_list_swap(py_Ref self, int i, int j);</code></pre>
  2332. </doc-codeblock></div>
  2333. <doc-anchor-target id="py_list_append">
  2334. <h3>
  2335. <doc-anchor-trigger class="header-anchor-trigger" to="#py_list_append">#</doc-anchor-trigger>
  2336. <span>py_list_append</span>
  2337. </h3>
  2338. </doc-anchor-target>
  2339. <div id="py_list_append-code-1" class="codeblock-wrapper"><doc-codeblock>
  2340. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2341. PK_API void py_list_append(py_Ref self, py_Ref val);</code></pre>
  2342. </doc-codeblock></div>
  2343. <doc-anchor-target id="py_list_emplace">
  2344. <h3>
  2345. <doc-anchor-trigger class="header-anchor-trigger" to="#py_list_emplace">#</doc-anchor-trigger>
  2346. <span>py_list_emplace</span>
  2347. </h3>
  2348. </doc-anchor-target>
  2349. <div id="py_list_emplace-code-1" class="codeblock-wrapper"><doc-codeblock>
  2350. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2351. PK_API py_ItemRef py_list_emplace(py_Ref self);</code></pre>
  2352. </doc-codeblock></div>
  2353. <doc-anchor-target id="py_list_clear">
  2354. <h3>
  2355. <doc-anchor-trigger class="header-anchor-trigger" to="#py_list_clear">#</doc-anchor-trigger>
  2356. <span>py_list_clear</span>
  2357. </h3>
  2358. </doc-anchor-target>
  2359. <div id="py_list_clear-code-1" class="codeblock-wrapper"><doc-codeblock>
  2360. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2361. PK_API void py_list_clear(py_Ref self);</code></pre>
  2362. </doc-codeblock></div>
  2363. <doc-anchor-target id="py_list_insert">
  2364. <h3>
  2365. <doc-anchor-trigger class="header-anchor-trigger" to="#py_list_insert">#</doc-anchor-trigger>
  2366. <span>py_list_insert</span>
  2367. </h3>
  2368. </doc-anchor-target>
  2369. <div id="py_list_insert-code-1" class="codeblock-wrapper"><doc-codeblock>
  2370. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2371. PK_API void py_list_insert(py_Ref self, int i, py_Ref val);</code></pre>
  2372. </doc-codeblock></div>
  2373. <doc-anchor-target id="py_newdict">
  2374. <h3>
  2375. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newdict">#</doc-anchor-trigger>
  2376. <span>py_newdict</span>
  2377. </h3>
  2378. </doc-anchor-target>
  2379. <div id="py_newdict-code-1" class="codeblock-wrapper"><doc-codeblock>
  2380. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create an empty `dict`.
  2381. PK_API void py_newdict(py_OutRef);</code></pre>
  2382. </doc-codeblock></div>
  2383. <doc-anchor-target id="py_dict_getitem">
  2384. <h3>
  2385. <doc-anchor-trigger class="header-anchor-trigger" to="#py_dict_getitem">#</doc-anchor-trigger>
  2386. <span>py_dict_getitem <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2387. <span>raise</span>
  2388. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2389. <span>return</span>
  2390. </a></span>
  2391. </h3>
  2392. </doc-anchor-target>
  2393. <div id="py_dict_getitem-code-1" class="codeblock-wrapper"><doc-codeblock>
  2394. <pre translate="no" class="language-c"><code v-pre class="language-c">/// -1: error, 0: not found, 1: found
  2395. PK_API int py_dict_getitem(py_Ref self, py_Ref key);</code></pre>
  2396. </doc-codeblock></div>
  2397. <doc-anchor-target id="py_dict_setitem">
  2398. <h3>
  2399. <doc-anchor-trigger class="header-anchor-trigger" to="#py_dict_setitem">#</doc-anchor-trigger>
  2400. <span>py_dict_setitem <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2401. <span>raise</span>
  2402. </a></span>
  2403. </h3>
  2404. </doc-anchor-target>
  2405. <div id="py_dict_setitem-code-1" class="codeblock-wrapper"><doc-codeblock>
  2406. <pre translate="no" class="language-c"><code v-pre class="language-c">/// true: success, false: error
  2407. PK_API bool py_dict_setitem(py_Ref self, py_Ref key, py_Ref val);</code></pre>
  2408. </doc-codeblock></div>
  2409. <doc-anchor-target id="py_dict_delitem">
  2410. <h3>
  2411. <doc-anchor-trigger class="header-anchor-trigger" to="#py_dict_delitem">#</doc-anchor-trigger>
  2412. <span>py_dict_delitem <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2413. <span>raise</span>
  2414. </a></span>
  2415. </h3>
  2416. </doc-anchor-target>
  2417. <div id="py_dict_delitem-code-1" class="codeblock-wrapper"><doc-codeblock>
  2418. <pre translate="no" class="language-c"><code v-pre class="language-c">/// -1: error, 0: not found, 1: found (and deleted)
  2419. PK_API int py_dict_delitem(py_Ref self, py_Ref key);</code></pre>
  2420. </doc-codeblock></div>
  2421. <doc-anchor-target id="py_dict_getitem_by_str">
  2422. <h3>
  2423. <doc-anchor-trigger class="header-anchor-trigger" to="#py_dict_getitem_by_str">#</doc-anchor-trigger>
  2424. <span>py_dict_getitem_by_str <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2425. <span>raise</span>
  2426. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2427. <span>return</span>
  2428. </a></span>
  2429. </h3>
  2430. </doc-anchor-target>
  2431. <div id="py_dict_getitem_by_str-code-1" class="codeblock-wrapper"><doc-codeblock>
  2432. <pre translate="no" class="language-c"><code v-pre class="language-c">/// -1: error, 0: not found, 1: found
  2433. PK_API int py_dict_getitem_by_str(py_Ref self, const char* key);</code></pre>
  2434. </doc-codeblock></div>
  2435. <doc-anchor-target id="py_dict_getitem_by_int">
  2436. <h3>
  2437. <doc-anchor-trigger class="header-anchor-trigger" to="#py_dict_getitem_by_int">#</doc-anchor-trigger>
  2438. <span>py_dict_getitem_by_int <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2439. <span>raise</span>
  2440. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2441. <span>return</span>
  2442. </a></span>
  2443. </h3>
  2444. </doc-anchor-target>
  2445. <div id="py_dict_getitem_by_int-code-1" class="codeblock-wrapper"><doc-codeblock>
  2446. <pre translate="no" class="language-c"><code v-pre class="language-c">/// -1: error, 0: not found, 1: found
  2447. PK_API int py_dict_getitem_by_int(py_Ref self, py_i64 key);</code></pre>
  2448. </doc-codeblock></div>
  2449. <doc-anchor-target id="py_dict_setitem_by_str">
  2450. <h3>
  2451. <doc-anchor-trigger class="header-anchor-trigger" to="#py_dict_setitem_by_str">#</doc-anchor-trigger>
  2452. <span>py_dict_setitem_by_str <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2453. <span>raise</span>
  2454. </a></span>
  2455. </h3>
  2456. </doc-anchor-target>
  2457. <div id="py_dict_setitem_by_str-code-1" class="codeblock-wrapper"><doc-codeblock>
  2458. <pre translate="no" class="language-c"><code v-pre class="language-c">/// true: success, false: error
  2459. PK_API bool py_dict_setitem_by_str(py_Ref self, const char* key, py_Ref val);</code></pre>
  2460. </doc-codeblock></div>
  2461. <doc-anchor-target id="py_dict_setitem_by_int">
  2462. <h3>
  2463. <doc-anchor-trigger class="header-anchor-trigger" to="#py_dict_setitem_by_int">#</doc-anchor-trigger>
  2464. <span>py_dict_setitem_by_int <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2465. <span>raise</span>
  2466. </a></span>
  2467. </h3>
  2468. </doc-anchor-target>
  2469. <div id="py_dict_setitem_by_int-code-1" class="codeblock-wrapper"><doc-codeblock>
  2470. <pre translate="no" class="language-c"><code v-pre class="language-c">/// true: success, false: error
  2471. PK_API bool py_dict_setitem_by_int(py_Ref self, py_i64 key, py_Ref val);</code></pre>
  2472. </doc-codeblock></div>
  2473. <doc-anchor-target id="py_dict_delitem_by_str">
  2474. <h3>
  2475. <doc-anchor-trigger class="header-anchor-trigger" to="#py_dict_delitem_by_str">#</doc-anchor-trigger>
  2476. <span>py_dict_delitem_by_str <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2477. <span>raise</span>
  2478. </a></span>
  2479. </h3>
  2480. </doc-anchor-target>
  2481. <div id="py_dict_delitem_by_str-code-1" class="codeblock-wrapper"><doc-codeblock>
  2482. <pre translate="no" class="language-c"><code v-pre class="language-c">/// -1: error, 0: not found, 1: found (and deleted)
  2483. PK_API int py_dict_delitem_by_str(py_Ref self, const char* key);</code></pre>
  2484. </doc-codeblock></div>
  2485. <doc-anchor-target id="py_dict_delitem_by_int">
  2486. <h3>
  2487. <doc-anchor-trigger class="header-anchor-trigger" to="#py_dict_delitem_by_int">#</doc-anchor-trigger>
  2488. <span>py_dict_delitem_by_int <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2489. <span>raise</span>
  2490. </a></span>
  2491. </h3>
  2492. </doc-anchor-target>
  2493. <div id="py_dict_delitem_by_int-code-1" class="codeblock-wrapper"><doc-codeblock>
  2494. <pre translate="no" class="language-c"><code v-pre class="language-c">/// -1: error, 0: not found, 1: found (and deleted)
  2495. PK_API int py_dict_delitem_by_int(py_Ref self, py_i64 key);</code></pre>
  2496. </doc-codeblock></div>
  2497. <doc-anchor-target id="py_dict_apply">
  2498. <h3>
  2499. <doc-anchor-trigger class="header-anchor-trigger" to="#py_dict_apply">#</doc-anchor-trigger>
  2500. <span>py_dict_apply <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2501. <span>raise</span>
  2502. </a></span>
  2503. </h3>
  2504. </doc-anchor-target>
  2505. <div id="py_dict_apply-code-1" class="codeblock-wrapper"><doc-codeblock>
  2506. <pre translate="no" class="language-c"><code v-pre class="language-c">/// true: success, false: error
  2507. PK_API bool py_dict_apply(py_Ref self, bool (*f)(py_Ref key, py_Ref val, void* ctx), void* ctx);</code></pre>
  2508. </doc-codeblock></div>
  2509. <doc-anchor-target id="py_dict_len">
  2510. <h3>
  2511. <doc-anchor-trigger class="header-anchor-trigger" to="#py_dict_len">#</doc-anchor-trigger>
  2512. <span>py_dict_len</span>
  2513. </h3>
  2514. </doc-anchor-target>
  2515. <div id="py_dict_len-code-1" class="codeblock-wrapper"><doc-codeblock>
  2516. <pre translate="no" class="language-c"><code v-pre class="language-c">/// noexcept
  2517. PK_API int py_dict_len(py_Ref self);</code></pre>
  2518. </doc-codeblock></div>
  2519. <doc-anchor-target id="py_newslice">
  2520. <h3>
  2521. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newslice">#</doc-anchor-trigger>
  2522. <span>py_newslice</span>
  2523. </h3>
  2524. </doc-anchor-target>
  2525. <div id="py_newslice-code-1" class="codeblock-wrapper"><doc-codeblock>
  2526. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create an UNINITIALIZED `slice` object.
  2527. /// You should use `py_setslot()` to set `start`, `stop`, and `step`.
  2528. PK_API py_ObjectRef py_newslice(py_OutRef);</code></pre>
  2529. </doc-codeblock></div>
  2530. <doc-anchor-target id="py_newsliceint">
  2531. <h3>
  2532. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newsliceint">#</doc-anchor-trigger>
  2533. <span>py_newsliceint</span>
  2534. </h3>
  2535. </doc-anchor-target>
  2536. <div id="py_newsliceint-code-1" class="codeblock-wrapper"><doc-codeblock>
  2537. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `slice` object from 3 integers.
  2538. PK_API void py_newsliceint(py_OutRef out, py_i64 start, py_i64 stop, py_i64 step);</code></pre>
  2539. </doc-codeblock></div>
  2540. <doc-anchor-target id="py_newrandom">
  2541. <h3>
  2542. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newrandom">#</doc-anchor-trigger>
  2543. <span>py_newRandom</span>
  2544. </h3>
  2545. </doc-anchor-target>
  2546. <div id="py_newrandom-code-1" class="codeblock-wrapper"><doc-codeblock>
  2547. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2548. PK_API void py_newRandom(py_OutRef out);</code></pre>
  2549. </doc-codeblock></div>
  2550. <doc-anchor-target id="py_random_seed">
  2551. <h3>
  2552. <doc-anchor-trigger class="header-anchor-trigger" to="#py_random_seed">#</doc-anchor-trigger>
  2553. <span>py_Random_seed</span>
  2554. </h3>
  2555. </doc-anchor-target>
  2556. <div id="py_random_seed-code-1" class="codeblock-wrapper"><doc-codeblock>
  2557. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2558. PK_API void py_Random_seed(py_Ref self, py_i64 seed);</code></pre>
  2559. </doc-codeblock></div>
  2560. <doc-anchor-target id="py_random_random">
  2561. <h3>
  2562. <doc-anchor-trigger class="header-anchor-trigger" to="#py_random_random">#</doc-anchor-trigger>
  2563. <span>py_Random_random</span>
  2564. </h3>
  2565. </doc-anchor-target>
  2566. <div id="py_random_random-code-1" class="codeblock-wrapper"><doc-codeblock>
  2567. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2568. PK_API py_f64 py_Random_random(py_Ref self);</code></pre>
  2569. </doc-codeblock></div>
  2570. <doc-anchor-target id="py_random_uniform">
  2571. <h3>
  2572. <doc-anchor-trigger class="header-anchor-trigger" to="#py_random_uniform">#</doc-anchor-trigger>
  2573. <span>py_Random_uniform</span>
  2574. </h3>
  2575. </doc-anchor-target>
  2576. <div id="py_random_uniform-code-1" class="codeblock-wrapper"><doc-codeblock>
  2577. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2578. PK_API py_f64 py_Random_uniform(py_Ref self, py_f64 a, py_f64 b);</code></pre>
  2579. </doc-codeblock></div>
  2580. <doc-anchor-target id="py_random_randint">
  2581. <h3>
  2582. <doc-anchor-trigger class="header-anchor-trigger" to="#py_random_randint">#</doc-anchor-trigger>
  2583. <span>py_Random_randint</span>
  2584. </h3>
  2585. </doc-anchor-target>
  2586. <div id="py_random_randint-code-1" class="codeblock-wrapper"><doc-codeblock>
  2587. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2588. PK_API py_i64 py_Random_randint(py_Ref self, py_i64 a, py_i64 b);</code></pre>
  2589. </doc-codeblock></div>
  2590. <doc-anchor-target id="py_newarray2d">
  2591. <h3>
  2592. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newarray2d">#</doc-anchor-trigger>
  2593. <span>py_newarray2d</span>
  2594. </h3>
  2595. </doc-anchor-target>
  2596. <div id="py_newarray2d-code-1" class="codeblock-wrapper"><doc-codeblock>
  2597. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2598. PK_API void py_newarray2d(py_OutRef out, int width, int height);</code></pre>
  2599. </doc-codeblock></div>
  2600. <doc-anchor-target id="py_array2d_getwidth">
  2601. <h3>
  2602. <doc-anchor-trigger class="header-anchor-trigger" to="#py_array2d_getwidth">#</doc-anchor-trigger>
  2603. <span>py_array2d_getwidth</span>
  2604. </h3>
  2605. </doc-anchor-target>
  2606. <div id="py_array2d_getwidth-code-1" class="codeblock-wrapper"><doc-codeblock>
  2607. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2608. PK_API int py_array2d_getwidth(py_Ref self);</code></pre>
  2609. </doc-codeblock></div>
  2610. <doc-anchor-target id="py_array2d_getheight">
  2611. <h3>
  2612. <doc-anchor-trigger class="header-anchor-trigger" to="#py_array2d_getheight">#</doc-anchor-trigger>
  2613. <span>py_array2d_getheight</span>
  2614. </h3>
  2615. </doc-anchor-target>
  2616. <div id="py_array2d_getheight-code-1" class="codeblock-wrapper"><doc-codeblock>
  2617. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2618. PK_API int py_array2d_getheight(py_Ref self);</code></pre>
  2619. </doc-codeblock></div>
  2620. <doc-anchor-target id="py_array2d_getitem">
  2621. <h3>
  2622. <doc-anchor-trigger class="header-anchor-trigger" to="#py_array2d_getitem">#</doc-anchor-trigger>
  2623. <span>py_array2d_getitem</span>
  2624. </h3>
  2625. </doc-anchor-target>
  2626. <div id="py_array2d_getitem-code-1" class="codeblock-wrapper"><doc-codeblock>
  2627. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2628. PK_API py_ObjectRef py_array2d_getitem(py_Ref self, int x, int y);</code></pre>
  2629. </doc-codeblock></div>
  2630. <doc-anchor-target id="py_array2d_setitem">
  2631. <h3>
  2632. <doc-anchor-trigger class="header-anchor-trigger" to="#py_array2d_setitem">#</doc-anchor-trigger>
  2633. <span>py_array2d_setitem</span>
  2634. </h3>
  2635. </doc-anchor-target>
  2636. <div id="py_array2d_setitem-code-1" class="codeblock-wrapper"><doc-codeblock>
  2637. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2638. PK_API void py_array2d_setitem(py_Ref self, int x, int y, py_Ref val);</code></pre>
  2639. </doc-codeblock></div>
  2640. <doc-anchor-target id="py_newvec2">
  2641. <h3>
  2642. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newvec2">#</doc-anchor-trigger>
  2643. <span>py_newvec2</span>
  2644. </h3>
  2645. </doc-anchor-target>
  2646. <div id="py_newvec2-code-1" class="codeblock-wrapper"><doc-codeblock>
  2647. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2648. PK_API void py_newvec2(py_OutRef out, c11_vec2);</code></pre>
  2649. </doc-codeblock></div>
  2650. <doc-anchor-target id="py_newvec3">
  2651. <h3>
  2652. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newvec3">#</doc-anchor-trigger>
  2653. <span>py_newvec3</span>
  2654. </h3>
  2655. </doc-anchor-target>
  2656. <div id="py_newvec3-code-1" class="codeblock-wrapper"><doc-codeblock>
  2657. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2658. PK_API void py_newvec3(py_OutRef out, c11_vec3);</code></pre>
  2659. </doc-codeblock></div>
  2660. <doc-anchor-target id="py_newvec2i">
  2661. <h3>
  2662. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newvec2i">#</doc-anchor-trigger>
  2663. <span>py_newvec2i</span>
  2664. </h3>
  2665. </doc-anchor-target>
  2666. <div id="py_newvec2i-code-1" class="codeblock-wrapper"><doc-codeblock>
  2667. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2668. PK_API void py_newvec2i(py_OutRef out, c11_vec2i);</code></pre>
  2669. </doc-codeblock></div>
  2670. <doc-anchor-target id="py_newvec3i">
  2671. <h3>
  2672. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newvec3i">#</doc-anchor-trigger>
  2673. <span>py_newvec3i</span>
  2674. </h3>
  2675. </doc-anchor-target>
  2676. <div id="py_newvec3i-code-1" class="codeblock-wrapper"><doc-codeblock>
  2677. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2678. PK_API void py_newvec3i(py_OutRef out, c11_vec3i);</code></pre>
  2679. </doc-codeblock></div>
  2680. <doc-anchor-target id="py_newvec4i">
  2681. <h3>
  2682. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newvec4i">#</doc-anchor-trigger>
  2683. <span>py_newvec4i</span>
  2684. </h3>
  2685. </doc-anchor-target>
  2686. <div id="py_newvec4i-code-1" class="codeblock-wrapper"><doc-codeblock>
  2687. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2688. PK_API void py_newvec4i(py_OutRef out, c11_vec4i);</code></pre>
  2689. </doc-codeblock></div>
  2690. <doc-anchor-target id="py_newcolor32">
  2691. <h3>
  2692. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newcolor32">#</doc-anchor-trigger>
  2693. <span>py_newcolor32</span>
  2694. </h3>
  2695. </doc-anchor-target>
  2696. <div id="py_newcolor32-code-1" class="codeblock-wrapper"><doc-codeblock>
  2697. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2698. PK_API void py_newcolor32(py_OutRef out, c11_color32);</code></pre>
  2699. </doc-codeblock></div>
  2700. <doc-anchor-target id="py_newmat3x3">
  2701. <h3>
  2702. <doc-anchor-trigger class="header-anchor-trigger" to="#py_newmat3x3">#</doc-anchor-trigger>
  2703. <span>py_newmat3x3</span>
  2704. </h3>
  2705. </doc-anchor-target>
  2706. <div id="py_newmat3x3-code-1" class="codeblock-wrapper"><doc-codeblock>
  2707. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2708. PK_API c11_mat3x3* py_newmat3x3(py_OutRef out);</code></pre>
  2709. </doc-codeblock></div>
  2710. <doc-anchor-target id="py_tovec2">
  2711. <h3>
  2712. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tovec2">#</doc-anchor-trigger>
  2713. <span>py_tovec2</span>
  2714. </h3>
  2715. </doc-anchor-target>
  2716. <div id="py_tovec2-code-1" class="codeblock-wrapper"><doc-codeblock>
  2717. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2718. PK_API c11_vec2 py_tovec2(py_Ref self);</code></pre>
  2719. </doc-codeblock></div>
  2720. <doc-anchor-target id="py_tovec3">
  2721. <h3>
  2722. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tovec3">#</doc-anchor-trigger>
  2723. <span>py_tovec3</span>
  2724. </h3>
  2725. </doc-anchor-target>
  2726. <div id="py_tovec3-code-1" class="codeblock-wrapper"><doc-codeblock>
  2727. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2728. PK_API c11_vec3 py_tovec3(py_Ref self);</code></pre>
  2729. </doc-codeblock></div>
  2730. <doc-anchor-target id="py_tovec2i">
  2731. <h3>
  2732. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tovec2i">#</doc-anchor-trigger>
  2733. <span>py_tovec2i</span>
  2734. </h3>
  2735. </doc-anchor-target>
  2736. <div id="py_tovec2i-code-1" class="codeblock-wrapper"><doc-codeblock>
  2737. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2738. PK_API c11_vec2i py_tovec2i(py_Ref self);</code></pre>
  2739. </doc-codeblock></div>
  2740. <doc-anchor-target id="py_tovec3i">
  2741. <h3>
  2742. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tovec3i">#</doc-anchor-trigger>
  2743. <span>py_tovec3i</span>
  2744. </h3>
  2745. </doc-anchor-target>
  2746. <div id="py_tovec3i-code-1" class="codeblock-wrapper"><doc-codeblock>
  2747. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2748. PK_API c11_vec3i py_tovec3i(py_Ref self);</code></pre>
  2749. </doc-codeblock></div>
  2750. <doc-anchor-target id="py_tovec4i">
  2751. <h3>
  2752. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tovec4i">#</doc-anchor-trigger>
  2753. <span>py_tovec4i</span>
  2754. </h3>
  2755. </doc-anchor-target>
  2756. <div id="py_tovec4i-code-1" class="codeblock-wrapper"><doc-codeblock>
  2757. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2758. PK_API c11_vec4i py_tovec4i(py_Ref self);</code></pre>
  2759. </doc-codeblock></div>
  2760. <doc-anchor-target id="py_tomat3x3">
  2761. <h3>
  2762. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tomat3x3">#</doc-anchor-trigger>
  2763. <span>py_tomat3x3</span>
  2764. </h3>
  2765. </doc-anchor-target>
  2766. <div id="py_tomat3x3-code-1" class="codeblock-wrapper"><doc-codeblock>
  2767. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2768. PK_API c11_mat3x3* py_tomat3x3(py_Ref self);</code></pre>
  2769. </doc-codeblock></div>
  2770. <doc-anchor-target id="py_tocolor32">
  2771. <h3>
  2772. <doc-anchor-trigger class="header-anchor-trigger" to="#py_tocolor32">#</doc-anchor-trigger>
  2773. <span>py_tocolor32</span>
  2774. </h3>
  2775. </doc-anchor-target>
  2776. <div id="py_tocolor32-code-1" class="codeblock-wrapper"><doc-codeblock>
  2777. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2778. PK_API c11_color32 py_tocolor32(py_Ref self);</code></pre>
  2779. </doc-codeblock></div>
  2780. <doc-anchor-target id="py_json_dumps">
  2781. <h3>
  2782. <doc-anchor-trigger class="header-anchor-trigger" to="#py_json_dumps">#</doc-anchor-trigger>
  2783. <span>py_json_dumps <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2784. <span>raise</span>
  2785. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2786. <span>return</span>
  2787. </a></span>
  2788. </h3>
  2789. </doc-anchor-target>
  2790. <div id="py_json_dumps-code-1" class="codeblock-wrapper"><doc-codeblock>
  2791. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `json.dumps(val)`.
  2792. PK_API bool py_json_dumps(py_Ref val, int indent);</code></pre>
  2793. </doc-codeblock></div>
  2794. <doc-anchor-target id="py_json_loads">
  2795. <h3>
  2796. <doc-anchor-trigger class="header-anchor-trigger" to="#py_json_loads">#</doc-anchor-trigger>
  2797. <span>py_json_loads <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2798. <span>raise</span>
  2799. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2800. <span>return</span>
  2801. </a></span>
  2802. </h3>
  2803. </doc-anchor-target>
  2804. <div id="py_json_loads-code-1" class="codeblock-wrapper"><doc-codeblock>
  2805. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `json.loads(val)`.
  2806. PK_API bool py_json_loads(const char* source);</code></pre>
  2807. </doc-codeblock></div>
  2808. <doc-anchor-target id="py_pickle_dumps">
  2809. <h3>
  2810. <doc-anchor-trigger class="header-anchor-trigger" to="#py_pickle_dumps">#</doc-anchor-trigger>
  2811. <span>py_pickle_dumps <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2812. <span>raise</span>
  2813. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2814. <span>return</span>
  2815. </a></span>
  2816. </h3>
  2817. </doc-anchor-target>
  2818. <div id="py_pickle_dumps-code-1" class="codeblock-wrapper"><doc-codeblock>
  2819. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `pickle.dumps(val)`.
  2820. PK_API bool py_pickle_dumps(py_Ref val);</code></pre>
  2821. </doc-codeblock></div>
  2822. <doc-anchor-target id="py_pickle_loads">
  2823. <h3>
  2824. <doc-anchor-trigger class="header-anchor-trigger" to="#py_pickle_loads">#</doc-anchor-trigger>
  2825. <span>py_pickle_loads <a href="../introduction/#py_raise-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-danger-text bg-badge-danger border border-badge-danger-border hover:text-badge-danger-text-hover hover:bg-badge-danger-hover hover:border-badge-danger-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2826. <span>raise</span>
  2827. </a> <a href="../introduction/#py_return-macro" class="no-link inline-flex align-middle items-center justify-center font-medium leading-none whitespace-nowrap text-badge-primary-text bg-badge-primary border border-badge-primary-border hover:text-badge-primary-text-hover hover:bg-badge-primary-hover hover:border-badge-primary-border-hover transition-colors duration-200 ease-out h-6 px-2 text-xs rounded-md">
  2828. <span>return</span>
  2829. </a></span>
  2830. </h3>
  2831. </doc-anchor-target>
  2832. <div id="py_pickle_loads-code-1" class="codeblock-wrapper"><doc-codeblock>
  2833. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `pickle.loads(val)`.
  2834. PK_API bool py_pickle_loads(const unsigned char* data, int size);</code></pre>
  2835. </doc-codeblock></div>
  2836. <doc-anchor-target id="py_watchdog_begin">
  2837. <h3>
  2838. <doc-anchor-trigger class="header-anchor-trigger" to="#py_watchdog_begin">#</doc-anchor-trigger>
  2839. <span>py_watchdog_begin</span>
  2840. </h3>
  2841. </doc-anchor-target>
  2842. <div id="py_watchdog_begin-code-1" class="codeblock-wrapper"><doc-codeblock>
  2843. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Begin the watchdog with `timeout` in milliseconds.
  2844. /// `PK_ENABLE_WATCHDOG` must be defined to `1` to use this feature.
  2845. /// You need to call `py_watchdog_end()` later.
  2846. /// If `timeout` is reached, `TimeoutError` will be raised.
  2847. PK_API void py_watchdog_begin(py_i64 timeout);</code></pre>
  2848. </doc-codeblock></div>
  2849. <doc-anchor-target id="py_watchdog_end">
  2850. <h3>
  2851. <doc-anchor-trigger class="header-anchor-trigger" to="#py_watchdog_end">#</doc-anchor-trigger>
  2852. <span>py_watchdog_end</span>
  2853. </h3>
  2854. </doc-anchor-target>
  2855. <div id="py_watchdog_end-code-1" class="codeblock-wrapper"><doc-codeblock>
  2856. <pre translate="no" class="language-c"><code v-pre class="language-c">/// Reset the watchdog.
  2857. PK_API void py_watchdog_end();</code></pre>
  2858. </doc-codeblock></div>
  2859. <doc-anchor-target id="py_profiler_begin">
  2860. <h3>
  2861. <doc-anchor-trigger class="header-anchor-trigger" to="#py_profiler_begin">#</doc-anchor-trigger>
  2862. <span>py_profiler_begin</span>
  2863. </h3>
  2864. </doc-anchor-target>
  2865. <div id="py_profiler_begin-code-1" class="codeblock-wrapper"><doc-codeblock>
  2866. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2867. PK_API void py_profiler_begin();</code></pre>
  2868. </doc-codeblock></div>
  2869. <doc-anchor-target id="py_profiler_end">
  2870. <h3>
  2871. <doc-anchor-trigger class="header-anchor-trigger" to="#py_profiler_end">#</doc-anchor-trigger>
  2872. <span>py_profiler_end</span>
  2873. </h3>
  2874. </doc-anchor-target>
  2875. <div id="py_profiler_end-code-1" class="codeblock-wrapper"><doc-codeblock>
  2876. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2877. PK_API void py_profiler_end();</code></pre>
  2878. </doc-codeblock></div>
  2879. <doc-anchor-target id="py_profiler_reset">
  2880. <h3>
  2881. <doc-anchor-trigger class="header-anchor-trigger" to="#py_profiler_reset">#</doc-anchor-trigger>
  2882. <span>py_profiler_reset</span>
  2883. </h3>
  2884. </doc-anchor-target>
  2885. <div id="py_profiler_reset-code-1" class="codeblock-wrapper"><doc-codeblock>
  2886. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2887. PK_API void py_profiler_reset();</code></pre>
  2888. </doc-codeblock></div>
  2889. <doc-anchor-target id="py_profiler_report">
  2890. <h3>
  2891. <doc-anchor-trigger class="header-anchor-trigger" to="#py_profiler_report">#</doc-anchor-trigger>
  2892. <span>py_profiler_report</span>
  2893. </h3>
  2894. </doc-anchor-target>
  2895. <div id="py_profiler_report-code-1" class="codeblock-wrapper"><doc-codeblock>
  2896. <pre translate="no" class="language-c"><code v-pre class="language-c">
  2897. PK_API char* py_profiler_report();</code></pre>
  2898. </doc-codeblock></div>
  2899. <doc-anchor-target id="py_replinput">
  2900. <h3>
  2901. <doc-anchor-trigger class="header-anchor-trigger" to="#py_replinput">#</doc-anchor-trigger>
  2902. <span>py_replinput</span>
  2903. </h3>
  2904. </doc-anchor-target>
  2905. <div id="py_replinput-code-1" class="codeblock-wrapper"><doc-codeblock>
  2906. <pre translate="no" class="language-c"><code v-pre class="language-c">/// An utility function to read a line from stdin for REPL.
  2907. PK_API int py_replinput(char* buf, int max_size);</code></pre>
  2908. </doc-codeblock></div>
  2909. <!-- Required only on API pages -->
  2910. <doc-toolbar-member-filter-no-results></doc-toolbar-member-filter-no-results>
  2911. </div>
  2912. <footer id="retype-content-footer" class="clear-both">
  2913. <nav id="retype-nextprev" class="print:hidden flex mt-14">
  2914. <div class="w-1/2">
  2915. <a class="px-5 py-4 h-full flex items-center break-normal font-medium text-body-link border border-base-border hover:border-base-border-hover rounded-l-lg transition-colors duration-150 relative hover:z-5" href="../../c-api/introduction/">
  2916. <svg xmlns="http://www.w3.org/2000/svg" class="mr-3" width="24" height="24" viewBox="0 0 24 24" fill="currentColor" overflow="visible"><path d="M19 11H7.41l5.29-5.29a.996.996 0 10-1.41-1.41l-7 7a1 1 0 000 1.42l7 7a1.024 1.024 0 001.42-.01.996.996 0 000-1.41L7.41 13H19c.55 0 1-.45 1-1s-.45-1-1-1z" /><path fill="none" d="M0 0h24v24H0z" /></svg>
  2917. <span>
  2918. <span class="block text-xs font-normal text-base-text-muted">Previous</span>
  2919. <span class="block mt-1">Introduction</span>
  2920. </span>
  2921. </a>
  2922. </div>
  2923. <div class="w-1/2">
  2924. <a class="px-5 py-4 -mx-px h-full flex items-center justify-end break-normal font-medium text-body-link border border-base-border hover:border-base-border-hover rounded-r-lg transition-colors duration-150 relative hover:z-5" href="../../modules/array2d/">
  2925. <span>
  2926. <span class="block text-xs font-normal text-right text-base-text-muted">Next</span>
  2927. <span class="block mt-1">array​2​d</span>
  2928. </span>
  2929. <svg xmlns="http://www.w3.org/2000/svg" class="ml-3" width="24" height="24" viewBox="0 0 24 24" fill="currentColor" overflow="visible"><path d="M19.92 12.38a1 1 0 00-.22-1.09l-7-7a.996.996 0 10-1.41 1.41l5.3 5.3H5c-.55 0-1 .45-1 1s.45 1 1 1h11.59l-5.29 5.29a.996.996 0 000 1.41c.19.2.44.3.7.3s.51-.1.71-.29l7-7c.09-.09.16-.21.21-.33z" /><path fill="none" d="M0 0h24v24H0z" /></svg>
  2930. </a>
  2931. </div>
  2932. </nav>
  2933. </footer>
  2934. </main>
  2935. <div id="retype-page-footer" class="print:border-none border-t border-base-border pt-6 mb-8">
  2936. <footer class="flex flex-wrap items-center justify-between print:justify-center">
  2937. <div id="retype-footer-links" class="print:hidden">
  2938. <ul class="flex flex-wrap items-center text-sm">
  2939. </ul>
  2940. </div>
  2941. <div id="retype-copyright" class="print:justify-center py-2 text-footer-text font-footer-link text-sm leading-relaxed"><p>© Copyright 2026 - <a href="https://github.com/blueloveTH">blueloveTH</a> - All rights reserved.</p></div>
  2942. </footer>
  2943. </div>
  2944. </div>
  2945. <!-- Rendered if sidebar right is enabled -->
  2946. <!-- Sidebar right skeleton-->
  2947. <div v-cloak class="fixed top-0 bottom-0 right-0 translate-x-full bg-sidebar-right-bg border-sidebar-right-border lg:sticky lg:border-l lg:shrink-0 lg:pt-6 lg:translate-x-0 sm:w-1/2 lg:w-64 lg:z-0 md:w-104 sidebar-right skeleton">
  2948. <div class="pl-5">
  2949. <div class="w-32 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
  2950. <div class="w-48 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
  2951. <div class="w-40 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
  2952. </div>
  2953. </div>
  2954. <!-- User should be able to hide sidebar right -->
  2955. <doc-sidebar-right v-cloak></doc-sidebar-right>
  2956. </div>
  2957. </div>
  2958. </div>
  2959. <doc-search-mobile></doc-search-mobile>
  2960. <doc-back-to-top></doc-back-to-top>
  2961. </div>
  2962. <div id="retype-overlay-target"></div>
  2963. <script data-cfasync="false">window.__DOCS__ = { "title": "Functions", level: 2, icon: "file", hasPrism: true, hasMermaid: false, hasMath: false, tocDepth: 23 }</script>
  2964. </body>
  2965. </html>