|
|
@@ -0,0 +1,1811 @@
|
|
|
+<!DOCTYPE html>
|
|
|
+<html lang="en" class="h-full">
|
|
|
+<head>
|
|
|
+ <meta charset="UTF-8">
|
|
|
+ <meta name="viewport" content="width=device-width,initial-scale=1">
|
|
|
+ <meta name="color-scheme" content="light dark">
|
|
|
+ <meta name="turbo-cache-control" content="no-cache" data-turbo-track="reload" data-track-token="4.3.0.827133044009">
|
|
|
+
|
|
|
+ <!-- See retype.com -->
|
|
|
+ <meta name="generator" content="Retype 4.3.0">
|
|
|
+
|
|
|
+ <!-- Primary Meta Tags -->
|
|
|
+ <title>Functions | Portable Python 3.x Interpreter in Modern C</title>
|
|
|
+ <meta name="title" content="Functions | Portable Python 3.x Interpreter in Modern C">
|
|
|
+
|
|
|
+ <!-- Canonical -->
|
|
|
+ <link rel="canonical" href="https://pocketpy.dev/c-api/functions/">
|
|
|
+
|
|
|
+ <!-- Open Graph -->
|
|
|
+ <meta property="og:type" content="website">
|
|
|
+ <meta property="og:url" content="https://pocketpy.dev/c-api/functions/">
|
|
|
+ <meta property="og:title" content="Functions | Portable Python 3.x Interpreter in Modern C">
|
|
|
+ <meta property="og:site_name" content="pocketpy">
|
|
|
+ <meta property="og:locale" content="en_US">
|
|
|
+
|
|
|
+ <!-- Twitter -->
|
|
|
+ <meta name="twitter:card" content="summary_large_image">
|
|
|
+ <meta name="twitter:url" content="https://pocketpy.dev/c-api/functions/">
|
|
|
+ <meta name="twitter:title" content="Functions | Portable Python 3.x Interpreter in Modern C">
|
|
|
+
|
|
|
+ <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>
|
|
|
+
|
|
|
+ <link id="retype-favicon" rel="icon" href="../../static/logo.png" />
|
|
|
+ <link href="../../resources/css/retype.css?v=4.3.0.827133044009" rel="stylesheet">
|
|
|
+
|
|
|
+ <script data-cfasync="false" src="../../resources/js/config.js?v=4.3.0.827133044009" data-turbo-eval="false" defer></script>
|
|
|
+ <script data-cfasync="false" src="../../resources/js/retype.js?v=4.3.0" data-turbo-eval="false" defer></script>
|
|
|
+ <script id="lunr-js" data-cfasync="false" src="../../resources/js/lunr.js?v=4.3.0.827133044009" data-turbo-eval="false" defer></script>
|
|
|
+ <script id="prism-js" data-cfasync="false" src="../../resources/js/prism.js?v=4.3.0.827133044009" defer></script>
|
|
|
+</head>
|
|
|
+<body>
|
|
|
+ <div id="retype-app" class="relative text-base antialiased text-base-text bg-base-bg font-body">
|
|
|
+ <div class="absolute bottom-0 left-0" style="top: 5rem; right: 50%"></div>
|
|
|
+
|
|
|
+ <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">
|
|
|
+ <div class="container relative flex items-center justify-between pr-6 grow md:justify-start">
|
|
|
+ <!-- Mobile menu button skeleton -->
|
|
|
+ <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>
|
|
|
+ <div v-cloak id="retype-sidebar-left-toggle-button"></div>
|
|
|
+
|
|
|
+ <!-- Logo -->
|
|
|
+ <div class="flex items-center justify-between h-full py-2 md:w-75">
|
|
|
+ <div class="flex items-center px-2 md:px-6">
|
|
|
+ <a id="retype-branding-logo" href="https://pocketpy.dev/" class="flex items-center leading-snug text-2xl">
|
|
|
+ <span class="w-10 mr-2 grow-0 shrink-0 overflow-hidden">
|
|
|
+ <img class="max-h-10 dark:hidden md:inline-block" src="../../static/logo.png" alt="" width="512" height="512">
|
|
|
+ <img class="max-h-10 hidden dark:inline-block" src="../../static/logo.png" alt="" width="512" height="512">
|
|
|
+ </span>
|
|
|
+ <span class="dark:text-white font-bold line-clamp-1 md:line-clamp-2">pocketpy</span>
|
|
|
+ </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>
|
|
|
+ </div>
|
|
|
+
|
|
|
+ <span class="hidden h-8 border-r md:inline-block border-base-border"></span>
|
|
|
+ </div>
|
|
|
+
|
|
|
+ <div class="flex justify-between md:grow">
|
|
|
+ <!-- Top Nav -->
|
|
|
+ <nav id="retype-header-nav" class="hidden md:flex">
|
|
|
+ <ul class="flex flex-col mb-4 md:pl-16 md:mb-0 md:flex-row md:items-center">
|
|
|
+ <li class="mr-6">
|
|
|
+ <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="">
|
|
|
+ <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1.5" width="18" height="18" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true" focusable="false">
|
|
|
+ <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"/>
|
|
|
+ </svg>
|
|
|
+ <span>Home</span>
|
|
|
+ </a>
|
|
|
+ </li>
|
|
|
+ <li class="mr-6">
|
|
|
+ <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">
|
|
|
+ <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1.5" width="18" height="18" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true" focusable="false">
|
|
|
+ <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"/>
|
|
|
+ </svg>
|
|
|
+ <span>Live Demo</span>
|
|
|
+ </a>
|
|
|
+ </li>
|
|
|
+ <li class="mr-6">
|
|
|
+ <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">
|
|
|
+ <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1.5" width="18" height="18" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true" focusable="false">
|
|
|
+ <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"/>
|
|
|
+ </svg>
|
|
|
+ <span>Live Examples</span>
|
|
|
+ </a>
|
|
|
+ </li>
|
|
|
+ <li class="mr-6">
|
|
|
+ <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">
|
|
|
+ <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1.5" width="18" height="18" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true" focusable="false">
|
|
|
+ <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"/>
|
|
|
+ </svg>
|
|
|
+ <span>Github</span>
|
|
|
+ </a>
|
|
|
+ </li>
|
|
|
+ <li class="mr-6">
|
|
|
+ <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">
|
|
|
+ <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1.5" width="18" height="18" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true" focusable="false">
|
|
|
+ <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"/>
|
|
|
+ </svg>
|
|
|
+ <span>Discord</span>
|
|
|
+ </a>
|
|
|
+ </li>
|
|
|
+
|
|
|
+ </ul>
|
|
|
+ </nav>
|
|
|
+
|
|
|
+ <div v-cloak class="flex justify-end grow">
|
|
|
+ <div id="retype-mobile-search-button"></div>
|
|
|
+ <doc-search-desktop></doc-search-desktop>
|
|
|
+
|
|
|
+ <doc-theme-switch class="lg:ml-2"></doc-theme-switch>
|
|
|
+ <doc-history></doc-history>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </header>
|
|
|
+
|
|
|
+
|
|
|
+ <div id="retype-container" class="container relative flex bg-white">
|
|
|
+ <!-- Sidebar Skeleton -->
|
|
|
+ <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">
|
|
|
+
|
|
|
+ <div class="flex items-center h-16 px-6">
|
|
|
+ <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">
|
|
|
+ </div>
|
|
|
+
|
|
|
+ <div class="pl-6 mt-1 mb-4">
|
|
|
+ <div class="w-32 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
|
|
|
+ <div class="w-48 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
|
|
|
+ <div class="w-40 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
|
|
|
+ <div class="w-32 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
|
|
|
+ <div class="w-48 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
|
|
|
+ <div class="w-40 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
|
|
|
+ </div>
|
|
|
+
|
|
|
+ <div class="shrink-0 mt-auto bg-transparent dark:border-base-border">
|
|
|
+ <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">
|
|
|
+ <span class="text-xs whitespace-nowrap">Powered by</span>
|
|
|
+ <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>
|
|
|
+ </a>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+
|
|
|
+ <!-- Sidebar component -->
|
|
|
+ <doc-sidebar v-cloak>
|
|
|
+ <template #sidebar-footer>
|
|
|
+ <div class="shrink-0 mt-auto border-t md:bg-transparent md:border-none dark:border-base-border">
|
|
|
+
|
|
|
+ <div class="py-3 px-6 md:hidden border-b dark:border-base-border">
|
|
|
+ <nav>
|
|
|
+ <ul class="flex flex-wrap justify-center items-center">
|
|
|
+ <li class="mr-6">
|
|
|
+ <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="">
|
|
|
+ <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1.5" width="18" height="18" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true" focusable="false">
|
|
|
+ <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"/>
|
|
|
+ </svg>
|
|
|
+ <span>Home</span>
|
|
|
+ </a>
|
|
|
+ </li>
|
|
|
+ <li class="mr-6">
|
|
|
+ <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">
|
|
|
+ <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1.5" width="18" height="18" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true" focusable="false">
|
|
|
+ <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"/>
|
|
|
+ </svg>
|
|
|
+ <span>Live Demo</span>
|
|
|
+ </a>
|
|
|
+ </li>
|
|
|
+ <li class="mr-6">
|
|
|
+ <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">
|
|
|
+ <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1.5" width="18" height="18" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true" focusable="false">
|
|
|
+ <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"/>
|
|
|
+ </svg>
|
|
|
+ <span>Live Examples</span>
|
|
|
+ </a>
|
|
|
+ </li>
|
|
|
+ <li class="mr-6">
|
|
|
+ <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">
|
|
|
+ <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1.5" width="18" height="18" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true" focusable="false">
|
|
|
+ <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"/>
|
|
|
+ </svg>
|
|
|
+ <span>Github</span>
|
|
|
+ </a>
|
|
|
+ </li>
|
|
|
+ <li class="mr-6">
|
|
|
+ <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">
|
|
|
+ <svg xmlns="http://www.w3.org/2000/svg" class="mb-px mr-1.5" width="18" height="18" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true" focusable="false">
|
|
|
+ <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"/>
|
|
|
+ </svg>
|
|
|
+ <span>Discord</span>
|
|
|
+ </a>
|
|
|
+ </li>
|
|
|
+
|
|
|
+ </ul>
|
|
|
+ </nav>
|
|
|
+ </div>
|
|
|
+
|
|
|
+ <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">
|
|
|
+ <span class="text-xs whitespace-nowrap">Powered by</span>
|
|
|
+ <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>
|
|
|
+ </a>
|
|
|
+ </div>
|
|
|
+ </template>
|
|
|
+ </doc-sidebar>
|
|
|
+
|
|
|
+ <div class="grow min-w-0 bg-body-bg">
|
|
|
+ <!-- Render "toolbar" template here on api pages --><!-- Render page content -->
|
|
|
+<div class="flex">
|
|
|
+ <div id="retype-main" class="min-w-0 p-4 grow md:px-16">
|
|
|
+ <main class="relative pb-12 lg:pt-2">
|
|
|
+ <div class="retype-markdown" id="retype-content">
|
|
|
+ <!-- Rendered if sidebar right is enabled -->
|
|
|
+ <div id="retype-sidebar-right-toggle"></div>
|
|
|
+ <!-- Page content -->
|
|
|
+<h1 id="functions">Functions</h1>
|
|
|
+<h3 id="py_initialize">py_initialize</h3>
|
|
|
+<div id="py_initialize-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Initialize pocketpy and the default VM.
|
|
|
+PK_API void py_initialize();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_finalize">py_finalize</h3>
|
|
|
+<div id="py_finalize-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Finalize pocketpy and free all VMs. This opearation is irreversible.
|
|
|
+/// After this call, you cannot use any function from this header anymore.
|
|
|
+PK_API void py_finalize();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_currentvm">py_currentvm</h3>
|
|
|
+<div id="py_currentvm-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the current VM index.
|
|
|
+PK_API int py_currentvm();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_switchvm">py_switchvm</h3>
|
|
|
+<div id="py_switchvm-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Switch to a VM.
|
|
|
+/// @param index index of the VM ranging from 0 to 16 (exclusive). `0` is the default VM.
|
|
|
+PK_API void py_switchvm(int index);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_resetvm">py_resetvm</h3>
|
|
|
+<div id="py_resetvm-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Reset the current VM.
|
|
|
+PK_API void py_resetvm();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_resetallvm">py_resetallvm</h3>
|
|
|
+<div id="py_resetallvm-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Reset All VMs.
|
|
|
+PK_API void py_resetallvm();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_getvmctx">py_getvmctx</h3>
|
|
|
+<div id="py_getvmctx-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the current VM context. This is used for user-defined data.
|
|
|
+PK_API void* py_getvmctx();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_setvmctx">py_setvmctx</h3>
|
|
|
+<div id="py_setvmctx-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Set the current VM context. This is used for user-defined data.
|
|
|
+PK_API void py_setvmctx(void* ctx);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_callbacks">py_callbacks</h3>
|
|
|
+<div id="py_callbacks-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Setup the callbacks for the current VM.
|
|
|
+PK_API py_Callbacks* py_callbacks();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_appcallbacks">py_appcallbacks</h3>
|
|
|
+<div id="py_appcallbacks-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Setup the application callbacks
|
|
|
+PK_API py_AppCallbacks* py_appcallbacks();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_sys_setargv">py_sys_setargv</h3>
|
|
|
+<div id="py_sys_setargv-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Set `sys.argv`. Used for storing command-line arguments.
|
|
|
+PK_API void py_sys_setargv(int argc, char** argv);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_sys_settrace">py_sys_settrace</h3>
|
|
|
+<div id="py_sys_settrace-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Set the trace function for the current VM.
|
|
|
+PK_API void py_sys_settrace(py_TraceFunc func, bool reset);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_gc_collect">py_gc_collect</h3>
|
|
|
+<div id="py_gc_collect-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Invoke the garbage collector.
|
|
|
+PK_API int py_gc_collect();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_malloc">py_malloc</h3>
|
|
|
+<div id="py_malloc-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Wrapper for `PK_MALLOC(size)`.
|
|
|
+PK_API void* py_malloc(size_t size);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_realloc">py_realloc</h3>
|
|
|
+<div id="py_realloc-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Wrapper for `PK_REALLOC(ptr, size)`.
|
|
|
+PK_API void* py_realloc(void* ptr, size_t size);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_free">py_free</h3>
|
|
|
+<div id="py_free-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Wrapper for `PK_FREE(ptr)`.
|
|
|
+PK_API void py_free(void* ptr);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_true">py_True</h3>
|
|
|
+<div id="py_true-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// A shorthand for `True`.
|
|
|
+PK_API py_GlobalRef py_True();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_false">py_False</h3>
|
|
|
+<div id="py_false-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// A shorthand for `False`.
|
|
|
+PK_API py_GlobalRef py_False();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_none">py_None</h3>
|
|
|
+<div id="py_none-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// A shorthand for `None`.
|
|
|
+PK_API py_GlobalRef py_None();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_nil">py_NIL</h3>
|
|
|
+<div id="py_nil-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// A shorthand for `nil`. `nil` is not a valid python object.
|
|
|
+PK_API py_GlobalRef py_NIL();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_frame_newglobals">py_Frame_newglobals</h3>
|
|
|
+<div id="py_frame_newglobals-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `globals()` with respect to the given frame.
|
|
|
+PK_API void py_Frame_newglobals(py_Frame* frame, py_OutRef out);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_frame_newlocals">py_Frame_newlocals</h3>
|
|
|
+<div id="py_frame_newlocals-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `locals()` with respect to the given frame.
|
|
|
+PK_API void py_Frame_newlocals(py_Frame* frame, py_OutRef out);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_frame_function">py_Frame_function</h3>
|
|
|
+<div id="py_frame_function-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the function object of the frame.
|
|
|
+/// Returns `NULL` if not available.
|
|
|
+PK_API py_StackRef py_Frame_function(py_Frame* frame);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_compile">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_compile-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Compile a source string into a code object.
|
|
|
+/// Use python's `exec()` or `eval()` to execute it.
|
|
|
+PK_API bool py_compile(const char* source,
|
|
|
+ const char* filename,
|
|
|
+ enum py_CompileMode mode,
|
|
|
+ bool is_dynamic);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_compilefile">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_compilefile-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Compile a `.py` file into a `.pyc` file.
|
|
|
+PK_API bool py_compilefile(const char* src_path,
|
|
|
+ const char* dst_path);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_execo">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_execo-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Run a compiled code object.
|
|
|
+PK_API bool py_execo(const void* data, int size, const char* filename, py_Ref module);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_exec">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_exec-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Run a source string.
|
|
|
+/// @param source source string.
|
|
|
+/// @param filename filename (for error messages).
|
|
|
+/// @param mode compile mode. Use `EXEC_MODE` for statements `EVAL_MODE` for expressions.
|
|
|
+/// @param module target module. Use NULL for the main module.
|
|
|
+/// @return `true` if the execution is successful or `false` if an exception is raised.
|
|
|
+PK_API bool py_exec(const char* source,
|
|
|
+ const char* filename,
|
|
|
+ enum py_CompileMode mode,
|
|
|
+ py_Ref module);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_eval">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_eval-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Evaluate a source string. Equivalent to `py_exec(source, "<string>", EVAL_MODE, module)`.
|
|
|
+PK_API bool py_eval(const char* source, py_Ref module);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_smartexec">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_smartexec-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Run a source string with smart interpretation.
|
|
|
+/// Example:
|
|
|
+/// `py_newstr(py_r0(), "abc");`
|
|
|
+/// `py_newint(py_r1(), 123);`
|
|
|
+/// `py_smartexec("print(_0, _1)", NULL, py_r0(), py_r1());`
|
|
|
+/// `// "abc 123" will be printed`.
|
|
|
+PK_API bool py_smartexec(const char* source, py_Ref module, ...);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_smarteval">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_smarteval-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Evaluate a source string with smart interpretation.
|
|
|
+/// Example:
|
|
|
+/// `py_newstr(py_r0(), "abc");`
|
|
|
+/// `py_smarteval("len(_)", NULL, py_r0());`
|
|
|
+/// `int res = py_toint(py_retval());`
|
|
|
+/// `// res will be 3`.
|
|
|
+PK_API bool py_smarteval(const char* source, py_Ref module, ...);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newint">py_newint</h3>
|
|
|
+<div id="py_newint-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create an `int` object.
|
|
|
+PK_API void py_newint(py_OutRef, py_i64);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newtrivial">py_newtrivial</h3>
|
|
|
+<div id="py_newtrivial-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a trivial value object.
|
|
|
+PK_API void py_newtrivial(py_OutRef out, py_Type type, void* data, int size);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newfloat">py_newfloat</h3>
|
|
|
+<div id="py_newfloat-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `float` object.
|
|
|
+PK_API void py_newfloat(py_OutRef, py_f64);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newbool">py_newbool</h3>
|
|
|
+<div id="py_newbool-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `bool` object.
|
|
|
+PK_API void py_newbool(py_OutRef, bool);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newstr">py_newstr</h3>
|
|
|
+<div id="py_newstr-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `str` object from a null-terminated string (utf-8).
|
|
|
+PK_API void py_newstr(py_OutRef, const char*);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newstrn">py_newstrn</h3>
|
|
|
+<div id="py_newstrn-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `str` object with `n` UNINITIALIZED bytes plus `'\0'`.
|
|
|
+PK_API char* py_newstrn(py_OutRef, int);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newstrv">py_newstrv</h3>
|
|
|
+<div id="py_newstrv-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `str` object from a `c11_sv`.
|
|
|
+PK_API void py_newstrv(py_OutRef, c11_sv);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newfstr">py_newfstr</h3>
|
|
|
+<div id="py_newfstr-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a formatted `str` object.
|
|
|
+PK_API void py_newfstr(py_OutRef, const char*, ...);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newnone">py_newnone</h3>
|
|
|
+<div id="py_newnone-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `None` object.
|
|
|
+PK_API void py_newnone(py_OutRef);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newnotimplemented">py_newnotimplemented</h3>
|
|
|
+<div id="py_newnotimplemented-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `NotImplemented` object.
|
|
|
+PK_API void py_newnotimplemented(py_OutRef);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newellipsis">py_newellipsis</h3>
|
|
|
+<div id="py_newellipsis-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `...` object.
|
|
|
+PK_API void py_newellipsis(py_OutRef);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newnil">py_newnil</h3>
|
|
|
+<div id="py_newnil-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `nil` object. `nil` is an invalid representation of an object.
|
|
|
+/// Don't use it unless you know what you are doing.
|
|
|
+PK_API void py_newnil(py_OutRef);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newnativefunc">py_newnativefunc</h3>
|
|
|
+<div id="py_newnativefunc-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `nativefunc` object.
|
|
|
+PK_API void py_newnativefunc(py_OutRef, py_CFunction);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newfunction">py_newfunction</h3>
|
|
|
+<div id="py_newfunction-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `function` object.
|
|
|
+PK_API py_Name py_newfunction(py_OutRef out,
|
|
|
+ const char* sig,
|
|
|
+ py_CFunction f,
|
|
|
+ const char* docstring,
|
|
|
+ int slots);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newboundmethod">py_newboundmethod</h3>
|
|
|
+<div id="py_newboundmethod-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `boundmethod` object.
|
|
|
+PK_API void py_newboundmethod(py_OutRef out, py_Ref self, py_Ref func);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newobject">py_newobject</h3>
|
|
|
+<div id="py_newobject-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a new object.
|
|
|
+/// @param out output reference.
|
|
|
+/// @param type type of the object.
|
|
|
+/// @param slots number of slots. Use `-1` to create a `__dict__`.
|
|
|
+/// @param udsize size of your userdata.
|
|
|
+/// @return pointer to the userdata.
|
|
|
+PK_API void* py_newobject(py_OutRef out, py_Type type, int slots, int udsize);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_name">py_name</h3>
|
|
|
+<div id="py_name-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a null-terminated string to a name.
|
|
|
+PK_API py_Name py_name(const char*);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_name2ref">py_name2ref</h3>
|
|
|
+<div id="py_name2ref-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a name to a python `str` object with cache.
|
|
|
+PK_API py_GlobalRef py_name2ref(py_Name);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_namev">py_namev</h3>
|
|
|
+<div id="py_namev-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a `c11_sv` to a name.
|
|
|
+PK_API py_Name py_namev(c11_sv);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_name2sv">py_name2sv</h3>
|
|
|
+<div id="py_name2sv-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a name to a `c11_sv`.
|
|
|
+PK_API c11_sv py_name2sv(py_Name);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_bind">py_bind</h3>
|
|
|
+<div id="py_bind-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Bind a function to the object via "decl-based" style.
|
|
|
+/// @param obj the target object.
|
|
|
+/// @param sig signature of the function. e.g. `add(x, y)`.
|
|
|
+/// @param f function to bind.
|
|
|
+PK_API void py_bind(py_Ref obj, const char* sig, py_CFunction f);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_bindmethod">py_bindmethod</h3>
|
|
|
+<div id="py_bindmethod-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Bind a method to type via "argc-based" style.
|
|
|
+/// @param type the target type.
|
|
|
+/// @param name name of the method.
|
|
|
+/// @param f function to bind.
|
|
|
+PK_API void py_bindmethod(py_Type type, const char* name, py_CFunction f);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_bindstaticmethod">py_bindstaticmethod</h3>
|
|
|
+<div id="py_bindstaticmethod-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Bind a static method to type via "argc-based" style.
|
|
|
+/// @param type the target type.
|
|
|
+/// @param name name of the method.
|
|
|
+/// @param f function to bind.
|
|
|
+PK_API void py_bindstaticmethod(py_Type type, const char* name, py_CFunction f);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_bindfunc">py_bindfunc</h3>
|
|
|
+<div id="py_bindfunc-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Bind a function to the object via "argc-based" style.
|
|
|
+/// @param obj the target object.
|
|
|
+/// @param name name of the function.
|
|
|
+/// @param f function to bind.
|
|
|
+PK_API void py_bindfunc(py_Ref obj, const char* name, py_CFunction f);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_bindproperty">py_bindproperty</h3>
|
|
|
+<div id="py_bindproperty-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Bind a property to type.
|
|
|
+/// @param type the target type.
|
|
|
+/// @param name name of the property.
|
|
|
+/// @param getter getter function.
|
|
|
+/// @param setter setter function. Use `NULL` if not needed.
|
|
|
+PK_API void py_bindproperty(py_Type type, const char* name, py_CFunction getter, py_CFunction setter);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_bindmagic">py_bindmagic</h3>
|
|
|
+<div id="py_bindmagic-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Bind a magic method to type.
|
|
|
+PK_API void py_bindmagic(py_Type type, py_Name name, py_CFunction f);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_toint">py_toint</h3>
|
|
|
+<div id="py_toint-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert an `int` object in python to `int64_t`.
|
|
|
+PK_API py_i64 py_toint(py_Ref);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_totrivial">py_totrivial</h3>
|
|
|
+<div id="py_totrivial-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the address of the trivial value object (16 bytes).
|
|
|
+PK_API void* py_totrivial(py_Ref);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tofloat">py_tofloat</h3>
|
|
|
+<div id="py_tofloat-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a `float` object in python to `double`.
|
|
|
+PK_API py_f64 py_tofloat(py_Ref);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_castfloat">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_castfloat-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Cast a `int` or `float` object in python to `double`.
|
|
|
+/// If successful, return true and set the value to `out`.
|
|
|
+/// Otherwise, return false and raise `TypeError`.
|
|
|
+PK_API bool py_castfloat(py_Ref, py_f64* out);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_castfloat32">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_castfloat32-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// 32-bit version of `py_castfloat`.
|
|
|
+PK_API bool py_castfloat32(py_Ref, float* out);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_castint">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_castint-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Cast a `int` object in python to `int64_t`.
|
|
|
+PK_API bool py_castint(py_Ref, py_i64* out);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tobool">py_tobool</h3>
|
|
|
+<div id="py_tobool-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a `bool` object in python to `bool`.
|
|
|
+PK_API bool py_tobool(py_Ref);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_totype">py_totype</h3>
|
|
|
+<div id="py_totype-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a `type` object in python to `py_Type`.
|
|
|
+PK_API py_Type py_totype(py_Ref);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_touserdata">py_touserdata</h3>
|
|
|
+<div id="py_touserdata-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a user-defined object to its userdata.
|
|
|
+PK_API void* py_touserdata(py_Ref);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tosv">py_tosv</h3>
|
|
|
+<div id="py_tosv-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Convert a `str` object in python to `c11_sv`.
|
|
|
+PK_API c11_sv py_tosv(py_Ref);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_bytes_resize">py_bytes_resize</h3>
|
|
|
+<div id="py_bytes_resize-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Resize a `bytes` object. It can only be resized down.
|
|
|
+PK_API void py_bytes_resize(py_Ref, int size);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newtype">py_newtype</h3>
|
|
|
+<div id="py_newtype-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a new type.
|
|
|
+/// @param name name of the type.
|
|
|
+/// @param base base type.
|
|
|
+/// @param module module where the type is defined. Use `NULL` for built-in types.
|
|
|
+/// @param dtor destructor function. Use `NULL` if not needed.
|
|
|
+PK_API py_Type py_newtype(const char* name, py_Type base, const py_GlobalRef module, py_Dtor dtor);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_istype">py_istype</h3>
|
|
|
+<div id="py_istype-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Check if the object is exactly the given type.
|
|
|
+PK_API bool py_istype(py_Ref, py_Type);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_typeof">py_typeof</h3>
|
|
|
+<div id="py_typeof-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the type of the object.
|
|
|
+PK_API py_Type py_typeof(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_isinstance">py_isinstance</h3>
|
|
|
+<div id="py_isinstance-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Check if the object is an instance of the given type.
|
|
|
+PK_API bool py_isinstance(py_Ref obj, py_Type type);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_issubclass">py_issubclass</h3>
|
|
|
+<div id="py_issubclass-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Check if the derived type is a subclass of the base type.
|
|
|
+PK_API bool py_issubclass(py_Type derived, py_Type base);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_gettype">py_gettype</h3>
|
|
|
+<div id="py_gettype-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get type by module and name. e.g. `py_gettype("time", py_name("struct_time"))`.
|
|
|
+/// Return `0` if not found.
|
|
|
+PK_API py_Type py_gettype(const char* module, py_Name name);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_checktype">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_checktype-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Check if the object is an instance of the given type exactly.
|
|
|
+/// Raise `TypeError` if the check fails.
|
|
|
+PK_API bool py_checktype(py_Ref self, py_Type type);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_checkinstance">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_checkinstance-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<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.
|
|
|
+/// Raise `TypeError` if the check fails.
|
|
|
+PK_API bool py_checkinstance(py_Ref self, py_Type type);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tpfindmagic">py_tpfindmagic</h3>
|
|
|
+<div id="py_tpfindmagic-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Search the magic method from the given type to the base type.
|
|
|
+/// Return `NULL` if not found.
|
|
|
+PK_API py_GlobalRef py_tpfindmagic(py_Type, py_Name name);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tpfindname">py_tpfindname</h3>
|
|
|
+<div id="py_tpfindname-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Search the name from the given type to the base type.
|
|
|
+/// Return `NULL` if not found.
|
|
|
+PK_API py_ItemRef py_tpfindname(py_Type, py_Name name);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tpbase">py_tpbase</h3>
|
|
|
+<div id="py_tpbase-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the base type of the given type.
|
|
|
+PK_API py_Type py_tpbase(py_Type type);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tpobject">py_tpobject</h3>
|
|
|
+<div id="py_tpobject-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the type object of the given type.
|
|
|
+PK_API py_GlobalRef py_tpobject(py_Type type);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tpsetfinal">py_tpsetfinal</h3>
|
|
|
+<div id="py_tpsetfinal-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Disable the type for subclassing.
|
|
|
+PK_API void py_tpsetfinal(py_Type type);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tphookattributes">py_tphookattributes</h3>
|
|
|
+<div id="py_tphookattributes-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Set attribute hooks for the given type.
|
|
|
+PK_API void py_tphookattributes(py_Type type,
|
|
|
+ bool (*getattribute)(py_Ref self, py_Name name) PY_RAISE PY_RETURN,
|
|
|
+ bool (*setattribute)(py_Ref self, py_Name name, py_Ref val)
|
|
|
+ PY_RAISE PY_RETURN,
|
|
|
+ bool (*delattribute)(py_Ref self, py_Name name) PY_RAISE,
|
|
|
+ bool (*getunboundmethod)(py_Ref self, py_Name name) PY_RETURN);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_inspect_currentfunction">py_inspect_currentfunction</h3>
|
|
|
+<div id="py_inspect_currentfunction-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the current `Callable` object on the stack of the most recent vectorcall.
|
|
|
+/// Return `NULL` if not available.
|
|
|
+/// NOTE: This function should be placed at the beginning of your bindings or you will get wrong result.
|
|
|
+PK_API py_StackRef py_inspect_currentfunction();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_inspect_currentmodule">py_inspect_currentmodule</h3>
|
|
|
+<div id="py_inspect_currentmodule-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the current `module` object where the code is executed.
|
|
|
+/// Return `NULL` if not available.
|
|
|
+PK_API py_GlobalRef py_inspect_currentmodule();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_inspect_currentframe">py_inspect_currentframe</h3>
|
|
|
+<div id="py_inspect_currentframe-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the current frame object.
|
|
|
+/// Return `NULL` if not available.
|
|
|
+PK_API py_Frame* py_inspect_currentframe();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newglobals">py_newglobals</h3>
|
|
|
+<div id="py_newglobals-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `globals()`.
|
|
|
+PK_API void py_newglobals(py_OutRef);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newlocals">py_newlocals</h3>
|
|
|
+<div id="py_newlocals-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `locals()`.
|
|
|
+PK_API void py_newlocals(py_OutRef);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_getreg">py_getreg</h3>
|
|
|
+<div id="py_getreg-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the i-th register.
|
|
|
+/// All registers are located in a contiguous memory.
|
|
|
+PK_API py_GlobalRef py_getreg(int i);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_setreg">py_setreg</h3>
|
|
|
+<div id="py_setreg-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Set the i-th register.
|
|
|
+PK_API void py_setreg(int i, py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_retval">py_retval</h3>
|
|
|
+<div id="py_retval-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the last return value.
|
|
|
+/// Please note that `py_retval()` cannot be used as input argument.
|
|
|
+PK_API py_GlobalRef py_retval();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_getdict">py_getdict</h3>
|
|
|
+<div id="py_getdict-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get an item from the object's `__dict__`.
|
|
|
+/// Return `NULL` if not found.
|
|
|
+PK_API py_ItemRef py_getdict(py_Ref self, py_Name name);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_setdict">py_setdict</h3>
|
|
|
+<div id="py_setdict-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Set an item to the object's `__dict__`.
|
|
|
+PK_API void py_setdict(py_Ref self, py_Name name, py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_deldict">py_deldict</h3>
|
|
|
+<div id="py_deldict-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Delete an item from the object's `__dict__`.
|
|
|
+/// Return `true` if the deletion is successful.
|
|
|
+PK_API bool py_deldict(py_Ref self, py_Name name);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_emplacedict">py_emplacedict</h3>
|
|
|
+<div id="py_emplacedict-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Prepare an insertion to the object's `__dict__`.
|
|
|
+PK_API py_ItemRef py_emplacedict(py_Ref self, py_Name name);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_applydict">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_applydict-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Apply a function to all items in the object's `__dict__`.
|
|
|
+/// Return `true` if the function is successful for all items.
|
|
|
+/// NOTE: Be careful if `f` modifies the object's `__dict__`.
|
|
|
+PK_API bool py_applydict(py_Ref self, bool (*f)(py_Name name, py_Ref val, void* ctx), void* ctx);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_cleardict">py_cleardict</h3>
|
|
|
+<div id="py_cleardict-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Clear the object's `__dict__`. This function is dangerous.
|
|
|
+PK_API void py_cleardict(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_getslot">py_getslot</h3>
|
|
|
+<div id="py_getslot-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the i-th slot of the object.
|
|
|
+/// The object must have slots and `i` must be in valid range.
|
|
|
+PK_API py_ObjectRef py_getslot(py_Ref self, int i);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_setslot">py_setslot</h3>
|
|
|
+<div id="py_setslot-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Set the i-th slot of the object.
|
|
|
+PK_API void py_setslot(py_Ref self, int i, py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_getbuiltin">py_getbuiltin</h3>
|
|
|
+<div id="py_getbuiltin-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get variable in the `builtins` module.
|
|
|
+PK_API py_ItemRef py_getbuiltin(py_Name name);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_getglobal">py_getglobal</h3>
|
|
|
+<div id="py_getglobal-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get variable in the `__main__` module.
|
|
|
+PK_API py_ItemRef py_getglobal(py_Name name);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_setglobal">py_setglobal</h3>
|
|
|
+<div id="py_setglobal-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Set variable in the `__main__` module.
|
|
|
+PK_API void py_setglobal(py_Name name, py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_peek">py_peek</h3>
|
|
|
+<div id="py_peek-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the i-th object from the top of the stack.
|
|
|
+/// `i` should be negative, e.g. (-1) means TOS.
|
|
|
+PK_API py_StackRef py_peek(int i);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_push">py_push</h3>
|
|
|
+<div id="py_push-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Push the object to the stack.
|
|
|
+PK_API void py_push(py_Ref src);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_pushnil">py_pushnil</h3>
|
|
|
+<div id="py_pushnil-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Push a `nil` object to the stack.
|
|
|
+PK_API void py_pushnil();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_pushnone">py_pushnone</h3>
|
|
|
+<div id="py_pushnone-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Push a `None` object to the stack.
|
|
|
+PK_API void py_pushnone();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_pushname">py_pushname</h3>
|
|
|
+<div id="py_pushname-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<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.
|
|
|
+PK_API void py_pushname(py_Name name);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_pop">py_pop</h3>
|
|
|
+<div id="py_pop-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Pop an object from the stack.
|
|
|
+PK_API void py_pop();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_shrink">py_shrink</h3>
|
|
|
+<div id="py_shrink-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Shrink the stack by n.
|
|
|
+PK_API void py_shrink(int n);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_pushtmp">py_pushtmp</h3>
|
|
|
+<div id="py_pushtmp-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get a temporary variable from the stack.
|
|
|
+PK_API py_StackRef py_pushtmp();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_pushmethod">py_pushmethod</h3>
|
|
|
+<div id="py_pushmethod-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the unbound method of the object.
|
|
|
+/// Assume the object is located at the top of the stack.
|
|
|
+/// If return true: `[self] -> [unbound, self]`.
|
|
|
+/// If return false: `[self] -> [self]` (no change).
|
|
|
+PK_API bool py_pushmethod(py_Name name);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_pusheval">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_pusheval-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Evaluate an expression and push the result to the stack.
|
|
|
+/// This function is used for testing.
|
|
|
+PK_API bool py_pusheval(const char* expr, py_GlobalRef module);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_vectorcall">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_vectorcall-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Call a callable object via pocketpy's calling convention.
|
|
|
+/// You need to prepare the stack using the following format:
|
|
|
+/// `callable, self/nil, arg1, arg2, ..., k1, v1, k2, v2, ...`.
|
|
|
+/// `argc` is the number of positional arguments excluding `self`.
|
|
|
+/// `kwargc` is the number of keyword arguments.
|
|
|
+/// The result will be set to `py_retval()`.
|
|
|
+/// The stack size will be reduced by `2 + argc + kwargc * 2`.
|
|
|
+PK_API bool py_vectorcall(uint16_t argc, uint16_t kwargc);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_call">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_call-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Call a function.
|
|
|
+/// It prepares the stack and then performs a `vectorcall(argc, 0, false)`.
|
|
|
+/// The result will be set to `py_retval()`.
|
|
|
+/// The stack remains unchanged if successful.
|
|
|
+PK_API bool py_call(py_Ref f, int argc, py_Ref argv);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tpcall">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_tpcall-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Call a type to create a new instance.
|
|
|
+PK_API bool py_tpcall(py_Type type, int argc, py_Ref argv);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_callcfunc">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_callcfunc-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Call a `py_CFunction` in a safe way.
|
|
|
+/// This function does extra checks to help you debug `py_CFunction`.
|
|
|
+PK_API bool py_callcfunc(py_CFunction f, int argc, py_Ref argv);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_binaryop">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_binaryop-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Perform a binary operation.
|
|
|
+/// The result will be set to `py_retval()`.
|
|
|
+/// The stack remains unchanged after the operation.
|
|
|
+PK_API bool py_binaryop(py_Ref lhs, py_Ref rhs, py_Name op, py_Name rop);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_binaryadd">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_binaryadd-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs + rhs
|
|
|
+PK_API bool py_binaryadd(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_binarysub">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_binarysub-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs - rhs
|
|
|
+PK_API bool py_binarysub(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_binarymul">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_binarymul-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs * rhs
|
|
|
+PK_API bool py_binarymul(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_binarytruediv">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_binarytruediv-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs / rhs
|
|
|
+PK_API bool py_binarytruediv(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_binaryfloordiv">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_binaryfloordiv-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs // rhs
|
|
|
+PK_API bool py_binaryfloordiv(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_binarymod">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_binarymod-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs % rhs
|
|
|
+PK_API bool py_binarymod(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_binarypow">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_binarypow-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs ** rhs
|
|
|
+PK_API bool py_binarypow(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_binarylshift">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_binarylshift-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs << rhs
|
|
|
+PK_API bool py_binarylshift(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_binaryrshift">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_binaryrshift-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs >> rhs
|
|
|
+PK_API bool py_binaryrshift(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_binaryand">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_binaryand-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs & rhs
|
|
|
+PK_API bool py_binaryand(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_binaryor">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_binaryor-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs | rhs
|
|
|
+PK_API bool py_binaryor(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_binaryxor">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_binaryxor-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs ^ rhs
|
|
|
+PK_API bool py_binaryxor(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_binarymatmul">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_binarymatmul-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs @ rhs
|
|
|
+PK_API bool py_binarymatmul(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_eq">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_eq-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs == rhs
|
|
|
+PK_API bool py_eq(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_ne">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_ne-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs != rhs
|
|
|
+PK_API bool py_ne(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_lt">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_lt-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs < rhs
|
|
|
+PK_API bool py_lt(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_le">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_le-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs <= rhs
|
|
|
+PK_API bool py_le(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_gt">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_gt-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs > rhs
|
|
|
+PK_API bool py_gt(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_ge">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_ge-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// lhs >= rhs
|
|
|
+PK_API bool py_ge(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_isidentical">py_isidentical</h3>
|
|
|
+<div id="py_isidentical-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `lhs is rhs`.
|
|
|
+PK_API bool py_isidentical(py_Ref, py_Ref);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_bool">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_bool-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `bool(val)`.
|
|
|
+/// 1: true, 0: false, -1: error
|
|
|
+PK_API int py_bool(py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_equal">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_equal-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Compare two objects.
|
|
|
+/// 1: lhs == rhs, 0: lhs != rhs, -1: error
|
|
|
+PK_API int py_equal(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_less">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_less-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Compare two objects.
|
|
|
+/// 1: lhs < rhs, 0: lhs >= rhs, -1: error
|
|
|
+PK_API int py_less(py_Ref lhs, py_Ref rhs);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_callable">py_callable</h3>
|
|
|
+<div id="py_callable-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `callable(val)`.
|
|
|
+PK_API bool py_callable(py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_hash">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_hash-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the hash value of the object.
|
|
|
+PK_API bool py_hash(py_Ref, py_i64* out);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_iter">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_iter-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the iterator of the object.
|
|
|
+PK_API bool py_iter(py_Ref);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_next">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_next-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get the next element from the iterator.
|
|
|
+/// 1: success, 0: StopIteration, -1: error
|
|
|
+PK_API int py_next(py_Ref);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_str">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_str-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `str(val)`.
|
|
|
+PK_API bool py_str(py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_repr">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_repr-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `repr(val)`.
|
|
|
+PK_API bool py_repr(py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_len">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_len-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `len(val)`.
|
|
|
+PK_API bool py_len(py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_getattr">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_getattr-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `getattr(self, name)`.
|
|
|
+PK_API bool py_getattr(py_Ref self, py_Name name);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_setattr">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_setattr-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `setattr(self, name, val)`.
|
|
|
+PK_API bool py_setattr(py_Ref self, py_Name name, py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_delattr">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_delattr-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `delattr(self, name)`.
|
|
|
+PK_API bool py_delattr(py_Ref self, py_Name name);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_getitem">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_getitem-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `self[key]`.
|
|
|
+PK_API bool py_getitem(py_Ref self, py_Ref key);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_setitem">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_setitem-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `self[key] = val`.
|
|
|
+PK_API bool py_setitem(py_Ref self, py_Ref key, py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_delitem">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_delitem-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `del self[key]`.
|
|
|
+PK_API bool py_delitem(py_Ref self, py_Ref key);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_getmodule">py_getmodule</h3>
|
|
|
+<div id="py_getmodule-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Get a module by path.
|
|
|
+PK_API py_GlobalRef py_getmodule(const char* path);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newmodule">py_newmodule</h3>
|
|
|
+<div id="py_newmodule-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a new module.
|
|
|
+PK_API py_GlobalRef py_newmodule(const char* path);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_importlib_reload">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_importlib_reload-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Reload an existing module.
|
|
|
+PK_API bool py_importlib_reload(py_Ref module);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_import">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_import-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Import a module.
|
|
|
+/// The result will be set to `py_retval()`.
|
|
|
+/// -1: error, 0: not found, 1: success
|
|
|
+PK_API int py_import(const char* path);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_checkexc">py_checkexc</h3>
|
|
|
+<div id="py_checkexc-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Check if there is an unhandled exception.
|
|
|
+PK_API bool py_checkexc();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_matchexc">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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_matchexc-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Check if the unhandled exception is an instance of the given type.
|
|
|
+/// If match, the exception will be stored in `py_retval()`.
|
|
|
+PK_API bool py_matchexc(py_Type type);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_clearexc">py_clearexc</h3>
|
|
|
+<div id="py_clearexc-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Clear the unhandled exception.
|
|
|
+/// @param p0 the unwinding point. Use `NULL` if not needed.
|
|
|
+PK_API void py_clearexc(py_StackRef p0);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_printexc">py_printexc</h3>
|
|
|
+<div id="py_printexc-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Print the unhandled exception.
|
|
|
+PK_API void py_printexc();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_formatexc">py_formatexc</h3>
|
|
|
+<div id="py_formatexc-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Format the unhandled exception and return a null-terminated string.
|
|
|
+/// The returned string should be freed by the caller.
|
|
|
+PK_API char* py_formatexc();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_exception">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_exception-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Raise an exception by type and message. Always return false.
|
|
|
+PK_API bool py_exception(py_Type type, const char* fmt, ...);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_raise">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_raise-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Raise an exception object. Always return false.
|
|
|
+PK_API bool py_raise(py_Ref);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="keyerror">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="keyerror-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API bool KeyError(py_Ref key);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="stopiteration">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="stopiteration-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API bool StopIteration();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_debugger_waitforattach">py_debugger_waitforattach</h3>
|
|
|
+<div id="py_debugger_waitforattach-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_debugger_waitforattach(const char* hostname, unsigned short port);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_debugger_status">py_debugger_status</h3>
|
|
|
+<div id="py_debugger_status-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API int py_debugger_status();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_debugger_exceptionbreakpoint">py_debugger_exceptionbreakpoint</h3>
|
|
|
+<div id="py_debugger_exceptionbreakpoint-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_debugger_exceptionbreakpoint(py_Ref exc);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_debugger_exit">py_debugger_exit</h3>
|
|
|
+<div id="py_debugger_exit-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_debugger_exit(int code);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newtuple">py_newtuple</h3>
|
|
|
+<div id="py_newtuple-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `tuple` with `n` UNINITIALIZED elements.
|
|
|
+/// You should initialize all elements before using it.
|
|
|
+PK_API py_ObjectRef py_newtuple(py_OutRef, int n);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tuple_data">py_tuple_data</h3>
|
|
|
+<div id="py_tuple_data-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API py_ObjectRef py_tuple_data(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tuple_getitem">py_tuple_getitem</h3>
|
|
|
+<div id="py_tuple_getitem-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API py_ObjectRef py_tuple_getitem(py_Ref self, int i);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tuple_setitem">py_tuple_setitem</h3>
|
|
|
+<div id="py_tuple_setitem-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_tuple_setitem(py_Ref self, int i, py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tuple_len">py_tuple_len</h3>
|
|
|
+<div id="py_tuple_len-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API int py_tuple_len(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newlist">py_newlist</h3>
|
|
|
+<div id="py_newlist-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create an empty `list`.
|
|
|
+PK_API void py_newlist(py_OutRef);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newlistn">py_newlistn</h3>
|
|
|
+<div id="py_newlistn-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `list` with `n` UNINITIALIZED elements.
|
|
|
+/// You should initialize all elements before using it.
|
|
|
+PK_API void py_newlistn(py_OutRef, int n);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_list_data">py_list_data</h3>
|
|
|
+<div id="py_list_data-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API py_ItemRef py_list_data(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_list_getitem">py_list_getitem</h3>
|
|
|
+<div id="py_list_getitem-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API py_ItemRef py_list_getitem(py_Ref self, int i);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_list_setitem">py_list_setitem</h3>
|
|
|
+<div id="py_list_setitem-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_list_setitem(py_Ref self, int i, py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_list_delitem">py_list_delitem</h3>
|
|
|
+<div id="py_list_delitem-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_list_delitem(py_Ref self, int i);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_list_len">py_list_len</h3>
|
|
|
+<div id="py_list_len-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API int py_list_len(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_list_swap">py_list_swap</h3>
|
|
|
+<div id="py_list_swap-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_list_swap(py_Ref self, int i, int j);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_list_append">py_list_append</h3>
|
|
|
+<div id="py_list_append-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_list_append(py_Ref self, py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_list_emplace">py_list_emplace</h3>
|
|
|
+<div id="py_list_emplace-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API py_ItemRef py_list_emplace(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_list_clear">py_list_clear</h3>
|
|
|
+<div id="py_list_clear-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_list_clear(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_list_insert">py_list_insert</h3>
|
|
|
+<div id="py_list_insert-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_list_insert(py_Ref self, int i, py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newdict">py_newdict</h3>
|
|
|
+<div id="py_newdict-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create an empty `dict`.
|
|
|
+PK_API void py_newdict(py_OutRef);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_dict_getitem">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_dict_getitem-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// -1: error, 0: not found, 1: found
|
|
|
+PK_API int py_dict_getitem(py_Ref self, py_Ref key);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_dict_setitem">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_dict_setitem-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// true: success, false: error
|
|
|
+PK_API bool py_dict_setitem(py_Ref self, py_Ref key, py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_dict_delitem">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_dict_delitem-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// -1: error, 0: not found, 1: found (and deleted)
|
|
|
+PK_API int py_dict_delitem(py_Ref self, py_Ref key);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_dict_getitem_by_str">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_dict_getitem_by_str-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// -1: error, 0: not found, 1: found
|
|
|
+PK_API int py_dict_getitem_by_str(py_Ref self, const char* key);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_dict_getitem_by_int">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_dict_getitem_by_int-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// -1: error, 0: not found, 1: found
|
|
|
+PK_API int py_dict_getitem_by_int(py_Ref self, py_i64 key);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_dict_setitem_by_str">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_dict_setitem_by_str-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// true: success, false: error
|
|
|
+PK_API bool py_dict_setitem_by_str(py_Ref self, const char* key, py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_dict_setitem_by_int">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_dict_setitem_by_int-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// true: success, false: error
|
|
|
+PK_API bool py_dict_setitem_by_int(py_Ref self, py_i64 key, py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_dict_delitem_by_str">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_dict_delitem_by_str-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// -1: error, 0: not found, 1: found (and deleted)
|
|
|
+PK_API int py_dict_delitem_by_str(py_Ref self, const char* key);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_dict_delitem_by_int">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_dict_delitem_by_int-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// -1: error, 0: not found, 1: found (and deleted)
|
|
|
+PK_API int py_dict_delitem_by_int(py_Ref self, py_i64 key);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_dict_apply">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">
|
|
|
+ <span>raise</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_dict_apply-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// true: success, false: error
|
|
|
+PK_API bool py_dict_apply(py_Ref self, bool (*f)(py_Ref key, py_Ref val, void* ctx), void* ctx);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_dict_len">py_dict_len</h3>
|
|
|
+<div id="py_dict_len-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// noexcept
|
|
|
+PK_API int py_dict_len(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newslice">py_newslice</h3>
|
|
|
+<div id="py_newslice-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create an UNINITIALIZED `slice` object.
|
|
|
+/// You should use `py_setslot()` to set `start`, `stop`, and `step`.
|
|
|
+PK_API py_ObjectRef py_newslice(py_OutRef);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newsliceint">py_newsliceint</h3>
|
|
|
+<div id="py_newsliceint-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Create a `slice` object from 3 integers.
|
|
|
+PK_API void py_newsliceint(py_OutRef out, py_i64 start, py_i64 stop, py_i64 step);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newrandom">py_newRandom</h3>
|
|
|
+<div id="py_newrandom-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_newRandom(py_OutRef out);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_random_seed">py_Random_seed</h3>
|
|
|
+<div id="py_random_seed-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_Random_seed(py_Ref self, py_i64 seed);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_random_random">py_Random_random</h3>
|
|
|
+<div id="py_random_random-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API py_f64 py_Random_random(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_random_uniform">py_Random_uniform</h3>
|
|
|
+<div id="py_random_uniform-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API py_f64 py_Random_uniform(py_Ref self, py_f64 a, py_f64 b);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_random_randint">py_Random_randint</h3>
|
|
|
+<div id="py_random_randint-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API py_i64 py_Random_randint(py_Ref self, py_i64 a, py_i64 b);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newarray2d">py_newarray2d</h3>
|
|
|
+<div id="py_newarray2d-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_newarray2d(py_OutRef out, int width, int height);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_array2d_getwidth">py_array2d_getwidth</h3>
|
|
|
+<div id="py_array2d_getwidth-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API int py_array2d_getwidth(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_array2d_getheight">py_array2d_getheight</h3>
|
|
|
+<div id="py_array2d_getheight-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API int py_array2d_getheight(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_array2d_getitem">py_array2d_getitem</h3>
|
|
|
+<div id="py_array2d_getitem-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API py_ObjectRef py_array2d_getitem(py_Ref self, int x, int y);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_array2d_setitem">py_array2d_setitem</h3>
|
|
|
+<div id="py_array2d_setitem-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_array2d_setitem(py_Ref self, int x, int y, py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newvec2">py_newvec2</h3>
|
|
|
+<div id="py_newvec2-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_newvec2(py_OutRef out, c11_vec2);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newvec3">py_newvec3</h3>
|
|
|
+<div id="py_newvec3-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_newvec3(py_OutRef out, c11_vec3);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newvec2i">py_newvec2i</h3>
|
|
|
+<div id="py_newvec2i-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_newvec2i(py_OutRef out, c11_vec2i);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newvec3i">py_newvec3i</h3>
|
|
|
+<div id="py_newvec3i-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_newvec3i(py_OutRef out, c11_vec3i);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newvec4i">py_newvec4i</h3>
|
|
|
+<div id="py_newvec4i-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_newvec4i(py_OutRef out, c11_vec4i);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newcolor32">py_newcolor32</h3>
|
|
|
+<div id="py_newcolor32-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_newcolor32(py_OutRef out, c11_color32);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_newmat3x3">py_newmat3x3</h3>
|
|
|
+<div id="py_newmat3x3-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API c11_mat3x3* py_newmat3x3(py_OutRef out);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tovec2">py_tovec2</h3>
|
|
|
+<div id="py_tovec2-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API c11_vec2 py_tovec2(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tovec3">py_tovec3</h3>
|
|
|
+<div id="py_tovec3-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API c11_vec3 py_tovec3(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tovec2i">py_tovec2i</h3>
|
|
|
+<div id="py_tovec2i-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API c11_vec2i py_tovec2i(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tovec3i">py_tovec3i</h3>
|
|
|
+<div id="py_tovec3i-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API c11_vec3i py_tovec3i(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tovec4i">py_tovec4i</h3>
|
|
|
+<div id="py_tovec4i-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API c11_vec4i py_tovec4i(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tomat3x3">py_tomat3x3</h3>
|
|
|
+<div id="py_tomat3x3-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API c11_mat3x3* py_tomat3x3(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_tocolor32">py_tocolor32</h3>
|
|
|
+<div id="py_tocolor32-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API c11_color32 py_tocolor32(py_Ref self);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_json_dumps">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_json_dumps-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `json.dumps(val)`.
|
|
|
+PK_API bool py_json_dumps(py_Ref val, int indent);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_json_loads">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_json_loads-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `json.loads(val)`.
|
|
|
+PK_API bool py_json_loads(const char* source);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_pickle_dumps">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_pickle_dumps-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `pickle.dumps(val)`.
|
|
|
+PK_API bool py_pickle_dumps(py_Ref val);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_pickle_loads">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">
|
|
|
+ <span>raise</span>
|
|
|
+</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">
|
|
|
+ <span>return</span>
|
|
|
+</a></h3>
|
|
|
+<div id="py_pickle_loads-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Python equivalent to `pickle.loads(val)`.
|
|
|
+PK_API bool py_pickle_loads(const unsigned char* data, int size);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_watchdog_begin">py_watchdog_begin</h3>
|
|
|
+<div id="py_watchdog_begin-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Begin the watchdog with `timeout` in milliseconds.
|
|
|
+/// `PK_ENABLE_WATCHDOG` must be defined to `1` to use this feature.
|
|
|
+/// You need to call `py_watchdog_end()` later.
|
|
|
+/// If `timeout` is reached, `TimeoutError` will be raised.
|
|
|
+PK_API void py_watchdog_begin(py_i64 timeout);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_watchdog_end">py_watchdog_end</h3>
|
|
|
+<div id="py_watchdog_end-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// Reset the watchdog.
|
|
|
+PK_API void py_watchdog_end();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_profiler_begin">py_profiler_begin</h3>
|
|
|
+<div id="py_profiler_begin-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_profiler_begin();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_profiler_end">py_profiler_end</h3>
|
|
|
+<div id="py_profiler_end-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_profiler_end();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_profiler_reset">py_profiler_reset</h3>
|
|
|
+<div id="py_profiler_reset-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API void py_profiler_reset();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_profiler_report">py_profiler_report</h3>
|
|
|
+<div id="py_profiler_report-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">
|
|
|
+PK_API char* py_profiler_report();</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+<h3 id="py_replinput">py_replinput</h3>
|
|
|
+<div id="py_replinput-code-1" class="codeblock-wrapper"><doc-codeblock>
|
|
|
+<pre translate="no" class="language-c"><code v-pre class="language-c">/// An utility function to read a line from stdin for REPL.
|
|
|
+PK_API int py_replinput(char* buf, int max_size);</code></pre>
|
|
|
+</doc-codeblock></div>
|
|
|
+
|
|
|
+
|
|
|
+ <!-- Required only on API pages -->
|
|
|
+ <doc-toolbar-member-filter-no-results></doc-toolbar-member-filter-no-results>
|
|
|
+ </div>
|
|
|
+ <footer id="retype-content-footer" class="clear-both">
|
|
|
+
|
|
|
+ <nav id="retype-nextprev" class="print:hidden flex mt-14">
|
|
|
+ <div class="w-1/2">
|
|
|
+ <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/">
|
|
|
+ <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>
|
|
|
+ <span>
|
|
|
+ <span class="block text-xs font-normal text-base-text-muted">Previous</span>
|
|
|
+ <span class="block mt-1">Introduction</span>
|
|
|
+ </span>
|
|
|
+ </a>
|
|
|
+ </div>
|
|
|
+
|
|
|
+ <div class="w-1/2">
|
|
|
+ <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/">
|
|
|
+ <span>
|
|
|
+ <span class="block text-xs font-normal text-right text-base-text-muted">Next</span>
|
|
|
+ <span class="block mt-1">array2d</span>
|
|
|
+ </span>
|
|
|
+ <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>
|
|
|
+ </a>
|
|
|
+ </div>
|
|
|
+ </nav>
|
|
|
+ </footer>
|
|
|
+ </main>
|
|
|
+
|
|
|
+ <div id="retype-page-footer" class="print:border-none border-t border-base-border pt-6 mb-8">
|
|
|
+ <footer class="flex flex-wrap items-center justify-between print:justify-center">
|
|
|
+ <div id="retype-footer-links" class="print:hidden">
|
|
|
+ <ul class="flex flex-wrap items-center text-sm">
|
|
|
+ </ul>
|
|
|
+ </div>
|
|
|
+ <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>
|
|
|
+ </footer>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+
|
|
|
+ <!-- Rendered if sidebar right is enabled -->
|
|
|
+ <!-- Sidebar right skeleton-->
|
|
|
+ <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">
|
|
|
+ <div class="pl-5">
|
|
|
+ <div class="w-32 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
|
|
|
+ <div class="w-48 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
|
|
|
+ <div class="w-40 h-3 mb-4 bg-skeleton-bg rounded-full loading"></div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+
|
|
|
+ <!-- User should be able to hide sidebar right -->
|
|
|
+ <doc-sidebar-right v-cloak></doc-sidebar-right>
|
|
|
+</div>
|
|
|
+
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+
|
|
|
+ <doc-search-mobile></doc-search-mobile>
|
|
|
+ <doc-back-to-top></doc-back-to-top>
|
|
|
+</div>
|
|
|
+
|
|
|
+
|
|
|
+ <div id="retype-overlay-target"></div>
|
|
|
+
|
|
|
+ <script data-cfasync="false">window.__DOCS__ = { "title": "Functions", level: 2, icon: "file", hasPrism: true, hasMermaid: false, hasMath: false, tocDepth: 23 }</script>
|
|
|
+</body>
|
|
|
+</html>
|