CINXE.COM

peps/peps/pep-0327.rst at main · python/peps · GitHub

<!DOCTYPE html> <html lang="en" data-color-mode="auto" data-light-theme="light" data-dark-theme="dark" data-a11y-animated-images="system" data-a11y-link-underlines="true" > <head> <meta charset="utf-8"> <link rel="dns-prefetch" href="https://github.githubassets.com"> <link rel="dns-prefetch" href="https://avatars.githubusercontent.com"> <link rel="dns-prefetch" href="https://github-cloud.s3.amazonaws.com"> <link rel="dns-prefetch" href="https://user-images.githubusercontent.com/"> <link rel="preconnect" href="https://github.githubassets.com" crossorigin> <link rel="preconnect" href="https://avatars.githubusercontent.com"> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/light-74231a1f3bbb.css" /><link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/dark-8a995f0bacd4.css" /><link data-color-theme="dark_dimmed" crossorigin="anonymous" media="all" rel="stylesheet" data-href="https://github.githubassets.com/assets/dark_dimmed-f37fb7684b1f.css" /><link data-color-theme="dark_high_contrast" crossorigin="anonymous" media="all" rel="stylesheet" data-href="https://github.githubassets.com/assets/dark_high_contrast-9ac301c3ebe5.css" /><link data-color-theme="dark_colorblind" crossorigin="anonymous" media="all" rel="stylesheet" data-href="https://github.githubassets.com/assets/dark_colorblind-cd826e8636dc.css" /><link data-color-theme="light_colorblind" crossorigin="anonymous" media="all" rel="stylesheet" data-href="https://github.githubassets.com/assets/light_colorblind-f91b0f603451.css" /><link data-color-theme="light_high_contrast" crossorigin="anonymous" media="all" rel="stylesheet" data-href="https://github.githubassets.com/assets/light_high_contrast-83beb16e0ecf.css" /><link data-color-theme="light_tritanopia" crossorigin="anonymous" media="all" rel="stylesheet" data-href="https://github.githubassets.com/assets/light_tritanopia-6e122dab64fc.css" /><link data-color-theme="dark_tritanopia" crossorigin="anonymous" media="all" rel="stylesheet" data-href="https://github.githubassets.com/assets/dark_tritanopia-18119e682df0.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-primitives-225433424a87.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-aaa714e5674d.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/global-0a3c53b9d1c2.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/github-ea73c9cb5377.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/repository-4fce88777fa8.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/code-0210be90f4d3.css" /> <script type="application/json" id="client-env">{"locale":"en","featureFlags":["a11y_quote_reply_fix","copilot_immersive_issue_preview","copilot_new_references_ui","copilot_chat_repo_custom_instructions_preview","copilot_no_floating_button","copilot_topics_as_references","copilot_read_shared_conversation","copilot_duplicate_thread","copilot_buffered_streaming","dotcom_chat_client_side_skills","experimentation_azure_variant_endpoint","failbot_handle_non_errors","geojson_azure_maps","ghost_pilot_confidence_truncation_25","ghost_pilot_confidence_truncation_40","github_models_gateway_parse_params","github_models_o3_mini_streaming","insert_before_patch","issues_react_remove_placeholders","issues_react_blur_item_picker_on_close","marketing_pages_search_explore_provider","primer_react_css_modules_ga","react_data_router_pull_requests","remove_child_patch","sample_network_conn_type","swp_enterprise_contact_form","site_proxima_australia_update","viewscreen_sandbox","issues_react_create_milestone","issues_react_cache_fix_workaround","lifecycle_label_name_updates","copilot_task_oriented_assistive_prompts","issue_types_prevent_private_type_creation","refresh_image_video_src","react_router_dispose_on_disconnect","codespaces_prebuild_region_target_update","turbo_app_id_restore","copilot_code_review_sign_up_closed"]}</script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/wp-runtime-8835fef01a5a.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_oddbird_popover-polyfill_dist_popover_js-9da652f58479.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_arianotify-polyfill_ariaNotify-polyfill_js-node_modules_github_mi-3abb8f-46b9f4874d95.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_failbot_failbot_ts-75968cfb5298.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/environment-f04cb2a9fc8c.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_primer_behaviors_dist_esm_index_mjs-0dbb79f97f8f.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_selector-observer_dist_index_esm_js-f690fd9ae3d5.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_relative-time-element_dist_index_js-62d275b7ddd9.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_text-expander-element_dist_index_js-78748950cb0c.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_auto-complete-element_dist_index_js-node_modules_github_catalyst_-8e9f78-a90ac05d2469.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_filter-input-element_dist_index_js-node_modules_github_remote-inp-b5f1d7-a1760ffda83d.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_markdown-toolbar-element_dist_index_js-ceef33f593fa.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_file-attachment-element_dist_index_js-node_modules_primer_view-co-c44a69-efa32db3a345.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/github-elements-394f8eb34f19.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/element-registry-25113a65b77f.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_braintree_browser-detection_dist_browser-detection_js-node_modules_githu-2906d7-2a07a295af40.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_lit-html_lit-html_js-be8cb88f481b.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_mini-throttle_dist_index_js-node_modules_morphdom_dist_morphdom-e-7c534c-a4a1922eb55f.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_turbo_dist_turbo_es2017-esm_js-a03ee12d659a.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_remote-form_dist_index_js-node_modules_delegated-events_dist_inde-893f9f-b6294cf703b7.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_color-convert_index_js-e3180fe3bcb3.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_quote-selection_dist_index_js-node_modules_github_session-resume_-947061-e7a6c4a19f98.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_updatable-content_updatable-content_ts-2a55124d5c52.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/app_assets_modules_github_behaviors_task-list_ts-app_assets_modules_github_sso_ts-ui_packages-900dde-768abe60b1f8.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/app_assets_modules_github_sticky-scroll-into-view_ts-3e000c5d31a9.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/app_assets_modules_github_behaviors_ajax-error_ts-app_assets_modules_github_behaviors_include-87a4ae-4c160a67a3f8.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/app_assets_modules_github_behaviors_commenting_edit_ts-app_assets_modules_github_behaviors_ht-83c235-e429cff6ceb1.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/behaviors-f41565a56b0d.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_delegated-events_dist_index_js-node_modules_github_catalyst_lib_index_js-f6223d90c7ba.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/notifications-global-01e85cd1be94.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_mini-throttle_dist_index_js-node_modules_github_catalyst_lib_inde-dbbea9-26cce2010167.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/code-menu-1c0aedc134b1.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/primer-react-602097a4b0db.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/react-core-a18127980111.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/react-lib-f1bca44e0926.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/octicons-react-cf2f2ab8dab4.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_emotion_is-prop-valid_dist_emotion-is-prop-valid_esm_js-node_modules_emo-62da9f-2df2f32ec596.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_mini-throttle_dist_index_js-node_modules_stacktrace-parser_dist_s-e7dcdd-9a233856b02c.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_oddbird_popover-polyfill_dist_popover-fn_js-55fea94174bf.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_dompurify_dist_purify_es_mjs-dd1d3ea6a436.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_lodash-es__Stack_js-node_modules_lodash-es__Uint8Array_js-node_modules_l-4faaa6-4a736fde5c2f.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_lodash-es__baseIsEqual_js-8929eb9718d5.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_react-intersection-observer_react-intersection-observer_modern_mjs-node_-b27033-ba82cef135e3.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_focus-visible_dist_focus-visible_js-node_modules_fzy_js_index_js-node_mo-f2fece-29a0ceccb1f1.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_aria-live_aria-live_ts-ui_packages_promise-with-resolvers-polyfill_promise-with-r-17c672-34345cb18aac.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_paths_index_ts-3adbcf6faa83.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_ref-selector_RefSelector_tsx-7496afc3784d.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_commit-attribution_index_ts-ui_packages_commit-checks-status_index_ts-ui_packages-7094d4-b869a469ca5e.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_diffs_diff-parts_ts-b05d9274ce63.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_app-uuid_app-uuid_ts-ui_packages_document-metadata_document-metadata_ts-ui_packag-4d8de9-c9f824da1b03.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_hydro-analytics_hydro-analytics_ts-ui_packages_verified-fetch_verified-fetch_ts-u-4672d1-96a19eaeffb7.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_code-view-shared_hooks_use-canonical-object_ts-ui_packages_code-view-shared_hooks-d63960-3a5579c864b4.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/app_assets_modules_github_blob-anchor_ts-ui_packages_code-nav_code-nav_ts-ui_packages_filter--8253c1-91468a3354f9.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/react-code-view-7ef3067691e7.js"></script> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-react.248e2356ac373ce2e5c1.module.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/react-code-view.a0633e3d36c876a6eaa1.module.css" /> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/notifications-subscriptions-menu-57956eade845.js"></script> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-react.248e2356ac373ce2e5c1.module.css" /> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/notifications-subscriptions-menu.1bcff9205c241e99cff2.module.css" /> <title>peps/peps/pep-0327.rst at main · python/peps · GitHub</title> <meta name="route-pattern" content="/:user_id/:repository/blob/*name(/*path)" data-turbo-transient> <meta name="route-controller" content="blob" data-turbo-transient> <meta name="route-action" content="show" data-turbo-transient> <meta name="current-catalog-service-hash" content="f3abb0cc802f3d7b95fc8762b94bdcb13bf39634c40c357301c4aa1d67a256fb"> <meta name="request-id" content="8A6E:296BF6:AEE657:CFCE5A:67E6EB48" data-pjax-transient="true"/><meta name="html-safe-nonce" content="60305632deea15a362b62da8460cf95d323fde38cde2cbbfebc70ad2a335229b" data-pjax-transient="true"/><meta name="visitor-payload" content="eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiI4QTZFOjI5NkJGNjpBRUU2NTc6Q0ZDRTVBOjY3RTZFQjQ4IiwidmlzaXRvcl9pZCI6IjYzNzQyNDcyOTg4NzQ0MDM2NTYiLCJyZWdpb25fZWRnZSI6InNvdXRoZWFzdGFzaWEiLCJyZWdpb25fcmVuZGVyIjoic291dGhlYXN0YXNpYSJ9" data-pjax-transient="true"/><meta name="visitor-hmac" content="470b079eaa12285317b5bec29d38d757f561846d0aed8a7242e0cc2c85b18444" data-pjax-transient="true"/> <meta name="hovercard-subject-tag" content="repository:13414105" data-turbo-transient> <meta name="github-keyboard-shortcuts" content="repository,source-code,file-tree,copilot" data-turbo-transient="true" /> <meta name="selected-link" value="repo_source" data-turbo-transient> <link rel="assets" href="https://github.githubassets.com/"> <meta name="google-site-verification" content="Apib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I"> <meta name="octolytics-url" content="https://collector.github.com/github/collect" /> <meta name="analytics-location" content="/&lt;user-name&gt;/&lt;repo-name&gt;/blob/show" data-turbo-transient="true" /> <meta name="user-login" content=""> <meta name="viewport" content="width=device-width"> <meta name="description" content="Python Enhancement Proposals. Contribute to python/peps development by creating an account on GitHub."> <link rel="search" type="application/opensearchdescription+xml" href="/opensearch.xml" title="GitHub"> <link rel="fluid-icon" href="https://github.com/fluidicon.png" title="GitHub"> <meta property="fb:app_id" content="1401488693436528"> <meta name="apple-itunes-app" content="app-id=1477376905, app-argument=https://github.com/python/peps/blob/main/peps/pep-0327.rst" /> <meta name="twitter:image" content="https://opengraph.githubassets.com/b71319dfda1f665ec60c2f00e2d95167ae8021a9d3c7b737b4aa81e81ffef405/python/peps" /><meta name="twitter:site" content="@github" /><meta name="twitter:card" content="summary_large_image" /><meta name="twitter:title" content="peps/peps/pep-0327.rst at main · python/peps" /><meta name="twitter:description" content="Python Enhancement Proposals. Contribute to python/peps development by creating an account on GitHub." /> <meta property="og:image" content="https://opengraph.githubassets.com/b71319dfda1f665ec60c2f00e2d95167ae8021a9d3c7b737b4aa81e81ffef405/python/peps" /><meta property="og:image:alt" content="Python Enhancement Proposals. Contribute to python/peps development by creating an account on GitHub." /><meta property="og:image:width" content="1200" /><meta property="og:image:height" content="600" /><meta property="og:site_name" content="GitHub" /><meta property="og:type" content="object" /><meta property="og:title" content="peps/peps/pep-0327.rst at main · python/peps" /><meta property="og:url" content="https://github.com/python/peps/blob/main/peps/pep-0327.rst" /><meta property="og:description" content="Python Enhancement Proposals. Contribute to python/peps development by creating an account on GitHub." /> <meta name="hostname" content="github.com"> <meta name="expected-hostname" content="github.com"> <meta http-equiv="x-pjax-version" content="9c2c29b39626a34dc55824f953fe2c2cd24d35caad0cb2b70eed98933f17a7c8" data-turbo-track="reload"> <meta http-equiv="x-pjax-csp-version" content="77190eb53eb47fc30bd2fcc17a7eefa2dfd8505869fee9299ba911be3a40a9eb" data-turbo-track="reload"> <meta http-equiv="x-pjax-css-version" content="159e03504eed5183f9787c72780a7d8c1460af30746ab09d728b048c41719efa" data-turbo-track="reload"> <meta http-equiv="x-pjax-js-version" content="373db3a6b0664eccf6234c8178e06da8f1708411ca11db871056537ed1a47cc3" data-turbo-track="reload"> <meta name="turbo-cache-control" content="no-preview" data-turbo-transient=""> <meta name="turbo-cache-control" content="no-cache" data-turbo-transient> <meta data-hydrostats="publish"> <meta name="go-import" content="github.com/python/peps git https://github.com/python/peps.git"> <meta name="octolytics-dimension-user_id" content="1525981" /><meta name="octolytics-dimension-user_login" content="python" /><meta name="octolytics-dimension-repository_id" content="13414105" /><meta name="octolytics-dimension-repository_nwo" content="python/peps" /><meta name="octolytics-dimension-repository_public" content="true" /><meta name="octolytics-dimension-repository_is_fork" content="false" /><meta name="octolytics-dimension-repository_network_root_id" content="13414105" /><meta name="octolytics-dimension-repository_network_root_nwo" content="python/peps" /> <meta name="turbo-body-classes" content="logged-out env-production page-responsive"> <meta name="browser-stats-url" content="https://api.github.com/_private/browser/stats"> <meta name="browser-errors-url" content="https://api.github.com/_private/browser/errors"> <meta name="release" content="356c11eac0ad211f55ef49f5ee50b47c1f7a2912"> <link rel="mask-icon" href="https://github.githubassets.com/assets/pinned-octocat-093da3e6fa40.svg" color="#000000"> <link rel="alternate icon" class="js-site-favicon" type="image/png" href="https://github.githubassets.com/favicons/favicon.png"> <link rel="icon" class="js-site-favicon" type="image/svg+xml" href="https://github.githubassets.com/favicons/favicon.svg" data-base-href="https://github.githubassets.com/favicons/favicon"> <meta name="theme-color" content="#1e2327"> <meta name="color-scheme" content="light dark" /> <link rel="manifest" href="/manifest.json" crossOrigin="use-credentials"> </head> <body class="logged-out env-production page-responsive" style="word-wrap: break-word;"> <div data-turbo-body class="logged-out env-production page-responsive" style="word-wrap: break-word;"> <div class="position-relative header-wrapper js-header-wrapper "> <a href="#start-of-content" data-skip-target-assigned="false" class="px-2 py-4 color-bg-accent-emphasis color-fg-on-emphasis show-on-focus js-skip-to-content">Skip to content</a> <span data-view-component="true" class="progress-pjax-loader Progress position-fixed width-full"> <span style="width: 0%;" data-view-component="true" class="Progress-item progress-pjax-loader-bar left-0 top-0 color-bg-accent-emphasis"></span> </span> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/ui_packages_ui-commands_ui-commands_ts-2ea4e93613c0.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/keyboard-shortcuts-dialog-79d6a754ebf9.js"></script> <link crossorigin="anonymous" media="all" rel="stylesheet" href="https://github.githubassets.com/assets/primer-react.248e2356ac373ce2e5c1.module.css" /> <react-partial partial-name="keyboard-shortcuts-dialog" data-ssr="false" data-attempted-ssr="false" > <script type="application/json" data-target="react-partial.embeddedData">{"props":{"docsUrl":"https://docs.github.com/get-started/accessibility/keyboard-shortcuts"}}</script> <div data-target="react-partial.reactRoot"></div> </react-partial> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/vendors-node_modules_github_remote-form_dist_index_js-node_modules_delegated-events_dist_inde-94fd67-4898d1bf4b51.js"></script> <script crossorigin="anonymous" defer="defer" type="application/javascript" src="https://github.githubassets.com/assets/sessions-730dca81d0a2.js"></script> <header class="HeaderMktg header-logged-out js-details-container js-header Details f4 py-3" role="banner" data-is-top="true" data-color-mode=light data-light-theme=light data-dark-theme=dark> <h2 class="sr-only">Navigation Menu</h2> <button type="button" class="HeaderMktg-backdrop d-lg-none border-0 position-fixed top-0 left-0 width-full height-full js-details-target" aria-label="Toggle navigation"> <span class="d-none">Toggle navigation</span> </button> <div class="d-flex flex-column flex-lg-row flex-items-center px-3 px-md-4 px-lg-5 height-full position-relative z-1"> <div class="d-flex flex-justify-between flex-items-center width-full width-lg-auto"> <div class="flex-1"> <button aria-label="Toggle navigation" aria-expanded="false" type="button" data-view-component="true" class="js-details-target js-nav-padding-recalculate js-header-menu-toggle Button--link Button--medium Button d-lg-none color-fg-inherit p-1"> <span class="Button-content"> <span class="Button-label"><div class="HeaderMenu-toggle-bar rounded my-1"></div> <div class="HeaderMenu-toggle-bar rounded my-1"></div> <div class="HeaderMenu-toggle-bar rounded my-1"></div></span> </span> </button> </div> <a class="mr-lg-3 color-fg-inherit flex-order-2 js-prevent-focus-on-mobile-nav" href="/" aria-label="Homepage" data-analytics-event="{&quot;category&quot;:&quot;Marketing nav&quot;,&quot;action&quot;:&quot;click to go to homepage&quot;,&quot;label&quot;:&quot;ref_page:Marketing;ref_cta:Logomark;ref_loc:Header&quot;}"> <svg height="32" aria-hidden="true" viewBox="0 0 24 24" version="1.1" width="32" data-view-component="true" class="octicon octicon-mark-github"> <path d="M12 1C5.9225 1 1 5.9225 1 12C1 16.8675 4.14875 20.9787 8.52125 22.4362C9.07125 22.5325 9.2775 22.2025 9.2775 21.9137C9.2775 21.6525 9.26375 20.7862 9.26375 19.865C6.5 20.3737 5.785 19.1912 5.565 18.5725C5.44125 18.2562 4.905 17.28 4.4375 17.0187C4.0525 16.8125 3.5025 16.3037 4.42375 16.29C5.29 16.2762 5.90875 17.0875 6.115 17.4175C7.105 19.0812 8.68625 18.6137 9.31875 18.325C9.415 17.61 9.70375 17.1287 10.02 16.8537C7.5725 16.5787 5.015 15.63 5.015 11.4225C5.015 10.2262 5.44125 9.23625 6.1425 8.46625C6.0325 8.19125 5.6475 7.06375 6.2525 5.55125C6.2525 5.55125 7.17375 5.2625 9.2775 6.67875C10.1575 6.43125 11.0925 6.3075 12.0275 6.3075C12.9625 6.3075 13.8975 6.43125 14.7775 6.67875C16.8813 5.24875 17.8025 5.55125 17.8025 5.55125C18.4075 7.06375 18.0225 8.19125 17.9125 8.46625C18.6138 9.23625 19.04 10.2125 19.04 11.4225C19.04 15.6437 16.4688 16.5787 14.0213 16.8537C14.42 17.1975 14.7638 17.8575 14.7638 18.8887C14.7638 20.36 14.75 21.5425 14.75 21.9137C14.75 22.2025 14.9563 22.5462 15.5063 22.4362C19.8513 20.9787 23 16.8537 23 12C23 5.9225 18.0775 1 12 1Z"></path> </svg> </a> <div class="flex-1 flex-order-2 text-right"> <a href="/login?return_to=https%3A%2F%2Fgithub.com%2Fpython%2Fpeps%2Fblob%2Fmain%2Fpeps%2Fpep-0327.rst" class="HeaderMenu-link HeaderMenu-button d-inline-flex d-lg-none flex-order-1 f5 no-underline border color-border-default rounded-2 px-2 py-1 color-fg-inherit js-prevent-focus-on-mobile-nav" data-hydro-click="{&quot;event_type&quot;:&quot;authentication.click&quot;,&quot;payload&quot;:{&quot;location_in_page&quot;:&quot;site header menu&quot;,&quot;repository_id&quot;:null,&quot;auth_type&quot;:&quot;SIGN_UP&quot;,&quot;originating_url&quot;:&quot;https://github.com/python/peps/blob/main/peps/pep-0327.rst&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="0bedca4cf3774db708d3d7328aa6565542a3c56eb63de6e3069bfa3166442f98" data-analytics-event="{&quot;category&quot;:&quot;Marketing nav&quot;,&quot;action&quot;:&quot;click to Sign in&quot;,&quot;label&quot;:&quot;ref_page:Marketing;ref_cta:Sign in;ref_loc:Header&quot;}" > Sign in </a> </div> </div> <div class="HeaderMenu js-header-menu height-fit position-lg-relative d-lg-flex flex-column flex-auto top-0"> <div class="HeaderMenu-wrapper d-flex flex-column flex-self-start flex-lg-row flex-auto rounded rounded-lg-0"> <nav class="HeaderMenu-nav" aria-label="Global"> <ul class="d-lg-flex list-style-none"> <li class="HeaderMenu-item position-relative flex-wrap flex-justify-between flex-items-center d-block d-lg-flex flex-lg-nowrap flex-lg-items-center js-details-container js-header-menu-item"> <button type="button" class="HeaderMenu-link border-0 width-full width-lg-auto px-0 px-lg-2 py-lg-2 no-wrap d-flex flex-items-center flex-justify-between js-details-target" aria-expanded="false"> Product <svg opacity="0.5" aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-chevron-down HeaderMenu-icon ml-1"> <path d="M12.78 5.22a.749.749 0 0 1 0 1.06l-4.25 4.25a.749.749 0 0 1-1.06 0L3.22 6.28a.749.749 0 1 1 1.06-1.06L8 8.939l3.72-3.719a.749.749 0 0 1 1.06 0Z"></path> </svg> </button> <div class="HeaderMenu-dropdown dropdown-menu rounded m-0 p-0 pt-2 pt-lg-4 position-relative position-lg-absolute left-0 left-lg-n3 pb-2 pb-lg-4 d-lg-flex flex-wrap dropdown-menu-wide"> <div class="HeaderMenu-column px-lg-4 border-lg-right mb-4 mb-lg-0 pr-lg-7"> <div class="border-bottom pb-3 pb-lg-0 border-lg-bottom-0"> <ul class="list-style-none f5" > <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;github_copilot&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;github_copilot_link_product_navbar&quot;}" href="https://github.com/features/copilot"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-copilot color-fg-subtle mr-3"> <path d="M23.922 16.992c-.861 1.495-5.859 5.023-11.922 5.023-6.063 0-11.061-3.528-11.922-5.023A.641.641 0 0 1 0 16.736v-2.869a.841.841 0 0 1 .053-.22c.372-.935 1.347-2.292 2.605-2.656.167-.429.414-1.055.644-1.517a10.195 10.195 0 0 1-.052-1.086c0-1.331.282-2.499 1.132-3.368.397-.406.89-.717 1.474-.952 1.399-1.136 3.392-2.093 6.122-2.093 2.731 0 4.767.957 6.166 2.093.584.235 1.077.546 1.474.952.85.869 1.132 2.037 1.132 3.368 0 .368-.014.733-.052 1.086.23.462.477 1.088.644 1.517 1.258.364 2.233 1.721 2.605 2.656a.832.832 0 0 1 .053.22v2.869a.641.641 0 0 1-.078.256ZM12.172 11h-.344a4.323 4.323 0 0 1-.355.508C10.703 12.455 9.555 13 7.965 13c-1.725 0-2.989-.359-3.782-1.259a2.005 2.005 0 0 1-.085-.104L4 11.741v6.585c1.435.779 4.514 2.179 8 2.179 3.486 0 6.565-1.4 8-2.179v-6.585l-.098-.104s-.033.045-.085.104c-.793.9-2.057 1.259-3.782 1.259-1.59 0-2.738-.545-3.508-1.492a4.323 4.323 0 0 1-.355-.508h-.016.016Zm.641-2.935c.136 1.057.403 1.913.878 2.497.442.544 1.134.938 2.344.938 1.573 0 2.292-.337 2.657-.751.384-.435.558-1.15.558-2.361 0-1.14-.243-1.847-.705-2.319-.477-.488-1.319-.862-2.824-1.025-1.487-.161-2.192.138-2.533.529-.269.307-.437.808-.438 1.578v.021c0 .265.021.562.063.893Zm-1.626 0c.042-.331.063-.628.063-.894v-.02c-.001-.77-.169-1.271-.438-1.578-.341-.391-1.046-.69-2.533-.529-1.505.163-2.347.537-2.824 1.025-.462.472-.705 1.179-.705 2.319 0 1.211.175 1.926.558 2.361.365.414 1.084.751 2.657.751 1.21 0 1.902-.394 2.344-.938.475-.584.742-1.44.878-2.497Z"></path><path d="M14.5 14.25a1 1 0 0 1 1 1v2a1 1 0 0 1-2 0v-2a1 1 0 0 1 1-1Zm-5 0a1 1 0 0 1 1 1v2a1 1 0 0 1-2 0v-2a1 1 0 0 1 1-1Z"></path> </svg> <div> <div class="color-fg-default h4">GitHub Copilot</div> Write better code with AI </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;security&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;security_link_product_navbar&quot;}" href="https://github.com/features/security"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-shield-check color-fg-subtle mr-3"> <path d="M16.53 9.78a.75.75 0 0 0-1.06-1.06L11 13.19l-1.97-1.97a.75.75 0 0 0-1.06 1.06l2.5 2.5a.75.75 0 0 0 1.06 0l5-5Z"></path><path d="m12.54.637 8.25 2.675A1.75 1.75 0 0 1 22 4.976V10c0 6.19-3.771 10.704-9.401 12.83a1.704 1.704 0 0 1-1.198 0C5.77 20.705 2 16.19 2 10V4.976c0-.758.489-1.43 1.21-1.664L11.46.637a1.748 1.748 0 0 1 1.08 0Zm-.617 1.426-8.25 2.676a.249.249 0 0 0-.173.237V10c0 5.46 3.28 9.483 8.43 11.426a.199.199 0 0 0 .14 0C17.22 19.483 20.5 15.461 20.5 10V4.976a.25.25 0 0 0-.173-.237l-8.25-2.676a.253.253 0 0 0-.154 0Z"></path> </svg> <div> <div class="color-fg-default h4">Security</div> Find and fix vulnerabilities </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;actions&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;actions_link_product_navbar&quot;}" href="https://github.com/features/actions"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-workflow color-fg-subtle mr-3"> <path d="M1 3a2 2 0 0 1 2-2h6.5a2 2 0 0 1 2 2v6.5a2 2 0 0 1-2 2H7v4.063C7 16.355 7.644 17 8.438 17H12.5v-2.5a2 2 0 0 1 2-2H21a2 2 0 0 1 2 2V21a2 2 0 0 1-2 2h-6.5a2 2 0 0 1-2-2v-2.5H8.437A2.939 2.939 0 0 1 5.5 15.562V11.5H3a2 2 0 0 1-2-2Zm2-.5a.5.5 0 0 0-.5.5v6.5a.5.5 0 0 0 .5.5h6.5a.5.5 0 0 0 .5-.5V3a.5.5 0 0 0-.5-.5ZM14.5 14a.5.5 0 0 0-.5.5V21a.5.5 0 0 0 .5.5H21a.5.5 0 0 0 .5-.5v-6.5a.5.5 0 0 0-.5-.5Z"></path> </svg> <div> <div class="color-fg-default h4">Actions</div> Automate any workflow </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;codespaces&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;codespaces_link_product_navbar&quot;}" href="https://github.com/features/codespaces"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-codespaces color-fg-subtle mr-3"> <path d="M3.5 3.75C3.5 2.784 4.284 2 5.25 2h13.5c.966 0 1.75.784 1.75 1.75v7.5A1.75 1.75 0 0 1 18.75 13H5.25a1.75 1.75 0 0 1-1.75-1.75Zm-2 12c0-.966.784-1.75 1.75-1.75h17.5c.966 0 1.75.784 1.75 1.75v4a1.75 1.75 0 0 1-1.75 1.75H3.25a1.75 1.75 0 0 1-1.75-1.75ZM5.25 3.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h13.5a.25.25 0 0 0 .25-.25v-7.5a.25.25 0 0 0-.25-.25Zm-2 12a.25.25 0 0 0-.25.25v4c0 .138.112.25.25.25h17.5a.25.25 0 0 0 .25-.25v-4a.25.25 0 0 0-.25-.25Z"></path><path d="M10 17.75a.75.75 0 0 1 .75-.75h6.5a.75.75 0 0 1 0 1.5h-6.5a.75.75 0 0 1-.75-.75Zm-4 0a.75.75 0 0 1 .75-.75h.5a.75.75 0 0 1 0 1.5h-.5a.75.75 0 0 1-.75-.75Z"></path> </svg> <div> <div class="color-fg-default h4">Codespaces</div> Instant dev environments </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;issues&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;issues_link_product_navbar&quot;}" href="https://github.com/features/issues"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-issue-opened color-fg-subtle mr-3"> <path d="M12 1c6.075 0 11 4.925 11 11s-4.925 11-11 11S1 18.075 1 12 5.925 1 12 1ZM2.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.5 9.5 9.5 0 0 0 2.5 12Zm9.5 2a2 2 0 1 1-.001-3.999A2 2 0 0 1 12 14Z"></path> </svg> <div> <div class="color-fg-default h4">Issues</div> Plan and track work </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;code_review&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;code_review_link_product_navbar&quot;}" href="https://github.com/features/code-review"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-code-review color-fg-subtle mr-3"> <path d="M10.3 6.74a.75.75 0 0 1-.04 1.06l-2.908 2.7 2.908 2.7a.75.75 0 1 1-1.02 1.1l-3.5-3.25a.75.75 0 0 1 0-1.1l3.5-3.25a.75.75 0 0 1 1.06.04Zm3.44 1.06a.75.75 0 1 1 1.02-1.1l3.5 3.25a.75.75 0 0 1 0 1.1l-3.5 3.25a.75.75 0 1 1-1.02-1.1l2.908-2.7-2.908-2.7Z"></path><path d="M1.5 4.25c0-.966.784-1.75 1.75-1.75h17.5c.966 0 1.75.784 1.75 1.75v12.5a1.75 1.75 0 0 1-1.75 1.75h-9.69l-3.573 3.573A1.458 1.458 0 0 1 5 21.043V18.5H3.25a1.75 1.75 0 0 1-1.75-1.75ZM3.25 4a.25.25 0 0 0-.25.25v12.5c0 .138.112.25.25.25h2.5a.75.75 0 0 1 .75.75v3.19l3.72-3.72a.749.749 0 0 1 .53-.22h10a.25.25 0 0 0 .25-.25V4.25a.25.25 0 0 0-.25-.25Z"></path> </svg> <div> <div class="color-fg-default h4">Code Review</div> Manage code changes </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;discussions&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;discussions_link_product_navbar&quot;}" href="https://github.com/features/discussions"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-comment-discussion color-fg-subtle mr-3"> <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><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"></path> </svg> <div> <div class="color-fg-default h4">Discussions</div> Collaborate outside of code </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;code_search&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;code_search_link_product_navbar&quot;}" href="https://github.com/features/code-search"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-code-square color-fg-subtle mr-3"> <path d="M10.3 8.24a.75.75 0 0 1-.04 1.06L7.352 12l2.908 2.7a.75.75 0 1 1-1.02 1.1l-3.5-3.25a.75.75 0 0 1 0-1.1l3.5-3.25a.75.75 0 0 1 1.06.04Zm3.44 1.06a.75.75 0 1 1 1.02-1.1l3.5 3.25a.75.75 0 0 1 0 1.1l-3.5 3.25a.75.75 0 1 1-1.02-1.1l2.908-2.7-2.908-2.7Z"></path><path d="M2 3.75C2 2.784 2.784 2 3.75 2h16.5c.966 0 1.75.784 1.75 1.75v16.5A1.75 1.75 0 0 1 20.25 22H3.75A1.75 1.75 0 0 1 2 20.25Zm1.75-.25a.25.25 0 0 0-.25.25v16.5c0 .138.112.25.25.25h16.5a.25.25 0 0 0 .25-.25V3.75a.25.25 0 0 0-.25-.25Z"></path> </svg> <div> <div class="color-fg-default h4">Code Search</div> Find more, search less </div> </a></li> </ul> </div> </div> <div class="HeaderMenu-column px-lg-4"> <div class="border-bottom pb-3 pb-lg-0 border-lg-bottom-0 border-bottom-0"> <span class="d-block h4 color-fg-default my-1" id="product-explore-heading">Explore</span> <ul class="list-style-none f5" aria-labelledby="product-explore-heading"> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;all_features&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;all_features_link_product_navbar&quot;}" href="https://github.com/features"> All features </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary Link--external" target="_blank" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;documentation&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;documentation_link_product_navbar&quot;}" href="https://docs.github.com"> Documentation <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-link-external HeaderMenu-external-icon color-fg-subtle"> <path d="M3.75 2h3.5a.75.75 0 0 1 0 1.5h-3.5a.25.25 0 0 0-.25.25v8.5c0 .138.112.25.25.25h8.5a.25.25 0 0 0 .25-.25v-3.5a.75.75 0 0 1 1.5 0v3.5A1.75 1.75 0 0 1 12.25 14h-8.5A1.75 1.75 0 0 1 2 12.25v-8.5C2 2.784 2.784 2 3.75 2Zm6.854-1h4.146a.25.25 0 0 1 .25.25v4.146a.25.25 0 0 1-.427.177L13.03 4.03 9.28 7.78a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042l3.75-3.75-1.543-1.543A.25.25 0 0 1 10.604 1Z"></path> </svg> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary Link--external" target="_blank" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;github_skills&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;github_skills_link_product_navbar&quot;}" href="https://skills.github.com"> GitHub Skills <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-link-external HeaderMenu-external-icon color-fg-subtle"> <path d="M3.75 2h3.5a.75.75 0 0 1 0 1.5h-3.5a.25.25 0 0 0-.25.25v8.5c0 .138.112.25.25.25h8.5a.25.25 0 0 0 .25-.25v-3.5a.75.75 0 0 1 1.5 0v3.5A1.75 1.75 0 0 1 12.25 14h-8.5A1.75 1.75 0 0 1 2 12.25v-8.5C2 2.784 2.784 2 3.75 2Zm6.854-1h4.146a.25.25 0 0 1 .25.25v4.146a.25.25 0 0 1-.427.177L13.03 4.03 9.28 7.78a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042l3.75-3.75-1.543-1.543A.25.25 0 0 1 10.604 1Z"></path> </svg> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary Link--external" target="_blank" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;blog&quot;,&quot;context&quot;:&quot;product&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;blog_link_product_navbar&quot;}" href="https://github.blog"> Blog <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-link-external HeaderMenu-external-icon color-fg-subtle"> <path d="M3.75 2h3.5a.75.75 0 0 1 0 1.5h-3.5a.25.25 0 0 0-.25.25v8.5c0 .138.112.25.25.25h8.5a.25.25 0 0 0 .25-.25v-3.5a.75.75 0 0 1 1.5 0v3.5A1.75 1.75 0 0 1 12.25 14h-8.5A1.75 1.75 0 0 1 2 12.25v-8.5C2 2.784 2.784 2 3.75 2Zm6.854-1h4.146a.25.25 0 0 1 .25.25v4.146a.25.25 0 0 1-.427.177L13.03 4.03 9.28 7.78a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042l3.75-3.75-1.543-1.543A.25.25 0 0 1 10.604 1Z"></path> </svg> </a></li> </ul> </div> </div> </div> </li> <li class="HeaderMenu-item position-relative flex-wrap flex-justify-between flex-items-center d-block d-lg-flex flex-lg-nowrap flex-lg-items-center js-details-container js-header-menu-item"> <button type="button" class="HeaderMenu-link border-0 width-full width-lg-auto px-0 px-lg-2 py-lg-2 no-wrap d-flex flex-items-center flex-justify-between js-details-target" aria-expanded="false"> Solutions <svg opacity="0.5" aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-chevron-down HeaderMenu-icon ml-1"> <path d="M12.78 5.22a.749.749 0 0 1 0 1.06l-4.25 4.25a.749.749 0 0 1-1.06 0L3.22 6.28a.749.749 0 1 1 1.06-1.06L8 8.939l3.72-3.719a.749.749 0 0 1 1.06 0Z"></path> </svg> </button> <div class="HeaderMenu-dropdown dropdown-menu rounded m-0 p-0 pt-2 pt-lg-4 position-relative position-lg-absolute left-0 left-lg-n3 d-lg-flex flex-wrap dropdown-menu-wide"> <div class="HeaderMenu-column px-lg-4 border-lg-right mb-4 mb-lg-0 pr-lg-7"> <div class="border-bottom pb-3 pb-lg-0 border-lg-bottom-0 pb-lg-3 mb-3 mb-lg-0"> <span class="d-block h4 color-fg-default my-1" id="solutions-by-company-size-heading">By company size</span> <ul class="list-style-none f5" aria-labelledby="solutions-by-company-size-heading"> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;enterprises&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;enterprises_link_solutions_navbar&quot;}" href="https://github.com/enterprise"> Enterprises </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;small_and_medium_teams&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;small_and_medium_teams_link_solutions_navbar&quot;}" href="https://github.com/team"> Small and medium teams </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;startups&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;startups_link_solutions_navbar&quot;}" href="https://github.com/enterprise/startups"> Startups </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;nonprofits&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;nonprofits_link_solutions_navbar&quot;}" href="/solutions/industry/nonprofits"> Nonprofits </a></li> </ul> </div> <div class="border-bottom pb-3 pb-lg-0 border-lg-bottom-0"> <span class="d-block h4 color-fg-default my-1" id="solutions-by-use-case-heading">By use case</span> <ul class="list-style-none f5" aria-labelledby="solutions-by-use-case-heading"> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;devsecops&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;devsecops_link_solutions_navbar&quot;}" href="/solutions/use-case/devsecops"> DevSecOps </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;devops&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;devops_link_solutions_navbar&quot;}" href="/solutions/use-case/devops"> DevOps </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;ci_cd&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;ci_cd_link_solutions_navbar&quot;}" href="/solutions/use-case/ci-cd"> CI/CD </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;view_all_use_cases&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;view_all_use_cases_link_solutions_navbar&quot;}" href="/solutions/use-case"> View all use cases </a></li> </ul> </div> </div> <div class="HeaderMenu-column px-lg-4"> <div class="border-bottom pb-3 pb-lg-0 border-lg-bottom-0"> <span class="d-block h4 color-fg-default my-1" id="solutions-by-industry-heading">By industry</span> <ul class="list-style-none f5" aria-labelledby="solutions-by-industry-heading"> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;healthcare&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;healthcare_link_solutions_navbar&quot;}" href="/solutions/industry/healthcare"> Healthcare </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;financial_services&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;financial_services_link_solutions_navbar&quot;}" href="/solutions/industry/financial-services"> Financial services </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;manufacturing&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;manufacturing_link_solutions_navbar&quot;}" href="/solutions/industry/manufacturing"> Manufacturing </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;government&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;government_link_solutions_navbar&quot;}" href="/solutions/industry/government"> Government </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;view_all_industries&quot;,&quot;context&quot;:&quot;solutions&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;view_all_industries_link_solutions_navbar&quot;}" href="/solutions/industry"> View all industries </a></li> </ul> </div> </div> <div class="HeaderMenu-trailing-link rounded-bottom-2 flex-shrink-0 mt-lg-4 px-lg-4 py-4 py-lg-3 f5 text-semibold"> <a href="/solutions"> View all solutions <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-chevron-right HeaderMenu-trailing-link-icon"> <path d="M6.22 3.22a.75.75 0 0 1 1.06 0l4.25 4.25a.75.75 0 0 1 0 1.06l-4.25 4.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L9.94 8 6.22 4.28a.75.75 0 0 1 0-1.06Z"></path> </svg> </a> </div> </div> </li> <li class="HeaderMenu-item position-relative flex-wrap flex-justify-between flex-items-center d-block d-lg-flex flex-lg-nowrap flex-lg-items-center js-details-container js-header-menu-item"> <button type="button" class="HeaderMenu-link border-0 width-full width-lg-auto px-0 px-lg-2 py-lg-2 no-wrap d-flex flex-items-center flex-justify-between js-details-target" aria-expanded="false"> Resources <svg opacity="0.5" aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-chevron-down HeaderMenu-icon ml-1"> <path d="M12.78 5.22a.749.749 0 0 1 0 1.06l-4.25 4.25a.749.749 0 0 1-1.06 0L3.22 6.28a.749.749 0 1 1 1.06-1.06L8 8.939l3.72-3.719a.749.749 0 0 1 1.06 0Z"></path> </svg> </button> <div class="HeaderMenu-dropdown dropdown-menu rounded m-0 p-0 pt-2 pt-lg-4 position-relative position-lg-absolute left-0 left-lg-n3 pb-2 pb-lg-4 d-lg-flex flex-wrap dropdown-menu-wide"> <div class="HeaderMenu-column px-lg-4 border-lg-right mb-4 mb-lg-0 pr-lg-7"> <div class="border-bottom pb-3 pb-lg-0 border-lg-bottom-0"> <span class="d-block h4 color-fg-default my-1" id="resources-topics-heading">Topics</span> <ul class="list-style-none f5" aria-labelledby="resources-topics-heading"> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;ai&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;ai_link_resources_navbar&quot;}" href="/resources/articles/ai"> AI </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;devops&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;devops_link_resources_navbar&quot;}" href="/resources/articles/devops"> DevOps </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;security&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;security_link_resources_navbar&quot;}" href="/resources/articles/security"> Security </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;software_development&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;software_development_link_resources_navbar&quot;}" href="/resources/articles/software-development"> Software Development </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;view_all&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;view_all_link_resources_navbar&quot;}" href="/resources/articles"> View all </a></li> </ul> </div> </div> <div class="HeaderMenu-column px-lg-4"> <div class="border-bottom pb-3 pb-lg-0 border-lg-bottom-0 border-bottom-0"> <span class="d-block h4 color-fg-default my-1" id="resources-explore-heading">Explore</span> <ul class="list-style-none f5" aria-labelledby="resources-explore-heading"> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary Link--external" target="_blank" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;learning_pathways&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;learning_pathways_link_resources_navbar&quot;}" href="https://resources.github.com/learn/pathways"> Learning Pathways <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-link-external HeaderMenu-external-icon color-fg-subtle"> <path d="M3.75 2h3.5a.75.75 0 0 1 0 1.5h-3.5a.25.25 0 0 0-.25.25v8.5c0 .138.112.25.25.25h8.5a.25.25 0 0 0 .25-.25v-3.5a.75.75 0 0 1 1.5 0v3.5A1.75 1.75 0 0 1 12.25 14h-8.5A1.75 1.75 0 0 1 2 12.25v-8.5C2 2.784 2.784 2 3.75 2Zm6.854-1h4.146a.25.25 0 0 1 .25.25v4.146a.25.25 0 0 1-.427.177L13.03 4.03 9.28 7.78a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042l3.75-3.75-1.543-1.543A.25.25 0 0 1 10.604 1Z"></path> </svg> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary Link--external" target="_blank" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;events_amp_webinars&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;events_amp_webinars_link_resources_navbar&quot;}" href="https://resources.github.com"> Events &amp; Webinars <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-link-external HeaderMenu-external-icon color-fg-subtle"> <path d="M3.75 2h3.5a.75.75 0 0 1 0 1.5h-3.5a.25.25 0 0 0-.25.25v8.5c0 .138.112.25.25.25h8.5a.25.25 0 0 0 .25-.25v-3.5a.75.75 0 0 1 1.5 0v3.5A1.75 1.75 0 0 1 12.25 14h-8.5A1.75 1.75 0 0 1 2 12.25v-8.5C2 2.784 2.784 2 3.75 2Zm6.854-1h4.146a.25.25 0 0 1 .25.25v4.146a.25.25 0 0 1-.427.177L13.03 4.03 9.28 7.78a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042l3.75-3.75-1.543-1.543A.25.25 0 0 1 10.604 1Z"></path> </svg> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;ebooks_amp_whitepapers&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;ebooks_amp_whitepapers_link_resources_navbar&quot;}" href="https://github.com/resources/whitepapers"> Ebooks &amp; Whitepapers </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;customer_stories&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;customer_stories_link_resources_navbar&quot;}" href="https://github.com/customer-stories"> Customer Stories </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary Link--external" target="_blank" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;partners&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;partners_link_resources_navbar&quot;}" href="https://partner.github.com"> Partners <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-link-external HeaderMenu-external-icon color-fg-subtle"> <path d="M3.75 2h3.5a.75.75 0 0 1 0 1.5h-3.5a.25.25 0 0 0-.25.25v8.5c0 .138.112.25.25.25h8.5a.25.25 0 0 0 .25-.25v-3.5a.75.75 0 0 1 1.5 0v3.5A1.75 1.75 0 0 1 12.25 14h-8.5A1.75 1.75 0 0 1 2 12.25v-8.5C2 2.784 2.784 2 3.75 2Zm6.854-1h4.146a.25.25 0 0 1 .25.25v4.146a.25.25 0 0 1-.427.177L13.03 4.03 9.28 7.78a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042l3.75-3.75-1.543-1.543A.25.25 0 0 1 10.604 1Z"></path> </svg> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;executive_insights&quot;,&quot;context&quot;:&quot;resources&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;executive_insights_link_resources_navbar&quot;}" href="https://github.com/solutions/executive-insights"> Executive Insights </a></li> </ul> </div> </div> </div> </li> <li class="HeaderMenu-item position-relative flex-wrap flex-justify-between flex-items-center d-block d-lg-flex flex-lg-nowrap flex-lg-items-center js-details-container js-header-menu-item"> <button type="button" class="HeaderMenu-link border-0 width-full width-lg-auto px-0 px-lg-2 py-lg-2 no-wrap d-flex flex-items-center flex-justify-between js-details-target" aria-expanded="false"> Open Source <svg opacity="0.5" aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-chevron-down HeaderMenu-icon ml-1"> <path d="M12.78 5.22a.749.749 0 0 1 0 1.06l-4.25 4.25a.749.749 0 0 1-1.06 0L3.22 6.28a.749.749 0 1 1 1.06-1.06L8 8.939l3.72-3.719a.749.749 0 0 1 1.06 0Z"></path> </svg> </button> <div class="HeaderMenu-dropdown dropdown-menu rounded m-0 p-0 pt-2 pt-lg-4 position-relative position-lg-absolute left-0 left-lg-n3 pb-2 pb-lg-4 px-lg-4"> <div class="HeaderMenu-column"> <div class="border-bottom pb-3 pb-lg-0 pb-lg-3 mb-3 mb-lg-0 mb-lg-3"> <ul class="list-style-none f5" > <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;github_sponsors&quot;,&quot;context&quot;:&quot;open_source&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;github_sponsors_link_open_source_navbar&quot;}" href="/sponsors"> <div> <div class="color-fg-default h4">GitHub Sponsors</div> Fund open source developers </div> </a></li> </ul> </div> <div class="border-bottom pb-3 pb-lg-0 pb-lg-3 mb-3 mb-lg-0 mb-lg-3"> <ul class="list-style-none f5" > <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;the_readme_project&quot;,&quot;context&quot;:&quot;open_source&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;the_readme_project_link_open_source_navbar&quot;}" href="https://github.com/readme"> <div> <div class="color-fg-default h4">The ReadME Project</div> GitHub community articles </div> </a></li> </ul> </div> <div class="border-bottom pb-3 pb-lg-0 border-bottom-0"> <span class="d-block h4 color-fg-default my-1" id="open-source-repositories-heading">Repositories</span> <ul class="list-style-none f5" aria-labelledby="open-source-repositories-heading"> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;topics&quot;,&quot;context&quot;:&quot;open_source&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;topics_link_open_source_navbar&quot;}" href="https://github.com/topics"> Topics </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;trending&quot;,&quot;context&quot;:&quot;open_source&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;trending_link_open_source_navbar&quot;}" href="https://github.com/trending"> Trending </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;collections&quot;,&quot;context&quot;:&quot;open_source&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;collections_link_open_source_navbar&quot;}" href="https://github.com/collections"> Collections </a></li> </ul> </div> </div> </div> </li> <li class="HeaderMenu-item position-relative flex-wrap flex-justify-between flex-items-center d-block d-lg-flex flex-lg-nowrap flex-lg-items-center js-details-container js-header-menu-item"> <button type="button" class="HeaderMenu-link border-0 width-full width-lg-auto px-0 px-lg-2 py-lg-2 no-wrap d-flex flex-items-center flex-justify-between js-details-target" aria-expanded="false"> Enterprise <svg opacity="0.5" aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-chevron-down HeaderMenu-icon ml-1"> <path d="M12.78 5.22a.749.749 0 0 1 0 1.06l-4.25 4.25a.749.749 0 0 1-1.06 0L3.22 6.28a.749.749 0 1 1 1.06-1.06L8 8.939l3.72-3.719a.749.749 0 0 1 1.06 0Z"></path> </svg> </button> <div class="HeaderMenu-dropdown dropdown-menu rounded m-0 p-0 pt-2 pt-lg-4 position-relative position-lg-absolute left-0 left-lg-n3 pb-2 pb-lg-4 px-lg-4"> <div class="HeaderMenu-column"> <div class="border-bottom pb-3 pb-lg-0 pb-lg-3 mb-3 mb-lg-0 mb-lg-3"> <ul class="list-style-none f5" > <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;enterprise_platform&quot;,&quot;context&quot;:&quot;enterprise&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;enterprise_platform_link_enterprise_navbar&quot;}" href="/enterprise"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-stack color-fg-subtle mr-3"> <path d="M11.063 1.456a1.749 1.749 0 0 1 1.874 0l8.383 5.316a1.751 1.751 0 0 1 0 2.956l-8.383 5.316a1.749 1.749 0 0 1-1.874 0L2.68 9.728a1.751 1.751 0 0 1 0-2.956Zm1.071 1.267a.25.25 0 0 0-.268 0L3.483 8.039a.25.25 0 0 0 0 .422l8.383 5.316a.25.25 0 0 0 .268 0l8.383-5.316a.25.25 0 0 0 0-.422Z"></path><path d="M1.867 12.324a.75.75 0 0 1 1.035-.232l8.964 5.685a.25.25 0 0 0 .268 0l8.964-5.685a.75.75 0 0 1 .804 1.267l-8.965 5.685a1.749 1.749 0 0 1-1.874 0l-8.965-5.685a.75.75 0 0 1-.231-1.035Z"></path><path d="M1.867 16.324a.75.75 0 0 1 1.035-.232l8.964 5.685a.25.25 0 0 0 .268 0l8.964-5.685a.75.75 0 0 1 .804 1.267l-8.965 5.685a1.749 1.749 0 0 1-1.874 0l-8.965-5.685a.75.75 0 0 1-.231-1.035Z"></path> </svg> <div> <div class="color-fg-default h4">Enterprise platform</div> AI-powered developer platform </div> </a></li> </ul> </div> <div class="border-bottom pb-3 pb-lg-0 border-bottom-0"> <span class="d-block h4 color-fg-default my-1" id="enterprise-available-add-ons-heading">Available add-ons</span> <ul class="list-style-none f5" aria-labelledby="enterprise-available-add-ons-heading"> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;advanced_security&quot;,&quot;context&quot;:&quot;enterprise&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;advanced_security_link_enterprise_navbar&quot;}" href="https://github.com/enterprise/advanced-security"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-shield-check color-fg-subtle mr-3"> <path d="M16.53 9.78a.75.75 0 0 0-1.06-1.06L11 13.19l-1.97-1.97a.75.75 0 0 0-1.06 1.06l2.5 2.5a.75.75 0 0 0 1.06 0l5-5Z"></path><path d="m12.54.637 8.25 2.675A1.75 1.75 0 0 1 22 4.976V10c0 6.19-3.771 10.704-9.401 12.83a1.704 1.704 0 0 1-1.198 0C5.77 20.705 2 16.19 2 10V4.976c0-.758.489-1.43 1.21-1.664L11.46.637a1.748 1.748 0 0 1 1.08 0Zm-.617 1.426-8.25 2.676a.249.249 0 0 0-.173.237V10c0 5.46 3.28 9.483 8.43 11.426a.199.199 0 0 0 .14 0C17.22 19.483 20.5 15.461 20.5 10V4.976a.25.25 0 0 0-.173-.237l-8.25-2.676a.253.253 0 0 0-.154 0Z"></path> </svg> <div> <div class="color-fg-default h4">Advanced Security</div> Enterprise-grade security features </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description pb-lg-3" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;copilot_for_business&quot;,&quot;context&quot;:&quot;enterprise&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;copilot_for_business_link_enterprise_navbar&quot;}" href="/features/copilot/copilot-business"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-copilot color-fg-subtle mr-3"> <path d="M23.922 16.992c-.861 1.495-5.859 5.023-11.922 5.023-6.063 0-11.061-3.528-11.922-5.023A.641.641 0 0 1 0 16.736v-2.869a.841.841 0 0 1 .053-.22c.372-.935 1.347-2.292 2.605-2.656.167-.429.414-1.055.644-1.517a10.195 10.195 0 0 1-.052-1.086c0-1.331.282-2.499 1.132-3.368.397-.406.89-.717 1.474-.952 1.399-1.136 3.392-2.093 6.122-2.093 2.731 0 4.767.957 6.166 2.093.584.235 1.077.546 1.474.952.85.869 1.132 2.037 1.132 3.368 0 .368-.014.733-.052 1.086.23.462.477 1.088.644 1.517 1.258.364 2.233 1.721 2.605 2.656a.832.832 0 0 1 .053.22v2.869a.641.641 0 0 1-.078.256ZM12.172 11h-.344a4.323 4.323 0 0 1-.355.508C10.703 12.455 9.555 13 7.965 13c-1.725 0-2.989-.359-3.782-1.259a2.005 2.005 0 0 1-.085-.104L4 11.741v6.585c1.435.779 4.514 2.179 8 2.179 3.486 0 6.565-1.4 8-2.179v-6.585l-.098-.104s-.033.045-.085.104c-.793.9-2.057 1.259-3.782 1.259-1.59 0-2.738-.545-3.508-1.492a4.323 4.323 0 0 1-.355-.508h-.016.016Zm.641-2.935c.136 1.057.403 1.913.878 2.497.442.544 1.134.938 2.344.938 1.573 0 2.292-.337 2.657-.751.384-.435.558-1.15.558-2.361 0-1.14-.243-1.847-.705-2.319-.477-.488-1.319-.862-2.824-1.025-1.487-.161-2.192.138-2.533.529-.269.307-.437.808-.438 1.578v.021c0 .265.021.562.063.893Zm-1.626 0c.042-.331.063-.628.063-.894v-.02c-.001-.77-.169-1.271-.438-1.578-.341-.391-1.046-.69-2.533-.529-1.505.163-2.347.537-2.824 1.025-.462.472-.705 1.179-.705 2.319 0 1.211.175 1.926.558 2.361.365.414 1.084.751 2.657.751 1.21 0 1.902-.394 2.344-.938.475-.584.742-1.44.878-2.497Z"></path><path d="M14.5 14.25a1 1 0 0 1 1 1v2a1 1 0 0 1-2 0v-2a1 1 0 0 1 1-1Zm-5 0a1 1 0 0 1 1 1v2a1 1 0 0 1-2 0v-2a1 1 0 0 1 1-1Z"></path> </svg> <div> <div class="color-fg-default h4">Copilot for business</div> Enterprise-grade AI features </div> </a></li> <li> <a class="HeaderMenu-dropdown-link d-block no-underline position-relative py-2 Link--secondary d-flex flex-items-center Link--has-description" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;premium_support&quot;,&quot;context&quot;:&quot;enterprise&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;premium_support_link_enterprise_navbar&quot;}" href="/premium-support"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-comment-discussion color-fg-subtle mr-3"> <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><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"></path> </svg> <div> <div class="color-fg-default h4">Premium Support</div> Enterprise-grade 24/7 support </div> </a></li> </ul> </div> </div> </div> </li> <li class="HeaderMenu-item position-relative flex-wrap flex-justify-between flex-items-center d-block d-lg-flex flex-lg-nowrap flex-lg-items-center js-details-container js-header-menu-item"> <a class="HeaderMenu-link no-underline px-0 px-lg-2 py-3 py-lg-2 d-block d-lg-inline-block" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;pricing&quot;,&quot;context&quot;:&quot;global&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;pricing_link_global_navbar&quot;}" href="https://github.com/pricing">Pricing</a> </li> </ul> </nav> <div class="d-flex flex-column flex-lg-row width-full flex-justify-end flex-lg-items-center text-center mt-3 mt-lg-0 text-lg-left ml-lg-3"> <qbsearch-input class="search-input" data-scope="repo:python/peps" data-custom-scopes-path="/search/custom_scopes" data-delete-custom-scopes-csrf="ic1hUz_HkTBKxEXevvfDQD6Er7Pnq8OHF0f6ZXqyM-zQXW8w8OHwOyA6e_UlHKa_FtOkLPbdoepWUgCoLlliYw" data-max-custom-scopes="10" data-header-redesign-enabled="false" data-initial-value="" data-blackbird-suggestions-path="/search/suggestions" data-jump-to-suggestions-path="/_graphql/GetSuggestedNavigationDestinations" data-current-repository="python/peps" data-current-org="python" data-current-owner="" data-logged-in="false" data-copilot-chat-enabled="false" data-nl-search-enabled="false" data-retain-scroll-position="true"> <div class="search-input-container search-with-dialog position-relative d-flex flex-row flex-items-center mr-4 rounded" data-action="click:qbsearch-input#searchInputContainerClicked" > <button type="button" class="header-search-button placeholder input-button form-control d-flex flex-1 flex-self-stretch flex-items-center no-wrap width-full py-0 pl-2 pr-0 text-left border-0 box-shadow-none" data-target="qbsearch-input.inputButton" aria-label="Search or jump to…" aria-haspopup="dialog" placeholder="Search or jump to..." data-hotkey=s,/ autocapitalize="off" data-analytics-event="{&quot;location&quot;:&quot;navbar&quot;,&quot;action&quot;:&quot;searchbar&quot;,&quot;context&quot;:&quot;global&quot;,&quot;tag&quot;:&quot;input&quot;,&quot;label&quot;:&quot;searchbar_input_global_navbar&quot;}" data-action="click:qbsearch-input#handleExpand" > <div class="mr-2 color-fg-muted"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-search"> <path d="M10.68 11.74a6 6 0 0 1-7.922-8.982 6 6 0 0 1 8.982 7.922l3.04 3.04a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215ZM11.5 7a4.499 4.499 0 1 0-8.997 0A4.499 4.499 0 0 0 11.5 7Z"></path> </svg> </div> <span class="flex-1" data-target="qbsearch-input.inputButtonText">Search or jump to...</span> <div class="d-flex" data-target="qbsearch-input.hotkeyIndicator"> <svg xmlns="http://www.w3.org/2000/svg" width="22" height="20" aria-hidden="true" class="mr-1"><path fill="none" stroke="#979A9C" opacity=".4" d="M3.5.5h12c1.7 0 3 1.3 3 3v13c0 1.7-1.3 3-3 3h-12c-1.7 0-3-1.3-3-3v-13c0-1.7 1.3-3 3-3z"></path><path fill="#979A9C" d="M11.8 6L8 15.1h-.9L10.8 6h1z"></path></svg> </div> </button> <input type="hidden" name="type" class="js-site-search-type-field"> <div class="Overlay--hidden " data-modal-dialog-overlay> <modal-dialog data-action="close:qbsearch-input#handleClose cancel:qbsearch-input#handleClose" data-target="qbsearch-input.searchSuggestionsDialog" role="dialog" id="search-suggestions-dialog" aria-modal="true" aria-labelledby="search-suggestions-dialog-header" data-view-component="true" class="Overlay Overlay--width-large Overlay--height-auto"> <h1 id="search-suggestions-dialog-header" class="sr-only">Search code, repositories, users, issues, pull requests...</h1> <div class="Overlay-body Overlay-body--paddingNone"> <div data-view-component="true"> <div class="search-suggestions position-fixed width-full color-shadow-large border color-fg-default color-bg-default overflow-hidden d-flex flex-column query-builder-container" style="border-radius: 12px;" data-target="qbsearch-input.queryBuilderContainer" hidden > <!-- '"` --><!-- </textarea></xmp> --></option></form><form id="query-builder-test-form" action="" accept-charset="UTF-8" method="get"> <query-builder data-target="qbsearch-input.queryBuilder" id="query-builder-query-builder-test" data-filter-key=":" data-view-component="true" class="QueryBuilder search-query-builder"> <div class="FormControl FormControl--fullWidth"> <label id="query-builder-test-label" for="query-builder-test" class="FormControl-label sr-only"> Search </label> <div class="QueryBuilder-StyledInput width-fit " data-target="query-builder.styledInput" > <span id="query-builder-test-leadingvisual-wrap" class="FormControl-input-leadingVisualWrap QueryBuilder-leadingVisualWrap"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-search FormControl-input-leadingVisual"> <path d="M10.68 11.74a6 6 0 0 1-7.922-8.982 6 6 0 0 1 8.982 7.922l3.04 3.04a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215ZM11.5 7a4.499 4.499 0 1 0-8.997 0A4.499 4.499 0 0 0 11.5 7Z"></path> </svg> </span> <div data-target="query-builder.styledInputContainer" class="QueryBuilder-StyledInputContainer"> <div aria-hidden="true" class="QueryBuilder-StyledInputContent" data-target="query-builder.styledInputContent" ></div> <div class="QueryBuilder-InputWrapper"> <div aria-hidden="true" class="QueryBuilder-Sizer" data-target="query-builder.sizer"></div> <input id="query-builder-test" name="query-builder-test" value="" autocomplete="off" type="text" role="combobox" spellcheck="false" aria-expanded="false" aria-describedby="validation-b54de372-e273-4d9d-9633-4ef61ddbc079" data-target="query-builder.input" data-action=" input:query-builder#inputChange blur:query-builder#inputBlur keydown:query-builder#inputKeydown focus:query-builder#inputFocus " data-view-component="true" class="FormControl-input QueryBuilder-Input FormControl-medium" /> </div> </div> <span class="sr-only" id="query-builder-test-clear">Clear</span> <button role="button" id="query-builder-test-clear-button" aria-labelledby="query-builder-test-clear query-builder-test-label" data-target="query-builder.clearButton" data-action=" click:query-builder#clear focus:query-builder#clearButtonFocus blur:query-builder#clearButtonBlur " variant="small" hidden="hidden" type="button" data-view-component="true" class="Button Button--iconOnly Button--invisible Button--medium mr-1 px-2 py-0 d-flex flex-items-center rounded-1 color-fg-muted"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x-circle-fill Button-visual"> <path d="M2.343 13.657A8 8 0 1 1 13.658 2.343 8 8 0 0 1 2.343 13.657ZM6.03 4.97a.751.751 0 0 0-1.042.018.751.751 0 0 0-.018 1.042L6.94 8 4.97 9.97a.749.749 0 0 0 .326 1.275.749.749 0 0 0 .734-.215L8 9.06l1.97 1.97a.749.749 0 0 0 1.275-.326.749.749 0 0 0-.215-.734L9.06 8l1.97-1.97a.749.749 0 0 0-.326-1.275.749.749 0 0 0-.734.215L8 6.94Z"></path> </svg> </button> </div> <template id="search-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-search"> <path d="M10.68 11.74a6 6 0 0 1-7.922-8.982 6 6 0 0 1 8.982 7.922l3.04 3.04a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215ZM11.5 7a4.499 4.499 0 1 0-8.997 0A4.499 4.499 0 0 0 11.5 7Z"></path> </svg> </template> <template id="code-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-code"> <path d="m11.28 3.22 4.25 4.25a.75.75 0 0 1 0 1.06l-4.25 4.25a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734L13.94 8l-3.72-3.72a.749.749 0 0 1 .326-1.275.749.749 0 0 1 .734.215Zm-6.56 0a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042L2.06 8l3.72 3.72a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L.47 8.53a.75.75 0 0 1 0-1.06Z"></path> </svg> </template> <template id="file-code-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-file-code"> <path d="M4 1.75C4 .784 4.784 0 5.75 0h5.586c.464 0 .909.184 1.237.513l2.914 2.914c.329.328.513.773.513 1.237v8.586A1.75 1.75 0 0 1 14.25 15h-9a.75.75 0 0 1 0-1.5h9a.25.25 0 0 0 .25-.25V6h-2.75A1.75 1.75 0 0 1 10 4.25V1.5H5.75a.25.25 0 0 0-.25.25v2.5a.75.75 0 0 1-1.5 0Zm1.72 4.97a.75.75 0 0 1 1.06 0l2 2a.75.75 0 0 1 0 1.06l-2 2a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734l1.47-1.47-1.47-1.47a.75.75 0 0 1 0-1.06ZM3.28 7.78 1.81 9.25l1.47 1.47a.751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018l-2-2a.75.75 0 0 1 0-1.06l2-2a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042Zm8.22-6.218V4.25c0 .138.112.25.25.25h2.688l-.011-.013-2.914-2.914-.013-.011Z"></path> </svg> </template> <template id="history-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-history"> <path d="m.427 1.927 1.215 1.215a8.002 8.002 0 1 1-1.6 5.685.75.75 0 1 1 1.493-.154 6.5 6.5 0 1 0 1.18-4.458l1.358 1.358A.25.25 0 0 1 3.896 6H.25A.25.25 0 0 1 0 5.75V2.104a.25.25 0 0 1 .427-.177ZM7.75 4a.75.75 0 0 1 .75.75v2.992l2.028.812a.75.75 0 0 1-.557 1.392l-2.5-1A.751.751 0 0 1 7 8.25v-3.5A.75.75 0 0 1 7.75 4Z"></path> </svg> </template> <template id="repo-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-repo"> <path d="M2 2.5A2.5 2.5 0 0 1 4.5 0h8.75a.75.75 0 0 1 .75.75v12.5a.75.75 0 0 1-.75.75h-2.5a.75.75 0 0 1 0-1.5h1.75v-2h-8a1 1 0 0 0-.714 1.7.75.75 0 1 1-1.072 1.05A2.495 2.495 0 0 1 2 11.5Zm10.5-1h-8a1 1 0 0 0-1 1v6.708A2.486 2.486 0 0 1 4.5 9h8ZM5 12.25a.25.25 0 0 1 .25-.25h3.5a.25.25 0 0 1 .25.25v3.25a.25.25 0 0 1-.4.2l-1.45-1.087a.249.249 0 0 0-.3 0L5.4 15.7a.25.25 0 0 1-.4-.2Z"></path> </svg> </template> <template id="bookmark-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-bookmark"> <path d="M3 2.75C3 1.784 3.784 1 4.75 1h6.5c.966 0 1.75.784 1.75 1.75v11.5a.75.75 0 0 1-1.227.579L8 11.722l-3.773 3.107A.751.751 0 0 1 3 14.25Zm1.75-.25a.25.25 0 0 0-.25.25v9.91l3.023-2.489a.75.75 0 0 1 .954 0l3.023 2.49V2.75a.25.25 0 0 0-.25-.25Z"></path> </svg> </template> <template id="plus-circle-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-plus-circle"> <path d="M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM1.5 8a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0Zm7.25-3.25v2.5h2.5a.75.75 0 0 1 0 1.5h-2.5v2.5a.75.75 0 0 1-1.5 0v-2.5h-2.5a.75.75 0 0 1 0-1.5h2.5v-2.5a.75.75 0 0 1 1.5 0Z"></path> </svg> </template> <template id="circle-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-dot-fill"> <path d="M8 4a4 4 0 1 1 0 8 4 4 0 0 1 0-8Z"></path> </svg> </template> <template id="trash-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-trash"> <path d="M11 1.75V3h2.25a.75.75 0 0 1 0 1.5H2.75a.75.75 0 0 1 0-1.5H5V1.75C5 .784 5.784 0 6.75 0h2.5C10.216 0 11 .784 11 1.75ZM4.496 6.675l.66 6.6a.25.25 0 0 0 .249.225h5.19a.25.25 0 0 0 .249-.225l.66-6.6a.75.75 0 0 1 1.492.149l-.66 6.6A1.748 1.748 0 0 1 10.595 15h-5.19a1.75 1.75 0 0 1-1.741-1.575l-.66-6.6a.75.75 0 1 1 1.492-.15ZM6.5 1.75V3h3V1.75a.25.25 0 0 0-.25-.25h-2.5a.25.25 0 0 0-.25.25Z"></path> </svg> </template> <template id="team-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-people"> <path d="M2 5.5a3.5 3.5 0 1 1 5.898 2.549 5.508 5.508 0 0 1 3.034 4.084.75.75 0 1 1-1.482.235 4 4 0 0 0-7.9 0 .75.75 0 0 1-1.482-.236A5.507 5.507 0 0 1 3.102 8.05 3.493 3.493 0 0 1 2 5.5ZM11 4a3.001 3.001 0 0 1 2.22 5.018 5.01 5.01 0 0 1 2.56 3.012.749.749 0 0 1-.885.954.752.752 0 0 1-.549-.514 3.507 3.507 0 0 0-2.522-2.372.75.75 0 0 1-.574-.73v-.352a.75.75 0 0 1 .416-.672A1.5 1.5 0 0 0 11 5.5.75.75 0 0 1 11 4Zm-5.5-.5a2 2 0 1 0-.001 3.999A2 2 0 0 0 5.5 3.5Z"></path> </svg> </template> <template id="project-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-project"> <path d="M1.75 0h12.5C15.216 0 16 .784 16 1.75v12.5A1.75 1.75 0 0 1 14.25 16H1.75A1.75 1.75 0 0 1 0 14.25V1.75C0 .784.784 0 1.75 0ZM1.5 1.75v12.5c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25V1.75a.25.25 0 0 0-.25-.25H1.75a.25.25 0 0 0-.25.25ZM11.75 3a.75.75 0 0 1 .75.75v7.5a.75.75 0 0 1-1.5 0v-7.5a.75.75 0 0 1 .75-.75Zm-8.25.75a.75.75 0 0 1 1.5 0v5.5a.75.75 0 0 1-1.5 0ZM8 3a.75.75 0 0 1 .75.75v3.5a.75.75 0 0 1-1.5 0v-3.5A.75.75 0 0 1 8 3Z"></path> </svg> </template> <template id="pencil-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-pencil"> <path d="M11.013 1.427a1.75 1.75 0 0 1 2.474 0l1.086 1.086a1.75 1.75 0 0 1 0 2.474l-8.61 8.61c-.21.21-.47.364-.756.445l-3.251.93a.75.75 0 0 1-.927-.928l.929-3.25c.081-.286.235-.547.445-.758l8.61-8.61Zm.176 4.823L9.75 4.81l-6.286 6.287a.253.253 0 0 0-.064.108l-.558 1.953 1.953-.558a.253.253 0 0 0 .108-.064Zm1.238-3.763a.25.25 0 0 0-.354 0L10.811 3.75l1.439 1.44 1.263-1.263a.25.25 0 0 0 0-.354Z"></path> </svg> </template> <template id="copilot-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-copilot"> <path d="M7.998 15.035c-4.562 0-7.873-2.914-7.998-3.749V9.338c.085-.628.677-1.686 1.588-2.065.013-.07.024-.143.036-.218.029-.183.06-.384.126-.612-.201-.508-.254-1.084-.254-1.656 0-.87.128-1.769.693-2.484.579-.733 1.494-1.124 2.724-1.261 1.206-.134 2.262.034 2.944.765.05.053.096.108.139.165.044-.057.094-.112.143-.165.682-.731 1.738-.899 2.944-.765 1.23.137 2.145.528 2.724 1.261.566.715.693 1.614.693 2.484 0 .572-.053 1.148-.254 1.656.066.228.098.429.126.612.012.076.024.148.037.218.924.385 1.522 1.471 1.591 2.095v1.872c0 .766-3.351 3.795-8.002 3.795Zm0-1.485c2.28 0 4.584-1.11 5.002-1.433V7.862l-.023-.116c-.49.21-1.075.291-1.727.291-1.146 0-2.059-.327-2.71-.991A3.222 3.222 0 0 1 8 6.303a3.24 3.24 0 0 1-.544.743c-.65.664-1.563.991-2.71.991-.652 0-1.236-.081-1.727-.291l-.023.116v4.255c.419.323 2.722 1.433 5.002 1.433ZM6.762 2.83c-.193-.206-.637-.413-1.682-.297-1.019.113-1.479.404-1.713.7-.247.312-.369.789-.369 1.554 0 .793.129 1.171.308 1.371.162.181.519.379 1.442.379.853 0 1.339-.235 1.638-.54.315-.322.527-.827.617-1.553.117-.935-.037-1.395-.241-1.614Zm4.155-.297c-1.044-.116-1.488.091-1.681.297-.204.219-.359.679-.242 1.614.091.726.303 1.231.618 1.553.299.305.784.54 1.638.54.922 0 1.28-.198 1.442-.379.179-.2.308-.578.308-1.371 0-.765-.123-1.242-.37-1.554-.233-.296-.693-.587-1.713-.7Z"></path><path d="M6.25 9.037a.75.75 0 0 1 .75.75v1.501a.75.75 0 0 1-1.5 0V9.787a.75.75 0 0 1 .75-.75Zm4.25.75v1.501a.75.75 0 0 1-1.5 0V9.787a.75.75 0 0 1 1.5 0Z"></path> </svg> </template> <template id="copilot-error-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-copilot-error"> <path d="M16 11.24c0 .112-.072.274-.21.467L13 9.688V7.862l-.023-.116c-.49.21-1.075.291-1.727.291-.198 0-.388-.009-.571-.029L6.833 5.226a4.01 4.01 0 0 0 .17-.782c.117-.935-.037-1.395-.241-1.614-.193-.206-.637-.413-1.682-.297-.683.076-1.115.231-1.395.415l-1.257-.91c.579-.564 1.413-.877 2.485-.996 1.206-.134 2.262.034 2.944.765.05.053.096.108.139.165.044-.057.094-.112.143-.165.682-.731 1.738-.899 2.944-.765 1.23.137 2.145.528 2.724 1.261.566.715.693 1.614.693 2.484 0 .572-.053 1.148-.254 1.656.066.228.098.429.126.612.012.076.024.148.037.218.924.385 1.522 1.471 1.591 2.095Zm-5.083-8.707c-1.044-.116-1.488.091-1.681.297-.204.219-.359.679-.242 1.614.091.726.303 1.231.618 1.553.299.305.784.54 1.638.54.922 0 1.28-.198 1.442-.379.179-.2.308-.578.308-1.371 0-.765-.123-1.242-.37-1.554-.233-.296-.693-.587-1.713-.7Zm2.511 11.074c-1.393.776-3.272 1.428-5.43 1.428-4.562 0-7.873-2.914-7.998-3.749V9.338c.085-.628.677-1.686 1.588-2.065.013-.07.024-.143.036-.218.029-.183.06-.384.126-.612-.18-.455-.241-.963-.252-1.475L.31 4.107A.747.747 0 0 1 0 3.509V3.49a.748.748 0 0 1 .625-.73c.156-.026.306.047.435.139l14.667 10.578a.592.592 0 0 1 .227.264.752.752 0 0 1 .046.249v.022a.75.75 0 0 1-1.19.596Zm-1.367-.991L5.635 7.964a5.128 5.128 0 0 1-.889.073c-.652 0-1.236-.081-1.727-.291l-.023.116v4.255c.419.323 2.722 1.433 5.002 1.433 1.539 0 3.089-.505 4.063-.934Z"></path> </svg> </template> <template id="workflow-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-workflow"> <path d="M0 1.75C0 .784.784 0 1.75 0h3.5C6.216 0 7 .784 7 1.75v3.5A1.75 1.75 0 0 1 5.25 7H4v4a1 1 0 0 0 1 1h4v-1.25C9 9.784 9.784 9 10.75 9h3.5c.966 0 1.75.784 1.75 1.75v3.5A1.75 1.75 0 0 1 14.25 16h-3.5A1.75 1.75 0 0 1 9 14.25v-.75H5A2.5 2.5 0 0 1 2.5 11V7h-.75A1.75 1.75 0 0 1 0 5.25Zm1.75-.25a.25.25 0 0 0-.25.25v3.5c0 .138.112.25.25.25h3.5a.25.25 0 0 0 .25-.25v-3.5a.25.25 0 0 0-.25-.25Zm9 9a.25.25 0 0 0-.25.25v3.5c0 .138.112.25.25.25h3.5a.25.25 0 0 0 .25-.25v-3.5a.25.25 0 0 0-.25-.25Z"></path> </svg> </template> <template id="book-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-book"> <path d="M0 1.75A.75.75 0 0 1 .75 1h4.253c1.227 0 2.317.59 3 1.501A3.743 3.743 0 0 1 11.006 1h4.245a.75.75 0 0 1 .75.75v10.5a.75.75 0 0 1-.75.75h-4.507a2.25 2.25 0 0 0-1.591.659l-.622.621a.75.75 0 0 1-1.06 0l-.622-.621A2.25 2.25 0 0 0 5.258 13H.75a.75.75 0 0 1-.75-.75Zm7.251 10.324.004-5.073-.002-2.253A2.25 2.25 0 0 0 5.003 2.5H1.5v9h3.757a3.75 3.75 0 0 1 1.994.574ZM8.755 4.75l-.004 7.322a3.752 3.752 0 0 1 1.992-.572H14.5v-9h-3.495a2.25 2.25 0 0 0-2.25 2.25Z"></path> </svg> </template> <template id="code-review-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-code-review"> <path d="M1.75 1h12.5c.966 0 1.75.784 1.75 1.75v8.5A1.75 1.75 0 0 1 14.25 13H8.061l-2.574 2.573A1.458 1.458 0 0 1 3 14.543V13H1.75A1.75 1.75 0 0 1 0 11.25v-8.5C0 1.784.784 1 1.75 1ZM1.5 2.75v8.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-8.5a.25.25 0 0 0-.25-.25H1.75a.25.25 0 0 0-.25.25Zm5.28 1.72a.75.75 0 0 1 0 1.06L5.31 7l1.47 1.47a.751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018l-2-2a.75.75 0 0 1 0-1.06l2-2a.75.75 0 0 1 1.06 0Zm2.44 0a.75.75 0 0 1 1.06 0l2 2a.75.75 0 0 1 0 1.06l-2 2a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L10.69 7 9.22 5.53a.75.75 0 0 1 0-1.06Z"></path> </svg> </template> <template id="codespaces-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-codespaces"> <path d="M0 11.25c0-.966.784-1.75 1.75-1.75h12.5c.966 0 1.75.784 1.75 1.75v3A1.75 1.75 0 0 1 14.25 16H1.75A1.75 1.75 0 0 1 0 14.25Zm2-9.5C2 .784 2.784 0 3.75 0h8.5C13.216 0 14 .784 14 1.75v5a1.75 1.75 0 0 1-1.75 1.75h-8.5A1.75 1.75 0 0 1 2 6.75Zm1.75-.25a.25.25 0 0 0-.25.25v5c0 .138.112.25.25.25h8.5a.25.25 0 0 0 .25-.25v-5a.25.25 0 0 0-.25-.25Zm-2 9.5a.25.25 0 0 0-.25.25v3c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25v-3a.25.25 0 0 0-.25-.25Z"></path><path d="M7 12.75a.75.75 0 0 1 .75-.75h4.5a.75.75 0 0 1 0 1.5h-4.5a.75.75 0 0 1-.75-.75Zm-4 0a.75.75 0 0 1 .75-.75h.5a.75.75 0 0 1 0 1.5h-.5a.75.75 0 0 1-.75-.75Z"></path> </svg> </template> <template id="comment-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-comment"> <path d="M1 2.75C1 1.784 1.784 1 2.75 1h10.5c.966 0 1.75.784 1.75 1.75v7.5A1.75 1.75 0 0 1 13.25 12H9.06l-2.573 2.573A1.458 1.458 0 0 1 4 13.543V12H2.75A1.75 1.75 0 0 1 1 10.25Zm1.75-.25a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h2a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h4.5a.25.25 0 0 0 .25-.25v-7.5a.25.25 0 0 0-.25-.25Z"></path> </svg> </template> <template id="comment-discussion-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-comment-discussion"> <path d="M1.75 1h8.5c.966 0 1.75.784 1.75 1.75v5.5A1.75 1.75 0 0 1 10.25 10H7.061l-2.574 2.573A1.458 1.458 0 0 1 2 11.543V10h-.25A1.75 1.75 0 0 1 0 8.25v-5.5C0 1.784.784 1 1.75 1ZM1.5 2.75v5.5c0 .138.112.25.25.25h1a.75.75 0 0 1 .75.75v2.19l2.72-2.72a.749.749 0 0 1 .53-.22h3.5a.25.25 0 0 0 .25-.25v-5.5a.25.25 0 0 0-.25-.25h-8.5a.25.25 0 0 0-.25.25Zm13 2a.25.25 0 0 0-.25-.25h-.5a.75.75 0 0 1 0-1.5h.5c.966 0 1.75.784 1.75 1.75v5.5A1.75 1.75 0 0 1 14.25 12H14v1.543a1.458 1.458 0 0 1-2.487 1.03L9.22 12.28a.749.749 0 0 1 .326-1.275.749.749 0 0 1 .734.215l2.22 2.22v-2.19a.75.75 0 0 1 .75-.75h1a.25.25 0 0 0 .25-.25Z"></path> </svg> </template> <template id="organization-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-organization"> <path d="M1.75 16A1.75 1.75 0 0 1 0 14.25V1.75C0 .784.784 0 1.75 0h8.5C11.216 0 12 .784 12 1.75v12.5c0 .085-.006.168-.018.25h2.268a.25.25 0 0 0 .25-.25V8.285a.25.25 0 0 0-.111-.208l-1.055-.703a.749.749 0 1 1 .832-1.248l1.055.703c.487.325.779.871.779 1.456v5.965A1.75 1.75 0 0 1 14.25 16h-3.5a.766.766 0 0 1-.197-.026c-.099.017-.2.026-.303.026h-3a.75.75 0 0 1-.75-.75V14h-1v1.25a.75.75 0 0 1-.75.75Zm-.25-1.75c0 .138.112.25.25.25H4v-1.25a.75.75 0 0 1 .75-.75h2.5a.75.75 0 0 1 .75.75v1.25h2.25a.25.25 0 0 0 .25-.25V1.75a.25.25 0 0 0-.25-.25h-8.5a.25.25 0 0 0-.25.25ZM3.75 6h.5a.75.75 0 0 1 0 1.5h-.5a.75.75 0 0 1 0-1.5ZM3 3.75A.75.75 0 0 1 3.75 3h.5a.75.75 0 0 1 0 1.5h-.5A.75.75 0 0 1 3 3.75Zm4 3A.75.75 0 0 1 7.75 6h.5a.75.75 0 0 1 0 1.5h-.5A.75.75 0 0 1 7 6.75ZM7.75 3h.5a.75.75 0 0 1 0 1.5h-.5a.75.75 0 0 1 0-1.5ZM3 9.75A.75.75 0 0 1 3.75 9h.5a.75.75 0 0 1 0 1.5h-.5A.75.75 0 0 1 3 9.75ZM7.75 9h.5a.75.75 0 0 1 0 1.5h-.5a.75.75 0 0 1 0-1.5Z"></path> </svg> </template> <template id="rocket-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-rocket"> <path d="M14.064 0h.186C15.216 0 16 .784 16 1.75v.186a8.752 8.752 0 0 1-2.564 6.186l-.458.459c-.314.314-.641.616-.979.904v3.207c0 .608-.315 1.172-.833 1.49l-2.774 1.707a.749.749 0 0 1-1.11-.418l-.954-3.102a1.214 1.214 0 0 1-.145-.125L3.754 9.816a1.218 1.218 0 0 1-.124-.145L.528 8.717a.749.749 0 0 1-.418-1.11l1.71-2.774A1.748 1.748 0 0 1 3.31 4h3.204c.288-.338.59-.665.904-.979l.459-.458A8.749 8.749 0 0 1 14.064 0ZM8.938 3.623h-.002l-.458.458c-.76.76-1.437 1.598-2.02 2.5l-1.5 2.317 2.143 2.143 2.317-1.5c.902-.583 1.74-1.26 2.499-2.02l.459-.458a7.25 7.25 0 0 0 2.123-5.127V1.75a.25.25 0 0 0-.25-.25h-.186a7.249 7.249 0 0 0-5.125 2.123ZM3.56 14.56c-.732.732-2.334 1.045-3.005 1.148a.234.234 0 0 1-.201-.064.234.234 0 0 1-.064-.201c.103-.671.416-2.273 1.15-3.003a1.502 1.502 0 1 1 2.12 2.12Zm6.94-3.935c-.088.06-.177.118-.266.175l-2.35 1.521.548 1.783 1.949-1.2a.25.25 0 0 0 .119-.213ZM3.678 8.116 5.2 5.766c.058-.09.117-.178.176-.266H3.309a.25.25 0 0 0-.213.119l-1.2 1.95ZM12 5a1 1 0 1 1-2 0 1 1 0 0 1 2 0Z"></path> </svg> </template> <template id="shield-check-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-shield-check"> <path d="m8.533.133 5.25 1.68A1.75 1.75 0 0 1 15 3.48V7c0 1.566-.32 3.182-1.303 4.682-.983 1.498-2.585 2.813-5.032 3.855a1.697 1.697 0 0 1-1.33 0c-2.447-1.042-4.049-2.357-5.032-3.855C1.32 10.182 1 8.566 1 7V3.48a1.75 1.75 0 0 1 1.217-1.667l5.25-1.68a1.748 1.748 0 0 1 1.066 0Zm-.61 1.429.001.001-5.25 1.68a.251.251 0 0 0-.174.237V7c0 1.36.275 2.666 1.057 3.859.784 1.194 2.121 2.342 4.366 3.298a.196.196 0 0 0 .154 0c2.245-.957 3.582-2.103 4.366-3.297C13.225 9.666 13.5 8.358 13.5 7V3.48a.25.25 0 0 0-.174-.238l-5.25-1.68a.25.25 0 0 0-.153 0ZM11.28 6.28l-3.5 3.5a.75.75 0 0 1-1.06 0l-1.5-1.5a.749.749 0 0 1 .326-1.275.749.749 0 0 1 .734.215l.97.97 2.97-2.97a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042Z"></path> </svg> </template> <template id="heart-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-heart"> <path d="m8 14.25.345.666a.75.75 0 0 1-.69 0l-.008-.004-.018-.01a7.152 7.152 0 0 1-.31-.17 22.055 22.055 0 0 1-3.434-2.414C2.045 10.731 0 8.35 0 5.5 0 2.836 2.086 1 4.25 1 5.797 1 7.153 1.802 8 3.02 8.847 1.802 10.203 1 11.75 1 13.914 1 16 2.836 16 5.5c0 2.85-2.045 5.231-3.885 6.818a22.066 22.066 0 0 1-3.744 2.584l-.018.01-.006.003h-.002ZM4.25 2.5c-1.336 0-2.75 1.164-2.75 3 0 2.15 1.58 4.144 3.365 5.682A20.58 20.58 0 0 0 8 13.393a20.58 20.58 0 0 0 3.135-2.211C12.92 9.644 14.5 7.65 14.5 5.5c0-1.836-1.414-3-2.75-3-1.373 0-2.609.986-3.029 2.456a.749.749 0 0 1-1.442 0C6.859 3.486 5.623 2.5 4.25 2.5Z"></path> </svg> </template> <template id="server-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-server"> <path d="M1.75 1h12.5c.966 0 1.75.784 1.75 1.75v4c0 .372-.116.717-.314 1 .198.283.314.628.314 1v4a1.75 1.75 0 0 1-1.75 1.75H1.75A1.75 1.75 0 0 1 0 12.75v-4c0-.358.109-.707.314-1a1.739 1.739 0 0 1-.314-1v-4C0 1.784.784 1 1.75 1ZM1.5 2.75v4c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25v-4a.25.25 0 0 0-.25-.25H1.75a.25.25 0 0 0-.25.25Zm.25 5.75a.25.25 0 0 0-.25.25v4c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25v-4a.25.25 0 0 0-.25-.25ZM7 4.75A.75.75 0 0 1 7.75 4h4.5a.75.75 0 0 1 0 1.5h-4.5A.75.75 0 0 1 7 4.75ZM7.75 10h4.5a.75.75 0 0 1 0 1.5h-4.5a.75.75 0 0 1 0-1.5ZM3 4.75A.75.75 0 0 1 3.75 4h.5a.75.75 0 0 1 0 1.5h-.5A.75.75 0 0 1 3 4.75ZM3.75 10h.5a.75.75 0 0 1 0 1.5h-.5a.75.75 0 0 1 0-1.5Z"></path> </svg> </template> <template id="globe-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-globe"> <path d="M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM5.78 8.75a9.64 9.64 0 0 0 1.363 4.177c.255.426.542.832.857 1.215.245-.296.551-.705.857-1.215A9.64 9.64 0 0 0 10.22 8.75Zm4.44-1.5a9.64 9.64 0 0 0-1.363-4.177c-.307-.51-.612-.919-.857-1.215a9.927 9.927 0 0 0-.857 1.215A9.64 9.64 0 0 0 5.78 7.25Zm-5.944 1.5H1.543a6.507 6.507 0 0 0 4.666 5.5c-.123-.181-.24-.365-.352-.552-.715-1.192-1.437-2.874-1.581-4.948Zm-2.733-1.5h2.733c.144-2.074.866-3.756 1.58-4.948.12-.197.237-.381.353-.552a6.507 6.507 0 0 0-4.666 5.5Zm10.181 1.5c-.144 2.074-.866 3.756-1.58 4.948-.12.197-.237.381-.353.552a6.507 6.507 0 0 0 4.666-5.5Zm2.733-1.5a6.507 6.507 0 0 0-4.666-5.5c.123.181.24.365.353.552.714 1.192 1.436 2.874 1.58 4.948Z"></path> </svg> </template> <template id="issue-opened-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-issue-opened"> <path d="M8 9.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z"></path><path d="M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM1.5 8a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0Z"></path> </svg> </template> <template id="device-mobile-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-device-mobile"> <path d="M3.75 0h8.5C13.216 0 14 .784 14 1.75v12.5A1.75 1.75 0 0 1 12.25 16h-8.5A1.75 1.75 0 0 1 2 14.25V1.75C2 .784 2.784 0 3.75 0ZM3.5 1.75v12.5c0 .138.112.25.25.25h8.5a.25.25 0 0 0 .25-.25V1.75a.25.25 0 0 0-.25-.25h-8.5a.25.25 0 0 0-.25.25ZM8 13a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z"></path> </svg> </template> <template id="package-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-package"> <path d="m8.878.392 5.25 3.045c.54.314.872.89.872 1.514v6.098a1.75 1.75 0 0 1-.872 1.514l-5.25 3.045a1.75 1.75 0 0 1-1.756 0l-5.25-3.045A1.75 1.75 0 0 1 1 11.049V4.951c0-.624.332-1.201.872-1.514L7.122.392a1.75 1.75 0 0 1 1.756 0ZM7.875 1.69l-4.63 2.685L8 7.133l4.755-2.758-4.63-2.685a.248.248 0 0 0-.25 0ZM2.5 5.677v5.372c0 .09.047.171.125.216l4.625 2.683V8.432Zm6.25 8.271 4.625-2.683a.25.25 0 0 0 .125-.216V5.677L8.75 8.432Z"></path> </svg> </template> <template id="credit-card-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-credit-card"> <path d="M10.75 9a.75.75 0 0 0 0 1.5h1.5a.75.75 0 0 0 0-1.5h-1.5Z"></path><path d="M0 3.75C0 2.784.784 2 1.75 2h12.5c.966 0 1.75.784 1.75 1.75v8.5A1.75 1.75 0 0 1 14.25 14H1.75A1.75 1.75 0 0 1 0 12.25ZM14.5 6.5h-13v5.75c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25Zm0-2.75a.25.25 0 0 0-.25-.25H1.75a.25.25 0 0 0-.25.25V5h13Z"></path> </svg> </template> <template id="play-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-play"> <path d="M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM1.5 8a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0Zm4.879-2.773 4.264 2.559a.25.25 0 0 1 0 .428l-4.264 2.559A.25.25 0 0 1 6 10.559V5.442a.25.25 0 0 1 .379-.215Z"></path> </svg> </template> <template id="gift-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-gift"> <path d="M2 2.75A2.75 2.75 0 0 1 4.75 0c.983 0 1.873.42 2.57 1.232.268.318.497.668.68 1.042.183-.375.411-.725.68-1.044C9.376.42 10.266 0 11.25 0a2.75 2.75 0 0 1 2.45 4h.55c.966 0 1.75.784 1.75 1.75v2c0 .698-.409 1.301-1 1.582v4.918A1.75 1.75 0 0 1 13.25 16H2.75A1.75 1.75 0 0 1 1 14.25V9.332C.409 9.05 0 8.448 0 7.75v-2C0 4.784.784 4 1.75 4h.55c-.192-.375-.3-.8-.3-1.25ZM7.25 9.5H2.5v4.75c0 .138.112.25.25.25h4.5Zm1.5 0v5h4.5a.25.25 0 0 0 .25-.25V9.5Zm0-4V8h5.5a.25.25 0 0 0 .25-.25v-2a.25.25 0 0 0-.25-.25Zm-7 0a.25.25 0 0 0-.25.25v2c0 .138.112.25.25.25h5.5V5.5h-5.5Zm3-4a1.25 1.25 0 0 0 0 2.5h2.309c-.233-.818-.542-1.401-.878-1.793-.43-.502-.915-.707-1.431-.707ZM8.941 4h2.309a1.25 1.25 0 0 0 0-2.5c-.516 0-1 .205-1.43.707-.337.392-.646.975-.879 1.793Z"></path> </svg> </template> <template id="code-square-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-code-square"> <path d="M0 1.75C0 .784.784 0 1.75 0h12.5C15.216 0 16 .784 16 1.75v12.5A1.75 1.75 0 0 1 14.25 16H1.75A1.75 1.75 0 0 1 0 14.25Zm1.75-.25a.25.25 0 0 0-.25.25v12.5c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25V1.75a.25.25 0 0 0-.25-.25Zm7.47 3.97a.75.75 0 0 1 1.06 0l2 2a.75.75 0 0 1 0 1.06l-2 2a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734L10.69 8 9.22 6.53a.75.75 0 0 1 0-1.06ZM6.78 6.53 5.31 8l1.47 1.47a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215l-2-2a.75.75 0 0 1 0-1.06l2-2a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042Z"></path> </svg> </template> <template id="device-desktop-icon"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-device-desktop"> <path d="M14.25 1c.966 0 1.75.784 1.75 1.75v7.5A1.75 1.75 0 0 1 14.25 12h-3.727c.099 1.041.52 1.872 1.292 2.757A.752.752 0 0 1 11.25 16h-6.5a.75.75 0 0 1-.565-1.243c.772-.885 1.192-1.716 1.292-2.757H1.75A1.75 1.75 0 0 1 0 10.25v-7.5C0 1.784.784 1 1.75 1ZM1.75 2.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h12.5a.25.25 0 0 0 .25-.25v-7.5a.25.25 0 0 0-.25-.25ZM9.018 12H6.982a5.72 5.72 0 0 1-.765 2.5h3.566a5.72 5.72 0 0 1-.765-2.5Z"></path> </svg> </template> <div class="position-relative"> <ul role="listbox" class="ActionListWrap QueryBuilder-ListWrap" aria-label="Suggestions" data-action=" combobox-commit:query-builder#comboboxCommit mousedown:query-builder#resultsMousedown " data-target="query-builder.resultsList" data-persist-list=false id="query-builder-test-results" ></ul> </div> <div class="FormControl-inlineValidation" id="validation-b54de372-e273-4d9d-9633-4ef61ddbc079" hidden="hidden"> <span class="FormControl-inlineValidation--visual"> <svg aria-hidden="true" height="12" viewBox="0 0 12 12" version="1.1" width="12" data-view-component="true" class="octicon octicon-alert-fill"> <path d="M4.855.708c.5-.896 1.79-.896 2.29 0l4.675 8.351a1.312 1.312 0 0 1-1.146 1.954H1.33A1.313 1.313 0 0 1 .183 9.058ZM7 7V3H5v4Zm-1 3a1 1 0 1 0 0-2 1 1 0 0 0 0 2Z"></path> </svg> </span> <span></span> </div> </div> <div data-target="query-builder.screenReaderFeedback" aria-live="polite" aria-atomic="true" class="sr-only"></div> </query-builder></form> <div class="d-flex flex-row color-fg-muted px-3 text-small color-bg-default search-feedback-prompt"> <a target="_blank" href="https://docs.github.com/search-github/github-code-search/understanding-github-code-search-syntax" data-view-component="true" class="Link color-fg-accent text-normal ml-2">Search syntax tips</a> <div class="d-flex flex-1"></div> </div> </div> </div> </div> </modal-dialog></div> </div> <div data-action="click:qbsearch-input#retract" class="dark-backdrop position-fixed" hidden data-target="qbsearch-input.darkBackdrop"></div> <div class="color-fg-default"> <dialog-helper> <dialog data-target="qbsearch-input.feedbackDialog" data-action="close:qbsearch-input#handleDialogClose cancel:qbsearch-input#handleDialogClose" id="feedback-dialog" aria-modal="true" aria-labelledby="feedback-dialog-title" aria-describedby="feedback-dialog-description" data-view-component="true" class="Overlay Overlay-whenNarrow Overlay--size-medium Overlay--motion-scaleFade Overlay--disableScroll"> <div data-view-component="true" class="Overlay-header"> <div class="Overlay-headerContentWrap"> <div class="Overlay-titleWrap"> <h1 class="Overlay-title " id="feedback-dialog-title"> Provide feedback </h1> </div> <div class="Overlay-actionWrap"> <button data-close-dialog-id="feedback-dialog" aria-label="Close" type="button" data-view-component="true" class="close-button Overlay-closeButton"><svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x"> <path d="M3.72 3.72a.75.75 0 0 1 1.06 0L8 6.94l3.22-3.22a.749.749 0 0 1 1.275.326.749.749 0 0 1-.215.734L9.06 8l3.22 3.22a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L8 9.06l-3.22 3.22a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L6.94 8 3.72 4.78a.75.75 0 0 1 0-1.06Z"></path> </svg></button> </div> </div> </div> <scrollable-region data-labelled-by="feedback-dialog-title"> <div data-view-component="true" class="Overlay-body"> <!-- '"` --><!-- </textarea></xmp> --></option></form><form id="code-search-feedback-form" data-turbo="false" action="/search/feedback" accept-charset="UTF-8" method="post"><input type="hidden" data-csrf="true" name="authenticity_token" value="apjSZTH5r9JJUjahTVJko7awddb7Zwp/n1p2U2D+9/va1K5AxCXfiPXEBwI/kl2MaJqM615AffCDxUZtUyvRcA==" /> <p>We read every piece of feedback, and take your input very seriously.</p> <textarea name="feedback" class="form-control width-full mb-2" style="height: 120px" id="feedback"></textarea> <input name="include_email" id="include_email" aria-label="Include my email address so I can be contacted" class="form-control mr-2" type="checkbox"> <label for="include_email" style="font-weight: normal">Include my email address so I can be contacted</label> </form></div> </scrollable-region> <div data-view-component="true" class="Overlay-footer Overlay-footer--alignEnd"> <button data-close-dialog-id="feedback-dialog" type="button" data-view-component="true" class="btn"> Cancel </button> <button form="code-search-feedback-form" data-action="click:qbsearch-input#submitFeedback" type="submit" data-view-component="true" class="btn-primary btn"> Submit feedback </button> </div> </dialog></dialog-helper> <custom-scopes data-target="qbsearch-input.customScopesManager"> <dialog-helper> <dialog data-target="custom-scopes.customScopesModalDialog" data-action="close:qbsearch-input#handleDialogClose cancel:qbsearch-input#handleDialogClose" id="custom-scopes-dialog" aria-modal="true" aria-labelledby="custom-scopes-dialog-title" aria-describedby="custom-scopes-dialog-description" data-view-component="true" class="Overlay Overlay-whenNarrow Overlay--size-medium Overlay--motion-scaleFade Overlay--disableScroll"> <div data-view-component="true" class="Overlay-header Overlay-header--divided"> <div class="Overlay-headerContentWrap"> <div class="Overlay-titleWrap"> <h1 class="Overlay-title " id="custom-scopes-dialog-title"> Saved searches </h1> <h2 id="custom-scopes-dialog-description" class="Overlay-description">Use saved searches to filter your results more quickly</h2> </div> <div class="Overlay-actionWrap"> <button data-close-dialog-id="custom-scopes-dialog" aria-label="Close" type="button" data-view-component="true" class="close-button Overlay-closeButton"><svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x"> <path d="M3.72 3.72a.75.75 0 0 1 1.06 0L8 6.94l3.22-3.22a.749.749 0 0 1 1.275.326.749.749 0 0 1-.215.734L9.06 8l3.22 3.22a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L8 9.06l-3.22 3.22a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L6.94 8 3.72 4.78a.75.75 0 0 1 0-1.06Z"></path> </svg></button> </div> </div> </div> <scrollable-region data-labelled-by="custom-scopes-dialog-title"> <div data-view-component="true" class="Overlay-body"> <div data-target="custom-scopes.customScopesModalDialogFlash"></div> <div hidden class="create-custom-scope-form" data-target="custom-scopes.createCustomScopeForm"> <!-- '"` --><!-- </textarea></xmp> --></option></form><form id="custom-scopes-dialog-form" data-turbo="false" action="/search/custom_scopes" accept-charset="UTF-8" method="post"><input type="hidden" data-csrf="true" name="authenticity_token" value="RQjbDReg0MmvQLq8dRmPsJoOHmwiyJIxhZ3LQvB/bbo9YTbEq96maXQ1y2kGqe3sidb6VSabFLKL3CghgiFnlw==" /> <div data-target="custom-scopes.customScopesModalDialogFlash"></div> <input type="hidden" id="custom_scope_id" name="custom_scope_id" data-target="custom-scopes.customScopesIdField"> <div class="form-group"> <label for="custom_scope_name">Name</label> <auto-check src="/search/custom_scopes/check_name" required only-validate-on-blur="false"> <input type="text" name="custom_scope_name" id="custom_scope_name" data-target="custom-scopes.customScopesNameField" class="form-control" autocomplete="off" placeholder="github-ruby" required maxlength="50"> <input type="hidden" data-csrf="true" value="s4uYHZyU3Q5ZfXSgte3lJSFG5p5fwynii7xVMlxUxVD5TkHKaon0kloHmtwaj0FTs0O/c0CbrU6NqwO2a5wr/A==" /> </auto-check> </div> <div class="form-group"> <label for="custom_scope_query">Query</label> <input type="text" name="custom_scope_query" id="custom_scope_query" data-target="custom-scopes.customScopesQueryField" class="form-control" autocomplete="off" placeholder="(repo:mona/a OR repo:mona/b) AND lang:python" required maxlength="500"> </div> <p class="text-small color-fg-muted"> To see all available qualifiers, see our <a class="Link--inTextBlock" href="https://docs.github.com/search-github/github-code-search/understanding-github-code-search-syntax">documentation</a>. </p> </form> </div> <div data-target="custom-scopes.manageCustomScopesForm"> <div data-target="custom-scopes.list"></div> </div> </div> </scrollable-region> <div data-view-component="true" class="Overlay-footer Overlay-footer--alignEnd Overlay-footer--divided"> <button data-action="click:custom-scopes#customScopesCancel" type="button" data-view-component="true" class="btn"> Cancel </button> <button form="custom-scopes-dialog-form" data-action="click:custom-scopes#customScopesSubmit" data-target="custom-scopes.customScopesSubmitButton" type="submit" data-view-component="true" class="btn-primary btn"> Create saved search </button> </div> </dialog></dialog-helper> </custom-scopes> </div> </qbsearch-input> <div class="position-relative HeaderMenu-link-wrap d-lg-inline-block"> <a href="/login?return_to=https%3A%2F%2Fgithub.com%2Fpython%2Fpeps%2Fblob%2Fmain%2Fpeps%2Fpep-0327.rst" class="HeaderMenu-link HeaderMenu-link--sign-in HeaderMenu-button flex-shrink-0 no-underline d-none d-lg-inline-flex border border-lg-0 rounded rounded-lg-0 px-2 py-1" style="margin-left: 12px;" data-hydro-click="{&quot;event_type&quot;:&quot;authentication.click&quot;,&quot;payload&quot;:{&quot;location_in_page&quot;:&quot;site header menu&quot;,&quot;repository_id&quot;:null,&quot;auth_type&quot;:&quot;SIGN_UP&quot;,&quot;originating_url&quot;:&quot;https://github.com/python/peps/blob/main/peps/pep-0327.rst&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="0bedca4cf3774db708d3d7328aa6565542a3c56eb63de6e3069bfa3166442f98" data-analytics-event="{&quot;category&quot;:&quot;Marketing nav&quot;,&quot;action&quot;:&quot;click to go to homepage&quot;,&quot;label&quot;:&quot;ref_page:Marketing;ref_cta:Sign in;ref_loc:Header&quot;}" > Sign in </a> </div> <a href="/signup?ref_cta=Sign+up&amp;ref_loc=header+logged+out&amp;ref_page=%2F%3Cuser-name%3E%2F%3Crepo-name%3E%2Fblob%2Fshow&amp;source=header-repo&amp;source_repo=python%2Fpeps" class="HeaderMenu-link HeaderMenu-link--sign-up HeaderMenu-button flex-shrink-0 d-flex d-lg-inline-flex no-underline border color-border-default rounded px-2 py-1" data-hydro-click="{&quot;event_type&quot;:&quot;authentication.click&quot;,&quot;payload&quot;:{&quot;location_in_page&quot;:&quot;site header menu&quot;,&quot;repository_id&quot;:null,&quot;auth_type&quot;:&quot;SIGN_UP&quot;,&quot;originating_url&quot;:&quot;https://github.com/python/peps/blob/main/peps/pep-0327.rst&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="0bedca4cf3774db708d3d7328aa6565542a3c56eb63de6e3069bfa3166442f98" data-analytics-event="{&quot;category&quot;:&quot;Sign up&quot;,&quot;action&quot;:&quot;click to sign up for account&quot;,&quot;label&quot;:&quot;ref_page:/&lt;user-name&gt;/&lt;repo-name&gt;/blob/show;ref_cta:Sign up;ref_loc:header logged out&quot;}" > Sign up </a> <button type="button" class="sr-only js-header-menu-focus-trap d-block d-lg-none">Reseting focus</button> </div> </div> </div> </div> </header> <div hidden="hidden" data-view-component="true" class="js-stale-session-flash stale-session-flash flash flash-warn flash-full"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-alert"> <path d="M6.457 1.047c.659-1.234 2.427-1.234 3.086 0l6.082 11.378A1.75 1.75 0 0 1 14.082 15H1.918a1.75 1.75 0 0 1-1.543-2.575Zm1.763.707a.25.25 0 0 0-.44 0L1.698 13.132a.25.25 0 0 0 .22.368h12.164a.25.25 0 0 0 .22-.368Zm.53 3.996v2.5a.75.75 0 0 1-1.5 0v-2.5a.75.75 0 0 1 1.5 0ZM9 11a1 1 0 1 1-2 0 1 1 0 0 1 2 0Z"></path> </svg> <span class="js-stale-session-flash-signed-in" hidden>You signed in with another tab or window. <a class="Link--inTextBlock" href="">Reload</a> to refresh your session.</span> <span class="js-stale-session-flash-signed-out" hidden>You signed out in another tab or window. <a class="Link--inTextBlock" href="">Reload</a> to refresh your session.</span> <span class="js-stale-session-flash-switched" hidden>You switched accounts on another tab or window. <a class="Link--inTextBlock" href="">Reload</a> to refresh your session.</span> <button id="icon-button-11c149b9-33c6-4baa-8066-6a9dcbab9e9f" aria-labelledby="tooltip-75e9d15e-0708-4dde-b1eb-4ec25c1c7aa6" type="button" data-view-component="true" class="Button Button--iconOnly Button--invisible Button--medium flash-close js-flash-close"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x Button-visual"> <path d="M3.72 3.72a.75.75 0 0 1 1.06 0L8 6.94l3.22-3.22a.749.749 0 0 1 1.275.326.749.749 0 0 1-.215.734L9.06 8l3.22 3.22a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L8 9.06l-3.22 3.22a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L6.94 8 3.72 4.78a.75.75 0 0 1 0-1.06Z"></path> </svg> </button><tool-tip id="tooltip-75e9d15e-0708-4dde-b1eb-4ec25c1c7aa6" for="icon-button-11c149b9-33c6-4baa-8066-6a9dcbab9e9f" popover="manual" data-direction="s" data-type="label" data-view-component="true" class="sr-only position-absolute">Dismiss alert</tool-tip> </div> </div> <div id="start-of-content" class="show-on-focus"></div> <div id="js-flash-container" class="flash-container" data-turbo-replace> <template class="js-flash-template"> <div class="flash flash-full {{ className }}"> <div > <button autofocus class="flash-close js-flash-close" type="button" aria-label="Dismiss this message"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x"> <path d="M3.72 3.72a.75.75 0 0 1 1.06 0L8 6.94l3.22-3.22a.749.749 0 0 1 1.275.326.749.749 0 0 1-.215.734L9.06 8l3.22 3.22a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L8 9.06l-3.22 3.22a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L6.94 8 3.72 4.78a.75.75 0 0 1 0-1.06Z"></path> </svg> </button> <div aria-atomic="true" role="alert" class="js-flash-alert"> <div>{{ message }}</div> </div> </div> </div> </template> </div> <div class="application-main " data-commit-hovercards-enabled data-discussion-hovercards-enabled data-issue-and-pr-hovercards-enabled data-project-hovercards-enabled > <div itemscope itemtype="http://schema.org/SoftwareSourceCode" class=""> <main id="js-repo-pjax-container" > <div id="repository-container-header" class="pt-3 hide-full-screen" style="background-color: var(--page-header-bgColor, var(--color-page-header-bg));" data-turbo-replace> <div class="d-flex flex-nowrap flex-justify-end mb-3 px-3 px-lg-5" style="gap: 1rem;"> <div class="flex-auto min-width-0 width-fit"> <div class=" d-flex flex-wrap flex-items-center wb-break-word f3 text-normal"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-repo color-fg-muted mr-2"> <path d="M2 2.5A2.5 2.5 0 0 1 4.5 0h8.75a.75.75 0 0 1 .75.75v12.5a.75.75 0 0 1-.75.75h-2.5a.75.75 0 0 1 0-1.5h1.75v-2h-8a1 1 0 0 0-.714 1.7.75.75 0 1 1-1.072 1.05A2.495 2.495 0 0 1 2 11.5Zm10.5-1h-8a1 1 0 0 0-1 1v6.708A2.486 2.486 0 0 1 4.5 9h8ZM5 12.25a.25.25 0 0 1 .25-.25h3.5a.25.25 0 0 1 .25.25v3.25a.25.25 0 0 1-.4.2l-1.45-1.087a.249.249 0 0 0-.3 0L5.4 15.7a.25.25 0 0 1-.4-.2Z"></path> </svg> <span class="author flex-self-stretch" itemprop="author"> <a class="url fn" rel="author" data-hovercard-type="organization" data-hovercard-url="/orgs/python/hovercard" data-octo-click="hovercard-link-click" data-octo-dimensions="link_type:self" href="/python"> python </a> </span> <span class="mx-1 flex-self-stretch color-fg-muted">/</span> <strong itemprop="name" class="mr-2 flex-self-stretch"> <a data-pjax="#repo-content-pjax-container" data-turbo-frame="repo-content-turbo-frame" href="/python/peps">peps</a> </strong> <span></span><span class="Label Label--secondary v-align-middle mr-1">Public</span> </div> </div> <div id="repository-details-container" class="flex-shrink-0" data-turbo-replace style="max-width: 70%;"> <ul class="pagehead-actions flex-shrink-0 d-none d-md-inline" style="padding: 2px 0;"> <li> <include-fragment src="/python/peps/sponsor_button"></include-fragment> </li> <li> <a href="/login?return_to=%2Fpython%2Fpeps" rel="nofollow" id="repository-details-watch-button" data-hydro-click="{&quot;event_type&quot;:&quot;authentication.click&quot;,&quot;payload&quot;:{&quot;location_in_page&quot;:&quot;notification subscription menu watch&quot;,&quot;repository_id&quot;:null,&quot;auth_type&quot;:&quot;LOG_IN&quot;,&quot;originating_url&quot;:&quot;https://github.com/python/peps/blob/main/peps/pep-0327.rst&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="d685e6f88416e70348d6c125ea9fc5caf1437e51a71bd3d590db281db3a7e675" aria-label="You must be signed in to change notification settings" data-view-component="true" class="btn-sm btn"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-bell mr-2"> <path d="M8 16a2 2 0 0 0 1.985-1.75c.017-.137-.097-.25-.235-.25h-3.5c-.138 0-.252.113-.235.25A2 2 0 0 0 8 16ZM3 5a5 5 0 0 1 10 0v2.947c0 .05.015.098.042.139l1.703 2.555A1.519 1.519 0 0 1 13.482 13H2.518a1.516 1.516 0 0 1-1.263-2.36l1.703-2.554A.255.255 0 0 0 3 7.947Zm5-3.5A3.5 3.5 0 0 0 4.5 5v2.947c0 .346-.102.683-.294.97l-1.703 2.556a.017.017 0 0 0-.003.01l.001.006c0 .002.002.004.004.006l.006.004.007.001h10.964l.007-.001.006-.004.004-.006.001-.007a.017.017 0 0 0-.003-.01l-1.703-2.554a1.745 1.745 0 0 1-.294-.97V5A3.5 3.5 0 0 0 8 1.5Z"></path> </svg>Notifications </a> <tool-tip id="tooltip-fae9c130-6e24-4dad-9f91-421894cfa4fb" for="repository-details-watch-button" popover="manual" data-direction="s" data-type="description" data-view-component="true" class="sr-only position-absolute">You must be signed in to change notification settings</tool-tip> </li> <li> <a icon="repo-forked" id="fork-button" href="/login?return_to=%2Fpython%2Fpeps" rel="nofollow" data-hydro-click="{&quot;event_type&quot;:&quot;authentication.click&quot;,&quot;payload&quot;:{&quot;location_in_page&quot;:&quot;repo details fork button&quot;,&quot;repository_id&quot;:13414105,&quot;auth_type&quot;:&quot;LOG_IN&quot;,&quot;originating_url&quot;:&quot;https://github.com/python/peps/blob/main/peps/pep-0327.rst&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="7ea36144d2c1e1c619f3630931de6f082d459ae2ab6f3e8eedcf751c97c6d699" data-view-component="true" class="btn-sm btn"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-repo-forked mr-2"> <path d="M5 5.372v.878c0 .414.336.75.75.75h4.5a.75.75 0 0 0 .75-.75v-.878a2.25 2.25 0 1 1 1.5 0v.878a2.25 2.25 0 0 1-2.25 2.25h-1.5v2.128a2.251 2.251 0 1 1-1.5 0V8.5h-1.5A2.25 2.25 0 0 1 3.5 6.25v-.878a2.25 2.25 0 1 1 1.5 0ZM5 3.25a.75.75 0 1 0-1.5 0 .75.75 0 0 0 1.5 0Zm6.75.75a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5Zm-3 8.75a.75.75 0 1 0-1.5 0 .75.75 0 0 0 1.5 0Z"></path> </svg>Fork <span id="repo-network-counter" data-pjax-replace="true" data-turbo-replace="true" title="1,583" data-view-component="true" class="Counter">1.6k</span> </a> </li> <li> <div data-view-component="true" class="BtnGroup d-flex"> <a href="/login?return_to=%2Fpython%2Fpeps" rel="nofollow" data-hydro-click="{&quot;event_type&quot;:&quot;authentication.click&quot;,&quot;payload&quot;:{&quot;location_in_page&quot;:&quot;star button&quot;,&quot;repository_id&quot;:13414105,&quot;auth_type&quot;:&quot;LOG_IN&quot;,&quot;originating_url&quot;:&quot;https://github.com/python/peps/blob/main/peps/pep-0327.rst&quot;,&quot;user_id&quot;:null}}" data-hydro-click-hmac="369a0778df8d1b8e89db71de0a8b143ca807e5bc29abd9278afc8378610a2261" aria-label="You must be signed in to star a repository" data-view-component="true" class="tooltipped tooltipped-sw btn-sm btn"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-star v-align-text-bottom d-inline-block mr-2"> <path d="M8 .25a.75.75 0 0 1 .673.418l1.882 3.815 4.21.612a.75.75 0 0 1 .416 1.279l-3.046 2.97.719 4.192a.751.751 0 0 1-1.088.791L8 12.347l-3.766 1.98a.75.75 0 0 1-1.088-.79l.72-4.194L.818 6.374a.75.75 0 0 1 .416-1.28l4.21-.611L7.327.668A.75.75 0 0 1 8 .25Zm0 2.445L6.615 5.5a.75.75 0 0 1-.564.41l-3.097.45 2.24 2.184a.75.75 0 0 1 .216.664l-.528 3.084 2.769-1.456a.75.75 0 0 1 .698 0l2.77 1.456-.53-3.084a.75.75 0 0 1 .216-.664l2.24-2.183-3.096-.45a.75.75 0 0 1-.564-.41L8 2.694Z"></path> </svg><span data-view-component="true" class="d-inline"> Star </span> <span id="repo-stars-counter-star" aria-label="4565 users starred this repository" data-singular-suffix="user starred this repository" data-plural-suffix="users starred this repository" data-turbo-replace="true" title="4,565" data-view-component="true" class="Counter js-social-count">4.6k</span> </a></div> </li> </ul> </div> </div> <div id="responsive-meta-container" data-turbo-replace> </div> <nav data-pjax="#js-repo-pjax-container" aria-label="Repository" data-view-component="true" class="js-repo-nav js-sidenav-container-pjax js-responsive-underlinenav overflow-hidden UnderlineNav px-3 px-md-4 px-lg-5"> <ul data-view-component="true" class="UnderlineNav-body list-style-none"> <li data-view-component="true" class="d-inline-flex"> <a id="code-tab" href="/python/peps" data-tab-item="i0code-tab" data-selected-links="repo_source repo_downloads repo_commits repo_releases repo_tags repo_branches repo_packages repo_deployments repo_attestations /python/peps" data-pjax="#repo-content-pjax-container" data-turbo-frame="repo-content-turbo-frame" data-hotkey="g c" data-analytics-event="{&quot;category&quot;:&quot;Underline navbar&quot;,&quot;action&quot;:&quot;Click tab&quot;,&quot;label&quot;:&quot;Code&quot;,&quot;target&quot;:&quot;UNDERLINE_NAV.TAB&quot;}" aria-current="page" data-view-component="true" class="UnderlineNav-item no-wrap js-responsive-underlinenav-item js-selected-navigation-item selected"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-code UnderlineNav-octicon d-none d-sm-inline"> <path d="m11.28 3.22 4.25 4.25a.75.75 0 0 1 0 1.06l-4.25 4.25a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734L13.94 8l-3.72-3.72a.749.749 0 0 1 .326-1.275.749.749 0 0 1 .734.215Zm-6.56 0a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042L2.06 8l3.72 3.72a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L.47 8.53a.75.75 0 0 1 0-1.06Z"></path> </svg> <span data-content="Code">Code</span> <span id="code-repo-tab-count" data-pjax-replace="" data-turbo-replace="" title="Not available" data-view-component="true" class="Counter"></span> </a></li> <li data-view-component="true" class="d-inline-flex"> <a id="issues-tab" href="/python/peps/issues" data-tab-item="i1issues-tab" data-selected-links="repo_issues repo_labels repo_milestones /python/peps/issues" data-pjax="#repo-content-pjax-container" data-turbo-frame="repo-content-turbo-frame" data-hotkey="g i" data-analytics-event="{&quot;category&quot;:&quot;Underline navbar&quot;,&quot;action&quot;:&quot;Click tab&quot;,&quot;label&quot;:&quot;Issues&quot;,&quot;target&quot;:&quot;UNDERLINE_NAV.TAB&quot;}" data-view-component="true" class="UnderlineNav-item no-wrap js-responsive-underlinenav-item js-selected-navigation-item"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-issue-opened UnderlineNav-octicon d-none d-sm-inline"> <path d="M8 9.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z"></path><path d="M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM1.5 8a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0Z"></path> </svg> <span data-content="Issues">Issues</span> <span id="issues-repo-tab-count" data-pjax-replace="" data-turbo-replace="" title="20" data-view-component="true" class="Counter">20</span> </a></li> <li data-view-component="true" class="d-inline-flex"> <a id="pull-requests-tab" href="/python/peps/pulls" data-tab-item="i2pull-requests-tab" data-selected-links="repo_pulls checks /python/peps/pulls" data-pjax="#repo-content-pjax-container" data-turbo-frame="repo-content-turbo-frame" data-hotkey="g p" data-analytics-event="{&quot;category&quot;:&quot;Underline navbar&quot;,&quot;action&quot;:&quot;Click tab&quot;,&quot;label&quot;:&quot;Pull requests&quot;,&quot;target&quot;:&quot;UNDERLINE_NAV.TAB&quot;}" data-view-component="true" class="UnderlineNav-item no-wrap js-responsive-underlinenav-item js-selected-navigation-item"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-git-pull-request UnderlineNav-octicon d-none d-sm-inline"> <path d="M1.5 3.25a2.25 2.25 0 1 1 3 2.122v5.256a2.251 2.251 0 1 1-1.5 0V5.372A2.25 2.25 0 0 1 1.5 3.25Zm5.677-.177L9.573.677A.25.25 0 0 1 10 .854V2.5h1A2.5 2.5 0 0 1 13.5 5v5.628a2.251 2.251 0 1 1-1.5 0V5a1 1 0 0 0-1-1h-1v1.646a.25.25 0 0 1-.427.177L7.177 3.427a.25.25 0 0 1 0-.354ZM3.75 2.5a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5Zm0 9.5a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5Zm8.25.75a.75.75 0 1 0 1.5 0 .75.75 0 0 0-1.5 0Z"></path> </svg> <span data-content="Pull requests">Pull requests</span> <span id="pull-requests-repo-tab-count" data-pjax-replace="" data-turbo-replace="" title="33" data-view-component="true" class="Counter">33</span> </a></li> <li data-view-component="true" class="d-inline-flex"> <a id="actions-tab" href="/python/peps/actions" data-tab-item="i3actions-tab" data-selected-links="repo_actions /python/peps/actions" data-pjax="#repo-content-pjax-container" data-turbo-frame="repo-content-turbo-frame" data-hotkey="g a" data-analytics-event="{&quot;category&quot;:&quot;Underline navbar&quot;,&quot;action&quot;:&quot;Click tab&quot;,&quot;label&quot;:&quot;Actions&quot;,&quot;target&quot;:&quot;UNDERLINE_NAV.TAB&quot;}" data-view-component="true" class="UnderlineNav-item no-wrap js-responsive-underlinenav-item js-selected-navigation-item"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-play UnderlineNav-octicon d-none d-sm-inline"> <path d="M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM1.5 8a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0Zm4.879-2.773 4.264 2.559a.25.25 0 0 1 0 .428l-4.264 2.559A.25.25 0 0 1 6 10.559V5.442a.25.25 0 0 1 .379-.215Z"></path> </svg> <span data-content="Actions">Actions</span> <span id="actions-repo-tab-count" data-pjax-replace="" data-turbo-replace="" title="Not available" data-view-component="true" class="Counter"></span> </a></li> <li data-view-component="true" class="d-inline-flex"> <a id="security-tab" href="/python/peps/security" data-tab-item="i4security-tab" data-selected-links="security overview alerts policy token_scanning code_scanning /python/peps/security" data-pjax="#repo-content-pjax-container" data-turbo-frame="repo-content-turbo-frame" data-hotkey="g s" data-analytics-event="{&quot;category&quot;:&quot;Underline navbar&quot;,&quot;action&quot;:&quot;Click tab&quot;,&quot;label&quot;:&quot;Security&quot;,&quot;target&quot;:&quot;UNDERLINE_NAV.TAB&quot;}" data-view-component="true" class="UnderlineNav-item no-wrap js-responsive-underlinenav-item js-selected-navigation-item"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-shield UnderlineNav-octicon d-none d-sm-inline"> <path d="M7.467.133a1.748 1.748 0 0 1 1.066 0l5.25 1.68A1.75 1.75 0 0 1 15 3.48V7c0 1.566-.32 3.182-1.303 4.682-.983 1.498-2.585 2.813-5.032 3.855a1.697 1.697 0 0 1-1.33 0c-2.447-1.042-4.049-2.357-5.032-3.855C1.32 10.182 1 8.566 1 7V3.48a1.75 1.75 0 0 1 1.217-1.667Zm.61 1.429a.25.25 0 0 0-.153 0l-5.25 1.68a.25.25 0 0 0-.174.238V7c0 1.358.275 2.666 1.057 3.86.784 1.194 2.121 2.34 4.366 3.297a.196.196 0 0 0 .154 0c2.245-.956 3.582-2.104 4.366-3.298C13.225 9.666 13.5 8.36 13.5 7V3.48a.251.251 0 0 0-.174-.237l-5.25-1.68ZM8.75 4.75v3a.75.75 0 0 1-1.5 0v-3a.75.75 0 0 1 1.5 0ZM9 10.5a1 1 0 1 1-2 0 1 1 0 0 1 2 0Z"></path> </svg> <span data-content="Security">Security</span> <include-fragment src="/python/peps/security/overall-count" accept="text/fragment+html"></include-fragment> </a></li> <li data-view-component="true" class="d-inline-flex"> <a id="insights-tab" href="/python/peps/pulse" data-tab-item="i5insights-tab" data-selected-links="repo_graphs repo_contributors dependency_graph dependabot_updates pulse people community /python/peps/pulse" data-pjax="#repo-content-pjax-container" data-turbo-frame="repo-content-turbo-frame" data-analytics-event="{&quot;category&quot;:&quot;Underline navbar&quot;,&quot;action&quot;:&quot;Click tab&quot;,&quot;label&quot;:&quot;Insights&quot;,&quot;target&quot;:&quot;UNDERLINE_NAV.TAB&quot;}" data-view-component="true" class="UnderlineNav-item no-wrap js-responsive-underlinenav-item js-selected-navigation-item"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-graph UnderlineNav-octicon d-none d-sm-inline"> <path d="M1.5 1.75V13.5h13.75a.75.75 0 0 1 0 1.5H.75a.75.75 0 0 1-.75-.75V1.75a.75.75 0 0 1 1.5 0Zm14.28 2.53-5.25 5.25a.75.75 0 0 1-1.06 0L7 7.06 4.28 9.78a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042l3.25-3.25a.75.75 0 0 1 1.06 0L10 7.94l4.72-4.72a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042Z"></path> </svg> <span data-content="Insights">Insights</span> <span id="insights-repo-tab-count" data-pjax-replace="" data-turbo-replace="" title="Not available" data-view-component="true" class="Counter"></span> </a></li> </ul> <div style="visibility:hidden;" data-view-component="true" class="UnderlineNav-actions js-responsive-underlinenav-overflow position-absolute pr-3 pr-md-4 pr-lg-5 right-0"> <action-menu data-select-variant="none" data-view-component="true"> <focus-group direction="vertical" mnemonics retain> <button id="action-menu-e56d3e32-63b0-43c1-b0df-277fb96ebfea-button" popovertarget="action-menu-e56d3e32-63b0-43c1-b0df-277fb96ebfea-overlay" aria-controls="action-menu-e56d3e32-63b0-43c1-b0df-277fb96ebfea-list" aria-haspopup="true" aria-labelledby="tooltip-9551c6f3-2f5c-4ac7-977b-042c0d1aab1e" type="button" data-view-component="true" class="Button Button--iconOnly Button--secondary Button--medium UnderlineNav-item"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-kebab-horizontal Button-visual"> <path d="M8 9a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3ZM1.5 9a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Zm13 0a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z"></path> </svg> </button><tool-tip id="tooltip-9551c6f3-2f5c-4ac7-977b-042c0d1aab1e" for="action-menu-e56d3e32-63b0-43c1-b0df-277fb96ebfea-button" popover="manual" data-direction="s" data-type="label" data-view-component="true" class="sr-only position-absolute">Additional navigation options</tool-tip> <anchored-position data-target="action-menu.overlay" id="action-menu-e56d3e32-63b0-43c1-b0df-277fb96ebfea-overlay" anchor="action-menu-e56d3e32-63b0-43c1-b0df-277fb96ebfea-button" align="start" side="outside-bottom" anchor-offset="normal" popover="auto" data-view-component="true"> <div data-view-component="true" class="Overlay Overlay--size-auto"> <div data-view-component="true" class="Overlay-body Overlay-body--paddingNone"> <action-list> <div data-view-component="true"> <ul aria-labelledby="action-menu-e56d3e32-63b0-43c1-b0df-277fb96ebfea-button" id="action-menu-e56d3e32-63b0-43c1-b0df-277fb96ebfea-list" role="menu" data-view-component="true" class="ActionListWrap--inset ActionListWrap"> <li hidden="hidden" data-menu-item="i0code-tab" data-targets="action-list.items" role="none" data-view-component="true" class="ActionListItem"> <a tabindex="-1" id="item-9c7c1b51-84ba-4cf8-9503-2cc8414166cd" href="/python/peps" role="menuitem" data-view-component="true" class="ActionListContent ActionListContent--visual16"> <span class="ActionListItem-visual ActionListItem-visual--leading"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-code"> <path d="m11.28 3.22 4.25 4.25a.75.75 0 0 1 0 1.06l-4.25 4.25a.749.749 0 0 1-1.275-.326.749.749 0 0 1 .215-.734L13.94 8l-3.72-3.72a.749.749 0 0 1 .326-1.275.749.749 0 0 1 .734.215Zm-6.56 0a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042L2.06 8l3.72 3.72a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L.47 8.53a.75.75 0 0 1 0-1.06Z"></path> </svg> </span> <span data-view-component="true" class="ActionListItem-label"> Code </span> </a> </li> <li hidden="hidden" data-menu-item="i1issues-tab" data-targets="action-list.items" role="none" data-view-component="true" class="ActionListItem"> <a tabindex="-1" id="item-f281c9b7-aa78-426b-97d8-9e5f7438e91c" href="/python/peps/issues" role="menuitem" data-view-component="true" class="ActionListContent ActionListContent--visual16"> <span class="ActionListItem-visual ActionListItem-visual--leading"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-issue-opened"> <path d="M8 9.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z"></path><path d="M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM1.5 8a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0Z"></path> </svg> </span> <span data-view-component="true" class="ActionListItem-label"> Issues </span> </a> </li> <li hidden="hidden" data-menu-item="i2pull-requests-tab" data-targets="action-list.items" role="none" data-view-component="true" class="ActionListItem"> <a tabindex="-1" id="item-c103435d-9d9a-4d54-b242-daa822727a9b" href="/python/peps/pulls" role="menuitem" data-view-component="true" class="ActionListContent ActionListContent--visual16"> <span class="ActionListItem-visual ActionListItem-visual--leading"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-git-pull-request"> <path d="M1.5 3.25a2.25 2.25 0 1 1 3 2.122v5.256a2.251 2.251 0 1 1-1.5 0V5.372A2.25 2.25 0 0 1 1.5 3.25Zm5.677-.177L9.573.677A.25.25 0 0 1 10 .854V2.5h1A2.5 2.5 0 0 1 13.5 5v5.628a2.251 2.251 0 1 1-1.5 0V5a1 1 0 0 0-1-1h-1v1.646a.25.25 0 0 1-.427.177L7.177 3.427a.25.25 0 0 1 0-.354ZM3.75 2.5a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5Zm0 9.5a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5Zm8.25.75a.75.75 0 1 0 1.5 0 .75.75 0 0 0-1.5 0Z"></path> </svg> </span> <span data-view-component="true" class="ActionListItem-label"> Pull requests </span> </a> </li> <li hidden="hidden" data-menu-item="i3actions-tab" data-targets="action-list.items" role="none" data-view-component="true" class="ActionListItem"> <a tabindex="-1" id="item-1bbf5726-d47a-45c5-92c3-ddf0e510c97d" href="/python/peps/actions" role="menuitem" data-view-component="true" class="ActionListContent ActionListContent--visual16"> <span class="ActionListItem-visual ActionListItem-visual--leading"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-play"> <path d="M8 0a8 8 0 1 1 0 16A8 8 0 0 1 8 0ZM1.5 8a6.5 6.5 0 1 0 13 0 6.5 6.5 0 0 0-13 0Zm4.879-2.773 4.264 2.559a.25.25 0 0 1 0 .428l-4.264 2.559A.25.25 0 0 1 6 10.559V5.442a.25.25 0 0 1 .379-.215Z"></path> </svg> </span> <span data-view-component="true" class="ActionListItem-label"> Actions </span> </a> </li> <li hidden="hidden" data-menu-item="i4security-tab" data-targets="action-list.items" role="none" data-view-component="true" class="ActionListItem"> <a tabindex="-1" id="item-8a77d83a-427f-4778-a856-c44b46a45e7b" href="/python/peps/security" role="menuitem" data-view-component="true" class="ActionListContent ActionListContent--visual16"> <span class="ActionListItem-visual ActionListItem-visual--leading"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-shield"> <path d="M7.467.133a1.748 1.748 0 0 1 1.066 0l5.25 1.68A1.75 1.75 0 0 1 15 3.48V7c0 1.566-.32 3.182-1.303 4.682-.983 1.498-2.585 2.813-5.032 3.855a1.697 1.697 0 0 1-1.33 0c-2.447-1.042-4.049-2.357-5.032-3.855C1.32 10.182 1 8.566 1 7V3.48a1.75 1.75 0 0 1 1.217-1.667Zm.61 1.429a.25.25 0 0 0-.153 0l-5.25 1.68a.25.25 0 0 0-.174.238V7c0 1.358.275 2.666 1.057 3.86.784 1.194 2.121 2.34 4.366 3.297a.196.196 0 0 0 .154 0c2.245-.956 3.582-2.104 4.366-3.298C13.225 9.666 13.5 8.36 13.5 7V3.48a.251.251 0 0 0-.174-.237l-5.25-1.68ZM8.75 4.75v3a.75.75 0 0 1-1.5 0v-3a.75.75 0 0 1 1.5 0ZM9 10.5a1 1 0 1 1-2 0 1 1 0 0 1 2 0Z"></path> </svg> </span> <span data-view-component="true" class="ActionListItem-label"> Security </span> </a> </li> <li hidden="hidden" data-menu-item="i5insights-tab" data-targets="action-list.items" role="none" data-view-component="true" class="ActionListItem"> <a tabindex="-1" id="item-b1ae87ee-acb9-4fb9-b108-3126a0a26a7f" href="/python/peps/pulse" role="menuitem" data-view-component="true" class="ActionListContent ActionListContent--visual16"> <span class="ActionListItem-visual ActionListItem-visual--leading"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-graph"> <path d="M1.5 1.75V13.5h13.75a.75.75 0 0 1 0 1.5H.75a.75.75 0 0 1-.75-.75V1.75a.75.75 0 0 1 1.5 0Zm14.28 2.53-5.25 5.25a.75.75 0 0 1-1.06 0L7 7.06 4.28 9.78a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042l3.25-3.25a.75.75 0 0 1 1.06 0L10 7.94l4.72-4.72a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042Z"></path> </svg> </span> <span data-view-component="true" class="ActionListItem-label"> Insights </span> </a> </li> </ul> </div></action-list> </div> </div></anchored-position> </focus-group> </action-menu></div> </nav> </div> <turbo-frame id="repo-content-turbo-frame" target="_top" data-turbo-action="advance" class=""> <div id="repo-content-pjax-container" class="repository-content " > <react-app app-name="react-code-view" initial-path="/python/peps/blob/main/peps/pep-0327.rst" style="display: block; min-height: calc(100vh - 64px);" data-attempted-ssr="true" data-ssr="true" data-lazy="false" data-alternate="false" data-data-router-enabled="false" > <script type="application/json" data-target="react-app.embeddedData">{"payload":{"allShortcutsEnabled":false,"fileTree":{"peps":{"items":[{"name":"api","path":"peps/api","contentType":"directory"},{"name":"pep-0001","path":"peps/pep-0001","contentType":"directory"},{"name":"pep-0012","path":"peps/pep-0012","contentType":"directory"},{"name":"pep-0418","path":"peps/pep-0418","contentType":"directory"},{"name":"pep-0426","path":"peps/pep-0426","contentType":"directory"},{"name":"pep-0433","path":"peps/pep-0433","contentType":"directory"},{"name":"pep-0446","path":"peps/pep-0446","contentType":"directory"},{"name":"pep-0465","path":"peps/pep-0465","contentType":"directory"},{"name":"pep-0505","path":"peps/pep-0505","contentType":"directory"},{"name":"pep-0532","path":"peps/pep-0532","contentType":"directory"},{"name":"pep-0605","path":"peps/pep-0605","contentType":"directory"},{"name":"pep-0639","path":"peps/pep-0639","contentType":"directory"},{"name":"pep-0662","path":"peps/pep-0662","contentType":"directory"},{"name":"pep-0739","path":"peps/pep-0739","contentType":"directory"},{"name":"pep-0777","path":"peps/pep-0777","contentType":"directory"},{"name":"conf.py","path":"peps/conf.py","contentType":"file"},{"name":"contents.rst","path":"peps/contents.rst","contentType":"file"},{"name":"pep-0001.rst","path":"peps/pep-0001.rst","contentType":"file"},{"name":"pep-0002.rst","path":"peps/pep-0002.rst","contentType":"file"},{"name":"pep-0003.rst","path":"peps/pep-0003.rst","contentType":"file"},{"name":"pep-0004.rst","path":"peps/pep-0004.rst","contentType":"file"},{"name":"pep-0005.rst","path":"peps/pep-0005.rst","contentType":"file"},{"name":"pep-0006.rst","path":"peps/pep-0006.rst","contentType":"file"},{"name":"pep-0007.rst","path":"peps/pep-0007.rst","contentType":"file"},{"name":"pep-0008.rst","path":"peps/pep-0008.rst","contentType":"file"},{"name":"pep-0009.rst","path":"peps/pep-0009.rst","contentType":"file"},{"name":"pep-0010.rst","path":"peps/pep-0010.rst","contentType":"file"},{"name":"pep-0011.rst","path":"peps/pep-0011.rst","contentType":"file"},{"name":"pep-0012.rst","path":"peps/pep-0012.rst","contentType":"file"},{"name":"pep-0013.rst","path":"peps/pep-0013.rst","contentType":"file"},{"name":"pep-0020.rst","path":"peps/pep-0020.rst","contentType":"file"},{"name":"pep-0042.rst","path":"peps/pep-0042.rst","contentType":"file"},{"name":"pep-0100.rst","path":"peps/pep-0100.rst","contentType":"file"},{"name":"pep-0101.rst","path":"peps/pep-0101.rst","contentType":"file"},{"name":"pep-0102.rst","path":"peps/pep-0102.rst","contentType":"file"},{"name":"pep-0103.rst","path":"peps/pep-0103.rst","contentType":"file"},{"name":"pep-0160.rst","path":"peps/pep-0160.rst","contentType":"file"},{"name":"pep-0200.rst","path":"peps/pep-0200.rst","contentType":"file"},{"name":"pep-0201.rst","path":"peps/pep-0201.rst","contentType":"file"},{"name":"pep-0202.rst","path":"peps/pep-0202.rst","contentType":"file"},{"name":"pep-0203.rst","path":"peps/pep-0203.rst","contentType":"file"},{"name":"pep-0204.rst","path":"peps/pep-0204.rst","contentType":"file"},{"name":"pep-0205.rst","path":"peps/pep-0205.rst","contentType":"file"},{"name":"pep-0206.rst","path":"peps/pep-0206.rst","contentType":"file"},{"name":"pep-0207.rst","path":"peps/pep-0207.rst","contentType":"file"},{"name":"pep-0208.rst","path":"peps/pep-0208.rst","contentType":"file"},{"name":"pep-0209.rst","path":"peps/pep-0209.rst","contentType":"file"},{"name":"pep-0210.rst","path":"peps/pep-0210.rst","contentType":"file"},{"name":"pep-0211.rst","path":"peps/pep-0211.rst","contentType":"file"},{"name":"pep-0212.rst","path":"peps/pep-0212.rst","contentType":"file"},{"name":"pep-0213.rst","path":"peps/pep-0213.rst","contentType":"file"},{"name":"pep-0214.rst","path":"peps/pep-0214.rst","contentType":"file"},{"name":"pep-0215.rst","path":"peps/pep-0215.rst","contentType":"file"},{"name":"pep-0216.rst","path":"peps/pep-0216.rst","contentType":"file"},{"name":"pep-0217.rst","path":"peps/pep-0217.rst","contentType":"file"},{"name":"pep-0218.rst","path":"peps/pep-0218.rst","contentType":"file"},{"name":"pep-0219.rst","path":"peps/pep-0219.rst","contentType":"file"},{"name":"pep-0220.rst","path":"peps/pep-0220.rst","contentType":"file"},{"name":"pep-0221.rst","path":"peps/pep-0221.rst","contentType":"file"},{"name":"pep-0222.rst","path":"peps/pep-0222.rst","contentType":"file"},{"name":"pep-0223.rst","path":"peps/pep-0223.rst","contentType":"file"},{"name":"pep-0224.rst","path":"peps/pep-0224.rst","contentType":"file"},{"name":"pep-0225.rst","path":"peps/pep-0225.rst","contentType":"file"},{"name":"pep-0226.rst","path":"peps/pep-0226.rst","contentType":"file"},{"name":"pep-0227.rst","path":"peps/pep-0227.rst","contentType":"file"},{"name":"pep-0228.rst","path":"peps/pep-0228.rst","contentType":"file"},{"name":"pep-0229.rst","path":"peps/pep-0229.rst","contentType":"file"},{"name":"pep-0230.rst","path":"peps/pep-0230.rst","contentType":"file"},{"name":"pep-0231.rst","path":"peps/pep-0231.rst","contentType":"file"},{"name":"pep-0232.rst","path":"peps/pep-0232.rst","contentType":"file"},{"name":"pep-0233.rst","path":"peps/pep-0233.rst","contentType":"file"},{"name":"pep-0234.rst","path":"peps/pep-0234.rst","contentType":"file"},{"name":"pep-0235.rst","path":"peps/pep-0235.rst","contentType":"file"},{"name":"pep-0236.rst","path":"peps/pep-0236.rst","contentType":"file"},{"name":"pep-0237.rst","path":"peps/pep-0237.rst","contentType":"file"},{"name":"pep-0238.rst","path":"peps/pep-0238.rst","contentType":"file"},{"name":"pep-0239.rst","path":"peps/pep-0239.rst","contentType":"file"},{"name":"pep-0240.rst","path":"peps/pep-0240.rst","contentType":"file"},{"name":"pep-0241.rst","path":"peps/pep-0241.rst","contentType":"file"},{"name":"pep-0242.rst","path":"peps/pep-0242.rst","contentType":"file"},{"name":"pep-0243.rst","path":"peps/pep-0243.rst","contentType":"file"},{"name":"pep-0244.rst","path":"peps/pep-0244.rst","contentType":"file"},{"name":"pep-0245.rst","path":"peps/pep-0245.rst","contentType":"file"},{"name":"pep-0246.rst","path":"peps/pep-0246.rst","contentType":"file"},{"name":"pep-0247.rst","path":"peps/pep-0247.rst","contentType":"file"},{"name":"pep-0248.rst","path":"peps/pep-0248.rst","contentType":"file"},{"name":"pep-0249.rst","path":"peps/pep-0249.rst","contentType":"file"},{"name":"pep-0250.rst","path":"peps/pep-0250.rst","contentType":"file"},{"name":"pep-0251.rst","path":"peps/pep-0251.rst","contentType":"file"},{"name":"pep-0252.rst","path":"peps/pep-0252.rst","contentType":"file"},{"name":"pep-0253.rst","path":"peps/pep-0253.rst","contentType":"file"},{"name":"pep-0254.rst","path":"peps/pep-0254.rst","contentType":"file"},{"name":"pep-0255.rst","path":"peps/pep-0255.rst","contentType":"file"},{"name":"pep-0256.rst","path":"peps/pep-0256.rst","contentType":"file"},{"name":"pep-0257.rst","path":"peps/pep-0257.rst","contentType":"file"},{"name":"pep-0258.rst","path":"peps/pep-0258.rst","contentType":"file"},{"name":"pep-0259.rst","path":"peps/pep-0259.rst","contentType":"file"},{"name":"pep-0260.rst","path":"peps/pep-0260.rst","contentType":"file"},{"name":"pep-0261.rst","path":"peps/pep-0261.rst","contentType":"file"},{"name":"pep-0262.rst","path":"peps/pep-0262.rst","contentType":"file"},{"name":"pep-0263.rst","path":"peps/pep-0263.rst","contentType":"file"},{"name":"pep-0264.rst","path":"peps/pep-0264.rst","contentType":"file"},{"name":"pep-0265.rst","path":"peps/pep-0265.rst","contentType":"file"},{"name":"pep-0266.rst","path":"peps/pep-0266.rst","contentType":"file"},{"name":"pep-0267.rst","path":"peps/pep-0267.rst","contentType":"file"},{"name":"pep-0268.rst","path":"peps/pep-0268.rst","contentType":"file"},{"name":"pep-0269.rst","path":"peps/pep-0269.rst","contentType":"file"},{"name":"pep-0270.rst","path":"peps/pep-0270.rst","contentType":"file"},{"name":"pep-0271.rst","path":"peps/pep-0271.rst","contentType":"file"},{"name":"pep-0272.rst","path":"peps/pep-0272.rst","contentType":"file"},{"name":"pep-0273.rst","path":"peps/pep-0273.rst","contentType":"file"},{"name":"pep-0274.rst","path":"peps/pep-0274.rst","contentType":"file"},{"name":"pep-0275.rst","path":"peps/pep-0275.rst","contentType":"file"},{"name":"pep-0276.rst","path":"peps/pep-0276.rst","contentType":"file"},{"name":"pep-0277.rst","path":"peps/pep-0277.rst","contentType":"file"},{"name":"pep-0278.rst","path":"peps/pep-0278.rst","contentType":"file"},{"name":"pep-0279.rst","path":"peps/pep-0279.rst","contentType":"file"},{"name":"pep-0280.rst","path":"peps/pep-0280.rst","contentType":"file"},{"name":"pep-0281.rst","path":"peps/pep-0281.rst","contentType":"file"},{"name":"pep-0282.rst","path":"peps/pep-0282.rst","contentType":"file"},{"name":"pep-0283.rst","path":"peps/pep-0283.rst","contentType":"file"},{"name":"pep-0284.rst","path":"peps/pep-0284.rst","contentType":"file"},{"name":"pep-0285.rst","path":"peps/pep-0285.rst","contentType":"file"},{"name":"pep-0286.rst","path":"peps/pep-0286.rst","contentType":"file"},{"name":"pep-0287.rst","path":"peps/pep-0287.rst","contentType":"file"},{"name":"pep-0288.rst","path":"peps/pep-0288.rst","contentType":"file"},{"name":"pep-0289.rst","path":"peps/pep-0289.rst","contentType":"file"},{"name":"pep-0290.rst","path":"peps/pep-0290.rst","contentType":"file"},{"name":"pep-0291.rst","path":"peps/pep-0291.rst","contentType":"file"},{"name":"pep-0292.rst","path":"peps/pep-0292.rst","contentType":"file"},{"name":"pep-0293.rst","path":"peps/pep-0293.rst","contentType":"file"},{"name":"pep-0294.rst","path":"peps/pep-0294.rst","contentType":"file"},{"name":"pep-0295.rst","path":"peps/pep-0295.rst","contentType":"file"},{"name":"pep-0296.rst","path":"peps/pep-0296.rst","contentType":"file"},{"name":"pep-0297.rst","path":"peps/pep-0297.rst","contentType":"file"},{"name":"pep-0298.rst","path":"peps/pep-0298.rst","contentType":"file"},{"name":"pep-0299.rst","path":"peps/pep-0299.rst","contentType":"file"},{"name":"pep-0301.rst","path":"peps/pep-0301.rst","contentType":"file"},{"name":"pep-0302.rst","path":"peps/pep-0302.rst","contentType":"file"},{"name":"pep-0303.rst","path":"peps/pep-0303.rst","contentType":"file"},{"name":"pep-0304.rst","path":"peps/pep-0304.rst","contentType":"file"},{"name":"pep-0305.rst","path":"peps/pep-0305.rst","contentType":"file"},{"name":"pep-0306.rst","path":"peps/pep-0306.rst","contentType":"file"},{"name":"pep-0307.rst","path":"peps/pep-0307.rst","contentType":"file"},{"name":"pep-0308.rst","path":"peps/pep-0308.rst","contentType":"file"},{"name":"pep-0309.rst","path":"peps/pep-0309.rst","contentType":"file"},{"name":"pep-0310.rst","path":"peps/pep-0310.rst","contentType":"file"},{"name":"pep-0311.rst","path":"peps/pep-0311.rst","contentType":"file"},{"name":"pep-0312.rst","path":"peps/pep-0312.rst","contentType":"file"},{"name":"pep-0313.rst","path":"peps/pep-0313.rst","contentType":"file"},{"name":"pep-0314.rst","path":"peps/pep-0314.rst","contentType":"file"},{"name":"pep-0315.rst","path":"peps/pep-0315.rst","contentType":"file"},{"name":"pep-0316.rst","path":"peps/pep-0316.rst","contentType":"file"},{"name":"pep-0317.rst","path":"peps/pep-0317.rst","contentType":"file"},{"name":"pep-0318.rst","path":"peps/pep-0318.rst","contentType":"file"},{"name":"pep-0319.rst","path":"peps/pep-0319.rst","contentType":"file"},{"name":"pep-0320.rst","path":"peps/pep-0320.rst","contentType":"file"},{"name":"pep-0321.rst","path":"peps/pep-0321.rst","contentType":"file"},{"name":"pep-0322.rst","path":"peps/pep-0322.rst","contentType":"file"},{"name":"pep-0323.rst","path":"peps/pep-0323.rst","contentType":"file"},{"name":"pep-0324.rst","path":"peps/pep-0324.rst","contentType":"file"},{"name":"pep-0325.rst","path":"peps/pep-0325.rst","contentType":"file"},{"name":"pep-0326.rst","path":"peps/pep-0326.rst","contentType":"file"},{"name":"pep-0327.rst","path":"peps/pep-0327.rst","contentType":"file"},{"name":"pep-0328.rst","path":"peps/pep-0328.rst","contentType":"file"},{"name":"pep-0329.rst","path":"peps/pep-0329.rst","contentType":"file"},{"name":"pep-0330.rst","path":"peps/pep-0330.rst","contentType":"file"},{"name":"pep-0331.rst","path":"peps/pep-0331.rst","contentType":"file"},{"name":"pep-0332.rst","path":"peps/pep-0332.rst","contentType":"file"},{"name":"pep-0333.rst","path":"peps/pep-0333.rst","contentType":"file"},{"name":"pep-0334.rst","path":"peps/pep-0334.rst","contentType":"file"},{"name":"pep-0335.rst","path":"peps/pep-0335.rst","contentType":"file"},{"name":"pep-0336.rst","path":"peps/pep-0336.rst","contentType":"file"},{"name":"pep-0337.rst","path":"peps/pep-0337.rst","contentType":"file"},{"name":"pep-0338.rst","path":"peps/pep-0338.rst","contentType":"file"},{"name":"pep-0339.rst","path":"peps/pep-0339.rst","contentType":"file"},{"name":"pep-0340.rst","path":"peps/pep-0340.rst","contentType":"file"},{"name":"pep-0341.rst","path":"peps/pep-0341.rst","contentType":"file"},{"name":"pep-0342.rst","path":"peps/pep-0342.rst","contentType":"file"},{"name":"pep-0343.rst","path":"peps/pep-0343.rst","contentType":"file"},{"name":"pep-0344.rst","path":"peps/pep-0344.rst","contentType":"file"},{"name":"pep-0345.rst","path":"peps/pep-0345.rst","contentType":"file"},{"name":"pep-0346.rst","path":"peps/pep-0346.rst","contentType":"file"},{"name":"pep-0347.rst","path":"peps/pep-0347.rst","contentType":"file"},{"name":"pep-0348.rst","path":"peps/pep-0348.rst","contentType":"file"},{"name":"pep-0349.rst","path":"peps/pep-0349.rst","contentType":"file"},{"name":"pep-0350.rst","path":"peps/pep-0350.rst","contentType":"file"},{"name":"pep-0351.rst","path":"peps/pep-0351.rst","contentType":"file"},{"name":"pep-0352.rst","path":"peps/pep-0352.rst","contentType":"file"},{"name":"pep-0353.rst","path":"peps/pep-0353.rst","contentType":"file"},{"name":"pep-0354.rst","path":"peps/pep-0354.rst","contentType":"file"},{"name":"pep-0355.rst","path":"peps/pep-0355.rst","contentType":"file"},{"name":"pep-0356.rst","path":"peps/pep-0356.rst","contentType":"file"},{"name":"pep-0357.rst","path":"peps/pep-0357.rst","contentType":"file"},{"name":"pep-0358.rst","path":"peps/pep-0358.rst","contentType":"file"},{"name":"pep-0359.rst","path":"peps/pep-0359.rst","contentType":"file"},{"name":"pep-0360.rst","path":"peps/pep-0360.rst","contentType":"file"},{"name":"pep-0361.rst","path":"peps/pep-0361.rst","contentType":"file"},{"name":"pep-0362.rst","path":"peps/pep-0362.rst","contentType":"file"},{"name":"pep-0363.rst","path":"peps/pep-0363.rst","contentType":"file"},{"name":"pep-0364.rst","path":"peps/pep-0364.rst","contentType":"file"},{"name":"pep-0365.rst","path":"peps/pep-0365.rst","contentType":"file"},{"name":"pep-0366.rst","path":"peps/pep-0366.rst","contentType":"file"},{"name":"pep-0367.rst","path":"peps/pep-0367.rst","contentType":"file"},{"name":"pep-0368.rst","path":"peps/pep-0368.rst","contentType":"file"},{"name":"pep-0369.rst","path":"peps/pep-0369.rst","contentType":"file"},{"name":"pep-0370.rst","path":"peps/pep-0370.rst","contentType":"file"},{"name":"pep-0371.rst","path":"peps/pep-0371.rst","contentType":"file"},{"name":"pep-0372.rst","path":"peps/pep-0372.rst","contentType":"file"},{"name":"pep-0373.rst","path":"peps/pep-0373.rst","contentType":"file"},{"name":"pep-0374.rst","path":"peps/pep-0374.rst","contentType":"file"},{"name":"pep-0375.rst","path":"peps/pep-0375.rst","contentType":"file"},{"name":"pep-0376.rst","path":"peps/pep-0376.rst","contentType":"file"},{"name":"pep-0377.rst","path":"peps/pep-0377.rst","contentType":"file"},{"name":"pep-0378.rst","path":"peps/pep-0378.rst","contentType":"file"},{"name":"pep-0379.rst","path":"peps/pep-0379.rst","contentType":"file"},{"name":"pep-0380.rst","path":"peps/pep-0380.rst","contentType":"file"},{"name":"pep-0381.rst","path":"peps/pep-0381.rst","contentType":"file"},{"name":"pep-0382.rst","path":"peps/pep-0382.rst","contentType":"file"},{"name":"pep-0383.rst","path":"peps/pep-0383.rst","contentType":"file"},{"name":"pep-0384.rst","path":"peps/pep-0384.rst","contentType":"file"},{"name":"pep-0385.rst","path":"peps/pep-0385.rst","contentType":"file"},{"name":"pep-0386.rst","path":"peps/pep-0386.rst","contentType":"file"},{"name":"pep-0387.rst","path":"peps/pep-0387.rst","contentType":"file"},{"name":"pep-0389.rst","path":"peps/pep-0389.rst","contentType":"file"},{"name":"pep-0390.rst","path":"peps/pep-0390.rst","contentType":"file"},{"name":"pep-0391.rst","path":"peps/pep-0391.rst","contentType":"file"},{"name":"pep-0392.rst","path":"peps/pep-0392.rst","contentType":"file"},{"name":"pep-0393.rst","path":"peps/pep-0393.rst","contentType":"file"},{"name":"pep-0394.rst","path":"peps/pep-0394.rst","contentType":"file"},{"name":"pep-0395.rst","path":"peps/pep-0395.rst","contentType":"file"},{"name":"pep-0396.rst","path":"peps/pep-0396.rst","contentType":"file"},{"name":"pep-0397.rst","path":"peps/pep-0397.rst","contentType":"file"},{"name":"pep-0398.rst","path":"peps/pep-0398.rst","contentType":"file"},{"name":"pep-0399.rst","path":"peps/pep-0399.rst","contentType":"file"},{"name":"pep-0400.rst","path":"peps/pep-0400.rst","contentType":"file"},{"name":"pep-0401.rst","path":"peps/pep-0401.rst","contentType":"file"},{"name":"pep-0402.rst","path":"peps/pep-0402.rst","contentType":"file"},{"name":"pep-0403.rst","path":"peps/pep-0403.rst","contentType":"file"},{"name":"pep-0404.rst","path":"peps/pep-0404.rst","contentType":"file"},{"name":"pep-0405.rst","path":"peps/pep-0405.rst","contentType":"file"},{"name":"pep-0406.rst","path":"peps/pep-0406.rst","contentType":"file"},{"name":"pep-0407.rst","path":"peps/pep-0407.rst","contentType":"file"},{"name":"pep-0408.rst","path":"peps/pep-0408.rst","contentType":"file"},{"name":"pep-0409.rst","path":"peps/pep-0409.rst","contentType":"file"},{"name":"pep-0410.rst","path":"peps/pep-0410.rst","contentType":"file"},{"name":"pep-0411.rst","path":"peps/pep-0411.rst","contentType":"file"},{"name":"pep-0412.rst","path":"peps/pep-0412.rst","contentType":"file"},{"name":"pep-0413.rst","path":"peps/pep-0413.rst","contentType":"file"},{"name":"pep-0414.rst","path":"peps/pep-0414.rst","contentType":"file"},{"name":"pep-0415.rst","path":"peps/pep-0415.rst","contentType":"file"},{"name":"pep-0416.rst","path":"peps/pep-0416.rst","contentType":"file"},{"name":"pep-0417.rst","path":"peps/pep-0417.rst","contentType":"file"},{"name":"pep-0418.rst","path":"peps/pep-0418.rst","contentType":"file"},{"name":"pep-0419.rst","path":"peps/pep-0419.rst","contentType":"file"},{"name":"pep-0420.rst","path":"peps/pep-0420.rst","contentType":"file"},{"name":"pep-0421.rst","path":"peps/pep-0421.rst","contentType":"file"},{"name":"pep-0422.rst","path":"peps/pep-0422.rst","contentType":"file"},{"name":"pep-0423.rst","path":"peps/pep-0423.rst","contentType":"file"},{"name":"pep-0424.rst","path":"peps/pep-0424.rst","contentType":"file"},{"name":"pep-0425.rst","path":"peps/pep-0425.rst","contentType":"file"},{"name":"pep-0426.rst","path":"peps/pep-0426.rst","contentType":"file"},{"name":"pep-0427.rst","path":"peps/pep-0427.rst","contentType":"file"},{"name":"pep-0428.rst","path":"peps/pep-0428.rst","contentType":"file"},{"name":"pep-0429.rst","path":"peps/pep-0429.rst","contentType":"file"},{"name":"pep-0430.rst","path":"peps/pep-0430.rst","contentType":"file"},{"name":"pep-0431.rst","path":"peps/pep-0431.rst","contentType":"file"},{"name":"pep-0432.rst","path":"peps/pep-0432.rst","contentType":"file"},{"name":"pep-0433.rst","path":"peps/pep-0433.rst","contentType":"file"},{"name":"pep-0434.rst","path":"peps/pep-0434.rst","contentType":"file"},{"name":"pep-0435.rst","path":"peps/pep-0435.rst","contentType":"file"},{"name":"pep-0436.rst","path":"peps/pep-0436.rst","contentType":"file"},{"name":"pep-0437.rst","path":"peps/pep-0437.rst","contentType":"file"},{"name":"pep-0438.rst","path":"peps/pep-0438.rst","contentType":"file"},{"name":"pep-0439.rst","path":"peps/pep-0439.rst","contentType":"file"},{"name":"pep-0440.rst","path":"peps/pep-0440.rst","contentType":"file"},{"name":"pep-0441.rst","path":"peps/pep-0441.rst","contentType":"file"},{"name":"pep-0442.rst","path":"peps/pep-0442.rst","contentType":"file"},{"name":"pep-0443.rst","path":"peps/pep-0443.rst","contentType":"file"},{"name":"pep-0444.rst","path":"peps/pep-0444.rst","contentType":"file"},{"name":"pep-0445.rst","path":"peps/pep-0445.rst","contentType":"file"},{"name":"pep-0446.rst","path":"peps/pep-0446.rst","contentType":"file"},{"name":"pep-0447.rst","path":"peps/pep-0447.rst","contentType":"file"},{"name":"pep-0448.rst","path":"peps/pep-0448.rst","contentType":"file"},{"name":"pep-0449.rst","path":"peps/pep-0449.rst","contentType":"file"},{"name":"pep-0450.rst","path":"peps/pep-0450.rst","contentType":"file"},{"name":"pep-0451.rst","path":"peps/pep-0451.rst","contentType":"file"},{"name":"pep-0452.rst","path":"peps/pep-0452.rst","contentType":"file"},{"name":"pep-0453.rst","path":"peps/pep-0453.rst","contentType":"file"},{"name":"pep-0454.rst","path":"peps/pep-0454.rst","contentType":"file"},{"name":"pep-0455.rst","path":"peps/pep-0455.rst","contentType":"file"},{"name":"pep-0456.rst","path":"peps/pep-0456.rst","contentType":"file"},{"name":"pep-0457.rst","path":"peps/pep-0457.rst","contentType":"file"},{"name":"pep-0458-1.png","path":"peps/pep-0458-1.png","contentType":"file"},{"name":"pep-0458.rst","path":"peps/pep-0458.rst","contentType":"file"},{"name":"pep-0459.rst","path":"peps/pep-0459.rst","contentType":"file"},{"name":"pep-0460.rst","path":"peps/pep-0460.rst","contentType":"file"},{"name":"pep-0461.rst","path":"peps/pep-0461.rst","contentType":"file"},{"name":"pep-0462.rst","path":"peps/pep-0462.rst","contentType":"file"},{"name":"pep-0463.rst","path":"peps/pep-0463.rst","contentType":"file"},{"name":"pep-0464.rst","path":"peps/pep-0464.rst","contentType":"file"},{"name":"pep-0465.rst","path":"peps/pep-0465.rst","contentType":"file"},{"name":"pep-0466.rst","path":"peps/pep-0466.rst","contentType":"file"},{"name":"pep-0467.rst","path":"peps/pep-0467.rst","contentType":"file"},{"name":"pep-0468.rst","path":"peps/pep-0468.rst","contentType":"file"},{"name":"pep-0469.rst","path":"peps/pep-0469.rst","contentType":"file"},{"name":"pep-0470.rst","path":"peps/pep-0470.rst","contentType":"file"},{"name":"pep-0471.rst","path":"peps/pep-0471.rst","contentType":"file"},{"name":"pep-0472.rst","path":"peps/pep-0472.rst","contentType":"file"},{"name":"pep-0473.rst","path":"peps/pep-0473.rst","contentType":"file"},{"name":"pep-0474.rst","path":"peps/pep-0474.rst","contentType":"file"},{"name":"pep-0475.rst","path":"peps/pep-0475.rst","contentType":"file"},{"name":"pep-0476.rst","path":"peps/pep-0476.rst","contentType":"file"},{"name":"pep-0477.rst","path":"peps/pep-0477.rst","contentType":"file"},{"name":"pep-0478.rst","path":"peps/pep-0478.rst","contentType":"file"},{"name":"pep-0479.rst","path":"peps/pep-0479.rst","contentType":"file"},{"name":"pep-0480-1.png","path":"peps/pep-0480-1.png","contentType":"file"},{"name":"pep-0480.rst","path":"peps/pep-0480.rst","contentType":"file"},{"name":"pep-0481.rst","path":"peps/pep-0481.rst","contentType":"file"},{"name":"pep-0482.rst","path":"peps/pep-0482.rst","contentType":"file"},{"name":"pep-0483.rst","path":"peps/pep-0483.rst","contentType":"file"},{"name":"pep-0484.rst","path":"peps/pep-0484.rst","contentType":"file"},{"name":"pep-0485.rst","path":"peps/pep-0485.rst","contentType":"file"},{"name":"pep-0486.rst","path":"peps/pep-0486.rst","contentType":"file"},{"name":"pep-0487.rst","path":"peps/pep-0487.rst","contentType":"file"},{"name":"pep-0488.rst","path":"peps/pep-0488.rst","contentType":"file"},{"name":"pep-0489.rst","path":"peps/pep-0489.rst","contentType":"file"},{"name":"pep-0490.rst","path":"peps/pep-0490.rst","contentType":"file"},{"name":"pep-0491.rst","path":"peps/pep-0491.rst","contentType":"file"},{"name":"pep-0492.rst","path":"peps/pep-0492.rst","contentType":"file"},{"name":"pep-0493.rst","path":"peps/pep-0493.rst","contentType":"file"},{"name":"pep-0494.rst","path":"peps/pep-0494.rst","contentType":"file"},{"name":"pep-0495-daylightsavings.png","path":"peps/pep-0495-daylightsavings.png","contentType":"file"},{"name":"pep-0495-fold.svg","path":"peps/pep-0495-fold.svg","contentType":"file"},{"name":"pep-0495-gap.svg","path":"peps/pep-0495-gap.svg","contentType":"file"},{"name":"pep-0495.rst","path":"peps/pep-0495.rst","contentType":"file"},{"name":"pep-0496.rst","path":"peps/pep-0496.rst","contentType":"file"},{"name":"pep-0497.rst","path":"peps/pep-0497.rst","contentType":"file"},{"name":"pep-0498.rst","path":"peps/pep-0498.rst","contentType":"file"},{"name":"pep-0499.rst","path":"peps/pep-0499.rst","contentType":"file"},{"name":"pep-0500.rst","path":"peps/pep-0500.rst","contentType":"file"},{"name":"pep-0501.rst","path":"peps/pep-0501.rst","contentType":"file"},{"name":"pep-0502.rst","path":"peps/pep-0502.rst","contentType":"file"},{"name":"pep-0503.rst","path":"peps/pep-0503.rst","contentType":"file"},{"name":"pep-0504.rst","path":"peps/pep-0504.rst","contentType":"file"},{"name":"pep-0505.rst","path":"peps/pep-0505.rst","contentType":"file"},{"name":"pep-0506.rst","path":"peps/pep-0506.rst","contentType":"file"},{"name":"pep-0507.rst","path":"peps/pep-0507.rst","contentType":"file"},{"name":"pep-0508.rst","path":"peps/pep-0508.rst","contentType":"file"},{"name":"pep-0509.rst","path":"peps/pep-0509.rst","contentType":"file"},{"name":"pep-0510.rst","path":"peps/pep-0510.rst","contentType":"file"},{"name":"pep-0511.rst","path":"peps/pep-0511.rst","contentType":"file"},{"name":"pep-0512.rst","path":"peps/pep-0512.rst","contentType":"file"},{"name":"pep-0513.rst","path":"peps/pep-0513.rst","contentType":"file"},{"name":"pep-0514.rst","path":"peps/pep-0514.rst","contentType":"file"},{"name":"pep-0515.rst","path":"peps/pep-0515.rst","contentType":"file"},{"name":"pep-0516.rst","path":"peps/pep-0516.rst","contentType":"file"},{"name":"pep-0517.rst","path":"peps/pep-0517.rst","contentType":"file"},{"name":"pep-0518.rst","path":"peps/pep-0518.rst","contentType":"file"},{"name":"pep-0519.rst","path":"peps/pep-0519.rst","contentType":"file"},{"name":"pep-0520.rst","path":"peps/pep-0520.rst","contentType":"file"},{"name":"pep-0521.rst","path":"peps/pep-0521.rst","contentType":"file"},{"name":"pep-0522.rst","path":"peps/pep-0522.rst","contentType":"file"},{"name":"pep-0523.rst","path":"peps/pep-0523.rst","contentType":"file"},{"name":"pep-0524.rst","path":"peps/pep-0524.rst","contentType":"file"},{"name":"pep-0525-1.png","path":"peps/pep-0525-1.png","contentType":"file"},{"name":"pep-0525.rst","path":"peps/pep-0525.rst","contentType":"file"},{"name":"pep-0526.rst","path":"peps/pep-0526.rst","contentType":"file"},{"name":"pep-0527.rst","path":"peps/pep-0527.rst","contentType":"file"},{"name":"pep-0528.rst","path":"peps/pep-0528.rst","contentType":"file"},{"name":"pep-0529.rst","path":"peps/pep-0529.rst","contentType":"file"},{"name":"pep-0530.rst","path":"peps/pep-0530.rst","contentType":"file"},{"name":"pep-0531.rst","path":"peps/pep-0531.rst","contentType":"file"},{"name":"pep-0532.rst","path":"peps/pep-0532.rst","contentType":"file"},{"name":"pep-0533.rst","path":"peps/pep-0533.rst","contentType":"file"},{"name":"pep-0534.rst","path":"peps/pep-0534.rst","contentType":"file"},{"name":"pep-0535.rst","path":"peps/pep-0535.rst","contentType":"file"},{"name":"pep-0536.rst","path":"peps/pep-0536.rst","contentType":"file"},{"name":"pep-0537.rst","path":"peps/pep-0537.rst","contentType":"file"},{"name":"pep-0538.rst","path":"peps/pep-0538.rst","contentType":"file"},{"name":"pep-0539.rst","path":"peps/pep-0539.rst","contentType":"file"},{"name":"pep-0540.rst","path":"peps/pep-0540.rst","contentType":"file"},{"name":"pep-0541.rst","path":"peps/pep-0541.rst","contentType":"file"},{"name":"pep-0542.rst","path":"peps/pep-0542.rst","contentType":"file"},{"name":"pep-0543.rst","path":"peps/pep-0543.rst","contentType":"file"},{"name":"pep-0544.rst","path":"peps/pep-0544.rst","contentType":"file"},{"name":"pep-0545.rst","path":"peps/pep-0545.rst","contentType":"file"},{"name":"pep-0546.rst","path":"peps/pep-0546.rst","contentType":"file"},{"name":"pep-0547.rst","path":"peps/pep-0547.rst","contentType":"file"},{"name":"pep-0548.rst","path":"peps/pep-0548.rst","contentType":"file"},{"name":"pep-0549.rst","path":"peps/pep-0549.rst","contentType":"file"},{"name":"pep-0550-hamt_vs_dict-v2.png","path":"peps/pep-0550-hamt_vs_dict-v2.png","contentType":"file"},{"name":"pep-0550-hamt_vs_dict.png","path":"peps/pep-0550-hamt_vs_dict.png","contentType":"file"},{"name":"pep-0550-lookup_hamt.png","path":"peps/pep-0550-lookup_hamt.png","contentType":"file"},{"name":"pep-0550.rst","path":"peps/pep-0550.rst","contentType":"file"},{"name":"pep-0551.rst","path":"peps/pep-0551.rst","contentType":"file"},{"name":"pep-0552.rst","path":"peps/pep-0552.rst","contentType":"file"},{"name":"pep-0553.rst","path":"peps/pep-0553.rst","contentType":"file"},{"name":"pep-0554.rst","path":"peps/pep-0554.rst","contentType":"file"},{"name":"pep-0555.rst","path":"peps/pep-0555.rst","contentType":"file"},{"name":"pep-0556.rst","path":"peps/pep-0556.rst","contentType":"file"},{"name":"pep-0557.rst","path":"peps/pep-0557.rst","contentType":"file"},{"name":"pep-0558.rst","path":"peps/pep-0558.rst","contentType":"file"},{"name":"pep-0559.rst","path":"peps/pep-0559.rst","contentType":"file"},{"name":"pep-0560.rst","path":"peps/pep-0560.rst","contentType":"file"},{"name":"pep-0561.rst","path":"peps/pep-0561.rst","contentType":"file"},{"name":"pep-0562.rst","path":"peps/pep-0562.rst","contentType":"file"},{"name":"pep-0563.rst","path":"peps/pep-0563.rst","contentType":"file"},{"name":"pep-0564.rst","path":"peps/pep-0564.rst","contentType":"file"},{"name":"pep-0565.rst","path":"peps/pep-0565.rst","contentType":"file"},{"name":"pep-0566.rst","path":"peps/pep-0566.rst","contentType":"file"},{"name":"pep-0567.rst","path":"peps/pep-0567.rst","contentType":"file"},{"name":"pep-0568.rst","path":"peps/pep-0568.rst","contentType":"file"},{"name":"pep-0569.rst","path":"peps/pep-0569.rst","contentType":"file"},{"name":"pep-0570.rst","path":"peps/pep-0570.rst","contentType":"file"},{"name":"pep-0571.rst","path":"peps/pep-0571.rst","contentType":"file"},{"name":"pep-0572.rst","path":"peps/pep-0572.rst","contentType":"file"},{"name":"pep-0573.rst","path":"peps/pep-0573.rst","contentType":"file"},{"name":"pep-0574.rst","path":"peps/pep-0574.rst","contentType":"file"},{"name":"pep-0575.rst","path":"peps/pep-0575.rst","contentType":"file"},{"name":"pep-0576.rst","path":"peps/pep-0576.rst","contentType":"file"},{"name":"pep-0577.rst","path":"peps/pep-0577.rst","contentType":"file"},{"name":"pep-0578.rst","path":"peps/pep-0578.rst","contentType":"file"},{"name":"pep-0579.rst","path":"peps/pep-0579.rst","contentType":"file"},{"name":"pep-0580.rst","path":"peps/pep-0580.rst","contentType":"file"},{"name":"pep-0581.rst","path":"peps/pep-0581.rst","contentType":"file"},{"name":"pep-0582.rst","path":"peps/pep-0582.rst","contentType":"file"},{"name":"pep-0583.rst","path":"peps/pep-0583.rst","contentType":"file"},{"name":"pep-0584.rst","path":"peps/pep-0584.rst","contentType":"file"},{"name":"pep-0585.rst","path":"peps/pep-0585.rst","contentType":"file"},{"name":"pep-0586.rst","path":"peps/pep-0586.rst","contentType":"file"},{"name":"pep-0587.rst","path":"peps/pep-0587.rst","contentType":"file"},{"name":"pep-0588.rst","path":"peps/pep-0588.rst","contentType":"file"},{"name":"pep-0589.rst","path":"peps/pep-0589.rst","contentType":"file"},{"name":"pep-0590.rst","path":"peps/pep-0590.rst","contentType":"file"},{"name":"pep-0591.rst","path":"peps/pep-0591.rst","contentType":"file"},{"name":"pep-0592.rst","path":"peps/pep-0592.rst","contentType":"file"},{"name":"pep-0593.rst","path":"peps/pep-0593.rst","contentType":"file"},{"name":"pep-0594.rst","path":"peps/pep-0594.rst","contentType":"file"},{"name":"pep-0595.rst","path":"peps/pep-0595.rst","contentType":"file"},{"name":"pep-0596.rst","path":"peps/pep-0596.rst","contentType":"file"},{"name":"pep-0597.rst","path":"peps/pep-0597.rst","contentType":"file"},{"name":"pep-0598.rst","path":"peps/pep-0598.rst","contentType":"file"},{"name":"pep-0599.rst","path":"peps/pep-0599.rst","contentType":"file"},{"name":"pep-0600.rst","path":"peps/pep-0600.rst","contentType":"file"},{"name":"pep-0601.rst","path":"peps/pep-0601.rst","contentType":"file"},{"name":"pep-0602-example-release-calendar.png","path":"peps/pep-0602-example-release-calendar.png","contentType":"file"},{"name":"pep-0602-example-release-calendar.pptx","path":"peps/pep-0602-example-release-calendar.pptx","contentType":"file"},{"name":"pep-0602-overlapping-support-matrix.png","path":"peps/pep-0602-overlapping-support-matrix.png","contentType":"file"},{"name":"pep-0602-overlapping-support-matrix.pptx","path":"peps/pep-0602-overlapping-support-matrix.pptx","contentType":"file"},{"name":"pep-0602.rst","path":"peps/pep-0602.rst","contentType":"file"},{"name":"pep-0603-hamt_vs_dict.png","path":"peps/pep-0603-hamt_vs_dict.png","contentType":"file"},{"name":"pep-0603-lookup_hamt.png","path":"peps/pep-0603-lookup_hamt.png","contentType":"file"},{"name":"pep-0603.rst","path":"peps/pep-0603.rst","contentType":"file"},{"name":"pep-0604.rst","path":"peps/pep-0604.rst","contentType":"file"},{"name":"pep-0605-example-release-calendar.png","path":"peps/pep-0605-example-release-calendar.png","contentType":"file"},{"name":"pep-0605-overlapping-support-matrix.png","path":"peps/pep-0605-overlapping-support-matrix.png","contentType":"file"},{"name":"pep-0605.rst","path":"peps/pep-0605.rst","contentType":"file"},{"name":"pep-0606.rst","path":"peps/pep-0606.rst","contentType":"file"},{"name":"pep-0607.rst","path":"peps/pep-0607.rst","contentType":"file"},{"name":"pep-0608.rst","path":"peps/pep-0608.rst","contentType":"file"},{"name":"pep-0609.rst","path":"peps/pep-0609.rst","contentType":"file"},{"name":"pep-0610.rst","path":"peps/pep-0610.rst","contentType":"file"},{"name":"pep-0611.rst","path":"peps/pep-0611.rst","contentType":"file"},{"name":"pep-0612.rst","path":"peps/pep-0612.rst","contentType":"file"},{"name":"pep-0613.rst","path":"peps/pep-0613.rst","contentType":"file"},{"name":"pep-0614.rst","path":"peps/pep-0614.rst","contentType":"file"},{"name":"pep-0615.rst","path":"peps/pep-0615.rst","contentType":"file"},{"name":"pep-0616.rst","path":"peps/pep-0616.rst","contentType":"file"},{"name":"pep-0617.rst","path":"peps/pep-0617.rst","contentType":"file"},{"name":"pep-0618.rst","path":"peps/pep-0618.rst","contentType":"file"},{"name":"pep-0619.rst","path":"peps/pep-0619.rst","contentType":"file"},{"name":"pep-0620.rst","path":"peps/pep-0620.rst","contentType":"file"},{"name":"pep-0621.rst","path":"peps/pep-0621.rst","contentType":"file"},{"name":"pep-0622.rst","path":"peps/pep-0622.rst","contentType":"file"},{"name":"pep-0623.rst","path":"peps/pep-0623.rst","contentType":"file"},{"name":"pep-0624.rst","path":"peps/pep-0624.rst","contentType":"file"},{"name":"pep-0625.rst","path":"peps/pep-0625.rst","contentType":"file"},{"name":"pep-0626.rst","path":"peps/pep-0626.rst","contentType":"file"},{"name":"pep-0627.rst","path":"peps/pep-0627.rst","contentType":"file"},{"name":"pep-0628.rst","path":"peps/pep-0628.rst","contentType":"file"},{"name":"pep-0629.rst","path":"peps/pep-0629.rst","contentType":"file"},{"name":"pep-0630.rst","path":"peps/pep-0630.rst","contentType":"file"},{"name":"pep-0631.rst","path":"peps/pep-0631.rst","contentType":"file"},{"name":"pep-0632.rst","path":"peps/pep-0632.rst","contentType":"file"},{"name":"pep-0633.rst","path":"peps/pep-0633.rst","contentType":"file"},{"name":"pep-0634.rst","path":"peps/pep-0634.rst","contentType":"file"},{"name":"pep-0635.rst","path":"peps/pep-0635.rst","contentType":"file"},{"name":"pep-0636.rst","path":"peps/pep-0636.rst","contentType":"file"},{"name":"pep-0637.rst","path":"peps/pep-0637.rst","contentType":"file"},{"name":"pep-0638.rst","path":"peps/pep-0638.rst","contentType":"file"},{"name":"pep-0639.rst","path":"peps/pep-0639.rst","contentType":"file"},{"name":"pep-0640.rst","path":"peps/pep-0640.rst","contentType":"file"},{"name":"pep-0641.rst","path":"peps/pep-0641.rst","contentType":"file"},{"name":"pep-0642.rst","path":"peps/pep-0642.rst","contentType":"file"},{"name":"pep-0643.rst","path":"peps/pep-0643.rst","contentType":"file"},{"name":"pep-0644.rst","path":"peps/pep-0644.rst","contentType":"file"},{"name":"pep-0645.rst","path":"peps/pep-0645.rst","contentType":"file"},{"name":"pep-0646.rst","path":"peps/pep-0646.rst","contentType":"file"},{"name":"pep-0647.rst","path":"peps/pep-0647.rst","contentType":"file"},{"name":"pep-0648.rst","path":"peps/pep-0648.rst","contentType":"file"},{"name":"pep-0649.rst","path":"peps/pep-0649.rst","contentType":"file"},{"name":"pep-0650.rst","path":"peps/pep-0650.rst","contentType":"file"},{"name":"pep-0651.rst","path":"peps/pep-0651.rst","contentType":"file"},{"name":"pep-0652.rst","path":"peps/pep-0652.rst","contentType":"file"},{"name":"pep-0653.rst","path":"peps/pep-0653.rst","contentType":"file"},{"name":"pep-0654.rst","path":"peps/pep-0654.rst","contentType":"file"},{"name":"pep-0655.rst","path":"peps/pep-0655.rst","contentType":"file"},{"name":"pep-0656.rst","path":"peps/pep-0656.rst","contentType":"file"},{"name":"pep-0657.rst","path":"peps/pep-0657.rst","contentType":"file"},{"name":"pep-0658.rst","path":"peps/pep-0658.rst","contentType":"file"},{"name":"pep-0659.rst","path":"peps/pep-0659.rst","contentType":"file"},{"name":"pep-0660.rst","path":"peps/pep-0660.rst","contentType":"file"},{"name":"pep-0661.rst","path":"peps/pep-0661.rst","contentType":"file"},{"name":"pep-0662.rst","path":"peps/pep-0662.rst","contentType":"file"},{"name":"pep-0663.rst","path":"peps/pep-0663.rst","contentType":"file"},{"name":"pep-0664.rst","path":"peps/pep-0664.rst","contentType":"file"},{"name":"pep-0665.rst","path":"peps/pep-0665.rst","contentType":"file"},{"name":"pep-0666.rst","path":"peps/pep-0666.rst","contentType":"file"},{"name":"pep-0667.rst","path":"peps/pep-0667.rst","contentType":"file"},{"name":"pep-0668.rst","path":"peps/pep-0668.rst","contentType":"file"},{"name":"pep-0669.rst","path":"peps/pep-0669.rst","contentType":"file"},{"name":"pep-0670.rst","path":"peps/pep-0670.rst","contentType":"file"},{"name":"pep-0671.rst","path":"peps/pep-0671.rst","contentType":"file"},{"name":"pep-0672.rst","path":"peps/pep-0672.rst","contentType":"file"},{"name":"pep-0673.rst","path":"peps/pep-0673.rst","contentType":"file"},{"name":"pep-0674.rst","path":"peps/pep-0674.rst","contentType":"file"},{"name":"pep-0675.rst","path":"peps/pep-0675.rst","contentType":"file"},{"name":"pep-0676.rst","path":"peps/pep-0676.rst","contentType":"file"},{"name":"pep-0677.rst","path":"peps/pep-0677.rst","contentType":"file"},{"name":"pep-0678.rst","path":"peps/pep-0678.rst","contentType":"file"},{"name":"pep-0679.rst","path":"peps/pep-0679.rst","contentType":"file"},{"name":"pep-0680.rst","path":"peps/pep-0680.rst","contentType":"file"},{"name":"pep-0681.rst","path":"peps/pep-0681.rst","contentType":"file"},{"name":"pep-0682.rst","path":"peps/pep-0682.rst","contentType":"file"},{"name":"pep-0683.rst","path":"peps/pep-0683.rst","contentType":"file"},{"name":"pep-0684.rst","path":"peps/pep-0684.rst","contentType":"file"},{"name":"pep-0685.rst","path":"peps/pep-0685.rst","contentType":"file"},{"name":"pep-0686.rst","path":"peps/pep-0686.rst","contentType":"file"},{"name":"pep-0687.rst","path":"peps/pep-0687.rst","contentType":"file"},{"name":"pep-0688.rst","path":"peps/pep-0688.rst","contentType":"file"},{"name":"pep-0689.rst","path":"peps/pep-0689.rst","contentType":"file"},{"name":"pep-0690.rst","path":"peps/pep-0690.rst","contentType":"file"},{"name":"pep-0691.rst","path":"peps/pep-0691.rst","contentType":"file"},{"name":"pep-0692.rst","path":"peps/pep-0692.rst","contentType":"file"},{"name":"pep-0693.rst","path":"peps/pep-0693.rst","contentType":"file"},{"name":"pep-0694.rst","path":"peps/pep-0694.rst","contentType":"file"},{"name":"pep-0695.rst","path":"peps/pep-0695.rst","contentType":"file"},{"name":"pep-0696.rst","path":"peps/pep-0696.rst","contentType":"file"},{"name":"pep-0697.rst","path":"peps/pep-0697.rst","contentType":"file"},{"name":"pep-0698.rst","path":"peps/pep-0698.rst","contentType":"file"},{"name":"pep-0699.rst","path":"peps/pep-0699.rst","contentType":"file"},{"name":"pep-0700.rst","path":"peps/pep-0700.rst","contentType":"file"},{"name":"pep-0701.rst","path":"peps/pep-0701.rst","contentType":"file"},{"name":"pep-0702.rst","path":"peps/pep-0702.rst","contentType":"file"},{"name":"pep-0703.rst","path":"peps/pep-0703.rst","contentType":"file"},{"name":"pep-0704.rst","path":"peps/pep-0704.rst","contentType":"file"},{"name":"pep-0705.rst","path":"peps/pep-0705.rst","contentType":"file"},{"name":"pep-0706.rst","path":"peps/pep-0706.rst","contentType":"file"},{"name":"pep-0707.rst","path":"peps/pep-0707.rst","contentType":"file"},{"name":"pep-0708.rst","path":"peps/pep-0708.rst","contentType":"file"},{"name":"pep-0709.rst","path":"peps/pep-0709.rst","contentType":"file"},{"name":"pep-0710.rst","path":"peps/pep-0710.rst","contentType":"file"},{"name":"pep-0711.rst","path":"peps/pep-0711.rst","contentType":"file"},{"name":"pep-0712.rst","path":"peps/pep-0712.rst","contentType":"file"},{"name":"pep-0713.rst","path":"peps/pep-0713.rst","contentType":"file"},{"name":"pep-0714.rst","path":"peps/pep-0714.rst","contentType":"file"},{"name":"pep-0715.rst","path":"peps/pep-0715.rst","contentType":"file"},{"name":"pep-0718.rst","path":"peps/pep-0718.rst","contentType":"file"},{"name":"pep-0719.rst","path":"peps/pep-0719.rst","contentType":"file"},{"name":"pep-0720.rst","path":"peps/pep-0720.rst","contentType":"file"},{"name":"pep-0721.rst","path":"peps/pep-0721.rst","contentType":"file"},{"name":"pep-0722.rst","path":"peps/pep-0722.rst","contentType":"file"},{"name":"pep-0723.rst","path":"peps/pep-0723.rst","contentType":"file"},{"name":"pep-0724.rst","path":"peps/pep-0724.rst","contentType":"file"},{"name":"pep-0725.rst","path":"peps/pep-0725.rst","contentType":"file"},{"name":"pep-0726.rst","path":"peps/pep-0726.rst","contentType":"file"},{"name":"pep-0727.rst","path":"peps/pep-0727.rst","contentType":"file"},{"name":"pep-0728.rst","path":"peps/pep-0728.rst","contentType":"file"},{"name":"pep-0729.rst","path":"peps/pep-0729.rst","contentType":"file"},{"name":"pep-0730.rst","path":"peps/pep-0730.rst","contentType":"file"},{"name":"pep-0731.rst","path":"peps/pep-0731.rst","contentType":"file"},{"name":"pep-0732-concentric.drawio.svg","path":"peps/pep-0732-concentric.drawio.svg","contentType":"file"},{"name":"pep-0732.rst","path":"peps/pep-0732.rst","contentType":"file"},{"name":"pep-0733.rst","path":"peps/pep-0733.rst","contentType":"file"},{"name":"pep-0734.rst","path":"peps/pep-0734.rst","contentType":"file"},{"name":"pep-0735.rst","path":"peps/pep-0735.rst","contentType":"file"},{"name":"pep-0736.rst","path":"peps/pep-0736.rst","contentType":"file"},{"name":"pep-0737.rst","path":"peps/pep-0737.rst","contentType":"file"},{"name":"pep-0738.rst","path":"peps/pep-0738.rst","contentType":"file"},{"name":"pep-0739.rst","path":"peps/pep-0739.rst","contentType":"file"},{"name":"pep-0740.rst","path":"peps/pep-0740.rst","contentType":"file"},{"name":"pep-0741.rst","path":"peps/pep-0741.rst","contentType":"file"},{"name":"pep-0742.rst","path":"peps/pep-0742.rst","contentType":"file"},{"name":"pep-0743.rst","path":"peps/pep-0743.rst","contentType":"file"},{"name":"pep-0744.rst","path":"peps/pep-0744.rst","contentType":"file"},{"name":"pep-0745.rst","path":"peps/pep-0745.rst","contentType":"file"},{"name":"pep-0746.rst","path":"peps/pep-0746.rst","contentType":"file"},{"name":"pep-0747.rst","path":"peps/pep-0747.rst","contentType":"file"},{"name":"pep-0748.rst","path":"peps/pep-0748.rst","contentType":"file"},{"name":"pep-0749.rst","path":"peps/pep-0749.rst","contentType":"file"},{"name":"pep-0750.rst","path":"peps/pep-0750.rst","contentType":"file"},{"name":"pep-0751.rst","path":"peps/pep-0751.rst","contentType":"file"},{"name":"pep-0752.rst","path":"peps/pep-0752.rst","contentType":"file"},{"name":"pep-0753.rst","path":"peps/pep-0753.rst","contentType":"file"},{"name":"pep-0754.rst","path":"peps/pep-0754.rst","contentType":"file"},{"name":"pep-0755.rst","path":"peps/pep-0755.rst","contentType":"file"},{"name":"pep-0756.rst","path":"peps/pep-0756.rst","contentType":"file"},{"name":"pep-0757.rst","path":"peps/pep-0757.rst","contentType":"file"},{"name":"pep-0758.rst","path":"peps/pep-0758.rst","contentType":"file"},{"name":"pep-0759.rst","path":"peps/pep-0759.rst","contentType":"file"},{"name":"pep-0760.rst","path":"peps/pep-0760.rst","contentType":"file"},{"name":"pep-0761.rst","path":"peps/pep-0761.rst","contentType":"file"},{"name":"pep-0762.rst","path":"peps/pep-0762.rst","contentType":"file"},{"name":"pep-0763.rst","path":"peps/pep-0763.rst","contentType":"file"},{"name":"pep-0764.rst","path":"peps/pep-0764.rst","contentType":"file"},{"name":"pep-0765.rst","path":"peps/pep-0765.rst","contentType":"file"},{"name":"pep-0766.rst","path":"peps/pep-0766.rst","contentType":"file"},{"name":"pep-0767.rst","path":"peps/pep-0767.rst","contentType":"file"},{"name":"pep-0768.rst","path":"peps/pep-0768.rst","contentType":"file"},{"name":"pep-0769.rst","path":"peps/pep-0769.rst","contentType":"file"},{"name":"pep-0770.rst","path":"peps/pep-0770.rst","contentType":"file"},{"name":"pep-0771.rst","path":"peps/pep-0771.rst","contentType":"file"},{"name":"pep-0772.rst","path":"peps/pep-0772.rst","contentType":"file"},{"name":"pep-0773.rst","path":"peps/pep-0773.rst","contentType":"file"},{"name":"pep-0774.rst","path":"peps/pep-0774.rst","contentType":"file"},{"name":"pep-0775.rst","path":"peps/pep-0775.rst","contentType":"file"},{"name":"pep-0776.rst","path":"peps/pep-0776.rst","contentType":"file"},{"name":"pep-0777.rst","path":"peps/pep-0777.rst","contentType":"file"},{"name":"pep-0779.rst","path":"peps/pep-0779.rst","contentType":"file"},{"name":"pep-0780.rst","path":"peps/pep-0780.rst","contentType":"file"},{"name":"pep-0781.rst","path":"peps/pep-0781.rst","contentType":"file"},{"name":"pep-0789.rst","path":"peps/pep-0789.rst","contentType":"file"},{"name":"pep-0801.rst","path":"peps/pep-0801.rst","contentType":"file"},{"name":"pep-2026.rst","path":"peps/pep-2026.rst","contentType":"file"},{"name":"pep-3000.rst","path":"peps/pep-3000.rst","contentType":"file"},{"name":"pep-3001.rst","path":"peps/pep-3001.rst","contentType":"file"},{"name":"pep-3002.rst","path":"peps/pep-3002.rst","contentType":"file"},{"name":"pep-3003.rst","path":"peps/pep-3003.rst","contentType":"file"},{"name":"pep-3099.rst","path":"peps/pep-3099.rst","contentType":"file"},{"name":"pep-3100.rst","path":"peps/pep-3100.rst","contentType":"file"},{"name":"pep-3101.rst","path":"peps/pep-3101.rst","contentType":"file"},{"name":"pep-3102.rst","path":"peps/pep-3102.rst","contentType":"file"},{"name":"pep-3103.rst","path":"peps/pep-3103.rst","contentType":"file"},{"name":"pep-3104.rst","path":"peps/pep-3104.rst","contentType":"file"},{"name":"pep-3105.rst","path":"peps/pep-3105.rst","contentType":"file"},{"name":"pep-3106.rst","path":"peps/pep-3106.rst","contentType":"file"},{"name":"pep-3107.rst","path":"peps/pep-3107.rst","contentType":"file"},{"name":"pep-3108.rst","path":"peps/pep-3108.rst","contentType":"file"},{"name":"pep-3109.rst","path":"peps/pep-3109.rst","contentType":"file"},{"name":"pep-3110.rst","path":"peps/pep-3110.rst","contentType":"file"},{"name":"pep-3111.rst","path":"peps/pep-3111.rst","contentType":"file"},{"name":"pep-3112.rst","path":"peps/pep-3112.rst","contentType":"file"},{"name":"pep-3113.rst","path":"peps/pep-3113.rst","contentType":"file"},{"name":"pep-3114.rst","path":"peps/pep-3114.rst","contentType":"file"},{"name":"pep-3115.rst","path":"peps/pep-3115.rst","contentType":"file"},{"name":"pep-3116.rst","path":"peps/pep-3116.rst","contentType":"file"},{"name":"pep-3117.rst","path":"peps/pep-3117.rst","contentType":"file"},{"name":"pep-3118.rst","path":"peps/pep-3118.rst","contentType":"file"},{"name":"pep-3119.rst","path":"peps/pep-3119.rst","contentType":"file"},{"name":"pep-3120.rst","path":"peps/pep-3120.rst","contentType":"file"},{"name":"pep-3121.rst","path":"peps/pep-3121.rst","contentType":"file"},{"name":"pep-3122.rst","path":"peps/pep-3122.rst","contentType":"file"},{"name":"pep-3123.rst","path":"peps/pep-3123.rst","contentType":"file"},{"name":"pep-3124.rst","path":"peps/pep-3124.rst","contentType":"file"},{"name":"pep-3125.rst","path":"peps/pep-3125.rst","contentType":"file"},{"name":"pep-3126.rst","path":"peps/pep-3126.rst","contentType":"file"},{"name":"pep-3127.rst","path":"peps/pep-3127.rst","contentType":"file"},{"name":"pep-3128.rst","path":"peps/pep-3128.rst","contentType":"file"},{"name":"pep-3129.rst","path":"peps/pep-3129.rst","contentType":"file"},{"name":"pep-3130.rst","path":"peps/pep-3130.rst","contentType":"file"},{"name":"pep-3131.rst","path":"peps/pep-3131.rst","contentType":"file"},{"name":"pep-3132.rst","path":"peps/pep-3132.rst","contentType":"file"},{"name":"pep-3133.rst","path":"peps/pep-3133.rst","contentType":"file"},{"name":"pep-3134.rst","path":"peps/pep-3134.rst","contentType":"file"},{"name":"pep-3135.rst","path":"peps/pep-3135.rst","contentType":"file"},{"name":"pep-3136.rst","path":"peps/pep-3136.rst","contentType":"file"},{"name":"pep-3137.rst","path":"peps/pep-3137.rst","contentType":"file"},{"name":"pep-3138.rst","path":"peps/pep-3138.rst","contentType":"file"},{"name":"pep-3139.rst","path":"peps/pep-3139.rst","contentType":"file"},{"name":"pep-3140.rst","path":"peps/pep-3140.rst","contentType":"file"},{"name":"pep-3141.rst","path":"peps/pep-3141.rst","contentType":"file"},{"name":"pep-3142.rst","path":"peps/pep-3142.rst","contentType":"file"},{"name":"pep-3143.rst","path":"peps/pep-3143.rst","contentType":"file"},{"name":"pep-3144.rst","path":"peps/pep-3144.rst","contentType":"file"},{"name":"pep-3145.rst","path":"peps/pep-3145.rst","contentType":"file"},{"name":"pep-3146.rst","path":"peps/pep-3146.rst","contentType":"file"},{"name":"pep-3147-1.dia","path":"peps/pep-3147-1.dia","contentType":"file"},{"name":"pep-3147-1.png","path":"peps/pep-3147-1.png","contentType":"file"},{"name":"pep-3147.rst","path":"peps/pep-3147.rst","contentType":"file"},{"name":"pep-3148.rst","path":"peps/pep-3148.rst","contentType":"file"},{"name":"pep-3149.rst","path":"peps/pep-3149.rst","contentType":"file"},{"name":"pep-3150.rst","path":"peps/pep-3150.rst","contentType":"file"},{"name":"pep-3151.rst","path":"peps/pep-3151.rst","contentType":"file"},{"name":"pep-3152.rst","path":"peps/pep-3152.rst","contentType":"file"},{"name":"pep-3153.rst","path":"peps/pep-3153.rst","contentType":"file"},{"name":"pep-3154.rst","path":"peps/pep-3154.rst","contentType":"file"},{"name":"pep-3155.rst","path":"peps/pep-3155.rst","contentType":"file"},{"name":"pep-3156.rst","path":"peps/pep-3156.rst","contentType":"file"},{"name":"pep-3333.rst","path":"peps/pep-3333.rst","contentType":"file"},{"name":"pep-789-example-no-yield.png","path":"peps/pep-789-example-no-yield.png","contentType":"file"},{"name":"pep-789-example-yield-allowed.png","path":"peps/pep-789-example-yield-allowed.png","contentType":"file"},{"name":"pep-789-example-yield-errors.png","path":"peps/pep-789-example-yield-errors.png","contentType":"file"},{"name":"pep-8000.rst","path":"peps/pep-8000.rst","contentType":"file"},{"name":"pep-8001.rst","path":"peps/pep-8001.rst","contentType":"file"},{"name":"pep-8002.rst","path":"peps/pep-8002.rst","contentType":"file"},{"name":"pep-8010.rst","path":"peps/pep-8010.rst","contentType":"file"},{"name":"pep-8011.rst","path":"peps/pep-8011.rst","contentType":"file"},{"name":"pep-8012.rst","path":"peps/pep-8012.rst","contentType":"file"},{"name":"pep-8013.rst","path":"peps/pep-8013.rst","contentType":"file"},{"name":"pep-8014.rst","path":"peps/pep-8014.rst","contentType":"file"},{"name":"pep-8015.rst","path":"peps/pep-8015.rst","contentType":"file"},{"name":"pep-8016.rst","path":"peps/pep-8016.rst","contentType":"file"},{"name":"pep-8100.rst","path":"peps/pep-8100.rst","contentType":"file"},{"name":"pep-8101.rst","path":"peps/pep-8101.rst","contentType":"file"},{"name":"pep-8102.rst","path":"peps/pep-8102.rst","contentType":"file"},{"name":"pep-8103.rst","path":"peps/pep-8103.rst","contentType":"file"},{"name":"pep-8104.rst","path":"peps/pep-8104.rst","contentType":"file"},{"name":"pep-8105.rst","path":"peps/pep-8105.rst","contentType":"file"},{"name":"pep-8106.rst","path":"peps/pep-8106.rst","contentType":"file"}],"totalCount":720},"":{"items":[{"name":"peps","path":"peps","contentType":"directory"}]}},"fileTreeProcessingTime":218.19329000000002,"foldersToFetch":[""],"repo":{"id":13414105,"defaultBranch":"main","name":"peps","ownerLogin":"python","currentUserCanPush":false,"isFork":false,"isEmpty":false,"createdAt":"2013-10-08T13:27:12.000Z","ownerAvatar":"https://avatars.githubusercontent.com/u/1525981?v=4","public":true,"private":false,"isOrgOwned":true},"codeLineWrapEnabled":false,"symbolsExpanded":false,"treeExpanded":true,"refInfo":{"name":"main","listCacheKey":"v0:1736207583.0","canEdit":false,"refType":"branch","currentOid":"993df23bc88c2f1829164b937b6595d72d2107e1"},"path":"peps/pep-0327.rst","currentUser":null,"blob":{"rawLines":null,"stylingDirectives":null,"colorizedLines":null,"csv":null,"csvError":null,"dependabotInfo":{"showConfigurationBanner":false,"configFilePath":null,"networkDependabotPath":"/python/peps/network/updates","dismissConfigurationNoticePath":"/settings/dismiss-notice/dependabot_configuration_notice","configurationNoticeDismissed":null},"displayName":"pep-0327.rst","displayUrl":"https://github.com/python/peps/blob/main/peps/pep-0327.rst?raw=true","headerInfo":{"blobSize":"39.5 KB","deleteTooltip":"You must be signed in to make or propose changes","editTooltip":"You must be signed in to make or propose changes","ghDesktopPath":"https://desktop.github.com","isGitLfs":false,"onBranch":true,"shortPath":"b5badd5","siteNavLoginPath":"/login?return_to=https%3A%2F%2Fgithub.com%2Fpython%2Fpeps%2Fblob%2Fmain%2Fpeps%2Fpep-0327.rst","isCSV":false,"isRichtext":true,"toc":[{"level":2,"text":"Abstract","anchor":"abstract","htmlText":"Abstract"},{"level":2,"text":"Motivation","anchor":"motivation","htmlText":"Motivation"},{"level":3,"text":"The problem with binary float","anchor":"the-problem-with-binary-float","htmlText":"The problem with binary float"},{"level":3,"text":"Why floating point?","anchor":"why-floating-point","htmlText":"Why floating point?"},{"level":3,"text":"Why not rational?","anchor":"why-not-rational","htmlText":"Why not rational?"},{"level":3,"text":"So, what do we have?","anchor":"so-what-do-we-have","htmlText":"So, what do we have?"},{"level":2,"text":"General Decimal Arithmetic Specification","anchor":"general-decimal-arithmetic-specification","htmlText":"General Decimal Arithmetic Specification"},{"level":3,"text":"The Arithmetic Model","anchor":"the-arithmetic-model","htmlText":"The Arithmetic Model"},{"level":3,"text":"Numbers","anchor":"numbers","htmlText":"Numbers"},{"level":3,"text":"Context","anchor":"context","htmlText":"Context"},{"level":3,"text":"Default Contexts","anchor":"default-contexts","htmlText":"Default Contexts"},{"level":3,"text":"Exceptional Conditions","anchor":"exceptional-conditions","htmlText":"Exceptional Conditions"},{"level":3,"text":"Rounding Algorithms","anchor":"rounding-algorithms","htmlText":"Rounding Algorithms"},{"level":2,"text":"Rationale","anchor":"rationale","htmlText":"Rationale"},{"level":3,"text":"Explicit construction","anchor":"explicit-construction","htmlText":"Explicit construction"},{"level":4,"text":"From int or long","anchor":"from-int-or-long","htmlText":"From int or long"},{"level":4,"text":"From string","anchor":"from-string","htmlText":"From string"},{"level":4,"text":"From float","anchor":"from-float","htmlText":"From float"},{"level":4,"text":"From tuples","anchor":"from-tuples","htmlText":"From tuples"},{"level":4,"text":"From Decimal","anchor":"from-decimal","htmlText":"From Decimal"},{"level":4,"text":"Syntax for All Cases","anchor":"syntax-for-all-cases","htmlText":"Syntax for All Cases"},{"level":4,"text":"Creating from Context","anchor":"creating-from-context","htmlText":"Creating from Context"},{"level":3,"text":"Implicit construction","anchor":"implicit-construction","htmlText":"Implicit construction"},{"level":4,"text":"From int or long","anchor":"from-int-or-long-1","htmlText":"From int or long"},{"level":4,"text":"From string","anchor":"from-string-1","htmlText":"From string"},{"level":4,"text":"From float","anchor":"from-float-1","htmlText":"From float"},{"level":4,"text":"From Decimal","anchor":"from-decimal-1","htmlText":"From Decimal"},{"level":3,"text":"Use of Context","anchor":"use-of-context","htmlText":"Use of Context"},{"level":3,"text":"Python Usability","anchor":"python-usability","htmlText":"Python Usability"},{"level":2,"text":"Documentation","anchor":"documentation","htmlText":"Documentation"},{"level":3,"text":"Decimal Attributes","anchor":"decimal-attributes","htmlText":"Decimal Attributes"},{"level":3,"text":"Decimal Methods","anchor":"decimal-methods","htmlText":"Decimal Methods"},{"level":3,"text":"Context Attributes","anchor":"context-attributes","htmlText":"Context Attributes"},{"level":3,"text":"Context Methods","anchor":"context-methods","htmlText":"Context Methods"},{"level":2,"text":"Reference Implementation","anchor":"reference-implementation","htmlText":"Reference Implementation"},{"level":2,"text":"References","anchor":"references","htmlText":"References"},{"level":2,"text":"Copyright","anchor":"copyright","htmlText":"Copyright"}],"lineInfo":{"truncatedLoc":"1239","truncatedSloc":"899"},"mode":"file"},"image":false,"isCodeownersFile":null,"isPlain":false,"isValidLegacyIssueTemplate":false,"issueTemplate":null,"discussionTemplate":null,"language":"reStructuredText","languageID":419,"large":false,"planSupportInfo":{"repoIsFork":null,"repoOwnedByCurrentUser":null,"requestFullPath":"/python/peps/blob/main/peps/pep-0327.rst","showFreeOrgGatedFeatureMessage":null,"showPlanSupportBanner":null,"upgradeDataAttributes":null,"upgradePath":null},"publishBannersInfo":{"dismissActionNoticePath":"/settings/dismiss-notice/publish_action_from_dockerfile","releasePath":"/python/peps/releases/new?marketplace=true","showPublishActionBanner":false},"rawBlobUrl":"https://github.com/python/peps/raw/refs/heads/main/peps/pep-0327.rst","renderImageOrRaw":false,"richText":"\u003carticle class=\"markdown-body entry-content container-lg\" itemprop=\"text\"\u003e\u003cp dir=\"auto\"\u003ePEP: 327\nTitle: Decimal Data Type\nAuthor: Facundo Batista \u0026lt;\u003ca href=\"mailto:facundo@taniquetil.com.ar\"\u003efacundo@taniquetil.com.ar\u003c/a\u003e\u0026gt;\nStatus: Final\nType: Standards Track\nCreated: 17-Oct-2003\nPython-Version: 2.4\nPost-History: 30-Nov-2003, 02-Jan-2004, 29-Jan-2004\u003c/p\u003e\n\u003ca name=\"user-content-abstract\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch2 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eAbstract\u003c/h2\u003e\u003ca id=\"user-content-abstract\" class=\"anchor\" aria-label=\"Permalink: Abstract\" href=\"#abstract\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eThe idea is to have a Decimal data type, for every use where decimals\nare needed but binary floating point is too inexact.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eThe Decimal data type will support the Python standard functions and\noperations, and must comply with the decimal arithmetic ANSI standard\nX3.274-1996 \u003ca href=\"#id19\" id=\"user-content-id1\"\u003e[1]\u003c/a\u003e.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eDecimal will be floating point (as opposed to fixed point) and will\nhave bounded precision (the precision is the upper limit on the\nnumber of significant digits in a result). However, precision is\nuser-settable, and a notion of significant trailing zeroes is supported\nso that fixed-point usage is also possible.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eThis work is based on code and test functions written by Eric Price,\nAahz and Tim Peters. Just before Python 2.4a1, the decimal.py\n\u003ca href=\"#reference-implementation\"\u003ereference implementation\u003c/a\u003e was moved into the standard library; along\nwith the documentation and the test suite, this was the work of\nRaymond Hettinger. Much of the explanation in this PEP is taken from\nCowlishaw's work \u003ca href=\"#id20\" id=\"user-content-id2\"\u003e[2]\u003c/a\u003e, comp.lang.python and python-dev.\u003c/p\u003e\n\u003ca name=\"user-content-motivation\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch2 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eMotivation\u003c/h2\u003e\u003ca id=\"user-content-motivation\" class=\"anchor\" aria-label=\"Permalink: Motivation\" href=\"#motivation\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eHere I'll expose the reasons of why I think a Decimal data type is\nneeded and why other numeric data types are not enough.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eI wanted a Money data type, and after proposing a pre-PEP in\ncomp.lang.python, the community agreed to have a numeric data type\nwith the needed arithmetic behaviour, and then build Money over it:\nall the considerations about quantity of digits after the decimal\npoint, rounding, etc., will be handled through Money. It is not the\npurpose of this PEP to have a data type that can be used as Money\nwithout further effort.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eOne of the biggest advantages of implementing a standard is that\nsomeone already thought out all the creepy cases for you. And to a\nstandard GvR redirected me: Mike Cowlishaw's General Decimal\nArithmetic specification \u003ca href=\"#id20\" id=\"user-content-id3\"\u003e[2]\u003c/a\u003e. This document defines a general\npurpose decimal arithmetic. A correct implementation of this\nspecification will conform to the decimal arithmetic defined in\nANSI/IEEE standard 854-1987, except for some minor restrictions, and\nwill also provide unrounded decimal arithmetic and integer arithmetic\nas proper subsets.\u003c/p\u003e\n\u003ca name=\"user-content-the-problem-with-binary-float\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eThe problem with binary float\u003c/h3\u003e\u003ca id=\"user-content-the-problem-with-binary-float\" class=\"anchor\" aria-label=\"Permalink: The problem with binary float\" href=\"#the-problem-with-binary-float\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eIn decimal math, there are many numbers that can't be represented with\na fixed number of decimal digits, e.g. 1/3 = 0.3333333333.......\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eIn base 2 (the way that standard floating point is calculated), 1/2 =\n0.1, 1/4 = 0.01, 1/8 = 0.001, etc. Decimal 0.2 equals 2/10 equals\n1/5, resulting in the binary fractional number\n0.001100110011001... As you can see, the problem is that some decimal\nnumbers can't be represented exactly in binary, resulting in small\nroundoff errors.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eSo we need a decimal data type that represents exactly decimal\nnumbers. Instead of a binary data type, we need a decimal one.\u003c/p\u003e\n\u003ca name=\"user-content-why-floating-point\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eWhy floating point?\u003c/h3\u003e\u003ca id=\"user-content-why-floating-point\" class=\"anchor\" aria-label=\"Permalink: Why floating point?\" href=\"#why-floating-point\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eSo we go to decimal, but why \u003cem\u003efloating point\u003c/em\u003e?\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eFloating point numbers use a fixed quantity of digits (precision) to\nrepresent a number, working with an exponent when the number gets too\nbig or too small. For example, with a precision of 5:\u003c/p\u003e\n\u003cpre\u003e 1234 ==\u0026gt; 1234e0\n 12345 ==\u0026gt; 12345e0\n123456 ==\u0026gt; 12346e1\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003e(note that in the last line the number got rounded to fit in five digits).\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eIn contrast, we have the example of a \u003ccode\u003elong\u003c/code\u003e integer with infinite\nprecision, meaning that you can have the number as big as you want,\nand you'll never lose any information.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eIn a fixed point number, the position of the decimal point is fixed.\nFor a fixed point data type, check Tim Peter's FixedPoint at\nSourceForge \u003ca href=\"#id22\" id=\"user-content-id4\"\u003e[4]\u003c/a\u003e. I'll go for floating point because it's easier to\nimplement the arithmetic behaviour of the standard, and then you can\nimplement a fixed point data type over Decimal.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eBut why can't we have a floating point number with infinite precision?\nIt's not so easy, because of inexact divisions. E.g.: 1/3 =\n0.3333333333333... ad infinitum. In this case you should store an\ninfinite amount of 3s, which takes too much memory, ;).\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eJohn Roth proposed to eliminate the division operator and force the\nuser to use an explicit method, just to avoid this kind of trouble.\nThis generated adverse reactions in comp.lang.python, as everybody\nwants to have support for the \u003ccode\u003e/\u003c/code\u003e operator in a numeric data type.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eWith this exposed maybe you're thinking \"Hey! Can we just store the 1\nand the 3 as numerator and denominator?\", which takes us to the next\npoint.\u003c/p\u003e\n\u003ca name=\"user-content-why-not-rational\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eWhy not rational?\u003c/h3\u003e\u003ca id=\"user-content-why-not-rational\" class=\"anchor\" aria-label=\"Permalink: Why not rational?\" href=\"#why-not-rational\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eRational numbers are stored using two integer numbers, the numerator\nand the denominator. This implies that the arithmetic operations\ncan't be executed directly (e.g. to add two rational numbers you first\nneed to calculate the common denominator).\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eQuoting Alex Martelli:\u003c/p\u003e\n\u003cblockquote\u003e\nThe performance implications of the fact that summing two\nrationals (which take O(M) and O(N) space respectively) gives a\nrational which takes O(M+N) memory space is just too troublesome.\nThere are excellent Rational implementations in both pure Python\nand as extensions (e.g., gmpy), but they'll always be a \"niche\nmarket\" IMHO. Probably worth PEPping, not worth doing without\nDecimal -- which is the right way to represent sums of money, a\ntruly major use case in the real world.\u003c/blockquote\u003e\n\u003cp dir=\"auto\"\u003eAnyway, if you're interested in this data type, you maybe will want to\ntake a look at \u003ca href=\"http://www.python.org/dev/peps/pep-0239\" rel=\"nofollow\"\u003ePEP 239\u003c/a\u003e: Adding a Rational Type to Python.\u003c/p\u003e\n\u003ca name=\"user-content-so-what-do-we-have\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eSo, what do we have?\u003c/h3\u003e\u003ca id=\"user-content-so-what-do-we-have\" class=\"anchor\" aria-label=\"Permalink: So, what do we have?\" href=\"#so-what-do-we-have\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eThe result is a Decimal data type, with bounded precision and floating\npoint.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eWill it be useful? I can't say it better than Alex Martelli:\u003c/p\u003e\n\u003cblockquote\u003e\nPython (out of the box) doesn't let you have binary floating point\nnumbers \u003cem\u003ewith whatever precision you specify\u003c/em\u003e: you're limited to\nwhat your hardware supplies. Decimal, be it used as a fixed or\nfloating point number, should suffer from no such limitation:\nwhatever bounded precision you may specify on number creation\n(your memory permitting) should work just as well. Most of the\nexpense of programming simplicity can be hidden from application\nprograms and placed in a suitable decimal arithmetic type. As per\n\u003ca href=\"http://speleotrove.com/decimal/\" rel=\"nofollow\"\u003ehttp://speleotrove.com/decimal/\u003c/a\u003e, \u003cem\u003ea single data type can be\nused for integer, fixed-point, and floating-point decimal\narithmetic\u003c/em\u003e -- and for money arithmetic which doesn't drive the\napplication programmer crazy.\u003c/blockquote\u003e\n\u003cp dir=\"auto\"\u003eThere are several uses for such a data type. As I said before, I will\nuse it as base for Money. In this case the bounded precision is not\nan issue; quoting Tim Peters:\u003c/p\u003e\n\u003cblockquote\u003e\nA precision of 20 would be way more than enough to account for\ntotal world economic output, down to the penny, since the\nbeginning of time.\u003c/blockquote\u003e\n\u003ca name=\"user-content-general-decimal-arithmetic-specification\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch2 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eGeneral Decimal Arithmetic Specification\u003c/h2\u003e\u003ca id=\"user-content-general-decimal-arithmetic-specification\" class=\"anchor\" aria-label=\"Permalink: General Decimal Arithmetic Specification\" href=\"#general-decimal-arithmetic-specification\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eHere I'll include information and descriptions that are part of the\nspecification \u003ca href=\"#id20\" id=\"user-content-id5\"\u003e[2]\u003c/a\u003e (the structure of the number, the context, etc.).\nAll the requirements included in this section are not for discussion\n(barring typos or other mistakes), as they are in the standard, and\nthe PEP is just for implementing the standard.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eBecause of copyright restrictions, I can not copy here explanations\ntaken from the specification, so I'll try to explain it in my own\nwords. I firmly encourage you to read the original specification\ndocument \u003ca href=\"#id20\" id=\"user-content-id6\"\u003e[2]\u003c/a\u003e for details or if you have any doubt.\u003c/p\u003e\n\u003ca name=\"user-content-the-arithmetic-model\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eThe Arithmetic Model\u003c/h3\u003e\u003ca id=\"user-content-the-arithmetic-model\" class=\"anchor\" aria-label=\"Permalink: The Arithmetic Model\" href=\"#the-arithmetic-model\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eThe specification is based on a decimal arithmetic model, as defined\nby the relevant standards: IEEE 854 \u003ca href=\"#id21\" id=\"user-content-id7\"\u003e[3]\u003c/a\u003e, ANSI X3-274 \u003ca href=\"#id19\" id=\"user-content-id8\"\u003e[1]\u003c/a\u003e, and the\nproposed revision \u003ca href=\"#id23\" id=\"user-content-id9\"\u003e[5]\u003c/a\u003e of IEEE 754 \u003ca href=\"#id24\" id=\"user-content-id10\"\u003e[6]\u003c/a\u003e.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eThe model has three components:\u003c/p\u003e\n\u003cul dir=\"auto\"\u003e\n\u003cli\u003eNumbers: just the values that the operation uses as input or output.\u003c/li\u003e\n\u003cli\u003eOperations: addition, multiplication, etc.\u003c/li\u003e\n\u003cli\u003eContext: a set of parameters and rules that the user can select and\nwhich govern the results of operations (for example, the precision\nto be used).\u003c/li\u003e\n\u003c/ul\u003e\n\u003ca name=\"user-content-numbers\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eNumbers\u003c/h3\u003e\u003ca id=\"user-content-numbers\" class=\"anchor\" aria-label=\"Permalink: Numbers\" href=\"#numbers\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eNumbers may be finite or special values. The former can be\nrepresented exactly. The latter are infinites and undefined (such as\n0/0).\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eFinite numbers are defined by three parameters:\u003c/p\u003e\n\u003cul dir=\"auto\"\u003e\n\u003cli\u003eSign: 0 (positive) or 1 (negative).\u003c/li\u003e\n\u003cli\u003eCoefficient: a non-negative integer.\u003c/li\u003e\n\u003cli\u003eExponent: a signed integer, the power of ten of the coefficient\nmultiplier.\u003c/li\u003e\n\u003c/ul\u003e\n\u003cp dir=\"auto\"\u003eThe numerical value of a finite number is given by:\u003c/p\u003e\n\u003cpre\u003e(-1)**sign * coefficient * 10**exponent\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003eSpecial values are named as following:\u003c/p\u003e\n\u003cul dir=\"auto\"\u003e\n\u003cli\u003eInfinity: a value which is infinitely large. Could be positive or\nnegative.\u003c/li\u003e\n\u003cli\u003eQuiet NaN (\"qNaN\"): represent undefined results (\u003cem\u003eNot a Number\u003c/em\u003e).\nDoes not cause an Invalid operation condition. The sign in a NaN\nhas no meaning.\u003c/li\u003e\n\u003cli\u003eSignaling NaN (\"sNaN\"): also \u003cem\u003eNot a Number\u003c/em\u003e, but will cause an\nInvalid operation condition if used in any operation.\u003c/li\u003e\n\u003c/ul\u003e\n\u003ca name=\"user-content-context\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eContext\u003c/h3\u003e\u003ca id=\"user-content-context\" class=\"anchor\" aria-label=\"Permalink: Context\" href=\"#context\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eThe context is a set of parameters and rules that the user can select\nand which govern the results of operations (for example, the precision\nto be used).\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eThe context gets that name because it surrounds the Decimal numbers,\nwith parts of context acting as input to, and output of, operations.\nIt's up to the application to work with one or several contexts,\nbut definitely the idea is not to get a context per Decimal number.\nFor example, a typical use would be to set the context's precision to\n20 digits at the start of a program, and never explicitly use context\nagain.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eThese definitions don't affect the internal storage of the Decimal\nnumbers, just the way that the arithmetic operations are performed.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eThe context is mainly defined by the following parameters (see\n\u003ca href=\"#context-attributes\"\u003eContext Attributes\u003c/a\u003e for all context attributes):\u003c/p\u003e\n\u003cul dir=\"auto\"\u003e\n\u003cli\u003ePrecision: The maximum number of significant digits that can result\nfrom an arithmetic operation (integer \u0026gt; 0). There is no maximum for\nthis value.\u003c/li\u003e\n\u003cli\u003eRounding: The name of the algorithm to be used when rounding is\nnecessary, one of \"round-down\", \"round-half-up\", \"round-half-even\",\n\"round-ceiling\", \"round-floor\", \"round-half-down\", and \"round-up\".\nSee \u003ca href=\"#rounding-algorithms\"\u003eRounding Algorithms\u003c/a\u003e below.\u003c/li\u003e\n\u003cli\u003eFlags and trap-enablers: \u003ca href=\"#exceptional-conditions\"\u003eExceptional conditions\u003c/a\u003e are grouped into\nsignals, controllable individually, each consisting of a flag\n(boolean, set when the signal occurs) and a trap-enabler (a boolean\nthat controls behavior). The signals are: \"clamped\",\n\"division-by-zero\", \"inexact\", \"invalid-operation\", \"overflow\",\n\"rounded\", \"subnormal\" and \"underflow\".\u003c/li\u003e\n\u003c/ul\u003e\n\u003ca name=\"user-content-default-contexts\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eDefault Contexts\u003c/h3\u003e\u003ca id=\"user-content-default-contexts\" class=\"anchor\" aria-label=\"Permalink: Default Contexts\" href=\"#default-contexts\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eThe specification defines two default contexts, which should be easily\nselectable by the user.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eBasic Default Context:\u003c/p\u003e\n\u003cul dir=\"auto\"\u003e\n\u003cli\u003eflags: all set to 0\u003c/li\u003e\n\u003cli\u003etrap-enablers: inexact, rounded, and subnormal are set to 0; all\nothers are set to 1\u003c/li\u003e\n\u003cli\u003eprecision: is set to 9\u003c/li\u003e\n\u003cli\u003erounding: is set to round-half-up\u003c/li\u003e\n\u003c/ul\u003e\n\u003cp dir=\"auto\"\u003eExtended Default Context:\u003c/p\u003e\n\u003cul dir=\"auto\"\u003e\n\u003cli\u003eflags: all set to 0\u003c/li\u003e\n\u003cli\u003etrap-enablers: all set to 0\u003c/li\u003e\n\u003cli\u003eprecision: is set to 9\u003c/li\u003e\n\u003cli\u003erounding: is set to round-half-even\u003c/li\u003e\n\u003c/ul\u003e\n\u003ca name=\"user-content-exceptional-conditions\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eExceptional Conditions\u003c/h3\u003e\u003ca id=\"user-content-exceptional-conditions\" class=\"anchor\" aria-label=\"Permalink: Exceptional Conditions\" href=\"#exceptional-conditions\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eThe table below lists the exceptional conditions that may arise during\nthe arithmetic operations, the corresponding signal, and the defined\nresult. For details, see the specification \u003ca href=\"#id20\" id=\"user-content-id11\"\u003e[2]\u003c/a\u003e.\u003c/p\u003e\n\u003cmarkdown-accessiblity-table\u003e\u003ctable\u003e\n\n\n\n\n\n\u003cthead valign=\"bottom\"\u003e\n\u003ctr\u003e\u003cth\u003eCondition\u003c/th\u003e\n\u003cth\u003eSignal\u003c/th\u003e\n\u003cth\u003eResult\u003c/th\u003e\n\u003c/tr\u003e\n\u003c/thead\u003e\n\u003ctbody valign=\"top\"\u003e\n\u003ctr\u003e\u003ctd\u003eClamped\u003c/td\u003e\n\u003ctd\u003eclamped\u003c/td\u003e\n\u003ctd\u003esee spec \u003ca href=\"#id20\" id=\"user-content-id12\"\u003e[2]\u003c/a\u003e\u003c/td\u003e\n\u003c/tr\u003e\n\u003ctr\u003e\u003ctd\u003eDivision by zero\u003c/td\u003e\n\u003ctd\u003edivision-by-zero\u003c/td\u003e\n\u003ctd\u003e[sign,inf]\u003c/td\u003e\n\u003c/tr\u003e\n\u003ctr\u003e\u003ctd\u003eInexact\u003c/td\u003e\n\u003ctd\u003einexact\u003c/td\u003e\n\u003ctd\u003eunchanged\u003c/td\u003e\n\u003c/tr\u003e\n\u003ctr\u003e\u003ctd\u003eInvalid operation\u003c/td\u003e\n\u003ctd\u003einvalid-operation\u003c/td\u003e\n\u003ctd\u003e[0,qNaN] (or [s,qNaN] or [s,qNaN,d]\nwhen the cause is a signaling NaN)\u003c/td\u003e\n\u003c/tr\u003e\n\u003ctr\u003e\u003ctd\u003eOverflow\u003c/td\u003e\n\u003ctd\u003eoverflow\u003c/td\u003e\n\u003ctd\u003edepends on the rounding mode\u003c/td\u003e\n\u003c/tr\u003e\n\u003ctr\u003e\u003ctd\u003eRounded\u003c/td\u003e\n\u003ctd\u003erounded\u003c/td\u003e\n\u003ctd\u003eunchanged\u003c/td\u003e\n\u003c/tr\u003e\n\u003ctr\u003e\u003ctd\u003eSubnormal\u003c/td\u003e\n\u003ctd\u003esubnormal\u003c/td\u003e\n\u003ctd\u003eunchanged\u003c/td\u003e\n\u003c/tr\u003e\n\u003ctr\u003e\u003ctd\u003eUnderflow\u003c/td\u003e\n\u003ctd\u003eunderflow\u003c/td\u003e\n\u003ctd\u003esee spec \u003ca href=\"#id20\" id=\"user-content-id13\"\u003e[2]\u003c/a\u003e\u003c/td\u003e\n\u003c/tr\u003e\n\u003c/tbody\u003e\n\u003c/table\u003e\u003c/markdown-accessiblity-table\u003e\n\u003cp dir=\"auto\"\u003eNote: when the standard talks about \"Insufficient storage\", as long as\nthis is implementation-specific behaviour about not having enough\nstorage to keep the internals of the number, this implementation will\nraise MemoryError.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eRegarding Overflow and Underflow, there's been a long discussion in\npython-dev about artificial limits. The general consensus is to keep\nthe artificial limits only if there are important reasons to do that.\nTim Peters gives us three:\u003c/p\u003e\n\u003cblockquote\u003e\n\u003cp dir=\"auto\"\u003e...eliminating bounds on exponents effectively means overflow\n(and underflow) can never happen. But overflow \u003cem\u003eis\u003c/em\u003e a valuable\nsafety net in real life fp use, like a canary in a coal mine,\ngiving danger signs early when a program goes insane.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eVirtually all implementations of 854 use (and as IBM's standard\neven suggests) \"forbidden\" exponent values to encode non-finite\nnumbers (infinities and NaNs). A bounded exponent can do this at\nvirtually no extra storage cost. If the exponent is unbounded,\nthen additional bits have to be used instead. This cost remains\nhidden until more time- and space- efficient implementations are\nattempted.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eBig as it is, the IBM standard is a tiny start at supplying a\ncomplete numeric facility. Having no bound on exponent size will\nenormously complicate the implementations of, e.g., decimal sin()\nand cos() (there's then no a priori limit on how many digits of\npi effectively need to be known in order to perform argument\nreduction).\u003c/p\u003e\n\u003c/blockquote\u003e\n\u003cp dir=\"auto\"\u003eEdward Loper give us an example of when the limits are to be crossed:\nprobabilities.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eThat said, Robert Brewer and Andrew Lentvorski want the limits to be\neasily modifiable by the users. Actually, this is quite possible:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d1 = Decimal(\"1e999999999\") # at the exponent limit\n\u0026gt;\u0026gt;\u0026gt; d1\nDecimal(\"1E+999999999\")\n\u0026gt;\u0026gt;\u0026gt; d1 * 10 # exceed the limit, got infinity\nTraceback (most recent call last):\n File \"\u0026lt;pyshell#3\u0026gt;\", line 1, in ?\n d1 * 10\n ...\n ...\nOverflow: above Emax\n\u0026gt;\u0026gt;\u0026gt; getcontext().Emax = 1000000000 # increase the limit\n\u0026gt;\u0026gt;\u0026gt; d1 * 10 # does not exceed any more\nDecimal(\"1.0E+1000000000\")\n\u0026gt;\u0026gt;\u0026gt; d1 * 100 # exceed again\nTraceback (most recent call last):\n File \"\u0026lt;pyshell#3\u0026gt;\", line 1, in ?\n d1 * 100\n ...\n ...\nOverflow: above Emax\n\u003c/pre\u003e\n\u003ca name=\"user-content-rounding-algorithms\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eRounding Algorithms\u003c/h3\u003e\u003ca id=\"user-content-rounding-algorithms\" class=\"anchor\" aria-label=\"Permalink: Rounding Algorithms\" href=\"#rounding-algorithms\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003e\u003ccode\u003eround-down\u003c/code\u003e: The discarded digits are ignored; the result is\nunchanged (round toward 0, truncate):\u003c/p\u003e\n\u003cpre\u003e1.123 --\u0026gt; 1.12\n1.128 --\u0026gt; 1.12\n1.125 --\u0026gt; 1.12\n1.135 --\u0026gt; 1.13\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003e\u003ccode\u003eround-half-up\u003c/code\u003e: If the discarded digits represent greater than or\nequal to half (0.5) then the result should be incremented by 1;\notherwise the discarded digits are ignored:\u003c/p\u003e\n\u003cpre\u003e1.123 --\u0026gt; 1.12\n1.128 --\u0026gt; 1.13\n1.125 --\u0026gt; 1.13\n1.135 --\u0026gt; 1.14\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003e\u003ccode\u003eround-half-even\u003c/code\u003e: If the discarded digits represent greater than\nhalf (0.5) then the result coefficient is incremented by 1; if they\nrepresent less than half, then the result is not adjusted; otherwise\nthe result is unaltered if its rightmost digit is even, or incremented\nby 1 if its rightmost digit is odd (to make an even digit):\u003c/p\u003e\n\u003cpre\u003e1.123 --\u0026gt; 1.12\n1.128 --\u0026gt; 1.13\n1.125 --\u0026gt; 1.12\n1.135 --\u0026gt; 1.14\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003e\u003ccode\u003eround-ceiling\u003c/code\u003e: If all of the discarded digits are zero or if the\nsign is negative the result is unchanged; otherwise, the result is\nincremented by 1 (round toward positive infinity):\u003c/p\u003e\n\u003cpre\u003e 1.123 --\u0026gt; 1.13\n 1.128 --\u0026gt; 1.13\n-1.123 --\u0026gt; -1.12\n-1.128 --\u0026gt; -1.12\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003e\u003ccode\u003eround-floor\u003c/code\u003e: If all of the discarded digits are zero or if the\nsign is positive the result is unchanged; otherwise, the absolute\nvalue of the result is incremented by 1 (round toward negative\ninfinity):\u003c/p\u003e\n\u003cpre\u003e 1.123 --\u0026gt; 1.12\n 1.128 --\u0026gt; 1.12\n-1.123 --\u0026gt; -1.13\n-1.128 --\u0026gt; -1.13\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003e\u003ccode\u003eround-half-down\u003c/code\u003e: If the discarded digits represent greater than\nhalf (0.5) then the result is incremented by 1; otherwise the\ndiscarded digits are ignored:\u003c/p\u003e\n\u003cpre\u003e1.123 --\u0026gt; 1.12\n1.128 --\u0026gt; 1.13\n1.125 --\u0026gt; 1.12\n1.135 --\u0026gt; 1.13\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003e\u003ccode\u003eround-up\u003c/code\u003e: If all of the discarded digits are zero the result is\nunchanged, otherwise the result is incremented by 1 (round away from\n0):\u003c/p\u003e\n\u003cpre\u003e1.123 --\u0026gt; 1.13\n1.128 --\u0026gt; 1.13\n1.125 --\u0026gt; 1.13\n1.135 --\u0026gt; 1.14\n\u003c/pre\u003e\n\u003ca name=\"user-content-rationale\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch2 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eRationale\u003c/h2\u003e\u003ca id=\"user-content-rationale\" class=\"anchor\" aria-label=\"Permalink: Rationale\" href=\"#rationale\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eI must separate the requirements in two sections. The first is to\ncomply with the ANSI standard. All the requirements for this are\nspecified in the Mike Cowlishaw's work \u003ca href=\"#id20\" id=\"user-content-id14\"\u003e[2]\u003c/a\u003e. He also provided a\n\u003cstrong\u003every large\u003c/strong\u003e suite of test cases.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eThe second section of requirements (standard Python functions support,\nusability, etc.) is detailed from here, where I'll include all the\ndecisions made and why, and all the subjects still being discussed.\u003c/p\u003e\n\u003ca name=\"user-content-explicit-construction\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eExplicit construction\u003c/h3\u003e\u003ca id=\"user-content-explicit-construction\" class=\"anchor\" aria-label=\"Permalink: Explicit construction\" href=\"#explicit-construction\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eThe explicit construction does not get affected by the context (there\nis no rounding, no limits by the precision, etc.), because the context\naffects just operations' results. The only exception to this is when\nyou're \u003ca href=\"#creating-from-context\"\u003eCreating from Context\u003c/a\u003e.\u003c/p\u003e\n\u003ca name=\"user-content-from-int-or-long\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch4 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eFrom int or long\u003c/h4\u003e\u003ca id=\"user-content-from-int-or-long\" class=\"anchor\" aria-label=\"Permalink: From int or long\" href=\"#from-int-or-long\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eThere's no loss and no need to specify any other information:\u003c/p\u003e\n\u003cpre\u003eDecimal(35)\nDecimal(-124)\n\u003c/pre\u003e\n\u003ca name=\"user-content-from-string\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch4 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eFrom string\u003c/h4\u003e\u003ca id=\"user-content-from-string\" class=\"anchor\" aria-label=\"Permalink: From string\" href=\"#from-string\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eStrings containing Python decimal integer literals and Python float\nliterals will be supported. In this transformation there is no loss\nof information, as the string is directly converted to Decimal (there\nis not an intermediate conversion through float):\u003c/p\u003e\n\u003cpre\u003eDecimal(\"-12\")\nDecimal(\"23.2e-7\")\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003eAlso, you can construct in this way all special values (Infinity and\nNot a Number):\u003c/p\u003e\n\u003cpre\u003eDecimal(\"Inf\")\nDecimal(\"NaN\")\n\u003c/pre\u003e\n\u003ca name=\"user-content-from-float\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch4 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eFrom float\u003c/h4\u003e\u003ca id=\"user-content-from-float\" class=\"anchor\" aria-label=\"Permalink: From float\" href=\"#from-float\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eThe initial discussion on this item was what should\nhappen when passing floating point to the constructor:\u003c/p\u003e\n\u003col dir=\"auto\"\u003e\n\u003cli\u003e\u003ccode\u003eDecimal(1.1) == Decimal('1.1')\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003e\u003ccode\u003eDecimal(1.1) ==\nDecimal('110000000000000008881784197001252...e-51')\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003ean exception is raised\u003c/li\u003e\n\u003c/ol\u003e\n\u003cp dir=\"auto\"\u003eSeveral people alleged that (1) is the better option here, because\nit's what you expect when writing \u003ccode\u003eDecimal(1.1)\u003c/code\u003e. And quoting John\nRoth, it's easy to implement:\u003c/p\u003e\n\u003cblockquote\u003e\nIt's not at all difficult to find where the actual number ends and\nwhere the fuzz begins. You can do it visually, and the algorithms\nto do it are quite well known.\u003c/blockquote\u003e\n\u003cp dir=\"auto\"\u003eBut If I \u003cem\u003ereally\u003c/em\u003e want my number to be\n\u003ccode\u003eDecimal('110000000000000008881784197001252...e-51')\u003c/code\u003e, why can't I\nwrite \u003ccode\u003eDecimal(1.1)\u003c/code\u003e? Why should I expect Decimal to be \"rounding\"\nit? Remember that \u003ccode\u003e1.1\u003c/code\u003e \u003cem\u003eis\u003c/em\u003e binary floating point, so I can\npredict the result. It's not intuitive to a beginner, but that's the\nway it is.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eAnyway, Paul Moore showed that (1) can't work, because:\u003c/p\u003e\n\u003cpre\u003e(1) says D(1.1) == D('1.1')\nbut 1.1 == 1.1000000000000001\nso D(1.1) == D(1.1000000000000001)\ntogether: D(1.1000000000000001) == D('1.1')\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003ewhich is wrong, because if I write \u003ccode\u003eDecimal('1.1')\u003c/code\u003e it is exact, not\n\u003ccode\u003eD(1.1000000000000001)\u003c/code\u003e. He also proposed to have an explicit\nconversion to float. bokr says you need to put the precision in the\nconstructor and mwilson agreed:\u003c/p\u003e\n\u003cpre\u003ed = Decimal (1.1, 1) # take float value to 1 decimal place\nd = Decimal (1.1) # gets `places` from pre-set context\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003eBut Alex Martelli says that:\u003c/p\u003e\n\u003cblockquote\u003e\nConstructing with some specified precision would be fine. Thus,\nI think \"construction from float with some default precision\" runs\na substantial risk of tricking naive users.\u003c/blockquote\u003e\n\u003cp dir=\"auto\"\u003eSo, the accepted solution through c.l.p is that you can not call Decimal\nwith a float. Instead you must use a method: Decimal.from_float(). The\nsyntax:\u003c/p\u003e\n\u003cpre\u003eDecimal.from_float(floatNumber, [decimal_places])\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003ewhere \u003ccode\u003efloatNumber\u003c/code\u003e is the float number origin of the construction\nand \u003ccode\u003edecimal_places\u003c/code\u003e are the number of digits after the decimal\npoint where you apply a round-half-up rounding, if any. In this way\nyou can do, for example:\u003c/p\u003e\n\u003cpre\u003eDecimal.from_float(1.1, 2): The same as doing Decimal('1.1').\nDecimal.from_float(1.1, 16): The same as doing Decimal('1.1000000000000001').\nDecimal.from_float(1.1): The same as doing Decimal('1100000000000000088817841970012523233890533447265625e-51').\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003eBased on later discussions, it was decided to omit from_float() from the\nAPI for Py2.4. Several ideas contributed to the thought process:\u003c/p\u003e\n\u003cul dir=\"auto\"\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eInteractions between decimal and binary floating point force the user to\ndeal with tricky issues of representation and round-off. Avoidance of those\nissues is a primary reason for having the module in the first place.\u003c/p\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eThe first release of the module should focus on that which is safe, minimal,\nand essential.\u003c/p\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eWhile theoretically nice, real world use cases for interactions between floats\nand decimals are lacking. Java included float/decimal conversions to handle\nan obscure case where calculations are best performed in decimal even though\na legacy data structure requires the inputs and outputs to be stored in\nbinary floating point.\u003c/p\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eIf the need arises, users can use string representations as an intermediate\ntype. The advantage of this approach is that it makes explicit the\nassumptions about precision and representation (no wondering what is going\non under the hood).\u003c/p\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eThe Java docs for BigDecimal(double val) reflected their experiences with\nthe constructor:\u003c/p\u003e\n\u003cpre\u003eThe results of this constructor can be somewhat\nunpredictable and its use is generally not recommended.\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003c/ul\u003e\n\u003ca name=\"user-content-from-tuples\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch4 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eFrom tuples\u003c/h4\u003e\u003ca id=\"user-content-from-tuples\" class=\"anchor\" aria-label=\"Permalink: From tuples\" href=\"#from-tuples\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eAahz suggested to construct from tuples: it's easier\nto implement \u003ccode\u003eeval()\u003c/code\u003e's round trip and \"someone who has numeric\nvalues representing a Decimal does not need to convert them to a\nstring.\"\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eThe structure will be a tuple of three elements: sign, number and\nexponent. The sign is 1 or 0, the number is a tuple of decimal digits\nand the exponent is a signed int or long:\u003c/p\u003e\n\u003cpre\u003eDecimal((1, (3, 2, 2, 5), -2)) # for -32.25\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003eOf course, you can construct in this way all special values:\u003c/p\u003e\n\u003cpre\u003eDecimal( (0, (0,), 'F') ) # for Infinity\nDecimal( (0, (0,), 'n') ) # for Not a Number\n\u003c/pre\u003e\n\u003ca name=\"user-content-from-decimal\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch4 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eFrom Decimal\u003c/h4\u003e\u003ca id=\"user-content-from-decimal\" class=\"anchor\" aria-label=\"Permalink: From Decimal\" href=\"#from-decimal\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eNo mystery here, just a copy.\u003c/p\u003e\n\u003ca name=\"user-content-syntax-for-all-cases\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch4 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eSyntax for All Cases\u003c/h4\u003e\u003ca id=\"user-content-syntax-for-all-cases\" class=\"anchor\" aria-label=\"Permalink: Syntax for All Cases\" href=\"#syntax-for-all-cases\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cpre\u003eDecimal(value1)\nDecimal.from_float(value2, [decimal_places])\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003ewhere \u003ccode\u003evalue1\u003c/code\u003e can be int, long, string, 3-tuple or Decimal,\n\u003ccode\u003evalue2\u003c/code\u003e can only be float, and \u003ccode\u003edecimal_places\u003c/code\u003e is an optional\nnon negative int.\u003c/p\u003e\n\u003ca name=\"user-content-creating-from-context\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch4 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eCreating from Context\u003c/h4\u003e\u003ca id=\"user-content-creating-from-context\" class=\"anchor\" aria-label=\"Permalink: Creating from Context\" href=\"#creating-from-context\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eThis item arose in python-dev from two sources in parallel. Ka-Ping\nYee proposes to pass the context as an argument at instance creation\n(he wants the context he passes to be used only in creation time: \"It\nwould not be persistent\"). Tony Meyer asks from_string to honor the\ncontext if it receives a parameter \"honour_context\" with a True value.\n(I don't like it, because the doc specifies that the context be\nhonored and I don't want the method to comply with the specification\nregarding the value of an argument.)\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eTim Peters gives us a reason to have a creation that uses context:\u003c/p\u003e\n\u003cblockquote\u003e\nIn general number-crunching, literals may be given to high\nprecision, but that precision isn't free and \u003cem\u003eusually\u003c/em\u003e isn't\nneeded\u003c/blockquote\u003e\n\u003cp dir=\"auto\"\u003eCasey Duncan wants to use another method, not a bool arg:\u003c/p\u003e\n\u003cblockquote\u003e\nI find boolean arguments a general anti-pattern, especially given\nwe have class methods. Why not use an alternate constructor like\nDecimal.rounded_to_context(\"3.14159265\").\u003c/blockquote\u003e\n\u003cp dir=\"auto\"\u003eIn the process of deciding the syntax of that, Tim came up with a\nbetter idea: he proposes not to have a method in Decimal to create\nwith a different context, but having instead a method in Context to\ncreate a Decimal instance. Basically, instead of:\u003c/p\u003e\n\u003cpre\u003eD.using_context(number, context)\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003eit will be:\u003c/p\u003e\n\u003cpre\u003econtext.create_decimal(number)\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003eFrom Tim:\u003c/p\u003e\n\u003cblockquote\u003e\nWhile all operations in the spec except for the two to-string\noperations use context, no operations in the spec support an\noptional local context. That the Decimal() constructor ignores\ncontext by default is an extension to the spec. We must supply a\ncontext-honoring from-string operation to meet the spec. I\nrecommend against any concept of \"local context\" in any operation\n-- it complicates the model and isn't necessary.\u003c/blockquote\u003e\n\u003cp dir=\"auto\"\u003eSo, we decided to use a context method to create a Decimal that will\nuse (only to be created) that context in particular (for further\noperations it will use the context of the thread). But, a method with\nwhat name?\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eTim Peters proposes three methods to create from diverse sources\n(from_string, from_int, from_float). I proposed to use one method,\n\u003ccode\u003ecreate_decimal()\u003c/code\u003e, without caring about the data type. Michael\nChermside: \"The name just fits my brain. The fact that it uses the\ncontext is obvious from the fact that it's Context method\".\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eThe community agreed with that. I think that it's OK because a newbie\nwill not be using the creation method from Context (the separate\nmethod in Decimal to construct from float is just to prevent newbies\nfrom encountering binary floating point issues).\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eSo, in short, if you want to create a Decimal instance using a\nparticular context (that will be used just at creation time and not\nany further), you'll have to use a method of that context:\u003c/p\u003e\n\u003cpre\u003e# n is any datatype accepted in Decimal(n) plus float\nmycontext.create_decimal(n)\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003eExample:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; # create a standard decimal instance\n\u0026gt;\u0026gt;\u0026gt; Decimal(\"11.2233445566778899\")\nDecimal(\"11.2233445566778899\")\n\u0026gt;\u0026gt;\u0026gt;\n\u0026gt;\u0026gt;\u0026gt; # create a decimal instance using the thread context\n\u0026gt;\u0026gt;\u0026gt; thread_context = getcontext()\n\u0026gt;\u0026gt;\u0026gt; thread_context.prec\n28\n\u0026gt;\u0026gt;\u0026gt; thread_context.create_decimal(\"11.2233445566778899\")\nDecimal(\"11.2233445566778899\")\n\u0026gt;\u0026gt;\u0026gt;\n\u0026gt;\u0026gt;\u0026gt; # create a decimal instance using other context\n\u0026gt;\u0026gt;\u0026gt; other_context = thread_context.copy()\n\u0026gt;\u0026gt;\u0026gt; other_context.prec = 4\n\u0026gt;\u0026gt;\u0026gt; other_context.create_decimal(\"11.2233445566778899\")\nDecimal(\"11.22\")\n\u003c/pre\u003e\n\u003ca name=\"user-content-implicit-construction\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eImplicit construction\u003c/h3\u003e\u003ca id=\"user-content-implicit-construction\" class=\"anchor\" aria-label=\"Permalink: Implicit construction\" href=\"#implicit-construction\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eAs the implicit construction is the consequence of an operation, it\nwill be affected by the context as is detailed in each point.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eJohn Roth suggested that \"The other type should be handled in the same\nway the decimal() constructor would handle it\". But Alex Martelli\nthinks that\u003c/p\u003e\n\u003cblockquote\u003e\nthis total breach with Python tradition would be a terrible\nmistake. 23+\"43\" is NOT handled in the same way as 23+int(\"45\"),\nand a VERY good thing that is too. It's a completely different\nthing for a user to EXPLICITLY indicate they want construction\n(conversion) and to just happen to sum two objects one of which by\nmistake could be a string.\u003c/blockquote\u003e\n\u003cp dir=\"auto\"\u003eSo, here I define the behaviour again for each data type.\u003c/p\u003e\n\u003ca name=\"user-content-id15\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch4 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eFrom int or long\u003c/h4\u003e\u003ca id=\"user-content-from-int-or-long-1\" class=\"anchor\" aria-label=\"Permalink: From int or long\" href=\"#from-int-or-long-1\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eAn int or long is a treated like a Decimal explicitly constructed from\nDecimal(str(x)) in the current context (meaning that the to-string rules\nfor rounding are applied and the appropriate flags are set). This\nguarantees that expressions like \u003ccode\u003eDecimal('1234567') + 13579\u003c/code\u003e match\nthe mental model of \u003ccode\u003eDecimal('1234567') + Decimal('13579')\u003c/code\u003e. That\nmodel works because all integers are representable as strings without\nrepresentation error.\u003c/p\u003e\n\u003ca name=\"user-content-id16\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch4 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eFrom string\u003c/h4\u003e\u003ca id=\"user-content-from-string-1\" class=\"anchor\" aria-label=\"Permalink: From string\" href=\"#from-string-1\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eEverybody agrees to raise an exception here.\u003c/p\u003e\n\u003ca name=\"user-content-id17\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch4 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eFrom float\u003c/h4\u003e\u003ca id=\"user-content-from-float-1\" class=\"anchor\" aria-label=\"Permalink: From float\" href=\"#from-float-1\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eAahz is strongly opposed to interact with float, suggesting an\nexplicit conversion:\u003c/p\u003e\n\u003cblockquote\u003e\nThe problem is that Decimal is capable of greater precision,\naccuracy, and range than float.\u003c/blockquote\u003e\n\u003cp dir=\"auto\"\u003eThe example of the valid python expression, \u003ccode\u003e35 + 1.1\u003c/code\u003e, seems to suggest\nthat \u003ccode\u003eDecimal(35) + 1.1\u003c/code\u003e should also be valid. However, a closer look\nshows that it only demonstrates the feasibility of integer to floating\npoint conversions. Hence, the correct analog for decimal floating point\nis \u003ccode\u003e35 + Decimal(1.1)\u003c/code\u003e. Both coercions, int-to-float and int-to-Decimal,\ncan be done without incurring representation error.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eThe question of how to coerce between binary and decimal floating point\nis more complex. I proposed allowing the interaction with float,\nmaking an exact conversion and raising ValueError if exceeds the\nprecision in the current context (this is maybe too tricky, because\nfor example with a precision of 9, \u003ccode\u003eDecimal(35) + 1.2\u003c/code\u003e is OK but\n\u003ccode\u003eDecimal(35) + 1.1\u003c/code\u003e raises an error).\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eThis resulted to be too tricky. So tricky, that c.l.p agreed to raise\nTypeError in this case: you could not mix Decimal and float.\u003c/p\u003e\n\u003ca name=\"user-content-id18\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch4 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eFrom Decimal\u003c/h4\u003e\u003ca id=\"user-content-from-decimal-1\" class=\"anchor\" aria-label=\"Permalink: From Decimal\" href=\"#from-decimal-1\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eThere isn't any issue here.\u003c/p\u003e\n\u003ca name=\"user-content-use-of-context\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eUse of Context\u003c/h3\u003e\u003ca id=\"user-content-use-of-context\" class=\"anchor\" aria-label=\"Permalink: Use of Context\" href=\"#use-of-context\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eIn the last pre-PEP I said that \"The Context must be omnipresent,\nmeaning that changes to it affects all the current and future Decimal\ninstances\". I was wrong. In response, John Roth said:\u003c/p\u003e\n\u003cblockquote\u003e\nThe context should be selectable for the particular usage. That\nis, it should be possible to have several different contexts in\nplay at one time in an application.\u003c/blockquote\u003e\n\u003cp dir=\"auto\"\u003eIn comp.lang.python, Aahz explained that the idea is to have a\n\"context per thread\". So, all the instances of a thread belongs to a\ncontext, and you can change a context in thread A (and the behaviour\nof the instances of that thread) without changing nothing in thread B.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eAlso, and again correcting me, he said:\u003c/p\u003e\n\u003cblockquote\u003e\n(the) Context applies only to operations, not to Decimal\ninstances; changing the Context does not affect existing instances\nif there are no operations on them.\u003c/blockquote\u003e\n\u003cp dir=\"auto\"\u003eArguing about special cases when there's need to perform operations\nwith other rules that those of the current context, Tim Peters said\nthat the context will have the operations as methods. This way, the\nuser \"can create whatever private context object(s) it needs, and\nspell arithmetic as explicit method calls on its private context\nobject(s), so that the default thread context object is neither\nconsulted nor modified\".\u003c/p\u003e\n\u003ca name=\"user-content-python-usability\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003ePython Usability\u003c/h3\u003e\u003ca id=\"user-content-python-usability\" class=\"anchor\" aria-label=\"Permalink: Python Usability\" href=\"#python-usability\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cul dir=\"auto\"\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eDecimal should support the basic arithmetic (\u003ccode\u003e+, -, *, /, //, **,\n%, divmod\u003c/code\u003e) and comparison (\u003ccode\u003e==, !=, \u0026lt;, \u0026gt;, \u0026lt;=, \u0026gt;=, cmp\u003c/code\u003e)\noperators in the following cases (check \u003ca href=\"#implicit-construction\"\u003eImplicit Construction\u003c/a\u003e to\nsee what types could OtherType be, and what happens in each case):\u003c/p\u003e\n\u003cul dir=\"auto\"\u003e\n\u003cli\u003eDecimal op Decimal\u003c/li\u003e\n\u003cli\u003eDecimal op otherType\u003c/li\u003e\n\u003cli\u003eotherType op Decimal\u003c/li\u003e\n\u003cli\u003eDecimal op= Decimal\u003c/li\u003e\n\u003cli\u003eDecimal op= otherType\u003c/li\u003e\n\u003c/ul\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eDecimal should support unary operators (\u003ccode\u003e-, +, abs\u003c/code\u003e).\u003c/p\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003erepr() should round trip, meaning that:\u003c/p\u003e\n\u003cpre\u003em = Decimal(...)\nm == eval(repr(m))\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eDecimal should be immutable.\u003c/p\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eDecimal should support the built-in methods:\u003c/p\u003e\n\u003cul dir=\"auto\"\u003e\n\u003cli\u003emin, max\u003c/li\u003e\n\u003cli\u003efloat, int, long\u003c/li\u003e\n\u003cli\u003estr, repr\u003c/li\u003e\n\u003cli\u003ehash\u003c/li\u003e\n\u003cli\u003ebool (0 is false, otherwise true)\u003c/li\u003e\n\u003c/ul\u003e\n\u003c/li\u003e\n\u003c/ul\u003e\n\u003cp dir=\"auto\"\u003eThere's been some discussion in python-dev about the behaviour of\n\u003ccode\u003ehash()\u003c/code\u003e. The community agrees that if the values are the same, the\nhashes of those values should also be the same. So, while Decimal(25)\n== 25 is True, hash(Decimal(25)) should be equal to hash(25).\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eThe detail is that you can NOT compare Decimal to floats or strings,\nso we should not worry about them giving the same hashes. In short:\u003c/p\u003e\n\u003cpre\u003ehash(n) == hash(Decimal(n)) # Only if n is int, long, or Decimal\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003eRegarding str() and repr() behaviour, Ka-Ping Yee proposes that repr()\nhave the same behaviour as str() and Tim Peters proposes that str()\nbehave like the to-scientific-string operation from the Spec.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eThis is possible, because (from Aahz): \"The string form already\ncontains all the necessary information to reconstruct a Decimal\nobject\".\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eAnd it also complies with the Spec; Tim Peters:\u003c/p\u003e\n\u003cblockquote\u003e\nThere's no requirement to have a method \u003cem\u003enamed\u003c/em\u003e \"to_sci_string\",\nthe only requirement is that \u003cem\u003esome\u003c/em\u003e way to spell to-sci-string's\nfunctionality be supplied. The meaning of to-sci-string is\nprecisely specified by the standard, and is a good choice for both\nstr(Decimal) and repr(Decimal).\u003c/blockquote\u003e\n\u003ca name=\"user-content-documentation\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch2 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eDocumentation\u003c/h2\u003e\u003ca id=\"user-content-documentation\" class=\"anchor\" aria-label=\"Permalink: Documentation\" href=\"#documentation\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eThis section explains all the public methods and attributes of Decimal\nand Context.\u003c/p\u003e\n\u003ca name=\"user-content-decimal-attributes\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eDecimal Attributes\u003c/h3\u003e\u003ca id=\"user-content-decimal-attributes\" class=\"anchor\" aria-label=\"Permalink: Decimal Attributes\" href=\"#decimal-attributes\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eDecimal has no public attributes. The internal information is stored\nin slots and should not be accessed by end users.\u003c/p\u003e\n\u003ca name=\"user-content-decimal-methods\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eDecimal Methods\u003c/h3\u003e\u003ca id=\"user-content-decimal-methods\" class=\"anchor\" aria-label=\"Permalink: Decimal Methods\" href=\"#decimal-methods\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eFollowing are the conversion and arithmetic operations defined in the\nSpec, and how that functionality can be achieved with the actual\nimplementation.\u003c/p\u003e\n\u003cul dir=\"auto\"\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eto-scientific-string: Use builtin function \u003ccode\u003estr()\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('123456789012.345')\n\u0026gt;\u0026gt;\u0026gt; str(d)\n'1.23456789E+11'\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eto-engineering-string: Use method \u003ccode\u003eto_eng_string()\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('123456789012.345')\n\u0026gt;\u0026gt;\u0026gt; d.to_eng_string()\n'123.456789E+9'\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eto-number: Use Context method \u003ccode\u003ecreate_decimal()\u003c/code\u003e. The standard\nconstructor or \u003ccode\u003efrom_float()\u003c/code\u003e constructor cannot be used because\nthese do not use the context (as is specified in the Spec for this\nconversion).\u003c/p\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eabs: Use builtin function \u003ccode\u003eabs()\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('-15.67')\n\u0026gt;\u0026gt;\u0026gt; abs(d)\nDecimal('15.67')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eadd: Use operator \u003ccode\u003e+\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('15.6')\n\u0026gt;\u0026gt;\u0026gt; d + 8\nDecimal('23.6')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003esubtract: Use operator \u003ccode\u003e-\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('15.6')\n\u0026gt;\u0026gt;\u0026gt; d - 8\nDecimal('7.6')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003ecompare: Use method \u003ccode\u003ecompare()\u003c/code\u003e. This method (and not the\nbuilt-in function cmp()) should only be used when dealing with\n\u003cem\u003especial values\u003c/em\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('-15.67')\n\u0026gt;\u0026gt;\u0026gt; nan = Decimal('NaN')\n\u0026gt;\u0026gt;\u0026gt; d.compare(23)\n'-1'\n\u0026gt;\u0026gt;\u0026gt; d.compare(nan)\n'NaN'\n\u0026gt;\u0026gt;\u0026gt; cmp(d, 23)\n-1\n\u0026gt;\u0026gt;\u0026gt; cmp(d, nan)\n1\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003edivide: Use operator \u003ccode\u003e/\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('-15.67')\n\u0026gt;\u0026gt;\u0026gt; d / 2\nDecimal('-7.835')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003edivide-integer: Use operator \u003ccode\u003e//\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('-15.67')\n\u0026gt;\u0026gt;\u0026gt; d // 2\nDecimal('-7')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003emax: Use method \u003ccode\u003emax()\u003c/code\u003e. Only use this method (and not the\nbuilt-in function max()) when dealing with \u003cem\u003especial values\u003c/em\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('15')\n\u0026gt;\u0026gt;\u0026gt; nan = Decimal('NaN')\n\u0026gt;\u0026gt;\u0026gt; d.max(8)\nDecimal('15')\n\u0026gt;\u0026gt;\u0026gt; d.max(nan)\nDecimal('NaN')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003emin: Use method \u003ccode\u003emin()\u003c/code\u003e. Only use this method (and not the\nbuilt-in function min()) when dealing with \u003cem\u003especial values\u003c/em\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('15')\n\u0026gt;\u0026gt;\u0026gt; nan = Decimal('NaN')\n\u0026gt;\u0026gt;\u0026gt; d.min(8)\nDecimal('8')\n\u0026gt;\u0026gt;\u0026gt; d.min(nan)\nDecimal('NaN')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eminus: Use unary operator \u003ccode\u003e-\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('-15.67')\n\u0026gt;\u0026gt;\u0026gt; -d\nDecimal('15.67')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eplus: Use unary operator \u003ccode\u003e+\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('-15.67')\n\u0026gt;\u0026gt;\u0026gt; +d\nDecimal('-15.67')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003emultiply: Use operator \u003ccode\u003e*\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('5.7')\n\u0026gt;\u0026gt;\u0026gt; d * 3\nDecimal('17.1')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003enormalize: Use method \u003ccode\u003enormalize()\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('123.45000')\n\u0026gt;\u0026gt;\u0026gt; d.normalize()\nDecimal('123.45')\n\u0026gt;\u0026gt;\u0026gt; d = Decimal('120.00')\n\u0026gt;\u0026gt;\u0026gt; d.normalize()\nDecimal('1.2E+2')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003equantize: Use method \u003ccode\u003equantize()\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('2.17')\n\u0026gt;\u0026gt;\u0026gt; d.quantize(Decimal('0.001'))\nDecimal('2.170')\n\u0026gt;\u0026gt;\u0026gt; d.quantize(Decimal('0.1'))\nDecimal('2.2')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eremainder: Use operator \u003ccode\u003e%\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('10')\n\u0026gt;\u0026gt;\u0026gt; d % 3\nDecimal('1')\n\u0026gt;\u0026gt;\u0026gt; d % 6\nDecimal('4')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eremainder-near: Use method \u003ccode\u003eremainder_near()\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('10')\n\u0026gt;\u0026gt;\u0026gt; d.remainder_near(3)\nDecimal('1')\n\u0026gt;\u0026gt;\u0026gt; d.remainder_near(6)\nDecimal('-2')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003eround-to-integral-value: Use method \u003ccode\u003eto_integral()\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('-123.456')\n\u0026gt;\u0026gt;\u0026gt; d.to_integral()\nDecimal('-123')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003esame-quantum: Use method \u003ccode\u003esame_quantum()\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('123.456')\n\u0026gt;\u0026gt;\u0026gt; d.same_quantum(Decimal('0.001'))\nTrue\n\u0026gt;\u0026gt;\u0026gt; d.same_quantum(Decimal('0.01'))\nFalse\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003esquare-root: Use method \u003ccode\u003esqrt()\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('123.456')\n\u0026gt;\u0026gt;\u0026gt; d.sqrt()\nDecimal('11.1110756')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003epower: User operator \u003ccode\u003e**\u003c/code\u003e:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('12.56')\n\u0026gt;\u0026gt;\u0026gt; d ** 2\nDecimal('157.7536')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003c/ul\u003e\n\u003cp dir=\"auto\"\u003eFollowing are other methods and why they exist:\u003c/p\u003e\n\u003cul dir=\"auto\"\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003e\u003ccode\u003eadjusted()\u003c/code\u003e: Returns the adjusted exponent. This concept is\ndefined in the Spec: the adjusted exponent is the value of the\nexponent of a number when that number is expressed as though in\nscientific notation with one digit before any decimal point:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('12.56')\n\u0026gt;\u0026gt;\u0026gt; d.adjusted()\n1\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003e\u003ccode\u003efrom_float()\u003c/code\u003e: Class method to create instances from float data\ntypes:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal.from_float(12.35)\n\u0026gt;\u0026gt;\u0026gt; d\nDecimal('12.3500000')\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003e\u003ccode\u003eas_tuple()\u003c/code\u003e: Show the internal structure of the Decimal, the\ntriple tuple. This method is not required by the Spec, but Tim\nPeters proposed it and the community agreed to have it (it's useful\nfor developing and debugging):\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; d = Decimal('123.4')\n\u0026gt;\u0026gt;\u0026gt; d.as_tuple()\n(0, (1, 2, 3, 4), -1)\n\u0026gt;\u0026gt;\u0026gt; d = Decimal('-2.34e5')\n\u0026gt;\u0026gt;\u0026gt; d.as_tuple()\n(1, (2, 3, 4), 3)\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003c/ul\u003e\n\u003ca name=\"user-content-context-attributes\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eContext Attributes\u003c/h3\u003e\u003ca id=\"user-content-context-attributes\" class=\"anchor\" aria-label=\"Permalink: Context Attributes\" href=\"#context-attributes\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eThese are the attributes that can be changed to modify the context.\u003c/p\u003e\n\u003cul dir=\"auto\"\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003e\u003ccode\u003eprec\u003c/code\u003e (int): the precision:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; c.prec\n9\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003e\u003ccode\u003erounding\u003c/code\u003e (str): rounding type (how to round):\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; c.rounding\n'half_even'\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003e\u003ccode\u003etrap_enablers\u003c/code\u003e (dict): if trap_enablers[exception] = 1, then an\nexception is raised when it is caused:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; c.trap_enablers[Underflow]\n0\n\u0026gt;\u0026gt;\u0026gt; c.trap_enablers[Clamped]\n0\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003e\u003ccode\u003eflags\u003c/code\u003e (dict): when an exception is caused, flags[exception] is\nincremented (whether or not the trap_enabler is set). Should be\nreset by the user of Decimal instance:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; c.flags[Underflow]\n0\n\u0026gt;\u0026gt;\u0026gt; c.flags[Clamped]\n0\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003e\u003ccode\u003eEmin\u003c/code\u003e (int): minimum exponent:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; c.Emin\n-999999999\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003e\u003ccode\u003eEmax\u003c/code\u003e (int): maximum exponent:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; c.Emax\n999999999\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003e\u003ccode\u003ecapitals\u003c/code\u003e (int): boolean flag to use 'E' (True/1) or 'e'\n(False/0) in the string (for example, '1.32e+2' or '1.32E+2'):\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; c.capitals\n1\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003c/ul\u003e\n\u003ca name=\"user-content-context-methods\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch3 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eContext Methods\u003c/h3\u003e\u003ca id=\"user-content-context-methods\" class=\"anchor\" aria-label=\"Permalink: Context Methods\" href=\"#context-methods\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eThe following methods comply with Decimal functionality from the Spec.\nBe aware that the operations that are called through a specific\ncontext use that context and not the thread context.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eTo use these methods, take note that the syntax changes when the\noperator is binary or unary, for example:\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; mycontext.abs(Decimal('-2'))\n'2'\n\u0026gt;\u0026gt;\u0026gt; mycontext.multiply(Decimal('2.3'), 5)\n'11.5'\n\u003c/pre\u003e\n\u003cp dir=\"auto\"\u003eSo, the following are the Spec operations and conversions and how to\nachieve them through a context (where \u003ccode\u003ed\u003c/code\u003e is a Decimal instance and\n\u003ccode\u003en\u003c/code\u003e a number that can be used in an \u003ca href=\"#implicit-construction\"\u003eImplicit construction\u003c/a\u003e):\u003c/p\u003e\n\u003cul dir=\"auto\"\u003e\n\u003cli\u003eto-scientific-string: \u003ccode\u003eto_sci_string(d)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003eto-engineering-string: \u003ccode\u003eto_eng_string(d)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003eto-number: \u003ccode\u003ecreate_decimal(number)\u003c/code\u003e, see \u003ca href=\"#explicit-construction\"\u003eExplicit construction\u003c/a\u003e\nfor \u003ccode\u003enumber\u003c/code\u003e.\u003c/li\u003e\n\u003cli\u003eabs: \u003ccode\u003eabs(d)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003eadd: \u003ccode\u003eadd(d, n)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003esubtract: \u003ccode\u003esubtract(d, n)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003ecompare: \u003ccode\u003ecompare(d, n)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003edivide: \u003ccode\u003edivide(d, n)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003edivide-integer: \u003ccode\u003edivide_int(d, n)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003emax: \u003ccode\u003emax(d, n)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003emin: \u003ccode\u003emin(d, n)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003eminus: \u003ccode\u003eminus(d)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003eplus: \u003ccode\u003eplus(d)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003emultiply: \u003ccode\u003emultiply(d, n)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003enormalize: \u003ccode\u003enormalize(d)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003equantize: \u003ccode\u003equantize(d, d)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003eremainder: \u003ccode\u003eremainder(d)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003eremainder-near: \u003ccode\u003eremainder_near(d)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003eround-to-integral-value: \u003ccode\u003eto_integral(d)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003esame-quantum: \u003ccode\u003esame_quantum(d, d)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003esquare-root: \u003ccode\u003esqrt(d)\u003c/code\u003e\u003c/li\u003e\n\u003cli\u003epower: \u003ccode\u003epower(d, n)\u003c/code\u003e\u003c/li\u003e\n\u003c/ul\u003e\n\u003cp dir=\"auto\"\u003eThe \u003ccode\u003edivmod(d, n)\u003c/code\u003e method supports decimal functionality through\nContext.\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eThese are methods that return useful information from the Context:\u003c/p\u003e\n\u003cul dir=\"auto\"\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003e\u003ccode\u003eEtiny()\u003c/code\u003e: Minimum exponent considering precision.\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; c.Emin\n-999999999\n\u0026gt;\u0026gt;\u0026gt; c.Etiny()\n-1000000007\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003e\u003ccode\u003eEtop()\u003c/code\u003e: Maximum exponent considering precision.\u003c/p\u003e\n\u003cpre\u003e\u0026gt;\u0026gt;\u0026gt; c.Emax\n999999999\n\u0026gt;\u0026gt;\u0026gt; c.Etop()\n999999991\n\u003c/pre\u003e\n\u003c/li\u003e\n\u003cli\u003e\u003cp dir=\"auto\"\u003e\u003ccode\u003ecopy()\u003c/code\u003e: Returns a copy of the context.\u003c/p\u003e\n\u003c/li\u003e\n\u003c/ul\u003e\n\u003ca name=\"user-content-reference-implementation\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch2 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eReference Implementation\u003c/h2\u003e\u003ca id=\"user-content-reference-implementation\" class=\"anchor\" aria-label=\"Permalink: Reference Implementation\" href=\"#reference-implementation\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eAs of Python 2.4-alpha, the code has been checked into the standard\nlibrary. The latest version is available from:\u003c/p\u003e\n\u003cp dir=\"auto\"\u003e\u003ca href=\"http://svn.python.org/view/python/trunk/Lib/decimal.py\" rel=\"nofollow\"\u003ehttp://svn.python.org/view/python/trunk/Lib/decimal.py\u003c/a\u003e\u003c/p\u003e\n\u003cp dir=\"auto\"\u003eThe test cases are here:\u003c/p\u003e\n\u003cp dir=\"auto\"\u003e\u003ca href=\"http://svn.python.org/view/python/trunk/Lib/test/test_decimal.py\" rel=\"nofollow\"\u003ehttp://svn.python.org/view/python/trunk/Lib/test/test_decimal.py\u003c/a\u003e\u003c/p\u003e\n\u003ca name=\"user-content-references\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch2 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eReferences\u003c/h2\u003e\u003ca id=\"user-content-references\" class=\"anchor\" aria-label=\"Permalink: References\" href=\"#references\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cmarkdown-accessiblity-table\u003e\u003ctable frame=\"void\" id=\"user-content-id19\" rules=\"none\"\u003e\n\n\u003ctbody valign=\"top\"\u003e\n\u003ctr\u003e\u003ctd\u003e[1]\u003c/td\u003e\u003ctd\u003e\u003cem\u003e(\u003ca href=\"#id1\"\u003e1\u003c/a\u003e, \u003ca href=\"#id8\"\u003e2\u003c/a\u003e)\u003c/em\u003e ANSI standard X3.274-1996 (Programming Language REXX):\n\u003ca href=\"http://www.rexxla.org/Standards/ansi.html\" rel=\"nofollow\"\u003ehttp://www.rexxla.org/Standards/ansi.html\u003c/a\u003e\u003c/td\u003e\u003c/tr\u003e\n\u003c/tbody\u003e\n\u003c/table\u003e\u003c/markdown-accessiblity-table\u003e\n\u003cmarkdown-accessiblity-table\u003e\u003ctable frame=\"void\" id=\"user-content-id20\" rules=\"none\"\u003e\n\n\u003ctbody valign=\"top\"\u003e\n\u003ctr\u003e\u003ctd\u003e[2]\u003c/td\u003e\u003ctd\u003e\u003cem\u003e(\u003ca href=\"#id2\"\u003e1\u003c/a\u003e, \u003ca href=\"#id3\"\u003e2\u003c/a\u003e, \u003ca href=\"#id5\"\u003e3\u003c/a\u003e, \u003ca href=\"#id6\"\u003e4\u003c/a\u003e, \u003ca href=\"#id11\"\u003e5\u003c/a\u003e, \u003ca href=\"#id12\"\u003e6\u003c/a\u003e, \u003ca href=\"#id13\"\u003e7\u003c/a\u003e, \u003ca href=\"#id14\"\u003e8\u003c/a\u003e)\u003c/em\u003e General Decimal Arithmetic specification (Cowlishaw):\n\u003ca href=\"http://speleotrove.com/decimal/decarith.html\" rel=\"nofollow\"\u003ehttp://speleotrove.com/decimal/decarith.html\u003c/a\u003e (related\ndocuments and links at \u003ca href=\"http://speleotrove.com/decimal/\" rel=\"nofollow\"\u003ehttp://speleotrove.com/decimal/\u003c/a\u003e)\u003c/td\u003e\u003c/tr\u003e\n\u003c/tbody\u003e\n\u003c/table\u003e\u003c/markdown-accessiblity-table\u003e\n\u003cmarkdown-accessiblity-table\u003e\u003ctable frame=\"void\" id=\"user-content-id21\" rules=\"none\"\u003e\n\n\u003ctbody valign=\"top\"\u003e\n\u003ctr\u003e\u003ctd\u003e\u003ca href=\"#id7\"\u003e[3]\u003c/a\u003e\u003c/td\u003e\u003ctd\u003eANSI/IEEE standard 854-1987 (Radix-Independent Floating-Point\nArithmetic):\n\u003ca href=\"http://www.cs.berkeley.edu/~ejr/projects/754/private/drafts/854-1987/dir.html\" rel=\"nofollow\"\u003ehttp://www.cs.berkeley.edu/~ejr/projects/754/private/drafts/854-1987/dir.html\u003c/a\u003e\n(unofficial text; official copies can be ordered from\n\u003ca href=\"http://standards.ieee.org/catalog/ordering.html\" rel=\"nofollow\"\u003ehttp://standards.ieee.org/catalog/ordering.html\u003c/a\u003e)\u003c/td\u003e\u003c/tr\u003e\n\u003c/tbody\u003e\n\u003c/table\u003e\u003c/markdown-accessiblity-table\u003e\n\u003cmarkdown-accessiblity-table\u003e\u003ctable frame=\"void\" id=\"user-content-id22\" rules=\"none\"\u003e\n\n\u003ctbody valign=\"top\"\u003e\n\u003ctr\u003e\u003ctd\u003e\u003ca href=\"#id4\"\u003e[4]\u003c/a\u003e\u003c/td\u003e\u003ctd\u003eTim Peter's FixedPoint at SourceForge:\n\u003ca href=\"http://fixedpoint.sourceforge.net/\" rel=\"nofollow\"\u003ehttp://fixedpoint.sourceforge.net/\u003c/a\u003e\u003c/td\u003e\u003c/tr\u003e\n\u003c/tbody\u003e\n\u003c/table\u003e\u003c/markdown-accessiblity-table\u003e\n\u003cmarkdown-accessiblity-table\u003e\u003ctable frame=\"void\" id=\"user-content-id23\" rules=\"none\"\u003e\n\n\u003ctbody valign=\"top\"\u003e\n\u003ctr\u003e\u003ctd\u003e\u003ca href=\"#id9\"\u003e[5]\u003c/a\u003e\u003c/td\u003e\u003ctd\u003eIEEE 754 revision:\n\u003ca href=\"http://grouper.ieee.org/groups/754/revision.html\" rel=\"nofollow\"\u003ehttp://grouper.ieee.org/groups/754/revision.html\u003c/a\u003e\u003c/td\u003e\u003c/tr\u003e\n\u003c/tbody\u003e\n\u003c/table\u003e\u003c/markdown-accessiblity-table\u003e\n\u003cmarkdown-accessiblity-table\u003e\u003ctable frame=\"void\" id=\"user-content-id24\" rules=\"none\"\u003e\n\n\u003ctbody valign=\"top\"\u003e\n\u003ctr\u003e\u003ctd\u003e\u003ca href=\"#id10\"\u003e[6]\u003c/a\u003e\u003c/td\u003e\u003ctd\u003eIEEE 754 references:\n\u003ca href=\"http://babbage.cs.qc.edu/courses/cs341/IEEE-754references.html\" rel=\"nofollow\"\u003ehttp://babbage.cs.qc.edu/courses/cs341/IEEE-754references.html\u003c/a\u003e\u003c/td\u003e\u003c/tr\u003e\n\u003c/tbody\u003e\n\u003c/table\u003e\u003c/markdown-accessiblity-table\u003e\n\u003ca name=\"user-content-copyright\"\u003e\u003c/a\u003e\n\u003cdiv class=\"markdown-heading\" dir=\"auto\"\u003e\u003ch2 tabindex=\"-1\" class=\"heading-element\" dir=\"auto\"\u003eCopyright\u003c/h2\u003e\u003ca id=\"user-content-copyright\" class=\"anchor\" aria-label=\"Permalink: Copyright\" href=\"#copyright\"\u003e\u003csvg class=\"octicon octicon-link\" viewBox=\"0 0 16 16\" version=\"1.1\" width=\"16\" height=\"16\" aria-hidden=\"true\"\u003e\u003cpath d=\"m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z\"\u003e\u003c/path\u003e\u003c/svg\u003e\u003c/a\u003e\u003c/div\u003e\n\u003cp dir=\"auto\"\u003eThis document has been placed in the public domain.\u003c/p\u003e\n\n\u003c/article\u003e","renderedFileInfo":null,"shortPath":null,"symbolsEnabled":true,"tabSize":8,"topBannersInfo":{"overridingGlobalFundingFile":false,"globalPreferredFundingPath":"/python/.github/blob/5a0a7cb55767fb3667fe2391bcb66bda638edcb4/FUNDING.yml","showInvalidCitationWarning":false,"citationHelpUrl":"https://docs.github.com/github/creating-cloning-and-archiving-repositories/creating-a-repository-on-github/about-citation-files","actionsOnboardingTip":null},"truncated":false,"viewable":true,"workflowRedirectUrl":null,"symbols":{"timed_out":false,"not_analyzed":true,"symbols":[]}},"copilotInfo":null,"copilotAccessAllowed":false,"modelsAccessAllowed":false,"modelsRepoIntegrationEnabled":false,"csrf_tokens":{"/python/peps/branches":{"post":"t9CAcL5mRw0_3iyna6zDEMA3wVuVJyZfBaMFyjRM4X7h93NY2V_jWys7yjCA4-RmSmw4G6tfFcZ60I1TBwwwCg"},"/repos/preferences":{"post":"qUZG3Rp3KaFf1gtpBp0iP-bS-4Q3tI3_0llsdvA222rZNmA3BknbZOOS145lygmIlxNUTBSoxgvM6SFMXTk_vQ"}}},"title":"peps/peps/pep-0327.rst at main · python/peps","appPayload":{"helpUrl":"https://docs.github.com","findFileWorkerPath":"/assets-cdn/worker/find-file-worker-7d7eb7c71814.js","findInFileWorkerPath":"/assets-cdn/worker/find-in-file-worker-96e76d5fdb2c.js","githubDevUrl":null,"enabled_features":{"code_nav_ui_events":false,"overview_shared_code_dropdown_button":false,"react_blob_overlay":false,"accessible_code_button":true,"github_models_repo_integration":false}}}</script> <div data-target="react-app.reactRoot"><style data-styled="true" data-styled-version="5.3.11">.gISSDQ{width:100%;}/*!sc*/ @media screen and (min-width:544px){.gISSDQ{width:100%;}}/*!sc*/ @media screen and (min-width:768px){.gISSDQ{width:auto;}}/*!sc*/ .iHHOSp{min-width:0;display:none;}/*!sc*/ @media screen and (min-width:768px){.iHHOSp{height:100vh;max-height:100vh !important;}}/*!sc*/ @media print,screen and (max-width:1011px) and (min-width:768px){.iHHOSp{display:none;}}/*!sc*/ .bHLmSv{position:absolute;inset:0 -2px;cursor:col-resize;background-color:transparent;-webkit-transition-delay:0.1s;transition-delay:0.1s;}/*!sc*/ .bHLmSv:hover{background-color:var(--bgColor-neutral-muted,var(--color-neutral-muted,rgba(175,184,193,0.2)));}/*!sc*/ .gsfaIN{margin-right:auto;}/*!sc*/ @media print{.gsfaIN{display:-webkit-box !important;display:-webkit-flex !important;display:-ms-flexbox !important;display:flex !important;}}/*!sc*/ .leYMvG{margin-left:auto;margin-right:auto;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;padding-bottom:40px;max-width:100%;margin-top:0;}/*!sc*/ .KMPzq{display:inherit;}/*!sc*/ .hfKjHv{width:100%;}/*!sc*/ .gZWyZE{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;gap:8px;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;width:100%;}/*!sc*/ .dwYKDk{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:start;-webkit-box-align:start;-ms-flex-align:start;align-items:start;-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between;gap:8px;}/*!sc*/ .ibcGmb{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:start;-webkit-box-align:start;-ms-flex-align:start;align-items:start;min-width:0;}/*!sc*/ .hKaEJF{display:block;margin-right:8px;}/*!sc*/ @media screen and (min-width:1360px){.hKaEJF{display:block;}}/*!sc*/ .XosP{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;font-size:14px;}/*!sc*/ .bCKfWo[data-size="medium"]{color:var(--fgColor-muted,var(--color-fg-muted,#656d76));padding-left:8px;padding-right:8px;display:none;}/*!sc*/ @media screen and (max-width:768px){.bCKfWo[data-size="medium"]{display:block;}}/*!sc*/ .gUkoLg{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;}/*!sc*/ .dmxRgG[data-size="medium"]{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;}/*!sc*/ .dmxRgG[data-size="medium"] svg{color:var(--fgColor-muted,var(--color-fg-muted,#656d76));}/*!sc*/ .dmxRgG[data-size="medium"] > span{width:inherit;}/*!sc*/ .bZBlpz{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;width:100%;}/*!sc*/ .lhTYNA{margin-right:4px;color:var(--fgColor-muted,var(--color-fg-muted,#656d76));}/*!sc*/ .dbrgmi{font-size:14px;min-width:0;max-width:125px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}/*!sc*/ .bmcJak{min-width:0;}/*!sc*/ .dHJiml{-webkit-align-self:center;-ms-flex-item-align:center;align-self:center;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;padding-left:8px;padding-right:8px;min-width:0;}/*!sc*/ .cEytCf{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row;font-size:16px;min-width:0;-webkit-flex-shrink:1;-ms-flex-negative:1;flex-shrink:1;-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;max-width:100%;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;}/*!sc*/ .fzFXnm{max-width:100%;}/*!sc*/ .iMnkmv{max-width:100%;list-style:none;display:inline-block;}/*!sc*/ .ghzDag{display:inline-block;max-width:100%;}/*!sc*/ .kHuKdh{font-weight:600;}/*!sc*/ .hzJBof{padding-left:4px;padding-right:4px;font-weight:400;color:var(--fgColor-muted,var(--color-fg-muted,#656d76));font-size:16px;}/*!sc*/ .kgiVEz{font-weight:400;}/*!sc*/ .jGhzSQ{font-weight:600;display:inline-block;max-width:100%;font-size:16px;}/*!sc*/ .faNtbn{min-height:32px;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:start;-webkit-box-align:start;-ms-flex-align:start;align-items:start;}/*!sc*/ .fmQaBv{margin-left:4px;margin-right:4px;}/*!sc*/ .vcvyP{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;min-width:160px;}/*!sc*/ .dwNhzn[data-size="medium"][data-no-visuals]{border-top-left-radius:0;border-bottom-left-radius:0;display:none;}/*!sc*/ .fGwBZA[data-size="medium"][data-no-visuals]{color:var(--fgColor-muted,var(--color-fg-muted,#656d76));}/*!sc*/ .dJxjrT{margin-left:16px;margin-right:16px;}/*!sc*/ .eFxKDQ{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;}/*!sc*/ .dzCJzi{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row;-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:8px;min-width:273px;padding:8px;}/*!sc*/ @media screen and (min-width:544px){.dzCJzi{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;}}/*!sc*/ .ldRxiI{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row;}/*!sc*/ .fVkfyA{width:100%;height:-webkit-fit-content;height:-moz-fit-content;height:fit-content;min-width:0;margin-right:0;}/*!sc*/ .gNAmSV{height:40px;padding-left:4px;padding-bottom:16px;}/*!sc*/ .jNEwzY{-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;}/*!sc*/ .bsDwxw{font-size:12px;-webkit-flex:auto;-ms-flex:auto;flex:auto;padding-right:16px;color:var(--fgColor-muted,var(--color-fg-muted,#656d76));min-width:0;}/*!sc*/ .jdLMhu{top:0px;z-index:4;background:var(--bgColor-default,var(--color-canvas-default));position:-webkit-sticky;position:sticky;}/*!sc*/ .tOISc{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;width:100%;position:absolute;}/*!sc*/ .hqwSEx{display:none;min-width:0;padding-top:8px;padding-bottom:8px;}/*!sc*/ .bDVoEr{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;overflow:hidden;margin-left:8px;margin-right:8px;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row;-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between;width:100%;}/*!sc*/ .kYLlPM{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;}/*!sc*/ .gYjEmn{margin-left:4px;margin-right:8px;}/*!sc*/ .kGqOLL{text-overflow:ellipsis;overflow:hidden;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;}/*!sc*/ .fHind{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row;font-size:14px;min-width:0;-webkit-flex-shrink:1;-ms-flex-negative:1;flex-shrink:1;-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;max-width:100%;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;}/*!sc*/ .oDtgN{padding-left:4px;padding-right:4px;font-weight:400;color:var(--fgColor-muted,var(--color-fg-muted,#656d76));font-size:14px;}/*!sc*/ .dnZoUW{font-weight:600;display:inline-block;max-width:100%;font-size:14px;}/*!sc*/ .jRZWlf[data-size="small"]{color:var(--fgColor-default,var(--color-fg-default,#1F2328));margin-left:8px;}/*!sc*/ .kTvpNk{padding-left:8px;padding-top:8px;padding-bottom:8px;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex:1;-ms-flex:1;flex:1;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between;background-color:var(--bgColor-muted,var(--color-canvas-subtle,#f6f8fa));border:1px solid var(--borderColor-default,var(--color-border-default));border-radius:6px 6px 0px 0px;}/*!sc*/ .iNMjfP{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:8px;min-width:0;}/*!sc*/ .gtTaSn{font-size:14px;}/*!sc*/ .dXYHoy{--separator-color:transparent;}/*!sc*/ .jBWIdY{--separator-color:var(--borderColor-default,var(--color-border-default,#d0d7de));}/*!sc*/ .kcLCKF{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:8px;margin-right:8px;}/*!sc*/ .kVWtTz{gap:8px;}/*!sc*/ .gWqxTd{padding-left:8px;padding-right:8px;}/*!sc*/ .gWqxTd linkButtonSx:hover:not([disabled]){-webkit-text-decoration:none;text-decoration:none;}/*!sc*/ .gWqxTd linkButtonSx:focus:not([disabled]){-webkit-text-decoration:none;text-decoration:none;}/*!sc*/ .gWqxTd linkButtonSx:active:not([disabled]){-webkit-text-decoration:none;text-decoration:none;}/*!sc*/ .ivobqY[data-size="small"][data-no-visuals]{border-top-left-radius:0;border-bottom-left-radius:0;}/*!sc*/ .iNRSob[data-size="small"][data-no-visuals]{color:var(--fgColor-muted,var(--color-fg-muted));margin-right:8px;}/*!sc*/ .ffkqe[data-size="small"][data-no-visuals]{color:var(--fgColor-muted,var(--color-fg-muted,#656d76));}/*!sc*/ .hGyMdv{border:1px solid;border-top:none;border-color:var(--borderColor-default,var(--color-border-default,#d0d7de));border-radius:0px 0px 6px 6px;min-width:273px;}/*!sc*/ .fGqKFv{background-color:var(--bgColor-default,var(--color-canvas-default));border:0px;border-width:0;border-radius:0px 0px 6px 6px;padding:0;min-width:0;margin-top:46px;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;}/*!sc*/ .eoaCFS{border-bottom-left-radius:6px;border-bottom-right-radius:6px;padding:32px;min-width:0;}/*!sc*/ .cCoXib{position:fixed;top:0;right:0;height:100%;width:15px;-webkit-transition:-webkit-transform 0.3s;-webkit-transition:transform 0.3s;transition:transform 0.3s;z-index:1;}/*!sc*/ .cCoXib:hover{-webkit-transform:scaleX(1.5);-ms-transform:scaleX(1.5);transform:scaleX(1.5);}/*!sc*/ data-styled.g1[id="Box-sc-g0xbh4-0"]{content:"gISSDQ,iHHOSp,bHLmSv,gsfaIN,leYMvG,KMPzq,hfKjHv,gZWyZE,dwYKDk,ibcGmb,hKaEJF,XosP,bCKfWo,gUkoLg,dmxRgG,bZBlpz,lhTYNA,dbrgmi,bmcJak,dHJiml,cEytCf,fzFXnm,iMnkmv,ghzDag,kHuKdh,hzJBof,kgiVEz,jGhzSQ,faNtbn,fmQaBv,vcvyP,dwNhzn,fGwBZA,dJxjrT,eFxKDQ,dzCJzi,ldRxiI,fVkfyA,gNAmSV,jNEwzY,bsDwxw,jdLMhu,tOISc,hqwSEx,bDVoEr,kYLlPM,gYjEmn,kGqOLL,fHind,oDtgN,dnZoUW,jRZWlf,kTvpNk,iNMjfP,gtTaSn,dXYHoy,jBWIdY,kcLCKF,kVWtTz,gWqxTd,ivobqY,iNRSob,ffkqe,hGyMdv,fGqKFv,eoaCFS,cCoXib,"}/*!sc*/ .hWlpPn{position:relative;display:inline-block;}/*!sc*/ .hWlpPn::after{position:absolute;z-index:1000000;display:none;padding:0.5em 0.75em;font:normal normal 11px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI","Noto Sans",Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji";-webkit-font-smoothing:subpixel-antialiased;color:var(--tooltip-fgColor,var(--fgColor-onEmphasis,var(--color-fg-on-emphasis,#ffffff)));text-align:center;-webkit-text-decoration:none;text-decoration:none;text-shadow:none;text-transform:none;-webkit-letter-spacing:normal;-moz-letter-spacing:normal;-ms-letter-spacing:normal;letter-spacing:normal;word-wrap:break-word;white-space:pre;pointer-events:none;content:attr(aria-label);background:var(--tooltip-bgColor,var(--bgColor-emphasis,var(--color-neutral-emphasis-plus,#24292f)));border-radius:6px;opacity:0;}/*!sc*/ @-webkit-keyframes tooltip-appear{from{opacity:0;}to{opacity:1;}}/*!sc*/ @keyframes tooltip-appear{from{opacity:0;}to{opacity:1;}}/*!sc*/ .hWlpPn:hover::after,.hWlpPn:active::after,.hWlpPn:focus::after,.hWlpPn:focus-within::after{display:inline-block;-webkit-text-decoration:none;text-decoration:none;-webkit-animation-name:tooltip-appear;animation-name:tooltip-appear;-webkit-animation-duration:0.1s;animation-duration:0.1s;-webkit-animation-fill-mode:forwards;animation-fill-mode:forwards;-webkit-animation-timing-function:ease-in;animation-timing-function:ease-in;-webkit-animation-delay:0s;animation-delay:0s;}/*!sc*/ .hWlpPn.tooltipped-no-delay:hover::after,.hWlpPn.tooltipped-no-delay:active::after,.hWlpPn.tooltipped-no-delay:focus::after,.hWlpPn.tooltipped-no-delay:focus-within::after{-webkit-animation-delay:0s;animation-delay:0s;}/*!sc*/ .hWlpPn.tooltipped-multiline:hover::after,.hWlpPn.tooltipped-multiline:active::after,.hWlpPn.tooltipped-multiline:focus::after,.hWlpPn.tooltipped-multiline:focus-within::after{display:table-cell;}/*!sc*/ .hWlpPn.tooltipped-s::after,.hWlpPn.tooltipped-se::after,.hWlpPn.tooltipped-sw::after{top:100%;right:50%;margin-top:6px;}/*!sc*/ .hWlpPn.tooltipped-se::after{right:auto;left:50%;margin-left:-16px;}/*!sc*/ .hWlpPn.tooltipped-sw::after{margin-right:-16px;}/*!sc*/ .hWlpPn.tooltipped-n::after,.hWlpPn.tooltipped-ne::after,.hWlpPn.tooltipped-nw::after{right:50%;bottom:100%;margin-bottom:6px;}/*!sc*/ .hWlpPn.tooltipped-ne::after{right:auto;left:50%;margin-left:-16px;}/*!sc*/ .hWlpPn.tooltipped-nw::after{margin-right:-16px;}/*!sc*/ .hWlpPn.tooltipped-s::after,.hWlpPn.tooltipped-n::after{-webkit-transform:translateX(50%);-ms-transform:translateX(50%);transform:translateX(50%);}/*!sc*/ .hWlpPn.tooltipped-w::after{right:100%;bottom:50%;margin-right:6px;-webkit-transform:translateY(50%);-ms-transform:translateY(50%);transform:translateY(50%);}/*!sc*/ .hWlpPn.tooltipped-e::after{bottom:50%;left:100%;margin-left:6px;-webkit-transform:translateY(50%);-ms-transform:translateY(50%);transform:translateY(50%);}/*!sc*/ .hWlpPn.tooltipped-multiline::after{width:-webkit-max-content;width:-moz-max-content;width:max-content;max-width:250px;word-wrap:break-word;white-space:pre-line;border-collapse:separate;}/*!sc*/ .hWlpPn.tooltipped-multiline.tooltipped-s::after,.hWlpPn.tooltipped-multiline.tooltipped-n::after{right:auto;left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%);}/*!sc*/ .hWlpPn.tooltipped-multiline.tooltipped-w::after,.hWlpPn.tooltipped-multiline.tooltipped-e::after{right:100%;}/*!sc*/ .hWlpPn.tooltipped-align-right-2::after{right:0;margin-right:0;}/*!sc*/ .hWlpPn.tooltipped-align-left-2::after{left:0;margin-left:0;}/*!sc*/ data-styled.g16[id="Tooltip__TooltipBase-sc-17tf59c-0"]{content:"hWlpPn,"}/*!sc*/ .eAtkQz{display:inline-block;overflow:hidden;text-overflow:ellipsis;vertical-align:top;white-space:nowrap;max-width:125px;max-width:100%;}/*!sc*/ data-styled.g18[id="Truncate__StyledTruncate-sc-23o1d2-0"]{content:"eAtkQz,"}/*!sc*/ </style><meta data-hydrostats="publish"/> <!-- --> <!-- --> <button hidden="" data-testid="header-permalink-button" data-hotkey-scope="read-only-cursor-text-area"></button><button hidden=""></button><div><div style="--sticky-pane-height:100vh;--spacing:var(--spacing-none)" class="Box-sc-g0xbh4-0 prc-PageLayout-PageLayoutRoot-1zlEO"><div class="Box-sc-g0xbh4-0 prc-PageLayout-PageLayoutWrapper-s2ao4" data-width="full"><div class="Box-sc-g0xbh4-0 prc-PageLayout-PageLayoutContent-jzDMn"><div tabindex="0" class="Box-sc-g0xbh4-0 gISSDQ"><div class="Box-sc-g0xbh4-0 iHHOSp prc-PageLayout-PaneWrapper-nGO0U" style="--offset-header:0px;--spacing-row:var(--spacing-none);--spacing-column:var(--spacing-none)" data-is-hidden="false" data-position="start" data-sticky="true"><div class="Box-sc-g0xbh4-0 prc-PageLayout-HorizontalDivider-CYLp5 prc-PageLayout-PaneHorizontalDivider-4exOb" data-variant="none" data-position="start" style="--spacing-divider:var(--spacing-none);--spacing:var(--spacing-none)"></div><div class="Box-sc-g0xbh4-0 prc-PageLayout-Pane-Vl5LI" data-resizable="true" style="--spacing:var(--spacing-none);--pane-min-width:256px;--pane-max-width:calc(100vw - var(--pane-max-width-diff));--pane-width-size:var(--pane-width-large);--pane-width:320px"></div><div class="Box-sc-g0xbh4-0 prc-PageLayout-VerticalDivider-4A4Qm prc-PageLayout-PaneVerticalDivider-1c9vy" data-variant="none" data-position="start" style="--spacing:var(--spacing-none)"><div role="slider" aria-label="Draggable pane splitter" aria-valuemin="0" aria-valuemax="0" aria-valuenow="0" aria-valuetext="Pane width 0 pixels" tabindex="0" class="Box-sc-g0xbh4-0 bHLmSv"></div></div></div></div><div class="Box-sc-g0xbh4-0 gsfaIN prc-PageLayout-ContentWrapper-b-QRo" data-is-hidden="false"><div class="Box-sc-g0xbh4-0"></div><div class="Box-sc-g0xbh4-0 prc-PageLayout-Content--F7-I" data-width="full" style="--spacing:var(--spacing-none)"><div data-selector="repos-split-pane-content" tabindex="0" class="Box-sc-g0xbh4-0 leYMvG"><div class="Box-sc-g0xbh4-0 KMPzq"><div class="Box-sc-g0xbh4-0 hfKjHv container"><div class="px-3 pt-3 pb-0" id="StickyHeader"><div class="Box-sc-g0xbh4-0 gZWyZE"><div class="Box-sc-g0xbh4-0 dwYKDk"><div class="Box-sc-g0xbh4-0 ibcGmb react-code-view-header-wrap--narrow"><div class="Box-sc-g0xbh4-0 hKaEJF"><h2 class="Box-sc-g0xbh4-0 XosP prc-Heading-Heading-6CmGO"><button style="--button-color:fg.muted" type="button" aria-label="Expand file tree" data-testid="expand-file-tree-button-mobile" class="Box-sc-g0xbh4-0 bCKfWo prc-Button-ButtonBase-c50BI" data-loading="false" data-size="medium" data-variant="invisible" aria-describedby=":Rld9lab:-loading-announcement"><span data-component="buttonContent" class="Box-sc-g0xbh4-0 gUkoLg prc-Button-ButtonContent-HKbr-"><span data-component="leadingVisual" class="prc-Button-Visual-2epfX prc-Button-VisualWrap-Db-eB"><svg aria-hidden="true" focusable="false" class="octicon octicon-arrow-left" viewBox="0 0 16 16" width="16" height="16" fill="currentColor" display="inline-block" overflow="visible" style="vertical-align:text-bottom"><path d="M7.78 12.53a.75.75 0 0 1-1.06 0L2.47 8.28a.75.75 0 0 1 0-1.06l4.25-4.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042L4.81 7h7.44a.75.75 0 0 1 0 1.5H4.81l2.97 2.97a.75.75 0 0 1 0 1.06Z"></path></svg></span><span data-component="text" class="prc-Button-Label-pTQ3x">Files</span></span></button><span role="tooltip" aria-label="Expand file tree" id="expand-button-file-tree-button" class="Tooltip__TooltipBase-sc-17tf59c-0 hWlpPn tooltipped-se"><button data-component="IconButton" type="button" data-testid="expand-file-tree-button" aria-controls="repos-file-tree" class="prc-Button-ButtonBase-c50BI position-relative ExpandFileTreeButton-module__expandButton--gL4is ExpandFileTreeButton-module__filesButtonBreakpoint--WfX9t fgColor-muted prc-Button-IconButton-szpyj" data-loading="false" data-no-visuals="true" data-size="medium" data-variant="invisible" aria-describedby=":R35d9lab:-loading-announcement" aria-labelledby="expand-button-file-tree-button"><svg aria-hidden="true" focusable="false" class="octicon octicon-sidebar-collapse" viewBox="0 0 16 16" width="16" height="16" fill="currentColor" display="inline-block" overflow="visible" style="vertical-align:text-bottom"><path d="M6.823 7.823a.25.25 0 0 1 0 .354l-2.396 2.396A.25.25 0 0 1 4 10.396V5.604a.25.25 0 0 1 .427-.177Z"></path><path d="M1.75 0h12.5C15.216 0 16 .784 16 1.75v12.5A1.75 1.75 0 0 1 14.25 16H1.75A1.75 1.75 0 0 1 0 14.25V1.75C0 .784.784 0 1.75 0ZM1.5 1.75v12.5c0 .138.112.25.25.25H9.5v-13H1.75a.25.25 0 0 0-.25.25ZM11 14.5h3.25a.25.25 0 0 0 .25-.25V1.75a.25.25 0 0 0-.25-.25H11Z"></path></svg></button></span><button hidden="" data-testid="" data-hotkey-scope="read-only-cursor-text-area"></button></h2></div><div class="react-code-view-header-mb--narrow mr-2"><button type="button" aria-haspopup="true" aria-expanded="false" tabindex="0" aria-label="main branch" data-testid="anchor-button" class="Box-sc-g0xbh4-0 dmxRgG prc-Button-ButtonBase-c50BI ref-selector-class" data-loading="false" data-size="medium" data-variant="default" aria-describedby="branch-picker-repos-header-ref-selector-wide-loading-announcement" id="branch-picker-repos-header-ref-selector-wide"><span data-component="buttonContent" class="Box-sc-g0xbh4-0 gUkoLg prc-Button-ButtonContent-HKbr-"><span data-component="text" class="prc-Button-Label-pTQ3x"><div class="Box-sc-g0xbh4-0 bZBlpz"><div class="Box-sc-g0xbh4-0 lhTYNA"><svg aria-hidden="true" focusable="false" class="octicon octicon-git-branch" viewBox="0 0 16 16" width="16" height="16" fill="currentColor" display="inline-block" overflow="visible" style="vertical-align:text-bottom"><path d="M9.5 3.25a2.25 2.25 0 1 1 3 2.122V6A2.5 2.5 0 0 1 10 8.5H6a1 1 0 0 0-1 1v1.128a2.251 2.251 0 1 1-1.5 0V5.372a2.25 2.25 0 1 1 1.5 0v1.836A2.493 2.493 0 0 1 6 7h4a1 1 0 0 0 1-1v-.628A2.25 2.25 0 0 1 9.5 3.25Zm-6 0a.75.75 0 1 0 1.5 0 .75.75 0 0 0-1.5 0Zm8.25-.75a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5ZM4.25 12a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5Z"></path></svg></div><div class="Box-sc-g0xbh4-0 dbrgmi ref-selector-button-text-container"><span class="Box-sc-g0xbh4-0 bmcJak prc-Text-Text-0ima0"> <!-- -->main</span></div></div></span><span data-component="trailingVisual" class="prc-Button-Visual-2epfX prc-Button-VisualWrap-Db-eB"><svg aria-hidden="true" focusable="false" class="octicon octicon-triangle-down" viewBox="0 0 16 16" width="16" height="16" fill="currentColor" display="inline-block" overflow="visible" style="vertical-align:text-bottom"><path d="m4.427 7.427 3.396 3.396a.25.25 0 0 0 .354 0l3.396-3.396A.25.25 0 0 0 11.396 7H4.604a.25.25 0 0 0-.177.427Z"></path></svg></span></span></button><button hidden="" data-hotkey-scope="read-only-cursor-text-area"></button></div><div class="Box-sc-g0xbh4-0 dHJiml react-code-view-header-mb--narrow"><div class="Box-sc-g0xbh4-0 cEytCf"><nav data-testid="breadcrumbs" aria-labelledby="repos-header-breadcrumb-heading" id="repos-header-breadcrumb" class="Box-sc-g0xbh4-0 fzFXnm"><h2 class="sr-only ScreenReaderHeading-module__userSelectNone--vW4Cq prc-Heading-Heading-6CmGO" data-testid="screen-reader-heading" id="repos-header-breadcrumb-heading">Breadcrumbs</h2><ol class="Box-sc-g0xbh4-0 iMnkmv"><li class="Box-sc-g0xbh4-0 ghzDag"><a class="Box-sc-g0xbh4-0 kHuKdh prc-Link-Link-85e08" sx="[object Object]" data-testid="breadcrumbs-repo-link" href="/python/peps/tree/main">peps</a></li><li class="Box-sc-g0xbh4-0 ghzDag"><span class="Box-sc-g0xbh4-0 hzJBof prc-Text-Text-0ima0" aria-hidden="true">/</span><a class="Box-sc-g0xbh4-0 kgiVEz prc-Link-Link-85e08" sx="[object Object]" href="/python/peps/tree/main/peps">peps</a></li></ol></nav><div data-testid="breadcrumbs-filename" class="Box-sc-g0xbh4-0 ghzDag"><span class="Box-sc-g0xbh4-0 hzJBof prc-Text-Text-0ima0" aria-hidden="true">/</span><h1 class="Box-sc-g0xbh4-0 jGhzSQ prc-Heading-Heading-6CmGO" tabindex="-1" id="file-name-id">pep-0327.rst</h1></div><button data-component="IconButton" type="button" class="prc-Button-ButtonBase-c50BI ml-2 prc-Button-IconButton-szpyj" data-loading="false" data-no-visuals="true" data-size="small" data-variant="invisible" aria-describedby=":Rftd9lab:-loading-announcement" aria-labelledby=":R1td9lab:"><svg aria-hidden="true" focusable="false" class="octicon octicon-copy" viewBox="0 0 16 16" width="16" height="16" fill="currentColor" display="inline-block" overflow="visible" style="vertical-align:text-bottom"><path d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 0 1 0 1.5h-1.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-1.5a.75.75 0 0 1 1.5 0v1.5A1.75 1.75 0 0 1 9.25 16h-7.5A1.75 1.75 0 0 1 0 14.25Z"></path><path d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0 1 14.25 11h-7.5A1.75 1.75 0 0 1 5 9.25Zm1.75-.25a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-7.5a.25.25 0 0 0-.25-.25Z"></path></svg></button><span class="CopyToClipboardButton-module__tooltip--Dq1IB prc-TooltipV2-Tooltip-cYMVY" data-direction="nw" aria-label="Copy path" aria-hidden="true" id=":R1td9lab:">Copy path</span></div></div></div><div class="react-code-view-header-element--wide"><div class="Box-sc-g0xbh4-0 faNtbn"><div class="d-flex gap-2"> <div><div class="Box-sc-g0xbh4-0 fmQaBv"><span class="Box-sc-g0xbh4-0 vcvyP TextInput-wrapper prc-components-TextInputWrapper-i1ofR prc-components-TextInputBaseWrapper-ueK9q" data-leading-visual="true" data-trailing-visual="true" aria-busy="false"><span class="TextInput-icon" id=":Rb66d9lab:" aria-hidden="true"><svg aria-hidden="true" focusable="false" class="octicon octicon-search" viewBox="0 0 16 16" width="16" height="16" fill="currentColor" display="inline-block" overflow="visible" style="vertical-align:text-bottom"><path d="M10.68 11.74a6 6 0 0 1-7.922-8.982 6 6 0 0 1 8.982 7.922l3.04 3.04a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215ZM11.5 7a4.499 4.499 0 1 0-8.997 0A4.499 4.499 0 0 0 11.5 7Z"></path></svg></span><input type="text" aria-label="Go to file" role="combobox" aria-controls="file-results-list" aria-expanded="false" aria-haspopup="dialog" autoCorrect="off" spellcheck="false" placeholder="Go to file" aria-describedby=":Rb66d9lab: :Rb66d9labH1:" data-component="input" class="prc-components-Input-Ic-y8" value=""/><span class="TextInput-icon" id=":Rb66d9labH1:" aria-hidden="true"></span></span></div><button hidden="" data-testid="" data-hotkey-scope="read-only-cursor-text-area"></button><button hidden=""></button></div><button type="button" class="Box-sc-g0xbh4-0 dwNhzn prc-Button-ButtonBase-c50BI" data-loading="false" data-no-visuals="true" data-size="medium" data-variant="default" aria-describedby=":R5a6d9lab:-loading-announcement"><span data-component="buttonContent" class="Box-sc-g0xbh4-0 gUkoLg prc-Button-ButtonContent-HKbr-"><span data-component="text" class="prc-Button-Label-pTQ3x">Blame</span></span></button><button hidden="" data-testid="" data-hotkey-scope="read-only-cursor-text-area"></button><button data-component="IconButton" type="button" aria-label="More file actions" title="More file actions" data-testid="more-file-actions-button-nav-menu-wide" aria-haspopup="true" aria-expanded="false" tabindex="0" class="Box-sc-g0xbh4-0 fGwBZA prc-Button-ButtonBase-c50BI js-blob-dropdown-click prc-Button-IconButton-szpyj" data-loading="false" data-no-visuals="true" data-size="medium" data-variant="default" aria-describedby=":R2a6d9lab:-loading-announcement" id=":R2a6d9lab:"><svg aria-hidden="true" focusable="false" class="octicon octicon-kebab-horizontal" viewBox="0 0 16 16" width="16" height="16" fill="currentColor" display="inline-block" overflow="visible" style="vertical-align:text-bottom"><path d="M8 9a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3ZM1.5 9a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Zm13 0a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z"></path></svg></button> </div></div></div><div class="react-code-view-header-element--narrow"><div class="Box-sc-g0xbh4-0 faNtbn"><div class="d-flex gap-2"> <button type="button" class="Box-sc-g0xbh4-0 dwNhzn prc-Button-ButtonBase-c50BI" data-loading="false" data-no-visuals="true" data-size="medium" data-variant="default" aria-describedby=":R5a7d9lab:-loading-announcement"><span data-component="buttonContent" class="Box-sc-g0xbh4-0 gUkoLg prc-Button-ButtonContent-HKbr-"><span data-component="text" class="prc-Button-Label-pTQ3x">Blame</span></span></button><button hidden="" data-testid="" data-hotkey-scope="read-only-cursor-text-area"></button><button data-component="IconButton" type="button" aria-label="More file actions" title="More file actions" data-testid="more-file-actions-button-nav-menu-narrow" aria-haspopup="true" aria-expanded="false" tabindex="0" class="Box-sc-g0xbh4-0 fGwBZA prc-Button-ButtonBase-c50BI js-blob-dropdown-click prc-Button-IconButton-szpyj" data-loading="false" data-no-visuals="true" data-size="medium" data-variant="default" aria-describedby=":R2a7d9lab:-loading-announcement" id=":R2a7d9lab:"><svg aria-hidden="true" focusable="false" class="octicon octicon-kebab-horizontal" viewBox="0 0 16 16" width="16" height="16" fill="currentColor" display="inline-block" overflow="visible" style="vertical-align:text-bottom"><path d="M8 9a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3ZM1.5 9a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Zm13 0a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z"></path></svg></button> </div></div></div></div></div></div></div></div><div class="Box-sc-g0xbh4-0 dJxjrT react-code-view-bottom-padding"> <div class="Box-sc-g0xbh4-0 eFxKDQ"></div> <!-- --> <!-- --> </div><div class="Box-sc-g0xbh4-0 dJxjrT"> <!-- --> <!-- --> <div class="d-flex flex-column border rounded-2 mb-3 pl-1"><div class="Box-sc-g0xbh4-0 dzCJzi"><h2 class="sr-only ScreenReaderHeading-module__userSelectNone--vW4Cq prc-Heading-Heading-6CmGO" data-testid="screen-reader-heading">Latest commit</h2><div style="width:120px" class="Skeleton Skeleton--text" data-testid="loading"> </div><div class="d-flex flex-shrink-0 gap-2"><div data-testid="latest-commit-details" class="d-none d-sm-flex flex-items-center"></div><div class="d-flex gap-2"><h2 class="sr-only ScreenReaderHeading-module__userSelectNone--vW4Cq prc-Heading-Heading-6CmGO" data-testid="screen-reader-heading">History</h2><a href="/python/peps/commits/main/peps/pep-0327.rst" class="prc-Button-ButtonBase-c50BI d-none d-lg-flex LinkButton-module__code-view-link-button--xvCGA flex-items-center fgColor-default" data-loading="false" data-size="small" data-variant="invisible" aria-describedby=":R5dlal9lab:-loading-announcement"><span data-component="buttonContent" data-align="center" class="prc-Button-ButtonContent-HKbr-"><span data-component="leadingVisual" class="prc-Button-Visual-2epfX prc-Button-VisualWrap-Db-eB"><svg aria-hidden="true" focusable="false" class="octicon octicon-history" viewBox="0 0 16 16" width="16" height="16" fill="currentColor" display="inline-block" overflow="visible" style="vertical-align:text-bottom"><path d="m.427 1.927 1.215 1.215a8.002 8.002 0 1 1-1.6 5.685.75.75 0 1 1 1.493-.154 6.5 6.5 0 1 0 1.18-4.458l1.358 1.358A.25.25 0 0 1 3.896 6H.25A.25.25 0 0 1 0 5.75V2.104a.25.25 0 0 1 .427-.177ZM7.75 4a.75.75 0 0 1 .75.75v2.992l2.028.812a.75.75 0 0 1-.557 1.392l-2.5-1A.751.751 0 0 1 7 8.25v-3.5A.75.75 0 0 1 7.75 4Z"></path></svg></span><span data-component="text" class="prc-Button-Label-pTQ3x"><span class="fgColor-default">History</span></span></span></a><div class="d-sm-none"></div><div class="d-flex d-lg-none"><span role="tooltip" aria-label="History" id="history-icon-button-tooltip" class="Tooltip__TooltipBase-sc-17tf59c-0 hWlpPn tooltipped-n"><a href="/python/peps/commits/main/peps/pep-0327.rst" class="prc-Button-ButtonBase-c50BI LinkButton-module__code-view-link-button--xvCGA flex-items-center fgColor-default" data-loading="false" data-size="small" data-variant="invisible" aria-describedby=":Rpdlal9lab:-loading-announcement history-icon-button-tooltip"><span data-component="buttonContent" data-align="center" class="prc-Button-ButtonContent-HKbr-"><span data-component="leadingVisual" class="prc-Button-Visual-2epfX prc-Button-VisualWrap-Db-eB"><svg aria-hidden="true" focusable="false" class="octicon octicon-history" viewBox="0 0 16 16" width="16" height="16" fill="currentColor" display="inline-block" overflow="visible" style="vertical-align:text-bottom"><path d="m.427 1.927 1.215 1.215a8.002 8.002 0 1 1-1.6 5.685.75.75 0 1 1 1.493-.154 6.5 6.5 0 1 0 1.18-4.458l1.358 1.358A.25.25 0 0 1 3.896 6H.25A.25.25 0 0 1 0 5.75V2.104a.25.25 0 0 1 .427-.177ZM7.75 4a.75.75 0 0 1 .75.75v2.992l2.028.812a.75.75 0 0 1-.557 1.392l-2.5-1A.751.751 0 0 1 7 8.25v-3.5A.75.75 0 0 1 7.75 4Z"></path></svg></span></span></a></span></div></div></div></div></div><div class="Box-sc-g0xbh4-0 ldRxiI"><div class="Box-sc-g0xbh4-0 fVkfyA container"><div class="Box-sc-g0xbh4-0 gNAmSV react-code-size-details-banner"><div class="Box-sc-g0xbh4-0 jNEwzY react-code-size-details-banner"><div class="Box-sc-g0xbh4-0 bsDwxw text-mono"><div title="39.5 KB" data-testid="blob-size" class="Truncate__StyledTruncate-sc-23o1d2-0 eAtkQz"><span>1239 lines (899 loc) · 39.5 KB</span></div></div></div></div><div class="Box-sc-g0xbh4-0 jdLMhu react-blob-view-header-sticky" id="repos-sticky-header"><div class="Box-sc-g0xbh4-0 tOISc"><div class="react-blob-sticky-header"><div class="Box-sc-g0xbh4-0 hqwSEx"><div class="Box-sc-g0xbh4-0 bDVoEr"><div class="Box-sc-g0xbh4-0 kYLlPM"><div class="Box-sc-g0xbh4-0 gYjEmn"><button type="button" aria-haspopup="true" aria-expanded="false" tabindex="0" aria-label="main branch" data-testid="anchor-button" class="Box-sc-g0xbh4-0 dmxRgG prc-Button-ButtonBase-c50BI ref-selector-class" data-loading="false" data-size="medium" data-variant="default" aria-describedby="branch-picker-repos-header-ref-selector-loading-announcement" id="branch-picker-repos-header-ref-selector"><span data-component="buttonContent" class="Box-sc-g0xbh4-0 gUkoLg prc-Button-ButtonContent-HKbr-"><span data-component="text" class="prc-Button-Label-pTQ3x"><div class="Box-sc-g0xbh4-0 bZBlpz"><div class="Box-sc-g0xbh4-0 lhTYNA"><svg aria-hidden="true" focusable="false" class="octicon octicon-git-branch" viewBox="0 0 16 16" width="16" height="16" fill="currentColor" display="inline-block" overflow="visible" style="vertical-align:text-bottom"><path d="M9.5 3.25a2.25 2.25 0 1 1 3 2.122V6A2.5 2.5 0 0 1 10 8.5H6a1 1 0 0 0-1 1v1.128a2.251 2.251 0 1 1-1.5 0V5.372a2.25 2.25 0 1 1 1.5 0v1.836A2.493 2.493 0 0 1 6 7h4a1 1 0 0 0 1-1v-.628A2.25 2.25 0 0 1 9.5 3.25Zm-6 0a.75.75 0 1 0 1.5 0 .75.75 0 0 0-1.5 0Zm8.25-.75a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5ZM4.25 12a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5Z"></path></svg></div><div class="Box-sc-g0xbh4-0 dbrgmi ref-selector-button-text-container"><span class="Box-sc-g0xbh4-0 bmcJak prc-Text-Text-0ima0"> <!-- -->main</span></div></div></span><span data-component="trailingVisual" class="prc-Button-Visual-2epfX prc-Button-VisualWrap-Db-eB"><svg aria-hidden="true" focusable="false" class="octicon octicon-triangle-down" viewBox="0 0 16 16" width="16" height="16" fill="currentColor" display="inline-block" overflow="visible" style="vertical-align:text-bottom"><path d="m4.427 7.427 3.396 3.396a.25.25 0 0 0 .354 0l3.396-3.396A.25.25 0 0 0 11.396 7H4.604a.25.25 0 0 0-.177.427Z"></path></svg></span></span></button><button hidden="" data-hotkey-scope="read-only-cursor-text-area"></button></div><div class="Box-sc-g0xbh4-0 kGqOLL"><div class="Box-sc-g0xbh4-0 fHind"><nav data-testid="breadcrumbs" aria-labelledby="sticky-breadcrumb-heading" id="sticky-breadcrumb" class="Box-sc-g0xbh4-0 fzFXnm"><h2 class="sr-only ScreenReaderHeading-module__userSelectNone--vW4Cq prc-Heading-Heading-6CmGO" data-testid="screen-reader-heading" id="sticky-breadcrumb-heading">Breadcrumbs</h2><ol class="Box-sc-g0xbh4-0 iMnkmv"><li class="Box-sc-g0xbh4-0 ghzDag"><a class="Box-sc-g0xbh4-0 kHuKdh prc-Link-Link-85e08" sx="[object Object]" data-testid="breadcrumbs-repo-link" href="/python/peps/tree/main">peps</a></li><li class="Box-sc-g0xbh4-0 ghzDag"><span class="Box-sc-g0xbh4-0 oDtgN prc-Text-Text-0ima0" aria-hidden="true">/</span><a class="Box-sc-g0xbh4-0 kgiVEz prc-Link-Link-85e08" sx="[object Object]" href="/python/peps/tree/main/peps">peps</a></li></ol></nav><div data-testid="breadcrumbs-filename" class="Box-sc-g0xbh4-0 ghzDag"><span class="Box-sc-g0xbh4-0 oDtgN prc-Text-Text-0ima0" aria-hidden="true">/</span><h1 class="Box-sc-g0xbh4-0 dnZoUW prc-Heading-Heading-6CmGO" tabindex="-1" id="sticky-file-name-id">pep-0327.rst</h1></div></div></div></div><button style="--button-color:fg.default" type="button" class="Box-sc-g0xbh4-0 jRZWlf prc-Button-ButtonBase-c50BI" data-loading="false" data-size="small" data-variant="invisible" aria-describedby=":Riptal9lab:-loading-announcement"><span data-component="buttonContent" class="Box-sc-g0xbh4-0 gUkoLg prc-Button-ButtonContent-HKbr-"><span data-component="leadingVisual" class="prc-Button-Visual-2epfX prc-Button-VisualWrap-Db-eB"><svg aria-hidden="true" focusable="false" class="octicon octicon-arrow-up" viewBox="0 0 16 16" width="16" height="16" fill="currentColor" display="inline-block" overflow="visible" style="vertical-align:text-bottom"><path d="M3.47 7.78a.75.75 0 0 1 0-1.06l4.25-4.25a.75.75 0 0 1 1.06 0l4.25 4.25a.751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018L9 4.81v7.44a.75.75 0 0 1-1.5 0V4.81L4.53 7.78a.75.75 0 0 1-1.06 0Z"></path></svg></span><span data-component="text" class="prc-Button-Label-pTQ3x">Top</span></span></button></div></div></div><div class="Box-sc-g0xbh4-0 kTvpNk"><h2 class="sr-only ScreenReaderHeading-module__userSelectNone--vW4Cq prc-Heading-Heading-6CmGO" data-testid="screen-reader-heading">File metadata and controls</h2><div class="Box-sc-g0xbh4-0 iNMjfP"><ul aria-label="File view" class="Box-sc-g0xbh4-0 gtTaSn prc-SegmentedControl-SegmentedControl-e7570" data-size="small"><li class="Box-sc-g0xbh4-0 dXYHoy prc-SegmentedControl-Item-7Aq6h" data-selected="true"><button aria-current="true" class="prc-SegmentedControl-Button-ojWXD" type="button"><span class="prc-SegmentedControl-Content-gnQ4n"><div class="Box-sc-g0xbh4-0 prc-SegmentedControl-Text-c5gSh" data-text="Preview">Preview</div></span></button></li><li class="Box-sc-g0xbh4-0 jBWIdY prc-SegmentedControl-Item-7Aq6h"><button aria-current="false" class="prc-SegmentedControl-Button-ojWXD" type="button"><span class="prc-SegmentedControl-Content-gnQ4n"><div class="Box-sc-g0xbh4-0 prc-SegmentedControl-Text-c5gSh" data-text="Code">Code</div></span></button></li><li class="Box-sc-g0xbh4-0 jBWIdY prc-SegmentedControl-Item-7Aq6h"><button aria-current="false" class="prc-SegmentedControl-Button-ojWXD" type="button"><span class="prc-SegmentedControl-Content-gnQ4n"><div class="Box-sc-g0xbh4-0 prc-SegmentedControl-Text-c5gSh" data-text="Blame">Blame</div></span></button></li></ul><button hidden="" data-testid="" data-hotkey-scope="read-only-cursor-text-area"></button><button hidden="" data-testid="" data-hotkey-scope="read-only-cursor-text-area"></button><button hidden="" data-testid="" data-hotkey-scope="read-only-cursor-text-area"></button><div class="Box-sc-g0xbh4-0 jNEwzY react-code-size-details-in-header"><div class="Box-sc-g0xbh4-0 bsDwxw text-mono"><div title="39.5 KB" data-testid="blob-size" class="Truncate__StyledTruncate-sc-23o1d2-0 eAtkQz"><span>1239 lines (899 loc) · 39.5 KB</span></div></div></div></div><div class="Box-sc-g0xbh4-0 kcLCKF"><div class="Box-sc-g0xbh4-0 kVWtTz react-blob-header-edit-and-raw-actions"><div class="Box-sc-g0xbh4-0 prc-ButtonGroup-ButtonGroup-vcMeG"><div><a href="https://github.com/python/peps/raw/refs/heads/main/peps/pep-0327.rst" data-testid="raw-button" class="Box-sc-g0xbh4-0 gWqxTd prc-Button-ButtonBase-c50BI" data-loading="false" data-no-visuals="true" data-size="small" data-variant="default" aria-describedby=":R5csptal9lab:-loading-announcement"><span data-component="buttonContent" class="Box-sc-g0xbh4-0 gUkoLg prc-Button-ButtonContent-HKbr-"><span data-component="text" class="prc-Button-Label-pTQ3x">Raw</span></span></a></div><div><button data-component="IconButton" type="button" aria-label="Copy raw content" data-testid="copy-raw-button" class="prc-Button-ButtonBase-c50BI prc-Button-IconButton-szpyj" data-loading="false" data-no-visuals="true" data-size="small" data-variant="default" aria-describedby=":Rpcsptal9lab:-loading-announcement"><svg aria-hidden="true" focusable="false" class="octicon octicon-copy" viewBox="0 0 16 16" width="16" height="16" fill="currentColor" display="inline-block" overflow="visible" style="vertical-align:text-bottom"><path d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 0 1 0 1.5h-1.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-1.5a.75.75 0 0 1 1.5 0v1.5A1.75 1.75 0 0 1 9.25 16h-7.5A1.75 1.75 0 0 1 0 14.25Z"></path><path d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0 1 14.25 11h-7.5A1.75 1.75 0 0 1 5 9.25Zm1.75-.25a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-7.5a.25.25 0 0 0-.25-.25Z"></path></svg></button></div><div><span role="tooltip" aria-label="Download raw file" id=":Rdcsptal9lab:" class="Tooltip__TooltipBase-sc-17tf59c-0 hWlpPn tooltipped-n"><button data-component="IconButton" type="button" aria-label="Download raw content" data-testid="download-raw-button" class="Box-sc-g0xbh4-0 ivobqY prc-Button-ButtonBase-c50BI prc-Button-IconButton-szpyj" data-loading="false" data-no-visuals="true" data-size="small" data-variant="default" aria-describedby=":Rtcsptal9lab:-loading-announcement"><svg aria-hidden="true" focusable="false" class="octicon octicon-download" viewBox="0 0 16 16" width="16" height="16" fill="currentColor" display="inline-block" overflow="visible" style="vertical-align:text-bottom"><path d="M2.75 14A1.75 1.75 0 0 1 1 12.25v-2.5a.75.75 0 0 1 1.5 0v2.5c0 .138.112.25.25.25h10.5a.25.25 0 0 0 .25-.25v-2.5a.75.75 0 0 1 1.5 0v2.5A1.75 1.75 0 0 1 13.25 14Z"></path><path d="M7.25 7.689V2a.75.75 0 0 1 1.5 0v5.689l1.97-1.969a.749.749 0 1 1 1.06 1.06l-3.25 3.25a.749.749 0 0 1-1.06 0L4.22 6.78a.749.749 0 1 1 1.06-1.06l1.97 1.969Z"></path></svg></button></span></div></div><button hidden="" data-testid="raw-button-shortcut" data-hotkey-scope="read-only-cursor-text-area"></button><button hidden="" data-testid="copy-raw-button-shortcut" data-hotkey-scope="read-only-cursor-text-area"></button><button hidden="" data-testid="download-raw-button-shortcut" data-hotkey-scope="read-only-cursor-text-area"></button></div><button data-component="IconButton" type="button" aria-label="Outline" aria-pressed="false" class="Box-sc-g0xbh4-0 iNRSob prc-Button-ButtonBase-c50BI prc-Button-IconButton-szpyj" data-loading="false" data-no-visuals="true" data-size="small" data-variant="invisible" aria-describedby=":R6sptal9lab:-loading-announcement"><svg aria-hidden="true" focusable="false" class="octicon octicon-list-unordered" viewBox="0 0 16 16" width="16" height="16" fill="currentColor" display="inline-block" overflow="visible" style="vertical-align:text-bottom"><path d="M5.75 2.5h8.5a.75.75 0 0 1 0 1.5h-8.5a.75.75 0 0 1 0-1.5Zm0 5h8.5a.75.75 0 0 1 0 1.5h-8.5a.75.75 0 0 1 0-1.5Zm0 5h8.5a.75.75 0 0 1 0 1.5h-8.5a.75.75 0 0 1 0-1.5ZM2 14a1 1 0 1 1 0-2 1 1 0 0 1 0 2Zm1-6a1 1 0 1 1-2 0 1 1 0 0 1 2 0ZM2 4a1 1 0 1 1 0-2 1 1 0 0 1 0 2Z"></path></svg></button><div class="react-blob-header-edit-and-raw-actions-combined"><button data-component="IconButton" type="button" aria-label="Edit and raw actions" title="More file actions" data-testid="more-file-actions-button" aria-haspopup="true" aria-expanded="false" tabindex="0" class="Box-sc-g0xbh4-0 ffkqe prc-Button-ButtonBase-c50BI js-blob-dropdown-click prc-Button-IconButton-szpyj" data-loading="false" data-no-visuals="true" data-size="small" data-variant="invisible" aria-describedby=":Rnsptal9lab:-loading-announcement" id=":Rnsptal9lab:"><svg aria-hidden="true" focusable="false" class="octicon octicon-kebab-horizontal" viewBox="0 0 16 16" width="16" height="16" fill="currentColor" display="inline-block" overflow="visible" style="vertical-align:text-bottom"><path d="M8 9a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3ZM1.5 9a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Zm13 0a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z"></path></svg></button></div></div></div></div><div></div></div><div class="Box-sc-g0xbh4-0 hGyMdv"><section aria-labelledby="file-name-id-wide file-name-id-mobile" class="Box-sc-g0xbh4-0 fGqKFv"><div class="Box-sc-g0xbh4-0 eoaCFS js-snippet-clipboard-copy-unpositioned undefined" data-hpc="true"><article class="markdown-body entry-content container-lg" itemprop="text"><p dir="auto">PEP: 327 Title: Decimal Data Type Author: Facundo Batista &lt;<a href="mailto:facundo@taniquetil.com.ar">facundo@taniquetil.com.ar</a>&gt; Status: Final Type: Standards Track Created: 17-Oct-2003 Python-Version: 2.4 Post-History: 30-Nov-2003, 02-Jan-2004, 29-Jan-2004</p> <a name="user-content-abstract"></a> <div class="markdown-heading" dir="auto"><h2 tabindex="-1" class="heading-element" dir="auto">Abstract</h2><a id="user-content-abstract" class="anchor" aria-label="Permalink: Abstract" href="#abstract"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">The idea is to have a Decimal data type, for every use where decimals are needed but binary floating point is too inexact.</p> <p dir="auto">The Decimal data type will support the Python standard functions and operations, and must comply with the decimal arithmetic ANSI standard X3.274-1996 <a href="#id19" id="user-content-id1">[1]</a>.</p> <p dir="auto">Decimal will be floating point (as opposed to fixed point) and will have bounded precision (the precision is the upper limit on the number of significant digits in a result). However, precision is user-settable, and a notion of significant trailing zeroes is supported so that fixed-point usage is also possible.</p> <p dir="auto">This work is based on code and test functions written by Eric Price, Aahz and Tim Peters. Just before Python 2.4a1, the decimal.py <a href="#reference-implementation">reference implementation</a> was moved into the standard library; along with the documentation and the test suite, this was the work of Raymond Hettinger. Much of the explanation in this PEP is taken from Cowlishaw's work <a href="#id20" id="user-content-id2">[2]</a>, comp.lang.python and python-dev.</p> <a name="user-content-motivation"></a> <div class="markdown-heading" dir="auto"><h2 tabindex="-1" class="heading-element" dir="auto">Motivation</h2><a id="user-content-motivation" class="anchor" aria-label="Permalink: Motivation" href="#motivation"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">Here I'll expose the reasons of why I think a Decimal data type is needed and why other numeric data types are not enough.</p> <p dir="auto">I wanted a Money data type, and after proposing a pre-PEP in comp.lang.python, the community agreed to have a numeric data type with the needed arithmetic behaviour, and then build Money over it: all the considerations about quantity of digits after the decimal point, rounding, etc., will be handled through Money. It is not the purpose of this PEP to have a data type that can be used as Money without further effort.</p> <p dir="auto">One of the biggest advantages of implementing a standard is that someone already thought out all the creepy cases for you. And to a standard GvR redirected me: Mike Cowlishaw's General Decimal Arithmetic specification <a href="#id20" id="user-content-id3">[2]</a>. This document defines a general purpose decimal arithmetic. A correct implementation of this specification will conform to the decimal arithmetic defined in ANSI/IEEE standard 854-1987, except for some minor restrictions, and will also provide unrounded decimal arithmetic and integer arithmetic as proper subsets.</p> <a name="user-content-the-problem-with-binary-float"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">The problem with binary float</h3><a id="user-content-the-problem-with-binary-float" class="anchor" aria-label="Permalink: The problem with binary float" href="#the-problem-with-binary-float"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">In decimal math, there are many numbers that can't be represented with a fixed number of decimal digits, e.g. 1/3 = 0.3333333333.......</p> <p dir="auto">In base 2 (the way that standard floating point is calculated), 1/2 = 0.1, 1/4 = 0.01, 1/8 = 0.001, etc. Decimal 0.2 equals 2/10 equals 1/5, resulting in the binary fractional number 0.001100110011001... As you can see, the problem is that some decimal numbers can't be represented exactly in binary, resulting in small roundoff errors.</p> <p dir="auto">So we need a decimal data type that represents exactly decimal numbers. Instead of a binary data type, we need a decimal one.</p> <a name="user-content-why-floating-point"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">Why floating point?</h3><a id="user-content-why-floating-point" class="anchor" aria-label="Permalink: Why floating point?" href="#why-floating-point"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">So we go to decimal, but why <em>floating point</em>?</p> <p dir="auto">Floating point numbers use a fixed quantity of digits (precision) to represent a number, working with an exponent when the number gets too big or too small. For example, with a precision of 5:</p> <pre> 1234 ==&gt; 1234e0 12345 ==&gt; 12345e0 123456 ==&gt; 12346e1 </pre> <p dir="auto">(note that in the last line the number got rounded to fit in five digits).</p> <p dir="auto">In contrast, we have the example of a <code>long</code> integer with infinite precision, meaning that you can have the number as big as you want, and you'll never lose any information.</p> <p dir="auto">In a fixed point number, the position of the decimal point is fixed. For a fixed point data type, check Tim Peter's FixedPoint at SourceForge <a href="#id22" id="user-content-id4">[4]</a>. I'll go for floating point because it's easier to implement the arithmetic behaviour of the standard, and then you can implement a fixed point data type over Decimal.</p> <p dir="auto">But why can't we have a floating point number with infinite precision? It's not so easy, because of inexact divisions. E.g.: 1/3 = 0.3333333333333... ad infinitum. In this case you should store an infinite amount of 3s, which takes too much memory, ;).</p> <p dir="auto">John Roth proposed to eliminate the division operator and force the user to use an explicit method, just to avoid this kind of trouble. This generated adverse reactions in comp.lang.python, as everybody wants to have support for the <code>/</code> operator in a numeric data type.</p> <p dir="auto">With this exposed maybe you're thinking "Hey! Can we just store the 1 and the 3 as numerator and denominator?", which takes us to the next point.</p> <a name="user-content-why-not-rational"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">Why not rational?</h3><a id="user-content-why-not-rational" class="anchor" aria-label="Permalink: Why not rational?" href="#why-not-rational"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">Rational numbers are stored using two integer numbers, the numerator and the denominator. This implies that the arithmetic operations can't be executed directly (e.g. to add two rational numbers you first need to calculate the common denominator).</p> <p dir="auto">Quoting Alex Martelli:</p> <blockquote> The performance implications of the fact that summing two rationals (which take O(M) and O(N) space respectively) gives a rational which takes O(M+N) memory space is just too troublesome. There are excellent Rational implementations in both pure Python and as extensions (e.g., gmpy), but they'll always be a "niche market" IMHO. Probably worth PEPping, not worth doing without Decimal -- which is the right way to represent sums of money, a truly major use case in the real world.</blockquote> <p dir="auto">Anyway, if you're interested in this data type, you maybe will want to take a look at <a href="http://www.python.org/dev/peps/pep-0239" rel="nofollow">PEP 239</a>: Adding a Rational Type to Python.</p> <a name="user-content-so-what-do-we-have"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">So, what do we have?</h3><a id="user-content-so-what-do-we-have" class="anchor" aria-label="Permalink: So, what do we have?" href="#so-what-do-we-have"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">The result is a Decimal data type, with bounded precision and floating point.</p> <p dir="auto">Will it be useful? I can't say it better than Alex Martelli:</p> <blockquote> Python (out of the box) doesn't let you have binary floating point numbers <em>with whatever precision you specify</em>: you're limited to what your hardware supplies. Decimal, be it used as a fixed or floating point number, should suffer from no such limitation: whatever bounded precision you may specify on number creation (your memory permitting) should work just as well. Most of the expense of programming simplicity can be hidden from application programs and placed in a suitable decimal arithmetic type. As per <a href="http://speleotrove.com/decimal/" rel="nofollow">http://speleotrove.com/decimal/</a>, <em>a single data type can be used for integer, fixed-point, and floating-point decimal arithmetic</em> -- and for money arithmetic which doesn't drive the application programmer crazy.</blockquote> <p dir="auto">There are several uses for such a data type. As I said before, I will use it as base for Money. In this case the bounded precision is not an issue; quoting Tim Peters:</p> <blockquote> A precision of 20 would be way more than enough to account for total world economic output, down to the penny, since the beginning of time.</blockquote> <a name="user-content-general-decimal-arithmetic-specification"></a> <div class="markdown-heading" dir="auto"><h2 tabindex="-1" class="heading-element" dir="auto">General Decimal Arithmetic Specification</h2><a id="user-content-general-decimal-arithmetic-specification" class="anchor" aria-label="Permalink: General Decimal Arithmetic Specification" href="#general-decimal-arithmetic-specification"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">Here I'll include information and descriptions that are part of the specification <a href="#id20" id="user-content-id5">[2]</a> (the structure of the number, the context, etc.). All the requirements included in this section are not for discussion (barring typos or other mistakes), as they are in the standard, and the PEP is just for implementing the standard.</p> <p dir="auto">Because of copyright restrictions, I can not copy here explanations taken from the specification, so I'll try to explain it in my own words. I firmly encourage you to read the original specification document <a href="#id20" id="user-content-id6">[2]</a> for details or if you have any doubt.</p> <a name="user-content-the-arithmetic-model"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">The Arithmetic Model</h3><a id="user-content-the-arithmetic-model" class="anchor" aria-label="Permalink: The Arithmetic Model" href="#the-arithmetic-model"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">The specification is based on a decimal arithmetic model, as defined by the relevant standards: IEEE 854 <a href="#id21" id="user-content-id7">[3]</a>, ANSI X3-274 <a href="#id19" id="user-content-id8">[1]</a>, and the proposed revision <a href="#id23" id="user-content-id9">[5]</a> of IEEE 754 <a href="#id24" id="user-content-id10">[6]</a>.</p> <p dir="auto">The model has three components:</p> <ul dir="auto"> <li>Numbers: just the values that the operation uses as input or output.</li> <li>Operations: addition, multiplication, etc.</li> <li>Context: a set of parameters and rules that the user can select and which govern the results of operations (for example, the precision to be used).</li> </ul> <a name="user-content-numbers"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">Numbers</h3><a id="user-content-numbers" class="anchor" aria-label="Permalink: Numbers" href="#numbers"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">Numbers may be finite or special values. The former can be represented exactly. The latter are infinites and undefined (such as 0/0).</p> <p dir="auto">Finite numbers are defined by three parameters:</p> <ul dir="auto"> <li>Sign: 0 (positive) or 1 (negative).</li> <li>Coefficient: a non-negative integer.</li> <li>Exponent: a signed integer, the power of ten of the coefficient multiplier.</li> </ul> <p dir="auto">The numerical value of a finite number is given by:</p> <pre>(-1)**sign * coefficient * 10**exponent </pre> <p dir="auto">Special values are named as following:</p> <ul dir="auto"> <li>Infinity: a value which is infinitely large. Could be positive or negative.</li> <li>Quiet NaN ("qNaN"): represent undefined results (<em>Not a Number</em>). Does not cause an Invalid operation condition. The sign in a NaN has no meaning.</li> <li>Signaling NaN ("sNaN"): also <em>Not a Number</em>, but will cause an Invalid operation condition if used in any operation.</li> </ul> <a name="user-content-context"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">Context</h3><a id="user-content-context" class="anchor" aria-label="Permalink: Context" href="#context"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">The context is a set of parameters and rules that the user can select and which govern the results of operations (for example, the precision to be used).</p> <p dir="auto">The context gets that name because it surrounds the Decimal numbers, with parts of context acting as input to, and output of, operations. It's up to the application to work with one or several contexts, but definitely the idea is not to get a context per Decimal number. For example, a typical use would be to set the context's precision to 20 digits at the start of a program, and never explicitly use context again.</p> <p dir="auto">These definitions don't affect the internal storage of the Decimal numbers, just the way that the arithmetic operations are performed.</p> <p dir="auto">The context is mainly defined by the following parameters (see <a href="#context-attributes">Context Attributes</a> for all context attributes):</p> <ul dir="auto"> <li>Precision: The maximum number of significant digits that can result from an arithmetic operation (integer &gt; 0). There is no maximum for this value.</li> <li>Rounding: The name of the algorithm to be used when rounding is necessary, one of "round-down", "round-half-up", "round-half-even", "round-ceiling", "round-floor", "round-half-down", and "round-up". See <a href="#rounding-algorithms">Rounding Algorithms</a> below.</li> <li>Flags and trap-enablers: <a href="#exceptional-conditions">Exceptional conditions</a> are grouped into signals, controllable individually, each consisting of a flag (boolean, set when the signal occurs) and a trap-enabler (a boolean that controls behavior). The signals are: "clamped", "division-by-zero", "inexact", "invalid-operation", "overflow", "rounded", "subnormal" and "underflow".</li> </ul> <a name="user-content-default-contexts"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">Default Contexts</h3><a id="user-content-default-contexts" class="anchor" aria-label="Permalink: Default Contexts" href="#default-contexts"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">The specification defines two default contexts, which should be easily selectable by the user.</p> <p dir="auto">Basic Default Context:</p> <ul dir="auto"> <li>flags: all set to 0</li> <li>trap-enablers: inexact, rounded, and subnormal are set to 0; all others are set to 1</li> <li>precision: is set to 9</li> <li>rounding: is set to round-half-up</li> </ul> <p dir="auto">Extended Default Context:</p> <ul dir="auto"> <li>flags: all set to 0</li> <li>trap-enablers: all set to 0</li> <li>precision: is set to 9</li> <li>rounding: is set to round-half-even</li> </ul> <a name="user-content-exceptional-conditions"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">Exceptional Conditions</h3><a id="user-content-exceptional-conditions" class="anchor" aria-label="Permalink: Exceptional Conditions" href="#exceptional-conditions"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">The table below lists the exceptional conditions that may arise during the arithmetic operations, the corresponding signal, and the defined result. For details, see the specification <a href="#id20" id="user-content-id11">[2]</a>.</p> <markdown-accessiblity-table><table> <thead valign="bottom"> <tr><th>Condition</th> <th>Signal</th> <th>Result</th> </tr> </thead> <tbody valign="top"> <tr><td>Clamped</td> <td>clamped</td> <td>see spec <a href="#id20" id="user-content-id12">[2]</a></td> </tr> <tr><td>Division by zero</td> <td>division-by-zero</td> <td>[sign,inf]</td> </tr> <tr><td>Inexact</td> <td>inexact</td> <td>unchanged</td> </tr> <tr><td>Invalid operation</td> <td>invalid-operation</td> <td>[0,qNaN] (or [s,qNaN] or [s,qNaN,d] when the cause is a signaling NaN)</td> </tr> <tr><td>Overflow</td> <td>overflow</td> <td>depends on the rounding mode</td> </tr> <tr><td>Rounded</td> <td>rounded</td> <td>unchanged</td> </tr> <tr><td>Subnormal</td> <td>subnormal</td> <td>unchanged</td> </tr> <tr><td>Underflow</td> <td>underflow</td> <td>see spec <a href="#id20" id="user-content-id13">[2]</a></td> </tr> </tbody> </table></markdown-accessiblity-table> <p dir="auto">Note: when the standard talks about "Insufficient storage", as long as this is implementation-specific behaviour about not having enough storage to keep the internals of the number, this implementation will raise MemoryError.</p> <p dir="auto">Regarding Overflow and Underflow, there's been a long discussion in python-dev about artificial limits. The general consensus is to keep the artificial limits only if there are important reasons to do that. Tim Peters gives us three:</p> <blockquote> <p dir="auto">...eliminating bounds on exponents effectively means overflow (and underflow) can never happen. But overflow <em>is</em> a valuable safety net in real life fp use, like a canary in a coal mine, giving danger signs early when a program goes insane.</p> <p dir="auto">Virtually all implementations of 854 use (and as IBM's standard even suggests) "forbidden" exponent values to encode non-finite numbers (infinities and NaNs). A bounded exponent can do this at virtually no extra storage cost. If the exponent is unbounded, then additional bits have to be used instead. This cost remains hidden until more time- and space- efficient implementations are attempted.</p> <p dir="auto">Big as it is, the IBM standard is a tiny start at supplying a complete numeric facility. Having no bound on exponent size will enormously complicate the implementations of, e.g., decimal sin() and cos() (there's then no a priori limit on how many digits of pi effectively need to be known in order to perform argument reduction).</p> </blockquote> <p dir="auto">Edward Loper give us an example of when the limits are to be crossed: probabilities.</p> <p dir="auto">That said, Robert Brewer and Andrew Lentvorski want the limits to be easily modifiable by the users. Actually, this is quite possible:</p> <pre>&gt;&gt;&gt; d1 = Decimal("1e999999999") # at the exponent limit &gt;&gt;&gt; d1 Decimal("1E+999999999") &gt;&gt;&gt; d1 * 10 # exceed the limit, got infinity Traceback (most recent call last): File "&lt;pyshell#3&gt;", line 1, in ? d1 * 10 ... ... Overflow: above Emax &gt;&gt;&gt; getcontext().Emax = 1000000000 # increase the limit &gt;&gt;&gt; d1 * 10 # does not exceed any more Decimal("1.0E+1000000000") &gt;&gt;&gt; d1 * 100 # exceed again Traceback (most recent call last): File "&lt;pyshell#3&gt;", line 1, in ? d1 * 100 ... ... Overflow: above Emax </pre> <a name="user-content-rounding-algorithms"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">Rounding Algorithms</h3><a id="user-content-rounding-algorithms" class="anchor" aria-label="Permalink: Rounding Algorithms" href="#rounding-algorithms"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto"><code>round-down</code>: The discarded digits are ignored; the result is unchanged (round toward 0, truncate):</p> <pre>1.123 --&gt; 1.12 1.128 --&gt; 1.12 1.125 --&gt; 1.12 1.135 --&gt; 1.13 </pre> <p dir="auto"><code>round-half-up</code>: If the discarded digits represent greater than or equal to half (0.5) then the result should be incremented by 1; otherwise the discarded digits are ignored:</p> <pre>1.123 --&gt; 1.12 1.128 --&gt; 1.13 1.125 --&gt; 1.13 1.135 --&gt; 1.14 </pre> <p dir="auto"><code>round-half-even</code>: If the discarded digits represent greater than half (0.5) then the result coefficient is incremented by 1; if they represent less than half, then the result is not adjusted; otherwise the result is unaltered if its rightmost digit is even, or incremented by 1 if its rightmost digit is odd (to make an even digit):</p> <pre>1.123 --&gt; 1.12 1.128 --&gt; 1.13 1.125 --&gt; 1.12 1.135 --&gt; 1.14 </pre> <p dir="auto"><code>round-ceiling</code>: If all of the discarded digits are zero or if the sign is negative the result is unchanged; otherwise, the result is incremented by 1 (round toward positive infinity):</p> <pre> 1.123 --&gt; 1.13 1.128 --&gt; 1.13 -1.123 --&gt; -1.12 -1.128 --&gt; -1.12 </pre> <p dir="auto"><code>round-floor</code>: If all of the discarded digits are zero or if the sign is positive the result is unchanged; otherwise, the absolute value of the result is incremented by 1 (round toward negative infinity):</p> <pre> 1.123 --&gt; 1.12 1.128 --&gt; 1.12 -1.123 --&gt; -1.13 -1.128 --&gt; -1.13 </pre> <p dir="auto"><code>round-half-down</code>: If the discarded digits represent greater than half (0.5) then the result is incremented by 1; otherwise the discarded digits are ignored:</p> <pre>1.123 --&gt; 1.12 1.128 --&gt; 1.13 1.125 --&gt; 1.12 1.135 --&gt; 1.13 </pre> <p dir="auto"><code>round-up</code>: If all of the discarded digits are zero the result is unchanged, otherwise the result is incremented by 1 (round away from 0):</p> <pre>1.123 --&gt; 1.13 1.128 --&gt; 1.13 1.125 --&gt; 1.13 1.135 --&gt; 1.14 </pre> <a name="user-content-rationale"></a> <div class="markdown-heading" dir="auto"><h2 tabindex="-1" class="heading-element" dir="auto">Rationale</h2><a id="user-content-rationale" class="anchor" aria-label="Permalink: Rationale" href="#rationale"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">I must separate the requirements in two sections. The first is to comply with the ANSI standard. All the requirements for this are specified in the Mike Cowlishaw's work <a href="#id20" id="user-content-id14">[2]</a>. He also provided a <strong>very large</strong> suite of test cases.</p> <p dir="auto">The second section of requirements (standard Python functions support, usability, etc.) is detailed from here, where I'll include all the decisions made and why, and all the subjects still being discussed.</p> <a name="user-content-explicit-construction"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">Explicit construction</h3><a id="user-content-explicit-construction" class="anchor" aria-label="Permalink: Explicit construction" href="#explicit-construction"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">The explicit construction does not get affected by the context (there is no rounding, no limits by the precision, etc.), because the context affects just operations' results. The only exception to this is when you're <a href="#creating-from-context">Creating from Context</a>.</p> <a name="user-content-from-int-or-long"></a> <div class="markdown-heading" dir="auto"><h4 tabindex="-1" class="heading-element" dir="auto">From int or long</h4><a id="user-content-from-int-or-long" class="anchor" aria-label="Permalink: From int or long" href="#from-int-or-long"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">There's no loss and no need to specify any other information:</p> <pre>Decimal(35) Decimal(-124) </pre> <a name="user-content-from-string"></a> <div class="markdown-heading" dir="auto"><h4 tabindex="-1" class="heading-element" dir="auto">From string</h4><a id="user-content-from-string" class="anchor" aria-label="Permalink: From string" href="#from-string"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">Strings containing Python decimal integer literals and Python float literals will be supported. In this transformation there is no loss of information, as the string is directly converted to Decimal (there is not an intermediate conversion through float):</p> <pre>Decimal("-12") Decimal("23.2e-7") </pre> <p dir="auto">Also, you can construct in this way all special values (Infinity and Not a Number):</p> <pre>Decimal("Inf") Decimal("NaN") </pre> <a name="user-content-from-float"></a> <div class="markdown-heading" dir="auto"><h4 tabindex="-1" class="heading-element" dir="auto">From float</h4><a id="user-content-from-float" class="anchor" aria-label="Permalink: From float" href="#from-float"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">The initial discussion on this item was what should happen when passing floating point to the constructor:</p> <ol dir="auto"> <li><code>Decimal(1.1) == Decimal('1.1')</code></li> <li><code>Decimal(1.1) == Decimal('110000000000000008881784197001252...e-51')</code></li> <li>an exception is raised</li> </ol> <p dir="auto">Several people alleged that (1) is the better option here, because it's what you expect when writing <code>Decimal(1.1)</code>. And quoting John Roth, it's easy to implement:</p> <blockquote> It's not at all difficult to find where the actual number ends and where the fuzz begins. You can do it visually, and the algorithms to do it are quite well known.</blockquote> <p dir="auto">But If I <em>really</em> want my number to be <code>Decimal('110000000000000008881784197001252...e-51')</code>, why can't I write <code>Decimal(1.1)</code>? Why should I expect Decimal to be "rounding" it? Remember that <code>1.1</code> <em>is</em> binary floating point, so I can predict the result. It's not intuitive to a beginner, but that's the way it is.</p> <p dir="auto">Anyway, Paul Moore showed that (1) can't work, because:</p> <pre>(1) says D(1.1) == D('1.1') but 1.1 == 1.1000000000000001 so D(1.1) == D(1.1000000000000001) together: D(1.1000000000000001) == D('1.1') </pre> <p dir="auto">which is wrong, because if I write <code>Decimal('1.1')</code> it is exact, not <code>D(1.1000000000000001)</code>. He also proposed to have an explicit conversion to float. bokr says you need to put the precision in the constructor and mwilson agreed:</p> <pre>d = Decimal (1.1, 1) # take float value to 1 decimal place d = Decimal (1.1) # gets `places` from pre-set context </pre> <p dir="auto">But Alex Martelli says that:</p> <blockquote> Constructing with some specified precision would be fine. Thus, I think "construction from float with some default precision" runs a substantial risk of tricking naive users.</blockquote> <p dir="auto">So, the accepted solution through c.l.p is that you can not call Decimal with a float. Instead you must use a method: Decimal.from_float(). The syntax:</p> <pre>Decimal.from_float(floatNumber, [decimal_places]) </pre> <p dir="auto">where <code>floatNumber</code> is the float number origin of the construction and <code>decimal_places</code> are the number of digits after the decimal point where you apply a round-half-up rounding, if any. In this way you can do, for example:</p> <pre>Decimal.from_float(1.1, 2): The same as doing Decimal('1.1'). Decimal.from_float(1.1, 16): The same as doing Decimal('1.1000000000000001'). Decimal.from_float(1.1): The same as doing Decimal('1100000000000000088817841970012523233890533447265625e-51'). </pre> <p dir="auto">Based on later discussions, it was decided to omit from_float() from the API for Py2.4. Several ideas contributed to the thought process:</p> <ul dir="auto"> <li><p dir="auto">Interactions between decimal and binary floating point force the user to deal with tricky issues of representation and round-off. Avoidance of those issues is a primary reason for having the module in the first place.</p> </li> <li><p dir="auto">The first release of the module should focus on that which is safe, minimal, and essential.</p> </li> <li><p dir="auto">While theoretically nice, real world use cases for interactions between floats and decimals are lacking. Java included float/decimal conversions to handle an obscure case where calculations are best performed in decimal even though a legacy data structure requires the inputs and outputs to be stored in binary floating point.</p> </li> <li><p dir="auto">If the need arises, users can use string representations as an intermediate type. The advantage of this approach is that it makes explicit the assumptions about precision and representation (no wondering what is going on under the hood).</p> </li> <li><p dir="auto">The Java docs for BigDecimal(double val) reflected their experiences with the constructor:</p> <pre>The results of this constructor can be somewhat unpredictable and its use is generally not recommended. </pre> </li> </ul> <a name="user-content-from-tuples"></a> <div class="markdown-heading" dir="auto"><h4 tabindex="-1" class="heading-element" dir="auto">From tuples</h4><a id="user-content-from-tuples" class="anchor" aria-label="Permalink: From tuples" href="#from-tuples"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">Aahz suggested to construct from tuples: it's easier to implement <code>eval()</code>'s round trip and "someone who has numeric values representing a Decimal does not need to convert them to a string."</p> <p dir="auto">The structure will be a tuple of three elements: sign, number and exponent. The sign is 1 or 0, the number is a tuple of decimal digits and the exponent is a signed int or long:</p> <pre>Decimal((1, (3, 2, 2, 5), -2)) # for -32.25 </pre> <p dir="auto">Of course, you can construct in this way all special values:</p> <pre>Decimal( (0, (0,), 'F') ) # for Infinity Decimal( (0, (0,), 'n') ) # for Not a Number </pre> <a name="user-content-from-decimal"></a> <div class="markdown-heading" dir="auto"><h4 tabindex="-1" class="heading-element" dir="auto">From Decimal</h4><a id="user-content-from-decimal" class="anchor" aria-label="Permalink: From Decimal" href="#from-decimal"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">No mystery here, just a copy.</p> <a name="user-content-syntax-for-all-cases"></a> <div class="markdown-heading" dir="auto"><h4 tabindex="-1" class="heading-element" dir="auto">Syntax for All Cases</h4><a id="user-content-syntax-for-all-cases" class="anchor" aria-label="Permalink: Syntax for All Cases" href="#syntax-for-all-cases"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <pre>Decimal(value1) Decimal.from_float(value2, [decimal_places]) </pre> <p dir="auto">where <code>value1</code> can be int, long, string, 3-tuple or Decimal, <code>value2</code> can only be float, and <code>decimal_places</code> is an optional non negative int.</p> <a name="user-content-creating-from-context"></a> <div class="markdown-heading" dir="auto"><h4 tabindex="-1" class="heading-element" dir="auto">Creating from Context</h4><a id="user-content-creating-from-context" class="anchor" aria-label="Permalink: Creating from Context" href="#creating-from-context"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">This item arose in python-dev from two sources in parallel. Ka-Ping Yee proposes to pass the context as an argument at instance creation (he wants the context he passes to be used only in creation time: "It would not be persistent"). Tony Meyer asks from_string to honor the context if it receives a parameter "honour_context" with a True value. (I don't like it, because the doc specifies that the context be honored and I don't want the method to comply with the specification regarding the value of an argument.)</p> <p dir="auto">Tim Peters gives us a reason to have a creation that uses context:</p> <blockquote> In general number-crunching, literals may be given to high precision, but that precision isn't free and <em>usually</em> isn't needed</blockquote> <p dir="auto">Casey Duncan wants to use another method, not a bool arg:</p> <blockquote> I find boolean arguments a general anti-pattern, especially given we have class methods. Why not use an alternate constructor like Decimal.rounded_to_context("3.14159265").</blockquote> <p dir="auto">In the process of deciding the syntax of that, Tim came up with a better idea: he proposes not to have a method in Decimal to create with a different context, but having instead a method in Context to create a Decimal instance. Basically, instead of:</p> <pre>D.using_context(number, context) </pre> <p dir="auto">it will be:</p> <pre>context.create_decimal(number) </pre> <p dir="auto">From Tim:</p> <blockquote> While all operations in the spec except for the two to-string operations use context, no operations in the spec support an optional local context. That the Decimal() constructor ignores context by default is an extension to the spec. We must supply a context-honoring from-string operation to meet the spec. I recommend against any concept of "local context" in any operation -- it complicates the model and isn't necessary.</blockquote> <p dir="auto">So, we decided to use a context method to create a Decimal that will use (only to be created) that context in particular (for further operations it will use the context of the thread). But, a method with what name?</p> <p dir="auto">Tim Peters proposes three methods to create from diverse sources (from_string, from_int, from_float). I proposed to use one method, <code>create_decimal()</code>, without caring about the data type. Michael Chermside: "The name just fits my brain. The fact that it uses the context is obvious from the fact that it's Context method".</p> <p dir="auto">The community agreed with that. I think that it's OK because a newbie will not be using the creation method from Context (the separate method in Decimal to construct from float is just to prevent newbies from encountering binary floating point issues).</p> <p dir="auto">So, in short, if you want to create a Decimal instance using a particular context (that will be used just at creation time and not any further), you'll have to use a method of that context:</p> <pre># n is any datatype accepted in Decimal(n) plus float mycontext.create_decimal(n) </pre> <p dir="auto">Example:</p> <pre>&gt;&gt;&gt; # create a standard decimal instance &gt;&gt;&gt; Decimal("11.2233445566778899") Decimal("11.2233445566778899") &gt;&gt;&gt; &gt;&gt;&gt; # create a decimal instance using the thread context &gt;&gt;&gt; thread_context = getcontext() &gt;&gt;&gt; thread_context.prec 28 &gt;&gt;&gt; thread_context.create_decimal("11.2233445566778899") Decimal("11.2233445566778899") &gt;&gt;&gt; &gt;&gt;&gt; # create a decimal instance using other context &gt;&gt;&gt; other_context = thread_context.copy() &gt;&gt;&gt; other_context.prec = 4 &gt;&gt;&gt; other_context.create_decimal("11.2233445566778899") Decimal("11.22") </pre> <a name="user-content-implicit-construction"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">Implicit construction</h3><a id="user-content-implicit-construction" class="anchor" aria-label="Permalink: Implicit construction" href="#implicit-construction"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">As the implicit construction is the consequence of an operation, it will be affected by the context as is detailed in each point.</p> <p dir="auto">John Roth suggested that "The other type should be handled in the same way the decimal() constructor would handle it". But Alex Martelli thinks that</p> <blockquote> this total breach with Python tradition would be a terrible mistake. 23+"43" is NOT handled in the same way as 23+int("45"), and a VERY good thing that is too. It's a completely different thing for a user to EXPLICITLY indicate they want construction (conversion) and to just happen to sum two objects one of which by mistake could be a string.</blockquote> <p dir="auto">So, here I define the behaviour again for each data type.</p> <a name="user-content-id15"></a> <div class="markdown-heading" dir="auto"><h4 tabindex="-1" class="heading-element" dir="auto">From int or long</h4><a id="user-content-from-int-or-long-1" class="anchor" aria-label="Permalink: From int or long" href="#from-int-or-long-1"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">An int or long is a treated like a Decimal explicitly constructed from Decimal(str(x)) in the current context (meaning that the to-string rules for rounding are applied and the appropriate flags are set). This guarantees that expressions like <code>Decimal('1234567') + 13579</code> match the mental model of <code>Decimal('1234567') + Decimal('13579')</code>. That model works because all integers are representable as strings without representation error.</p> <a name="user-content-id16"></a> <div class="markdown-heading" dir="auto"><h4 tabindex="-1" class="heading-element" dir="auto">From string</h4><a id="user-content-from-string-1" class="anchor" aria-label="Permalink: From string" href="#from-string-1"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">Everybody agrees to raise an exception here.</p> <a name="user-content-id17"></a> <div class="markdown-heading" dir="auto"><h4 tabindex="-1" class="heading-element" dir="auto">From float</h4><a id="user-content-from-float-1" class="anchor" aria-label="Permalink: From float" href="#from-float-1"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">Aahz is strongly opposed to interact with float, suggesting an explicit conversion:</p> <blockquote> The problem is that Decimal is capable of greater precision, accuracy, and range than float.</blockquote> <p dir="auto">The example of the valid python expression, <code>35 + 1.1</code>, seems to suggest that <code>Decimal(35) + 1.1</code> should also be valid. However, a closer look shows that it only demonstrates the feasibility of integer to floating point conversions. Hence, the correct analog for decimal floating point is <code>35 + Decimal(1.1)</code>. Both coercions, int-to-float and int-to-Decimal, can be done without incurring representation error.</p> <p dir="auto">The question of how to coerce between binary and decimal floating point is more complex. I proposed allowing the interaction with float, making an exact conversion and raising ValueError if exceeds the precision in the current context (this is maybe too tricky, because for example with a precision of 9, <code>Decimal(35) + 1.2</code> is OK but <code>Decimal(35) + 1.1</code> raises an error).</p> <p dir="auto">This resulted to be too tricky. So tricky, that c.l.p agreed to raise TypeError in this case: you could not mix Decimal and float.</p> <a name="user-content-id18"></a> <div class="markdown-heading" dir="auto"><h4 tabindex="-1" class="heading-element" dir="auto">From Decimal</h4><a id="user-content-from-decimal-1" class="anchor" aria-label="Permalink: From Decimal" href="#from-decimal-1"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">There isn't any issue here.</p> <a name="user-content-use-of-context"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">Use of Context</h3><a id="user-content-use-of-context" class="anchor" aria-label="Permalink: Use of Context" href="#use-of-context"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">In the last pre-PEP I said that "The Context must be omnipresent, meaning that changes to it affects all the current and future Decimal instances". I was wrong. In response, John Roth said:</p> <blockquote> The context should be selectable for the particular usage. That is, it should be possible to have several different contexts in play at one time in an application.</blockquote> <p dir="auto">In comp.lang.python, Aahz explained that the idea is to have a "context per thread". So, all the instances of a thread belongs to a context, and you can change a context in thread A (and the behaviour of the instances of that thread) without changing nothing in thread B.</p> <p dir="auto">Also, and again correcting me, he said:</p> <blockquote> (the) Context applies only to operations, not to Decimal instances; changing the Context does not affect existing instances if there are no operations on them.</blockquote> <p dir="auto">Arguing about special cases when there's need to perform operations with other rules that those of the current context, Tim Peters said that the context will have the operations as methods. This way, the user "can create whatever private context object(s) it needs, and spell arithmetic as explicit method calls on its private context object(s), so that the default thread context object is neither consulted nor modified".</p> <a name="user-content-python-usability"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">Python Usability</h3><a id="user-content-python-usability" class="anchor" aria-label="Permalink: Python Usability" href="#python-usability"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <ul dir="auto"> <li><p dir="auto">Decimal should support the basic arithmetic (<code>+, -, *, /, //, **, %, divmod</code>) and comparison (<code>==, !=, &lt;, &gt;, &lt;=, &gt;=, cmp</code>) operators in the following cases (check <a href="#implicit-construction">Implicit Construction</a> to see what types could OtherType be, and what happens in each case):</p> <ul dir="auto"> <li>Decimal op Decimal</li> <li>Decimal op otherType</li> <li>otherType op Decimal</li> <li>Decimal op= Decimal</li> <li>Decimal op= otherType</li> </ul> </li> <li><p dir="auto">Decimal should support unary operators (<code>-, +, abs</code>).</p> </li> <li><p dir="auto">repr() should round trip, meaning that:</p> <pre>m = Decimal(...) m == eval(repr(m)) </pre> </li> <li><p dir="auto">Decimal should be immutable.</p> </li> <li><p dir="auto">Decimal should support the built-in methods:</p> <ul dir="auto"> <li>min, max</li> <li>float, int, long</li> <li>str, repr</li> <li>hash</li> <li>bool (0 is false, otherwise true)</li> </ul> </li> </ul> <p dir="auto">There's been some discussion in python-dev about the behaviour of <code>hash()</code>. The community agrees that if the values are the same, the hashes of those values should also be the same. So, while Decimal(25) == 25 is True, hash(Decimal(25)) should be equal to hash(25).</p> <p dir="auto">The detail is that you can NOT compare Decimal to floats or strings, so we should not worry about them giving the same hashes. In short:</p> <pre>hash(n) == hash(Decimal(n)) # Only if n is int, long, or Decimal </pre> <p dir="auto">Regarding str() and repr() behaviour, Ka-Ping Yee proposes that repr() have the same behaviour as str() and Tim Peters proposes that str() behave like the to-scientific-string operation from the Spec.</p> <p dir="auto">This is possible, because (from Aahz): "The string form already contains all the necessary information to reconstruct a Decimal object".</p> <p dir="auto">And it also complies with the Spec; Tim Peters:</p> <blockquote> There's no requirement to have a method <em>named</em> "to_sci_string", the only requirement is that <em>some</em> way to spell to-sci-string's functionality be supplied. The meaning of to-sci-string is precisely specified by the standard, and is a good choice for both str(Decimal) and repr(Decimal).</blockquote> <a name="user-content-documentation"></a> <div class="markdown-heading" dir="auto"><h2 tabindex="-1" class="heading-element" dir="auto">Documentation</h2><a id="user-content-documentation" class="anchor" aria-label="Permalink: Documentation" href="#documentation"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">This section explains all the public methods and attributes of Decimal and Context.</p> <a name="user-content-decimal-attributes"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">Decimal Attributes</h3><a id="user-content-decimal-attributes" class="anchor" aria-label="Permalink: Decimal Attributes" href="#decimal-attributes"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">Decimal has no public attributes. The internal information is stored in slots and should not be accessed by end users.</p> <a name="user-content-decimal-methods"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">Decimal Methods</h3><a id="user-content-decimal-methods" class="anchor" aria-label="Permalink: Decimal Methods" href="#decimal-methods"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">Following are the conversion and arithmetic operations defined in the Spec, and how that functionality can be achieved with the actual implementation.</p> <ul dir="auto"> <li><p dir="auto">to-scientific-string: Use builtin function <code>str()</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('123456789012.345') &gt;&gt;&gt; str(d) '1.23456789E+11' </pre> </li> <li><p dir="auto">to-engineering-string: Use method <code>to_eng_string()</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('123456789012.345') &gt;&gt;&gt; d.to_eng_string() '123.456789E+9' </pre> </li> <li><p dir="auto">to-number: Use Context method <code>create_decimal()</code>. The standard constructor or <code>from_float()</code> constructor cannot be used because these do not use the context (as is specified in the Spec for this conversion).</p> </li> <li><p dir="auto">abs: Use builtin function <code>abs()</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('-15.67') &gt;&gt;&gt; abs(d) Decimal('15.67') </pre> </li> <li><p dir="auto">add: Use operator <code>+</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('15.6') &gt;&gt;&gt; d + 8 Decimal('23.6') </pre> </li> <li><p dir="auto">subtract: Use operator <code>-</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('15.6') &gt;&gt;&gt; d - 8 Decimal('7.6') </pre> </li> <li><p dir="auto">compare: Use method <code>compare()</code>. This method (and not the built-in function cmp()) should only be used when dealing with <em>special values</em>:</p> <pre>&gt;&gt;&gt; d = Decimal('-15.67') &gt;&gt;&gt; nan = Decimal('NaN') &gt;&gt;&gt; d.compare(23) '-1' &gt;&gt;&gt; d.compare(nan) 'NaN' &gt;&gt;&gt; cmp(d, 23) -1 &gt;&gt;&gt; cmp(d, nan) 1 </pre> </li> <li><p dir="auto">divide: Use operator <code>/</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('-15.67') &gt;&gt;&gt; d / 2 Decimal('-7.835') </pre> </li> <li><p dir="auto">divide-integer: Use operator <code>//</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('-15.67') &gt;&gt;&gt; d // 2 Decimal('-7') </pre> </li> <li><p dir="auto">max: Use method <code>max()</code>. Only use this method (and not the built-in function max()) when dealing with <em>special values</em>:</p> <pre>&gt;&gt;&gt; d = Decimal('15') &gt;&gt;&gt; nan = Decimal('NaN') &gt;&gt;&gt; d.max(8) Decimal('15') &gt;&gt;&gt; d.max(nan) Decimal('NaN') </pre> </li> <li><p dir="auto">min: Use method <code>min()</code>. Only use this method (and not the built-in function min()) when dealing with <em>special values</em>:</p> <pre>&gt;&gt;&gt; d = Decimal('15') &gt;&gt;&gt; nan = Decimal('NaN') &gt;&gt;&gt; d.min(8) Decimal('8') &gt;&gt;&gt; d.min(nan) Decimal('NaN') </pre> </li> <li><p dir="auto">minus: Use unary operator <code>-</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('-15.67') &gt;&gt;&gt; -d Decimal('15.67') </pre> </li> <li><p dir="auto">plus: Use unary operator <code>+</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('-15.67') &gt;&gt;&gt; +d Decimal('-15.67') </pre> </li> <li><p dir="auto">multiply: Use operator <code>*</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('5.7') &gt;&gt;&gt; d * 3 Decimal('17.1') </pre> </li> <li><p dir="auto">normalize: Use method <code>normalize()</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('123.45000') &gt;&gt;&gt; d.normalize() Decimal('123.45') &gt;&gt;&gt; d = Decimal('120.00') &gt;&gt;&gt; d.normalize() Decimal('1.2E+2') </pre> </li> <li><p dir="auto">quantize: Use method <code>quantize()</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('2.17') &gt;&gt;&gt; d.quantize(Decimal('0.001')) Decimal('2.170') &gt;&gt;&gt; d.quantize(Decimal('0.1')) Decimal('2.2') </pre> </li> <li><p dir="auto">remainder: Use operator <code>%</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('10') &gt;&gt;&gt; d % 3 Decimal('1') &gt;&gt;&gt; d % 6 Decimal('4') </pre> </li> <li><p dir="auto">remainder-near: Use method <code>remainder_near()</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('10') &gt;&gt;&gt; d.remainder_near(3) Decimal('1') &gt;&gt;&gt; d.remainder_near(6) Decimal('-2') </pre> </li> <li><p dir="auto">round-to-integral-value: Use method <code>to_integral()</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('-123.456') &gt;&gt;&gt; d.to_integral() Decimal('-123') </pre> </li> <li><p dir="auto">same-quantum: Use method <code>same_quantum()</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('123.456') &gt;&gt;&gt; d.same_quantum(Decimal('0.001')) True &gt;&gt;&gt; d.same_quantum(Decimal('0.01')) False </pre> </li> <li><p dir="auto">square-root: Use method <code>sqrt()</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('123.456') &gt;&gt;&gt; d.sqrt() Decimal('11.1110756') </pre> </li> <li><p dir="auto">power: User operator <code>**</code>:</p> <pre>&gt;&gt;&gt; d = Decimal('12.56') &gt;&gt;&gt; d ** 2 Decimal('157.7536') </pre> </li> </ul> <p dir="auto">Following are other methods and why they exist:</p> <ul dir="auto"> <li><p dir="auto"><code>adjusted()</code>: Returns the adjusted exponent. This concept is defined in the Spec: the adjusted exponent is the value of the exponent of a number when that number is expressed as though in scientific notation with one digit before any decimal point:</p> <pre>&gt;&gt;&gt; d = Decimal('12.56') &gt;&gt;&gt; d.adjusted() 1 </pre> </li> <li><p dir="auto"><code>from_float()</code>: Class method to create instances from float data types:</p> <pre>&gt;&gt;&gt; d = Decimal.from_float(12.35) &gt;&gt;&gt; d Decimal('12.3500000') </pre> </li> <li><p dir="auto"><code>as_tuple()</code>: Show the internal structure of the Decimal, the triple tuple. This method is not required by the Spec, but Tim Peters proposed it and the community agreed to have it (it's useful for developing and debugging):</p> <pre>&gt;&gt;&gt; d = Decimal('123.4') &gt;&gt;&gt; d.as_tuple() (0, (1, 2, 3, 4), -1) &gt;&gt;&gt; d = Decimal('-2.34e5') &gt;&gt;&gt; d.as_tuple() (1, (2, 3, 4), 3) </pre> </li> </ul> <a name="user-content-context-attributes"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">Context Attributes</h3><a id="user-content-context-attributes" class="anchor" aria-label="Permalink: Context Attributes" href="#context-attributes"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">These are the attributes that can be changed to modify the context.</p> <ul dir="auto"> <li><p dir="auto"><code>prec</code> (int): the precision:</p> <pre>&gt;&gt;&gt; c.prec 9 </pre> </li> <li><p dir="auto"><code>rounding</code> (str): rounding type (how to round):</p> <pre>&gt;&gt;&gt; c.rounding 'half_even' </pre> </li> <li><p dir="auto"><code>trap_enablers</code> (dict): if trap_enablers[exception] = 1, then an exception is raised when it is caused:</p> <pre>&gt;&gt;&gt; c.trap_enablers[Underflow] 0 &gt;&gt;&gt; c.trap_enablers[Clamped] 0 </pre> </li> <li><p dir="auto"><code>flags</code> (dict): when an exception is caused, flags[exception] is incremented (whether or not the trap_enabler is set). Should be reset by the user of Decimal instance:</p> <pre>&gt;&gt;&gt; c.flags[Underflow] 0 &gt;&gt;&gt; c.flags[Clamped] 0 </pre> </li> <li><p dir="auto"><code>Emin</code> (int): minimum exponent:</p> <pre>&gt;&gt;&gt; c.Emin -999999999 </pre> </li> <li><p dir="auto"><code>Emax</code> (int): maximum exponent:</p> <pre>&gt;&gt;&gt; c.Emax 999999999 </pre> </li> <li><p dir="auto"><code>capitals</code> (int): boolean flag to use 'E' (True/1) or 'e' (False/0) in the string (for example, '1.32e+2' or '1.32E+2'):</p> <pre>&gt;&gt;&gt; c.capitals 1 </pre> </li> </ul> <a name="user-content-context-methods"></a> <div class="markdown-heading" dir="auto"><h3 tabindex="-1" class="heading-element" dir="auto">Context Methods</h3><a id="user-content-context-methods" class="anchor" aria-label="Permalink: Context Methods" href="#context-methods"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">The following methods comply with Decimal functionality from the Spec. Be aware that the operations that are called through a specific context use that context and not the thread context.</p> <p dir="auto">To use these methods, take note that the syntax changes when the operator is binary or unary, for example:</p> <pre>&gt;&gt;&gt; mycontext.abs(Decimal('-2')) '2' &gt;&gt;&gt; mycontext.multiply(Decimal('2.3'), 5) '11.5' </pre> <p dir="auto">So, the following are the Spec operations and conversions and how to achieve them through a context (where <code>d</code> is a Decimal instance and <code>n</code> a number that can be used in an <a href="#implicit-construction">Implicit construction</a>):</p> <ul dir="auto"> <li>to-scientific-string: <code>to_sci_string(d)</code></li> <li>to-engineering-string: <code>to_eng_string(d)</code></li> <li>to-number: <code>create_decimal(number)</code>, see <a href="#explicit-construction">Explicit construction</a> for <code>number</code>.</li> <li>abs: <code>abs(d)</code></li> <li>add: <code>add(d, n)</code></li> <li>subtract: <code>subtract(d, n)</code></li> <li>compare: <code>compare(d, n)</code></li> <li>divide: <code>divide(d, n)</code></li> <li>divide-integer: <code>divide_int(d, n)</code></li> <li>max: <code>max(d, n)</code></li> <li>min: <code>min(d, n)</code></li> <li>minus: <code>minus(d)</code></li> <li>plus: <code>plus(d)</code></li> <li>multiply: <code>multiply(d, n)</code></li> <li>normalize: <code>normalize(d)</code></li> <li>quantize: <code>quantize(d, d)</code></li> <li>remainder: <code>remainder(d)</code></li> <li>remainder-near: <code>remainder_near(d)</code></li> <li>round-to-integral-value: <code>to_integral(d)</code></li> <li>same-quantum: <code>same_quantum(d, d)</code></li> <li>square-root: <code>sqrt(d)</code></li> <li>power: <code>power(d, n)</code></li> </ul> <p dir="auto">The <code>divmod(d, n)</code> method supports decimal functionality through Context.</p> <p dir="auto">These are methods that return useful information from the Context:</p> <ul dir="auto"> <li><p dir="auto"><code>Etiny()</code>: Minimum exponent considering precision.</p> <pre>&gt;&gt;&gt; c.Emin -999999999 &gt;&gt;&gt; c.Etiny() -1000000007 </pre> </li> <li><p dir="auto"><code>Etop()</code>: Maximum exponent considering precision.</p> <pre>&gt;&gt;&gt; c.Emax 999999999 &gt;&gt;&gt; c.Etop() 999999991 </pre> </li> <li><p dir="auto"><code>copy()</code>: Returns a copy of the context.</p> </li> </ul> <a name="user-content-reference-implementation"></a> <div class="markdown-heading" dir="auto"><h2 tabindex="-1" class="heading-element" dir="auto">Reference Implementation</h2><a id="user-content-reference-implementation" class="anchor" aria-label="Permalink: Reference Implementation" href="#reference-implementation"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">As of Python 2.4-alpha, the code has been checked into the standard library. The latest version is available from:</p> <p dir="auto"><a href="http://svn.python.org/view/python/trunk/Lib/decimal.py" rel="nofollow">http://svn.python.org/view/python/trunk/Lib/decimal.py</a></p> <p dir="auto">The test cases are here:</p> <p dir="auto"><a href="http://svn.python.org/view/python/trunk/Lib/test/test_decimal.py" rel="nofollow">http://svn.python.org/view/python/trunk/Lib/test/test_decimal.py</a></p> <a name="user-content-references"></a> <div class="markdown-heading" dir="auto"><h2 tabindex="-1" class="heading-element" dir="auto">References</h2><a id="user-content-references" class="anchor" aria-label="Permalink: References" href="#references"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <markdown-accessiblity-table><table frame="void" id="user-content-id19" rules="none"> <tbody valign="top"> <tr><td>[1]</td><td><em>(<a href="#id1">1</a>, <a href="#id8">2</a>)</em> ANSI standard X3.274-1996 (Programming Language REXX): <a href="http://www.rexxla.org/Standards/ansi.html" rel="nofollow">http://www.rexxla.org/Standards/ansi.html</a></td></tr> </tbody> </table></markdown-accessiblity-table> <markdown-accessiblity-table><table frame="void" id="user-content-id20" rules="none"> <tbody valign="top"> <tr><td>[2]</td><td><em>(<a href="#id2">1</a>, <a href="#id3">2</a>, <a href="#id5">3</a>, <a href="#id6">4</a>, <a href="#id11">5</a>, <a href="#id12">6</a>, <a href="#id13">7</a>, <a href="#id14">8</a>)</em> General Decimal Arithmetic specification (Cowlishaw): <a href="http://speleotrove.com/decimal/decarith.html" rel="nofollow">http://speleotrove.com/decimal/decarith.html</a> (related documents and links at <a href="http://speleotrove.com/decimal/" rel="nofollow">http://speleotrove.com/decimal/</a>)</td></tr> </tbody> </table></markdown-accessiblity-table> <markdown-accessiblity-table><table frame="void" id="user-content-id21" rules="none"> <tbody valign="top"> <tr><td><a href="#id7">[3]</a></td><td>ANSI/IEEE standard 854-1987 (Radix-Independent Floating-Point Arithmetic): <a href="http://www.cs.berkeley.edu/~ejr/projects/754/private/drafts/854-1987/dir.html" rel="nofollow">http://www.cs.berkeley.edu/~ejr/projects/754/private/drafts/854-1987/dir.html</a> (unofficial text; official copies can be ordered from <a href="http://standards.ieee.org/catalog/ordering.html" rel="nofollow">http://standards.ieee.org/catalog/ordering.html</a>)</td></tr> </tbody> </table></markdown-accessiblity-table> <markdown-accessiblity-table><table frame="void" id="user-content-id22" rules="none"> <tbody valign="top"> <tr><td><a href="#id4">[4]</a></td><td>Tim Peter's FixedPoint at SourceForge: <a href="http://fixedpoint.sourceforge.net/" rel="nofollow">http://fixedpoint.sourceforge.net/</a></td></tr> </tbody> </table></markdown-accessiblity-table> <markdown-accessiblity-table><table frame="void" id="user-content-id23" rules="none"> <tbody valign="top"> <tr><td><a href="#id9">[5]</a></td><td>IEEE 754 revision: <a href="http://grouper.ieee.org/groups/754/revision.html" rel="nofollow">http://grouper.ieee.org/groups/754/revision.html</a></td></tr> </tbody> </table></markdown-accessiblity-table> <markdown-accessiblity-table><table frame="void" id="user-content-id24" rules="none"> <tbody valign="top"> <tr><td><a href="#id10">[6]</a></td><td>IEEE 754 references: <a href="http://babbage.cs.qc.edu/courses/cs341/IEEE-754references.html" rel="nofollow">http://babbage.cs.qc.edu/courses/cs341/IEEE-754references.html</a></td></tr> </tbody> </table></markdown-accessiblity-table> <a name="user-content-copyright"></a> <div class="markdown-heading" dir="auto"><h2 tabindex="-1" class="heading-element" dir="auto">Copyright</h2><a id="user-content-copyright" class="anchor" aria-label="Permalink: Copyright" href="#copyright"><svg class="octicon octicon-link" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path d="m7.775 3.275 1.25-1.25a3.5 3.5 0 1 1 4.95 4.95l-2.5 2.5a3.5 3.5 0 0 1-4.95 0 .751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018 1.998 1.998 0 0 0 2.83 0l2.5-2.5a2.002 2.002 0 0 0-2.83-2.83l-1.25 1.25a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042Zm-4.69 9.64a1.998 1.998 0 0 0 2.83 0l1.25-1.25a.751.751 0 0 1 1.042.018.751.751 0 0 1 .018 1.042l-1.25 1.25a3.5 3.5 0 1 1-4.95-4.95l2.5-2.5a3.5 3.5 0 0 1 4.95 0 .751.751 0 0 1-.018 1.042.751.751 0 0 1-1.042.018 1.998 1.998 0 0 0-2.83 0l-2.5 2.5a1.998 1.998 0 0 0 0 2.83Z"></path></svg></a></div> <p dir="auto">This document has been placed in the public domain.</p> </article></div><button hidden=""></button></section></div></div></div> <!-- --> <!-- --> </div></div></div><div class="Box-sc-g0xbh4-0"></div></div></div></div></div><div id="find-result-marks-container" class="Box-sc-g0xbh4-0 cCoXib"></div><button hidden="" data-testid="" data-hotkey-scope="read-only-cursor-text-area"></button><button hidden=""></button></div> <!-- --> <!-- --> <script type="application/json" id="__PRIMER_DATA_:R0:__">{"resolvedServerColorMode":"day"}</script></div> </react-app> </turbo-frame> </div> </turbo-frame> </main> </div> </div> <footer class="footer pt-8 pb-6 f6 color-fg-muted p-responsive" role="contentinfo" > <h2 class='sr-only'>Footer</h2> <div class="d-flex flex-justify-center flex-items-center flex-column-reverse flex-lg-row flex-wrap flex-lg-nowrap"> <div class="d-flex flex-items-center flex-shrink-0 mx-2"> <a aria-label="Homepage" title="GitHub" class="footer-octicon mr-2" href="https://github.com"> <svg aria-hidden="true" height="24" viewBox="0 0 24 24" version="1.1" width="24" data-view-component="true" class="octicon octicon-mark-github"> <path d="M12 1C5.9225 1 1 5.9225 1 12C1 16.8675 4.14875 20.9787 8.52125 22.4362C9.07125 22.5325 9.2775 22.2025 9.2775 21.9137C9.2775 21.6525 9.26375 20.7862 9.26375 19.865C6.5 20.3737 5.785 19.1912 5.565 18.5725C5.44125 18.2562 4.905 17.28 4.4375 17.0187C4.0525 16.8125 3.5025 16.3037 4.42375 16.29C5.29 16.2762 5.90875 17.0875 6.115 17.4175C7.105 19.0812 8.68625 18.6137 9.31875 18.325C9.415 17.61 9.70375 17.1287 10.02 16.8537C7.5725 16.5787 5.015 15.63 5.015 11.4225C5.015 10.2262 5.44125 9.23625 6.1425 8.46625C6.0325 8.19125 5.6475 7.06375 6.2525 5.55125C6.2525 5.55125 7.17375 5.2625 9.2775 6.67875C10.1575 6.43125 11.0925 6.3075 12.0275 6.3075C12.9625 6.3075 13.8975 6.43125 14.7775 6.67875C16.8813 5.24875 17.8025 5.55125 17.8025 5.55125C18.4075 7.06375 18.0225 8.19125 17.9125 8.46625C18.6138 9.23625 19.04 10.2125 19.04 11.4225C19.04 15.6437 16.4688 16.5787 14.0213 16.8537C14.42 17.1975 14.7638 17.8575 14.7638 18.8887C14.7638 20.36 14.75 21.5425 14.75 21.9137C14.75 22.2025 14.9563 22.5462 15.5063 22.4362C19.8513 20.9787 23 16.8537 23 12C23 5.9225 18.0775 1 12 1Z"></path> </svg> </a> <span> &copy; 2025 GitHub,&nbsp;Inc. </span> </div> <nav aria-label="Footer"> <h3 class="sr-only" id="sr-footer-heading">Footer navigation</h3> <ul class="list-style-none d-flex flex-justify-center flex-wrap mb-2 mb-lg-0" aria-labelledby="sr-footer-heading"> <li class="mx-2"> <a data-analytics-event="{&quot;category&quot;:&quot;Footer&quot;,&quot;action&quot;:&quot;go to Terms&quot;,&quot;label&quot;:&quot;text:terms&quot;}" href="https://docs.github.com/site-policy/github-terms/github-terms-of-service" data-view-component="true" class="Link--secondary Link">Terms</a> </li> <li class="mx-2"> <a data-analytics-event="{&quot;category&quot;:&quot;Footer&quot;,&quot;action&quot;:&quot;go to privacy&quot;,&quot;label&quot;:&quot;text:privacy&quot;}" href="https://docs.github.com/site-policy/privacy-policies/github-privacy-statement" data-view-component="true" class="Link--secondary Link">Privacy</a> </li> <li class="mx-2"> <a data-analytics-event="{&quot;category&quot;:&quot;Footer&quot;,&quot;action&quot;:&quot;go to security&quot;,&quot;label&quot;:&quot;text:security&quot;}" href="https://github.com/security" data-view-component="true" class="Link--secondary Link">Security</a> </li> <li class="mx-2"> <a data-analytics-event="{&quot;category&quot;:&quot;Footer&quot;,&quot;action&quot;:&quot;go to status&quot;,&quot;label&quot;:&quot;text:status&quot;}" href="https://www.githubstatus.com/" data-view-component="true" class="Link--secondary Link">Status</a> </li> <li class="mx-2"> <a data-analytics-event="{&quot;category&quot;:&quot;Footer&quot;,&quot;action&quot;:&quot;go to docs&quot;,&quot;label&quot;:&quot;text:docs&quot;}" href="https://docs.github.com/" data-view-component="true" class="Link--secondary Link">Docs</a> </li> <li class="mx-2"> <a data-analytics-event="{&quot;category&quot;:&quot;Footer&quot;,&quot;action&quot;:&quot;go to contact&quot;,&quot;label&quot;:&quot;text:contact&quot;}" href="https://support.github.com?tags=dotcom-footer" data-view-component="true" class="Link--secondary Link">Contact</a> </li> <li class="mx-2" > <cookie-consent-link> <button type="button" class="Link--secondary underline-on-hover border-0 p-0 color-bg-transparent" data-action="click:cookie-consent-link#showConsentManagement" data-analytics-event="{&quot;location&quot;:&quot;footer&quot;,&quot;action&quot;:&quot;cookies&quot;,&quot;context&quot;:&quot;subfooter&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;cookies_link_subfooter_footer&quot;}" > Manage cookies </button> </cookie-consent-link> </li> <li class="mx-2"> <cookie-consent-link> <button type="button" class="Link--secondary underline-on-hover border-0 p-0 color-bg-transparent" data-action="click:cookie-consent-link#showConsentManagement" data-analytics-event="{&quot;location&quot;:&quot;footer&quot;,&quot;action&quot;:&quot;dont_share_info&quot;,&quot;context&quot;:&quot;subfooter&quot;,&quot;tag&quot;:&quot;link&quot;,&quot;label&quot;:&quot;dont_share_info_link_subfooter_footer&quot;}" > Do not share my personal information </button> </cookie-consent-link> </li> </ul> </nav> </div> </footer> <ghcc-consent id="ghcc" class="position-fixed bottom-0 left-0" style="z-index: 999999" data-initial-cookie-consent-allowed="" data-cookie-consent-required="false"></ghcc-consent> <div id="ajax-error-message" class="ajax-error-message flash flash-error" hidden> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-alert"> <path d="M6.457 1.047c.659-1.234 2.427-1.234 3.086 0l6.082 11.378A1.75 1.75 0 0 1 14.082 15H1.918a1.75 1.75 0 0 1-1.543-2.575Zm1.763.707a.25.25 0 0 0-.44 0L1.698 13.132a.25.25 0 0 0 .22.368h12.164a.25.25 0 0 0 .22-.368Zm.53 3.996v2.5a.75.75 0 0 1-1.5 0v-2.5a.75.75 0 0 1 1.5 0ZM9 11a1 1 0 1 1-2 0 1 1 0 0 1 2 0Z"></path> </svg> <button type="button" class="flash-close js-ajax-error-dismiss" aria-label="Dismiss error"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x"> <path d="M3.72 3.72a.75.75 0 0 1 1.06 0L8 6.94l3.22-3.22a.749.749 0 0 1 1.275.326.749.749 0 0 1-.215.734L9.06 8l3.22 3.22a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L8 9.06l-3.22 3.22a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L6.94 8 3.72 4.78a.75.75 0 0 1 0-1.06Z"></path> </svg> </button> You can’t perform that action at this time. </div> <template id="site-details-dialog"> <details class="details-reset details-overlay details-overlay-dark lh-default color-fg-default hx_rsm" open> <summary role="button" aria-label="Close dialog"></summary> <details-dialog class="Box Box--overlay d-flex flex-column anim-fade-in fast hx_rsm-dialog hx_rsm-modal"> <button class="Box-btn-octicon m-0 btn-octicon position-absolute right-0 top-0" type="button" aria-label="Close dialog" data-close-dialog> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-x"> <path d="M3.72 3.72a.75.75 0 0 1 1.06 0L8 6.94l3.22-3.22a.749.749 0 0 1 1.275.326.749.749 0 0 1-.215.734L9.06 8l3.22 3.22a.749.749 0 0 1-.326 1.275.749.749 0 0 1-.734-.215L8 9.06l-3.22 3.22a.751.751 0 0 1-1.042-.018.751.751 0 0 1-.018-1.042L6.94 8 3.72 4.78a.75.75 0 0 1 0-1.06Z"></path> </svg> </button> <div class="octocat-spinner my-6 js-details-dialog-spinner"></div> </details-dialog> </details> </template> <div class="Popover js-hovercard-content position-absolute" style="display: none; outline: none;"> <div class="Popover-message Popover-message--bottom-left Popover-message--large Box color-shadow-large" style="width:360px;"> </div> </div> <template id="snippet-clipboard-copy-button"> <div class="zeroclipboard-container position-absolute right-0 top-0"> <clipboard-copy aria-label="Copy" class="ClipboardButton btn js-clipboard-copy m-2 p-0" data-copy-feedback="Copied!" data-tooltip-direction="w"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-copy js-clipboard-copy-icon m-2"> <path d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 0 1 0 1.5h-1.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-1.5a.75.75 0 0 1 1.5 0v1.5A1.75 1.75 0 0 1 9.25 16h-7.5A1.75 1.75 0 0 1 0 14.25Z"></path><path d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0 1 14.25 11h-7.5A1.75 1.75 0 0 1 5 9.25Zm1.75-.25a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-7.5a.25.25 0 0 0-.25-.25Z"></path> </svg> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-check js-clipboard-check-icon color-fg-success d-none m-2"> <path d="M13.78 4.22a.75.75 0 0 1 0 1.06l-7.25 7.25a.75.75 0 0 1-1.06 0L2.22 9.28a.751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018L6 10.94l6.72-6.72a.75.75 0 0 1 1.06 0Z"></path> </svg> </clipboard-copy> </div> </template> <template id="snippet-clipboard-copy-button-unpositioned"> <div class="zeroclipboard-container"> <clipboard-copy aria-label="Copy" class="ClipboardButton btn btn-invisible js-clipboard-copy m-2 p-0 d-flex flex-justify-center flex-items-center" data-copy-feedback="Copied!" data-tooltip-direction="w"> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-copy js-clipboard-copy-icon"> <path d="M0 6.75C0 5.784.784 5 1.75 5h1.5a.75.75 0 0 1 0 1.5h-1.5a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-1.5a.75.75 0 0 1 1.5 0v1.5A1.75 1.75 0 0 1 9.25 16h-7.5A1.75 1.75 0 0 1 0 14.25Z"></path><path d="M5 1.75C5 .784 5.784 0 6.75 0h7.5C15.216 0 16 .784 16 1.75v7.5A1.75 1.75 0 0 1 14.25 11h-7.5A1.75 1.75 0 0 1 5 9.25Zm1.75-.25a.25.25 0 0 0-.25.25v7.5c0 .138.112.25.25.25h7.5a.25.25 0 0 0 .25-.25v-7.5a.25.25 0 0 0-.25-.25Z"></path> </svg> <svg aria-hidden="true" height="16" viewBox="0 0 16 16" version="1.1" width="16" data-view-component="true" class="octicon octicon-check js-clipboard-check-icon color-fg-success d-none"> <path d="M13.78 4.22a.75.75 0 0 1 0 1.06l-7.25 7.25a.75.75 0 0 1-1.06 0L2.22 9.28a.751.751 0 0 1 .018-1.042.751.751 0 0 1 1.042-.018L6 10.94l6.72-6.72a.75.75 0 0 1 1.06 0Z"></path> </svg> </clipboard-copy> </div> </template> </div> <div id="js-global-screen-reader-notice" class="sr-only mt-n1" aria-live="polite" aria-atomic="true" ></div> <div id="js-global-screen-reader-notice-assertive" class="sr-only mt-n1" aria-live="assertive" aria-atomic="true"></div> </body> </html>

Pages: 1 2 3 4 5 6 7 8 9 10