mirror of
				https://github.com/jart/cosmopolitan.git
				synced 2025-10-25 18:50:57 +00:00 
			
		
		
		
	Fix build and delete superfluous files
- Make Python make formatting pristine - Add missing `#pragma weak` to Python source - Fix Clang script flake due to missing directory
This commit is contained in:
		
							parent
							
								
									295b3d6ca5
								
							
						
					
					
						commit
						798d542f15
					
				
					 901 changed files with 683 additions and 455657 deletions
				
			
		|  | @ -3,6 +3,7 @@ | ||||||
| #───vi: set net ft=sh ts=2 sts=2 fenc=utf-8 :vi─────────────┘ | #───vi: set net ft=sh ts=2 sts=2 fenc=utf-8 :vi─────────────┘ | ||||||
| 
 | 
 | ||||||
| if CLANG=$(command -v clang); then | if CLANG=$(command -v clang); then | ||||||
|  |   mkdir -p o/$MODE/test/libc/release | ||||||
|   $CLANG                                              \ |   $CLANG                                              \ | ||||||
|       -o o/$MODE/test/libc/release/smokeclang.com.dbg \ |       -o o/$MODE/test/libc/release/smokeclang.com.dbg \ | ||||||
|       -Os                                             \ |       -Os                                             \ | ||||||
|  |  | ||||||
|  | @ -5,6 +5,7 @@ | ||||||
| # TODO(jart): implement me | # TODO(jart): implement me | ||||||
| 
 | 
 | ||||||
| if CLANG=$(command -v clang); then | if CLANG=$(command -v clang); then | ||||||
|  |   mkdir -p o/$MODE/test/libc/release | ||||||
|   $CLANG                                              \ |   $CLANG                                              \ | ||||||
|       -o o/$MODE/test/libc/release/smokeclang.com.dbg \ |       -o o/$MODE/test/libc/release/smokeclang.com.dbg \ | ||||||
|       -Os                                             \ |       -Os                                             \ | ||||||
|  |  | ||||||
|  | @ -8,6 +8,8 @@ if [ "$MODE" = opt ]; then | ||||||
|   exit |   exit | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
|  | mkdir -p o/$MODE/test/libc/release/ | ||||||
|  | 
 | ||||||
| # smoke test booting on bare metal and printing data to serial uart | # smoke test booting on bare metal and printing data to serial uart | ||||||
| CMD="o/$MODE/tool/build/blinkenlights.com.dbg -r o/$MODE/examples/hello.com" | CMD="o/$MODE/tool/build/blinkenlights.com.dbg -r o/$MODE/examples/hello.com" | ||||||
| if OUTPUT="$($CMD)"; then | if OUTPUT="$($CMD)"; then | ||||||
|  |  | ||||||
							
								
								
									
										137
									
								
								third_party/python/.azure-pipelines/ci.yml
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										137
									
								
								third_party/python/.azure-pipelines/ci.yml
									
										
									
									
										vendored
									
									
								
							|  | @ -1,137 +0,0 @@ | ||||||
| variables: |  | ||||||
|   manylinux: false |  | ||||||
|   coverage: false |  | ||||||
| 
 |  | ||||||
| jobs: |  | ||||||
| - job: Prebuild |  | ||||||
|   displayName: Pre-build checks |  | ||||||
| 
 |  | ||||||
|   pool: |  | ||||||
|     vmImage: ubuntu-16.04 |  | ||||||
| 
 |  | ||||||
|   steps: |  | ||||||
|   - template: ./prebuild-checks.yml |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| - job: Docs_PR |  | ||||||
|   displayName: Docs PR |  | ||||||
|   dependsOn: Prebuild |  | ||||||
|   condition: and(succeeded(), eq(dependencies.Prebuild.outputs['docs.run'], 'true')) |  | ||||||
| 
 |  | ||||||
|   pool: |  | ||||||
|     vmImage: ubuntu-16.04 |  | ||||||
| 
 |  | ||||||
|   steps: |  | ||||||
|   - template: ./docs-steps.yml |  | ||||||
|     parameters: |  | ||||||
|       upload: true |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| - job: macOS_CI_Tests |  | ||||||
|   displayName: macOS CI Tests |  | ||||||
|   dependsOn: Prebuild |  | ||||||
|   #condition: and(succeeded(), eq(dependencies.Prebuild.outputs['tests.run'], 'true')) |  | ||||||
|   # bpo-39837: macOS tests on Azure Pipelines are disabled |  | ||||||
| 
 |  | ||||||
|   variables: |  | ||||||
|     testRunTitle: '$(build.sourceBranchName)-macos' |  | ||||||
|     testRunPlatform: macos |  | ||||||
| 
 |  | ||||||
|   pool: |  | ||||||
|     vmImage: macos-10.14 |  | ||||||
| 
 |  | ||||||
|   steps: |  | ||||||
|   - template: ./macos-steps.yml |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| - job: Ubuntu_CI_Tests |  | ||||||
|   displayName: Ubuntu CI Tests |  | ||||||
|   dependsOn: Prebuild |  | ||||||
|   condition: and(succeeded(), eq(dependencies.Prebuild.outputs['tests.run'], 'true')) |  | ||||||
| 
 |  | ||||||
|   pool: |  | ||||||
|     vmImage: ubuntu-16.04 |  | ||||||
| 
 |  | ||||||
|   variables: |  | ||||||
|     testRunTitle: '$(build.sourceBranchName)-linux' |  | ||||||
|     testRunPlatform: linux |  | ||||||
|     openssl_version: 1.1.0g |  | ||||||
| 
 |  | ||||||
|   steps: |  | ||||||
|   - template: ./posix-steps.yml |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| - job: ManyLinux1_CI_Tests |  | ||||||
|   displayName: ManyLinux1 CI Tests |  | ||||||
|   dependsOn: Prebuild |  | ||||||
|   condition: | |  | ||||||
|     and( |  | ||||||
|         and( |  | ||||||
|             succeeded(), |  | ||||||
|             eq(variables['manylinux'], 'true') |  | ||||||
|         ), |  | ||||||
|         eq(dependencies.Prebuild.outputs['tests.run'], 'true') |  | ||||||
|     ) |  | ||||||
| 
 |  | ||||||
|   pool: |  | ||||||
|     vmImage: ubuntu-16.04 |  | ||||||
| 
 |  | ||||||
|   variables: |  | ||||||
|     testRunTitle: '$(build.sourceBranchName)-manylinux1' |  | ||||||
|     testRunPlatform: manylinux1 |  | ||||||
|     imageName: 'dockcross/manylinux-x64' |  | ||||||
| 
 |  | ||||||
|   steps: |  | ||||||
|   - template: ./docker-steps.yml |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| - job: Ubuntu_Coverage_CI_Tests |  | ||||||
|   displayName: Ubuntu CI Tests (coverage) |  | ||||||
|   dependsOn: Prebuild |  | ||||||
|   condition: | |  | ||||||
|     and( |  | ||||||
|         and( |  | ||||||
|             succeeded(), |  | ||||||
|             eq(variables['coverage'], 'true') |  | ||||||
|         ), |  | ||||||
|         eq(dependencies.Prebuild.outputs['tests.run'], 'true') |  | ||||||
|     ) |  | ||||||
| 
 |  | ||||||
|   pool: |  | ||||||
|     vmImage: ubuntu-16.04 |  | ||||||
| 
 |  | ||||||
|   variables: |  | ||||||
|     testRunTitle: '$(Build.SourceBranchName)-linux-coverage' |  | ||||||
|     testRunPlatform: linux-coverage |  | ||||||
|     openssl_version: 1.1.0g |  | ||||||
| 
 |  | ||||||
|   steps: |  | ||||||
|   - template: ./posix-steps.yml |  | ||||||
|     parameters: |  | ||||||
|       coverage: true |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| - job: Windows_CI_Tests |  | ||||||
|   displayName: Windows CI Tests |  | ||||||
|   dependsOn: Prebuild |  | ||||||
|   condition: and(succeeded(), eq(dependencies.Prebuild.outputs['tests.run'], 'true')) |  | ||||||
| 
 |  | ||||||
|   pool: |  | ||||||
|     vmImage: vs2017-win2016 |  | ||||||
| 
 |  | ||||||
|   strategy: |  | ||||||
|     matrix: |  | ||||||
|       win32: |  | ||||||
|         arch: win32 |  | ||||||
|         buildOpt: |  | ||||||
|         testRunTitle: '$(Build.SourceBranchName)-win32' |  | ||||||
|         testRunPlatform: win32 |  | ||||||
|       win64: |  | ||||||
|         arch: amd64 |  | ||||||
|         buildOpt: '-p x64' |  | ||||||
|         testRunTitle: '$(Build.SourceBranchName)-win64' |  | ||||||
|         testRunPlatform: win64 |  | ||||||
|     maxParallel: 2 |  | ||||||
| 
 |  | ||||||
|   steps: |  | ||||||
|   - template: ./windows-steps.yml |  | ||||||
|  | @ -1,76 +0,0 @@ | ||||||
| steps: |  | ||||||
| - checkout: self |  | ||||||
|   clean: true |  | ||||||
|   fetchDepth: 5 |  | ||||||
| 
 |  | ||||||
| - ${{ if ne(parameters.targetBranch, '') }}: |  | ||||||
|   - script: | |  | ||||||
|      git fetch -q origin ${{ parameters.targetbranch }} |  | ||||||
|      if ! git diff --name-only HEAD $(git merge-base HEAD FETCH_HEAD) | grep -qvE '(\.rst$|^Doc|^Misc)' |  | ||||||
|      then |  | ||||||
|        echo "Only docs were updated, stopping build process." |  | ||||||
|        echo "##vso[task.setvariable variable=DocOnly]true" |  | ||||||
|        exit |  | ||||||
|      fi |  | ||||||
|     displayName: Detect doc-only changes |  | ||||||
| 
 |  | ||||||
| - task: docker@0 |  | ||||||
|   displayName: 'Configure CPython (debug)' |  | ||||||
|   inputs: |  | ||||||
|     action: 'Run an image' |  | ||||||
|     imageName: $(imageName) |  | ||||||
|     volumes: | |  | ||||||
|       $(build.sourcesDirectory):/src |  | ||||||
|       $(build.binariesDirectory):/build |  | ||||||
|     workDir: '/src' |  | ||||||
|     containerCommand: './configure --with-pydebug' |  | ||||||
|     detached: false |  | ||||||
|   condition: and(succeeded(), ne(variables['DocOnly'], 'true')) |  | ||||||
| 
 |  | ||||||
| - task: docker@0 |  | ||||||
|   displayName: 'Build CPython' |  | ||||||
|   inputs: |  | ||||||
|     action: 'Run an image' |  | ||||||
|     imageName: $(imageName) |  | ||||||
|     volumes: | |  | ||||||
|       $(build.sourcesDirectory):/src |  | ||||||
|       $(build.binariesDirectory):/build |  | ||||||
|     workDir: '/src' |  | ||||||
|     containerCommand: 'make -s -j4' |  | ||||||
|     detached: false |  | ||||||
|   condition: and(succeeded(), ne(variables['DocOnly'], 'true')) |  | ||||||
| 
 |  | ||||||
| - task: docker@0 |  | ||||||
|   displayName: 'Display build info' |  | ||||||
|   inputs: |  | ||||||
|     action: 'Run an image' |  | ||||||
|     imageName: $(imageName) |  | ||||||
|     volumes: | |  | ||||||
|       $(build.sourcesDirectory):/src |  | ||||||
|       $(build.binariesDirectory):/build |  | ||||||
|     workDir: '/src' |  | ||||||
|     containerCommand: 'make pythoninfo' |  | ||||||
|     detached: false |  | ||||||
|   condition: and(succeeded(), ne(variables['DocOnly'], 'true')) |  | ||||||
| 
 |  | ||||||
| - task: docker@0 |  | ||||||
|   displayName: 'Tests' |  | ||||||
|   inputs: |  | ||||||
|     action: 'Run an image' |  | ||||||
|     imageName: $(imageName) |  | ||||||
|     volumes: | |  | ||||||
|       $(build.sourcesDirectory):/src |  | ||||||
|       $(build.binariesDirectory):/build |  | ||||||
|     workDir: '/src' |  | ||||||
|     containerCommand: 'make buildbottest TESTOPTS="-j4 -uall,-cpu --junit-xml=/build/test-results.xml"' |  | ||||||
|     detached: false |  | ||||||
|   condition: and(succeeded(), ne(variables['DocOnly'], 'true')) |  | ||||||
| 
 |  | ||||||
| - task: PublishTestResults@2 |  | ||||||
|   displayName: 'Publish Test Results' |  | ||||||
|   inputs: |  | ||||||
|     testResultsFiles: '$(build.binariesDirectory)/test-results.xml' |  | ||||||
|     mergeTestResults: true |  | ||||||
|     testRunTitle: $(testRunTitle) |  | ||||||
|     platform: $(testRunPlatform) |  | ||||||
|   condition: and(succeededOrFailed(), ne(variables['DocOnly'], 'true')) |  | ||||||
|  | @ -1,46 +0,0 @@ | ||||||
| parameters: |  | ||||||
|   latex: false |  | ||||||
|   upload: false |  | ||||||
| 
 |  | ||||||
| steps: |  | ||||||
| - checkout: self |  | ||||||
|   clean: true |  | ||||||
|   fetchDepth: 5 |  | ||||||
| 
 |  | ||||||
| - task: UsePythonVersion@0 |  | ||||||
|   displayName: 'Use Python 3.6 or later' |  | ||||||
|   inputs: |  | ||||||
|     versionSpec: '>=3.6' |  | ||||||
| 
 |  | ||||||
| - script: python -m pip install sphinx==1.8.2 blurb python-docs-theme |  | ||||||
|   displayName: 'Install build dependencies' |  | ||||||
| 
 |  | ||||||
| - ${{ if ne(parameters.latex, 'true') }}: |  | ||||||
|   - script: make check suspicious html PYTHON=python |  | ||||||
|     workingDirectory: '$(build.sourcesDirectory)/Doc' |  | ||||||
|     displayName: 'Build documentation' |  | ||||||
| 
 |  | ||||||
| - ${{ if eq(parameters.latex, 'true') }}: |  | ||||||
|   - script: sudo apt-get update && sudo apt-get install -qy --force-yes texlive-full  |  | ||||||
|     displayName: 'Install LaTeX' |  | ||||||
| 
 |  | ||||||
|   - script: make dist PYTHON=python SPHINXBUILD='python -m sphinx' BLURB='python -m blurb' |  | ||||||
|     workingDirectory: '$(build.sourcesDirectory)/Doc' |  | ||||||
|     displayName: 'Build documentation' |  | ||||||
| 
 |  | ||||||
| - ${{ if eq(parameters.upload, 'true') }}: |  | ||||||
|   - task: PublishBuildArtifacts@1 |  | ||||||
|     displayName: 'Publish docs' |  | ||||||
|    |  | ||||||
|     inputs: |  | ||||||
|       PathToPublish: '$(build.sourcesDirectory)/Doc/build' |  | ||||||
|       ArtifactName: docs |  | ||||||
|       publishLocation: Container |  | ||||||
| 
 |  | ||||||
|   - ${{ if eq(parameters.latex, 'true') }}: |  | ||||||
|     - task: PublishBuildArtifacts@1 |  | ||||||
|       displayName: 'Publish dist' |  | ||||||
|       inputs: |  | ||||||
|         PathToPublish: '$(build.sourcesDirectory)/Doc/dist' |  | ||||||
|         ArtifactName: docs_dist |  | ||||||
|         publishLocation: Container |  | ||||||
|  | @ -1,27 +0,0 @@ | ||||||
| steps: |  | ||||||
| - checkout: self |  | ||||||
|   clean: true |  | ||||||
|   fetchDepth: 5 |  | ||||||
| 
 |  | ||||||
| - script: ./configure --with-pydebug --with-openssl=/usr/local/opt/openssl --prefix=/opt/python-azdev |  | ||||||
|   displayName: 'Configure CPython (debug)' |  | ||||||
| 
 |  | ||||||
| - script: make -j4 |  | ||||||
|   displayName: 'Build CPython' |  | ||||||
| 
 |  | ||||||
| - script: make pythoninfo |  | ||||||
|   displayName: 'Display build info' |  | ||||||
| 
 |  | ||||||
| - script: make buildbottest TESTOPTS="-j4 -uall,-cpu --junit-xml=$(build.binariesDirectory)/test-results.xml" |  | ||||||
|   displayName: 'Tests' |  | ||||||
|   continueOnError: true |  | ||||||
|   timeoutInMinutes: 30 |  | ||||||
| 
 |  | ||||||
| - task: PublishTestResults@2 |  | ||||||
|   displayName: 'Publish Test Results' |  | ||||||
|   inputs: |  | ||||||
|     testResultsFiles: '$(build.binariesDirectory)/test-results.xml' |  | ||||||
|     mergeTestResults: true |  | ||||||
|     testRunTitle: $(testRunTitle) |  | ||||||
|     platform: $(testRunPlatform) |  | ||||||
|   condition: succeededOrFailed() |  | ||||||
|  | @ -1,26 +0,0 @@ | ||||||
| sudo apt-get update |  | ||||||
| 
 |  | ||||||
| sudo apt-get -yq install \ |  | ||||||
|     build-essential \ |  | ||||||
|     zlib1g-dev \ |  | ||||||
|     libbz2-dev \ |  | ||||||
|     liblzma-dev \ |  | ||||||
|     libncurses5-dev \ |  | ||||||
|     libreadline6-dev \ |  | ||||||
|     libsqlite3-dev \ |  | ||||||
|     libssl-dev \ |  | ||||||
|     libgdbm-dev \ |  | ||||||
|     tk-dev \ |  | ||||||
|     lzma \ |  | ||||||
|     lzma-dev \ |  | ||||||
|     liblzma-dev \ |  | ||||||
|     libffi-dev \ |  | ||||||
|     uuid-dev \ |  | ||||||
|     xvfb |  | ||||||
| 
 |  | ||||||
| if [ ! -z "$1" ] |  | ||||||
| then |  | ||||||
|   echo ##vso[task.prependpath]$PWD/multissl/openssl/$1 |  | ||||||
|   echo ##vso[task.setvariable variable=OPENSSL_DIR]$PWD/multissl/openssl/$1 |  | ||||||
|   python3 Tools/ssl/multissltests.py --steps=library --base-directory $PWD/multissl --openssl $1 --system Linux |  | ||||||
| fi |  | ||||||
|  | @ -1,63 +0,0 @@ | ||||||
| parameters: |  | ||||||
|   coverage: false |  | ||||||
| 
 |  | ||||||
| steps: |  | ||||||
| - checkout: self |  | ||||||
|   clean: true |  | ||||||
|   fetchDepth: 5 |  | ||||||
| 
 |  | ||||||
| - script: ./.azure-pipelines/posix-deps.sh $(openssl_version) |  | ||||||
|   displayName: 'Install dependencies' |  | ||||||
| 
 |  | ||||||
| - script: ./configure --with-pydebug |  | ||||||
|   displayName: 'Configure CPython (debug)' |  | ||||||
| 
 |  | ||||||
| - script: make -s -j4 |  | ||||||
|   displayName: 'Build CPython' |  | ||||||
| 
 |  | ||||||
| - ${{ if eq(parameters.coverage, 'true') }}: |  | ||||||
|   - script: ./python -m venv venv && ./venv/bin/python -m pip install -U coverage |  | ||||||
|     displayName: 'Set up virtual environment' |  | ||||||
| 
 |  | ||||||
|   - script: ./venv/bin/python -m test.pythoninfo |  | ||||||
|     displayName: 'Display build info' |  | ||||||
| 
 |  | ||||||
|   - script: | |  | ||||||
|       xvfb-run ./venv/bin/python -m coverage run --pylib -m test \ |  | ||||||
|                 --fail-env-changed \ |  | ||||||
|                 -uall,-cpu \ |  | ||||||
|                 --junit-xml=$(build.binariesDirectory)/test-results.xml" \ |  | ||||||
|                 -x test_multiprocessing_fork \ |  | ||||||
|                 -x test_multiprocessing_forkserver \ |  | ||||||
|                 -x test_multiprocessing_spawn \ |  | ||||||
|                 -x test_concurrent_futures |  | ||||||
|     displayName: 'Tests with coverage' |  | ||||||
| 
 |  | ||||||
|   - script: ./venv/bin/python -m coverage xml |  | ||||||
|     displayName: 'Generate coverage.xml' |  | ||||||
| 
 |  | ||||||
|   - script: source ./venv/bin/activate && bash <(curl -s https://codecov.io/bash) |  | ||||||
|     displayName: 'Publish code coverage results' |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| - ${{ if ne(parameters.coverage, 'true') }}: |  | ||||||
|   - script: make pythoninfo |  | ||||||
|     displayName: 'Display build info' |  | ||||||
| 
 |  | ||||||
|   - script: xvfb-run make buildbottest TESTOPTS="-j4 -uall,-cpu --junit-xml=$(build.binariesDirectory)/test-results.xml" |  | ||||||
|     displayName: 'Tests' |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| - script: ./python Tools/scripts/patchcheck.py --travis true |  | ||||||
|   displayName: 'Run patchcheck.py' |  | ||||||
|   condition: and(succeeded(), eq(variables['Build.Reason'], 'PullRequest')) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| - task: PublishTestResults@2 |  | ||||||
|   displayName: 'Publish Test Results' |  | ||||||
|   inputs: |  | ||||||
|     testResultsFiles: '$(build.binariesDirectory)/test-results.xml' |  | ||||||
|     mergeTestResults: true |  | ||||||
|     testRunTitle: $(testRunTitle) |  | ||||||
|     platform: $(testRunPlatform) |  | ||||||
|   condition: succeededOrFailed() |  | ||||||
							
								
								
									
										88
									
								
								third_party/python/.azure-pipelines/pr.yml
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										88
									
								
								third_party/python/.azure-pipelines/pr.yml
									
										
									
									
										vendored
									
									
								
							|  | @ -1,88 +0,0 @@ | ||||||
| jobs: |  | ||||||
| - job: Prebuild |  | ||||||
|   displayName: Pre-build checks |  | ||||||
| 
 |  | ||||||
|   pool: |  | ||||||
|     vmImage: ubuntu-16.04 |  | ||||||
| 
 |  | ||||||
|   steps: |  | ||||||
|   - template: ./prebuild-checks.yml |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| - job: Docs_PR |  | ||||||
|   displayName: Docs PR |  | ||||||
|   dependsOn: Prebuild |  | ||||||
|   condition: and(succeeded(), eq(dependencies.Prebuild.outputs['docs.run'], 'true')) |  | ||||||
| 
 |  | ||||||
|   pool: |  | ||||||
|     vmImage: ubuntu-16.04 |  | ||||||
| 
 |  | ||||||
|   steps: |  | ||||||
|   - template: ./docs-steps.yml |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| - job: macOS_PR_Tests |  | ||||||
|   displayName: macOS PR Tests |  | ||||||
|   dependsOn: Prebuild |  | ||||||
|   condition: and(succeeded(), eq(dependencies.Prebuild.outputs['tests.run'], 'true')) |  | ||||||
|   #condition: and(succeeded(), eq(dependencies.Prebuild.outputs['tests.run'], 'true')) |  | ||||||
|   # bpo-39837: macOS tests on Azure Pipelines are disabled |  | ||||||
| 
 |  | ||||||
|   variables: |  | ||||||
|     testRunTitle: '$(system.pullRequest.TargetBranch)-macos' |  | ||||||
|     testRunPlatform: macos |  | ||||||
| 
 |  | ||||||
|   pool: |  | ||||||
|     vmImage: macos-10.14 |  | ||||||
| 
 |  | ||||||
|   steps: |  | ||||||
|   - template: ./macos-steps.yml |  | ||||||
|     parameters: |  | ||||||
|       targetBranch: $(System.PullRequest.TargetBranch) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| - job: Ubuntu_PR_Tests |  | ||||||
|   displayName: Ubuntu PR Tests |  | ||||||
|   dependsOn: Prebuild |  | ||||||
|   condition: and(succeeded(), eq(dependencies.Prebuild.outputs['tests.run'], 'true')) |  | ||||||
| 
 |  | ||||||
|   pool: |  | ||||||
|     vmImage: ubuntu-16.04 |  | ||||||
| 
 |  | ||||||
|   variables: |  | ||||||
|     testRunTitle: '$(system.pullRequest.TargetBranch)-linux' |  | ||||||
|     testRunPlatform: linux |  | ||||||
|     openssl_version: 1.1.0g |  | ||||||
| 
 |  | ||||||
|   steps: |  | ||||||
|   - template: ./posix-steps.yml |  | ||||||
|     parameters: |  | ||||||
|       targetBranch: $(System.PullRequest.TargetBranch) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| - job: Windows_PR_Tests |  | ||||||
|   displayName: Windows PR Tests |  | ||||||
|   dependsOn: Prebuild |  | ||||||
|   condition: and(succeeded(), eq(dependencies.Prebuild.outputs['tests.run'], 'true')) |  | ||||||
| 
 |  | ||||||
|   pool: |  | ||||||
|     vmImage: vs2017-win2016 |  | ||||||
| 
 |  | ||||||
|   strategy: |  | ||||||
|     matrix: |  | ||||||
|       win32: |  | ||||||
|         arch: win32 |  | ||||||
|         buildOpt: |  | ||||||
|         testRunTitle: '$(System.PullRequest.TargetBranch)-win32' |  | ||||||
|         testRunPlatform: win32 |  | ||||||
|       win64: |  | ||||||
|         arch: amd64 |  | ||||||
|         buildOpt: '-p x64' |  | ||||||
|         testRunTitle: '$(System.PullRequest.TargetBranch)-win64' |  | ||||||
|         testRunPlatform: win64 |  | ||||||
|     maxParallel: 2 |  | ||||||
| 
 |  | ||||||
|   steps: |  | ||||||
|   - template: ./windows-steps.yml |  | ||||||
|     parameters: |  | ||||||
|       targetBranch: $(System.PullRequest.TargetBranch) |  | ||||||
|  | @ -1,36 +0,0 @@ | ||||||
| steps: |  | ||||||
| - checkout: self |  | ||||||
|   fetchDepth: 5 |  | ||||||
| 
 |  | ||||||
| - script: echo "##vso[task.setvariable variable=diffTarget]HEAD~1" |  | ||||||
|   displayName: Set default diff target |  | ||||||
| 
 |  | ||||||
| - script: | |  | ||||||
|     git fetch -q origin $(System.PullRequest.TargetBranch) |  | ||||||
|     echo "##vso[task.setvariable variable=diffTarget]HEAD \$(git merge-base HEAD FETCH_HEAD)" |  | ||||||
|   displayName: Fetch comparison tree |  | ||||||
|   condition: and(succeeded(), variables['System.PullRequest.TargetBranch']) |  | ||||||
| 
 |  | ||||||
| - script: | |  | ||||||
|    if ! git diff --name-only $(diffTarget) | grep -qE '(\.rst$|^Doc|^Misc)' |  | ||||||
|    then |  | ||||||
|      echo "No docs were updated: docs.run=false" |  | ||||||
|      echo "##vso[task.setvariable variable=run;isOutput=true]false" |  | ||||||
|    else |  | ||||||
|      echo "Docs were updated: docs.run=true" |  | ||||||
|      echo "##vso[task.setvariable variable=run;isOutput=true]true" |  | ||||||
|    fi |  | ||||||
|   displayName: Detect documentation changes |  | ||||||
|   name: docs |  | ||||||
| 
 |  | ||||||
| - script: | |  | ||||||
|    if ! git diff --name-only $(diffTarget) | grep -qvE '(\.rst$|^Doc|^Misc)' |  | ||||||
|    then |  | ||||||
|      echo "Only docs were updated: tests.run=false" |  | ||||||
|      echo "##vso[task.setvariable variable=run;isOutput=true]false" |  | ||||||
|    else |  | ||||||
|      echo "Code was updated: tests.run=true" |  | ||||||
|      echo "##vso[task.setvariable variable=run;isOutput=true]true" |  | ||||||
|    fi |  | ||||||
|   displayName: Detect source changes |  | ||||||
|   name: tests |  | ||||||
|  | @ -1,32 +0,0 @@ | ||||||
| steps: |  | ||||||
| - checkout: self |  | ||||||
|   clean: true |  | ||||||
|   fetchDepth: 5 |  | ||||||
| 
 |  | ||||||
| - powershell: | |  | ||||||
|     # Relocate build outputs outside of source directory to make cleaning faster |  | ||||||
|     Write-Host '##vso[task.setvariable variable=Py_IntDir]$(Build.BinariesDirectory)\obj' |  | ||||||
|     # UNDONE: Do not build to a different directory because of broken tests |  | ||||||
|     Write-Host '##vso[task.setvariable variable=Py_OutDir]$(Build.SourcesDirectory)\PCbuild' |  | ||||||
|     Write-Host '##vso[task.setvariable variable=EXTERNAL_DIR]$(Build.BinariesDirectory)\externals' |  | ||||||
|   displayName: Update build locations |  | ||||||
| 
 |  | ||||||
| - script: PCbuild\build.bat -e $(buildOpt) |  | ||||||
|   displayName: 'Build CPython' |  | ||||||
| 
 |  | ||||||
| - script: python.bat -m test.pythoninfo |  | ||||||
|   displayName: 'Display build info' |  | ||||||
| 
 |  | ||||||
| - script: PCbuild\rt.bat -q -uall -u-cpu -rwW --slowest --timeout=1200 -j0 --junit-xml="$(Build.BinariesDirectory)\test-results.xml" |  | ||||||
|   displayName: 'Tests' |  | ||||||
|   env: |  | ||||||
|     PREFIX: $(Py_OutDir)\$(arch) |  | ||||||
| 
 |  | ||||||
| - task: PublishTestResults@2 |  | ||||||
|   displayName: 'Publish Test Results' |  | ||||||
|   inputs: |  | ||||||
|     testResultsFiles: '$(Build.BinariesDirectory)\test-results.xml' |  | ||||||
|     mergeTestResults: true |  | ||||||
|     testRunTitle: $(testRunTitle) |  | ||||||
|     platform: $(testRunPlatform) |  | ||||||
|   condition: succeededOrFailed() |  | ||||||
							
								
								
									
										42
									
								
								third_party/python/.bzrignore
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										42
									
								
								third_party/python/.bzrignore
									
										
									
									
										vendored
									
									
								
							|  | @ -1,42 +0,0 @@ | ||||||
| .purify |  | ||||||
| autom4te.cache |  | ||||||
| config.log |  | ||||||
| config.cache |  | ||||||
| config.status |  | ||||||
| config.status.lineno |  | ||||||
| db_home |  | ||||||
| Makefile |  | ||||||
| buildno |  | ||||||
| python |  | ||||||
| build |  | ||||||
| Makefile.pre |  | ||||||
| platform |  | ||||||
| pybuilddir.txt |  | ||||||
| pyconfig.h |  | ||||||
| libpython*.a |  | ||||||
| libpython*.so* |  | ||||||
| python.exe |  | ||||||
| python-gdb.py |  | ||||||
| reflog.txt |  | ||||||
| tags |  | ||||||
| TAGS |  | ||||||
| .gdb_history |  | ||||||
| Doc/tools/sphinx |  | ||||||
| Doc/tools/jinja |  | ||||||
| Doc/tools/jinja2 |  | ||||||
| Doc/tools/pygments |  | ||||||
| Doc/tools/docutils |  | ||||||
| Misc/python.pc |  | ||||||
| Modules/Setup |  | ||||||
| Modules/Setup.config |  | ||||||
| Modules/Setup.local |  | ||||||
| Modules/config.c |  | ||||||
| Modules/ld_so_aix |  | ||||||
| Parser/pgen |  | ||||||
| Lib/test/data/* |  | ||||||
| Lib/lib2to3/Grammar*.pickle |  | ||||||
| Lib/lib2to3/PatternGrammar*.pickle |  | ||||||
| __pycache__ |  | ||||||
| .coverage |  | ||||||
| coverage/* |  | ||||||
| htmlcov/* |  | ||||||
|  | @ -1,9 +0,0 @@ | ||||||
| ## CPython Mirror |  | ||||||
| 
 |  | ||||||
| https://github.com/python/cpython is a cpython mirror repository. Pull requests |  | ||||||
| are not accepted on this repo and will be automatically closed. |  | ||||||
| 
 |  | ||||||
| ### Submit patches at https://bugs.python.org |  | ||||||
| 
 |  | ||||||
| For additional information about contributing to CPython, see the |  | ||||||
| [developer's guide](https://docs.python.org/devguide/#contributing). |  | ||||||
							
								
								
									
										38
									
								
								third_party/python/.github/appveyor.yml
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										38
									
								
								third_party/python/.github/appveyor.yml
									
										
									
									
										vendored
									
									
								
							|  | @ -1,38 +0,0 @@ | ||||||
| version: 3.6build{build} |  | ||||||
| clone_depth: 5 |  | ||||||
| branches: |  | ||||||
|   only: |  | ||||||
|     - master |  | ||||||
|     - /\d\.\d/ |  | ||||||
|     - buildbot-custom |  | ||||||
| cache: |  | ||||||
|   - externals -> PCbuild\* |  | ||||||
| before_build: |  | ||||||
|   - ps: |+ |  | ||||||
|       if ($env:APPVEYOR_RE_BUILD) { |  | ||||||
|         echo 'Doing full build due to re-build request.' |  | ||||||
|       } elseif (!$env:APPVEYOR_PULL_REQUEST_HEAD_COMMIT) { |  | ||||||
|         echo 'Not a PR, doing full build.' |  | ||||||
|       } else { |  | ||||||
|         git fetch -q origin +refs/heads/$env:APPVEYOR_REPO_BRANCH |  | ||||||
|         $mergebase = git merge-base HEAD FETCH_HEAD |  | ||||||
|         $changes = git diff --name-only HEAD $mergebase | grep -vE '(\.rst$)|(^Doc)|(^Misc)' |  | ||||||
|         If (!$changes) { |  | ||||||
|           echo 'Only docs were updated, stopping build process.' |  | ||||||
|           Exit-AppveyorBuild |  | ||||||
|         } else { |  | ||||||
|           echo 'Doing full build due to non-doc changes in these files:' |  | ||||||
|           echo $changes |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| build_script: |  | ||||||
|   - cmd: PCbuild\build.bat -e |  | ||||||
|   - cmd: PCbuild\win32\python.exe -m test.pythoninfo |  | ||||||
| test_script: |  | ||||||
|   - cmd: PCbuild\rt.bat -q -uall -u-cpu -u-largefile -rwW --slowest --timeout=1200 -j0 |  | ||||||
| environment: |  | ||||||
|   HOST_PYTHON: C:\Python36\python.exe |  | ||||||
| image: |  | ||||||
|   - Visual Studio 2015 |  | ||||||
							
								
								
									
										30
									
								
								third_party/python/.github/codecov.yml
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										30
									
								
								third_party/python/.github/codecov.yml
									
										
									
									
										vendored
									
									
								
							|  | @ -1,30 +0,0 @@ | ||||||
| codecov: |  | ||||||
|   strict_yaml_branch: master |  | ||||||
|   notify: |  | ||||||
|     require_ci_to_pass: true |  | ||||||
| comment: off |  | ||||||
| ignore: |  | ||||||
|   - "Doc/**/*" |  | ||||||
|   - "Misc/**/*" |  | ||||||
|   - "Mac/**/*" |  | ||||||
|   - "PC/**/*" |  | ||||||
|   - "PCbuild/**/*" |  | ||||||
|   - "Tools/**/*" |  | ||||||
|   - "Grammar/*" |  | ||||||
| coverage: |  | ||||||
|   precision: 2 |  | ||||||
|   range: 70...90 |  | ||||||
|   round: down |  | ||||||
|   status: |  | ||||||
|     changes: off |  | ||||||
|     project: off |  | ||||||
|     patch: off |  | ||||||
| parsers: |  | ||||||
|   gcov: |  | ||||||
|     branch_detection: |  | ||||||
|       conditional: true |  | ||||||
|       loop: true |  | ||||||
|       macro: false |  | ||||||
|       method: false |  | ||||||
|   javascript: |  | ||||||
|     enable_partials: false |  | ||||||
							
								
								
									
										105
									
								
								third_party/python/.hgignore
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										105
									
								
								third_party/python/.hgignore
									
										
									
									
										vendored
									
									
								
							|  | @ -1,105 +0,0 @@ | ||||||
| .gdb_history |  | ||||||
| .purify |  | ||||||
| .svn/ |  | ||||||
| ^.idea/ |  | ||||||
| ^.vscode/ |  | ||||||
| .DS_Store |  | ||||||
| Makefile$ |  | ||||||
| Makefile.pre$ |  | ||||||
| TAGS$ |  | ||||||
| autom4te.cache$ |  | ||||||
| ^build/ |  | ||||||
| ^Doc/build/ |  | ||||||
| ^Doc/venv/ |  | ||||||
| buildno$ |  | ||||||
| config.cache |  | ||||||
| config.log |  | ||||||
| config.status |  | ||||||
| config.status.lineno |  | ||||||
| db_home |  | ||||||
| platform$ |  | ||||||
| pyconfig.h$ |  | ||||||
| python$ |  | ||||||
| python.bat$ |  | ||||||
| python.exe$ |  | ||||||
| python-config$ |  | ||||||
| python-config.py$ |  | ||||||
| reflog.txt$ |  | ||||||
| tags$ |  | ||||||
| Misc/python.pc |  | ||||||
| Misc/python-config.sh$ |  | ||||||
| Modules/Setup$ |  | ||||||
| Modules/Setup.config |  | ||||||
| Modules/Setup.local |  | ||||||
| Modules/config.c |  | ||||||
| Modules/ld_so_aix$ |  | ||||||
| Parser/pgen$ |  | ||||||
| ^lcov-report/ |  | ||||||
| ^core |  | ||||||
| ^python-gdb.py |  | ||||||
| ^python.exe-gdb.py |  | ||||||
| ^pybuilddir.txt |  | ||||||
| 
 |  | ||||||
| syntax: glob |  | ||||||
| libpython*.a |  | ||||||
| libpython*.so* |  | ||||||
| libpython*.dylib |  | ||||||
| *.swp |  | ||||||
| *.o |  | ||||||
| *.pyc |  | ||||||
| *.pyo |  | ||||||
| *.pyd |  | ||||||
| *.cover |  | ||||||
| *~ |  | ||||||
| *.gc?? |  | ||||||
| *.profclang? |  | ||||||
| *.profraw |  | ||||||
| *.dyn |  | ||||||
| Include/pydtrace_probes.h |  | ||||||
| Lib/distutils/command/*.pdb |  | ||||||
| Lib/lib2to3/*.pickle |  | ||||||
| Lib/test/data/* |  | ||||||
| Misc/*.wpu |  | ||||||
| PC/python_nt*.h |  | ||||||
| PC/pythonnt_rc*.h |  | ||||||
| PC/*/*.exe |  | ||||||
| PC/*/*.exp |  | ||||||
| PC/*/*.lib |  | ||||||
| PC/*/*.bsc |  | ||||||
| PC/*/*.dll |  | ||||||
| PC/*/*.pdb |  | ||||||
| PC/*/*.user |  | ||||||
| PC/*/*.ncb |  | ||||||
| PC/*/*.suo |  | ||||||
| PC/*/Win32-temp-* |  | ||||||
| PC/*/x64-temp-* |  | ||||||
| PC/*/amd64 |  | ||||||
| PCbuild/*.user |  | ||||||
| PCbuild/*.suo |  | ||||||
| PCbuild/*.*sdf |  | ||||||
| PCbuild/*-pgi |  | ||||||
| PCbuild/*-pgo |  | ||||||
| PCbuild/.vs |  | ||||||
| PCbuild/amd64 |  | ||||||
| PCbuild/obj |  | ||||||
| PCbuild/win32 |  | ||||||
| Tools/unicode/build/ |  | ||||||
| Tools/unicode/MAPPINGS/ |  | ||||||
| BuildLog.htm |  | ||||||
| __pycache__ |  | ||||||
| Programs/_freeze_importlib |  | ||||||
| Programs/_testembed |  | ||||||
| .coverage |  | ||||||
| coverage/ |  | ||||||
| externals/ |  | ||||||
| htmlcov/ |  | ||||||
| *.gcda |  | ||||||
| *.gcno |  | ||||||
| *.gcov |  | ||||||
| ipch/ |  | ||||||
| coverage.info |  | ||||||
| Tools/msi/obj |  | ||||||
| Tools/ssl/amd64 |  | ||||||
| Tools/ssl/win32 |  | ||||||
| .vs/ |  | ||||||
| .vscode/ |  | ||||||
							
								
								
									
										135
									
								
								third_party/python/.travis.yml
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										135
									
								
								third_party/python/.travis.yml
									
										
									
									
										vendored
									
									
								
							|  | @ -1,135 +0,0 @@ | ||||||
| language: c |  | ||||||
| dist: xenial |  | ||||||
| 
 |  | ||||||
| # To cache doc-building dependencies and C compiler output. |  | ||||||
| cache: |  | ||||||
|   - pip |  | ||||||
|   - ccache |  | ||||||
| 
 |  | ||||||
| env: |  | ||||||
|   global: |  | ||||||
|     # Use -O3 because we don't use debugger on Travis-CI |  | ||||||
|     - CFLAGS="-O3" |  | ||||||
| 
 |  | ||||||
| branches: |  | ||||||
|   only: |  | ||||||
|     - master |  | ||||||
|     - /^\d\.\d$/ |  | ||||||
|     - buildbot-custom |  | ||||||
| 
 |  | ||||||
| matrix: |  | ||||||
|   fast_finish: true |  | ||||||
|   allow_failures: |  | ||||||
|     - env: OPTIONAL=true |  | ||||||
|   include: |  | ||||||
|     - os: linux |  | ||||||
|       language: c |  | ||||||
|       compiler: clang |  | ||||||
|       # gcc also works, but to keep the # of concurrent builds down, we use one C |  | ||||||
|       # compiler here and the other to run the coverage build. Clang is preferred |  | ||||||
|       # in this instance for its better error messages. |  | ||||||
|       env: TESTING=cpython |  | ||||||
|       addons: |  | ||||||
|         apt: |  | ||||||
|           packages: |  | ||||||
|             - xvfb |  | ||||||
|     - os: linux |  | ||||||
|       language: python |  | ||||||
|       python: 3.6 |  | ||||||
|       env: TESTING=docs |  | ||||||
|       before_script: |  | ||||||
|         - cd Doc |  | ||||||
|         # Sphinx is pinned so that new versions that introduce new warnings won't suddenly cause build failures. |  | ||||||
|         # (Updating the version is fine as long as no warnings are raised by doing so.) |  | ||||||
|         - python -m pip install sphinx==1.8.2 blurb |  | ||||||
|       script: |  | ||||||
|         - make check suspicious html SPHINXOPTS="-q -W -j4" |  | ||||||
|     - os: linux |  | ||||||
|       language: c |  | ||||||
|       compiler: gcc |  | ||||||
|       env: OPTIONAL=true |  | ||||||
|       addons: |  | ||||||
|         apt: |  | ||||||
|           packages: |  | ||||||
|             - xvfb |  | ||||||
|       before_script: |  | ||||||
|         - ./configure PYTHON_FOR_REGEN=python3 |  | ||||||
|         - make -s -j4 |  | ||||||
|         # Need a venv that can parse covered code. |  | ||||||
|         - ./python -m venv venv |  | ||||||
|         - ./venv/bin/python -m pip install -U coverage |  | ||||||
|         - ./venv/bin/python -m test.pythoninfo |  | ||||||
|       script: |  | ||||||
|         # Skip tests that re-run the entire test suite. |  | ||||||
|         - xvfb-run ./venv/bin/python -m coverage run --pylib -m test -uall,-cpu -x test_multiprocessing_fork -x test_multiprocessing_forkserver -x test_multiprocessing_spawn |  | ||||||
|       after_script:  # Probably should be after_success once test suite updated to run under coverage.py. |  | ||||||
|         # Make the `coverage` command available to Codecov w/ a version of Python that can parse all source files. |  | ||||||
|         - source ./venv/bin/activate |  | ||||||
|         - bash <(curl -s https://codecov.io/bash) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| before_install: |  | ||||||
|   - set -e |  | ||||||
|   - | |  | ||||||
|       # Check short-circuit conditions |  | ||||||
|       if [ "${TESTING}" != "docs" ] |  | ||||||
|       then |  | ||||||
|         if [ "$TRAVIS_PULL_REQUEST" = "false" ] |  | ||||||
|         then |  | ||||||
|           echo "Not a PR, doing full build." |  | ||||||
|         else |  | ||||||
|           # Pull requests are slightly complicated because $TRAVIS_COMMIT_RANGE |  | ||||||
|           # may include more changes than desired if the history is convoluted. |  | ||||||
|           # Instead, explicitly fetch the base branch and compare against the |  | ||||||
|           # merge-base commit. |  | ||||||
|           git fetch -q origin +refs/heads/$TRAVIS_BRANCH |  | ||||||
|           changes=$(git diff --name-only HEAD $(git merge-base HEAD FETCH_HEAD)) |  | ||||||
|           echo "Files changed:" |  | ||||||
|           echo "$changes" |  | ||||||
|           if ! echo "$changes" | grep -qvE '(\.rst$)|(^Doc)|(^Misc)' |  | ||||||
|           then |  | ||||||
|             echo "Only docs were updated, stopping build process." |  | ||||||
|             exit |  | ||||||
|           fi |  | ||||||
|         fi |  | ||||||
|       fi |  | ||||||
| 
 |  | ||||||
| # Travis provides only 2 cores, so don't overdo the parallelism and waste memory. |  | ||||||
| before_script: |  | ||||||
|   - ./configure --with-pydebug PYTHON_FOR_REGEN=python3 |  | ||||||
|   - make -j4 regen-all |  | ||||||
|   - changes=`git status --porcelain` |  | ||||||
|   - | |  | ||||||
|       # Check for changes in regenerated files |  | ||||||
|       if ! test -z "$changes" |  | ||||||
|       then |  | ||||||
|         echo "Generated files not up to date" |  | ||||||
|         echo "$changes" |  | ||||||
|         exit 1 |  | ||||||
|       fi |  | ||||||
|   - make -j4 |  | ||||||
|   - make pythoninfo |  | ||||||
| 
 |  | ||||||
| script: |  | ||||||
|   # Using the built Python as patchcheck.py is built around the idea of using |  | ||||||
|   # a checkout-build of CPython to know things like what base branch the changes |  | ||||||
|   # should be compared against. |  | ||||||
|   # Only run on Linux as the check only needs to be run once. |  | ||||||
|   - if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then ./python Tools/scripts/patchcheck.py --travis $TRAVIS_PULL_REQUEST; fi |  | ||||||
|   # Check that all symbols exported by libpython start with "Py" or "_Py" |  | ||||||
|   - make smelly |  | ||||||
|   # `-r -w` implicitly provided through `make buildbottest`. |  | ||||||
|   - if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then XVFB_RUN=xvfb-run; fi; $XVFB_RUN make buildbottest TESTOPTS="-j4 -uall,-cpu" |  | ||||||
| 
 |  | ||||||
| notifications: |  | ||||||
|   email: false |  | ||||||
|   irc: |  | ||||||
|     channels: |  | ||||||
|       # This is set to a secure variable to prevent forks from notifying the |  | ||||||
|       # IRC channel whenever they fail a build. This can be removed when travis |  | ||||||
|       # implements https://github.com/travis-ci/travis-ci/issues/1094. |  | ||||||
|       # The actual value here is: irc.freenode.net#python-dev |  | ||||||
|       - secure: "s7kAkpcom2yUJ8XqyjFI0obJmhAGrn1xmoivdaPdgBIA++X47TBp1x4pgDsbEsoalef7bEwa4l07KdT4qa+DOd/c4QxaWom7fbN3BuLVsZuVfODnl79+gYq/TAbGfyH+yDs18DXrUfPgwD7C5aW32ugsqAOd4iWzfGJQ5OrOZzqzGjYdYQUEkJFXgxDEIb4aHvxNDWGO3Po9uKISrhb5saQ0l776yLo1Ur7M4oxl8RTbCdgX0vf5TzPg52BgvZpOgt3DHOUYPeiJLKNjAE6ibg0U95sEvMfHX77nz4aFY4/3UI6FFaRla34rZ+mYKrn0TdxOhera1QOgPmM6HzdO4K44FpfK1DS0Xxk9U9/uApq+cG0bU3W+cVUHDBe5+90lpRBAXHeHCgT7TI8gec614aiT8lEr3+yH8OBRYGzkjNK8E2LJZ/SxnVxDe7aLF6AWcoWLfS6/ziAIBFQ5Nc4U72CT8fGVSkl8ywPiRlvixKdvTODMSZo0jMqlfZSNaAPTsNRx4wu5Uis4qekwe32Fz4aB6KGpsuuVjBi+H6v0RKxNJNGY3JKDiEH2TK0UE2auJ5GvLW48aUVFcQMB7euCWYXlSWVRHh3WLU8QXF29Dw4JduRZqUpOdRgMHU79UHRq+mkE0jAS/nBcS6CvsmxCpTSrfVYuMOu32yt18QQoTyU=" |  | ||||||
|     on_success: change |  | ||||||
|     on_failure: always |  | ||||||
|     skip_join: true |  | ||||||
							
								
								
									
										138
									
								
								third_party/python/Doc/README.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										138
									
								
								third_party/python/Doc/README.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,138 +0,0 @@ | ||||||
| Python Documentation README |  | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~ |  | ||||||
| 
 |  | ||||||
| This directory contains the reStructuredText (reST) sources to the Python |  | ||||||
| documentation.  You don't need to build them yourself, `prebuilt versions are |  | ||||||
| available <https://docs.python.org/dev/download.html>`_. |  | ||||||
| 
 |  | ||||||
| Documentation on authoring Python documentation, including information about |  | ||||||
| both style and markup, is available in the "`Documenting Python |  | ||||||
| <https://devguide.python.org/documenting/>`_" chapter of the |  | ||||||
| developers guide. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Building the docs |  | ||||||
| ================= |  | ||||||
| 
 |  | ||||||
| The documentation is built with several tools which are not included in this |  | ||||||
| tree but are maintained separately and are available from |  | ||||||
| `PyPI <https://pypi.org/>`_. |  | ||||||
| 
 |  | ||||||
| * `Sphinx <https://pypi.org/project/Sphinx/>`_ |  | ||||||
| * `blurb <https://pypi.org/project/blurb/>`_ |  | ||||||
| 
 |  | ||||||
| The easiest way to install these tools is to create a virtual environment and |  | ||||||
| install the tools into there. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Using make |  | ||||||
| ---------- |  | ||||||
| 
 |  | ||||||
| To get started on UNIX, you can create a virtual environment with the command :: |  | ||||||
| 
 |  | ||||||
|   make venv |  | ||||||
| 
 |  | ||||||
| That will install all the tools necessary to build the documentation. Assuming |  | ||||||
| the virtual environment was created in the ``venv`` directory (the default; |  | ||||||
| configurable with the VENVDIR variable), you can run the following command to |  | ||||||
| build the HTML output files:: |  | ||||||
| 
 |  | ||||||
|   make html |  | ||||||
| 
 |  | ||||||
| By default, if the virtual environment is not created, the Makefile will |  | ||||||
| look for instances of sphinxbuild and blurb installed on your process PATH |  | ||||||
| (configurable with the SPHINXBUILD and BLURB variables). |  | ||||||
| 
 |  | ||||||
| On Windows, we try to emulate the Makefile as closely as possible with a |  | ||||||
| ``make.bat`` file. If you need to specify the Python interpreter to use, |  | ||||||
| set the PYTHON environment variable instead. |  | ||||||
| 
 |  | ||||||
| Available make targets are: |  | ||||||
| 
 |  | ||||||
| * "clean", which removes all build files. |  | ||||||
| 
 |  | ||||||
| * "venv", which creates a virtual environment with all necessary tools |  | ||||||
|   installed. |  | ||||||
| 
 |  | ||||||
| * "html", which builds standalone HTML files for offline viewing. |  | ||||||
| 
 |  | ||||||
| * "htmlview", which re-uses the "html" builder, but then opens the main page |  | ||||||
|   in your default web browser. |  | ||||||
| 
 |  | ||||||
| * "htmlhelp", which builds HTML files and a HTML Help project file usable to |  | ||||||
|   convert them into a single Compiled HTML (.chm) file -- these are popular |  | ||||||
|   under Microsoft Windows, but very handy on every platform. |  | ||||||
| 
 |  | ||||||
|   To create the CHM file, you need to run the Microsoft HTML Help Workshop |  | ||||||
|   over the generated project (.hhp) file.  The make.bat script does this for |  | ||||||
|   you on Windows. |  | ||||||
| 
 |  | ||||||
| * "latex", which builds LaTeX source files as input to "pdflatex" to produce |  | ||||||
|   PDF documents. |  | ||||||
| 
 |  | ||||||
| * "text", which builds a plain text file for each source file. |  | ||||||
| 
 |  | ||||||
| * "epub", which builds an EPUB document, suitable to be viewed on e-book |  | ||||||
|   readers. |  | ||||||
| 
 |  | ||||||
| * "linkcheck", which checks all external references to see whether they are |  | ||||||
|   broken, redirected or malformed, and outputs this information to stdout as |  | ||||||
|   well as a plain-text (.txt) file. |  | ||||||
| 
 |  | ||||||
| * "changes", which builds an overview over all versionadded/versionchanged/ |  | ||||||
|   deprecated items in the current version. This is meant as a help for the |  | ||||||
|   writer of the "What's New" document. |  | ||||||
| 
 |  | ||||||
| * "coverage", which builds a coverage overview for standard library modules and |  | ||||||
|   C API. |  | ||||||
| 
 |  | ||||||
| * "pydoc-topics", which builds a Python module containing a dictionary with |  | ||||||
|   plain text documentation for the labels defined in |  | ||||||
|   `tools/pyspecific.py` -- pydoc needs these to show topic and keyword help. |  | ||||||
| 
 |  | ||||||
| * "suspicious", which checks the parsed markup for text that looks like |  | ||||||
|   malformed and thus unconverted reST. |  | ||||||
| 
 |  | ||||||
| * "check", which checks for frequent markup errors. |  | ||||||
| 
 |  | ||||||
| * "serve", which serves the build/html directory on port 8000. |  | ||||||
| 
 |  | ||||||
| * "dist", (Unix only) which creates distributable archives of HTML, text, |  | ||||||
|   PDF, and EPUB builds. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Without make |  | ||||||
| ------------ |  | ||||||
| 
 |  | ||||||
| First, install the tool dependencies from PyPI. |  | ||||||
| 
 |  | ||||||
| Then, from the ``Doc`` directory, run :: |  | ||||||
| 
 |  | ||||||
|    sphinx-build -b<builder> . build/<builder> |  | ||||||
| 
 |  | ||||||
| where ``<builder>`` is one of html, text, latex, or htmlhelp (for explanations |  | ||||||
| see the make targets above). |  | ||||||
| 
 |  | ||||||
| Deprecation header |  | ||||||
| ================== |  | ||||||
| 
 |  | ||||||
| You can define the ``outdated`` variable in ``html_context`` to show a |  | ||||||
| red banner on each page redirecting to the "latest" version. |  | ||||||
| 
 |  | ||||||
| The link points to the same page on ``/3/``, sadly for the moment the |  | ||||||
| language is lost during the process. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Contributing |  | ||||||
| ============ |  | ||||||
| 
 |  | ||||||
| Bugs in the content should be reported to the |  | ||||||
| `Python bug tracker <https://bugs.python.org>`_. |  | ||||||
| 
 |  | ||||||
| Bugs in the toolset should be reported to the tools themselves. |  | ||||||
| 
 |  | ||||||
| You can also send a mail to the Python Documentation Team at docs@python.org, |  | ||||||
| and we will process your request as soon as possible. |  | ||||||
| 
 |  | ||||||
| If you want to help the Documentation Team, you are always welcome.  Just send |  | ||||||
| a mail to docs@python.org. |  | ||||||
							
								
								
									
										39
									
								
								third_party/python/Doc/about.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										39
									
								
								third_party/python/Doc/about.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,39 +0,0 @@ | ||||||
| ===================== |  | ||||||
| About these documents |  | ||||||
| ===================== |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| These documents are generated from `reStructuredText`_ sources by `Sphinx`_, a |  | ||||||
| document processor specifically written for the Python documentation. |  | ||||||
| 
 |  | ||||||
| .. _reStructuredText: http://docutils.sourceforge.net/rst.html |  | ||||||
| .. _Sphinx: http://sphinx-doc.org/ |  | ||||||
| 
 |  | ||||||
| .. In the online version of these documents, you can submit comments and suggest |  | ||||||
|    changes directly on the documentation pages. |  | ||||||
| 
 |  | ||||||
| Development of the documentation and its toolchain is an entirely volunteer |  | ||||||
| effort, just like Python itself.  If you want to contribute, please take a |  | ||||||
| look at the :ref:`reporting-bugs` page for information on how to do so.  New |  | ||||||
| volunteers are always welcome! |  | ||||||
| 
 |  | ||||||
| Many thanks go to: |  | ||||||
| 
 |  | ||||||
| * Fred L. Drake, Jr., the creator of the original Python documentation toolset |  | ||||||
|   and writer of much of the content; |  | ||||||
| * the `Docutils <http://docutils.sourceforge.net/>`_ project for creating |  | ||||||
|   reStructuredText and the Docutils suite; |  | ||||||
| * Fredrik Lundh for his `Alternative Python Reference |  | ||||||
|   <http://effbot.org/zone/pyref.htm>`_ project from which Sphinx got many good |  | ||||||
|   ideas. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Contributors to the Python Documentation |  | ||||||
| ---------------------------------------- |  | ||||||
| 
 |  | ||||||
| Many people have contributed to the Python language, the Python standard |  | ||||||
| library, and the Python documentation.  See :source:`Misc/ACKS` in the Python |  | ||||||
| source distribution for a partial list of contributors. |  | ||||||
| 
 |  | ||||||
| It is only with the input and contributions of the Python community |  | ||||||
| that Python has such wonderful documentation -- Thank You! |  | ||||||
							
								
								
									
										92
									
								
								third_party/python/Doc/bugs.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										92
									
								
								third_party/python/Doc/bugs.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,92 +0,0 @@ | ||||||
| .. _reporting-bugs: |  | ||||||
| 
 |  | ||||||
| ***************** |  | ||||||
| Dealing with Bugs |  | ||||||
| ***************** |  | ||||||
| 
 |  | ||||||
| Python is a mature programming language which has established a reputation for |  | ||||||
| stability.  In order to maintain this reputation, the developers would like to |  | ||||||
| know of any deficiencies you find in Python. |  | ||||||
| 
 |  | ||||||
| It can be sometimes faster to fix bugs yourself and contribute patches to |  | ||||||
| Python as it streamlines the process and involves less people. Learn how to |  | ||||||
| :ref:`contribute <contributing-to-python>`. |  | ||||||
| 
 |  | ||||||
| Documentation bugs |  | ||||||
| ================== |  | ||||||
| 
 |  | ||||||
| If you find a bug in this documentation or would like to propose an improvement, |  | ||||||
| please submit a bug report on the :ref:`tracker <using-the-tracker>`.  If you |  | ||||||
| have a suggestion how to fix it, include that as well. |  | ||||||
| 
 |  | ||||||
| If you're short on time, you can also email documentation bug reports to |  | ||||||
| docs@python.org (behavioral bugs can be sent to python-list@python.org). |  | ||||||
| 'docs@' is a mailing list run by volunteers; your request will be noticed, |  | ||||||
| though it may take a while to be processed. |  | ||||||
| 
 |  | ||||||
| .. seealso:: |  | ||||||
|    `Documentation bugs`_ on the Python issue tracker |  | ||||||
| 
 |  | ||||||
| .. _using-the-tracker: |  | ||||||
| 
 |  | ||||||
| Using the Python issue tracker |  | ||||||
| ============================== |  | ||||||
| 
 |  | ||||||
| Bug reports for Python itself should be submitted via the Python Bug Tracker |  | ||||||
| (https://bugs.python.org/).  The bug tracker offers a Web form which allows |  | ||||||
| pertinent information to be entered and submitted to the developers. |  | ||||||
| 
 |  | ||||||
| The first step in filing a report is to determine whether the problem has |  | ||||||
| already been reported.  The advantage in doing so, aside from saving the |  | ||||||
| developers time, is that you learn what has been done to fix it; it may be that |  | ||||||
| the problem has already been fixed for the next release, or additional |  | ||||||
| information is needed (in which case you are welcome to provide it if you can!). |  | ||||||
| To do this, search the bug database using the search box on the top of the page. |  | ||||||
| 
 |  | ||||||
| If the problem you're reporting is not already in the bug tracker, go back to |  | ||||||
| the Python Bug Tracker and log in.  If you don't already have a tracker account, |  | ||||||
| select the "Register" link or, if you use OpenID, one of the OpenID provider |  | ||||||
| logos in the sidebar.  It is not possible to submit a bug report anonymously. |  | ||||||
| 
 |  | ||||||
| Being now logged in, you can submit a bug.  Select the "Create New" link in the |  | ||||||
| sidebar to open the bug reporting form. |  | ||||||
| 
 |  | ||||||
| The submission form has a number of fields.  For the "Title" field, enter a |  | ||||||
| *very* short description of the problem; less than ten words is good.  In the |  | ||||||
| "Type" field, select the type of your problem; also select the "Component" and |  | ||||||
| "Versions" to which the bug relates. |  | ||||||
| 
 |  | ||||||
| In the "Comment" field, describe the problem in detail, including what you |  | ||||||
| expected to happen and what did happen.  Be sure to include whether any |  | ||||||
| extension modules were involved, and what hardware and software platform you |  | ||||||
| were using (including version information as appropriate). |  | ||||||
| 
 |  | ||||||
| Each bug report will be assigned to a developer who will determine what needs to |  | ||||||
| be done to correct the problem.  You will receive an update each time action is |  | ||||||
| taken on the bug. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. seealso:: |  | ||||||
| 
 |  | ||||||
|    `How to Report Bugs Effectively <http://www.chiark.greenend.org.uk/~sgtatham/bugs.html>`_ |  | ||||||
|       Article which goes into some detail about how to create a useful bug report. |  | ||||||
|       This describes what kind of information is useful and why it is useful. |  | ||||||
| 
 |  | ||||||
|    `Bug Writing Guidelines <https://developer.mozilla.org/en-US/docs/Mozilla/QA/Bug_writing_guidelines>`_ |  | ||||||
|       Information about writing a good bug report.  Some of this is specific to the |  | ||||||
|       Mozilla project, but describes general good practices. |  | ||||||
| 
 |  | ||||||
| .. _contributing-to-python: |  | ||||||
| 
 |  | ||||||
| Getting started contributing to Python yourself |  | ||||||
| =============================================== |  | ||||||
| 
 |  | ||||||
| Beyond just reporting bugs that you find, you are also welcome to submit |  | ||||||
| patches to fix them.  You can find more information on how to get started |  | ||||||
| patching Python in the `Python Developer's Guide`_.  If you have questions, |  | ||||||
| the `core-mentorship mailing list`_ is a friendly place to get answers to |  | ||||||
| any and all questions pertaining to the process of fixing issues in Python. |  | ||||||
| 
 |  | ||||||
| .. _Documentation bugs: https://bugs.python.org/issue?@filter=status&@filter=components&components=4&status=1&@columns=id,activity,title,status&@sort=-activity |  | ||||||
| .. _Python Developer's Guide: https://devguide.python.org/ |  | ||||||
| .. _core-mentorship mailing list: https://mail.python.org/mailman/listinfo/core-mentorship/ |  | ||||||
							
								
								
									
										26
									
								
								third_party/python/Doc/c-api/abstract.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										26
									
								
								third_party/python/Doc/c-api/abstract.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,26 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _abstract: |  | ||||||
| 
 |  | ||||||
| ********************** |  | ||||||
| Abstract Objects Layer |  | ||||||
| ********************** |  | ||||||
| 
 |  | ||||||
| The functions in this chapter interact with Python objects regardless of their |  | ||||||
| type, or with wide classes of object types (e.g. all numerical types, or all |  | ||||||
| sequence types).  When used on object types for which they do not apply, they |  | ||||||
| will raise a Python exception. |  | ||||||
| 
 |  | ||||||
| It is not possible to use these functions on objects that are not properly |  | ||||||
| initialized, such as a list object that has been created by :c:func:`PyList_New`, |  | ||||||
| but whose items have not been set to some non-\ ``NULL`` value yet. |  | ||||||
| 
 |  | ||||||
| .. toctree:: |  | ||||||
| 
 |  | ||||||
|    object.rst |  | ||||||
|    number.rst |  | ||||||
|    sequence.rst |  | ||||||
|    mapping.rst |  | ||||||
|    iter.rst |  | ||||||
|    buffer.rst |  | ||||||
|    objbuffer.rst |  | ||||||
							
								
								
									
										71
									
								
								third_party/python/Doc/c-api/allocation.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										71
									
								
								third_party/python/Doc/c-api/allocation.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,71 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _allocating-objects: |  | ||||||
| 
 |  | ||||||
| Allocating Objects on the Heap |  | ||||||
| ============================== |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* _PyObject_New(PyTypeObject *type) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyVarObject* _PyObject_NewVar(PyTypeObject *type, Py_ssize_t size) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_Init(PyObject *op, PyTypeObject *type) |  | ||||||
| 
 |  | ||||||
|    Initialize a newly-allocated object *op* with its type and initial |  | ||||||
|    reference.  Returns the initialized object.  If *type* indicates that the |  | ||||||
|    object participates in the cyclic garbage detector, it is added to the |  | ||||||
|    detector's set of observed objects. Other fields of the object are not |  | ||||||
|    affected. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyVarObject* PyObject_InitVar(PyVarObject *op, PyTypeObject *type, Py_ssize_t size) |  | ||||||
| 
 |  | ||||||
|    This does everything :c:func:`PyObject_Init` does, and also initializes the |  | ||||||
|    length information for a variable-size object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: TYPE* PyObject_New(TYPE, PyTypeObject *type) |  | ||||||
| 
 |  | ||||||
|    Allocate a new Python object using the C structure type *TYPE* and the |  | ||||||
|    Python type object *type*.  Fields not defined by the Python object header |  | ||||||
|    are not initialized; the object's reference count will be one.  The size of |  | ||||||
|    the memory allocation is determined from the :c:member:`~PyTypeObject.tp_basicsize` field of |  | ||||||
|    the type object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: TYPE* PyObject_NewVar(TYPE, PyTypeObject *type, Py_ssize_t size) |  | ||||||
| 
 |  | ||||||
|    Allocate a new Python object using the C structure type *TYPE* and the |  | ||||||
|    Python type object *type*.  Fields not defined by the Python object header |  | ||||||
|    are not initialized.  The allocated memory allows for the *TYPE* structure |  | ||||||
|    plus *size* fields of the size given by the :c:member:`~PyTypeObject.tp_itemsize` field of |  | ||||||
|    *type*.  This is useful for implementing objects like tuples, which are |  | ||||||
|    able to determine their size at construction time.  Embedding the array of |  | ||||||
|    fields into the same allocation decreases the number of allocations, |  | ||||||
|    improving the memory management efficiency. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyObject_Del(PyObject *op) |  | ||||||
| 
 |  | ||||||
|    Releases memory allocated to an object using :c:func:`PyObject_New` or |  | ||||||
|    :c:func:`PyObject_NewVar`.  This is normally called from the |  | ||||||
|    :c:member:`~PyTypeObject.tp_dealloc` handler specified in the object's type.  The fields of |  | ||||||
|    the object should not be accessed after this call as the memory is no |  | ||||||
|    longer a valid Python object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyObject _Py_NoneStruct |  | ||||||
| 
 |  | ||||||
|    Object which is visible in Python as ``None``.  This should only be accessed |  | ||||||
|    using the :c:macro:`Py_None` macro, which evaluates to a pointer to this |  | ||||||
|    object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. seealso:: |  | ||||||
| 
 |  | ||||||
|    :c:func:`PyModule_Create` |  | ||||||
|       To allocate and create extension modules. |  | ||||||
| 
 |  | ||||||
							
								
								
									
										39
									
								
								third_party/python/Doc/c-api/apiabiversion.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										39
									
								
								third_party/python/Doc/c-api/apiabiversion.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,39 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _apiabiversion: |  | ||||||
| 
 |  | ||||||
| *********************** |  | ||||||
| API and ABI Versioning |  | ||||||
| *********************** |  | ||||||
| 
 |  | ||||||
| ``PY_VERSION_HEX`` is the Python version number encoded in a single integer. |  | ||||||
| 
 |  | ||||||
| For example if the ``PY_VERSION_HEX`` is set to ``0x030401a2``, the underlying |  | ||||||
| version information can be found by treating it as a 32 bit number in |  | ||||||
| the following manner: |  | ||||||
| 
 |  | ||||||
|    +-------+-------------------------+------------------------------------------------+ |  | ||||||
|    | Bytes | Bits (big endian order) | Meaning                                        | |  | ||||||
|    +=======+=========================+================================================+ |  | ||||||
|    | ``1`` |       ``1-8``           |  ``PY_MAJOR_VERSION`` (the ``3`` in            | |  | ||||||
|    |       |                         |  ``3.4.1a2``)                                  | |  | ||||||
|    +-------+-------------------------+------------------------------------------------+ |  | ||||||
|    | ``2`` |       ``9-16``          |  ``PY_MINOR_VERSION`` (the ``4`` in            | |  | ||||||
|    |       |                         |  ``3.4.1a2``)                                  | |  | ||||||
|    +-------+-------------------------+------------------------------------------------+ |  | ||||||
|    | ``3`` |       ``17-24``         |  ``PY_MICRO_VERSION`` (the ``1`` in            | |  | ||||||
|    |       |                         |  ``3.4.1a2``)                                  | |  | ||||||
|    +-------+-------------------------+------------------------------------------------+ |  | ||||||
|    | ``4`` |       ``25-28``         |  ``PY_RELEASE_LEVEL`` (``0xA`` for alpha,      | |  | ||||||
|    |       |                         |  ``0xB`` for beta, ``0xC`` for release         | |  | ||||||
|    |       |                         |  candidate and ``0xF`` for final), in this     | |  | ||||||
|    |       |                         |  case it is alpha.                             | |  | ||||||
|    +-------+-------------------------+------------------------------------------------+ |  | ||||||
|    |       |       ``29-32``         |  ``PY_RELEASE_SERIAL`` (the ``2`` in           | |  | ||||||
|    |       |                         |  ``3.4.1a2``, zero for final releases)         | |  | ||||||
|    +-------+-------------------------+------------------------------------------------+ |  | ||||||
| 
 |  | ||||||
| Thus ``3.4.1a2`` is hexversion ``0x030401a2``. |  | ||||||
| 
 |  | ||||||
| All the given macros are defined in :source:`Include/patchlevel.h`. |  | ||||||
| 
 |  | ||||||
							
								
								
									
										676
									
								
								third_party/python/Doc/c-api/arg.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										676
									
								
								third_party/python/Doc/c-api/arg.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,676 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _arg-parsing: |  | ||||||
| 
 |  | ||||||
| Parsing arguments and building values |  | ||||||
| ===================================== |  | ||||||
| 
 |  | ||||||
| These functions are useful when creating your own extensions functions and |  | ||||||
| methods.  Additional information and examples are available in |  | ||||||
| :ref:`extending-index`. |  | ||||||
| 
 |  | ||||||
| The first three of these functions described, :c:func:`PyArg_ParseTuple`, |  | ||||||
| :c:func:`PyArg_ParseTupleAndKeywords`, and :c:func:`PyArg_Parse`, all use *format |  | ||||||
| strings* which are used to tell the function about the expected arguments.  The |  | ||||||
| format strings use the same syntax for each of these functions. |  | ||||||
| 
 |  | ||||||
| ----------------- |  | ||||||
| Parsing arguments |  | ||||||
| ----------------- |  | ||||||
| 
 |  | ||||||
| A format string consists of zero or more "format units."  A format unit |  | ||||||
| describes one Python object; it is usually a single character or a parenthesized |  | ||||||
| sequence of format units.  With a few exceptions, a format unit that is not a |  | ||||||
| parenthesized sequence normally corresponds to a single address argument to |  | ||||||
| these functions.  In the following description, the quoted form is the format |  | ||||||
| unit; the entry in (round) parentheses is the Python object type that matches |  | ||||||
| the format unit; and the entry in [square] brackets is the type of the C |  | ||||||
| variable(s) whose address should be passed. |  | ||||||
| 
 |  | ||||||
| Strings and buffers |  | ||||||
| ------------------- |  | ||||||
| 
 |  | ||||||
| These formats allow accessing an object as a contiguous chunk of memory. |  | ||||||
| You don't have to provide raw storage for the returned unicode or bytes |  | ||||||
| area. |  | ||||||
| 
 |  | ||||||
| In general, when a format sets a pointer to a buffer, the buffer is |  | ||||||
| managed by the corresponding Python object, and the buffer shares |  | ||||||
| the lifetime of this object.  You won't have to release any memory yourself. |  | ||||||
| The only exceptions are ``es``, ``es#``, ``et`` and ``et#``. |  | ||||||
| 
 |  | ||||||
| However, when a :c:type:`Py_buffer` structure gets filled, the underlying |  | ||||||
| buffer is locked so that the caller can subsequently use the buffer even |  | ||||||
| inside a :c:type:`Py_BEGIN_ALLOW_THREADS` block without the risk of mutable data |  | ||||||
| being resized or destroyed.  As a result, **you have to call** |  | ||||||
| :c:func:`PyBuffer_Release` after you have finished processing the data (or |  | ||||||
| in any early abort case). |  | ||||||
| 
 |  | ||||||
| Unless otherwise stated, buffers are not NUL-terminated. |  | ||||||
| 
 |  | ||||||
| Some formats require a read-only :term:`bytes-like object`, and set a |  | ||||||
| pointer instead of a buffer structure.  They work by checking that |  | ||||||
| the object's :c:member:`PyBufferProcs.bf_releasebuffer` field is *NULL*, |  | ||||||
| which disallows mutable objects such as :class:`bytearray`. |  | ||||||
| 
 |  | ||||||
| .. note:: |  | ||||||
| 
 |  | ||||||
|    For all ``#`` variants of formats (``s#``, ``y#``, etc.), the type of |  | ||||||
|    the length argument (int or :c:type:`Py_ssize_t`) is controlled by |  | ||||||
|    defining the macro :c:macro:`PY_SSIZE_T_CLEAN` before including |  | ||||||
|    :file:`Python.h`.  If the macro was defined, length is a |  | ||||||
|    :c:type:`Py_ssize_t` rather than an :c:type:`int`. This behavior will change |  | ||||||
|    in a future Python version to only support :c:type:`Py_ssize_t` and |  | ||||||
|    drop :c:type:`int` support. It is best to always define :c:macro:`PY_SSIZE_T_CLEAN`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| ``s`` (:class:`str`) [const char \*] |  | ||||||
|    Convert a Unicode object to a C pointer to a character string. |  | ||||||
|    A pointer to an existing string is stored in the character pointer |  | ||||||
|    variable whose address you pass.  The C string is NUL-terminated. |  | ||||||
|    The Python string must not contain embedded null code points; if it does, |  | ||||||
|    a :exc:`ValueError` exception is raised. Unicode objects are converted |  | ||||||
|    to C strings using ``'utf-8'`` encoding. If this conversion fails, a |  | ||||||
|    :exc:`UnicodeError` is raised. |  | ||||||
| 
 |  | ||||||
|    .. note:: |  | ||||||
|       This format does not accept :term:`bytes-like objects |  | ||||||
|       <bytes-like object>`.  If you want to accept |  | ||||||
|       filesystem paths and convert them to C character strings, it is |  | ||||||
|       preferable to use the ``O&`` format with :c:func:`PyUnicode_FSConverter` |  | ||||||
|       as *converter*. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.5 |  | ||||||
|       Previously, :exc:`TypeError` was raised when embedded null code points |  | ||||||
|       were encountered in the Python string. |  | ||||||
| 
 |  | ||||||
| ``s*`` (:class:`str` or :term:`bytes-like object`) [Py_buffer] |  | ||||||
|    This format accepts Unicode objects as well as bytes-like objects. |  | ||||||
|    It fills a :c:type:`Py_buffer` structure provided by the caller. |  | ||||||
|    In this case the resulting C string may contain embedded NUL bytes. |  | ||||||
|    Unicode objects are converted to C strings using ``'utf-8'`` encoding. |  | ||||||
| 
 |  | ||||||
| ``s#`` (:class:`str`, read-only :term:`bytes-like object`) [const char \*, int or :c:type:`Py_ssize_t`] |  | ||||||
|    Like ``s*``, except that it doesn't accept mutable objects. |  | ||||||
|    The result is stored into two C variables, |  | ||||||
|    the first one a pointer to a C string, the second one its length. |  | ||||||
|    The string may contain embedded null bytes. Unicode objects are converted |  | ||||||
|    to C strings using ``'utf-8'`` encoding. |  | ||||||
| 
 |  | ||||||
| ``z`` (:class:`str` or ``None``) [const char \*] |  | ||||||
|    Like ``s``, but the Python object may also be ``None``, in which case the C |  | ||||||
|    pointer is set to *NULL*. |  | ||||||
| 
 |  | ||||||
| ``z*`` (:class:`str`, :term:`bytes-like object` or ``None``) [Py_buffer] |  | ||||||
|    Like ``s*``, but the Python object may also be ``None``, in which case the |  | ||||||
|    ``buf`` member of the :c:type:`Py_buffer` structure is set to *NULL*. |  | ||||||
| 
 |  | ||||||
| ``z#`` (:class:`str`, read-only :term:`bytes-like object` or ``None``) [const char \*, int] |  | ||||||
|    Like ``s#``, but the Python object may also be ``None``, in which case the C |  | ||||||
|    pointer is set to *NULL*. |  | ||||||
| 
 |  | ||||||
| ``y`` (read-only :term:`bytes-like object`) [const char \*] |  | ||||||
|    This format converts a bytes-like object to a C pointer to a character |  | ||||||
|    string; it does not accept Unicode objects.  The bytes buffer must not |  | ||||||
|    contain embedded null bytes; if it does, a :exc:`ValueError` |  | ||||||
|    exception is raised. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.5 |  | ||||||
|       Previously, :exc:`TypeError` was raised when embedded null bytes were |  | ||||||
|       encountered in the bytes buffer. |  | ||||||
| 
 |  | ||||||
| ``y*`` (:term:`bytes-like object`) [Py_buffer] |  | ||||||
|    This variant on ``s*`` doesn't accept Unicode objects, only |  | ||||||
|    bytes-like objects.  **This is the recommended way to accept |  | ||||||
|    binary data.** |  | ||||||
| 
 |  | ||||||
| ``y#`` (read-only :term:`bytes-like object`) [const char \*, int] |  | ||||||
|    This variant on ``s#`` doesn't accept Unicode objects, only bytes-like |  | ||||||
|    objects. |  | ||||||
| 
 |  | ||||||
| ``S`` (:class:`bytes`) [PyBytesObject \*] |  | ||||||
|    Requires that the Python object is a :class:`bytes` object, without |  | ||||||
|    attempting any conversion.  Raises :exc:`TypeError` if the object is not |  | ||||||
|    a bytes object.  The C variable may also be declared as :c:type:`PyObject\*`. |  | ||||||
| 
 |  | ||||||
| ``Y`` (:class:`bytearray`) [PyByteArrayObject \*] |  | ||||||
|    Requires that the Python object is a :class:`bytearray` object, without |  | ||||||
|    attempting any conversion.  Raises :exc:`TypeError` if the object is not |  | ||||||
|    a :class:`bytearray` object. The C variable may also be declared as :c:type:`PyObject\*`. |  | ||||||
| 
 |  | ||||||
| ``u`` (:class:`str`) [Py_UNICODE \*] |  | ||||||
|    Convert a Python Unicode object to a C pointer to a NUL-terminated buffer of |  | ||||||
|    Unicode characters.  You must pass the address of a :c:type:`Py_UNICODE` |  | ||||||
|    pointer variable, which will be filled with the pointer to an existing |  | ||||||
|    Unicode buffer.  Please note that the width of a :c:type:`Py_UNICODE` |  | ||||||
|    character depends on compilation options (it is either 16 or 32 bits). |  | ||||||
|    The Python string must not contain embedded null code points; if it does, |  | ||||||
|    a :exc:`ValueError` exception is raised. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.5 |  | ||||||
|       Previously, :exc:`TypeError` was raised when embedded null code points |  | ||||||
|       were encountered in the Python string. |  | ||||||
| 
 |  | ||||||
|    .. deprecated-removed:: 3.3 4.0 |  | ||||||
|       Part of the old-style :c:type:`Py_UNICODE` API; please migrate to using |  | ||||||
|       :c:func:`PyUnicode_AsWideCharString`. |  | ||||||
| 
 |  | ||||||
| ``u#`` (:class:`str`) [Py_UNICODE \*, int] |  | ||||||
|    This variant on ``u`` stores into two C variables, the first one a pointer to a |  | ||||||
|    Unicode data buffer, the second one its length.  This variant allows |  | ||||||
|    null code points. |  | ||||||
| 
 |  | ||||||
|    .. deprecated-removed:: 3.3 4.0 |  | ||||||
|       Part of the old-style :c:type:`Py_UNICODE` API; please migrate to using |  | ||||||
|       :c:func:`PyUnicode_AsWideCharString`. |  | ||||||
| 
 |  | ||||||
| ``Z`` (:class:`str` or ``None``) [Py_UNICODE \*] |  | ||||||
|    Like ``u``, but the Python object may also be ``None``, in which case the |  | ||||||
|    :c:type:`Py_UNICODE` pointer is set to *NULL*. |  | ||||||
| 
 |  | ||||||
|    .. deprecated-removed:: 3.3 4.0 |  | ||||||
|       Part of the old-style :c:type:`Py_UNICODE` API; please migrate to using |  | ||||||
|       :c:func:`PyUnicode_AsWideCharString`. |  | ||||||
| 
 |  | ||||||
| ``Z#`` (:class:`str` or ``None``) [Py_UNICODE \*, int] |  | ||||||
|    Like ``u#``, but the Python object may also be ``None``, in which case the |  | ||||||
|    :c:type:`Py_UNICODE` pointer is set to *NULL*. |  | ||||||
| 
 |  | ||||||
|    .. deprecated-removed:: 3.3 4.0 |  | ||||||
|       Part of the old-style :c:type:`Py_UNICODE` API; please migrate to using |  | ||||||
|       :c:func:`PyUnicode_AsWideCharString`. |  | ||||||
| 
 |  | ||||||
| ``U`` (:class:`str`) [PyObject \*] |  | ||||||
|    Requires that the Python object is a Unicode object, without attempting |  | ||||||
|    any conversion.  Raises :exc:`TypeError` if the object is not a Unicode |  | ||||||
|    object.  The C variable may also be declared as :c:type:`PyObject\*`. |  | ||||||
| 
 |  | ||||||
| ``w*`` (read-write :term:`bytes-like object`) [Py_buffer] |  | ||||||
|    This format accepts any object which implements the read-write buffer |  | ||||||
|    interface. It fills a :c:type:`Py_buffer` structure provided by the caller. |  | ||||||
|    The buffer may contain embedded null bytes. The caller have to call |  | ||||||
|    :c:func:`PyBuffer_Release` when it is done with the buffer. |  | ||||||
| 
 |  | ||||||
| ``es`` (:class:`str`) [const char \*encoding, char \*\*buffer] |  | ||||||
|    This variant on ``s`` is used for encoding Unicode into a character buffer. |  | ||||||
|    It only works for encoded data without embedded NUL bytes. |  | ||||||
| 
 |  | ||||||
|    This format requires two arguments.  The first is only used as input, and |  | ||||||
|    must be a :c:type:`const char\*` which points to the name of an encoding as a |  | ||||||
|    NUL-terminated string, or *NULL*, in which case ``'utf-8'`` encoding is used. |  | ||||||
|    An exception is raised if the named encoding is not known to Python.  The |  | ||||||
|    second argument must be a :c:type:`char\*\*`; the value of the pointer it |  | ||||||
|    references will be set to a buffer with the contents of the argument text. |  | ||||||
|    The text will be encoded in the encoding specified by the first argument. |  | ||||||
| 
 |  | ||||||
|    :c:func:`PyArg_ParseTuple` will allocate a buffer of the needed size, copy the |  | ||||||
|    encoded data into this buffer and adjust *\*buffer* to reference the newly |  | ||||||
|    allocated storage.  The caller is responsible for calling :c:func:`PyMem_Free` to |  | ||||||
|    free the allocated buffer after use. |  | ||||||
| 
 |  | ||||||
| ``et`` (:class:`str`, :class:`bytes` or :class:`bytearray`) [const char \*encoding, char \*\*buffer] |  | ||||||
|    Same as ``es`` except that byte string objects are passed through without |  | ||||||
|    recoding them.  Instead, the implementation assumes that the byte string object uses |  | ||||||
|    the encoding passed in as parameter. |  | ||||||
| 
 |  | ||||||
| ``es#`` (:class:`str`) [const char \*encoding, char \*\*buffer, int \*buffer_length] |  | ||||||
|    This variant on ``s#`` is used for encoding Unicode into a character buffer. |  | ||||||
|    Unlike the ``es`` format, this variant allows input data which contains NUL |  | ||||||
|    characters. |  | ||||||
| 
 |  | ||||||
|    It requires three arguments.  The first is only used as input, and must be a |  | ||||||
|    :c:type:`const char\*` which points to the name of an encoding as a |  | ||||||
|    NUL-terminated string, or *NULL*, in which case ``'utf-8'`` encoding is used. |  | ||||||
|    An exception is raised if the named encoding is not known to Python.  The |  | ||||||
|    second argument must be a :c:type:`char\*\*`; the value of the pointer it |  | ||||||
|    references will be set to a buffer with the contents of the argument text. |  | ||||||
|    The text will be encoded in the encoding specified by the first argument. |  | ||||||
|    The third argument must be a pointer to an integer; the referenced integer |  | ||||||
|    will be set to the number of bytes in the output buffer. |  | ||||||
| 
 |  | ||||||
|    There are two modes of operation: |  | ||||||
| 
 |  | ||||||
|    If *\*buffer* points a *NULL* pointer, the function will allocate a buffer of |  | ||||||
|    the needed size, copy the encoded data into this buffer and set *\*buffer* to |  | ||||||
|    reference the newly allocated storage.  The caller is responsible for calling |  | ||||||
|    :c:func:`PyMem_Free` to free the allocated buffer after usage. |  | ||||||
| 
 |  | ||||||
|    If *\*buffer* points to a non-*NULL* pointer (an already allocated buffer), |  | ||||||
|    :c:func:`PyArg_ParseTuple` will use this location as the buffer and interpret the |  | ||||||
|    initial value of *\*buffer_length* as the buffer size.  It will then copy the |  | ||||||
|    encoded data into the buffer and NUL-terminate it.  If the buffer is not large |  | ||||||
|    enough, a :exc:`ValueError` will be set. |  | ||||||
| 
 |  | ||||||
|    In both cases, *\*buffer_length* is set to the length of the encoded data |  | ||||||
|    without the trailing NUL byte. |  | ||||||
| 
 |  | ||||||
| ``et#`` (:class:`str`, :class:`bytes` or :class:`bytearray`) [const char \*encoding, char \*\*buffer, int \*buffer_length] |  | ||||||
|    Same as ``es#`` except that byte string objects are passed through without recoding |  | ||||||
|    them. Instead, the implementation assumes that the byte string object uses the |  | ||||||
|    encoding passed in as parameter. |  | ||||||
| 
 |  | ||||||
| Numbers |  | ||||||
| ------- |  | ||||||
| 
 |  | ||||||
| ``b`` (:class:`int`) [unsigned char] |  | ||||||
|    Convert a nonnegative Python integer to an unsigned tiny int, stored in a C |  | ||||||
|    :c:type:`unsigned char`. |  | ||||||
| 
 |  | ||||||
| ``B`` (:class:`int`) [unsigned char] |  | ||||||
|    Convert a Python integer to a tiny int without overflow checking, stored in a C |  | ||||||
|    :c:type:`unsigned char`. |  | ||||||
| 
 |  | ||||||
| ``h`` (:class:`int`) [short int] |  | ||||||
|    Convert a Python integer to a C :c:type:`short int`. |  | ||||||
| 
 |  | ||||||
| ``H`` (:class:`int`) [unsigned short int] |  | ||||||
|    Convert a Python integer to a C :c:type:`unsigned short int`, without overflow |  | ||||||
|    checking. |  | ||||||
| 
 |  | ||||||
| ``i`` (:class:`int`) [int] |  | ||||||
|    Convert a Python integer to a plain C :c:type:`int`. |  | ||||||
| 
 |  | ||||||
| ``I`` (:class:`int`) [unsigned int] |  | ||||||
|    Convert a Python integer to a C :c:type:`unsigned int`, without overflow |  | ||||||
|    checking. |  | ||||||
| 
 |  | ||||||
| ``l`` (:class:`int`) [long int] |  | ||||||
|    Convert a Python integer to a C :c:type:`long int`. |  | ||||||
| 
 |  | ||||||
| ``k`` (:class:`int`) [unsigned long] |  | ||||||
|    Convert a Python integer to a C :c:type:`unsigned long` without |  | ||||||
|    overflow checking. |  | ||||||
| 
 |  | ||||||
| ``L`` (:class:`int`) [long long] |  | ||||||
|    Convert a Python integer to a C :c:type:`long long`. |  | ||||||
| 
 |  | ||||||
| ``K`` (:class:`int`) [unsigned long long] |  | ||||||
|    Convert a Python integer to a C :c:type:`unsigned long long` |  | ||||||
|    without overflow checking. |  | ||||||
| 
 |  | ||||||
| ``n`` (:class:`int`) [Py_ssize_t] |  | ||||||
|    Convert a Python integer to a C :c:type:`Py_ssize_t`. |  | ||||||
| 
 |  | ||||||
| ``c`` (:class:`bytes` or :class:`bytearray` of length 1) [char] |  | ||||||
|    Convert a Python byte, represented as a :class:`bytes` or |  | ||||||
|    :class:`bytearray` object of length 1, to a C :c:type:`char`. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.3 |  | ||||||
|       Allow :class:`bytearray` objects. |  | ||||||
| 
 |  | ||||||
| ``C`` (:class:`str` of length 1) [int] |  | ||||||
|    Convert a Python character, represented as a :class:`str` object of |  | ||||||
|    length 1, to a C :c:type:`int`. |  | ||||||
| 
 |  | ||||||
| ``f`` (:class:`float`) [float] |  | ||||||
|    Convert a Python floating point number to a C :c:type:`float`. |  | ||||||
| 
 |  | ||||||
| ``d`` (:class:`float`) [double] |  | ||||||
|    Convert a Python floating point number to a C :c:type:`double`. |  | ||||||
| 
 |  | ||||||
| ``D`` (:class:`complex`) [Py_complex] |  | ||||||
|    Convert a Python complex number to a C :c:type:`Py_complex` structure. |  | ||||||
| 
 |  | ||||||
| Other objects |  | ||||||
| ------------- |  | ||||||
| 
 |  | ||||||
| ``O`` (object) [PyObject \*] |  | ||||||
|    Store a Python object (without any conversion) in a C object pointer.  The C |  | ||||||
|    program thus receives the actual object that was passed.  The object's reference |  | ||||||
|    count is not increased.  The pointer stored is not *NULL*. |  | ||||||
| 
 |  | ||||||
| ``O!`` (object) [*typeobject*, PyObject \*] |  | ||||||
|    Store a Python object in a C object pointer.  This is similar to ``O``, but |  | ||||||
|    takes two C arguments: the first is the address of a Python type object, the |  | ||||||
|    second is the address of the C variable (of type :c:type:`PyObject\*`) into which |  | ||||||
|    the object pointer is stored.  If the Python object does not have the required |  | ||||||
|    type, :exc:`TypeError` is raised. |  | ||||||
| 
 |  | ||||||
| .. _o_ampersand: |  | ||||||
| 
 |  | ||||||
| ``O&`` (object) [*converter*, *anything*] |  | ||||||
|    Convert a Python object to a C variable through a *converter* function.  This |  | ||||||
|    takes two arguments: the first is a function, the second is the address of a C |  | ||||||
|    variable (of arbitrary type), converted to :c:type:`void \*`.  The *converter* |  | ||||||
|    function in turn is called as follows:: |  | ||||||
| 
 |  | ||||||
|       status = converter(object, address); |  | ||||||
| 
 |  | ||||||
|    where *object* is the Python object to be converted and *address* is the |  | ||||||
|    :c:type:`void\*` argument that was passed to the :c:func:`PyArg_Parse\*` function. |  | ||||||
|    The returned *status* should be ``1`` for a successful conversion and ``0`` if |  | ||||||
|    the conversion has failed.  When the conversion fails, the *converter* function |  | ||||||
|    should raise an exception and leave the content of *address* unmodified. |  | ||||||
| 
 |  | ||||||
|    If the *converter* returns ``Py_CLEANUP_SUPPORTED``, it may get called a |  | ||||||
|    second time if the argument parsing eventually fails, giving the converter a |  | ||||||
|    chance to release any memory that it had already allocated. In this second |  | ||||||
|    call, the *object* parameter will be NULL; *address* will have the same value |  | ||||||
|    as in the original call. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.1 |  | ||||||
|       ``Py_CLEANUP_SUPPORTED`` was added. |  | ||||||
| 
 |  | ||||||
| ``p`` (:class:`bool`) [int] |  | ||||||
|    Tests the value passed in for truth (a boolean **p**\ redicate) and converts |  | ||||||
|    the result to its equivalent C true/false integer value. |  | ||||||
|    Sets the int to ``1`` if the expression was true and ``0`` if it was false. |  | ||||||
|    This accepts any valid Python value.  See :ref:`truth` for more |  | ||||||
|    information about how Python tests values for truth. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
| ``(items)`` (:class:`tuple`) [*matching-items*] |  | ||||||
|    The object must be a Python sequence whose length is the number of format units |  | ||||||
|    in *items*.  The C arguments must correspond to the individual format units in |  | ||||||
|    *items*.  Format units for sequences may be nested. |  | ||||||
| 
 |  | ||||||
| It is possible to pass "long" integers (integers whose value exceeds the |  | ||||||
| platform's :const:`LONG_MAX`) however no proper range checking is done --- the |  | ||||||
| most significant bits are silently truncated when the receiving field is too |  | ||||||
| small to receive the value (actually, the semantics are inherited from downcasts |  | ||||||
| in C --- your mileage may vary). |  | ||||||
| 
 |  | ||||||
| A few other characters have a meaning in a format string.  These may not occur |  | ||||||
| inside nested parentheses.  They are: |  | ||||||
| 
 |  | ||||||
| ``|`` |  | ||||||
|    Indicates that the remaining arguments in the Python argument list are optional. |  | ||||||
|    The C variables corresponding to optional arguments should be initialized to |  | ||||||
|    their default value --- when an optional argument is not specified, |  | ||||||
|    :c:func:`PyArg_ParseTuple` does not touch the contents of the corresponding C |  | ||||||
|    variable(s). |  | ||||||
| 
 |  | ||||||
| ``$`` |  | ||||||
|    :c:func:`PyArg_ParseTupleAndKeywords` only: |  | ||||||
|    Indicates that the remaining arguments in the Python argument list are |  | ||||||
|    keyword-only.  Currently, all keyword-only arguments must also be optional |  | ||||||
|    arguments, so ``|`` must always be specified before ``$`` in the format |  | ||||||
|    string. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
| ``:`` |  | ||||||
|    The list of format units ends here; the string after the colon is used as the |  | ||||||
|    function name in error messages (the "associated value" of the exception that |  | ||||||
|    :c:func:`PyArg_ParseTuple` raises). |  | ||||||
| 
 |  | ||||||
| ``;`` |  | ||||||
|    The list of format units ends here; the string after the semicolon is used as |  | ||||||
|    the error message *instead* of the default error message.  ``:`` and ``;`` |  | ||||||
|    mutually exclude each other. |  | ||||||
| 
 |  | ||||||
| Note that any Python object references which are provided to the caller are |  | ||||||
| *borrowed* references; do not decrement their reference count! |  | ||||||
| 
 |  | ||||||
| Additional arguments passed to these functions must be addresses of variables |  | ||||||
| whose type is determined by the format string; these are used to store values |  | ||||||
| from the input tuple.  There are a few cases, as described in the list of format |  | ||||||
| units above, where these parameters are used as input values; they should match |  | ||||||
| what is specified for the corresponding format unit in that case. |  | ||||||
| 
 |  | ||||||
| For the conversion to succeed, the *arg* object must match the format |  | ||||||
| and the format must be exhausted.  On success, the |  | ||||||
| :c:func:`PyArg_Parse\*` functions return true, otherwise they return |  | ||||||
| false and raise an appropriate exception. When the |  | ||||||
| :c:func:`PyArg_Parse\*` functions fail due to conversion failure in one |  | ||||||
| of the format units, the variables at the addresses corresponding to that |  | ||||||
| and the following format units are left untouched. |  | ||||||
| 
 |  | ||||||
| API Functions |  | ||||||
| ------------- |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyArg_ParseTuple(PyObject *args, const char *format, ...) |  | ||||||
| 
 |  | ||||||
|    Parse the parameters of a function that takes only positional parameters into |  | ||||||
|    local variables.  Returns true on success; on failure, it returns false and |  | ||||||
|    raises the appropriate exception. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyArg_VaParse(PyObject *args, const char *format, va_list vargs) |  | ||||||
| 
 |  | ||||||
|    Identical to :c:func:`PyArg_ParseTuple`, except that it accepts a va_list rather |  | ||||||
|    than a variable number of arguments. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyArg_ParseTupleAndKeywords(PyObject *args, PyObject *kw, const char *format, char *keywords[], ...) |  | ||||||
| 
 |  | ||||||
|    Parse the parameters of a function that takes both positional and keyword |  | ||||||
|    parameters into local variables.  The *keywords* argument is a |  | ||||||
|    *NULL*-terminated array of keyword parameter names.  Empty names denote |  | ||||||
|    :ref:`positional-only parameters <positional-only_parameter>`. |  | ||||||
|    Returns true on success; on failure, it returns false and raises the |  | ||||||
|    appropriate exception. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.6 |  | ||||||
|       Added support for :ref:`positional-only parameters |  | ||||||
|       <positional-only_parameter>`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyArg_VaParseTupleAndKeywords(PyObject *args, PyObject *kw, const char *format, char *keywords[], va_list vargs) |  | ||||||
| 
 |  | ||||||
|    Identical to :c:func:`PyArg_ParseTupleAndKeywords`, except that it accepts a |  | ||||||
|    va_list rather than a variable number of arguments. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyArg_ValidateKeywordArguments(PyObject *) |  | ||||||
| 
 |  | ||||||
|    Ensure that the keys in the keywords argument dictionary are strings.  This |  | ||||||
|    is only needed if :c:func:`PyArg_ParseTupleAndKeywords` is not used, since the |  | ||||||
|    latter already does this check. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.2 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. XXX deprecated, will be removed |  | ||||||
| .. c:function:: int PyArg_Parse(PyObject *args, const char *format, ...) |  | ||||||
| 
 |  | ||||||
|    Function used to deconstruct the argument lists of "old-style" functions --- |  | ||||||
|    these are functions which use the :const:`METH_OLDARGS` parameter parsing |  | ||||||
|    method, which has been removed in Python 3.  This is not recommended for use |  | ||||||
|    in parameter parsing in new code, and most code in the standard interpreter |  | ||||||
|    has been modified to no longer use this for that purpose.  It does remain a |  | ||||||
|    convenient way to decompose other tuples, however, and may continue to be |  | ||||||
|    used for that purpose. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyArg_UnpackTuple(PyObject *args, const char *name, Py_ssize_t min, Py_ssize_t max, ...) |  | ||||||
| 
 |  | ||||||
|    A simpler form of parameter retrieval which does not use a format string to |  | ||||||
|    specify the types of the arguments.  Functions which use this method to retrieve |  | ||||||
|    their parameters should be declared as :const:`METH_VARARGS` in function or |  | ||||||
|    method tables.  The tuple containing the actual parameters should be passed as |  | ||||||
|    *args*; it must actually be a tuple.  The length of the tuple must be at least |  | ||||||
|    *min* and no more than *max*; *min* and *max* may be equal.  Additional |  | ||||||
|    arguments must be passed to the function, each of which should be a pointer to a |  | ||||||
|    :c:type:`PyObject\*` variable; these will be filled in with the values from |  | ||||||
|    *args*; they will contain borrowed references.  The variables which correspond |  | ||||||
|    to optional parameters not given by *args* will not be filled in; these should |  | ||||||
|    be initialized by the caller. This function returns true on success and false if |  | ||||||
|    *args* is not a tuple or contains the wrong number of elements; an exception |  | ||||||
|    will be set if there was a failure. |  | ||||||
| 
 |  | ||||||
|    This is an example of the use of this function, taken from the sources for the |  | ||||||
|    :mod:`_weakref` helper module for weak references:: |  | ||||||
| 
 |  | ||||||
|       static PyObject * |  | ||||||
|       weakref_ref(PyObject *self, PyObject *args) |  | ||||||
|       { |  | ||||||
|           PyObject *object; |  | ||||||
|           PyObject *callback = NULL; |  | ||||||
|           PyObject *result = NULL; |  | ||||||
| 
 |  | ||||||
|           if (PyArg_UnpackTuple(args, "ref", 1, 2, &object, &callback)) { |  | ||||||
|               result = PyWeakref_NewRef(object, callback); |  | ||||||
|           } |  | ||||||
|           return result; |  | ||||||
|       } |  | ||||||
| 
 |  | ||||||
|    The call to :c:func:`PyArg_UnpackTuple` in this example is entirely equivalent to |  | ||||||
|    this call to :c:func:`PyArg_ParseTuple`:: |  | ||||||
| 
 |  | ||||||
|       PyArg_ParseTuple(args, "O|O:ref", &object, &callback) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| --------------- |  | ||||||
| Building values |  | ||||||
| --------------- |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* Py_BuildValue(const char *format, ...) |  | ||||||
| 
 |  | ||||||
|    Create a new value based on a format string similar to those accepted by the |  | ||||||
|    :c:func:`PyArg_Parse\*` family of functions and a sequence of values.  Returns |  | ||||||
|    the value or *NULL* in the case of an error; an exception will be raised if |  | ||||||
|    *NULL* is returned. |  | ||||||
| 
 |  | ||||||
|    :c:func:`Py_BuildValue` does not always build a tuple.  It builds a tuple only if |  | ||||||
|    its format string contains two or more format units.  If the format string is |  | ||||||
|    empty, it returns ``None``; if it contains exactly one format unit, it returns |  | ||||||
|    whatever object is described by that format unit.  To force it to return a tuple |  | ||||||
|    of size 0 or one, parenthesize the format string. |  | ||||||
| 
 |  | ||||||
|    When memory buffers are passed as parameters to supply data to build objects, as |  | ||||||
|    for the ``s`` and ``s#`` formats, the required data is copied.  Buffers provided |  | ||||||
|    by the caller are never referenced by the objects created by |  | ||||||
|    :c:func:`Py_BuildValue`.  In other words, if your code invokes :c:func:`malloc` |  | ||||||
|    and passes the allocated memory to :c:func:`Py_BuildValue`, your code is |  | ||||||
|    responsible for calling :c:func:`free` for that memory once |  | ||||||
|    :c:func:`Py_BuildValue` returns. |  | ||||||
| 
 |  | ||||||
|    In the following description, the quoted form is the format unit; the entry in |  | ||||||
|    (round) parentheses is the Python object type that the format unit will return; |  | ||||||
|    and the entry in [square] brackets is the type of the C value(s) to be passed. |  | ||||||
| 
 |  | ||||||
|    The characters space, tab, colon and comma are ignored in format strings (but |  | ||||||
|    not within format units such as ``s#``).  This can be used to make long format |  | ||||||
|    strings a tad more readable. |  | ||||||
| 
 |  | ||||||
|    ``s`` (:class:`str` or ``None``) [char \*] |  | ||||||
|       Convert a null-terminated C string to a Python :class:`str` object using ``'utf-8'`` |  | ||||||
|       encoding. If the C string pointer is *NULL*, ``None`` is used. |  | ||||||
| 
 |  | ||||||
|    ``s#`` (:class:`str` or ``None``) [char \*, int] |  | ||||||
|       Convert a C string and its length to a Python :class:`str` object using ``'utf-8'`` |  | ||||||
|       encoding. If the C string pointer is *NULL*, the length is ignored and |  | ||||||
|       ``None`` is returned. |  | ||||||
| 
 |  | ||||||
|    ``y`` (:class:`bytes`) [char \*] |  | ||||||
|       This converts a C string to a Python :class:`bytes` object.  If the C |  | ||||||
|       string pointer is *NULL*, ``None`` is returned. |  | ||||||
| 
 |  | ||||||
|    ``y#`` (:class:`bytes`) [char \*, int] |  | ||||||
|       This converts a C string and its lengths to a Python object.  If the C |  | ||||||
|       string pointer is *NULL*, ``None`` is returned. |  | ||||||
| 
 |  | ||||||
|    ``z`` (:class:`str` or ``None``) [char \*] |  | ||||||
|       Same as ``s``. |  | ||||||
| 
 |  | ||||||
|    ``z#`` (:class:`str` or ``None``) [char \*, int] |  | ||||||
|       Same as ``s#``. |  | ||||||
| 
 |  | ||||||
|    ``u`` (:class:`str`) [wchar_t \*] |  | ||||||
|       Convert a null-terminated :c:type:`wchar_t` buffer of Unicode (UTF-16 or UCS-4) |  | ||||||
|       data to a Python Unicode object.  If the Unicode buffer pointer is *NULL*, |  | ||||||
|       ``None`` is returned. |  | ||||||
| 
 |  | ||||||
|    ``u#`` (:class:`str`) [wchar_t \*, int] |  | ||||||
|       Convert a Unicode (UTF-16 or UCS-4) data buffer and its length to a Python |  | ||||||
|       Unicode object.   If the Unicode buffer pointer is *NULL*, the length is ignored |  | ||||||
|       and ``None`` is returned. |  | ||||||
| 
 |  | ||||||
|    ``U`` (:class:`str` or ``None``) [char \*] |  | ||||||
|       Same as ``s``. |  | ||||||
| 
 |  | ||||||
|    ``U#`` (:class:`str` or ``None``) [char \*, int] |  | ||||||
|       Same as ``s#``. |  | ||||||
| 
 |  | ||||||
|    ``i`` (:class:`int`) [int] |  | ||||||
|       Convert a plain C :c:type:`int` to a Python integer object. |  | ||||||
| 
 |  | ||||||
|    ``b`` (:class:`int`) [char] |  | ||||||
|       Convert a plain C :c:type:`char` to a Python integer object. |  | ||||||
| 
 |  | ||||||
|    ``h`` (:class:`int`) [short int] |  | ||||||
|       Convert a plain C :c:type:`short int` to a Python integer object. |  | ||||||
| 
 |  | ||||||
|    ``l`` (:class:`int`) [long int] |  | ||||||
|       Convert a C :c:type:`long int` to a Python integer object. |  | ||||||
| 
 |  | ||||||
|    ``B`` (:class:`int`) [unsigned char] |  | ||||||
|       Convert a C :c:type:`unsigned char` to a Python integer object. |  | ||||||
| 
 |  | ||||||
|    ``H`` (:class:`int`) [unsigned short int] |  | ||||||
|       Convert a C :c:type:`unsigned short int` to a Python integer object. |  | ||||||
| 
 |  | ||||||
|    ``I`` (:class:`int`) [unsigned int] |  | ||||||
|       Convert a C :c:type:`unsigned int` to a Python integer object. |  | ||||||
| 
 |  | ||||||
|    ``k`` (:class:`int`) [unsigned long] |  | ||||||
|       Convert a C :c:type:`unsigned long` to a Python integer object. |  | ||||||
| 
 |  | ||||||
|    ``L`` (:class:`int`) [long long] |  | ||||||
|       Convert a C :c:type:`long long` to a Python integer object. |  | ||||||
| 
 |  | ||||||
|    ``K`` (:class:`int`) [unsigned long long] |  | ||||||
|       Convert a C :c:type:`unsigned long long` to a Python integer object. |  | ||||||
| 
 |  | ||||||
|    ``n`` (:class:`int`) [Py_ssize_t] |  | ||||||
|       Convert a C :c:type:`Py_ssize_t` to a Python integer. |  | ||||||
| 
 |  | ||||||
|    ``c`` (:class:`bytes` of length 1) [char] |  | ||||||
|       Convert a C :c:type:`int` representing a byte to a Python :class:`bytes` object of |  | ||||||
|       length 1. |  | ||||||
| 
 |  | ||||||
|    ``C`` (:class:`str` of length 1) [int] |  | ||||||
|       Convert a C :c:type:`int` representing a character to Python :class:`str` |  | ||||||
|       object of length 1. |  | ||||||
| 
 |  | ||||||
|    ``d`` (:class:`float`) [double] |  | ||||||
|       Convert a C :c:type:`double` to a Python floating point number. |  | ||||||
| 
 |  | ||||||
|    ``f`` (:class:`float`) [float] |  | ||||||
|       Convert a C :c:type:`float` to a Python floating point number. |  | ||||||
| 
 |  | ||||||
|    ``D`` (:class:`complex`) [Py_complex \*] |  | ||||||
|       Convert a C :c:type:`Py_complex` structure to a Python complex number. |  | ||||||
| 
 |  | ||||||
|    ``O`` (object) [PyObject \*] |  | ||||||
|       Pass a Python object untouched (except for its reference count, which is |  | ||||||
|       incremented by one).  If the object passed in is a *NULL* pointer, it is assumed |  | ||||||
|       that this was caused because the call producing the argument found an error and |  | ||||||
|       set an exception. Therefore, :c:func:`Py_BuildValue` will return *NULL* but won't |  | ||||||
|       raise an exception.  If no exception has been raised yet, :exc:`SystemError` is |  | ||||||
|       set. |  | ||||||
| 
 |  | ||||||
|    ``S`` (object) [PyObject \*] |  | ||||||
|       Same as ``O``. |  | ||||||
| 
 |  | ||||||
|    ``N`` (object) [PyObject \*] |  | ||||||
|       Same as ``O``, except it doesn't increment the reference count on the object. |  | ||||||
|       Useful when the object is created by a call to an object constructor in the |  | ||||||
|       argument list. |  | ||||||
| 
 |  | ||||||
|    ``O&`` (object) [*converter*, *anything*] |  | ||||||
|       Convert *anything* to a Python object through a *converter* function.  The |  | ||||||
|       function is called with *anything* (which should be compatible with :c:type:`void |  | ||||||
|       \*`) as its argument and should return a "new" Python object, or *NULL* if an |  | ||||||
|       error occurred. |  | ||||||
| 
 |  | ||||||
|    ``(items)`` (:class:`tuple`) [*matching-items*] |  | ||||||
|       Convert a sequence of C values to a Python tuple with the same number of items. |  | ||||||
| 
 |  | ||||||
|    ``[items]`` (:class:`list`) [*matching-items*] |  | ||||||
|       Convert a sequence of C values to a Python list with the same number of items. |  | ||||||
| 
 |  | ||||||
|    ``{items}`` (:class:`dict`) [*matching-items*] |  | ||||||
|       Convert a sequence of C values to a Python dictionary.  Each pair of consecutive |  | ||||||
|       C values adds one item to the dictionary, serving as key and value, |  | ||||||
|       respectively. |  | ||||||
| 
 |  | ||||||
|    If there is an error in the format string, the :exc:`SystemError` exception is |  | ||||||
|    set and *NULL* returned. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* Py_VaBuildValue(const char *format, va_list vargs) |  | ||||||
| 
 |  | ||||||
|    Identical to :c:func:`Py_BuildValue`, except that it accepts a va_list |  | ||||||
|    rather than a variable number of arguments. |  | ||||||
							
								
								
									
										46
									
								
								third_party/python/Doc/c-api/bool.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										46
									
								
								third_party/python/Doc/c-api/bool.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,46 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _boolobjects: |  | ||||||
| 
 |  | ||||||
| Boolean Objects |  | ||||||
| --------------- |  | ||||||
| 
 |  | ||||||
| Booleans in Python are implemented as a subclass of integers.  There are only |  | ||||||
| two booleans, :const:`Py_False` and :const:`Py_True`.  As such, the normal |  | ||||||
| creation and deletion functions don't apply to booleans.  The following macros |  | ||||||
| are available, however. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyBool_Check(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return true if *o* is of type :c:data:`PyBool_Type`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyObject* Py_False |  | ||||||
| 
 |  | ||||||
|    The Python ``False`` object.  This object has no methods.  It needs to be |  | ||||||
|    treated just like any other object with respect to reference counts. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyObject* Py_True |  | ||||||
| 
 |  | ||||||
|    The Python ``True`` object.  This object has no methods.  It needs to be treated |  | ||||||
|    just like any other object with respect to reference counts. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:macro:: Py_RETURN_FALSE |  | ||||||
| 
 |  | ||||||
|    Return :const:`Py_False` from a function, properly incrementing its reference |  | ||||||
|    count. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:macro:: Py_RETURN_TRUE |  | ||||||
| 
 |  | ||||||
|    Return :const:`Py_True` from a function, properly incrementing its reference |  | ||||||
|    count. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyBool_FromLong(long v) |  | ||||||
| 
 |  | ||||||
|    Return a new reference to :const:`Py_True` or :const:`Py_False` depending on the |  | ||||||
|    truth value of *v*. |  | ||||||
							
								
								
									
										508
									
								
								third_party/python/Doc/c-api/buffer.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										508
									
								
								third_party/python/Doc/c-api/buffer.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,508 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. index:: |  | ||||||
|    single: buffer protocol |  | ||||||
|    single: buffer interface; (see buffer protocol) |  | ||||||
|    single: buffer object; (see buffer protocol) |  | ||||||
| 
 |  | ||||||
| .. _bufferobjects: |  | ||||||
| 
 |  | ||||||
| Buffer Protocol |  | ||||||
| --------------- |  | ||||||
| 
 |  | ||||||
| .. sectionauthor:: Greg Stein <gstein@lyra.org> |  | ||||||
| .. sectionauthor:: Benjamin Peterson |  | ||||||
| .. sectionauthor:: Stefan Krah |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Certain objects available in Python wrap access to an underlying memory |  | ||||||
| array or *buffer*.  Such objects include the built-in :class:`bytes` and |  | ||||||
| :class:`bytearray`, and some extension types like :class:`array.array`. |  | ||||||
| Third-party libraries may define their own types for special purposes, such |  | ||||||
| as image processing or numeric analysis. |  | ||||||
| 
 |  | ||||||
| While each of these types have their own semantics, they share the common |  | ||||||
| characteristic of being backed by a possibly large memory buffer.  It is |  | ||||||
| then desirable, in some situations, to access that buffer directly and |  | ||||||
| without intermediate copying. |  | ||||||
| 
 |  | ||||||
| Python provides such a facility at the C level in the form of the :ref:`buffer |  | ||||||
| protocol <bufferobjects>`.  This protocol has two sides: |  | ||||||
| 
 |  | ||||||
| .. index:: single: PyBufferProcs |  | ||||||
| 
 |  | ||||||
| - on the producer side, a type can export a "buffer interface" which allows |  | ||||||
|   objects of that type to expose information about their underlying buffer. |  | ||||||
|   This interface is described in the section :ref:`buffer-structs`; |  | ||||||
| 
 |  | ||||||
| - on the consumer side, several means are available to obtain a pointer to |  | ||||||
|   the raw underlying data of an object (for example a method parameter). |  | ||||||
| 
 |  | ||||||
| Simple objects such as :class:`bytes` and :class:`bytearray` expose their |  | ||||||
| underlying buffer in byte-oriented form.  Other forms are possible; for example, |  | ||||||
| the elements exposed by an :class:`array.array` can be multi-byte values. |  | ||||||
| 
 |  | ||||||
| An example consumer of the buffer interface is the :meth:`~io.BufferedIOBase.write` |  | ||||||
| method of file objects: any object that can export a series of bytes through |  | ||||||
| the buffer interface can be written to a file.  While :meth:`write` only |  | ||||||
| needs read-only access to the internal contents of the object passed to it, |  | ||||||
| other methods such as :meth:`~io.BufferedIOBase.readinto` need write access |  | ||||||
| to the contents of their argument.  The buffer interface allows objects to |  | ||||||
| selectively allow or reject exporting of read-write and read-only buffers. |  | ||||||
| 
 |  | ||||||
| There are two ways for a consumer of the buffer interface to acquire a buffer |  | ||||||
| over a target object: |  | ||||||
| 
 |  | ||||||
| * call :c:func:`PyObject_GetBuffer` with the right parameters; |  | ||||||
| 
 |  | ||||||
| * call :c:func:`PyArg_ParseTuple` (or one of its siblings) with one of the |  | ||||||
|   ``y*``, ``w*`` or ``s*`` :ref:`format codes <arg-parsing>`. |  | ||||||
| 
 |  | ||||||
| In both cases, :c:func:`PyBuffer_Release` must be called when the buffer |  | ||||||
| isn't needed anymore.  Failure to do so could lead to various issues such as |  | ||||||
| resource leaks. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _buffer-structure: |  | ||||||
| 
 |  | ||||||
| Buffer structure |  | ||||||
| ================ |  | ||||||
| 
 |  | ||||||
| Buffer structures (or simply "buffers") are useful as a way to expose the |  | ||||||
| binary data from another object to the Python programmer.  They can also be |  | ||||||
| used as a zero-copy slicing mechanism.  Using their ability to reference a |  | ||||||
| block of memory, it is possible to expose any data to the Python programmer |  | ||||||
| quite easily.  The memory could be a large, constant array in a C extension, |  | ||||||
| it could be a raw block of memory for manipulation before passing to an |  | ||||||
| operating system library, or it could be used to pass around structured data |  | ||||||
| in its native, in-memory format. |  | ||||||
| 
 |  | ||||||
| Contrary to most data types exposed by the Python interpreter, buffers |  | ||||||
| are not :c:type:`PyObject` pointers but rather simple C structures.  This |  | ||||||
| allows them to be created and copied very simply.  When a generic wrapper |  | ||||||
| around a buffer is needed, a :ref:`memoryview <memoryview-objects>` object |  | ||||||
| can be created. |  | ||||||
| 
 |  | ||||||
| For short instructions how to write an exporting object, see |  | ||||||
| :ref:`Buffer Object Structures <buffer-structs>`. For obtaining |  | ||||||
| a buffer, see :c:func:`PyObject_GetBuffer`. |  | ||||||
| 
 |  | ||||||
| .. c:type:: Py_buffer |  | ||||||
| 
 |  | ||||||
|    .. c:member:: void \*buf |  | ||||||
| 
 |  | ||||||
|       A pointer to the start of the logical structure described by the buffer |  | ||||||
|       fields. This can be any location within the underlying physical memory |  | ||||||
|       block of the exporter. For example, with negative :c:member:`~Py_buffer.strides` |  | ||||||
|       the value may point to the end of the memory block. |  | ||||||
| 
 |  | ||||||
|       For :term:`contiguous` arrays, the value points to the beginning of |  | ||||||
|       the memory block. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: void \*obj |  | ||||||
| 
 |  | ||||||
|       A new reference to the exporting object. The reference is owned by |  | ||||||
|       the consumer and automatically decremented and set to *NULL* by |  | ||||||
|       :c:func:`PyBuffer_Release`. The field is the equivalent of the return |  | ||||||
|       value of any standard C-API function. |  | ||||||
| 
 |  | ||||||
|       As a special case, for *temporary* buffers that are wrapped by |  | ||||||
|       :c:func:`PyMemoryView_FromBuffer` or :c:func:`PyBuffer_FillInfo` |  | ||||||
|       this field is *NULL*. In general, exporting objects MUST NOT |  | ||||||
|       use this scheme. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: Py_ssize_t len |  | ||||||
| 
 |  | ||||||
|       ``product(shape) * itemsize``. For contiguous arrays, this is the length |  | ||||||
|       of the underlying memory block. For non-contiguous arrays, it is the length |  | ||||||
|       that the logical structure would have if it were copied to a contiguous |  | ||||||
|       representation. |  | ||||||
| 
 |  | ||||||
|       Accessing ``((char *)buf)[0] up to ((char *)buf)[len-1]`` is only valid |  | ||||||
|       if the buffer has been obtained by a request that guarantees contiguity. In |  | ||||||
|       most cases such a request will be :c:macro:`PyBUF_SIMPLE` or :c:macro:`PyBUF_WRITABLE`. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: int readonly |  | ||||||
| 
 |  | ||||||
|       An indicator of whether the buffer is read-only. This field is controlled |  | ||||||
|       by the :c:macro:`PyBUF_WRITABLE` flag. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: Py_ssize_t itemsize |  | ||||||
| 
 |  | ||||||
|       Item size in bytes of a single element. Same as the value of :func:`struct.calcsize` |  | ||||||
|       called on non-NULL :c:member:`~Py_buffer.format` values. |  | ||||||
| 
 |  | ||||||
|       Important exception: If a consumer requests a buffer without the |  | ||||||
|       :c:macro:`PyBUF_FORMAT` flag, :c:member:`~Py_buffer.format` will |  | ||||||
|       be set to  *NULL*,  but :c:member:`~Py_buffer.itemsize` still has |  | ||||||
|       the value for the original format. |  | ||||||
| 
 |  | ||||||
|       If :c:member:`~Py_buffer.shape` is present, the equality |  | ||||||
|       ``product(shape) * itemsize == len`` still holds and the consumer |  | ||||||
|       can use :c:member:`~Py_buffer.itemsize` to navigate the buffer. |  | ||||||
| 
 |  | ||||||
|       If :c:member:`~Py_buffer.shape` is *NULL* as a result of a :c:macro:`PyBUF_SIMPLE` |  | ||||||
|       or a :c:macro:`PyBUF_WRITABLE` request, the consumer must disregard |  | ||||||
|       :c:member:`~Py_buffer.itemsize` and assume ``itemsize == 1``. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: const char \*format |  | ||||||
| 
 |  | ||||||
|       A *NUL* terminated string in :mod:`struct` module style syntax describing |  | ||||||
|       the contents of a single item. If this is *NULL*, ``"B"`` (unsigned bytes) |  | ||||||
|       is assumed. |  | ||||||
| 
 |  | ||||||
|       This field is controlled by the :c:macro:`PyBUF_FORMAT` flag. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: int ndim |  | ||||||
| 
 |  | ||||||
|       The number of dimensions the memory represents as an n-dimensional array. |  | ||||||
|       If it is ``0``, :c:member:`~Py_buffer.buf` points to a single item representing |  | ||||||
|       a scalar. In this case, :c:member:`~Py_buffer.shape`, :c:member:`~Py_buffer.strides` |  | ||||||
|       and :c:member:`~Py_buffer.suboffsets` MUST be *NULL*. |  | ||||||
| 
 |  | ||||||
|       The macro :c:macro:`PyBUF_MAX_NDIM` limits the maximum number of dimensions |  | ||||||
|       to 64. Exporters MUST respect this limit, consumers of multi-dimensional |  | ||||||
|       buffers SHOULD be able to handle up to :c:macro:`PyBUF_MAX_NDIM` dimensions. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: Py_ssize_t \*shape |  | ||||||
| 
 |  | ||||||
|       An array of :c:type:`Py_ssize_t` of length :c:member:`~Py_buffer.ndim` |  | ||||||
|       indicating the shape of the memory as an n-dimensional array. Note that |  | ||||||
|       ``shape[0] * ... * shape[ndim-1] * itemsize`` MUST be equal to |  | ||||||
|       :c:member:`~Py_buffer.len`. |  | ||||||
| 
 |  | ||||||
|       Shape values are restricted to ``shape[n] >= 0``. The case |  | ||||||
|       ``shape[n] == 0`` requires special attention. See `complex arrays`_ |  | ||||||
|       for further information. |  | ||||||
| 
 |  | ||||||
|       The shape array is read-only for the consumer. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: Py_ssize_t \*strides |  | ||||||
| 
 |  | ||||||
|       An array of :c:type:`Py_ssize_t` of length :c:member:`~Py_buffer.ndim` |  | ||||||
|       giving the number of bytes to skip to get to a new element in each |  | ||||||
|       dimension. |  | ||||||
| 
 |  | ||||||
|       Stride values can be any integer. For regular arrays, strides are |  | ||||||
|       usually positive, but a consumer MUST be able to handle the case |  | ||||||
|       ``strides[n] <= 0``. See `complex arrays`_ for further information. |  | ||||||
| 
 |  | ||||||
|       The strides array is read-only for the consumer. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: Py_ssize_t \*suboffsets |  | ||||||
| 
 |  | ||||||
|       An array of :c:type:`Py_ssize_t` of length :c:member:`~Py_buffer.ndim`. |  | ||||||
|       If ``suboffsets[n] >= 0``, the values stored along the nth dimension are |  | ||||||
|       pointers and the suboffset value dictates how many bytes to add to each |  | ||||||
|       pointer after de-referencing. A suboffset value that is negative |  | ||||||
|       indicates that no de-referencing should occur (striding in a contiguous |  | ||||||
|       memory block). |  | ||||||
| 
 |  | ||||||
|       If all suboffsets are negative (i.e. no de-referencing is needed), then |  | ||||||
|       this field must be NULL (the default value). |  | ||||||
| 
 |  | ||||||
|       This type of array representation is used by the Python Imaging Library |  | ||||||
|       (PIL). See `complex arrays`_ for further information how to access elements |  | ||||||
|       of such an array. |  | ||||||
| 
 |  | ||||||
|       The suboffsets array is read-only for the consumer. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: void \*internal |  | ||||||
| 
 |  | ||||||
|       This is for use internally by the exporting object. For example, this |  | ||||||
|       might be re-cast as an integer by the exporter and used to store flags |  | ||||||
|       about whether or not the shape, strides, and suboffsets arrays must be |  | ||||||
|       freed when the buffer is released. The consumer MUST NOT alter this |  | ||||||
|       value. |  | ||||||
| 
 |  | ||||||
| .. _buffer-request-types: |  | ||||||
| 
 |  | ||||||
| Buffer request types |  | ||||||
| ==================== |  | ||||||
| 
 |  | ||||||
| Buffers are usually obtained by sending a buffer request to an exporting |  | ||||||
| object via :c:func:`PyObject_GetBuffer`. Since the complexity of the logical |  | ||||||
| structure of the memory can vary drastically, the consumer uses the *flags* |  | ||||||
| argument to specify the exact buffer type it can handle. |  | ||||||
| 
 |  | ||||||
| All :c:data:`Py_buffer` fields are unambiguously defined by the request |  | ||||||
| type. |  | ||||||
| 
 |  | ||||||
| request-independent fields |  | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~ |  | ||||||
| The following fields are not influenced by *flags* and must always be filled in |  | ||||||
| with the correct values: :c:member:`~Py_buffer.obj`, :c:member:`~Py_buffer.buf`, |  | ||||||
| :c:member:`~Py_buffer.len`, :c:member:`~Py_buffer.itemsize`, :c:member:`~Py_buffer.ndim`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| readonly, format |  | ||||||
| ~~~~~~~~~~~~~~~~ |  | ||||||
| 
 |  | ||||||
|    .. c:macro:: PyBUF_WRITABLE |  | ||||||
| 
 |  | ||||||
|       Controls the :c:member:`~Py_buffer.readonly` field. If set, the exporter |  | ||||||
|       MUST provide a writable buffer or else report failure. Otherwise, the |  | ||||||
|       exporter MAY provide either a read-only or writable buffer, but the choice |  | ||||||
|       MUST be consistent for all consumers. |  | ||||||
| 
 |  | ||||||
|    .. c:macro:: PyBUF_FORMAT |  | ||||||
| 
 |  | ||||||
|       Controls the :c:member:`~Py_buffer.format` field. If set, this field MUST |  | ||||||
|       be filled in correctly. Otherwise, this field MUST be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| :c:macro:`PyBUF_WRITABLE` can be \|'d to any of the flags in the next section. |  | ||||||
| Since :c:macro:`PyBUF_SIMPLE` is defined as 0, :c:macro:`PyBUF_WRITABLE` |  | ||||||
| can be used as a stand-alone flag to request a simple writable buffer. |  | ||||||
| 
 |  | ||||||
| :c:macro:`PyBUF_FORMAT` can be \|'d to any of the flags except :c:macro:`PyBUF_SIMPLE`. |  | ||||||
| The latter already implies format ``B`` (unsigned bytes). |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| shape, strides, suboffsets |  | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~ |  | ||||||
| 
 |  | ||||||
| The flags that control the logical structure of the memory are listed |  | ||||||
| in decreasing order of complexity. Note that each flag contains all bits |  | ||||||
| of the flags below it. |  | ||||||
| 
 |  | ||||||
| .. tabularcolumns:: |p{0.35\linewidth}|l|l|l| |  | ||||||
| 
 |  | ||||||
| +-----------------------------+-------+---------+------------+ |  | ||||||
| |  Request                    | shape | strides | suboffsets | |  | ||||||
| +=============================+=======+=========+============+ |  | ||||||
| | .. c:macro:: PyBUF_INDIRECT |  yes  |   yes   | if needed  | |  | ||||||
| +-----------------------------+-------+---------+------------+ |  | ||||||
| | .. c:macro:: PyBUF_STRIDES  |  yes  |   yes   |    NULL    | |  | ||||||
| +-----------------------------+-------+---------+------------+ |  | ||||||
| | .. c:macro:: PyBUF_ND       |  yes  |   NULL  |    NULL    | |  | ||||||
| +-----------------------------+-------+---------+------------+ |  | ||||||
| | .. c:macro:: PyBUF_SIMPLE   |  NULL |   NULL  |    NULL    | |  | ||||||
| +-----------------------------+-------+---------+------------+ |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. index:: contiguous, C-contiguous, Fortran contiguous |  | ||||||
| 
 |  | ||||||
| contiguity requests |  | ||||||
| ~~~~~~~~~~~~~~~~~~~ |  | ||||||
| 
 |  | ||||||
| C or Fortran :term:`contiguity <contiguous>` can be explicitly requested, |  | ||||||
| with and without stride information. Without stride information, the buffer |  | ||||||
| must be C-contiguous. |  | ||||||
| 
 |  | ||||||
| .. tabularcolumns:: |p{0.35\linewidth}|l|l|l|l| |  | ||||||
| 
 |  | ||||||
| +-----------------------------------+-------+---------+------------+--------+ |  | ||||||
| |  Request                          | shape | strides | suboffsets | contig | |  | ||||||
| +===================================+=======+=========+============+========+ |  | ||||||
| | .. c:macro:: PyBUF_C_CONTIGUOUS   |  yes  |   yes   |    NULL    |   C    | |  | ||||||
| +-----------------------------------+-------+---------+------------+--------+ |  | ||||||
| | .. c:macro:: PyBUF_F_CONTIGUOUS   |  yes  |   yes   |    NULL    |   F    | |  | ||||||
| +-----------------------------------+-------+---------+------------+--------+ |  | ||||||
| | .. c:macro:: PyBUF_ANY_CONTIGUOUS |  yes  |   yes   |    NULL    | C or F | |  | ||||||
| +-----------------------------------+-------+---------+------------+--------+ |  | ||||||
| | .. c:macro:: PyBUF_ND             |  yes  |   NULL  |    NULL    |   C    | |  | ||||||
| +-----------------------------------+-------+---------+------------+--------+ |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| compound requests |  | ||||||
| ~~~~~~~~~~~~~~~~~ |  | ||||||
| 
 |  | ||||||
| All possible requests are fully defined by some combination of the flags in |  | ||||||
| the previous section. For convenience, the buffer protocol provides frequently |  | ||||||
| used combinations as single flags. |  | ||||||
| 
 |  | ||||||
| In the following table *U* stands for undefined contiguity. The consumer would |  | ||||||
| have to call :c:func:`PyBuffer_IsContiguous` to determine contiguity. |  | ||||||
| 
 |  | ||||||
| .. tabularcolumns:: |p{0.35\linewidth}|l|l|l|l|l|l| |  | ||||||
| 
 |  | ||||||
| +-------------------------------+-------+---------+------------+--------+----------+--------+ |  | ||||||
| |  Request                      | shape | strides | suboffsets | contig | readonly | format | |  | ||||||
| +===============================+=======+=========+============+========+==========+========+ |  | ||||||
| | .. c:macro:: PyBUF_FULL       |  yes  |   yes   | if needed  |   U    |     0    |  yes   | |  | ||||||
| +-------------------------------+-------+---------+------------+--------+----------+--------+ |  | ||||||
| | .. c:macro:: PyBUF_FULL_RO    |  yes  |   yes   | if needed  |   U    |  1 or 0  |  yes   | |  | ||||||
| +-------------------------------+-------+---------+------------+--------+----------+--------+ |  | ||||||
| | .. c:macro:: PyBUF_RECORDS    |  yes  |   yes   |    NULL    |   U    |     0    |  yes   | |  | ||||||
| +-------------------------------+-------+---------+------------+--------+----------+--------+ |  | ||||||
| | .. c:macro:: PyBUF_RECORDS_RO |  yes  |   yes   |    NULL    |   U    |  1 or 0  |  yes   | |  | ||||||
| +-------------------------------+-------+---------+------------+--------+----------+--------+ |  | ||||||
| | .. c:macro:: PyBUF_STRIDED    |  yes  |   yes   |    NULL    |   U    |     0    |  NULL  | |  | ||||||
| +-------------------------------+-------+---------+------------+--------+----------+--------+ |  | ||||||
| | .. c:macro:: PyBUF_STRIDED_RO |  yes  |   yes   |    NULL    |   U    |  1 or 0  |  NULL  | |  | ||||||
| +-------------------------------+-------+---------+------------+--------+----------+--------+ |  | ||||||
| | .. c:macro:: PyBUF_CONTIG     |  yes  |   NULL  |    NULL    |   C    |     0    |  NULL  | |  | ||||||
| +-------------------------------+-------+---------+------------+--------+----------+--------+ |  | ||||||
| | .. c:macro:: PyBUF_CONTIG_RO  |  yes  |   NULL  |    NULL    |   C    |  1 or 0  |  NULL  | |  | ||||||
| +-------------------------------+-------+---------+------------+--------+----------+--------+ |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Complex arrays |  | ||||||
| ============== |  | ||||||
| 
 |  | ||||||
| NumPy-style: shape and strides |  | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |  | ||||||
| 
 |  | ||||||
| The logical structure of NumPy-style arrays is defined by :c:member:`~Py_buffer.itemsize`, |  | ||||||
| :c:member:`~Py_buffer.ndim`, :c:member:`~Py_buffer.shape` and :c:member:`~Py_buffer.strides`. |  | ||||||
| 
 |  | ||||||
| If ``ndim == 0``, the memory location pointed to by :c:member:`~Py_buffer.buf` is |  | ||||||
| interpreted as a scalar of size :c:member:`~Py_buffer.itemsize`. In that case, |  | ||||||
| both :c:member:`~Py_buffer.shape` and :c:member:`~Py_buffer.strides` are *NULL*. |  | ||||||
| 
 |  | ||||||
| If :c:member:`~Py_buffer.strides` is *NULL*, the array is interpreted as |  | ||||||
| a standard n-dimensional C-array. Otherwise, the consumer must access an |  | ||||||
| n-dimensional array as follows: |  | ||||||
| 
 |  | ||||||
|    ``ptr = (char *)buf + indices[0] * strides[0] + ... + indices[n-1] * strides[n-1]`` |  | ||||||
|    ``item = *((typeof(item) *)ptr);`` |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| As noted above, :c:member:`~Py_buffer.buf` can point to any location within |  | ||||||
| the actual memory block. An exporter can check the validity of a buffer with |  | ||||||
| this function: |  | ||||||
| 
 |  | ||||||
| .. code-block:: python |  | ||||||
| 
 |  | ||||||
|    def verify_structure(memlen, itemsize, ndim, shape, strides, offset): |  | ||||||
|        """Verify that the parameters represent a valid array within |  | ||||||
|           the bounds of the allocated memory: |  | ||||||
|               char *mem: start of the physical memory block |  | ||||||
|               memlen: length of the physical memory block |  | ||||||
|               offset: (char *)buf - mem |  | ||||||
|        """ |  | ||||||
|        if offset % itemsize: |  | ||||||
|            return False |  | ||||||
|        if offset < 0 or offset+itemsize > memlen: |  | ||||||
|            return False |  | ||||||
|        if any(v % itemsize for v in strides): |  | ||||||
|            return False |  | ||||||
| 
 |  | ||||||
|        if ndim <= 0: |  | ||||||
|            return ndim == 0 and not shape and not strides |  | ||||||
|        if 0 in shape: |  | ||||||
|            return True |  | ||||||
| 
 |  | ||||||
|        imin = sum(strides[j]*(shape[j]-1) for j in range(ndim) |  | ||||||
|                   if strides[j] <= 0) |  | ||||||
|        imax = sum(strides[j]*(shape[j]-1) for j in range(ndim) |  | ||||||
|                   if strides[j] > 0) |  | ||||||
| 
 |  | ||||||
|        return 0 <= offset+imin and offset+imax+itemsize <= memlen |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| PIL-style: shape, strides and suboffsets |  | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |  | ||||||
| 
 |  | ||||||
| In addition to the regular items, PIL-style arrays can contain pointers |  | ||||||
| that must be followed in order to get to the next element in a dimension. |  | ||||||
| For example, the regular three-dimensional C-array ``char v[2][2][3]`` can |  | ||||||
| also be viewed as an array of 2 pointers to 2 two-dimensional arrays: |  | ||||||
| ``char (*v[2])[2][3]``. In suboffsets representation, those two pointers |  | ||||||
| can be embedded at the start of :c:member:`~Py_buffer.buf`, pointing |  | ||||||
| to two ``char x[2][3]`` arrays that can be located anywhere in memory. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Here is a function that returns a pointer to the element in an N-D array |  | ||||||
| pointed to by an N-dimensional index when there are both non-NULL strides |  | ||||||
| and suboffsets:: |  | ||||||
| 
 |  | ||||||
|    void *get_item_pointer(int ndim, void *buf, Py_ssize_t *strides, |  | ||||||
|                           Py_ssize_t *suboffsets, Py_ssize_t *indices) { |  | ||||||
|        char *pointer = (char*)buf; |  | ||||||
|        int i; |  | ||||||
|        for (i = 0; i < ndim; i++) { |  | ||||||
|            pointer += strides[i] * indices[i]; |  | ||||||
|            if (suboffsets[i] >=0 ) { |  | ||||||
|                pointer = *((char**)pointer) + suboffsets[i]; |  | ||||||
|            } |  | ||||||
|        } |  | ||||||
|        return (void*)pointer; |  | ||||||
|    } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Buffer-related functions |  | ||||||
| ======================== |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_CheckBuffer(PyObject *obj) |  | ||||||
| 
 |  | ||||||
|    Return ``1`` if *obj* supports the buffer interface otherwise ``0``.  When ``1`` is |  | ||||||
|    returned, it doesn't guarantee that :c:func:`PyObject_GetBuffer` will |  | ||||||
|    succeed.  This function always succeeds. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_GetBuffer(PyObject *exporter, Py_buffer *view, int flags) |  | ||||||
| 
 |  | ||||||
|    Send a request to *exporter* to fill in *view* as specified by  *flags*. |  | ||||||
|    If the exporter cannot provide a buffer of the exact type, it MUST raise |  | ||||||
|    :c:data:`PyExc_BufferError`, set :c:member:`view->obj` to *NULL* and |  | ||||||
|    return ``-1``. |  | ||||||
| 
 |  | ||||||
|    On success, fill in *view*, set :c:member:`view->obj` to a new reference |  | ||||||
|    to *exporter* and return 0. In the case of chained buffer providers |  | ||||||
|    that redirect requests to a single object, :c:member:`view->obj` MAY |  | ||||||
|    refer to this object instead of *exporter* (See :ref:`Buffer Object Structures <buffer-structs>`). |  | ||||||
| 
 |  | ||||||
|    Successful calls to :c:func:`PyObject_GetBuffer` must be paired with calls |  | ||||||
|    to :c:func:`PyBuffer_Release`, similar to :c:func:`malloc` and :c:func:`free`. |  | ||||||
|    Thus, after the consumer is done with the buffer, :c:func:`PyBuffer_Release` |  | ||||||
|    must be called exactly once. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyBuffer_Release(Py_buffer *view) |  | ||||||
| 
 |  | ||||||
|    Release the buffer *view* and decrement the reference count for |  | ||||||
|    :c:member:`view->obj`. This function MUST be called when the buffer |  | ||||||
|    is no longer being used, otherwise reference leaks may occur. |  | ||||||
| 
 |  | ||||||
|    It is an error to call this function on a buffer that was not obtained via |  | ||||||
|    :c:func:`PyObject_GetBuffer`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PyBuffer_SizeFromFormat(const char *) |  | ||||||
| 
 |  | ||||||
|    Return the implied :c:data:`~Py_buffer.itemsize` from :c:data:`~Py_buffer.format`. |  | ||||||
|    This function is not yet implemented. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyBuffer_IsContiguous(Py_buffer *view, char order) |  | ||||||
| 
 |  | ||||||
|    Return ``1`` if the memory defined by the *view* is C-style (*order* is |  | ||||||
|    ``'C'``) or Fortran-style (*order* is ``'F'``) :term:`contiguous` or either one |  | ||||||
|    (*order* is ``'A'``).  Return ``0`` otherwise.  This function always succeeds. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyBuffer_ToContiguous(void *buf, Py_buffer *src, Py_ssize_t len, char order) |  | ||||||
| 
 |  | ||||||
|    Copy *len* bytes from *src* to its contiguous representation in *buf*. |  | ||||||
|    *order* can be ``'C'`` or ``'F'`` (for C-style or Fortran-style ordering). |  | ||||||
|    ``0`` is returned on success, ``-1`` on error. |  | ||||||
| 
 |  | ||||||
|    This function fails if *len* != *src->len*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyBuffer_FillContiguousStrides(int ndims, Py_ssize_t *shape, Py_ssize_t *strides, int itemsize, char order) |  | ||||||
| 
 |  | ||||||
|    Fill the *strides* array with byte-strides of a :term:`contiguous` (C-style if |  | ||||||
|    *order* is ``'C'`` or Fortran-style if *order* is ``'F'``) array of the |  | ||||||
|    given shape with the given number of bytes per element. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyBuffer_FillInfo(Py_buffer *view, PyObject *exporter, void *buf, Py_ssize_t len, int readonly, int flags) |  | ||||||
| 
 |  | ||||||
|    Handle buffer requests for an exporter that wants to expose *buf* of size *len* |  | ||||||
|    with writability set according to *readonly*. *buf* is interpreted as a sequence |  | ||||||
|    of unsigned bytes. |  | ||||||
| 
 |  | ||||||
|    The *flags* argument indicates the request type. This function always fills in |  | ||||||
|    *view* as specified by flags, unless *buf* has been designated as read-only |  | ||||||
|    and :c:macro:`PyBUF_WRITABLE` is set in *flags*. |  | ||||||
| 
 |  | ||||||
|    On success, set :c:member:`view->obj` to a new reference to *exporter* and |  | ||||||
|    return 0. Otherwise, raise :c:data:`PyExc_BufferError`, set |  | ||||||
|    :c:member:`view->obj` to *NULL* and return ``-1``; |  | ||||||
| 
 |  | ||||||
|    If this function is used as part of a :ref:`getbufferproc <buffer-structs>`, |  | ||||||
|    *exporter* MUST be set to the exporting object and *flags* must be passed |  | ||||||
|    unmodified. Otherwise, *exporter* MUST be NULL. |  | ||||||
							
								
								
									
										87
									
								
								third_party/python/Doc/c-api/bytearray.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										87
									
								
								third_party/python/Doc/c-api/bytearray.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,87 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _bytearrayobjects: |  | ||||||
| 
 |  | ||||||
| Byte Array Objects |  | ||||||
| ------------------ |  | ||||||
| 
 |  | ||||||
| .. index:: object: bytearray |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyByteArrayObject |  | ||||||
| 
 |  | ||||||
|    This subtype of :c:type:`PyObject` represents a Python bytearray object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyByteArray_Type |  | ||||||
| 
 |  | ||||||
|    This instance of :c:type:`PyTypeObject` represents the Python bytearray type; |  | ||||||
|    it is the same object as :class:`bytearray` in the Python layer. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Type check macros |  | ||||||
| ^^^^^^^^^^^^^^^^^ |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyByteArray_Check(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return true if the object *o* is a bytearray object or an instance of a |  | ||||||
|    subtype of the bytearray type. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyByteArray_CheckExact(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return true if the object *o* is a bytearray object, but not an instance of a |  | ||||||
|    subtype of the bytearray type. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Direct API functions |  | ||||||
| ^^^^^^^^^^^^^^^^^^^^ |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyByteArray_FromObject(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return a new bytearray object from any object, *o*, that implements the |  | ||||||
|    :ref:`buffer protocol <bufferobjects>`. |  | ||||||
| 
 |  | ||||||
|    .. XXX expand about the buffer protocol, at least somewhere |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyByteArray_FromStringAndSize(const char *string, Py_ssize_t len) |  | ||||||
| 
 |  | ||||||
|    Create a new bytearray object from *string* and its length, *len*.  On |  | ||||||
|    failure, *NULL* is returned. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyByteArray_Concat(PyObject *a, PyObject *b) |  | ||||||
| 
 |  | ||||||
|    Concat bytearrays *a* and *b* and return a new bytearray with the result. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PyByteArray_Size(PyObject *bytearray) |  | ||||||
| 
 |  | ||||||
|    Return the size of *bytearray* after checking for a *NULL* pointer. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: char* PyByteArray_AsString(PyObject *bytearray) |  | ||||||
| 
 |  | ||||||
|    Return the contents of *bytearray* as a char array after checking for a |  | ||||||
|    *NULL* pointer.  The returned array always has an extra |  | ||||||
|    null byte appended. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyByteArray_Resize(PyObject *bytearray, Py_ssize_t len) |  | ||||||
| 
 |  | ||||||
|    Resize the internal buffer of *bytearray* to *len*. |  | ||||||
| 
 |  | ||||||
| Macros |  | ||||||
| ^^^^^^ |  | ||||||
| 
 |  | ||||||
| These macros trade safety for speed and they don't check pointers. |  | ||||||
| 
 |  | ||||||
| .. c:function:: char* PyByteArray_AS_STRING(PyObject *bytearray) |  | ||||||
| 
 |  | ||||||
|    Macro version of :c:func:`PyByteArray_AsString`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PyByteArray_GET_SIZE(PyObject *bytearray) |  | ||||||
| 
 |  | ||||||
|    Macro version of :c:func:`PyByteArray_Size`. |  | ||||||
							
								
								
									
										202
									
								
								third_party/python/Doc/c-api/bytes.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										202
									
								
								third_party/python/Doc/c-api/bytes.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,202 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _bytesobjects: |  | ||||||
| 
 |  | ||||||
| Bytes Objects |  | ||||||
| ------------- |  | ||||||
| 
 |  | ||||||
| These functions raise :exc:`TypeError` when expecting a bytes parameter and are |  | ||||||
| called with a non-bytes parameter. |  | ||||||
| 
 |  | ||||||
| .. index:: object: bytes |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyBytesObject |  | ||||||
| 
 |  | ||||||
|    This subtype of :c:type:`PyObject` represents a Python bytes object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyBytes_Type |  | ||||||
| 
 |  | ||||||
|    This instance of :c:type:`PyTypeObject` represents the Python bytes type; it |  | ||||||
|    is the same object as :class:`bytes` in the Python layer. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyBytes_Check(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return true if the object *o* is a bytes object or an instance of a subtype |  | ||||||
|    of the bytes type. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyBytes_CheckExact(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return true if the object *o* is a bytes object, but not an instance of a |  | ||||||
|    subtype of the bytes type. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyBytes_FromString(const char *v) |  | ||||||
| 
 |  | ||||||
|    Return a new bytes object with a copy of the string *v* as value on success, |  | ||||||
|    and *NULL* on failure.  The parameter *v* must not be *NULL*; it will not be |  | ||||||
|    checked. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyBytes_FromStringAndSize(const char *v, Py_ssize_t len) |  | ||||||
| 
 |  | ||||||
|    Return a new bytes object with a copy of the string *v* as value and length |  | ||||||
|    *len* on success, and *NULL* on failure.  If *v* is *NULL*, the contents of |  | ||||||
|    the bytes object are uninitialized. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyBytes_FromFormat(const char *format, ...) |  | ||||||
| 
 |  | ||||||
|    Take a C :c:func:`printf`\ -style *format* string and a variable number of |  | ||||||
|    arguments, calculate the size of the resulting Python bytes object and return |  | ||||||
|    a bytes object with the values formatted into it.  The variable arguments |  | ||||||
|    must be C types and must correspond exactly to the format characters in the |  | ||||||
|    *format* string.  The following format characters are allowed: |  | ||||||
| 
 |  | ||||||
|    .. % XXX: This should be exactly the same as the table in PyErr_Format. |  | ||||||
|    .. % One should just refer to the other. |  | ||||||
|    .. % XXX: The descriptions for %zd and %zu are wrong, but the truth is complicated |  | ||||||
|    .. % because not all compilers support the %z width modifier -- we fake it |  | ||||||
|    .. % when necessary via interpolating PY_FORMAT_SIZE_T. |  | ||||||
| 
 |  | ||||||
|    .. tabularcolumns:: |l|l|L| |  | ||||||
| 
 |  | ||||||
|    +-------------------+---------------+--------------------------------+ |  | ||||||
|    | Format Characters | Type          | Comment                        | |  | ||||||
|    +===================+===============+================================+ |  | ||||||
|    | :attr:`%%`        | *n/a*         | The literal % character.       | |  | ||||||
|    +-------------------+---------------+--------------------------------+ |  | ||||||
|    | :attr:`%c`        | int           | A single byte,                 | |  | ||||||
|    |                   |               | represented as a C int.        | |  | ||||||
|    +-------------------+---------------+--------------------------------+ |  | ||||||
|    | :attr:`%d`        | int           | Exactly equivalent to          | |  | ||||||
|    |                   |               | ``printf("%d")``.              | |  | ||||||
|    +-------------------+---------------+--------------------------------+ |  | ||||||
|    | :attr:`%u`        | unsigned int  | Exactly equivalent to          | |  | ||||||
|    |                   |               | ``printf("%u")``.              | |  | ||||||
|    +-------------------+---------------+--------------------------------+ |  | ||||||
|    | :attr:`%ld`       | long          | Exactly equivalent to          | |  | ||||||
|    |                   |               | ``printf("%ld")``.             | |  | ||||||
|    +-------------------+---------------+--------------------------------+ |  | ||||||
|    | :attr:`%lu`       | unsigned long | Exactly equivalent to          | |  | ||||||
|    |                   |               | ``printf("%lu")``.             | |  | ||||||
|    +-------------------+---------------+--------------------------------+ |  | ||||||
|    | :attr:`%zd`       | Py_ssize_t    | Exactly equivalent to          | |  | ||||||
|    |                   |               | ``printf("%zd")``.             | |  | ||||||
|    +-------------------+---------------+--------------------------------+ |  | ||||||
|    | :attr:`%zu`       | size_t        | Exactly equivalent to          | |  | ||||||
|    |                   |               | ``printf("%zu")``.             | |  | ||||||
|    +-------------------+---------------+--------------------------------+ |  | ||||||
|    | :attr:`%i`        | int           | Exactly equivalent to          | |  | ||||||
|    |                   |               | ``printf("%i")``.              | |  | ||||||
|    +-------------------+---------------+--------------------------------+ |  | ||||||
|    | :attr:`%x`        | int           | Exactly equivalent to          | |  | ||||||
|    |                   |               | ``printf("%x")``.              | |  | ||||||
|    +-------------------+---------------+--------------------------------+ |  | ||||||
|    | :attr:`%s`        | char\*        | A null-terminated C character  | |  | ||||||
|    |                   |               | array.                         | |  | ||||||
|    +-------------------+---------------+--------------------------------+ |  | ||||||
|    | :attr:`%p`        | void\*        | The hex representation of a C  | |  | ||||||
|    |                   |               | pointer. Mostly equivalent to  | |  | ||||||
|    |                   |               | ``printf("%p")`` except that   | |  | ||||||
|    |                   |               | it is guaranteed to start with | |  | ||||||
|    |                   |               | the literal ``0x`` regardless  | |  | ||||||
|    |                   |               | of what the platform's         | |  | ||||||
|    |                   |               | ``printf`` yields.             | |  | ||||||
|    +-------------------+---------------+--------------------------------+ |  | ||||||
| 
 |  | ||||||
|    An unrecognized format character causes all the rest of the format string to be |  | ||||||
|    copied as-is to the result object, and any extra arguments discarded. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyBytes_FromFormatV(const char *format, va_list vargs) |  | ||||||
| 
 |  | ||||||
|    Identical to :c:func:`PyBytes_FromFormat` except that it takes exactly two |  | ||||||
|    arguments. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyBytes_FromObject(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return the bytes representation of object *o* that implements the buffer |  | ||||||
|    protocol. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PyBytes_Size(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return the length of the bytes in bytes object *o*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PyBytes_GET_SIZE(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Macro form of :c:func:`PyBytes_Size` but without error checking. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: char* PyBytes_AsString(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return a pointer to the contents of *o*.  The pointer |  | ||||||
|    refers to the internal buffer of *o*, which consists of ``len(o) + 1`` |  | ||||||
|    bytes.  The last byte in the buffer is always null, regardless of |  | ||||||
|    whether there are any other null bytes.  The data must not be |  | ||||||
|    modified in any way, unless the object was just created using |  | ||||||
|    ``PyBytes_FromStringAndSize(NULL, size)``. It must not be deallocated.  If |  | ||||||
|    *o* is not a bytes object at all, :c:func:`PyBytes_AsString` returns *NULL* |  | ||||||
|    and raises :exc:`TypeError`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: char* PyBytes_AS_STRING(PyObject *string) |  | ||||||
| 
 |  | ||||||
|    Macro form of :c:func:`PyBytes_AsString` but without error checking. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyBytes_AsStringAndSize(PyObject *obj, char **buffer, Py_ssize_t *length) |  | ||||||
| 
 |  | ||||||
|    Return the null-terminated contents of the object *obj* |  | ||||||
|    through the output variables *buffer* and *length*. |  | ||||||
| 
 |  | ||||||
|    If *length* is *NULL*, the bytes object |  | ||||||
|    may not contain embedded null bytes; |  | ||||||
|    if it does, the function returns ``-1`` and a :exc:`ValueError` is raised. |  | ||||||
| 
 |  | ||||||
|    The buffer refers to an internal buffer of *obj*, which includes an |  | ||||||
|    additional null byte at the end (not counted in *length*).  The data |  | ||||||
|    must not be modified in any way, unless the object was just created using |  | ||||||
|    ``PyBytes_FromStringAndSize(NULL, size)``.  It must not be deallocated.  If |  | ||||||
|    *obj* is not a bytes object at all, :c:func:`PyBytes_AsStringAndSize` |  | ||||||
|    returns ``-1`` and raises :exc:`TypeError`. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.5 |  | ||||||
|       Previously, :exc:`TypeError` was raised when embedded null bytes were |  | ||||||
|       encountered in the bytes object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyBytes_Concat(PyObject **bytes, PyObject *newpart) |  | ||||||
| 
 |  | ||||||
|    Create a new bytes object in *\*bytes* containing the contents of *newpart* |  | ||||||
|    appended to *bytes*; the caller will own the new reference.  The reference to |  | ||||||
|    the old value of *bytes* will be stolen.  If the new object cannot be |  | ||||||
|    created, the old reference to *bytes* will still be discarded and the value |  | ||||||
|    of *\*bytes* will be set to *NULL*; the appropriate exception will be set. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyBytes_ConcatAndDel(PyObject **bytes, PyObject *newpart) |  | ||||||
| 
 |  | ||||||
|    Create a new bytes object in *\*bytes* containing the contents of *newpart* |  | ||||||
|    appended to *bytes*.  This version decrements the reference count of |  | ||||||
|    *newpart*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int _PyBytes_Resize(PyObject **bytes, Py_ssize_t newsize) |  | ||||||
| 
 |  | ||||||
|    A way to resize a bytes object even though it is "immutable". Only use this |  | ||||||
|    to build up a brand new bytes object; don't use this if the bytes may already |  | ||||||
|    be known in other parts of the code.  It is an error to call this function if |  | ||||||
|    the refcount on the input bytes object is not one. Pass the address of an |  | ||||||
|    existing bytes object as an lvalue (it may be written into), and the new size |  | ||||||
|    desired.  On success, *\*bytes* holds the resized bytes object and ``0`` is |  | ||||||
|    returned; the address in *\*bytes* may differ from its input value.  If the |  | ||||||
|    reallocation fails, the original bytes object at *\*bytes* is deallocated, |  | ||||||
|    *\*bytes* is set to *NULL*, :exc:`MemoryError` is set, and ``-1`` is |  | ||||||
|    returned. |  | ||||||
							
								
								
									
										157
									
								
								third_party/python/Doc/c-api/capsule.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										157
									
								
								third_party/python/Doc/c-api/capsule.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,157 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _capsules: |  | ||||||
| 
 |  | ||||||
| Capsules |  | ||||||
| -------- |  | ||||||
| 
 |  | ||||||
| .. index:: object: Capsule |  | ||||||
| 
 |  | ||||||
| Refer to :ref:`using-capsules` for more information on using these objects. |  | ||||||
| 
 |  | ||||||
| .. versionadded:: 3.1 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyCapsule |  | ||||||
| 
 |  | ||||||
|    This subtype of :c:type:`PyObject` represents an opaque value, useful for C |  | ||||||
|    extension modules who need to pass an opaque value (as a :c:type:`void\*` |  | ||||||
|    pointer) through Python code to other C code.  It is often used to make a C |  | ||||||
|    function pointer defined in one module available to other modules, so the |  | ||||||
|    regular import mechanism can be used to access C APIs defined in dynamically |  | ||||||
|    loaded modules. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyCapsule_Destructor |  | ||||||
| 
 |  | ||||||
|    The type of a destructor callback for a capsule.  Defined as:: |  | ||||||
| 
 |  | ||||||
|       typedef void (*PyCapsule_Destructor)(PyObject *); |  | ||||||
| 
 |  | ||||||
|    See :c:func:`PyCapsule_New` for the semantics of PyCapsule_Destructor |  | ||||||
|    callbacks. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyCapsule_CheckExact(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if its argument is a :c:type:`PyCapsule`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCapsule_New(void *pointer, const char *name, PyCapsule_Destructor destructor) |  | ||||||
| 
 |  | ||||||
|    Create a :c:type:`PyCapsule` encapsulating the *pointer*.  The *pointer* |  | ||||||
|    argument may not be *NULL*. |  | ||||||
| 
 |  | ||||||
|    On failure, set an exception and return *NULL*. |  | ||||||
| 
 |  | ||||||
|    The *name* string may either be *NULL* or a pointer to a valid C string.  If |  | ||||||
|    non-*NULL*, this string must outlive the capsule.  (Though it is permitted to |  | ||||||
|    free it inside the *destructor*.) |  | ||||||
| 
 |  | ||||||
|    If the *destructor* argument is not *NULL*, it will be called with the |  | ||||||
|    capsule as its argument when it is destroyed. |  | ||||||
| 
 |  | ||||||
|    If this capsule will be stored as an attribute of a module, the *name* should |  | ||||||
|    be specified as ``modulename.attributename``.  This will enable other modules |  | ||||||
|    to import the capsule using :c:func:`PyCapsule_Import`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void* PyCapsule_GetPointer(PyObject *capsule, const char *name) |  | ||||||
| 
 |  | ||||||
|    Retrieve the *pointer* stored in the capsule.  On failure, set an exception |  | ||||||
|    and return *NULL*. |  | ||||||
| 
 |  | ||||||
|    The *name* parameter must compare exactly to the name stored in the capsule. |  | ||||||
|    If the name stored in the capsule is *NULL*, the *name* passed in must also |  | ||||||
|    be *NULL*.  Python uses the C function :c:func:`strcmp` to compare capsule |  | ||||||
|    names. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyCapsule_Destructor PyCapsule_GetDestructor(PyObject *capsule) |  | ||||||
| 
 |  | ||||||
|    Return the current destructor stored in the capsule.  On failure, set an |  | ||||||
|    exception and return *NULL*. |  | ||||||
| 
 |  | ||||||
|    It is legal for a capsule to have a *NULL* destructor.  This makes a *NULL* |  | ||||||
|    return code somewhat ambiguous; use :c:func:`PyCapsule_IsValid` or |  | ||||||
|    :c:func:`PyErr_Occurred` to disambiguate. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void* PyCapsule_GetContext(PyObject *capsule) |  | ||||||
| 
 |  | ||||||
|    Return the current context stored in the capsule.  On failure, set an |  | ||||||
|    exception and return *NULL*. |  | ||||||
| 
 |  | ||||||
|    It is legal for a capsule to have a *NULL* context.  This makes a *NULL* |  | ||||||
|    return code somewhat ambiguous; use :c:func:`PyCapsule_IsValid` or |  | ||||||
|    :c:func:`PyErr_Occurred` to disambiguate. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: const char* PyCapsule_GetName(PyObject *capsule) |  | ||||||
| 
 |  | ||||||
|    Return the current name stored in the capsule.  On failure, set an exception |  | ||||||
|    and return *NULL*. |  | ||||||
| 
 |  | ||||||
|    It is legal for a capsule to have a *NULL* name.  This makes a *NULL* return |  | ||||||
|    code somewhat ambiguous; use :c:func:`PyCapsule_IsValid` or |  | ||||||
|    :c:func:`PyErr_Occurred` to disambiguate. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void* PyCapsule_Import(const char *name, int no_block) |  | ||||||
| 
 |  | ||||||
|    Import a pointer to a C object from a capsule attribute in a module.  The |  | ||||||
|    *name* parameter should specify the full name to the attribute, as in |  | ||||||
|    ``module.attribute``.  The *name* stored in the capsule must match this |  | ||||||
|    string exactly.  If *no_block* is true, import the module without blocking |  | ||||||
|    (using :c:func:`PyImport_ImportModuleNoBlock`).  If *no_block* is false, |  | ||||||
|    import the module conventionally (using :c:func:`PyImport_ImportModule`). |  | ||||||
| 
 |  | ||||||
|    Return the capsule's internal *pointer* on success.  On failure, set an |  | ||||||
|    exception and return *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyCapsule_IsValid(PyObject *capsule, const char *name) |  | ||||||
| 
 |  | ||||||
|    Determines whether or not *capsule* is a valid capsule.  A valid capsule is |  | ||||||
|    non-*NULL*, passes :c:func:`PyCapsule_CheckExact`, has a non-*NULL* pointer |  | ||||||
|    stored in it, and its internal name matches the *name* parameter.  (See |  | ||||||
|    :c:func:`PyCapsule_GetPointer` for information on how capsule names are |  | ||||||
|    compared.) |  | ||||||
| 
 |  | ||||||
|    In other words, if :c:func:`PyCapsule_IsValid` returns a true value, calls to |  | ||||||
|    any of the accessors (any function starting with :c:func:`PyCapsule_Get`) are |  | ||||||
|    guaranteed to succeed. |  | ||||||
| 
 |  | ||||||
|    Return a nonzero value if the object is valid and matches the name passed in. |  | ||||||
|    Return ``0`` otherwise.  This function will not fail. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyCapsule_SetContext(PyObject *capsule, void *context) |  | ||||||
| 
 |  | ||||||
|    Set the context pointer inside *capsule* to *context*. |  | ||||||
| 
 |  | ||||||
|    Return ``0`` on success.  Return nonzero and set an exception on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyCapsule_SetDestructor(PyObject *capsule, PyCapsule_Destructor destructor) |  | ||||||
| 
 |  | ||||||
|    Set the destructor inside *capsule* to *destructor*. |  | ||||||
| 
 |  | ||||||
|    Return ``0`` on success.  Return nonzero and set an exception on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyCapsule_SetName(PyObject *capsule, const char *name) |  | ||||||
| 
 |  | ||||||
|    Set the name inside *capsule* to *name*.  If non-*NULL*, the name must |  | ||||||
|    outlive the capsule.  If the previous *name* stored in the capsule was not |  | ||||||
|    *NULL*, no attempt is made to free it. |  | ||||||
| 
 |  | ||||||
|    Return ``0`` on success.  Return nonzero and set an exception on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyCapsule_SetPointer(PyObject *capsule, void *pointer) |  | ||||||
| 
 |  | ||||||
|    Set the void pointer inside *capsule* to *pointer*.  The pointer may not be |  | ||||||
|    *NULL*. |  | ||||||
| 
 |  | ||||||
|    Return ``0`` on success.  Return nonzero and set an exception on failure. |  | ||||||
							
								
								
									
										62
									
								
								third_party/python/Doc/c-api/cell.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										62
									
								
								third_party/python/Doc/c-api/cell.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,62 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _cell-objects: |  | ||||||
| 
 |  | ||||||
| Cell Objects |  | ||||||
| ------------ |  | ||||||
| 
 |  | ||||||
| "Cell" objects are used to implement variables referenced by multiple scopes. |  | ||||||
| For each such variable, a cell object is created to store the value; the local |  | ||||||
| variables of each stack frame that references the value contains a reference to |  | ||||||
| the cells from outer scopes which also use that variable.  When the value is |  | ||||||
| accessed, the value contained in the cell is used instead of the cell object |  | ||||||
| itself.  This de-referencing of the cell object requires support from the |  | ||||||
| generated byte-code; these are not automatically de-referenced when accessed. |  | ||||||
| Cell objects are not likely to be useful elsewhere. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyCellObject |  | ||||||
| 
 |  | ||||||
|    The C structure used for cell objects. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyCell_Type |  | ||||||
| 
 |  | ||||||
|    The type object corresponding to cell objects. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyCell_Check(ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob* is a cell object; *ob* must not be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCell_New(PyObject *ob) |  | ||||||
| 
 |  | ||||||
|    Create and return a new cell object containing the value *ob*. The parameter may |  | ||||||
|    be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCell_Get(PyObject *cell) |  | ||||||
| 
 |  | ||||||
|    Return the contents of the cell *cell*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCell_GET(PyObject *cell) |  | ||||||
| 
 |  | ||||||
|    Return the contents of the cell *cell*, but without checking that *cell* is |  | ||||||
|    non-*NULL* and a cell object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyCell_Set(PyObject *cell, PyObject *value) |  | ||||||
| 
 |  | ||||||
|    Set the contents of the cell object *cell* to *value*.  This releases the |  | ||||||
|    reference to any current content of the cell. *value* may be *NULL*.  *cell* |  | ||||||
|    must be non-*NULL*; if it is not a cell object, ``-1`` will be returned.  On |  | ||||||
|    success, ``0`` will be returned. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyCell_SET(PyObject *cell, PyObject *value) |  | ||||||
| 
 |  | ||||||
|    Sets the value of the cell object *cell* to *value*.  No reference counts are |  | ||||||
|    adjusted, and no checks are made for safety; *cell* must be non-*NULL* and must |  | ||||||
|    be a cell object. |  | ||||||
							
								
								
									
										48
									
								
								third_party/python/Doc/c-api/code.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										48
									
								
								third_party/python/Doc/c-api/code.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,48 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _codeobjects: |  | ||||||
| 
 |  | ||||||
| .. index:: object; code, code object |  | ||||||
| 
 |  | ||||||
| Code Objects |  | ||||||
| ------------ |  | ||||||
| 
 |  | ||||||
| .. sectionauthor:: Jeffrey Yasskin <jyasskin@gmail.com> |  | ||||||
| 
 |  | ||||||
| Code objects are a low-level detail of the CPython implementation. |  | ||||||
| Each one represents a chunk of executable code that hasn't yet been |  | ||||||
| bound into a function. |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyCodeObject |  | ||||||
| 
 |  | ||||||
|    The C structure of the objects used to describe code objects.  The |  | ||||||
|    fields of this type are subject to change at any time. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyCode_Type |  | ||||||
| 
 |  | ||||||
|    This is an instance of :c:type:`PyTypeObject` representing the Python |  | ||||||
|    :class:`code` type. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyCode_Check(PyObject *co) |  | ||||||
| 
 |  | ||||||
|    Return true if *co* is a :class:`code` object. |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyCode_GetNumFree(PyCodeObject *co) |  | ||||||
| 
 |  | ||||||
|    Return the number of free variables in *co*. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyCodeObject* PyCode_New(int argcount, int kwonlyargcount, int nlocals, int stacksize, int flags, PyObject *code, PyObject *consts, PyObject *names, PyObject *varnames, PyObject *freevars, PyObject *cellvars, PyObject *filename, PyObject *name, int firstlineno, PyObject *lnotab) |  | ||||||
| 
 |  | ||||||
|    Return a new code object.  If you need a dummy code object to |  | ||||||
|    create a frame, use :c:func:`PyCode_NewEmpty` instead.  Calling |  | ||||||
|    :c:func:`PyCode_New` directly can bind you to a precise Python |  | ||||||
|    version since the definition of the bytecode changes often. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyCodeObject* PyCode_NewEmpty(const char *filename, const char *funcname, int firstlineno) |  | ||||||
| 
 |  | ||||||
|    Return a new empty code object with the specified filename, |  | ||||||
|    function name, and first line number.  It is illegal to |  | ||||||
|    :func:`exec` or :func:`eval` the resulting code object. |  | ||||||
							
								
								
									
										123
									
								
								third_party/python/Doc/c-api/codec.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										123
									
								
								third_party/python/Doc/c-api/codec.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,123 +0,0 @@ | ||||||
| .. _codec-registry: |  | ||||||
| 
 |  | ||||||
| Codec registry and support functions |  | ||||||
| ==================================== |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyCodec_Register(PyObject *search_function) |  | ||||||
| 
 |  | ||||||
|    Register a new codec search function. |  | ||||||
| 
 |  | ||||||
|    As side effect, this tries to load the :mod:`encodings` package, if not yet |  | ||||||
|    done, to make sure that it is always first in the list of search functions. |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyCodec_KnownEncoding(const char *encoding) |  | ||||||
| 
 |  | ||||||
|    Return ``1`` or ``0`` depending on whether there is a registered codec for |  | ||||||
|    the given *encoding*.  This function always succeeds. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCodec_Encode(PyObject *object, const char *encoding, const char *errors) |  | ||||||
| 
 |  | ||||||
|    Generic codec based encoding API. |  | ||||||
| 
 |  | ||||||
|    *object* is passed through the encoder function found for the given |  | ||||||
|    *encoding* using the error handling method defined by *errors*.  *errors* may |  | ||||||
|    be *NULL* to use the default method defined for the codec.  Raises a |  | ||||||
|    :exc:`LookupError` if no encoder can be found. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCodec_Decode(PyObject *object, const char *encoding, const char *errors) |  | ||||||
| 
 |  | ||||||
|    Generic codec based decoding API. |  | ||||||
| 
 |  | ||||||
|    *object* is passed through the decoder function found for the given |  | ||||||
|    *encoding* using the error handling method defined by *errors*.  *errors* may |  | ||||||
|    be *NULL* to use the default method defined for the codec.  Raises a |  | ||||||
|    :exc:`LookupError` if no encoder can be found. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Codec lookup API |  | ||||||
| ---------------- |  | ||||||
| 
 |  | ||||||
| In the following functions, the *encoding* string is looked up converted to all |  | ||||||
| lower-case characters, which makes encodings looked up through this mechanism |  | ||||||
| effectively case-insensitive.  If no codec is found, a :exc:`KeyError` is set |  | ||||||
| and *NULL* returned. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCodec_Encoder(const char *encoding) |  | ||||||
| 
 |  | ||||||
|    Get an encoder function for the given *encoding*. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCodec_Decoder(const char *encoding) |  | ||||||
| 
 |  | ||||||
|    Get a decoder function for the given *encoding*. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCodec_IncrementalEncoder(const char *encoding, const char *errors) |  | ||||||
| 
 |  | ||||||
|    Get an :class:`~codecs.IncrementalEncoder` object for the given *encoding*. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCodec_IncrementalDecoder(const char *encoding, const char *errors) |  | ||||||
| 
 |  | ||||||
|    Get an :class:`~codecs.IncrementalDecoder` object for the given *encoding*. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCodec_StreamReader(const char *encoding, PyObject *stream, const char *errors) |  | ||||||
| 
 |  | ||||||
|    Get a :class:`~codecs.StreamReader` factory function for the given *encoding*. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCodec_StreamWriter(const char *encoding, PyObject *stream, const char *errors) |  | ||||||
| 
 |  | ||||||
|    Get a :class:`~codecs.StreamWriter` factory function for the given *encoding*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Registry API for Unicode encoding error handlers |  | ||||||
| ------------------------------------------------ |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyCodec_RegisterError(const char *name, PyObject *error) |  | ||||||
| 
 |  | ||||||
|    Register the error handling callback function *error* under the given *name*. |  | ||||||
|    This callback function will be called by a codec when it encounters |  | ||||||
|    unencodable characters/undecodable bytes and *name* is specified as the error |  | ||||||
|    parameter in the call to the encode/decode function. |  | ||||||
| 
 |  | ||||||
|    The callback gets a single argument, an instance of |  | ||||||
|    :exc:`UnicodeEncodeError`, :exc:`UnicodeDecodeError` or |  | ||||||
|    :exc:`UnicodeTranslateError` that holds information about the problematic |  | ||||||
|    sequence of characters or bytes and their offset in the original string (see |  | ||||||
|    :ref:`unicodeexceptions` for functions to extract this information).  The |  | ||||||
|    callback must either raise the given exception, or return a two-item tuple |  | ||||||
|    containing the replacement for the problematic sequence, and an integer |  | ||||||
|    giving the offset in the original string at which encoding/decoding should be |  | ||||||
|    resumed. |  | ||||||
| 
 |  | ||||||
|    Return ``0`` on success, ``-1`` on error. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCodec_LookupError(const char *name) |  | ||||||
| 
 |  | ||||||
|    Lookup the error handling callback function registered under *name*.  As a |  | ||||||
|    special case *NULL* can be passed, in which case the error handling callback |  | ||||||
|    for "strict" will be returned. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCodec_StrictErrors(PyObject *exc) |  | ||||||
| 
 |  | ||||||
|    Raise *exc* as an exception. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCodec_IgnoreErrors(PyObject *exc) |  | ||||||
| 
 |  | ||||||
|    Ignore the unicode error, skipping the faulty input. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCodec_ReplaceErrors(PyObject *exc) |  | ||||||
| 
 |  | ||||||
|    Replace the unicode encode error with ``?`` or ``U+FFFD``. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCodec_XMLCharRefReplaceErrors(PyObject *exc) |  | ||||||
| 
 |  | ||||||
|    Replace the unicode encode error with XML character references. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCodec_BackslashReplaceErrors(PyObject *exc) |  | ||||||
| 
 |  | ||||||
|    Replace the unicode encode error with backslash escapes (``\x``, ``\u`` and |  | ||||||
|    ``\U``). |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCodec_NameReplaceErrors(PyObject *exc) |  | ||||||
| 
 |  | ||||||
|    Replace the unicode encode error with ``\N{...}`` escapes. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.5 |  | ||||||
							
								
								
									
										132
									
								
								third_party/python/Doc/c-api/complex.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										132
									
								
								third_party/python/Doc/c-api/complex.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,132 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _complexobjects: |  | ||||||
| 
 |  | ||||||
| Complex Number Objects |  | ||||||
| ---------------------- |  | ||||||
| 
 |  | ||||||
| .. index:: object: complex number |  | ||||||
| 
 |  | ||||||
| Python's complex number objects are implemented as two distinct types when |  | ||||||
| viewed from the C API:  one is the Python object exposed to Python programs, and |  | ||||||
| the other is a C structure which represents the actual complex number value. |  | ||||||
| The API provides functions for working with both. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Complex Numbers as C Structures |  | ||||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |  | ||||||
| 
 |  | ||||||
| Note that the functions which accept these structures as parameters and return |  | ||||||
| them as results do so *by value* rather than dereferencing them through |  | ||||||
| pointers.  This is consistent throughout the API. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: Py_complex |  | ||||||
| 
 |  | ||||||
|    The C structure which corresponds to the value portion of a Python complex |  | ||||||
|    number object.  Most of the functions for dealing with complex number objects |  | ||||||
|    use structures of this type as input or output values, as appropriate.  It is |  | ||||||
|    defined as:: |  | ||||||
| 
 |  | ||||||
|       typedef struct { |  | ||||||
|          double real; |  | ||||||
|          double imag; |  | ||||||
|       } Py_complex; |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_complex _Py_c_sum(Py_complex left, Py_complex right) |  | ||||||
| 
 |  | ||||||
|    Return the sum of two complex numbers, using the C :c:type:`Py_complex` |  | ||||||
|    representation. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_complex _Py_c_diff(Py_complex left, Py_complex right) |  | ||||||
| 
 |  | ||||||
|    Return the difference between two complex numbers, using the C |  | ||||||
|    :c:type:`Py_complex` representation. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_complex _Py_c_neg(Py_complex complex) |  | ||||||
| 
 |  | ||||||
|    Return the negation of the complex number *complex*, using the C |  | ||||||
|    :c:type:`Py_complex` representation. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_complex _Py_c_prod(Py_complex left, Py_complex right) |  | ||||||
| 
 |  | ||||||
|    Return the product of two complex numbers, using the C :c:type:`Py_complex` |  | ||||||
|    representation. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_complex _Py_c_quot(Py_complex dividend, Py_complex divisor) |  | ||||||
| 
 |  | ||||||
|    Return the quotient of two complex numbers, using the C :c:type:`Py_complex` |  | ||||||
|    representation. |  | ||||||
| 
 |  | ||||||
|    If *divisor* is null, this method returns zero and sets |  | ||||||
|    :c:data:`errno` to :c:data:`EDOM`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_complex _Py_c_pow(Py_complex num, Py_complex exp) |  | ||||||
| 
 |  | ||||||
|    Return the exponentiation of *num* by *exp*, using the C :c:type:`Py_complex` |  | ||||||
|    representation. |  | ||||||
| 
 |  | ||||||
|    If *num* is null and *exp* is not a positive real number, |  | ||||||
|    this method returns zero and sets :c:data:`errno` to :c:data:`EDOM`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Complex Numbers as Python Objects |  | ||||||
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyComplexObject |  | ||||||
| 
 |  | ||||||
|    This subtype of :c:type:`PyObject` represents a Python complex number object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyComplex_Type |  | ||||||
| 
 |  | ||||||
|    This instance of :c:type:`PyTypeObject` represents the Python complex number |  | ||||||
|    type. It is the same object as :class:`complex` in the Python layer. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyComplex_Check(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if its argument is a :c:type:`PyComplexObject` or a subtype of |  | ||||||
|    :c:type:`PyComplexObject`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyComplex_CheckExact(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if its argument is a :c:type:`PyComplexObject`, but not a subtype of |  | ||||||
|    :c:type:`PyComplexObject`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyComplex_FromCComplex(Py_complex v) |  | ||||||
| 
 |  | ||||||
|    Create a new Python complex number object from a C :c:type:`Py_complex` value. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyComplex_FromDoubles(double real, double imag) |  | ||||||
| 
 |  | ||||||
|    Return a new :c:type:`PyComplexObject` object from *real* and *imag*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: double PyComplex_RealAsDouble(PyObject *op) |  | ||||||
| 
 |  | ||||||
|    Return the real part of *op* as a C :c:type:`double`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: double PyComplex_ImagAsDouble(PyObject *op) |  | ||||||
| 
 |  | ||||||
|    Return the imaginary part of *op* as a C :c:type:`double`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_complex PyComplex_AsCComplex(PyObject *op) |  | ||||||
| 
 |  | ||||||
|    Return the :c:type:`Py_complex` value of the complex number *op*. |  | ||||||
| 
 |  | ||||||
|    If *op* is not a Python complex number object but has a :meth:`__complex__` |  | ||||||
|    method, this method will first be called to convert *op* to a Python complex |  | ||||||
|    number object. Upon failure, this method returns ``-1.0`` as a real value. |  | ||||||
							
								
								
									
										117
									
								
								third_party/python/Doc/c-api/concrete.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										117
									
								
								third_party/python/Doc/c-api/concrete.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,117 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _concrete: |  | ||||||
| 
 |  | ||||||
| ********************** |  | ||||||
| Concrete Objects Layer |  | ||||||
| ********************** |  | ||||||
| 
 |  | ||||||
| The functions in this chapter are specific to certain Python object types. |  | ||||||
| Passing them an object of the wrong type is not a good idea; if you receive an |  | ||||||
| object from a Python program and you are not sure that it has the right type, |  | ||||||
| you must perform a type check first; for example, to check that an object is a |  | ||||||
| dictionary, use :c:func:`PyDict_Check`.  The chapter is structured like the |  | ||||||
| "family tree" of Python object types. |  | ||||||
| 
 |  | ||||||
| .. warning:: |  | ||||||
| 
 |  | ||||||
|    While the functions described in this chapter carefully check the type of the |  | ||||||
|    objects which are passed in, many of them do not check for *NULL* being passed |  | ||||||
|    instead of a valid object.  Allowing *NULL* to be passed in can cause memory |  | ||||||
|    access violations and immediate termination of the interpreter. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _fundamental: |  | ||||||
| 
 |  | ||||||
| Fundamental Objects |  | ||||||
| =================== |  | ||||||
| 
 |  | ||||||
| This section describes Python type objects and the singleton object ``None``. |  | ||||||
| 
 |  | ||||||
| .. toctree:: |  | ||||||
| 
 |  | ||||||
|    type.rst |  | ||||||
|    none.rst |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _numericobjects: |  | ||||||
| 
 |  | ||||||
| Numeric Objects |  | ||||||
| =============== |  | ||||||
| 
 |  | ||||||
| .. index:: object: numeric |  | ||||||
| 
 |  | ||||||
| .. toctree:: |  | ||||||
| 
 |  | ||||||
|    long.rst |  | ||||||
|    bool.rst |  | ||||||
|    float.rst |  | ||||||
|    complex.rst |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _sequenceobjects: |  | ||||||
| 
 |  | ||||||
| Sequence Objects |  | ||||||
| ================ |  | ||||||
| 
 |  | ||||||
| .. index:: object: sequence |  | ||||||
| 
 |  | ||||||
| Generic operations on sequence objects were discussed in the previous chapter; |  | ||||||
| this section deals with the specific kinds of sequence objects that are |  | ||||||
| intrinsic to the Python language. |  | ||||||
| 
 |  | ||||||
| .. XXX sort out unicode, str, bytes and bytearray |  | ||||||
| 
 |  | ||||||
| .. toctree:: |  | ||||||
| 
 |  | ||||||
|    bytes.rst |  | ||||||
|    bytearray.rst |  | ||||||
|    unicode.rst |  | ||||||
|    tuple.rst |  | ||||||
|    list.rst |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _mapobjects: |  | ||||||
| 
 |  | ||||||
| Container Objects |  | ||||||
| ================= |  | ||||||
| 
 |  | ||||||
| .. index:: object: mapping |  | ||||||
| 
 |  | ||||||
| .. toctree:: |  | ||||||
| 
 |  | ||||||
|    dict.rst |  | ||||||
|    set.rst |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _otherobjects: |  | ||||||
| 
 |  | ||||||
| Function Objects |  | ||||||
| ================ |  | ||||||
| 
 |  | ||||||
| .. toctree:: |  | ||||||
| 
 |  | ||||||
|    function.rst |  | ||||||
|    method.rst |  | ||||||
|    cell.rst |  | ||||||
|    code.rst |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Other Objects |  | ||||||
| ============= |  | ||||||
| 
 |  | ||||||
| .. toctree:: |  | ||||||
| 
 |  | ||||||
|    file.rst |  | ||||||
|    module.rst |  | ||||||
|    iterator.rst |  | ||||||
|    descriptor.rst |  | ||||||
|    slice.rst |  | ||||||
|    memoryview.rst |  | ||||||
|    weakref.rst |  | ||||||
|    capsule.rst |  | ||||||
|    gen.rst |  | ||||||
|    coro.rst |  | ||||||
|    datetime.rst |  | ||||||
| 
 |  | ||||||
							
								
								
									
										131
									
								
								third_party/python/Doc/c-api/conversion.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										131
									
								
								third_party/python/Doc/c-api/conversion.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,131 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _string-conversion: |  | ||||||
| 
 |  | ||||||
| String conversion and formatting |  | ||||||
| ================================ |  | ||||||
| 
 |  | ||||||
| Functions for number conversion and formatted string output. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyOS_snprintf(char *str, size_t size,  const char *format, ...) |  | ||||||
| 
 |  | ||||||
|    Output not more than *size* bytes to *str* according to the format string |  | ||||||
|    *format* and the extra arguments. See the Unix man page :manpage:`snprintf(2)`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyOS_vsnprintf(char *str, size_t size, const char *format, va_list va) |  | ||||||
| 
 |  | ||||||
|    Output not more than *size* bytes to *str* according to the format string |  | ||||||
|    *format* and the variable argument list *va*. Unix man page |  | ||||||
|    :manpage:`vsnprintf(2)`. |  | ||||||
| 
 |  | ||||||
| :c:func:`PyOS_snprintf` and :c:func:`PyOS_vsnprintf` wrap the Standard C library |  | ||||||
| functions :c:func:`snprintf` and :c:func:`vsnprintf`. Their purpose is to |  | ||||||
| guarantee consistent behavior in corner cases, which the Standard C functions do |  | ||||||
| not. |  | ||||||
| 
 |  | ||||||
| The wrappers ensure that *str*[*size*-1] is always ``'\0'`` upon return. They |  | ||||||
| never write more than *size* bytes (including the trailing ``'\0'``) into str. |  | ||||||
| Both functions require that ``str != NULL``, ``size > 0`` and ``format != |  | ||||||
| NULL``. |  | ||||||
| 
 |  | ||||||
| If the platform doesn't have :c:func:`vsnprintf` and the buffer size needed to |  | ||||||
| avoid truncation exceeds *size* by more than 512 bytes, Python aborts with a |  | ||||||
| *Py_FatalError*. |  | ||||||
| 
 |  | ||||||
| The return value (*rv*) for these functions should be interpreted as follows: |  | ||||||
| 
 |  | ||||||
| * When ``0 <= rv < size``, the output conversion was successful and *rv* |  | ||||||
|   characters were written to *str* (excluding the trailing ``'\0'`` byte at |  | ||||||
|   *str*[*rv*]). |  | ||||||
| 
 |  | ||||||
| * When ``rv >= size``, the output conversion was truncated and a buffer with |  | ||||||
|   ``rv + 1`` bytes would have been needed to succeed. *str*[*size*-1] is ``'\0'`` |  | ||||||
|   in this case. |  | ||||||
| 
 |  | ||||||
| * When ``rv < 0``, "something bad happened." *str*[*size*-1] is ``'\0'`` in |  | ||||||
|   this case too, but the rest of *str* is undefined. The exact cause of the error |  | ||||||
|   depends on the underlying platform. |  | ||||||
| 
 |  | ||||||
| The following functions provide locale-independent string to number conversions. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: double PyOS_string_to_double(const char *s, char **endptr, PyObject *overflow_exception) |  | ||||||
| 
 |  | ||||||
|    Convert a string ``s`` to a :c:type:`double`, raising a Python |  | ||||||
|    exception on failure.  The set of accepted strings corresponds to |  | ||||||
|    the set of strings accepted by Python's :func:`float` constructor, |  | ||||||
|    except that ``s`` must not have leading or trailing whitespace. |  | ||||||
|    The conversion is independent of the current locale. |  | ||||||
| 
 |  | ||||||
|    If ``endptr`` is ``NULL``, convert the whole string.  Raise |  | ||||||
|    ValueError and return ``-1.0`` if the string is not a valid |  | ||||||
|    representation of a floating-point number. |  | ||||||
| 
 |  | ||||||
|    If endptr is not ``NULL``, convert as much of the string as |  | ||||||
|    possible and set ``*endptr`` to point to the first unconverted |  | ||||||
|    character.  If no initial segment of the string is the valid |  | ||||||
|    representation of a floating-point number, set ``*endptr`` to point |  | ||||||
|    to the beginning of the string, raise ValueError, and return |  | ||||||
|    ``-1.0``. |  | ||||||
| 
 |  | ||||||
|    If ``s`` represents a value that is too large to store in a float |  | ||||||
|    (for example, ``"1e500"`` is such a string on many platforms) then |  | ||||||
|    if ``overflow_exception`` is ``NULL`` return ``Py_HUGE_VAL`` (with |  | ||||||
|    an appropriate sign) and don't set any exception.  Otherwise, |  | ||||||
|    ``overflow_exception`` must point to a Python exception object; |  | ||||||
|    raise that exception and return ``-1.0``.  In both cases, set |  | ||||||
|    ``*endptr`` to point to the first character after the converted value. |  | ||||||
| 
 |  | ||||||
|    If any other error occurs during the conversion (for example an |  | ||||||
|    out-of-memory error), set the appropriate Python exception and |  | ||||||
|    return ``-1.0``. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.1 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: char* PyOS_double_to_string(double val, char format_code, int precision, int flags, int *ptype) |  | ||||||
| 
 |  | ||||||
|    Convert a :c:type:`double` *val* to a string using supplied |  | ||||||
|    *format_code*, *precision*, and *flags*. |  | ||||||
| 
 |  | ||||||
|    *format_code* must be one of ``'e'``, ``'E'``, ``'f'``, ``'F'``, |  | ||||||
|    ``'g'``, ``'G'`` or ``'r'``.  For ``'r'``, the supplied *precision* |  | ||||||
|    must be 0 and is ignored.  The ``'r'`` format code specifies the |  | ||||||
|    standard :func:`repr` format. |  | ||||||
| 
 |  | ||||||
|    *flags* can be zero or more of the values *Py_DTSF_SIGN*, |  | ||||||
|    *Py_DTSF_ADD_DOT_0*, or *Py_DTSF_ALT*, or-ed together: |  | ||||||
| 
 |  | ||||||
|    * *Py_DTSF_SIGN* means to always precede the returned string with a sign |  | ||||||
|      character, even if *val* is non-negative. |  | ||||||
| 
 |  | ||||||
|    * *Py_DTSF_ADD_DOT_0* means to ensure that the returned string will not look |  | ||||||
|      like an integer. |  | ||||||
| 
 |  | ||||||
|    * *Py_DTSF_ALT* means to apply "alternate" formatting rules.  See the |  | ||||||
|      documentation for the :c:func:`PyOS_snprintf` ``'#'`` specifier for |  | ||||||
|      details. |  | ||||||
| 
 |  | ||||||
|    If *ptype* is non-NULL, then the value it points to will be set to one of |  | ||||||
|    *Py_DTST_FINITE*, *Py_DTST_INFINITE*, or *Py_DTST_NAN*, signifying that |  | ||||||
|    *val* is a finite number, an infinite number, or not a number, respectively. |  | ||||||
| 
 |  | ||||||
|    The return value is a pointer to *buffer* with the converted string or |  | ||||||
|    *NULL* if the conversion failed. The caller is responsible for freeing the |  | ||||||
|    returned string by calling :c:func:`PyMem_Free`. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.1 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyOS_stricmp(const char *s1, const char *s2) |  | ||||||
| 
 |  | ||||||
|    Case insensitive comparison of strings. The function works almost |  | ||||||
|    identically to :c:func:`strcmp` except that it ignores the case. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyOS_strnicmp(const char *s1, const char *s2, Py_ssize_t  size) |  | ||||||
| 
 |  | ||||||
|    Case insensitive comparison of strings. The function works almost |  | ||||||
|    identically to :c:func:`strncmp` except that it ignores the case. |  | ||||||
							
								
								
									
										34
									
								
								third_party/python/Doc/c-api/coro.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										34
									
								
								third_party/python/Doc/c-api/coro.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,34 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _coro-objects: |  | ||||||
| 
 |  | ||||||
| Coroutine Objects |  | ||||||
| ----------------- |  | ||||||
| 
 |  | ||||||
| .. versionadded:: 3.5 |  | ||||||
| 
 |  | ||||||
| Coroutine objects are what functions declared with an ``async`` keyword |  | ||||||
| return. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyCoroObject |  | ||||||
| 
 |  | ||||||
|    The C structure used for coroutine objects. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyCoro_Type |  | ||||||
| 
 |  | ||||||
|    The type object corresponding to coroutine objects. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyCoro_CheckExact(PyObject *ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob*'s type is *PyCoro_Type*; *ob* must not be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCoro_New(PyFrameObject *frame, PyObject *name, PyObject *qualname) |  | ||||||
| 
 |  | ||||||
|    Create and return a new coroutine object based on the *frame* object, |  | ||||||
|    with ``__name__`` and ``__qualname__`` set to *name* and *qualname*. |  | ||||||
|    A reference to *frame* is stolen by this function.  The *frame* argument |  | ||||||
|    must not be *NULL*. |  | ||||||
							
								
								
									
										209
									
								
								third_party/python/Doc/c-api/datetime.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										209
									
								
								third_party/python/Doc/c-api/datetime.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,209 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _datetimeobjects: |  | ||||||
| 
 |  | ||||||
| DateTime Objects |  | ||||||
| ---------------- |  | ||||||
| 
 |  | ||||||
| Various date and time objects are supplied by the :mod:`datetime` module. |  | ||||||
| Before using any of these functions, the header file :file:`datetime.h` must be |  | ||||||
| included in your source (note that this is not included by :file:`Python.h`), |  | ||||||
| and the macro :c:macro:`PyDateTime_IMPORT` must be invoked, usually as part of |  | ||||||
| the module initialisation function.  The macro puts a pointer to a C structure |  | ||||||
| into a static variable, :c:data:`PyDateTimeAPI`, that is used by the following |  | ||||||
| macros. |  | ||||||
| 
 |  | ||||||
| Type-check macros: |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDate_Check(PyObject *ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob* is of type :c:data:`PyDateTime_DateType` or a subtype of |  | ||||||
|    :c:data:`PyDateTime_DateType`.  *ob* must not be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDate_CheckExact(PyObject *ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob* is of type :c:data:`PyDateTime_DateType`. *ob* must not be |  | ||||||
|    *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDateTime_Check(PyObject *ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob* is of type :c:data:`PyDateTime_DateTimeType` or a subtype of |  | ||||||
|    :c:data:`PyDateTime_DateTimeType`.  *ob* must not be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDateTime_CheckExact(PyObject *ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob* is of type :c:data:`PyDateTime_DateTimeType`. *ob* must not |  | ||||||
|    be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyTime_Check(PyObject *ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob* is of type :c:data:`PyDateTime_TimeType` or a subtype of |  | ||||||
|    :c:data:`PyDateTime_TimeType`.  *ob* must not be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyTime_CheckExact(PyObject *ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob* is of type :c:data:`PyDateTime_TimeType`. *ob* must not be |  | ||||||
|    *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDelta_Check(PyObject *ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob* is of type :c:data:`PyDateTime_DeltaType` or a subtype of |  | ||||||
|    :c:data:`PyDateTime_DeltaType`.  *ob* must not be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDelta_CheckExact(PyObject *ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob* is of type :c:data:`PyDateTime_DeltaType`. *ob* must not be |  | ||||||
|    *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyTZInfo_Check(PyObject *ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob* is of type :c:data:`PyDateTime_TZInfoType` or a subtype of |  | ||||||
|    :c:data:`PyDateTime_TZInfoType`.  *ob* must not be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyTZInfo_CheckExact(PyObject *ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob* is of type :c:data:`PyDateTime_TZInfoType`. *ob* must not be |  | ||||||
|    *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Macros to create objects: |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDate_FromDate(int year, int month, int day) |  | ||||||
| 
 |  | ||||||
|    Return a ``datetime.date`` object with the specified year, month and day. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDateTime_FromDateAndTime(int year, int month, int day, int hour, int minute, int second, int usecond) |  | ||||||
| 
 |  | ||||||
|    Return a ``datetime.datetime`` object with the specified year, month, day, hour, |  | ||||||
|    minute, second and microsecond. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyTime_FromTime(int hour, int minute, int second, int usecond) |  | ||||||
| 
 |  | ||||||
|    Return a ``datetime.time`` object with the specified hour, minute, second and |  | ||||||
|    microsecond. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDelta_FromDSU(int days, int seconds, int useconds) |  | ||||||
| 
 |  | ||||||
|    Return a ``datetime.timedelta`` object representing the given number of days, |  | ||||||
|    seconds and microseconds.  Normalization is performed so that the resulting |  | ||||||
|    number of microseconds and seconds lie in the ranges documented for |  | ||||||
|    ``datetime.timedelta`` objects. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Macros to extract fields from date objects.  The argument must be an instance of |  | ||||||
| :c:data:`PyDateTime_Date`, including subclasses (such as |  | ||||||
| :c:data:`PyDateTime_DateTime`).  The argument must not be *NULL*, and the type is |  | ||||||
| not checked: |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDateTime_GET_YEAR(PyDateTime_Date *o) |  | ||||||
| 
 |  | ||||||
|    Return the year, as a positive int. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDateTime_GET_MONTH(PyDateTime_Date *o) |  | ||||||
| 
 |  | ||||||
|    Return the month, as an int from 1 through 12. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDateTime_GET_DAY(PyDateTime_Date *o) |  | ||||||
| 
 |  | ||||||
|    Return the day, as an int from 1 through 31. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Macros to extract fields from datetime objects.  The argument must be an |  | ||||||
| instance of :c:data:`PyDateTime_DateTime`, including subclasses. The argument |  | ||||||
| must not be *NULL*, and the type is not checked: |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDateTime_DATE_GET_HOUR(PyDateTime_DateTime *o) |  | ||||||
| 
 |  | ||||||
|    Return the hour, as an int from 0 through 23. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDateTime_DATE_GET_MINUTE(PyDateTime_DateTime *o) |  | ||||||
| 
 |  | ||||||
|    Return the minute, as an int from 0 through 59. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDateTime_DATE_GET_SECOND(PyDateTime_DateTime *o) |  | ||||||
| 
 |  | ||||||
|    Return the second, as an int from 0 through 59. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDateTime_DATE_GET_MICROSECOND(PyDateTime_DateTime *o) |  | ||||||
| 
 |  | ||||||
|    Return the microsecond, as an int from 0 through 999999. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Macros to extract fields from time objects.  The argument must be an instance of |  | ||||||
| :c:data:`PyDateTime_Time`, including subclasses. The argument must not be *NULL*, |  | ||||||
| and the type is not checked: |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDateTime_TIME_GET_HOUR(PyDateTime_Time *o) |  | ||||||
| 
 |  | ||||||
|    Return the hour, as an int from 0 through 23. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDateTime_TIME_GET_MINUTE(PyDateTime_Time *o) |  | ||||||
| 
 |  | ||||||
|    Return the minute, as an int from 0 through 59. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDateTime_TIME_GET_SECOND(PyDateTime_Time *o) |  | ||||||
| 
 |  | ||||||
|    Return the second, as an int from 0 through 59. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDateTime_TIME_GET_MICROSECOND(PyDateTime_Time *o) |  | ||||||
| 
 |  | ||||||
|    Return the microsecond, as an int from 0 through 999999. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Macros to extract fields from time delta objects.  The argument must be an |  | ||||||
| instance of :c:data:`PyDateTime_Delta`, including subclasses. The argument must |  | ||||||
| not be *NULL*, and the type is not checked: |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDateTime_DELTA_GET_DAYS(PyDateTime_Delta *o) |  | ||||||
| 
 |  | ||||||
|    Return the number of days, as an int from -999999999 to 999999999. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDateTime_DELTA_GET_SECONDS(PyDateTime_Delta *o) |  | ||||||
| 
 |  | ||||||
|    Return the number of seconds, as an int from 0 through 86399. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDateTime_DELTA_GET_MICROSECONDS(PyDateTime_Delta *o) |  | ||||||
| 
 |  | ||||||
|    Return the number of microseconds, as an int from 0 through 999999. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Macros for the convenience of modules implementing the DB API: |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDateTime_FromTimestamp(PyObject *args) |  | ||||||
| 
 |  | ||||||
|    Create and return a new ``datetime.datetime`` object given an argument tuple |  | ||||||
|    suitable for passing to ``datetime.datetime.fromtimestamp()``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDate_FromTimestamp(PyObject *args) |  | ||||||
| 
 |  | ||||||
|    Create and return a new ``datetime.date`` object given an argument tuple |  | ||||||
|    suitable for passing to ``datetime.date.fromtimestamp()``. |  | ||||||
							
								
								
									
										40
									
								
								third_party/python/Doc/c-api/descriptor.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										40
									
								
								third_party/python/Doc/c-api/descriptor.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,40 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _descriptor-objects: |  | ||||||
| 
 |  | ||||||
| Descriptor Objects |  | ||||||
| ------------------ |  | ||||||
| 
 |  | ||||||
| "Descriptors" are objects that describe some attribute of an object. They are |  | ||||||
| found in the dictionary of type objects. |  | ||||||
| 
 |  | ||||||
| .. XXX document these! |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyProperty_Type |  | ||||||
| 
 |  | ||||||
|    The type object for the built-in descriptor types. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDescr_NewGetSet(PyTypeObject *type, struct PyGetSetDef *getset) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDescr_NewMember(PyTypeObject *type, struct PyMemberDef *meth) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDescr_NewMethod(PyTypeObject *type, struct PyMethodDef *meth) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDescr_NewWrapper(PyTypeObject *type, struct wrapperbase *wrapper, void *wrapped) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDescr_NewClassMethod(PyTypeObject *type, PyMethodDef *method) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDescr_IsData(PyObject *descr) |  | ||||||
| 
 |  | ||||||
|    Return true if the descriptor objects *descr* describes a data attribute, or |  | ||||||
|    false if it describes a method.  *descr* must be a descriptor object; there is |  | ||||||
|    no error checking. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyWrapper_New(PyObject *, PyObject *) |  | ||||||
							
								
								
									
										240
									
								
								third_party/python/Doc/c-api/dict.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										240
									
								
								third_party/python/Doc/c-api/dict.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,240 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _dictobjects: |  | ||||||
| 
 |  | ||||||
| Dictionary Objects |  | ||||||
| ------------------ |  | ||||||
| 
 |  | ||||||
| .. index:: object: dictionary |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyDictObject |  | ||||||
| 
 |  | ||||||
|    This subtype of :c:type:`PyObject` represents a Python dictionary object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyDict_Type |  | ||||||
| 
 |  | ||||||
|    This instance of :c:type:`PyTypeObject` represents the Python dictionary |  | ||||||
|    type.  This is the same object as :class:`dict` in the Python layer. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDict_Check(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if *p* is a dict object or an instance of a subtype of the dict |  | ||||||
|    type. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDict_CheckExact(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if *p* is a dict object, but not an instance of a subtype of |  | ||||||
|    the dict type. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDict_New() |  | ||||||
| 
 |  | ||||||
|    Return a new empty dictionary, or *NULL* on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDictProxy_New(PyObject *mapping) |  | ||||||
| 
 |  | ||||||
|    Return a :class:`types.MappingProxyType` object for a mapping which |  | ||||||
|    enforces read-only behavior.  This is normally used to create a view to |  | ||||||
|    prevent modification of the dictionary for non-dynamic class types. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyDict_Clear(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Empty an existing dictionary of all key-value pairs. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDict_Contains(PyObject *p, PyObject *key) |  | ||||||
| 
 |  | ||||||
|    Determine if dictionary *p* contains *key*.  If an item in *p* is matches |  | ||||||
|    *key*, return ``1``, otherwise return ``0``.  On error, return ``-1``. |  | ||||||
|    This is equivalent to the Python expression ``key in p``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDict_Copy(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return a new dictionary that contains the same key-value pairs as *p*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDict_SetItem(PyObject *p, PyObject *key, PyObject *val) |  | ||||||
| 
 |  | ||||||
|    Insert *value* into the dictionary *p* with a key of *key*.  *key* must be |  | ||||||
|    :term:`hashable`; if it isn't, :exc:`TypeError` will be raised. Return |  | ||||||
|    ``0`` on success or ``-1`` on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDict_SetItemString(PyObject *p, const char *key, PyObject *val) |  | ||||||
| 
 |  | ||||||
|    .. index:: single: PyUnicode_FromString() |  | ||||||
| 
 |  | ||||||
|    Insert *value* into the dictionary *p* using *key* as a key. *key* should |  | ||||||
|    be a :c:type:`char\*`.  The key object is created using |  | ||||||
|    ``PyUnicode_FromString(key)``.  Return ``0`` on success or ``-1`` on |  | ||||||
|    failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDict_DelItem(PyObject *p, PyObject *key) |  | ||||||
| 
 |  | ||||||
|    Remove the entry in dictionary *p* with key *key*. *key* must be hashable; |  | ||||||
|    if it isn't, :exc:`TypeError` is raised.  Return ``0`` on success or ``-1`` |  | ||||||
|    on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDict_DelItemString(PyObject *p, const char *key) |  | ||||||
| 
 |  | ||||||
|    Remove the entry in dictionary *p* which has a key specified by the string |  | ||||||
|    *key*.  Return ``0`` on success or ``-1`` on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDict_GetItem(PyObject *p, PyObject *key) |  | ||||||
| 
 |  | ||||||
|    Return the object from dictionary *p* which has a key *key*.  Return *NULL* |  | ||||||
|    if the key *key* is not present, but *without* setting an exception. |  | ||||||
| 
 |  | ||||||
|    Note that exceptions which occur while calling :meth:`__hash__` and |  | ||||||
|    :meth:`__eq__` methods will get suppressed. |  | ||||||
|    To get error reporting use :c:func:`PyDict_GetItemWithError()` instead. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDict_GetItemWithError(PyObject *p, PyObject *key) |  | ||||||
| 
 |  | ||||||
|    Variant of :c:func:`PyDict_GetItem` that does not suppress |  | ||||||
|    exceptions. Return *NULL* **with** an exception set if an exception |  | ||||||
|    occurred.  Return *NULL* **without** an exception set if the key |  | ||||||
|    wasn't present. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDict_GetItemString(PyObject *p, const char *key) |  | ||||||
| 
 |  | ||||||
|    This is the same as :c:func:`PyDict_GetItem`, but *key* is specified as a |  | ||||||
|    :c:type:`char\*`, rather than a :c:type:`PyObject\*`. |  | ||||||
| 
 |  | ||||||
|    Note that exceptions which occur while calling :meth:`__hash__` and |  | ||||||
|    :meth:`__eq__` methods and creating a temporary string object |  | ||||||
|    will get suppressed. |  | ||||||
|    To get error reporting use :c:func:`PyDict_GetItemWithError()` instead. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDict_SetDefault(PyObject *p, PyObject *key, PyObject *default) |  | ||||||
| 
 |  | ||||||
|    This is the same as the Python-level :meth:`dict.setdefault`.  If present, it |  | ||||||
|    returns the value corresponding to *key* from the dictionary *p*.  If the key |  | ||||||
|    is not in the dict, it is inserted with value *defaultobj* and *defaultobj* |  | ||||||
|    is returned.  This function evaluates the hash function of *key* only once, |  | ||||||
|    instead of evaluating it independently for the lookup and the insertion. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.4 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDict_Items(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return a :c:type:`PyListObject` containing all the items from the dictionary. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDict_Keys(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return a :c:type:`PyListObject` containing all the keys from the dictionary. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyDict_Values(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return a :c:type:`PyListObject` containing all the values from the dictionary |  | ||||||
|    *p*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PyDict_Size(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: len |  | ||||||
| 
 |  | ||||||
|    Return the number of items in the dictionary.  This is equivalent to |  | ||||||
|    ``len(p)`` on a dictionary. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDict_Next(PyObject *p, Py_ssize_t *ppos, PyObject **pkey, PyObject **pvalue) |  | ||||||
| 
 |  | ||||||
|    Iterate over all key-value pairs in the dictionary *p*.  The |  | ||||||
|    :c:type:`Py_ssize_t` referred to by *ppos* must be initialized to ``0`` |  | ||||||
|    prior to the first call to this function to start the iteration; the |  | ||||||
|    function returns true for each pair in the dictionary, and false once all |  | ||||||
|    pairs have been reported.  The parameters *pkey* and *pvalue* should either |  | ||||||
|    point to :c:type:`PyObject\*` variables that will be filled in with each key |  | ||||||
|    and value, respectively, or may be *NULL*.  Any references returned through |  | ||||||
|    them are borrowed.  *ppos* should not be altered during iteration. Its |  | ||||||
|    value represents offsets within the internal dictionary structure, and |  | ||||||
|    since the structure is sparse, the offsets are not consecutive. |  | ||||||
| 
 |  | ||||||
|    For example:: |  | ||||||
| 
 |  | ||||||
|       PyObject *key, *value; |  | ||||||
|       Py_ssize_t pos = 0; |  | ||||||
| 
 |  | ||||||
|       while (PyDict_Next(self->dict, &pos, &key, &value)) { |  | ||||||
|           /* do something interesting with the values... */ |  | ||||||
|           ... |  | ||||||
|       } |  | ||||||
| 
 |  | ||||||
|    The dictionary *p* should not be mutated during iteration.  It is safe to |  | ||||||
|    modify the values of the keys as you iterate over the dictionary, but only |  | ||||||
|    so long as the set of keys does not change.  For example:: |  | ||||||
| 
 |  | ||||||
|       PyObject *key, *value; |  | ||||||
|       Py_ssize_t pos = 0; |  | ||||||
| 
 |  | ||||||
|       while (PyDict_Next(self->dict, &pos, &key, &value)) { |  | ||||||
|           long i = PyLong_AsLong(value); |  | ||||||
|           if (i == -1 && PyErr_Occurred()) { |  | ||||||
|               return -1; |  | ||||||
|           } |  | ||||||
|           PyObject *o = PyLong_FromLong(i + 1); |  | ||||||
|           if (o == NULL) |  | ||||||
|               return -1; |  | ||||||
|           if (PyDict_SetItem(self->dict, key, o) < 0) { |  | ||||||
|               Py_DECREF(o); |  | ||||||
|               return -1; |  | ||||||
|           } |  | ||||||
|           Py_DECREF(o); |  | ||||||
|       } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDict_Merge(PyObject *a, PyObject *b, int override) |  | ||||||
| 
 |  | ||||||
|    Iterate over mapping object *b* adding key-value pairs to dictionary *a*. |  | ||||||
|    *b* may be a dictionary, or any object supporting :c:func:`PyMapping_Keys` |  | ||||||
|    and :c:func:`PyObject_GetItem`. If *override* is true, existing pairs in *a* |  | ||||||
|    will be replaced if a matching key is found in *b*, otherwise pairs will |  | ||||||
|    only be added if there is not a matching key in *a*. Return ``0`` on |  | ||||||
|    success or ``-1`` if an exception was raised. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDict_Update(PyObject *a, PyObject *b) |  | ||||||
| 
 |  | ||||||
|    This is the same as ``PyDict_Merge(a, b, 1)`` in C, and is similar to |  | ||||||
|    ``a.update(b)`` in Python except that :c:func:`PyDict_Update` doesn't fall |  | ||||||
|    back to the iterating over a sequence of key value pairs if the second |  | ||||||
|    argument has no "keys" attribute.  Return ``0`` on success or ``-1`` if an |  | ||||||
|    exception was raised. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDict_MergeFromSeq2(PyObject *a, PyObject *seq2, int override) |  | ||||||
| 
 |  | ||||||
|    Update or merge into dictionary *a*, from the key-value pairs in *seq2*. |  | ||||||
|    *seq2* must be an iterable object producing iterable objects of length 2, |  | ||||||
|    viewed as key-value pairs.  In case of duplicate keys, the last wins if |  | ||||||
|    *override* is true, else the first wins. Return ``0`` on success or ``-1`` |  | ||||||
|    if an exception was raised. Equivalent Python (except for the return |  | ||||||
|    value):: |  | ||||||
| 
 |  | ||||||
|       def PyDict_MergeFromSeq2(a, seq2, override): |  | ||||||
|           for key, value in seq2: |  | ||||||
|               if override or key not in a: |  | ||||||
|                   a[key] = value |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyDict_ClearFreeList() |  | ||||||
| 
 |  | ||||||
|    Clear the free list. Return the total number of freed items. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
							
								
								
									
										1020
									
								
								third_party/python/Doc/c-api/exceptions.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										1020
									
								
								third_party/python/Doc/c-api/exceptions.rst
									
										
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										76
									
								
								third_party/python/Doc/c-api/file.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										76
									
								
								third_party/python/Doc/c-api/file.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,76 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _fileobjects: |  | ||||||
| 
 |  | ||||||
| File Objects |  | ||||||
| ------------ |  | ||||||
| 
 |  | ||||||
| .. index:: object: file |  | ||||||
| 
 |  | ||||||
| These APIs are a minimal emulation of the Python 2 C API for built-in file |  | ||||||
| objects, which used to rely on the buffered I/O (:c:type:`FILE\*`) support |  | ||||||
| from the C standard library.  In Python 3, files and streams use the new |  | ||||||
| :mod:`io` module, which defines several layers over the low-level unbuffered |  | ||||||
| I/O of the operating system.  The functions described below are |  | ||||||
| convenience C wrappers over these new APIs, and meant mostly for internal |  | ||||||
| error reporting in the interpreter; third-party code is advised to access |  | ||||||
| the :mod:`io` APIs instead. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyFile_FromFd(int fd, const char *name, const char *mode, int buffering, const char *encoding, const char *errors, const char *newline, int closefd) |  | ||||||
| 
 |  | ||||||
|    Create a Python file object from the file descriptor of an already |  | ||||||
|    opened file *fd*.  The arguments *name*, *encoding*, *errors* and *newline* |  | ||||||
|    can be *NULL* to use the defaults; *buffering* can be *-1* to use the |  | ||||||
|    default. *name* is ignored and kept for backward compatibility. Return |  | ||||||
|    *NULL* on failure. For a more comprehensive description of the arguments, |  | ||||||
|    please refer to the :func:`io.open` function documentation. |  | ||||||
| 
 |  | ||||||
|    .. warning:: |  | ||||||
| 
 |  | ||||||
|      Since Python streams have their own buffering layer, mixing them with |  | ||||||
|      OS-level file descriptors can produce various issues (such as unexpected |  | ||||||
|      ordering of data). |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.2 |  | ||||||
|       Ignore *name* attribute. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_AsFileDescriptor(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return the file descriptor associated with *p* as an :c:type:`int`.  If the |  | ||||||
|    object is an integer, its value is returned.  If not, the |  | ||||||
|    object's :meth:`~io.IOBase.fileno` method is called if it exists; the |  | ||||||
|    method must return an integer, which is returned as the file descriptor |  | ||||||
|    value.  Sets an exception and returns ``-1`` on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyFile_GetLine(PyObject *p, int n) |  | ||||||
| 
 |  | ||||||
|    .. index:: single: EOFError (built-in exception) |  | ||||||
| 
 |  | ||||||
|    Equivalent to ``p.readline([n])``, this function reads one line from the |  | ||||||
|    object *p*.  *p* may be a file object or any object with a |  | ||||||
|    :meth:`~io.IOBase.readline` |  | ||||||
|    method.  If *n* is ``0``, exactly one line is read, regardless of the length of |  | ||||||
|    the line.  If *n* is greater than ``0``, no more than *n* bytes will be read |  | ||||||
|    from the file; a partial line can be returned.  In both cases, an empty string |  | ||||||
|    is returned if the end of the file is reached immediately.  If *n* is less than |  | ||||||
|    ``0``, however, one line is read regardless of length, but :exc:`EOFError` is |  | ||||||
|    raised if the end of the file is reached immediately. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyFile_WriteObject(PyObject *obj, PyObject *p, int flags) |  | ||||||
| 
 |  | ||||||
|    .. index:: single: Py_PRINT_RAW |  | ||||||
| 
 |  | ||||||
|    Write object *obj* to file object *p*.  The only supported flag for *flags* is |  | ||||||
|    :const:`Py_PRINT_RAW`; if given, the :func:`str` of the object is written |  | ||||||
|    instead of the :func:`repr`.  Return ``0`` on success or ``-1`` on failure; the |  | ||||||
|    appropriate exception will be set. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyFile_WriteString(const char *s, PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Write string *s* to file object *p*.  Return ``0`` on success or ``-1`` on |  | ||||||
|    failure; the appropriate exception will be set. |  | ||||||
							
								
								
									
										79
									
								
								third_party/python/Doc/c-api/float.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										79
									
								
								third_party/python/Doc/c-api/float.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,79 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _floatobjects: |  | ||||||
| 
 |  | ||||||
| Floating Point Objects |  | ||||||
| ---------------------- |  | ||||||
| 
 |  | ||||||
| .. index:: object: floating point |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyFloatObject |  | ||||||
| 
 |  | ||||||
|    This subtype of :c:type:`PyObject` represents a Python floating point object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyFloat_Type |  | ||||||
| 
 |  | ||||||
|    This instance of :c:type:`PyTypeObject` represents the Python floating point |  | ||||||
|    type.  This is the same object as :class:`float` in the Python layer. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyFloat_Check(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if its argument is a :c:type:`PyFloatObject` or a subtype of |  | ||||||
|    :c:type:`PyFloatObject`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyFloat_CheckExact(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if its argument is a :c:type:`PyFloatObject`, but not a subtype of |  | ||||||
|    :c:type:`PyFloatObject`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyFloat_FromString(PyObject *str) |  | ||||||
| 
 |  | ||||||
|    Create a :c:type:`PyFloatObject` object based on the string value in *str*, or |  | ||||||
|    *NULL* on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyFloat_FromDouble(double v) |  | ||||||
| 
 |  | ||||||
|    Create a :c:type:`PyFloatObject` object from *v*, or *NULL* on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: double PyFloat_AsDouble(PyObject *pyfloat) |  | ||||||
| 
 |  | ||||||
|    Return a C :c:type:`double` representation of the contents of *pyfloat*.  If |  | ||||||
|    *pyfloat* is not a Python floating point object but has a :meth:`__float__` |  | ||||||
|    method, this method will first be called to convert *pyfloat* into a float. |  | ||||||
|    This method returns ``-1.0`` upon failure, so one should call |  | ||||||
|    :c:func:`PyErr_Occurred` to check for errors. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: double PyFloat_AS_DOUBLE(PyObject *pyfloat) |  | ||||||
| 
 |  | ||||||
|    Return a C :c:type:`double` representation of the contents of *pyfloat*, but |  | ||||||
|    without error checking. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyFloat_GetInfo(void) |  | ||||||
| 
 |  | ||||||
|    Return a structseq instance which contains information about the |  | ||||||
|    precision, minimum and maximum values of a float. It's a thin wrapper |  | ||||||
|    around the header file :file:`float.h`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: double PyFloat_GetMax() |  | ||||||
| 
 |  | ||||||
|    Return the maximum representable finite float *DBL_MAX* as C :c:type:`double`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: double PyFloat_GetMin() |  | ||||||
| 
 |  | ||||||
|    Return the minimum normalized positive float *DBL_MIN* as C :c:type:`double`. |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyFloat_ClearFreeList() |  | ||||||
| 
 |  | ||||||
|    Clear the float free list. Return the number of items that could not |  | ||||||
|    be freed. |  | ||||||
							
								
								
									
										108
									
								
								third_party/python/Doc/c-api/function.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										108
									
								
								third_party/python/Doc/c-api/function.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,108 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _function-objects: |  | ||||||
| 
 |  | ||||||
| Function Objects |  | ||||||
| ---------------- |  | ||||||
| 
 |  | ||||||
| .. index:: object: function |  | ||||||
| 
 |  | ||||||
| There are a few functions specific to Python functions. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyFunctionObject |  | ||||||
| 
 |  | ||||||
|    The C structure used for functions. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyFunction_Type |  | ||||||
| 
 |  | ||||||
|    .. index:: single: MethodType (in module types) |  | ||||||
| 
 |  | ||||||
|    This is an instance of :c:type:`PyTypeObject` and represents the Python function |  | ||||||
|    type.  It is exposed to Python programmers as ``types.FunctionType``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyFunction_Check(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return true if *o* is a function object (has type :c:data:`PyFunction_Type`). |  | ||||||
|    The parameter must not be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyFunction_New(PyObject *code, PyObject *globals) |  | ||||||
| 
 |  | ||||||
|    Return a new function object associated with the code object *code*. *globals* |  | ||||||
|    must be a dictionary with the global variables accessible to the function. |  | ||||||
| 
 |  | ||||||
|    The function's docstring and name are retrieved from the code object. *__module__* |  | ||||||
|    is retrieved from *globals*. The argument defaults, annotations and closure are |  | ||||||
|    set to *NULL*. *__qualname__* is set to the same value as the function's name. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyFunction_NewWithQualName(PyObject *code, PyObject *globals, PyObject *qualname) |  | ||||||
| 
 |  | ||||||
|    As :c:func:`PyFunction_New`, but also allows setting the function object's |  | ||||||
|    ``__qualname__`` attribute.  *qualname* should be a unicode object or NULL; |  | ||||||
|    if NULL, the ``__qualname__`` attribute is set to the same value as its |  | ||||||
|    ``__name__`` attribute. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyFunction_GetCode(PyObject *op) |  | ||||||
| 
 |  | ||||||
|    Return the code object associated with the function object *op*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyFunction_GetGlobals(PyObject *op) |  | ||||||
| 
 |  | ||||||
|    Return the globals dictionary associated with the function object *op*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyFunction_GetModule(PyObject *op) |  | ||||||
| 
 |  | ||||||
|    Return the *__module__* attribute of the function object *op*. This is normally |  | ||||||
|    a string containing the module name, but can be set to any other object by |  | ||||||
|    Python code. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyFunction_GetDefaults(PyObject *op) |  | ||||||
| 
 |  | ||||||
|    Return the argument default values of the function object *op*. This can be a |  | ||||||
|    tuple of arguments or *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyFunction_SetDefaults(PyObject *op, PyObject *defaults) |  | ||||||
| 
 |  | ||||||
|    Set the argument default values for the function object *op*. *defaults* must be |  | ||||||
|    *Py_None* or a tuple. |  | ||||||
| 
 |  | ||||||
|    Raises :exc:`SystemError` and returns ``-1`` on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyFunction_GetClosure(PyObject *op) |  | ||||||
| 
 |  | ||||||
|    Return the closure associated with the function object *op*. This can be *NULL* |  | ||||||
|    or a tuple of cell objects. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyFunction_SetClosure(PyObject *op, PyObject *closure) |  | ||||||
| 
 |  | ||||||
|    Set the closure associated with the function object *op*. *closure* must be |  | ||||||
|    *Py_None* or a tuple of cell objects. |  | ||||||
| 
 |  | ||||||
|    Raises :exc:`SystemError` and returns ``-1`` on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject *PyFunction_GetAnnotations(PyObject *op) |  | ||||||
| 
 |  | ||||||
|    Return the annotations of the function object *op*. This can be a |  | ||||||
|    mutable dictionary or *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyFunction_SetAnnotations(PyObject *op, PyObject *annotations) |  | ||||||
| 
 |  | ||||||
|    Set the annotations for the function object *op*. *annotations* |  | ||||||
|    must be a dictionary or *Py_None*. |  | ||||||
| 
 |  | ||||||
|    Raises :exc:`SystemError` and returns ``-1`` on failure. |  | ||||||
							
								
								
									
										159
									
								
								third_party/python/Doc/c-api/gcsupport.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										159
									
								
								third_party/python/Doc/c-api/gcsupport.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,159 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _supporting-cycle-detection: |  | ||||||
| 
 |  | ||||||
| Supporting Cyclic Garbage Collection |  | ||||||
| ==================================== |  | ||||||
| 
 |  | ||||||
| Python's support for detecting and collecting garbage which involves circular |  | ||||||
| references requires support from object types which are "containers" for other |  | ||||||
| objects which may also be containers.  Types which do not store references to |  | ||||||
| other objects, or which only store references to atomic types (such as numbers |  | ||||||
| or strings), do not need to provide any explicit support for garbage |  | ||||||
| collection. |  | ||||||
| 
 |  | ||||||
| To create a container type, the :c:member:`~PyTypeObject.tp_flags` field of the type object must |  | ||||||
| include the :const:`Py_TPFLAGS_HAVE_GC` and provide an implementation of the |  | ||||||
| :c:member:`~PyTypeObject.tp_traverse` handler.  If instances of the type are mutable, a |  | ||||||
| :c:member:`~PyTypeObject.tp_clear` implementation must also be provided. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. data:: Py_TPFLAGS_HAVE_GC |  | ||||||
|    :noindex: |  | ||||||
| 
 |  | ||||||
|    Objects with a type with this flag set must conform with the rules |  | ||||||
|    documented here.  For convenience these objects will be referred to as |  | ||||||
|    container objects. |  | ||||||
| 
 |  | ||||||
| Constructors for container types must conform to two rules: |  | ||||||
| 
 |  | ||||||
| #. The memory for the object must be allocated using :c:func:`PyObject_GC_New` |  | ||||||
|    or :c:func:`PyObject_GC_NewVar`. |  | ||||||
| 
 |  | ||||||
| #. Once all the fields which may contain references to other containers are |  | ||||||
|    initialized, it must call :c:func:`PyObject_GC_Track`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: TYPE* PyObject_GC_New(TYPE, PyTypeObject *type) |  | ||||||
| 
 |  | ||||||
|    Analogous to :c:func:`PyObject_New` but for container objects with the |  | ||||||
|    :const:`Py_TPFLAGS_HAVE_GC` flag set. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: TYPE* PyObject_GC_NewVar(TYPE, PyTypeObject *type, Py_ssize_t size) |  | ||||||
| 
 |  | ||||||
|    Analogous to :c:func:`PyObject_NewVar` but for container objects with the |  | ||||||
|    :const:`Py_TPFLAGS_HAVE_GC` flag set. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: TYPE* PyObject_GC_Resize(TYPE, PyVarObject *op, Py_ssize_t newsize) |  | ||||||
| 
 |  | ||||||
|    Resize an object allocated by :c:func:`PyObject_NewVar`.  Returns the |  | ||||||
|    resized object or *NULL* on failure.  *op* must not be tracked by the collector yet. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyObject_GC_Track(PyObject *op) |  | ||||||
| 
 |  | ||||||
|    Adds the object *op* to the set of container objects tracked by the |  | ||||||
|    collector.  The collector can run at unexpected times so objects must be |  | ||||||
|    valid while being tracked.  This should be called once all the fields |  | ||||||
|    followed by the :c:member:`~PyTypeObject.tp_traverse` handler become valid, usually near the |  | ||||||
|    end of the constructor. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void _PyObject_GC_TRACK(PyObject *op) |  | ||||||
| 
 |  | ||||||
|    A macro version of :c:func:`PyObject_GC_Track`.  It should not be used for |  | ||||||
|    extension modules. |  | ||||||
| 
 |  | ||||||
|    .. deprecated:: 3.6 |  | ||||||
|       This macro is removed from Python 3.8. |  | ||||||
| 
 |  | ||||||
| Similarly, the deallocator for the object must conform to a similar pair of |  | ||||||
| rules: |  | ||||||
| 
 |  | ||||||
| #. Before fields which refer to other containers are invalidated, |  | ||||||
|    :c:func:`PyObject_GC_UnTrack` must be called. |  | ||||||
| 
 |  | ||||||
| #. The object's memory must be deallocated using :c:func:`PyObject_GC_Del`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyObject_GC_Del(void *op) |  | ||||||
| 
 |  | ||||||
|    Releases memory allocated to an object using :c:func:`PyObject_GC_New` or |  | ||||||
|    :c:func:`PyObject_GC_NewVar`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyObject_GC_UnTrack(void *op) |  | ||||||
| 
 |  | ||||||
|    Remove the object *op* from the set of container objects tracked by the |  | ||||||
|    collector.  Note that :c:func:`PyObject_GC_Track` can be called again on |  | ||||||
|    this object to add it back to the set of tracked objects.  The deallocator |  | ||||||
|    (:c:member:`~PyTypeObject.tp_dealloc` handler) should call this for the object before any of |  | ||||||
|    the fields used by the :c:member:`~PyTypeObject.tp_traverse` handler become invalid. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void _PyObject_GC_UNTRACK(PyObject *op) |  | ||||||
| 
 |  | ||||||
|    A macro version of :c:func:`PyObject_GC_UnTrack`.  It should not be used for |  | ||||||
|    extension modules. |  | ||||||
| 
 |  | ||||||
|    .. deprecated:: 3.6 |  | ||||||
|       This macro is removed from Python 3.8. |  | ||||||
| 
 |  | ||||||
| The :c:member:`~PyTypeObject.tp_traverse` handler accepts a function parameter of this type: |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: int (*visitproc)(PyObject *object, void *arg) |  | ||||||
| 
 |  | ||||||
|    Type of the visitor function passed to the :c:member:`~PyTypeObject.tp_traverse` handler. |  | ||||||
|    The function should be called with an object to traverse as *object* and |  | ||||||
|    the third parameter to the :c:member:`~PyTypeObject.tp_traverse` handler as *arg*.  The |  | ||||||
|    Python core uses several visitor functions to implement cyclic garbage |  | ||||||
|    detection; it's not expected that users will need to write their own |  | ||||||
|    visitor functions. |  | ||||||
| 
 |  | ||||||
| The :c:member:`~PyTypeObject.tp_traverse` handler must have the following type: |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: int (*traverseproc)(PyObject *self, visitproc visit, void *arg) |  | ||||||
| 
 |  | ||||||
|    Traversal function for a container object.  Implementations must call the |  | ||||||
|    *visit* function for each object directly contained by *self*, with the |  | ||||||
|    parameters to *visit* being the contained object and the *arg* value passed |  | ||||||
|    to the handler.  The *visit* function must not be called with a *NULL* |  | ||||||
|    object argument.  If *visit* returns a non-zero value that value should be |  | ||||||
|    returned immediately. |  | ||||||
| 
 |  | ||||||
| To simplify writing :c:member:`~PyTypeObject.tp_traverse` handlers, a :c:func:`Py_VISIT` macro is |  | ||||||
| provided.  In order to use this macro, the :c:member:`~PyTypeObject.tp_traverse` implementation |  | ||||||
| must name its arguments exactly *visit* and *arg*: |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void Py_VISIT(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    If *o* is not *NULL*, call the *visit* callback, with arguments *o* |  | ||||||
|    and *arg*.  If *visit* returns a non-zero value, then return it. |  | ||||||
|    Using this macro, :c:member:`~PyTypeObject.tp_traverse` handlers |  | ||||||
|    look like:: |  | ||||||
| 
 |  | ||||||
|       static int |  | ||||||
|       my_traverse(Noddy *self, visitproc visit, void *arg) |  | ||||||
|       { |  | ||||||
|           Py_VISIT(self->foo); |  | ||||||
|           Py_VISIT(self->bar); |  | ||||||
|           return 0; |  | ||||||
|       } |  | ||||||
| 
 |  | ||||||
| The :c:member:`~PyTypeObject.tp_clear` handler must be of the :c:type:`inquiry` type, or *NULL* |  | ||||||
| if the object is immutable. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: int (*inquiry)(PyObject *self) |  | ||||||
| 
 |  | ||||||
|    Drop references that may have created reference cycles.  Immutable objects |  | ||||||
|    do not have to define this method since they can never directly create |  | ||||||
|    reference cycles.  Note that the object must still be valid after calling |  | ||||||
|    this method (don't just call :c:func:`Py_DECREF` on a reference).  The |  | ||||||
|    collector will call this method if it detects that this object is involved |  | ||||||
|    in a reference cycle. |  | ||||||
							
								
								
									
										44
									
								
								third_party/python/Doc/c-api/gen.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										44
									
								
								third_party/python/Doc/c-api/gen.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,44 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _gen-objects: |  | ||||||
| 
 |  | ||||||
| Generator Objects |  | ||||||
| ----------------- |  | ||||||
| 
 |  | ||||||
| Generator objects are what Python uses to implement generator iterators. They |  | ||||||
| are normally created by iterating over a function that yields values, rather |  | ||||||
| than explicitly calling :c:func:`PyGen_New` or :c:func:`PyGen_NewWithQualName`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyGenObject |  | ||||||
| 
 |  | ||||||
|    The C structure used for generator objects. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyGen_Type |  | ||||||
| 
 |  | ||||||
|    The type object corresponding to generator objects. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyGen_Check(PyObject *ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob* is a generator object; *ob* must not be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyGen_CheckExact(PyObject *ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob*'s type is *PyGen_Type*; *ob* must not be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyGen_New(PyFrameObject *frame) |  | ||||||
| 
 |  | ||||||
|    Create and return a new generator object based on the *frame* object. |  | ||||||
|    A reference to *frame* is stolen by this function. The argument must not be |  | ||||||
|    *NULL*. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyGen_NewWithQualName(PyFrameObject *frame, PyObject *name, PyObject *qualname) |  | ||||||
| 
 |  | ||||||
|    Create and return a new generator object based on the *frame* object, |  | ||||||
|    with ``__name__`` and ``__qualname__`` set to *name* and *qualname*. |  | ||||||
|    A reference to *frame* is stolen by this function.  The *frame* argument |  | ||||||
|    must not be *NULL*. |  | ||||||
							
								
								
									
										315
									
								
								third_party/python/Doc/c-api/import.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										315
									
								
								third_party/python/Doc/c-api/import.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,315 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _importing: |  | ||||||
| 
 |  | ||||||
| Importing Modules |  | ||||||
| ================= |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyImport_ImportModule(const char *name) |  | ||||||
| 
 |  | ||||||
|    .. index:: |  | ||||||
|       single: package variable; __all__ |  | ||||||
|       single: __all__ (package variable) |  | ||||||
|       single: modules (in module sys) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to :c:func:`PyImport_ImportModuleEx` below, |  | ||||||
|    leaving the *globals* and *locals* arguments set to *NULL* and *level* set |  | ||||||
|    to 0.  When the *name* |  | ||||||
|    argument contains a dot (when it specifies a submodule of a package), the |  | ||||||
|    *fromlist* argument is set to the list ``['*']`` so that the return value is the |  | ||||||
|    named module rather than the top-level package containing it as would otherwise |  | ||||||
|    be the case.  (Unfortunately, this has an additional side effect when *name* in |  | ||||||
|    fact specifies a subpackage instead of a submodule: the submodules specified in |  | ||||||
|    the package's ``__all__`` variable are  loaded.)  Return a new reference to the |  | ||||||
|    imported module, or *NULL* with an exception set on failure.  A failing |  | ||||||
|    import of a module doesn't leave the module in :data:`sys.modules`. |  | ||||||
| 
 |  | ||||||
|    This function always uses absolute imports. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyImport_ImportModuleNoBlock(const char *name) |  | ||||||
| 
 |  | ||||||
|    This function is a deprecated alias of :c:func:`PyImport_ImportModule`. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.3 |  | ||||||
|       This function used to fail immediately when the import lock was held |  | ||||||
|       by another thread.  In Python 3.3 though, the locking scheme switched |  | ||||||
|       to per-module locks for most purposes, so this function's special |  | ||||||
|       behaviour isn't needed anymore. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyImport_ImportModuleEx(const char *name, PyObject *globals, PyObject *locals, PyObject *fromlist) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: __import__ |  | ||||||
| 
 |  | ||||||
|    Import a module.  This is best described by referring to the built-in Python |  | ||||||
|    function :func:`__import__`. |  | ||||||
| 
 |  | ||||||
|    The return value is a new reference to the imported module or top-level |  | ||||||
|    package, or *NULL* with an exception set on failure.  Like for |  | ||||||
|    :func:`__import__`, the return value when a submodule of a package was |  | ||||||
|    requested is normally the top-level package, unless a non-empty *fromlist* |  | ||||||
|    was given. |  | ||||||
| 
 |  | ||||||
|    Failing imports remove incomplete module objects, like with |  | ||||||
|    :c:func:`PyImport_ImportModule`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyImport_ImportModuleLevelObject(PyObject *name, PyObject *globals, PyObject *locals, PyObject *fromlist, int level) |  | ||||||
| 
 |  | ||||||
|    Import a module.  This is best described by referring to the built-in Python |  | ||||||
|    function :func:`__import__`, as the standard :func:`__import__` function calls |  | ||||||
|    this function directly. |  | ||||||
| 
 |  | ||||||
|    The return value is a new reference to the imported module or top-level package, |  | ||||||
|    or *NULL* with an exception set on failure.  Like for :func:`__import__`, |  | ||||||
|    the return value when a submodule of a package was requested is normally the |  | ||||||
|    top-level package, unless a non-empty *fromlist* was given. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyImport_ImportModuleLevel(const char *name, PyObject *globals, PyObject *locals, PyObject *fromlist, int level) |  | ||||||
| 
 |  | ||||||
|    Similar to :c:func:`PyImport_ImportModuleLevelObject`, but the name is a |  | ||||||
|    UTF-8 encoded string instead of a Unicode object. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.3 |  | ||||||
|          Negative values for *level* are no longer accepted. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyImport_Import(PyObject *name) |  | ||||||
| 
 |  | ||||||
|    This is a higher-level interface that calls the current "import hook |  | ||||||
|    function" (with an explicit *level* of 0, meaning absolute import).  It |  | ||||||
|    invokes the :func:`__import__` function from the ``__builtins__`` of the |  | ||||||
|    current globals.  This means that the import is done using whatever import |  | ||||||
|    hooks are installed in the current environment. |  | ||||||
| 
 |  | ||||||
|    This function always uses absolute imports. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyImport_ReloadModule(PyObject *m) |  | ||||||
| 
 |  | ||||||
|    Reload a module.  Return a new reference to the reloaded module, or *NULL* with |  | ||||||
|    an exception set on failure (the module still exists in this case). |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyImport_AddModuleObject(PyObject *name) |  | ||||||
| 
 |  | ||||||
|    Return the module object corresponding to a module name.  The *name* argument |  | ||||||
|    may be of the form ``package.module``. First check the modules dictionary if |  | ||||||
|    there's one there, and if not, create a new one and insert it in the modules |  | ||||||
|    dictionary. Return *NULL* with an exception set on failure. |  | ||||||
| 
 |  | ||||||
|    .. note:: |  | ||||||
| 
 |  | ||||||
|       This function does not load or import the module; if the module wasn't already |  | ||||||
|       loaded, you will get an empty module object. Use :c:func:`PyImport_ImportModule` |  | ||||||
|       or one of its variants to import a module.  Package structures implied by a |  | ||||||
|       dotted name for *name* are not created if not already present. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyImport_AddModule(const char *name) |  | ||||||
| 
 |  | ||||||
|    Similar to :c:func:`PyImport_AddModuleObject`, but the name is a UTF-8 |  | ||||||
|    encoded string instead of a Unicode object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyImport_ExecCodeModule(const char *name, PyObject *co) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: compile |  | ||||||
| 
 |  | ||||||
|    Given a module name (possibly of the form ``package.module``) and a code object |  | ||||||
|    read from a Python bytecode file or obtained from the built-in function |  | ||||||
|    :func:`compile`, load the module.  Return a new reference to the module object, |  | ||||||
|    or *NULL* with an exception set if an error occurred.  *name* |  | ||||||
|    is removed from :attr:`sys.modules` in error cases, even if *name* was already |  | ||||||
|    in :attr:`sys.modules` on entry to :c:func:`PyImport_ExecCodeModule`.  Leaving |  | ||||||
|    incompletely initialized modules in :attr:`sys.modules` is dangerous, as imports of |  | ||||||
|    such modules have no way to know that the module object is an unknown (and |  | ||||||
|    probably damaged with respect to the module author's intents) state. |  | ||||||
| 
 |  | ||||||
|    The module's :attr:`__spec__` and :attr:`__loader__` will be set, if |  | ||||||
|    not set already, with the appropriate values.  The spec's loader will |  | ||||||
|    be set to the module's ``__loader__`` (if set) and to an instance of |  | ||||||
|    :class:`SourceFileLoader` otherwise. |  | ||||||
| 
 |  | ||||||
|    The module's :attr:`__file__` attribute will be set to the code object's |  | ||||||
|    :c:member:`co_filename`.  If applicable, :attr:`__cached__` will also |  | ||||||
|    be set. |  | ||||||
| 
 |  | ||||||
|    This function will reload the module if it was already imported.  See |  | ||||||
|    :c:func:`PyImport_ReloadModule` for the intended way to reload a module. |  | ||||||
| 
 |  | ||||||
|    If *name* points to a dotted name of the form ``package.module``, any package |  | ||||||
|    structures not already created will still not be created. |  | ||||||
| 
 |  | ||||||
|    See also :c:func:`PyImport_ExecCodeModuleEx` and |  | ||||||
|    :c:func:`PyImport_ExecCodeModuleWithPathnames`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyImport_ExecCodeModuleEx(const char *name, PyObject *co, const char *pathname) |  | ||||||
| 
 |  | ||||||
|    Like :c:func:`PyImport_ExecCodeModule`, but the :attr:`__file__` attribute of |  | ||||||
|    the module object is set to *pathname* if it is non-``NULL``. |  | ||||||
| 
 |  | ||||||
|    See also :c:func:`PyImport_ExecCodeModuleWithPathnames`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyImport_ExecCodeModuleObject(PyObject *name, PyObject *co, PyObject *pathname, PyObject *cpathname) |  | ||||||
| 
 |  | ||||||
|    Like :c:func:`PyImport_ExecCodeModuleEx`, but the :attr:`__cached__` |  | ||||||
|    attribute of the module object is set to *cpathname* if it is |  | ||||||
|    non-``NULL``.  Of the three functions, this is the preferred one to use. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyImport_ExecCodeModuleWithPathnames(const char *name, PyObject *co, const char *pathname, const char *cpathname) |  | ||||||
| 
 |  | ||||||
|    Like :c:func:`PyImport_ExecCodeModuleObject`, but *name*, *pathname* and |  | ||||||
|    *cpathname* are UTF-8 encoded strings. Attempts are also made to figure out |  | ||||||
|    what the value for *pathname* should be from *cpathname* if the former is |  | ||||||
|    set to ``NULL``. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.2 |  | ||||||
|    .. versionchanged:: 3.3 |  | ||||||
|       Uses :func:`imp.source_from_cache()` in calculating the source path if |  | ||||||
|       only the bytecode path is provided. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: long PyImport_GetMagicNumber() |  | ||||||
| 
 |  | ||||||
|    Return the magic number for Python bytecode files (a.k.a. :file:`.pyc` file). |  | ||||||
|    The magic number should be present in the first four bytes of the bytecode |  | ||||||
|    file, in little-endian byte order. Returns ``-1`` on error. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.3 |  | ||||||
|       Return value of ``-1`` upon failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: const char * PyImport_GetMagicTag() |  | ||||||
| 
 |  | ||||||
|    Return the magic tag string for :pep:`3147` format Python bytecode file |  | ||||||
|    names.  Keep in mind that the value at ``sys.implementation.cache_tag`` is |  | ||||||
|    authoritative and should be used instead of this function. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.2 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyImport_GetModuleDict() |  | ||||||
| 
 |  | ||||||
|    Return the dictionary used for the module administration (a.k.a. |  | ||||||
|    ``sys.modules``).  Note that this is a per-interpreter variable. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyImport_GetImporter(PyObject *path) |  | ||||||
| 
 |  | ||||||
|    Return a finder object for a :data:`sys.path`/:attr:`pkg.__path__` item |  | ||||||
|    *path*, possibly by fetching it from the :data:`sys.path_importer_cache` |  | ||||||
|    dict.  If it wasn't yet cached, traverse :data:`sys.path_hooks` until a hook |  | ||||||
|    is found that can handle the path item.  Return ``None`` if no hook could; |  | ||||||
|    this tells our caller that the :term:`path based finder` could not find a |  | ||||||
|    finder for this path item. Cache the result in :data:`sys.path_importer_cache`. |  | ||||||
|    Return a new reference to the finder object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void _PyImport_Init() |  | ||||||
| 
 |  | ||||||
|    Initialize the import mechanism.  For internal use only. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyImport_Cleanup() |  | ||||||
| 
 |  | ||||||
|    Empty the module table.  For internal use only. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void _PyImport_Fini() |  | ||||||
| 
 |  | ||||||
|    Finalize the import mechanism.  For internal use only. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* _PyImport_FindExtension(char *, char *) |  | ||||||
| 
 |  | ||||||
|    For internal use only. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyImport_ImportFrozenModuleObject(PyObject *name) |  | ||||||
| 
 |  | ||||||
|    Load a frozen module named *name*.  Return ``1`` for success, ``0`` if the |  | ||||||
|    module is not found, and ``-1`` with an exception set if the initialization |  | ||||||
|    failed.  To access the imported module on a successful load, use |  | ||||||
|    :c:func:`PyImport_ImportModule`.  (Note the misnomer --- this function would |  | ||||||
|    reload the module if it was already imported.) |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.4 |  | ||||||
|       The ``__file__`` attribute is no longer set on the module. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyImport_ImportFrozenModule(const char *name) |  | ||||||
| 
 |  | ||||||
|    Similar to :c:func:`PyImport_ImportFrozenModuleObject`, but the name is a |  | ||||||
|    UTF-8 encoded string instead of a Unicode object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: struct _frozen |  | ||||||
| 
 |  | ||||||
|    .. index:: single: freeze utility |  | ||||||
| 
 |  | ||||||
|    This is the structure type definition for frozen module descriptors, as |  | ||||||
|    generated by the :program:`freeze` utility (see :file:`Tools/freeze/` in the |  | ||||||
|    Python source distribution).  Its definition, found in :file:`Include/import.h`, |  | ||||||
|    is:: |  | ||||||
| 
 |  | ||||||
|       struct _frozen { |  | ||||||
|           char *name; |  | ||||||
|           unsigned char *code; |  | ||||||
|           int size; |  | ||||||
|       }; |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: const struct _frozen* PyImport_FrozenModules |  | ||||||
| 
 |  | ||||||
|    This pointer is initialized to point to an array of :c:type:`struct _frozen` |  | ||||||
|    records, terminated by one whose members are all *NULL* or zero.  When a frozen |  | ||||||
|    module is imported, it is searched in this table.  Third-party code could play |  | ||||||
|    tricks with this to provide a dynamically created collection of frozen modules. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyImport_AppendInittab(const char *name, PyObject* (*initfunc)(void)) |  | ||||||
| 
 |  | ||||||
|    Add a single module to the existing table of built-in modules.  This is a |  | ||||||
|    convenience wrapper around :c:func:`PyImport_ExtendInittab`, returning ``-1`` if |  | ||||||
|    the table could not be extended.  The new module can be imported by the name |  | ||||||
|    *name*, and uses the function *initfunc* as the initialization function called |  | ||||||
|    on the first attempted import.  This should be called before |  | ||||||
|    :c:func:`Py_Initialize`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: struct _inittab |  | ||||||
| 
 |  | ||||||
|    Structure describing a single entry in the list of built-in modules.  Each of |  | ||||||
|    these structures gives the name and initialization function for a module built |  | ||||||
|    into the interpreter.  The name is an ASCII encoded string.  Programs which |  | ||||||
|    embed Python may use an array of these structures in conjunction with |  | ||||||
|    :c:func:`PyImport_ExtendInittab` to provide additional built-in modules. |  | ||||||
|    The structure is defined in :file:`Include/import.h` as:: |  | ||||||
| 
 |  | ||||||
|       struct _inittab { |  | ||||||
|           char *name;                 /* ASCII encoded string */ |  | ||||||
|           PyObject* (*initfunc)(void); |  | ||||||
|       }; |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyImport_ExtendInittab(struct _inittab *newtab) |  | ||||||
| 
 |  | ||||||
|    Add a collection of modules to the table of built-in modules.  The *newtab* |  | ||||||
|    array must end with a sentinel entry which contains *NULL* for the :attr:`name` |  | ||||||
|    field; failure to provide the sentinel value can result in a memory fault. |  | ||||||
|    Returns ``0`` on success or ``-1`` if insufficient memory could be allocated to |  | ||||||
|    extend the internal table.  In the event of failure, no modules are added to the |  | ||||||
|    internal table.  This should be called before :c:func:`Py_Initialize`. |  | ||||||
							
								
								
									
										26
									
								
								third_party/python/Doc/c-api/index.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										26
									
								
								third_party/python/Doc/c-api/index.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,26 +0,0 @@ | ||||||
| .. _c-api-index: |  | ||||||
| 
 |  | ||||||
| ################################## |  | ||||||
|   Python/C API Reference Manual |  | ||||||
| ################################## |  | ||||||
| 
 |  | ||||||
| This manual documents the API used by C and C++ programmers who want to write |  | ||||||
| extension modules or embed Python.  It is a companion to :ref:`extending-index`, |  | ||||||
| which describes the general principles of extension writing but does not |  | ||||||
| document the API functions in detail. |  | ||||||
| 
 |  | ||||||
| .. toctree:: |  | ||||||
|    :maxdepth: 2 |  | ||||||
| 
 |  | ||||||
|    intro.rst |  | ||||||
|    stable.rst |  | ||||||
|    veryhigh.rst |  | ||||||
|    refcounting.rst |  | ||||||
|    exceptions.rst |  | ||||||
|    utilities.rst |  | ||||||
|    abstract.rst |  | ||||||
|    concrete.rst |  | ||||||
|    init.rst |  | ||||||
|    memory.rst |  | ||||||
|    objimpl.rst |  | ||||||
|    apiabiversion.rst |  | ||||||
							
								
								
									
										1227
									
								
								third_party/python/Doc/c-api/init.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										1227
									
								
								third_party/python/Doc/c-api/init.rst
									
										
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										645
									
								
								third_party/python/Doc/c-api/intro.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										645
									
								
								third_party/python/Doc/c-api/intro.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,645 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _api-intro: |  | ||||||
| 
 |  | ||||||
| ************ |  | ||||||
| Introduction |  | ||||||
| ************ |  | ||||||
| 
 |  | ||||||
| The Application Programmer's Interface to Python gives C and C++ programmers |  | ||||||
| access to the Python interpreter at a variety of levels.  The API is equally |  | ||||||
| usable from C++, but for brevity it is generally referred to as the Python/C |  | ||||||
| API.  There are two fundamentally different reasons for using the Python/C API. |  | ||||||
| The first reason is to write *extension modules* for specific purposes; these |  | ||||||
| are C modules that extend the Python interpreter.  This is probably the most |  | ||||||
| common use.  The second reason is to use Python as a component in a larger |  | ||||||
| application; this technique is generally referred to as :dfn:`embedding` Python |  | ||||||
| in an application. |  | ||||||
| 
 |  | ||||||
| Writing an extension module is a relatively well-understood process,  where a |  | ||||||
| "cookbook" approach works well.  There are several tools  that automate the |  | ||||||
| process to some extent.  While people have embedded  Python in other |  | ||||||
| applications since its early existence, the process of  embedding Python is less |  | ||||||
| straightforward than writing an extension. |  | ||||||
| 
 |  | ||||||
| Many API functions are useful independent of whether you're embedding  or |  | ||||||
| extending Python; moreover, most applications that embed Python  will need to |  | ||||||
| provide a custom extension as well, so it's probably a  good idea to become |  | ||||||
| familiar with writing an extension before  attempting to embed Python in a real |  | ||||||
| application. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _api-includes: |  | ||||||
| 
 |  | ||||||
| Include Files |  | ||||||
| ============= |  | ||||||
| 
 |  | ||||||
| All function, type and macro definitions needed to use the Python/C API are |  | ||||||
| included in your code by the following line:: |  | ||||||
| 
 |  | ||||||
|    #include "Python.h" |  | ||||||
| 
 |  | ||||||
| This implies inclusion of the following standard headers: ``<stdio.h>``, |  | ||||||
| ``<string.h>``, ``<errno.h>``, ``<limits.h>``, ``<assert.h>`` and ``<stdlib.h>`` |  | ||||||
| (if available). |  | ||||||
| 
 |  | ||||||
| .. note:: |  | ||||||
| 
 |  | ||||||
|    Since Python may define some pre-processor definitions which affect the standard |  | ||||||
|    headers on some systems, you *must* include :file:`Python.h` before any standard |  | ||||||
|    headers are included. |  | ||||||
| 
 |  | ||||||
| All user visible names defined by Python.h (except those defined by the included |  | ||||||
| standard headers) have one of the prefixes ``Py`` or ``_Py``.  Names beginning |  | ||||||
| with ``_Py`` are for internal use by the Python implementation and should not be |  | ||||||
| used by extension writers. Structure member names do not have a reserved prefix. |  | ||||||
| 
 |  | ||||||
| **Important:** user code should never define names that begin with ``Py`` or |  | ||||||
| ``_Py``.  This confuses the reader, and jeopardizes the portability of the user |  | ||||||
| code to future Python versions, which may define additional names beginning with |  | ||||||
| one of these prefixes. |  | ||||||
| 
 |  | ||||||
| The header files are typically installed with Python.  On Unix, these  are |  | ||||||
| located in the directories :file:`{prefix}/include/pythonversion/` and |  | ||||||
| :file:`{exec_prefix}/include/pythonversion/`, where :envvar:`prefix` and |  | ||||||
| :envvar:`exec_prefix` are defined by the corresponding parameters to Python's |  | ||||||
| :program:`configure` script and *version* is |  | ||||||
| ``'%d.%d' % sys.version_info[:2]``.  On Windows, the headers are installed |  | ||||||
| in :file:`{prefix}/include`, where :envvar:`prefix` is the installation |  | ||||||
| directory specified to the installer. |  | ||||||
| 
 |  | ||||||
| To include the headers, place both directories (if different) on your compiler's |  | ||||||
| search path for includes.  Do *not* place the parent directories on the search |  | ||||||
| path and then use ``#include <pythonX.Y/Python.h>``; this will break on |  | ||||||
| multi-platform builds since the platform independent headers under |  | ||||||
| :envvar:`prefix` include the platform specific headers from |  | ||||||
| :envvar:`exec_prefix`. |  | ||||||
| 
 |  | ||||||
| C++ users should note that though the API is defined entirely using C, the |  | ||||||
| header files do properly declare the entry points to be ``extern "C"``, so there |  | ||||||
| is no need to do anything special to use the API from C++. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _api-objects: |  | ||||||
| 
 |  | ||||||
| Objects, Types and Reference Counts |  | ||||||
| =================================== |  | ||||||
| 
 |  | ||||||
| .. index:: object: type |  | ||||||
| 
 |  | ||||||
| Most Python/C API functions have one or more arguments as well as a return value |  | ||||||
| of type :c:type:`PyObject\*`.  This type is a pointer to an opaque data type |  | ||||||
| representing an arbitrary Python object.  Since all Python object types are |  | ||||||
| treated the same way by the Python language in most situations (e.g., |  | ||||||
| assignments, scope rules, and argument passing), it is only fitting that they |  | ||||||
| should be represented by a single C type.  Almost all Python objects live on the |  | ||||||
| heap: you never declare an automatic or static variable of type |  | ||||||
| :c:type:`PyObject`, only pointer variables of type :c:type:`PyObject\*` can  be |  | ||||||
| declared.  The sole exception are the type objects; since these must never be |  | ||||||
| deallocated, they are typically static :c:type:`PyTypeObject` objects. |  | ||||||
| 
 |  | ||||||
| All Python objects (even Python integers) have a :dfn:`type` and a |  | ||||||
| :dfn:`reference count`.  An object's type determines what kind of object it is |  | ||||||
| (e.g., an integer, a list, or a user-defined function; there are many more as |  | ||||||
| explained in :ref:`types`).  For each of the well-known types there is a macro |  | ||||||
| to check whether an object is of that type; for instance, ``PyList_Check(a)`` is |  | ||||||
| true if (and only if) the object pointed to by *a* is a Python list. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _api-refcounts: |  | ||||||
| 
 |  | ||||||
| Reference Counts |  | ||||||
| ---------------- |  | ||||||
| 
 |  | ||||||
| The reference count is important because today's computers have a  finite (and |  | ||||||
| often severely limited) memory size; it counts how many  different places there |  | ||||||
| are that have a reference to an object.  Such a  place could be another object, |  | ||||||
| or a global (or static) C variable, or  a local variable in some C function. |  | ||||||
| When an object's reference count  becomes zero, the object is deallocated.  If |  | ||||||
| it contains references to  other objects, their reference count is decremented. |  | ||||||
| Those other  objects may be deallocated in turn, if this decrement makes their |  | ||||||
| reference count become zero, and so on.  (There's an obvious problem  with |  | ||||||
| objects that reference each other here; for now, the solution is  "don't do |  | ||||||
| that.") |  | ||||||
| 
 |  | ||||||
| .. index:: |  | ||||||
|    single: Py_INCREF() |  | ||||||
|    single: Py_DECREF() |  | ||||||
| 
 |  | ||||||
| Reference counts are always manipulated explicitly.  The normal way is  to use |  | ||||||
| the macro :c:func:`Py_INCREF` to increment an object's reference count by one, |  | ||||||
| and :c:func:`Py_DECREF` to decrement it by   one.  The :c:func:`Py_DECREF` macro |  | ||||||
| is considerably more complex than the incref one, since it must check whether |  | ||||||
| the reference count becomes zero and then cause the object's deallocator to be |  | ||||||
| called. The deallocator is a function pointer contained in the object's type |  | ||||||
| structure.  The type-specific deallocator takes care of decrementing the |  | ||||||
| reference counts for other objects contained in the object if this is a compound |  | ||||||
| object type, such as a list, as well as performing any additional finalization |  | ||||||
| that's needed.  There's no chance that the reference count can overflow; at |  | ||||||
| least as many bits are used to hold the reference count as there are distinct |  | ||||||
| memory locations in virtual memory (assuming ``sizeof(Py_ssize_t) >= sizeof(void*)``). |  | ||||||
| Thus, the reference count increment is a simple operation. |  | ||||||
| 
 |  | ||||||
| It is not necessary to increment an object's reference count for every  local |  | ||||||
| variable that contains a pointer to an object.  In theory, the  object's |  | ||||||
| reference count goes up by one when the variable is made to  point to it and it |  | ||||||
| goes down by one when the variable goes out of  scope.  However, these two |  | ||||||
| cancel each other out, so at the end the  reference count hasn't changed.  The |  | ||||||
| only real reason to use the  reference count is to prevent the object from being |  | ||||||
| deallocated as  long as our variable is pointing to it.  If we know that there |  | ||||||
| is at  least one other reference to the object that lives at least as long as |  | ||||||
| our variable, there is no need to increment the reference count  temporarily. |  | ||||||
| An important situation where this arises is in objects  that are passed as |  | ||||||
| arguments to C functions in an extension module  that are called from Python; |  | ||||||
| the call mechanism guarantees to hold a  reference to every argument for the |  | ||||||
| duration of the call. |  | ||||||
| 
 |  | ||||||
| However, a common pitfall is to extract an object from a list and hold on to it |  | ||||||
| for a while without incrementing its reference count. Some other operation might |  | ||||||
| conceivably remove the object from the list, decrementing its reference count |  | ||||||
| and possible deallocating it. The real danger is that innocent-looking |  | ||||||
| operations may invoke arbitrary Python code which could do this; there is a code |  | ||||||
| path which allows control to flow back to the user from a :c:func:`Py_DECREF`, so |  | ||||||
| almost any operation is potentially dangerous. |  | ||||||
| 
 |  | ||||||
| A safe approach is to always use the generic operations (functions  whose name |  | ||||||
| begins with ``PyObject_``, ``PyNumber_``, ``PySequence_`` or ``PyMapping_``). |  | ||||||
| These operations always increment the reference count of the object they return. |  | ||||||
| This leaves the caller with the responsibility to call :c:func:`Py_DECREF` when |  | ||||||
| they are done with the result; this soon becomes second nature. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _api-refcountdetails: |  | ||||||
| 
 |  | ||||||
| Reference Count Details |  | ||||||
| ^^^^^^^^^^^^^^^^^^^^^^^ |  | ||||||
| 
 |  | ||||||
| The reference count behavior of functions in the Python/C API is best  explained |  | ||||||
| in terms of *ownership of references*.  Ownership pertains to references, never |  | ||||||
| to objects (objects are not owned: they are always shared).  "Owning a |  | ||||||
| reference" means being responsible for calling Py_DECREF on it when the |  | ||||||
| reference is no longer needed.  Ownership can also be transferred, meaning that |  | ||||||
| the code that receives ownership of the reference then becomes responsible for |  | ||||||
| eventually decref'ing it by calling :c:func:`Py_DECREF` or :c:func:`Py_XDECREF` |  | ||||||
| when it's no longer needed---or passing on this responsibility (usually to its |  | ||||||
| caller). When a function passes ownership of a reference on to its caller, the |  | ||||||
| caller is said to receive a *new* reference.  When no ownership is transferred, |  | ||||||
| the caller is said to *borrow* the reference. Nothing needs to be done for a |  | ||||||
| borrowed reference. |  | ||||||
| 
 |  | ||||||
| Conversely, when a calling function passes in a reference to an  object, there |  | ||||||
| are two possibilities: the function *steals* a  reference to the object, or it |  | ||||||
| does not.  *Stealing a reference* means that when you pass a reference to a |  | ||||||
| function, that function assumes that it now owns that reference, and you are not |  | ||||||
| responsible for it any longer. |  | ||||||
| 
 |  | ||||||
| .. index:: |  | ||||||
|    single: PyList_SetItem() |  | ||||||
|    single: PyTuple_SetItem() |  | ||||||
| 
 |  | ||||||
| Few functions steal references; the two notable exceptions are |  | ||||||
| :c:func:`PyList_SetItem` and :c:func:`PyTuple_SetItem`, which  steal a reference |  | ||||||
| to the item (but not to the tuple or list into which the item is put!).  These |  | ||||||
| functions were designed to steal a reference because of a common idiom for |  | ||||||
| populating a tuple or list with newly created objects; for example, the code to |  | ||||||
| create the tuple ``(1, 2, "three")`` could look like this (forgetting about |  | ||||||
| error handling for the moment; a better way to code this is shown below):: |  | ||||||
| 
 |  | ||||||
|    PyObject *t; |  | ||||||
| 
 |  | ||||||
|    t = PyTuple_New(3); |  | ||||||
|    PyTuple_SetItem(t, 0, PyLong_FromLong(1L)); |  | ||||||
|    PyTuple_SetItem(t, 1, PyLong_FromLong(2L)); |  | ||||||
|    PyTuple_SetItem(t, 2, PyUnicode_FromString("three")); |  | ||||||
| 
 |  | ||||||
| Here, :c:func:`PyLong_FromLong` returns a new reference which is immediately |  | ||||||
| stolen by :c:func:`PyTuple_SetItem`.  When you want to keep using an object |  | ||||||
| although the reference to it will be stolen, use :c:func:`Py_INCREF` to grab |  | ||||||
| another reference before calling the reference-stealing function. |  | ||||||
| 
 |  | ||||||
| Incidentally, :c:func:`PyTuple_SetItem` is the *only* way to set tuple items; |  | ||||||
| :c:func:`PySequence_SetItem` and :c:func:`PyObject_SetItem` refuse to do this |  | ||||||
| since tuples are an immutable data type.  You should only use |  | ||||||
| :c:func:`PyTuple_SetItem` for tuples that you are creating yourself. |  | ||||||
| 
 |  | ||||||
| Equivalent code for populating a list can be written using :c:func:`PyList_New` |  | ||||||
| and :c:func:`PyList_SetItem`. |  | ||||||
| 
 |  | ||||||
| However, in practice, you will rarely use these ways of creating and populating |  | ||||||
| a tuple or list.  There's a generic function, :c:func:`Py_BuildValue`, that can |  | ||||||
| create most common objects from C values, directed by a :dfn:`format string`. |  | ||||||
| For example, the above two blocks of code could be replaced by the following |  | ||||||
| (which also takes care of the error checking):: |  | ||||||
| 
 |  | ||||||
|    PyObject *tuple, *list; |  | ||||||
| 
 |  | ||||||
|    tuple = Py_BuildValue("(iis)", 1, 2, "three"); |  | ||||||
|    list = Py_BuildValue("[iis]", 1, 2, "three"); |  | ||||||
| 
 |  | ||||||
| It is much more common to use :c:func:`PyObject_SetItem` and friends with items |  | ||||||
| whose references you are only borrowing, like arguments that were passed in to |  | ||||||
| the function you are writing.  In that case, their behaviour regarding reference |  | ||||||
| counts is much saner, since you don't have to increment a reference count so you |  | ||||||
| can give a reference away ("have it be stolen").  For example, this function |  | ||||||
| sets all items of a list (actually, any mutable sequence) to a given item:: |  | ||||||
| 
 |  | ||||||
|    int |  | ||||||
|    set_all(PyObject *target, PyObject *item) |  | ||||||
|    { |  | ||||||
|        Py_ssize_t i, n; |  | ||||||
| 
 |  | ||||||
|        n = PyObject_Length(target); |  | ||||||
|        if (n < 0) |  | ||||||
|            return -1; |  | ||||||
|        for (i = 0; i < n; i++) { |  | ||||||
|            PyObject *index = PyLong_FromSsize_t(i); |  | ||||||
|            if (!index) |  | ||||||
|                return -1; |  | ||||||
|            if (PyObject_SetItem(target, index, item) < 0) { |  | ||||||
|                Py_DECREF(index); |  | ||||||
|                return -1; |  | ||||||
|            } |  | ||||||
|            Py_DECREF(index); |  | ||||||
|        } |  | ||||||
|        return 0; |  | ||||||
|    } |  | ||||||
| 
 |  | ||||||
| .. index:: single: set_all() |  | ||||||
| 
 |  | ||||||
| The situation is slightly different for function return values.   While passing |  | ||||||
| a reference to most functions does not change your  ownership responsibilities |  | ||||||
| for that reference, many functions that  return a reference to an object give |  | ||||||
| you ownership of the reference. The reason is simple: in many cases, the |  | ||||||
| returned object is created  on the fly, and the reference you get is the only |  | ||||||
| reference to the  object.  Therefore, the generic functions that return object |  | ||||||
| references, like :c:func:`PyObject_GetItem` and  :c:func:`PySequence_GetItem`, |  | ||||||
| always return a new reference (the caller becomes the owner of the reference). |  | ||||||
| 
 |  | ||||||
| It is important to realize that whether you own a reference returned  by a |  | ||||||
| function depends on which function you call only --- *the plumage* (the type of |  | ||||||
| the object passed as an argument to the function) *doesn't enter into it!* |  | ||||||
| Thus, if you  extract an item from a list using :c:func:`PyList_GetItem`, you |  | ||||||
| don't own the reference --- but if you obtain the same item from the same list |  | ||||||
| using :c:func:`PySequence_GetItem` (which happens to take exactly the same |  | ||||||
| arguments), you do own a reference to the returned object. |  | ||||||
| 
 |  | ||||||
| .. index:: |  | ||||||
|    single: PyList_GetItem() |  | ||||||
|    single: PySequence_GetItem() |  | ||||||
| 
 |  | ||||||
| Here is an example of how you could write a function that computes the sum of |  | ||||||
| the items in a list of integers; once using  :c:func:`PyList_GetItem`, and once |  | ||||||
| using :c:func:`PySequence_GetItem`. :: |  | ||||||
| 
 |  | ||||||
|    long |  | ||||||
|    sum_list(PyObject *list) |  | ||||||
|    { |  | ||||||
|        Py_ssize_t i, n; |  | ||||||
|        long total = 0, value; |  | ||||||
|        PyObject *item; |  | ||||||
| 
 |  | ||||||
|        n = PyList_Size(list); |  | ||||||
|        if (n < 0) |  | ||||||
|            return -1; /* Not a list */ |  | ||||||
|        for (i = 0; i < n; i++) { |  | ||||||
|            item = PyList_GetItem(list, i); /* Can't fail */ |  | ||||||
|            if (!PyLong_Check(item)) continue; /* Skip non-integers */ |  | ||||||
|            value = PyLong_AsLong(item); |  | ||||||
|            if (value == -1 && PyErr_Occurred()) |  | ||||||
|                /* Integer too big to fit in a C long, bail out */ |  | ||||||
|                return -1; |  | ||||||
|            total += value; |  | ||||||
|        } |  | ||||||
|        return total; |  | ||||||
|    } |  | ||||||
| 
 |  | ||||||
| .. index:: single: sum_list() |  | ||||||
| 
 |  | ||||||
| :: |  | ||||||
| 
 |  | ||||||
|    long |  | ||||||
|    sum_sequence(PyObject *sequence) |  | ||||||
|    { |  | ||||||
|        Py_ssize_t i, n; |  | ||||||
|        long total = 0, value; |  | ||||||
|        PyObject *item; |  | ||||||
|        n = PySequence_Length(sequence); |  | ||||||
|        if (n < 0) |  | ||||||
|            return -1; /* Has no length */ |  | ||||||
|        for (i = 0; i < n; i++) { |  | ||||||
|            item = PySequence_GetItem(sequence, i); |  | ||||||
|            if (item == NULL) |  | ||||||
|                return -1; /* Not a sequence, or other failure */ |  | ||||||
|            if (PyLong_Check(item)) { |  | ||||||
|                value = PyLong_AsLong(item); |  | ||||||
|                Py_DECREF(item); |  | ||||||
|                if (value == -1 && PyErr_Occurred()) |  | ||||||
|                    /* Integer too big to fit in a C long, bail out */ |  | ||||||
|                    return -1; |  | ||||||
|                total += value; |  | ||||||
|            } |  | ||||||
|            else { |  | ||||||
|                Py_DECREF(item); /* Discard reference ownership */ |  | ||||||
|            } |  | ||||||
|        } |  | ||||||
|        return total; |  | ||||||
|    } |  | ||||||
| 
 |  | ||||||
| .. index:: single: sum_sequence() |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _api-types: |  | ||||||
| 
 |  | ||||||
| Types |  | ||||||
| ----- |  | ||||||
| 
 |  | ||||||
| There are few other data types that play a significant role in  the Python/C |  | ||||||
| API; most are simple C types such as :c:type:`int`,  :c:type:`long`, |  | ||||||
| :c:type:`double` and :c:type:`char\*`.  A few structure types  are used to |  | ||||||
| describe static tables used to list the functions exported  by a module or the |  | ||||||
| data attributes of a new object type, and another is used to describe the value |  | ||||||
| of a complex number.  These will  be discussed together with the functions that |  | ||||||
| use them. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _api-exceptions: |  | ||||||
| 
 |  | ||||||
| Exceptions |  | ||||||
| ========== |  | ||||||
| 
 |  | ||||||
| The Python programmer only needs to deal with exceptions if specific  error |  | ||||||
| handling is required; unhandled exceptions are automatically  propagated to the |  | ||||||
| caller, then to the caller's caller, and so on, until they reach the top-level |  | ||||||
| interpreter, where they are reported to the  user accompanied by a stack |  | ||||||
| traceback. |  | ||||||
| 
 |  | ||||||
| .. index:: single: PyErr_Occurred() |  | ||||||
| 
 |  | ||||||
| For C programmers, however, error checking always has to be explicit.  All |  | ||||||
| functions in the Python/C API can raise exceptions, unless an explicit claim is |  | ||||||
| made otherwise in a function's documentation.  In general, when a function |  | ||||||
| encounters an error, it sets an exception, discards any object references that |  | ||||||
| it owns, and returns an error indicator.  If not documented otherwise, this |  | ||||||
| indicator is either *NULL* or ``-1``, depending on the function's return type. |  | ||||||
| A few functions return a Boolean true/false result, with false indicating an |  | ||||||
| error.  Very few functions return no explicit error indicator or have an |  | ||||||
| ambiguous return value, and require explicit testing for errors with |  | ||||||
| :c:func:`PyErr_Occurred`.  These exceptions are always explicitly documented. |  | ||||||
| 
 |  | ||||||
| .. index:: |  | ||||||
|    single: PyErr_SetString() |  | ||||||
|    single: PyErr_Clear() |  | ||||||
| 
 |  | ||||||
| Exception state is maintained in per-thread storage (this is  equivalent to |  | ||||||
| using global storage in an unthreaded application).  A  thread can be in one of |  | ||||||
| two states: an exception has occurred, or not. The function |  | ||||||
| :c:func:`PyErr_Occurred` can be used to check for this: it returns a borrowed |  | ||||||
| reference to the exception type object when an exception has occurred, and |  | ||||||
| *NULL* otherwise.  There are a number of functions to set the exception state: |  | ||||||
| :c:func:`PyErr_SetString` is the most common (though not the most general) |  | ||||||
| function to set the exception state, and :c:func:`PyErr_Clear` clears the |  | ||||||
| exception state. |  | ||||||
| 
 |  | ||||||
| The full exception state consists of three objects (all of which can  be |  | ||||||
| *NULL*): the exception type, the corresponding exception  value, and the |  | ||||||
| traceback.  These have the same meanings as the Python result of |  | ||||||
| ``sys.exc_info()``; however, they are not the same: the Python objects represent |  | ||||||
| the last exception being handled by a Python  :keyword:`try` ... |  | ||||||
| :keyword:`except` statement, while the C level exception state only exists while |  | ||||||
| an exception is being passed on between C functions until it reaches the Python |  | ||||||
| bytecode interpreter's  main loop, which takes care of transferring it to |  | ||||||
| ``sys.exc_info()`` and friends. |  | ||||||
| 
 |  | ||||||
| .. index:: single: exc_info() (in module sys) |  | ||||||
| 
 |  | ||||||
| Note that starting with Python 1.5, the preferred, thread-safe way to access the |  | ||||||
| exception state from Python code is to call the function :func:`sys.exc_info`, |  | ||||||
| which returns the per-thread exception state for Python code.  Also, the |  | ||||||
| semantics of both ways to access the exception state have changed so that a |  | ||||||
| function which catches an exception will save and restore its thread's exception |  | ||||||
| state so as to preserve the exception state of its caller.  This prevents common |  | ||||||
| bugs in exception handling code caused by an innocent-looking function |  | ||||||
| overwriting the exception being handled; it also reduces the often unwanted |  | ||||||
| lifetime extension for objects that are referenced by the stack frames in the |  | ||||||
| traceback. |  | ||||||
| 
 |  | ||||||
| As a general principle, a function that calls another function to  perform some |  | ||||||
| task should check whether the called function raised an  exception, and if so, |  | ||||||
| pass the exception state on to its caller.  It  should discard any object |  | ||||||
| references that it owns, and return an  error indicator, but it should *not* set |  | ||||||
| another exception --- that would overwrite the exception that was just raised, |  | ||||||
| and lose important information about the exact cause of the error. |  | ||||||
| 
 |  | ||||||
| .. index:: single: sum_sequence() |  | ||||||
| 
 |  | ||||||
| A simple example of detecting exceptions and passing them on is shown in the |  | ||||||
| :c:func:`sum_sequence` example above.  It so happens that this example doesn't |  | ||||||
| need to clean up any owned references when it detects an error.  The following |  | ||||||
| example function shows some error cleanup.  First, to remind you why you like |  | ||||||
| Python, we show the equivalent Python code:: |  | ||||||
| 
 |  | ||||||
|    def incr_item(dict, key): |  | ||||||
|        try: |  | ||||||
|            item = dict[key] |  | ||||||
|        except KeyError: |  | ||||||
|            item = 0 |  | ||||||
|        dict[key] = item + 1 |  | ||||||
| 
 |  | ||||||
| .. index:: single: incr_item() |  | ||||||
| 
 |  | ||||||
| Here is the corresponding C code, in all its glory:: |  | ||||||
| 
 |  | ||||||
|    int |  | ||||||
|    incr_item(PyObject *dict, PyObject *key) |  | ||||||
|    { |  | ||||||
|        /* Objects all initialized to NULL for Py_XDECREF */ |  | ||||||
|        PyObject *item = NULL, *const_one = NULL, *incremented_item = NULL; |  | ||||||
|        int rv = -1; /* Return value initialized to -1 (failure) */ |  | ||||||
| 
 |  | ||||||
|        item = PyObject_GetItem(dict, key); |  | ||||||
|        if (item == NULL) { |  | ||||||
|            /* Handle KeyError only: */ |  | ||||||
|            if (!PyErr_ExceptionMatches(PyExc_KeyError)) |  | ||||||
|                goto error; |  | ||||||
| 
 |  | ||||||
|            /* Clear the error and use zero: */ |  | ||||||
|            PyErr_Clear(); |  | ||||||
|            item = PyLong_FromLong(0L); |  | ||||||
|            if (item == NULL) |  | ||||||
|                goto error; |  | ||||||
|        } |  | ||||||
|        const_one = PyLong_FromLong(1L); |  | ||||||
|        if (const_one == NULL) |  | ||||||
|            goto error; |  | ||||||
| 
 |  | ||||||
|        incremented_item = PyNumber_Add(item, const_one); |  | ||||||
|        if (incremented_item == NULL) |  | ||||||
|            goto error; |  | ||||||
| 
 |  | ||||||
|        if (PyObject_SetItem(dict, key, incremented_item) < 0) |  | ||||||
|            goto error; |  | ||||||
|        rv = 0; /* Success */ |  | ||||||
|        /* Continue with cleanup code */ |  | ||||||
| 
 |  | ||||||
|     error: |  | ||||||
|        /* Cleanup code, shared by success and failure path */ |  | ||||||
| 
 |  | ||||||
|        /* Use Py_XDECREF() to ignore NULL references */ |  | ||||||
|        Py_XDECREF(item); |  | ||||||
|        Py_XDECREF(const_one); |  | ||||||
|        Py_XDECREF(incremented_item); |  | ||||||
| 
 |  | ||||||
|        return rv; /* -1 for error, 0 for success */ |  | ||||||
|    } |  | ||||||
| 
 |  | ||||||
| .. index:: single: incr_item() |  | ||||||
| 
 |  | ||||||
| .. index:: |  | ||||||
|    single: PyErr_ExceptionMatches() |  | ||||||
|    single: PyErr_Clear() |  | ||||||
|    single: Py_XDECREF() |  | ||||||
| 
 |  | ||||||
| This example represents an endorsed use of the ``goto`` statement  in C! |  | ||||||
| It illustrates the use of :c:func:`PyErr_ExceptionMatches` and |  | ||||||
| :c:func:`PyErr_Clear` to handle specific exceptions, and the use of |  | ||||||
| :c:func:`Py_XDECREF` to dispose of owned references that may be *NULL* (note the |  | ||||||
| ``'X'`` in the name; :c:func:`Py_DECREF` would crash when confronted with a |  | ||||||
| *NULL* reference).  It is important that the variables used to hold owned |  | ||||||
| references are initialized to *NULL* for this to work; likewise, the proposed |  | ||||||
| return value is initialized to ``-1`` (failure) and only set to success after |  | ||||||
| the final call made is successful. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _api-embedding: |  | ||||||
| 
 |  | ||||||
| Embedding Python |  | ||||||
| ================ |  | ||||||
| 
 |  | ||||||
| The one important task that only embedders (as opposed to extension writers) of |  | ||||||
| the Python interpreter have to worry about is the initialization, and possibly |  | ||||||
| the finalization, of the Python interpreter.  Most functionality of the |  | ||||||
| interpreter can only be used after the interpreter has been initialized. |  | ||||||
| 
 |  | ||||||
| .. index:: |  | ||||||
|    single: Py_Initialize() |  | ||||||
|    module: builtins |  | ||||||
|    module: __main__ |  | ||||||
|    module: sys |  | ||||||
|    triple: module; search; path |  | ||||||
|    single: path (in module sys) |  | ||||||
| 
 |  | ||||||
| The basic initialization function is :c:func:`Py_Initialize`. This initializes |  | ||||||
| the table of loaded modules, and creates the fundamental modules |  | ||||||
| :mod:`builtins`, :mod:`__main__`, and :mod:`sys`.  It also |  | ||||||
| initializes the module search path (``sys.path``). |  | ||||||
| 
 |  | ||||||
| .. index:: single: PySys_SetArgvEx() |  | ||||||
| 
 |  | ||||||
| :c:func:`Py_Initialize` does not set the "script argument list"  (``sys.argv``). |  | ||||||
| If this variable is needed by Python code that will be executed later, it must |  | ||||||
| be set explicitly with a call to  ``PySys_SetArgvEx(argc, argv, updatepath)`` |  | ||||||
| after the call to :c:func:`Py_Initialize`. |  | ||||||
| 
 |  | ||||||
| On most systems (in particular, on Unix and Windows, although the details are |  | ||||||
| slightly different), :c:func:`Py_Initialize` calculates the module search path |  | ||||||
| based upon its best guess for the location of the standard Python interpreter |  | ||||||
| executable, assuming that the Python library is found in a fixed location |  | ||||||
| relative to the Python interpreter executable.  In particular, it looks for a |  | ||||||
| directory named :file:`lib/python{X.Y}` relative to the parent directory |  | ||||||
| where the executable named :file:`python` is found on the shell command search |  | ||||||
| path (the environment variable :envvar:`PATH`). |  | ||||||
| 
 |  | ||||||
| For instance, if the Python executable is found in |  | ||||||
| :file:`/usr/local/bin/python`, it will assume that the libraries are in |  | ||||||
| :file:`/usr/local/lib/python{X.Y}`.  (In fact, this particular path is also |  | ||||||
| the "fallback" location, used when no executable file named :file:`python` is |  | ||||||
| found along :envvar:`PATH`.)  The user can override this behavior by setting the |  | ||||||
| environment variable :envvar:`PYTHONHOME`, or insert additional directories in |  | ||||||
| front of the standard path by setting :envvar:`PYTHONPATH`. |  | ||||||
| 
 |  | ||||||
| .. index:: |  | ||||||
|    single: Py_SetProgramName() |  | ||||||
|    single: Py_GetPath() |  | ||||||
|    single: Py_GetPrefix() |  | ||||||
|    single: Py_GetExecPrefix() |  | ||||||
|    single: Py_GetProgramFullPath() |  | ||||||
| 
 |  | ||||||
| The embedding application can steer the search by calling |  | ||||||
| ``Py_SetProgramName(file)`` *before* calling  :c:func:`Py_Initialize`.  Note that |  | ||||||
| :envvar:`PYTHONHOME` still overrides this and :envvar:`PYTHONPATH` is still |  | ||||||
| inserted in front of the standard path.  An application that requires total |  | ||||||
| control has to provide its own implementation of :c:func:`Py_GetPath`, |  | ||||||
| :c:func:`Py_GetPrefix`, :c:func:`Py_GetExecPrefix`, and |  | ||||||
| :c:func:`Py_GetProgramFullPath` (all defined in :file:`Modules/getpath.c`). |  | ||||||
| 
 |  | ||||||
| .. index:: single: Py_IsInitialized() |  | ||||||
| 
 |  | ||||||
| Sometimes, it is desirable to "uninitialize" Python.  For instance,  the |  | ||||||
| application may want to start over (make another call to |  | ||||||
| :c:func:`Py_Initialize`) or the application is simply done with its  use of |  | ||||||
| Python and wants to free memory allocated by Python.  This can be accomplished |  | ||||||
| by calling :c:func:`Py_FinalizeEx`.  The function :c:func:`Py_IsInitialized` returns |  | ||||||
| true if Python is currently in the initialized state.  More information about |  | ||||||
| these functions is given in a later chapter. Notice that :c:func:`Py_FinalizeEx` |  | ||||||
| does *not* free all memory allocated by the Python interpreter, e.g. memory |  | ||||||
| allocated by extension modules currently cannot be released. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _api-debugging: |  | ||||||
| 
 |  | ||||||
| Debugging Builds |  | ||||||
| ================ |  | ||||||
| 
 |  | ||||||
| Python can be built with several macros to enable extra checks of the |  | ||||||
| interpreter and extension modules.  These checks tend to add a large amount of |  | ||||||
| overhead to the runtime so they are not enabled by default. |  | ||||||
| 
 |  | ||||||
| A full list of the various types of debugging builds is in the file |  | ||||||
| :file:`Misc/SpecialBuilds.txt` in the Python source distribution. Builds are |  | ||||||
| available that support tracing of reference counts, debugging the memory |  | ||||||
| allocator, or low-level profiling of the main interpreter loop.  Only the most |  | ||||||
| frequently-used builds will be described in the remainder of this section. |  | ||||||
| 
 |  | ||||||
| Compiling the interpreter with the :c:macro:`Py_DEBUG` macro defined produces |  | ||||||
| what is generally meant by "a debug build" of Python. :c:macro:`Py_DEBUG` is |  | ||||||
| enabled in the Unix build by adding ``--with-pydebug`` to the |  | ||||||
| :file:`./configure` command.  It is also implied by the presence of the |  | ||||||
| not-Python-specific :c:macro:`_DEBUG` macro.  When :c:macro:`Py_DEBUG` is enabled |  | ||||||
| in the Unix build, compiler optimization is disabled. |  | ||||||
| 
 |  | ||||||
| In addition to the reference count debugging described below, the following |  | ||||||
| extra checks are performed: |  | ||||||
| 
 |  | ||||||
| * Extra checks are added to the object allocator. |  | ||||||
| 
 |  | ||||||
| * Extra checks are added to the parser and compiler. |  | ||||||
| 
 |  | ||||||
| * Downcasts from wide types to narrow types are checked for loss of information. |  | ||||||
| 
 |  | ||||||
| * A number of assertions are added to the dictionary and set implementations. |  | ||||||
|   In addition, the set object acquires a :meth:`test_c_api` method. |  | ||||||
| 
 |  | ||||||
| * Sanity checks of the input arguments are added to frame creation. |  | ||||||
| 
 |  | ||||||
| * The storage for ints is initialized with a known invalid pattern to catch |  | ||||||
|   reference to uninitialized digits. |  | ||||||
| 
 |  | ||||||
| * Low-level tracing and extra exception checking are added to the runtime |  | ||||||
|   virtual machine. |  | ||||||
| 
 |  | ||||||
| * Extra checks are added to the memory arena implementation. |  | ||||||
| 
 |  | ||||||
| * Extra debugging is added to the thread module. |  | ||||||
| 
 |  | ||||||
| There may be additional checks not mentioned here. |  | ||||||
| 
 |  | ||||||
| Defining :c:macro:`Py_TRACE_REFS` enables reference tracing.  When defined, a |  | ||||||
| circular doubly linked list of active objects is maintained by adding two extra |  | ||||||
| fields to every :c:type:`PyObject`.  Total allocations are tracked as well.  Upon |  | ||||||
| exit, all existing references are printed.  (In interactive mode this happens |  | ||||||
| after every statement run by the interpreter.)  Implied by :c:macro:`Py_DEBUG`. |  | ||||||
| 
 |  | ||||||
| Please refer to :file:`Misc/SpecialBuilds.txt` in the Python source distribution |  | ||||||
| for more detailed information. |  | ||||||
| 
 |  | ||||||
							
								
								
									
										46
									
								
								third_party/python/Doc/c-api/iter.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										46
									
								
								third_party/python/Doc/c-api/iter.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,46 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _iterator: |  | ||||||
| 
 |  | ||||||
| Iterator Protocol |  | ||||||
| ================= |  | ||||||
| 
 |  | ||||||
| There are two functions specifically for working with iterators. |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyIter_Check(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return true if the object *o* supports the iterator protocol. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyIter_Next(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return the next value from the iteration *o*.  The object must be an iterator |  | ||||||
|    (it is up to the caller to check this).  If there are no remaining values, |  | ||||||
|    returns *NULL* with no exception set.  If an error occurs while retrieving |  | ||||||
|    the item, returns *NULL* and passes along the exception. |  | ||||||
| 
 |  | ||||||
| To write a loop which iterates over an iterator, the C code should look |  | ||||||
| something like this:: |  | ||||||
| 
 |  | ||||||
|    PyObject *iterator = PyObject_GetIter(obj); |  | ||||||
|    PyObject *item; |  | ||||||
| 
 |  | ||||||
|    if (iterator == NULL) { |  | ||||||
|        /* propagate error */ |  | ||||||
|    } |  | ||||||
| 
 |  | ||||||
|    while (item = PyIter_Next(iterator)) { |  | ||||||
|        /* do something with item */ |  | ||||||
|        ... |  | ||||||
|        /* release reference when done */ |  | ||||||
|        Py_DECREF(item); |  | ||||||
|    } |  | ||||||
| 
 |  | ||||||
|    Py_DECREF(iterator); |  | ||||||
| 
 |  | ||||||
|    if (PyErr_Occurred()) { |  | ||||||
|        /* propagate error */ |  | ||||||
|    } |  | ||||||
|    else { |  | ||||||
|        /* continue doing useful work */ |  | ||||||
|    } |  | ||||||
							
								
								
									
										50
									
								
								third_party/python/Doc/c-api/iterator.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										50
									
								
								third_party/python/Doc/c-api/iterator.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,50 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _iterator-objects: |  | ||||||
| 
 |  | ||||||
| Iterator Objects |  | ||||||
| ---------------- |  | ||||||
| 
 |  | ||||||
| Python provides two general-purpose iterator objects.  The first, a sequence |  | ||||||
| iterator, works with an arbitrary sequence supporting the :meth:`__getitem__` |  | ||||||
| method.  The second works with a callable object and a sentinel value, calling |  | ||||||
| the callable for each item in the sequence, and ending the iteration when the |  | ||||||
| sentinel value is returned. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PySeqIter_Type |  | ||||||
| 
 |  | ||||||
|    Type object for iterator objects returned by :c:func:`PySeqIter_New` and the |  | ||||||
|    one-argument form of the :func:`iter` built-in function for built-in sequence |  | ||||||
|    types. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PySeqIter_Check(op) |  | ||||||
| 
 |  | ||||||
|    Return true if the type of *op* is :c:data:`PySeqIter_Type`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PySeqIter_New(PyObject *seq) |  | ||||||
| 
 |  | ||||||
|    Return an iterator that works with a general sequence object, *seq*.  The |  | ||||||
|    iteration ends when the sequence raises :exc:`IndexError` for the subscripting |  | ||||||
|    operation. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyCallIter_Type |  | ||||||
| 
 |  | ||||||
|    Type object for iterator objects returned by :c:func:`PyCallIter_New` and the |  | ||||||
|    two-argument form of the :func:`iter` built-in function. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyCallIter_Check(op) |  | ||||||
| 
 |  | ||||||
|    Return true if the type of *op* is :c:data:`PyCallIter_Type`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyCallIter_New(PyObject *callable, PyObject *sentinel) |  | ||||||
| 
 |  | ||||||
|    Return a new iterator.  The first parameter, *callable*, can be any Python |  | ||||||
|    callable object that can be called with no parameters; each call to it should |  | ||||||
|    return the next item in the iteration.  When *callable* returns a value equal to |  | ||||||
|    *sentinel*, the iteration will be terminated. |  | ||||||
							
								
								
									
										151
									
								
								third_party/python/Doc/c-api/list.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										151
									
								
								third_party/python/Doc/c-api/list.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,151 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _listobjects: |  | ||||||
| 
 |  | ||||||
| List Objects |  | ||||||
| ------------ |  | ||||||
| 
 |  | ||||||
| .. index:: object: list |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyListObject |  | ||||||
| 
 |  | ||||||
|    This subtype of :c:type:`PyObject` represents a Python list object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyList_Type |  | ||||||
| 
 |  | ||||||
|    This instance of :c:type:`PyTypeObject` represents the Python list type. |  | ||||||
|    This is the same object as :class:`list` in the Python layer. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyList_Check(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if *p* is a list object or an instance of a subtype of the list |  | ||||||
|    type. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyList_CheckExact(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if *p* is a list object, but not an instance of a subtype of |  | ||||||
|    the list type. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyList_New(Py_ssize_t len) |  | ||||||
| 
 |  | ||||||
|    Return a new list of length *len* on success, or *NULL* on failure. |  | ||||||
| 
 |  | ||||||
|    .. note:: |  | ||||||
| 
 |  | ||||||
|       If *len* is greater than zero, the returned list object's items are |  | ||||||
|       set to ``NULL``.  Thus you cannot use abstract API functions such as |  | ||||||
|       :c:func:`PySequence_SetItem`  or expose the object to Python code before |  | ||||||
|       setting all items to a real object with :c:func:`PyList_SetItem`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PyList_Size(PyObject *list) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: len |  | ||||||
| 
 |  | ||||||
|    Return the length of the list object in *list*; this is equivalent to |  | ||||||
|    ``len(list)`` on a list object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PyList_GET_SIZE(PyObject *list) |  | ||||||
| 
 |  | ||||||
|    Macro form of :c:func:`PyList_Size` without error checking. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyList_GetItem(PyObject *list, Py_ssize_t index) |  | ||||||
| 
 |  | ||||||
|    Return the object at position *index* in the list pointed to by *list*.  The |  | ||||||
|    position must be positive, indexing from the end of the list is not |  | ||||||
|    supported.  If *index* is out of bounds, return *NULL* and set an |  | ||||||
|    :exc:`IndexError` exception. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyList_GET_ITEM(PyObject *list, Py_ssize_t i) |  | ||||||
| 
 |  | ||||||
|    Macro form of :c:func:`PyList_GetItem` without error checking. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyList_SetItem(PyObject *list, Py_ssize_t index, PyObject *item) |  | ||||||
| 
 |  | ||||||
|    Set the item at index *index* in list to *item*.  Return ``0`` on success |  | ||||||
|    or ``-1`` on failure. |  | ||||||
| 
 |  | ||||||
|    .. note:: |  | ||||||
| 
 |  | ||||||
|       This function "steals" a reference to *item* and discards a reference to |  | ||||||
|       an item already in the list at the affected position. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyList_SET_ITEM(PyObject *list, Py_ssize_t i, PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Macro form of :c:func:`PyList_SetItem` without error checking. This is |  | ||||||
|    normally only used to fill in new lists where there is no previous content. |  | ||||||
| 
 |  | ||||||
|    .. note:: |  | ||||||
| 
 |  | ||||||
|       This macro "steals" a reference to *item*, and, unlike |  | ||||||
|       :c:func:`PyList_SetItem`, does *not* discard a reference to any item that |  | ||||||
|       is being replaced; any reference in *list* at position *i* will be |  | ||||||
|       leaked. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyList_Insert(PyObject *list, Py_ssize_t index, PyObject *item) |  | ||||||
| 
 |  | ||||||
|    Insert the item *item* into list *list* in front of index *index*.  Return |  | ||||||
|    ``0`` if successful; return ``-1`` and set an exception if unsuccessful. |  | ||||||
|    Analogous to ``list.insert(index, item)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyList_Append(PyObject *list, PyObject *item) |  | ||||||
| 
 |  | ||||||
|    Append the object *item* at the end of list *list*. Return ``0`` if |  | ||||||
|    successful; return ``-1`` and set an exception if unsuccessful.  Analogous |  | ||||||
|    to ``list.append(item)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyList_GetSlice(PyObject *list, Py_ssize_t low, Py_ssize_t high) |  | ||||||
| 
 |  | ||||||
|    Return a list of the objects in *list* containing the objects *between* *low* |  | ||||||
|    and *high*.  Return *NULL* and set an exception if unsuccessful.  Analogous |  | ||||||
|    to ``list[low:high]``.  Negative indices, as when slicing from Python, are not |  | ||||||
|    supported. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyList_SetSlice(PyObject *list, Py_ssize_t low, Py_ssize_t high, PyObject *itemlist) |  | ||||||
| 
 |  | ||||||
|    Set the slice of *list* between *low* and *high* to the contents of |  | ||||||
|    *itemlist*.  Analogous to ``list[low:high] = itemlist``. The *itemlist* may |  | ||||||
|    be *NULL*, indicating the assignment of an empty list (slice deletion). |  | ||||||
|    Return ``0`` on success, ``-1`` on failure.  Negative indices, as when |  | ||||||
|    slicing from Python, are not supported. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyList_Sort(PyObject *list) |  | ||||||
| 
 |  | ||||||
|    Sort the items of *list* in place.  Return ``0`` on success, ``-1`` on |  | ||||||
|    failure.  This is equivalent to ``list.sort()``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyList_Reverse(PyObject *list) |  | ||||||
| 
 |  | ||||||
|    Reverse the items of *list* in place.  Return ``0`` on success, ``-1`` on |  | ||||||
|    failure.  This is the equivalent of ``list.reverse()``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyList_AsTuple(PyObject *list) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: tuple |  | ||||||
| 
 |  | ||||||
|    Return a new tuple object containing the contents of *list*; equivalent to |  | ||||||
|    ``tuple(list)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyList_ClearFreeList() |  | ||||||
| 
 |  | ||||||
|    Clear the free list. Return the total number of freed items. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
							
								
								
									
										295
									
								
								third_party/python/Doc/c-api/long.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										295
									
								
								third_party/python/Doc/c-api/long.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,295 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _longobjects: |  | ||||||
| 
 |  | ||||||
| Integer Objects |  | ||||||
| --------------- |  | ||||||
| 
 |  | ||||||
| .. index:: object: long integer |  | ||||||
|            object: integer |  | ||||||
| 
 |  | ||||||
| All integers are implemented as "long" integer objects of arbitrary size. |  | ||||||
| 
 |  | ||||||
| On error, most ``PyLong_As*`` APIs return ``(return type)-1`` which cannot be |  | ||||||
| distinguished from a number.  Use :c:func:`PyErr_Occurred` to disambiguate. |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyLongObject |  | ||||||
| 
 |  | ||||||
|    This subtype of :c:type:`PyObject` represents a Python integer object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyLong_Type |  | ||||||
| 
 |  | ||||||
|    This instance of :c:type:`PyTypeObject` represents the Python integer type. |  | ||||||
|    This is the same object as :class:`int` in the Python layer. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyLong_Check(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if its argument is a :c:type:`PyLongObject` or a subtype of |  | ||||||
|    :c:type:`PyLongObject`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyLong_CheckExact(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if its argument is a :c:type:`PyLongObject`, but not a subtype of |  | ||||||
|    :c:type:`PyLongObject`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyLong_FromLong(long v) |  | ||||||
| 
 |  | ||||||
|    Return a new :c:type:`PyLongObject` object from *v*, or *NULL* on failure. |  | ||||||
| 
 |  | ||||||
|    The current implementation keeps an array of integer objects for all integers |  | ||||||
|    between ``-5`` and ``256``, when you create an int in that range you actually |  | ||||||
|    just get back a reference to the existing object. So it should be possible to |  | ||||||
|    change the value of ``1``.  I suspect the behaviour of Python in this case is |  | ||||||
|    undefined. :-) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyLong_FromUnsignedLong(unsigned long v) |  | ||||||
| 
 |  | ||||||
|    Return a new :c:type:`PyLongObject` object from a C :c:type:`unsigned long`, or |  | ||||||
|    *NULL* on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyLong_FromSsize_t(Py_ssize_t v) |  | ||||||
| 
 |  | ||||||
|    Return a new :c:type:`PyLongObject` object from a C :c:type:`Py_ssize_t`, or |  | ||||||
|    *NULL* on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyLong_FromSize_t(size_t v) |  | ||||||
| 
 |  | ||||||
|    Return a new :c:type:`PyLongObject` object from a C :c:type:`size_t`, or |  | ||||||
|    *NULL* on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyLong_FromLongLong(long long v) |  | ||||||
| 
 |  | ||||||
|    Return a new :c:type:`PyLongObject` object from a C :c:type:`long long`, or *NULL* |  | ||||||
|    on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyLong_FromUnsignedLongLong(unsigned long long v) |  | ||||||
| 
 |  | ||||||
|    Return a new :c:type:`PyLongObject` object from a C :c:type:`unsigned long long`, |  | ||||||
|    or *NULL* on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyLong_FromDouble(double v) |  | ||||||
| 
 |  | ||||||
|    Return a new :c:type:`PyLongObject` object from the integer part of *v*, or |  | ||||||
|    *NULL* on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyLong_FromString(const char *str, char **pend, int base) |  | ||||||
| 
 |  | ||||||
|    Return a new :c:type:`PyLongObject` based on the string value in *str*, which |  | ||||||
|    is interpreted according to the radix in *base*.  If *pend* is non-*NULL*, |  | ||||||
|    *\*pend* will point to the first character in *str* which follows the |  | ||||||
|    representation of the number.  If *base* is ``0``, *str* is interpreted using |  | ||||||
|    the :ref:`integers` definition; in this case, leading zeros in a |  | ||||||
|    non-zero decimal number raises a :exc:`ValueError`. If *base* is not ``0``, |  | ||||||
|    it must be between ``2`` and ``36``, inclusive.  Leading spaces and single |  | ||||||
|    underscores after a base specifier and between digits are ignored.  If there |  | ||||||
|    are no digits, :exc:`ValueError` will be raised. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyLong_FromUnicode(Py_UNICODE *u, Py_ssize_t length, int base) |  | ||||||
| 
 |  | ||||||
|    Convert a sequence of Unicode digits to a Python integer value.  The Unicode |  | ||||||
|    string is first encoded to a byte string using :c:func:`PyUnicode_EncodeDecimal` |  | ||||||
|    and then converted using :c:func:`PyLong_FromString`. |  | ||||||
| 
 |  | ||||||
|    .. deprecated-removed:: 3.3 4.0 |  | ||||||
|       Part of the old-style :c:type:`Py_UNICODE` API; please migrate to using |  | ||||||
|       :c:func:`PyLong_FromUnicodeObject`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyLong_FromUnicodeObject(PyObject *u, int base) |  | ||||||
| 
 |  | ||||||
|    Convert a sequence of Unicode digits in the string *u* to a Python integer |  | ||||||
|    value.  The Unicode string is first encoded to a byte string using |  | ||||||
|    :c:func:`PyUnicode_EncodeDecimal` and then converted using |  | ||||||
|    :c:func:`PyLong_FromString`. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyLong_FromVoidPtr(void *p) |  | ||||||
| 
 |  | ||||||
|    Create a Python integer from the pointer *p*. The pointer value can be |  | ||||||
|    retrieved from the resulting value using :c:func:`PyLong_AsVoidPtr`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. XXX alias PyLong_AS_LONG (for now) |  | ||||||
| .. c:function:: long PyLong_AsLong(PyObject *obj) |  | ||||||
| 
 |  | ||||||
|    .. index:: |  | ||||||
|       single: LONG_MAX |  | ||||||
|       single: OverflowError (built-in exception) |  | ||||||
| 
 |  | ||||||
|    Return a C :c:type:`long` representation of *obj*.  If *obj* is not an |  | ||||||
|    instance of :c:type:`PyLongObject`, first call its :meth:`__int__` method |  | ||||||
|    (if present) to convert it to a :c:type:`PyLongObject`. |  | ||||||
| 
 |  | ||||||
|    Raise :exc:`OverflowError` if the value of *obj* is out of range for a |  | ||||||
|    :c:type:`long`. |  | ||||||
| 
 |  | ||||||
|    Returns ``-1`` on error.  Use :c:func:`PyErr_Occurred` to disambiguate. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: long PyLong_AsLongAndOverflow(PyObject *obj, int *overflow) |  | ||||||
| 
 |  | ||||||
|    Return a C :c:type:`long` representation of *obj*.  If *obj* is not an |  | ||||||
|    instance of :c:type:`PyLongObject`, first call its :meth:`__int__` method |  | ||||||
|    (if present) to convert it to a :c:type:`PyLongObject`. |  | ||||||
| 
 |  | ||||||
|    If the value of *obj* is greater than :const:`LONG_MAX` or less than |  | ||||||
|    :const:`LONG_MIN`, set *\*overflow* to ``1`` or ``-1``, respectively, and |  | ||||||
|    return ``-1``; otherwise, set *\*overflow* to ``0``.  If any other exception |  | ||||||
|    occurs set *\*overflow* to ``0`` and return ``-1`` as usual. |  | ||||||
| 
 |  | ||||||
|    Returns ``-1`` on error.  Use :c:func:`PyErr_Occurred` to disambiguate. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: long long PyLong_AsLongLong(PyObject *obj) |  | ||||||
| 
 |  | ||||||
|    .. index:: |  | ||||||
|       single: OverflowError (built-in exception) |  | ||||||
| 
 |  | ||||||
|    Return a C :c:type:`long long` representation of *obj*.  If *obj* is not an |  | ||||||
|    instance of :c:type:`PyLongObject`, first call its :meth:`__int__` method |  | ||||||
|    (if present) to convert it to a :c:type:`PyLongObject`. |  | ||||||
| 
 |  | ||||||
|    Raise :exc:`OverflowError` if the value of *obj* is out of range for a |  | ||||||
|    :c:type:`long`. |  | ||||||
| 
 |  | ||||||
|    Returns ``-1`` on error.  Use :c:func:`PyErr_Occurred` to disambiguate. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: long long PyLong_AsLongLongAndOverflow(PyObject *obj, int *overflow) |  | ||||||
| 
 |  | ||||||
|    Return a C :c:type:`long long` representation of *obj*.  If *obj* is not an |  | ||||||
|    instance of :c:type:`PyLongObject`, first call its :meth:`__int__` method |  | ||||||
|    (if present) to convert it to a :c:type:`PyLongObject`. |  | ||||||
| 
 |  | ||||||
|    If the value of *obj* is greater than :const:`PY_LLONG_MAX` or less than |  | ||||||
|    :const:`PY_LLONG_MIN`, set *\*overflow* to ``1`` or ``-1``, respectively, |  | ||||||
|    and return ``-1``; otherwise, set *\*overflow* to ``0``.  If any other |  | ||||||
|    exception occurs set *\*overflow* to ``0`` and return ``-1`` as usual. |  | ||||||
| 
 |  | ||||||
|    Returns ``-1`` on error.  Use :c:func:`PyErr_Occurred` to disambiguate. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.2 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PyLong_AsSsize_t(PyObject *pylong) |  | ||||||
| 
 |  | ||||||
|    .. index:: |  | ||||||
|       single: PY_SSIZE_T_MAX |  | ||||||
|       single: OverflowError (built-in exception) |  | ||||||
| 
 |  | ||||||
|    Return a C :c:type:`Py_ssize_t` representation of *pylong*.  *pylong* must |  | ||||||
|    be an instance of :c:type:`PyLongObject`. |  | ||||||
| 
 |  | ||||||
|    Raise :exc:`OverflowError` if the value of *pylong* is out of range for a |  | ||||||
|    :c:type:`Py_ssize_t`. |  | ||||||
| 
 |  | ||||||
|    Returns ``-1`` on error.  Use :c:func:`PyErr_Occurred` to disambiguate. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: unsigned long PyLong_AsUnsignedLong(PyObject *pylong) |  | ||||||
| 
 |  | ||||||
|    .. index:: |  | ||||||
|       single: ULONG_MAX |  | ||||||
|       single: OverflowError (built-in exception) |  | ||||||
| 
 |  | ||||||
|    Return a C :c:type:`unsigned long` representation of *pylong*.  *pylong* |  | ||||||
|    must be an instance of :c:type:`PyLongObject`. |  | ||||||
| 
 |  | ||||||
|    Raise :exc:`OverflowError` if the value of *pylong* is out of range for a |  | ||||||
|    :c:type:`unsigned long`. |  | ||||||
| 
 |  | ||||||
|    Returns ``(unsigned long)-1`` on error. |  | ||||||
|    Use :c:func:`PyErr_Occurred` to disambiguate. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: size_t PyLong_AsSize_t(PyObject *pylong) |  | ||||||
| 
 |  | ||||||
|    .. index:: |  | ||||||
|       single: SIZE_MAX |  | ||||||
|       single: OverflowError (built-in exception) |  | ||||||
| 
 |  | ||||||
|    Return a C :c:type:`size_t` representation of *pylong*.  *pylong* must be |  | ||||||
|    an instance of :c:type:`PyLongObject`. |  | ||||||
| 
 |  | ||||||
|    Raise :exc:`OverflowError` if the value of *pylong* is out of range for a |  | ||||||
|    :c:type:`size_t`. |  | ||||||
| 
 |  | ||||||
|    Returns ``(size_t)-1`` on error. |  | ||||||
|    Use :c:func:`PyErr_Occurred` to disambiguate. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: unsigned long long PyLong_AsUnsignedLongLong(PyObject *pylong) |  | ||||||
| 
 |  | ||||||
|    .. index:: |  | ||||||
|       single: OverflowError (built-in exception) |  | ||||||
| 
 |  | ||||||
|    Return a C :c:type:`unsigned long long` representation of *pylong*.  *pylong* |  | ||||||
|    must be an instance of :c:type:`PyLongObject`. |  | ||||||
| 
 |  | ||||||
|    Raise :exc:`OverflowError` if the value of *pylong* is out of range for an |  | ||||||
|    :c:type:`unsigned long long`. |  | ||||||
| 
 |  | ||||||
|    Returns ``(unsigned long long)-1`` on error. |  | ||||||
|    Use :c:func:`PyErr_Occurred` to disambiguate. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.1 |  | ||||||
|       A negative *pylong* now raises :exc:`OverflowError`, not :exc:`TypeError`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: unsigned long PyLong_AsUnsignedLongMask(PyObject *obj) |  | ||||||
| 
 |  | ||||||
|    Return a C :c:type:`unsigned long` representation of *obj*.  If *obj* |  | ||||||
|    is not an instance of :c:type:`PyLongObject`, first call its :meth:`__int__` |  | ||||||
|    method (if present) to convert it to a :c:type:`PyLongObject`. |  | ||||||
| 
 |  | ||||||
|    If the value of *obj* is out of range for an :c:type:`unsigned long`, |  | ||||||
|    return the reduction of that value modulo ``ULONG_MAX + 1``. |  | ||||||
| 
 |  | ||||||
|    Returns ``-1`` on error.  Use :c:func:`PyErr_Occurred` to disambiguate. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: unsigned long long PyLong_AsUnsignedLongLongMask(PyObject *obj) |  | ||||||
| 
 |  | ||||||
|    Return a C :c:type:`unsigned long long` representation of *obj*.  If *obj* |  | ||||||
|    is not an instance of :c:type:`PyLongObject`, first call its :meth:`__int__` |  | ||||||
|    method (if present) to convert it to a :c:type:`PyLongObject`. |  | ||||||
| 
 |  | ||||||
|    If the value of *obj* is out of range for an :c:type:`unsigned long long`, |  | ||||||
|    return the reduction of that value modulo ``PY_ULLONG_MAX + 1``. |  | ||||||
| 
 |  | ||||||
|    Returns ``-1`` on error.  Use :c:func:`PyErr_Occurred` to disambiguate. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: double PyLong_AsDouble(PyObject *pylong) |  | ||||||
| 
 |  | ||||||
|    Return a C :c:type:`double` representation of *pylong*.  *pylong* must be |  | ||||||
|    an instance of :c:type:`PyLongObject`. |  | ||||||
| 
 |  | ||||||
|    Raise :exc:`OverflowError` if the value of *pylong* is out of range for a |  | ||||||
|    :c:type:`double`. |  | ||||||
| 
 |  | ||||||
|    Returns ``-1.0`` on error.  Use :c:func:`PyErr_Occurred` to disambiguate. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void* PyLong_AsVoidPtr(PyObject *pylong) |  | ||||||
| 
 |  | ||||||
|    Convert a Python integer *pylong* to a C :c:type:`void` pointer. |  | ||||||
|    If *pylong* cannot be converted, an :exc:`OverflowError` will be raised.  This |  | ||||||
|    is only assured to produce a usable :c:type:`void` pointer for values created |  | ||||||
|    with :c:func:`PyLong_FromVoidPtr`. |  | ||||||
| 
 |  | ||||||
|    Returns *NULL* on error.  Use :c:func:`PyErr_Occurred` to disambiguate. |  | ||||||
							
								
								
									
										94
									
								
								third_party/python/Doc/c-api/mapping.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										94
									
								
								third_party/python/Doc/c-api/mapping.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,94 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _mapping: |  | ||||||
| 
 |  | ||||||
| Mapping Protocol |  | ||||||
| ================ |  | ||||||
| 
 |  | ||||||
| See also :c:func:`PyObject_GetItem`, :c:func:`PyObject_SetItem` and |  | ||||||
| :c:func:`PyObject_DelItem`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyMapping_Check(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return ``1`` if the object provides mapping protocol or supports slicing, |  | ||||||
|    and ``0`` otherwise.  Note that it returns ``1`` for Python classes with |  | ||||||
|    a :meth:`__getitem__` method since in general case it is impossible to |  | ||||||
|    determine what the type of keys it supports.  This function always |  | ||||||
|    succeeds. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PyMapping_Size(PyObject *o) |  | ||||||
|                Py_ssize_t PyMapping_Length(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: len |  | ||||||
| 
 |  | ||||||
|    Returns the number of keys in object *o* on success, and ``-1`` on failure. |  | ||||||
|    This is equivalent to the Python expression ``len(o)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyMapping_GetItemString(PyObject *o, const char *key) |  | ||||||
| 
 |  | ||||||
|    Return element of *o* corresponding to the string *key* or *NULL* on failure. |  | ||||||
|    This is the equivalent of the Python expression ``o[key]``. |  | ||||||
|    See also :c:func:`PyObject_GetItem`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyMapping_SetItemString(PyObject *o, const char *key, PyObject *v) |  | ||||||
| 
 |  | ||||||
|    Map the string *key* to the value *v* in object *o*.  Returns ``-1`` on |  | ||||||
|    failure.  This is the equivalent of the Python statement ``o[key] = v``. |  | ||||||
|    See also :c:func:`PyObject_SetItem`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyMapping_DelItem(PyObject *o, PyObject *key) |  | ||||||
| 
 |  | ||||||
|    Remove the mapping for the object *key* from the object *o*.  Return ``-1`` |  | ||||||
|    on failure.  This is equivalent to the Python statement ``del o[key]``. |  | ||||||
|    This is an alias of :c:func:`PyObject_DelItem`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyMapping_DelItemString(PyObject *o, const char *key) |  | ||||||
| 
 |  | ||||||
|    Remove the mapping for the string *key* from the object *o*.  Return ``-1`` |  | ||||||
|    on failure.  This is equivalent to the Python statement ``del o[key]``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyMapping_HasKey(PyObject *o, PyObject *key) |  | ||||||
| 
 |  | ||||||
|    Return ``1`` if the mapping object has the key *key* and ``0`` otherwise. |  | ||||||
|    This is equivalent to the Python expression ``key in o``. |  | ||||||
|    This function always succeeds. |  | ||||||
| 
 |  | ||||||
|    Note that exceptions which occur while calling the :meth:`__getitem__` |  | ||||||
|    method will get suppressed. |  | ||||||
|    To get error reporting use :c:func:`PyObject_GetItem()` instead. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyMapping_HasKeyString(PyObject *o, const char *key) |  | ||||||
| 
 |  | ||||||
|    Return ``1`` if the mapping object has the key *key* and ``0`` otherwise. |  | ||||||
|    This is equivalent to the Python expression ``key in o``. |  | ||||||
|    This function always succeeds. |  | ||||||
| 
 |  | ||||||
|    Note that exceptions which occur while calling the :meth:`__getitem__` |  | ||||||
|    method and creating a temporary string object will get suppressed. |  | ||||||
|    To get error reporting use :c:func:`PyMapping_GetItemString()` instead. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyMapping_Keys(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    On success, return a list or tuple of the keys in object *o*.  On failure, |  | ||||||
|    return *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyMapping_Values(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    On success, return a list or tuple of the values in object *o*.  On failure, |  | ||||||
|    return *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyMapping_Items(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    On success, return a list or tuple of the items in object *o*, where each item |  | ||||||
|    is a tuple containing a key-value pair.  On failure, return *NULL*. |  | ||||||
							
								
								
									
										94
									
								
								third_party/python/Doc/c-api/marshal.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										94
									
								
								third_party/python/Doc/c-api/marshal.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,94 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _marshalling-utils: |  | ||||||
| 
 |  | ||||||
| Data marshalling support |  | ||||||
| ======================== |  | ||||||
| 
 |  | ||||||
| These routines allow C code to work with serialized objects using the same |  | ||||||
| data format as the :mod:`marshal` module.  There are functions to write data |  | ||||||
| into the serialization format, and additional functions that can be used to |  | ||||||
| read the data back.  Files used to store marshalled data must be opened in |  | ||||||
| binary mode. |  | ||||||
| 
 |  | ||||||
| Numeric values are stored with the least significant byte first. |  | ||||||
| 
 |  | ||||||
| The module supports two versions of the data format: version 0 is the |  | ||||||
| historical version, version 1 shares interned strings in the file, and upon |  | ||||||
| unmarshalling.  Version 2 uses a binary format for floating point numbers. |  | ||||||
| *Py_MARSHAL_VERSION* indicates the current file format (currently 2). |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyMarshal_WriteLongToFile(long value, FILE *file, int version) |  | ||||||
| 
 |  | ||||||
|    Marshal a :c:type:`long` integer, *value*, to *file*.  This will only write |  | ||||||
|    the least-significant 32 bits of *value*; regardless of the size of the |  | ||||||
|    native :c:type:`long` type.  *version* indicates the file format. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyMarshal_WriteObjectToFile(PyObject *value, FILE *file, int version) |  | ||||||
| 
 |  | ||||||
|    Marshal a Python object, *value*, to *file*. |  | ||||||
|    *version* indicates the file format. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyMarshal_WriteObjectToString(PyObject *value, int version) |  | ||||||
| 
 |  | ||||||
|    Return a bytes object containing the marshalled representation of *value*. |  | ||||||
|    *version* indicates the file format. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| The following functions allow marshalled values to be read back in. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: long PyMarshal_ReadLongFromFile(FILE *file) |  | ||||||
| 
 |  | ||||||
|    Return a C :c:type:`long` from the data stream in a :c:type:`FILE\*` opened |  | ||||||
|    for reading.  Only a 32-bit value can be read in using this function, |  | ||||||
|    regardless of the native size of :c:type:`long`. |  | ||||||
| 
 |  | ||||||
|    On error, sets the appropriate exception (:exc:`EOFError`) and returns |  | ||||||
|    ``-1``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyMarshal_ReadShortFromFile(FILE *file) |  | ||||||
| 
 |  | ||||||
|    Return a C :c:type:`short` from the data stream in a :c:type:`FILE\*` opened |  | ||||||
|    for reading.  Only a 16-bit value can be read in using this function, |  | ||||||
|    regardless of the native size of :c:type:`short`. |  | ||||||
| 
 |  | ||||||
|    On error, sets the appropriate exception (:exc:`EOFError`) and returns |  | ||||||
|    ``-1``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyMarshal_ReadObjectFromFile(FILE *file) |  | ||||||
| 
 |  | ||||||
|    Return a Python object from the data stream in a :c:type:`FILE\*` opened for |  | ||||||
|    reading. |  | ||||||
| 
 |  | ||||||
|    On error, sets the appropriate exception (:exc:`EOFError`, :exc:`ValueError` |  | ||||||
|    or :exc:`TypeError`) and returns *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyMarshal_ReadLastObjectFromFile(FILE *file) |  | ||||||
| 
 |  | ||||||
|    Return a Python object from the data stream in a :c:type:`FILE\*` opened for |  | ||||||
|    reading.  Unlike :c:func:`PyMarshal_ReadObjectFromFile`, this function |  | ||||||
|    assumes that no further objects will be read from the file, allowing it to |  | ||||||
|    aggressively load file data into memory so that the de-serialization can |  | ||||||
|    operate from data in memory rather than reading a byte at a time from the |  | ||||||
|    file.  Only use these variant if you are certain that you won't be reading |  | ||||||
|    anything else from the file. |  | ||||||
| 
 |  | ||||||
|    On error, sets the appropriate exception (:exc:`EOFError`, :exc:`ValueError` |  | ||||||
|    or :exc:`TypeError`) and returns *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyMarshal_ReadObjectFromString(const char *data, Py_ssize_t len) |  | ||||||
| 
 |  | ||||||
|    Return a Python object from the data stream in a byte buffer |  | ||||||
|    containing *len* bytes pointed to by *data*. |  | ||||||
| 
 |  | ||||||
|    On error, sets the appropriate exception (:exc:`EOFError`, :exc:`ValueError` |  | ||||||
|    or :exc:`TypeError`) and returns *NULL*. |  | ||||||
| 
 |  | ||||||
							
								
								
									
										546
									
								
								third_party/python/Doc/c-api/memory.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										546
									
								
								third_party/python/Doc/c-api/memory.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,546 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _memory: |  | ||||||
| 
 |  | ||||||
| ***************** |  | ||||||
| Memory Management |  | ||||||
| ***************** |  | ||||||
| 
 |  | ||||||
| .. sectionauthor:: Vladimir Marangozov <Vladimir.Marangozov@inrialpes.fr> |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _memoryoverview: |  | ||||||
| 
 |  | ||||||
| Overview |  | ||||||
| ======== |  | ||||||
| 
 |  | ||||||
| Memory management in Python involves a private heap containing all Python |  | ||||||
| objects and data structures. The management of this private heap is ensured |  | ||||||
| internally by the *Python memory manager*.  The Python memory manager has |  | ||||||
| different components which deal with various dynamic storage management aspects, |  | ||||||
| like sharing, segmentation, preallocation or caching. |  | ||||||
| 
 |  | ||||||
| At the lowest level, a raw memory allocator ensures that there is enough room in |  | ||||||
| the private heap for storing all Python-related data by interacting with the |  | ||||||
| memory manager of the operating system. On top of the raw memory allocator, |  | ||||||
| several object-specific allocators operate on the same heap and implement |  | ||||||
| distinct memory management policies adapted to the peculiarities of every object |  | ||||||
| type. For example, integer objects are managed differently within the heap than |  | ||||||
| strings, tuples or dictionaries because integers imply different storage |  | ||||||
| requirements and speed/space tradeoffs. The Python memory manager thus delegates |  | ||||||
| some of the work to the object-specific allocators, but ensures that the latter |  | ||||||
| operate within the bounds of the private heap. |  | ||||||
| 
 |  | ||||||
| It is important to understand that the management of the Python heap is |  | ||||||
| performed by the interpreter itself and that the user has no control over it, |  | ||||||
| even if they regularly manipulate object pointers to memory blocks inside that |  | ||||||
| heap.  The allocation of heap space for Python objects and other internal |  | ||||||
| buffers is performed on demand by the Python memory manager through the Python/C |  | ||||||
| API functions listed in this document. |  | ||||||
| 
 |  | ||||||
| .. index:: |  | ||||||
|    single: malloc() |  | ||||||
|    single: calloc() |  | ||||||
|    single: realloc() |  | ||||||
|    single: free() |  | ||||||
| 
 |  | ||||||
| To avoid memory corruption, extension writers should never try to operate on |  | ||||||
| Python objects with the functions exported by the C library: :c:func:`malloc`, |  | ||||||
| :c:func:`calloc`, :c:func:`realloc` and :c:func:`free`.  This will result in  mixed |  | ||||||
| calls between the C allocator and the Python memory manager with fatal |  | ||||||
| consequences, because they implement different algorithms and operate on |  | ||||||
| different heaps.  However, one may safely allocate and release memory blocks |  | ||||||
| with the C library allocator for individual purposes, as shown in the following |  | ||||||
| example:: |  | ||||||
| 
 |  | ||||||
|    PyObject *res; |  | ||||||
|    char *buf = (char *) malloc(BUFSIZ); /* for I/O */ |  | ||||||
| 
 |  | ||||||
|    if (buf == NULL) |  | ||||||
|        return PyErr_NoMemory(); |  | ||||||
|    ...Do some I/O operation involving buf... |  | ||||||
|    res = PyBytes_FromString(buf); |  | ||||||
|    free(buf); /* malloc'ed */ |  | ||||||
|    return res; |  | ||||||
| 
 |  | ||||||
| In this example, the memory request for the I/O buffer is handled by the C |  | ||||||
| library allocator. The Python memory manager is involved only in the allocation |  | ||||||
| of the string object returned as a result. |  | ||||||
| 
 |  | ||||||
| In most situations, however, it is recommended to allocate memory from the |  | ||||||
| Python heap specifically because the latter is under control of the Python |  | ||||||
| memory manager. For example, this is required when the interpreter is extended |  | ||||||
| with new object types written in C. Another reason for using the Python heap is |  | ||||||
| the desire to *inform* the Python memory manager about the memory needs of the |  | ||||||
| extension module. Even when the requested memory is used exclusively for |  | ||||||
| internal, highly-specific purposes, delegating all memory requests to the Python |  | ||||||
| memory manager causes the interpreter to have a more accurate image of its |  | ||||||
| memory footprint as a whole. Consequently, under certain circumstances, the |  | ||||||
| Python memory manager may or may not trigger appropriate actions, like garbage |  | ||||||
| collection, memory compaction or other preventive procedures. Note that by using |  | ||||||
| the C library allocator as shown in the previous example, the allocated memory |  | ||||||
| for the I/O buffer escapes completely the Python memory manager. |  | ||||||
| 
 |  | ||||||
| .. seealso:: |  | ||||||
| 
 |  | ||||||
|    The :envvar:`PYTHONMALLOC` environment variable can be used to configure |  | ||||||
|    the memory allocators used by Python. |  | ||||||
| 
 |  | ||||||
|    The :envvar:`PYTHONMALLOCSTATS` environment variable can be used to print |  | ||||||
|    statistics of the :ref:`pymalloc memory allocator <pymalloc>` every time a |  | ||||||
|    new pymalloc object arena is created, and on shutdown. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Raw Memory Interface |  | ||||||
| ==================== |  | ||||||
| 
 |  | ||||||
| The following function sets are wrappers to the system allocator. These |  | ||||||
| functions are thread-safe, the :term:`GIL <global interpreter lock>` does not |  | ||||||
| need to be held. |  | ||||||
| 
 |  | ||||||
| The default raw memory block allocator uses the following functions: |  | ||||||
| :c:func:`malloc`, :c:func:`calloc`, :c:func:`realloc` and :c:func:`free`; call |  | ||||||
| ``malloc(1)`` (or ``calloc(1, 1)``) when requesting zero bytes. |  | ||||||
| 
 |  | ||||||
| .. versionadded:: 3.4 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void* PyMem_RawMalloc(size_t n) |  | ||||||
| 
 |  | ||||||
|    Allocates *n* bytes and returns a pointer of type :c:type:`void\*` to the |  | ||||||
|    allocated memory, or *NULL* if the request fails. |  | ||||||
| 
 |  | ||||||
|    Requesting zero bytes returns a distinct non-*NULL* pointer if possible, as |  | ||||||
|    if ``PyMem_RawMalloc(1)`` had been called instead. The memory will not have |  | ||||||
|    been initialized in any way. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void* PyMem_RawCalloc(size_t nelem, size_t elsize) |  | ||||||
| 
 |  | ||||||
|    Allocates *nelem* elements each whose size in bytes is *elsize* and returns |  | ||||||
|    a pointer of type :c:type:`void\*` to the allocated memory, or *NULL* if the |  | ||||||
|    request fails. The memory is initialized to zeros. |  | ||||||
| 
 |  | ||||||
|    Requesting zero elements or elements of size zero bytes returns a distinct |  | ||||||
|    non-*NULL* pointer if possible, as if ``PyMem_RawCalloc(1, 1)`` had been |  | ||||||
|    called instead. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.5 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void* PyMem_RawRealloc(void *p, size_t n) |  | ||||||
| 
 |  | ||||||
|    Resizes the memory block pointed to by *p* to *n* bytes. The contents will |  | ||||||
|    be unchanged to the minimum of the old and the new sizes. |  | ||||||
| 
 |  | ||||||
|    If *p* is *NULL*, the call is equivalent to ``PyMem_RawMalloc(n)``; else if |  | ||||||
|    *n* is equal to zero, the memory block is resized but is not freed, and the |  | ||||||
|    returned pointer is non-*NULL*. |  | ||||||
| 
 |  | ||||||
|    Unless *p* is *NULL*, it must have been returned by a previous call to |  | ||||||
|    :c:func:`PyMem_RawMalloc`, :c:func:`PyMem_RawRealloc` or |  | ||||||
|    :c:func:`PyMem_RawCalloc`. |  | ||||||
| 
 |  | ||||||
|    If the request fails, :c:func:`PyMem_RawRealloc` returns *NULL* and *p* |  | ||||||
|    remains a valid pointer to the previous memory area. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyMem_RawFree(void *p) |  | ||||||
| 
 |  | ||||||
|    Frees the memory block pointed to by *p*, which must have been returned by a |  | ||||||
|    previous call to :c:func:`PyMem_RawMalloc`, :c:func:`PyMem_RawRealloc` or |  | ||||||
|    :c:func:`PyMem_RawCalloc`.  Otherwise, or if ``PyMem_RawFree(p)`` has been |  | ||||||
|    called before, undefined behavior occurs. |  | ||||||
| 
 |  | ||||||
|    If *p* is *NULL*, no operation is performed. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _memoryinterface: |  | ||||||
| 
 |  | ||||||
| Memory Interface |  | ||||||
| ================ |  | ||||||
| 
 |  | ||||||
| The following function sets, modeled after the ANSI C standard, but specifying |  | ||||||
| behavior when requesting zero bytes, are available for allocating and releasing |  | ||||||
| memory from the Python heap. |  | ||||||
| 
 |  | ||||||
| By default, these functions use :ref:`pymalloc memory allocator <pymalloc>`. |  | ||||||
| 
 |  | ||||||
| .. warning:: |  | ||||||
| 
 |  | ||||||
|    The :term:`GIL <global interpreter lock>` must be held when using these |  | ||||||
|    functions. |  | ||||||
| 
 |  | ||||||
| .. versionchanged:: 3.6 |  | ||||||
| 
 |  | ||||||
|    The default allocator is now pymalloc instead of system :c:func:`malloc`. |  | ||||||
| 
 |  | ||||||
| .. c:function:: void* PyMem_Malloc(size_t n) |  | ||||||
| 
 |  | ||||||
|    Allocates *n* bytes and returns a pointer of type :c:type:`void\*` to the |  | ||||||
|    allocated memory, or *NULL* if the request fails. |  | ||||||
| 
 |  | ||||||
|    Requesting zero bytes returns a distinct non-*NULL* pointer if possible, as |  | ||||||
|    if ``PyMem_Malloc(1)`` had been called instead. The memory will not have |  | ||||||
|    been initialized in any way. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void* PyMem_Calloc(size_t nelem, size_t elsize) |  | ||||||
| 
 |  | ||||||
|    Allocates *nelem* elements each whose size in bytes is *elsize* and returns |  | ||||||
|    a pointer of type :c:type:`void\*` to the allocated memory, or *NULL* if the |  | ||||||
|    request fails. The memory is initialized to zeros. |  | ||||||
| 
 |  | ||||||
|    Requesting zero elements or elements of size zero bytes returns a distinct |  | ||||||
|    non-*NULL* pointer if possible, as if ``PyMem_Calloc(1, 1)`` had been called |  | ||||||
|    instead. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.5 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void* PyMem_Realloc(void *p, size_t n) |  | ||||||
| 
 |  | ||||||
|    Resizes the memory block pointed to by *p* to *n* bytes. The contents will be |  | ||||||
|    unchanged to the minimum of the old and the new sizes. |  | ||||||
| 
 |  | ||||||
|    If *p* is *NULL*, the call is equivalent to ``PyMem_Malloc(n)``; else if *n* |  | ||||||
|    is equal to zero, the memory block is resized but is not freed, and the |  | ||||||
|    returned pointer is non-*NULL*. |  | ||||||
| 
 |  | ||||||
|    Unless *p* is *NULL*, it must have been returned by a previous call to |  | ||||||
|    :c:func:`PyMem_Malloc`, :c:func:`PyMem_Realloc` or :c:func:`PyMem_Calloc`. |  | ||||||
| 
 |  | ||||||
|    If the request fails, :c:func:`PyMem_Realloc` returns *NULL* and *p* remains |  | ||||||
|    a valid pointer to the previous memory area. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyMem_Free(void *p) |  | ||||||
| 
 |  | ||||||
|    Frees the memory block pointed to by *p*, which must have been returned by a |  | ||||||
|    previous call to :c:func:`PyMem_Malloc`, :c:func:`PyMem_Realloc` or |  | ||||||
|    :c:func:`PyMem_Calloc`.  Otherwise, or if ``PyMem_Free(p)`` has been called |  | ||||||
|    before, undefined behavior occurs. |  | ||||||
| 
 |  | ||||||
|    If *p* is *NULL*, no operation is performed. |  | ||||||
| 
 |  | ||||||
| The following type-oriented macros are provided for convenience.  Note  that |  | ||||||
| *TYPE* refers to any C type. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: TYPE* PyMem_New(TYPE, size_t n) |  | ||||||
| 
 |  | ||||||
|    Same as :c:func:`PyMem_Malloc`, but allocates ``(n * sizeof(TYPE))`` bytes of |  | ||||||
|    memory.  Returns a pointer cast to :c:type:`TYPE\*`.  The memory will not have |  | ||||||
|    been initialized in any way. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: TYPE* PyMem_Resize(void *p, TYPE, size_t n) |  | ||||||
| 
 |  | ||||||
|    Same as :c:func:`PyMem_Realloc`, but the memory block is resized to ``(n * |  | ||||||
|    sizeof(TYPE))`` bytes.  Returns a pointer cast to :c:type:`TYPE\*`. On return, |  | ||||||
|    *p* will be a pointer to the new memory area, or *NULL* in the event of |  | ||||||
|    failure. |  | ||||||
| 
 |  | ||||||
|    This is a C preprocessor macro; *p* is always reassigned.  Save the original |  | ||||||
|    value of *p* to avoid losing memory when handling errors. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyMem_Del(void *p) |  | ||||||
| 
 |  | ||||||
|    Same as :c:func:`PyMem_Free`. |  | ||||||
| 
 |  | ||||||
| In addition, the following macro sets are provided for calling the Python memory |  | ||||||
| allocator directly, without involving the C API functions listed above. However, |  | ||||||
| note that their use does not preserve binary compatibility across Python |  | ||||||
| versions and is therefore deprecated in extension modules. |  | ||||||
| 
 |  | ||||||
| * ``PyMem_MALLOC(size)`` |  | ||||||
| * ``PyMem_NEW(type, size)`` |  | ||||||
| * ``PyMem_REALLOC(ptr, size)`` |  | ||||||
| * ``PyMem_RESIZE(ptr, type, size)`` |  | ||||||
| * ``PyMem_FREE(ptr)`` |  | ||||||
| * ``PyMem_DEL(ptr)`` |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Object allocators |  | ||||||
| ================= |  | ||||||
| 
 |  | ||||||
| The following function sets, modeled after the ANSI C standard, but specifying |  | ||||||
| behavior when requesting zero bytes, are available for allocating and releasing |  | ||||||
| memory from the Python heap. |  | ||||||
| 
 |  | ||||||
| By default, these functions use :ref:`pymalloc memory allocator <pymalloc>`. |  | ||||||
| 
 |  | ||||||
| .. warning:: |  | ||||||
| 
 |  | ||||||
|    The :term:`GIL <global interpreter lock>` must be held when using these |  | ||||||
|    functions. |  | ||||||
| 
 |  | ||||||
| .. c:function:: void* PyObject_Malloc(size_t n) |  | ||||||
| 
 |  | ||||||
|    Allocates *n* bytes and returns a pointer of type :c:type:`void\*` to the |  | ||||||
|    allocated memory, or *NULL* if the request fails. |  | ||||||
| 
 |  | ||||||
|    Requesting zero bytes returns a distinct non-*NULL* pointer if possible, as |  | ||||||
|    if ``PyObject_Malloc(1)`` had been called instead. The memory will not have |  | ||||||
|    been initialized in any way. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void* PyObject_Calloc(size_t nelem, size_t elsize) |  | ||||||
| 
 |  | ||||||
|    Allocates *nelem* elements each whose size in bytes is *elsize* and returns |  | ||||||
|    a pointer of type :c:type:`void\*` to the allocated memory, or *NULL* if the |  | ||||||
|    request fails. The memory is initialized to zeros. |  | ||||||
| 
 |  | ||||||
|    Requesting zero elements or elements of size zero bytes returns a distinct |  | ||||||
|    non-*NULL* pointer if possible, as if ``PyObject_Calloc(1, 1)`` had been called |  | ||||||
|    instead. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.5 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void* PyObject_Realloc(void *p, size_t n) |  | ||||||
| 
 |  | ||||||
|    Resizes the memory block pointed to by *p* to *n* bytes. The contents will be |  | ||||||
|    unchanged to the minimum of the old and the new sizes. |  | ||||||
| 
 |  | ||||||
|    If *p* is *NULL*, the call is equivalent to ``PyObject_Malloc(n)``; else if *n* |  | ||||||
|    is equal to zero, the memory block is resized but is not freed, and the |  | ||||||
|    returned pointer is non-*NULL*. |  | ||||||
| 
 |  | ||||||
|    Unless *p* is *NULL*, it must have been returned by a previous call to |  | ||||||
|    :c:func:`PyObject_Malloc`, :c:func:`PyObject_Realloc` or :c:func:`PyObject_Calloc`. |  | ||||||
| 
 |  | ||||||
|    If the request fails, :c:func:`PyObject_Realloc` returns *NULL* and *p* remains |  | ||||||
|    a valid pointer to the previous memory area. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyObject_Free(void *p) |  | ||||||
| 
 |  | ||||||
|    Frees the memory block pointed to by *p*, which must have been returned by a |  | ||||||
|    previous call to :c:func:`PyObject_Malloc`, :c:func:`PyObject_Realloc` or |  | ||||||
|    :c:func:`PyObject_Calloc`.  Otherwise, or if ``PyObject_Free(p)`` has been called |  | ||||||
|    before, undefined behavior occurs. |  | ||||||
| 
 |  | ||||||
|    If *p* is *NULL*, no operation is performed. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Customize Memory Allocators |  | ||||||
| =========================== |  | ||||||
| 
 |  | ||||||
| .. versionadded:: 3.4 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyMemAllocatorEx |  | ||||||
| 
 |  | ||||||
|    Structure used to describe a memory block allocator. The structure has |  | ||||||
|    four fields: |  | ||||||
| 
 |  | ||||||
|    +----------------------------------------------------------+---------------------------------------+ |  | ||||||
|    | Field                                                    | Meaning                               | |  | ||||||
|    +==========================================================+=======================================+ |  | ||||||
|    | ``void *ctx``                                            | user context passed as first argument | |  | ||||||
|    +----------------------------------------------------------+---------------------------------------+ |  | ||||||
|    | ``void* malloc(void *ctx, size_t size)``                 | allocate a memory block               | |  | ||||||
|    +----------------------------------------------------------+---------------------------------------+ |  | ||||||
|    | ``void* calloc(void *ctx, size_t nelem, size_t elsize)`` | allocate a memory block initialized   | |  | ||||||
|    |                                                          | with zeros                            | |  | ||||||
|    +----------------------------------------------------------+---------------------------------------+ |  | ||||||
|    | ``void* realloc(void *ctx, void *ptr, size_t new_size)`` | allocate or resize a memory block     | |  | ||||||
|    +----------------------------------------------------------+---------------------------------------+ |  | ||||||
|    | ``void free(void *ctx, void *ptr)``                      | free a memory block                   | |  | ||||||
|    +----------------------------------------------------------+---------------------------------------+ |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.5 |  | ||||||
|       The :c:type:`PyMemAllocator` structure was renamed to |  | ||||||
|       :c:type:`PyMemAllocatorEx` and a new ``calloc`` field was added. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyMemAllocatorDomain |  | ||||||
| 
 |  | ||||||
|    Enum used to identify an allocator domain. Domains: |  | ||||||
| 
 |  | ||||||
|    .. c:var:: PYMEM_DOMAIN_RAW |  | ||||||
| 
 |  | ||||||
|       Functions: |  | ||||||
| 
 |  | ||||||
|       * :c:func:`PyMem_RawMalloc` |  | ||||||
|       * :c:func:`PyMem_RawRealloc` |  | ||||||
|       * :c:func:`PyMem_RawCalloc` |  | ||||||
|       * :c:func:`PyMem_RawFree` |  | ||||||
| 
 |  | ||||||
|    .. c:var:: PYMEM_DOMAIN_MEM |  | ||||||
| 
 |  | ||||||
|       Functions: |  | ||||||
| 
 |  | ||||||
|       * :c:func:`PyMem_Malloc`, |  | ||||||
|       * :c:func:`PyMem_Realloc` |  | ||||||
|       * :c:func:`PyMem_Calloc` |  | ||||||
|       * :c:func:`PyMem_Free` |  | ||||||
| 
 |  | ||||||
|    .. c:var:: PYMEM_DOMAIN_OBJ |  | ||||||
| 
 |  | ||||||
|       Functions: |  | ||||||
| 
 |  | ||||||
|       * :c:func:`PyObject_Malloc` |  | ||||||
|       * :c:func:`PyObject_Realloc` |  | ||||||
|       * :c:func:`PyObject_Calloc` |  | ||||||
|       * :c:func:`PyObject_Free` |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyMem_GetAllocator(PyMemAllocatorDomain domain, PyMemAllocatorEx *allocator) |  | ||||||
| 
 |  | ||||||
|    Get the memory block allocator of the specified domain. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyMem_SetAllocator(PyMemAllocatorDomain domain, PyMemAllocatorEx *allocator) |  | ||||||
| 
 |  | ||||||
|    Set the memory block allocator of the specified domain. |  | ||||||
| 
 |  | ||||||
|    The new allocator must return a distinct non-NULL pointer when requesting |  | ||||||
|    zero bytes. |  | ||||||
| 
 |  | ||||||
|    For the :c:data:`PYMEM_DOMAIN_RAW` domain, the allocator must be |  | ||||||
|    thread-safe: the :term:`GIL <global interpreter lock>` is not held when the |  | ||||||
|    allocator is called. |  | ||||||
| 
 |  | ||||||
|    If the new allocator is not a hook (does not call the previous allocator), |  | ||||||
|    the :c:func:`PyMem_SetupDebugHooks` function must be called to reinstall the |  | ||||||
|    debug hooks on top on the new allocator. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyMem_SetupDebugHooks(void) |  | ||||||
| 
 |  | ||||||
|    Setup hooks to detect bugs in the Python memory allocator functions. |  | ||||||
| 
 |  | ||||||
|    Newly allocated memory is filled with the byte ``0xCB``, freed memory is |  | ||||||
|    filled with the byte ``0xDB``. |  | ||||||
| 
 |  | ||||||
|    Runtime checks: |  | ||||||
| 
 |  | ||||||
|    - Detect API violations, ex: :c:func:`PyObject_Free` called on a buffer |  | ||||||
|      allocated by :c:func:`PyMem_Malloc` |  | ||||||
|    - Detect write before the start of the buffer (buffer underflow) |  | ||||||
|    - Detect write after the end of the buffer (buffer overflow) |  | ||||||
|    - Check that the :term:`GIL <global interpreter lock>` is held when |  | ||||||
|      allocator functions of :c:data:`PYMEM_DOMAIN_OBJ` (ex: |  | ||||||
|      :c:func:`PyObject_Malloc`) and :c:data:`PYMEM_DOMAIN_MEM` (ex: |  | ||||||
|      :c:func:`PyMem_Malloc`) domains are called |  | ||||||
| 
 |  | ||||||
|    On error, the debug hooks use the :mod:`tracemalloc` module to get the |  | ||||||
|    traceback where a memory block was allocated. The traceback is only |  | ||||||
|    displayed if :mod:`tracemalloc` is tracing Python memory allocations and the |  | ||||||
|    memory block was traced. |  | ||||||
| 
 |  | ||||||
|    These hooks are installed by default if Python is compiled in debug |  | ||||||
|    mode. The :envvar:`PYTHONMALLOC` environment variable can be used to install |  | ||||||
|    debug hooks on a Python compiled in release mode. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.6 |  | ||||||
|       This function now also works on Python compiled in release mode. |  | ||||||
|       On error, the debug hooks now use :mod:`tracemalloc` to get the traceback |  | ||||||
|       where a memory block was allocated. The debug hooks now also check |  | ||||||
|       if the GIL is held when functions of :c:data:`PYMEM_DOMAIN_OBJ` and |  | ||||||
|       :c:data:`PYMEM_DOMAIN_MEM` domains are called. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _pymalloc: |  | ||||||
| 
 |  | ||||||
| The pymalloc allocator |  | ||||||
| ====================== |  | ||||||
| 
 |  | ||||||
| Python has a *pymalloc* allocator optimized for small objects (smaller or equal |  | ||||||
| to 512 bytes) with a short lifetime. It uses memory mappings called "arenas" |  | ||||||
| with a fixed size of 256 KB. It falls back to :c:func:`PyMem_RawMalloc` and |  | ||||||
| :c:func:`PyMem_RawRealloc` for allocations larger than 512 bytes. |  | ||||||
| 
 |  | ||||||
| *pymalloc* is the default allocator of the :c:data:`PYMEM_DOMAIN_MEM` (ex: |  | ||||||
| :c:func:`PyMem_Malloc`) and :c:data:`PYMEM_DOMAIN_OBJ` (ex: |  | ||||||
| :c:func:`PyObject_Malloc`) domains. |  | ||||||
| 
 |  | ||||||
| The arena allocator uses the following functions: |  | ||||||
| 
 |  | ||||||
| * :c:func:`VirtualAlloc` and :c:func:`VirtualFree` on Windows, |  | ||||||
| * :c:func:`mmap` and :c:func:`munmap` if available, |  | ||||||
| * :c:func:`malloc` and :c:func:`free` otherwise. |  | ||||||
| 
 |  | ||||||
| Customize pymalloc Arena Allocator |  | ||||||
| ---------------------------------- |  | ||||||
| 
 |  | ||||||
| .. versionadded:: 3.4 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyObjectArenaAllocator |  | ||||||
| 
 |  | ||||||
|    Structure used to describe an arena allocator. The structure has |  | ||||||
|    three fields: |  | ||||||
| 
 |  | ||||||
|    +--------------------------------------------------+---------------------------------------+ |  | ||||||
|    | Field                                            | Meaning                               | |  | ||||||
|    +==================================================+=======================================+ |  | ||||||
|    | ``void *ctx``                                    | user context passed as first argument | |  | ||||||
|    +--------------------------------------------------+---------------------------------------+ |  | ||||||
|    | ``void* alloc(void *ctx, size_t size)``          | allocate an arena of size bytes       | |  | ||||||
|    +--------------------------------------------------+---------------------------------------+ |  | ||||||
|    | ``void free(void *ctx, size_t size, void *ptr)`` | free an arena                         | |  | ||||||
|    +--------------------------------------------------+---------------------------------------+ |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject_GetArenaAllocator(PyObjectArenaAllocator *allocator) |  | ||||||
| 
 |  | ||||||
|    Get the arena allocator. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject_SetArenaAllocator(PyObjectArenaAllocator *allocator) |  | ||||||
| 
 |  | ||||||
|    Set the arena allocator. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _memoryexamples: |  | ||||||
| 
 |  | ||||||
| Examples |  | ||||||
| ======== |  | ||||||
| 
 |  | ||||||
| Here is the example from section :ref:`memoryoverview`, rewritten so that the |  | ||||||
| I/O buffer is allocated from the Python heap by using the first function set:: |  | ||||||
| 
 |  | ||||||
|    PyObject *res; |  | ||||||
|    char *buf = (char *) PyMem_Malloc(BUFSIZ); /* for I/O */ |  | ||||||
| 
 |  | ||||||
|    if (buf == NULL) |  | ||||||
|        return PyErr_NoMemory(); |  | ||||||
|    /* ...Do some I/O operation involving buf... */ |  | ||||||
|    res = PyBytes_FromString(buf); |  | ||||||
|    PyMem_Free(buf); /* allocated with PyMem_Malloc */ |  | ||||||
|    return res; |  | ||||||
| 
 |  | ||||||
| The same code using the type-oriented function set:: |  | ||||||
| 
 |  | ||||||
|    PyObject *res; |  | ||||||
|    char *buf = PyMem_New(char, BUFSIZ); /* for I/O */ |  | ||||||
| 
 |  | ||||||
|    if (buf == NULL) |  | ||||||
|        return PyErr_NoMemory(); |  | ||||||
|    /* ...Do some I/O operation involving buf... */ |  | ||||||
|    res = PyBytes_FromString(buf); |  | ||||||
|    PyMem_Del(buf); /* allocated with PyMem_New */ |  | ||||||
|    return res; |  | ||||||
| 
 |  | ||||||
| Note that in the two examples above, the buffer is always manipulated via |  | ||||||
| functions belonging to the same set. Indeed, it is required to use the same |  | ||||||
| memory API family for a given memory block, so that the risk of mixing different |  | ||||||
| allocators is reduced to a minimum. The following code sequence contains two |  | ||||||
| errors, one of which is labeled as *fatal* because it mixes two different |  | ||||||
| allocators operating on different heaps. :: |  | ||||||
| 
 |  | ||||||
|    char *buf1 = PyMem_New(char, BUFSIZ); |  | ||||||
|    char *buf2 = (char *) malloc(BUFSIZ); |  | ||||||
|    char *buf3 = (char *) PyMem_Malloc(BUFSIZ); |  | ||||||
|    ... |  | ||||||
|    PyMem_Del(buf3);  /* Wrong -- should be PyMem_Free() */ |  | ||||||
|    free(buf2);       /* Right -- allocated via malloc() */ |  | ||||||
|    free(buf1);       /* Fatal -- should be PyMem_Del()  */ |  | ||||||
| 
 |  | ||||||
| In addition to the functions aimed at handling raw memory blocks from the Python |  | ||||||
| heap, objects in Python are allocated and released with :c:func:`PyObject_New`, |  | ||||||
| :c:func:`PyObject_NewVar` and :c:func:`PyObject_Del`. |  | ||||||
| 
 |  | ||||||
| These will be explained in the next chapter on defining and implementing new |  | ||||||
| object types in C. |  | ||||||
| 
 |  | ||||||
							
								
								
									
										63
									
								
								third_party/python/Doc/c-api/memoryview.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										63
									
								
								third_party/python/Doc/c-api/memoryview.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,63 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _memoryview-objects: |  | ||||||
| 
 |  | ||||||
| .. index:: |  | ||||||
|    object: memoryview |  | ||||||
| 
 |  | ||||||
| MemoryView objects |  | ||||||
| ------------------ |  | ||||||
| 
 |  | ||||||
| A :class:`memoryview` object exposes the C level :ref:`buffer interface |  | ||||||
| <bufferobjects>` as a Python object which can then be passed around like |  | ||||||
| any other object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject *PyMemoryView_FromObject(PyObject *obj) |  | ||||||
| 
 |  | ||||||
|    Create a memoryview object from an object that provides the buffer interface. |  | ||||||
|    If *obj* supports writable buffer exports, the memoryview object will be |  | ||||||
|    read/write, otherwise it may be either read-only or read/write at the |  | ||||||
|    discretion of the exporter. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject *PyMemoryView_FromMemory(char *mem, Py_ssize_t size, int flags) |  | ||||||
| 
 |  | ||||||
|    Create a memoryview object using *mem* as the underlying buffer. |  | ||||||
|    *flags* can be one of :c:macro:`PyBUF_READ` or :c:macro:`PyBUF_WRITE`. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject *PyMemoryView_FromBuffer(Py_buffer *view) |  | ||||||
| 
 |  | ||||||
|    Create a memoryview object wrapping the given buffer structure *view*. |  | ||||||
|    For simple byte buffers, :c:func:`PyMemoryView_FromMemory` is the preferred |  | ||||||
|    function. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject *PyMemoryView_GetContiguous(PyObject *obj, int buffertype, char order) |  | ||||||
| 
 |  | ||||||
|    Create a memoryview object to a :term:`contiguous` chunk of memory (in either |  | ||||||
|    'C' or 'F'ortran *order*) from an object that defines the buffer |  | ||||||
|    interface. If memory is contiguous, the memoryview object points to the |  | ||||||
|    original memory. Otherwise, a copy is made and the memoryview points to a |  | ||||||
|    new bytes object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyMemoryView_Check(PyObject *obj) |  | ||||||
| 
 |  | ||||||
|    Return true if the object *obj* is a memoryview object.  It is not |  | ||||||
|    currently allowed to create subclasses of :class:`memoryview`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_buffer *PyMemoryView_GET_BUFFER(PyObject *mview) |  | ||||||
| 
 |  | ||||||
|    Return a pointer to the memoryview's private copy of the exporter's buffer. |  | ||||||
|    *mview* **must** be a memoryview instance; this macro doesn't check its type, |  | ||||||
|    you must do it yourself or you will risk crashes. |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_buffer *PyMemoryView_GET_BASE(PyObject *mview) |  | ||||||
| 
 |  | ||||||
|    Return either a pointer to the exporting object that the memoryview is based |  | ||||||
|    on or *NULL* if the memoryview has been created by one of the functions |  | ||||||
|    :c:func:`PyMemoryView_FromMemory` or :c:func:`PyMemoryView_FromBuffer`. |  | ||||||
|    *mview* **must** be a memoryview instance. |  | ||||||
| 
 |  | ||||||
							
								
								
									
										100
									
								
								third_party/python/Doc/c-api/method.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										100
									
								
								third_party/python/Doc/c-api/method.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,100 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _instancemethod-objects: |  | ||||||
| 
 |  | ||||||
| Instance Method Objects |  | ||||||
| ----------------------- |  | ||||||
| 
 |  | ||||||
| .. index:: object: instancemethod |  | ||||||
| 
 |  | ||||||
| An instance method is a wrapper for a :c:data:`PyCFunction` and the new way |  | ||||||
| to bind a :c:data:`PyCFunction` to a class object. It replaces the former call |  | ||||||
| ``PyMethod_New(func, NULL, class)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyInstanceMethod_Type |  | ||||||
| 
 |  | ||||||
|    This instance of :c:type:`PyTypeObject` represents the Python instance |  | ||||||
|    method type. It is not exposed to Python programs. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyInstanceMethod_Check(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return true if *o* is an instance method object (has type |  | ||||||
|    :c:data:`PyInstanceMethod_Type`).  The parameter must not be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyInstanceMethod_New(PyObject *func) |  | ||||||
| 
 |  | ||||||
|    Return a new instance method object, with *func* being any callable object |  | ||||||
|    *func* is the function that will be called when the instance method is |  | ||||||
|    called. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyInstanceMethod_Function(PyObject *im) |  | ||||||
| 
 |  | ||||||
|    Return the function object associated with the instance method *im*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyInstanceMethod_GET_FUNCTION(PyObject *im) |  | ||||||
| 
 |  | ||||||
|    Macro version of :c:func:`PyInstanceMethod_Function` which avoids error checking. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _method-objects: |  | ||||||
| 
 |  | ||||||
| Method Objects |  | ||||||
| -------------- |  | ||||||
| 
 |  | ||||||
| .. index:: object: method |  | ||||||
| 
 |  | ||||||
| Methods are bound function objects. Methods are always bound to an instance of |  | ||||||
| a user-defined class. Unbound methods (methods bound to a class object) are |  | ||||||
| no longer available. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyMethod_Type |  | ||||||
| 
 |  | ||||||
|    .. index:: single: MethodType (in module types) |  | ||||||
| 
 |  | ||||||
|    This instance of :c:type:`PyTypeObject` represents the Python method type.  This |  | ||||||
|    is exposed to Python programs as ``types.MethodType``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyMethod_Check(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return true if *o* is a method object (has type :c:data:`PyMethod_Type`).  The |  | ||||||
|    parameter must not be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyMethod_New(PyObject *func, PyObject *self) |  | ||||||
| 
 |  | ||||||
|    Return a new method object, with *func* being any callable object and *self* |  | ||||||
|    the instance the method should be bound. *func* is the function that will |  | ||||||
|    be called when the method is called. *self* must not be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyMethod_Function(PyObject *meth) |  | ||||||
| 
 |  | ||||||
|    Return the function object associated with the method *meth*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyMethod_GET_FUNCTION(PyObject *meth) |  | ||||||
| 
 |  | ||||||
|    Macro version of :c:func:`PyMethod_Function` which avoids error checking. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyMethod_Self(PyObject *meth) |  | ||||||
| 
 |  | ||||||
|    Return the instance associated with the method *meth*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyMethod_GET_SELF(PyObject *meth) |  | ||||||
| 
 |  | ||||||
|    Macro version of :c:func:`PyMethod_Self` which avoids error checking. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyMethod_ClearFreeList() |  | ||||||
| 
 |  | ||||||
|    Clear the free list. Return the total number of freed items. |  | ||||||
| 
 |  | ||||||
							
								
								
									
										479
									
								
								third_party/python/Doc/c-api/module.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										479
									
								
								third_party/python/Doc/c-api/module.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,479 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _moduleobjects: |  | ||||||
| 
 |  | ||||||
| Module Objects |  | ||||||
| -------------- |  | ||||||
| 
 |  | ||||||
| .. index:: object: module |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyModule_Type |  | ||||||
| 
 |  | ||||||
|    .. index:: single: ModuleType (in module types) |  | ||||||
| 
 |  | ||||||
|    This instance of :c:type:`PyTypeObject` represents the Python module type.  This |  | ||||||
|    is exposed to Python programs as ``types.ModuleType``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyModule_Check(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if *p* is a module object, or a subtype of a module object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyModule_CheckExact(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if *p* is a module object, but not a subtype of |  | ||||||
|    :c:data:`PyModule_Type`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyModule_NewObject(PyObject *name) |  | ||||||
| 
 |  | ||||||
|    .. index:: |  | ||||||
|       single: __name__ (module attribute) |  | ||||||
|       single: __doc__ (module attribute) |  | ||||||
|       single: __file__ (module attribute) |  | ||||||
|       single: __package__ (module attribute) |  | ||||||
|       single: __loader__ (module attribute) |  | ||||||
| 
 |  | ||||||
|    Return a new module object with the :attr:`__name__` attribute set to *name*. |  | ||||||
|    The module's :attr:`__name__`, :attr:`__doc__`, :attr:`__package__`, and |  | ||||||
|    :attr:`__loader__` attributes are filled in (all but :attr:`__name__` are set |  | ||||||
|    to ``None``); the caller is responsible for providing a :attr:`__file__` |  | ||||||
|    attribute. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.4 |  | ||||||
|       :attr:`__package__` and :attr:`__loader__` are set to ``None``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyModule_New(const char *name) |  | ||||||
| 
 |  | ||||||
|    Similar to :c:func:`PyModule_NewObject`, but the name is a UTF-8 encoded |  | ||||||
|    string instead of a Unicode object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyModule_GetDict(PyObject *module) |  | ||||||
| 
 |  | ||||||
|    .. index:: single: __dict__ (module attribute) |  | ||||||
| 
 |  | ||||||
|    Return the dictionary object that implements *module*'s namespace; this object |  | ||||||
|    is the same as the :attr:`~object.__dict__` attribute of the module object. |  | ||||||
|    If *module* is not a module object (or a subtype of a module object), |  | ||||||
|    :exc:`SystemError` is raised and *NULL* is returned. |  | ||||||
| 
 |  | ||||||
|    It is recommended extensions use other :c:func:`PyModule_\*` and |  | ||||||
|    :c:func:`PyObject_\*` functions rather than directly manipulate a module's |  | ||||||
|    :attr:`~object.__dict__`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyModule_GetNameObject(PyObject *module) |  | ||||||
| 
 |  | ||||||
|    .. index:: |  | ||||||
|       single: __name__ (module attribute) |  | ||||||
|       single: SystemError (built-in exception) |  | ||||||
| 
 |  | ||||||
|    Return *module*'s :attr:`__name__` value.  If the module does not provide one, |  | ||||||
|    or if it is not a string, :exc:`SystemError` is raised and *NULL* is returned. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: char* PyModule_GetName(PyObject *module) |  | ||||||
| 
 |  | ||||||
|    Similar to :c:func:`PyModule_GetNameObject` but return the name encoded to |  | ||||||
|    ``'utf-8'``. |  | ||||||
| 
 |  | ||||||
| .. c:function:: void* PyModule_GetState(PyObject *module) |  | ||||||
| 
 |  | ||||||
|    Return the "state" of the module, that is, a pointer to the block of memory |  | ||||||
|    allocated at module creation time, or *NULL*.  See |  | ||||||
|    :c:member:`PyModuleDef.m_size`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyModuleDef* PyModule_GetDef(PyObject *module) |  | ||||||
| 
 |  | ||||||
|    Return a pointer to the :c:type:`PyModuleDef` struct from which the module was |  | ||||||
|    created, or *NULL* if the module wasn't created from a definition. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyModule_GetFilenameObject(PyObject *module) |  | ||||||
| 
 |  | ||||||
|    .. index:: |  | ||||||
|       single: __file__ (module attribute) |  | ||||||
|       single: SystemError (built-in exception) |  | ||||||
| 
 |  | ||||||
|    Return the name of the file from which *module* was loaded using *module*'s |  | ||||||
|    :attr:`__file__` attribute.  If this is not defined, or if it is not a |  | ||||||
|    unicode string, raise :exc:`SystemError` and return *NULL*; otherwise return |  | ||||||
|    a reference to a Unicode object. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.2 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: char* PyModule_GetFilename(PyObject *module) |  | ||||||
| 
 |  | ||||||
|    Similar to :c:func:`PyModule_GetFilenameObject` but return the filename |  | ||||||
|    encoded to 'utf-8'. |  | ||||||
| 
 |  | ||||||
|    .. deprecated:: 3.2 |  | ||||||
|       :c:func:`PyModule_GetFilename` raises :c:type:`UnicodeEncodeError` on |  | ||||||
|       unencodable filenames, use :c:func:`PyModule_GetFilenameObject` instead. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _initializing-modules: |  | ||||||
| 
 |  | ||||||
| Initializing C modules |  | ||||||
| ^^^^^^^^^^^^^^^^^^^^^^ |  | ||||||
| 
 |  | ||||||
| Modules objects are usually created from extension modules (shared libraries |  | ||||||
| which export an initialization function), or compiled-in modules |  | ||||||
| (where the initialization function is added using :c:func:`PyImport_AppendInittab`). |  | ||||||
| See :ref:`building` or :ref:`extending-with-embedding` for details. |  | ||||||
| 
 |  | ||||||
| The initialization function can either pass a module definition instance |  | ||||||
| to :c:func:`PyModule_Create`, and return the resulting module object, |  | ||||||
| or request "multi-phase initialization" by returning the definition struct itself. |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyModuleDef |  | ||||||
| 
 |  | ||||||
|    The module definition struct, which holds all information needed to create |  | ||||||
|    a module object. There is usually only one statically initialized variable |  | ||||||
|    of this type for each module. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: PyModuleDef_Base m_base |  | ||||||
| 
 |  | ||||||
|       Always initialize this member to :const:`PyModuleDef_HEAD_INIT`. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: char* m_name |  | ||||||
| 
 |  | ||||||
|       Name for the new module. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: char* m_doc |  | ||||||
| 
 |  | ||||||
|       Docstring for the module; usually a docstring variable created with |  | ||||||
|       :c:func:`PyDoc_STRVAR` is used. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: Py_ssize_t m_size |  | ||||||
| 
 |  | ||||||
|       Module state may be kept in a per-module memory area that can be |  | ||||||
|       retrieved with :c:func:`PyModule_GetState`, rather than in static globals. |  | ||||||
|       This makes modules safe for use in multiple sub-interpreters. |  | ||||||
| 
 |  | ||||||
|       This memory area is allocated based on *m_size* on module creation, |  | ||||||
|       and freed when the module object is deallocated, after the |  | ||||||
|       :c:member:`m_free` function has been called, if present. |  | ||||||
| 
 |  | ||||||
|       Setting ``m_size`` to ``-1`` means that the module does not support |  | ||||||
|       sub-interpreters, because it has global state. |  | ||||||
| 
 |  | ||||||
|       Setting it to a non-negative value means that the module can be |  | ||||||
|       re-initialized and specifies the additional amount of memory it requires |  | ||||||
|       for its state. Non-negative ``m_size`` is required for multi-phase |  | ||||||
|       initialization. |  | ||||||
| 
 |  | ||||||
|       See :PEP:`3121` for more details. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: PyMethodDef* m_methods |  | ||||||
| 
 |  | ||||||
|       A pointer to a table of module-level functions, described by |  | ||||||
|       :c:type:`PyMethodDef` values.  Can be *NULL* if no functions are present. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: PyModuleDef_Slot* m_slots |  | ||||||
| 
 |  | ||||||
|       An array of slot definitions for multi-phase initialization, terminated by |  | ||||||
|       a ``{0, NULL}`` entry. |  | ||||||
|       When using single-phase initialization, *m_slots* must be *NULL*. |  | ||||||
| 
 |  | ||||||
|       .. versionchanged:: 3.5 |  | ||||||
| 
 |  | ||||||
|          Prior to version 3.5, this member was always set to *NULL*, |  | ||||||
|          and was defined as: |  | ||||||
| 
 |  | ||||||
|            .. c:member:: inquiry m_reload |  | ||||||
| 
 |  | ||||||
|    .. c:member:: traverseproc m_traverse |  | ||||||
| 
 |  | ||||||
|       A traversal function to call during GC traversal of the module object, or |  | ||||||
|       *NULL* if not needed. This function may be called before module state |  | ||||||
|       is allocated (:c:func:`PyModule_GetState()` may return `NULL`), |  | ||||||
|       and before the :c:member:`Py_mod_exec` function is executed. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: inquiry m_clear |  | ||||||
| 
 |  | ||||||
|       A clear function to call during GC clearing of the module object, or |  | ||||||
|       *NULL* if not needed. This function may be called before module state |  | ||||||
|       is allocated (:c:func:`PyModule_GetState()` may return `NULL`), |  | ||||||
|       and before the :c:member:`Py_mod_exec` function is executed. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: freefunc m_free |  | ||||||
| 
 |  | ||||||
|       A function to call during deallocation of the module object, or *NULL* if |  | ||||||
|       not needed. This function may be called before module state |  | ||||||
|       is allocated (:c:func:`PyModule_GetState()` may return `NULL`), |  | ||||||
|       and before the :c:member:`Py_mod_exec` function is executed. |  | ||||||
| 
 |  | ||||||
| Single-phase initialization |  | ||||||
| ........................... |  | ||||||
| 
 |  | ||||||
| The module initialization function may create and return the module object |  | ||||||
| directly. This is referred to as "single-phase initialization", and uses one |  | ||||||
| of the following two module creation functions: |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyModule_Create(PyModuleDef *def) |  | ||||||
| 
 |  | ||||||
|    Create a new module object, given the definition in *def*.  This behaves |  | ||||||
|    like :c:func:`PyModule_Create2` with *module_api_version* set to |  | ||||||
|    :const:`PYTHON_API_VERSION`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyModule_Create2(PyModuleDef *def, int module_api_version) |  | ||||||
| 
 |  | ||||||
|    Create a new module object, given the definition in *def*, assuming the |  | ||||||
|    API version *module_api_version*.  If that version does not match the version |  | ||||||
|    of the running interpreter, a :exc:`RuntimeWarning` is emitted. |  | ||||||
| 
 |  | ||||||
|    .. note:: |  | ||||||
| 
 |  | ||||||
|       Most uses of this function should be using :c:func:`PyModule_Create` |  | ||||||
|       instead; only use this if you are sure you need it. |  | ||||||
| 
 |  | ||||||
| Before it is returned from in the initialization function, the resulting module |  | ||||||
| object is typically populated using functions like :c:func:`PyModule_AddObject`. |  | ||||||
| 
 |  | ||||||
| .. _multi-phase-initialization: |  | ||||||
| 
 |  | ||||||
| Multi-phase initialization |  | ||||||
| .......................... |  | ||||||
| 
 |  | ||||||
| An alternate way to specify extensions is to request "multi-phase initialization". |  | ||||||
| Extension modules created this way behave more like Python modules: the |  | ||||||
| initialization is split between the *creation phase*, when the module object |  | ||||||
| is created, and the *execution phase*, when it is populated. |  | ||||||
| The distinction is similar to the :py:meth:`__new__` and :py:meth:`__init__` methods |  | ||||||
| of classes. |  | ||||||
| 
 |  | ||||||
| Unlike modules created using single-phase initialization, these modules are not |  | ||||||
| singletons: if the *sys.modules* entry is removed and the module is re-imported, |  | ||||||
| a new module object is created, and the old module is subject to normal garbage |  | ||||||
| collection -- as with Python modules. |  | ||||||
| By default, multiple modules created from the same definition should be |  | ||||||
| independent: changes to one should not affect the others. |  | ||||||
| This means that all state should be specific to the module object (using e.g. |  | ||||||
| using :c:func:`PyModule_GetState`), or its contents (such as the module's |  | ||||||
| :attr:`__dict__` or individual classes created with :c:func:`PyType_FromSpec`). |  | ||||||
| 
 |  | ||||||
| All modules created using multi-phase initialization are expected to support |  | ||||||
| :ref:`sub-interpreters <sub-interpreter-support>`. Making sure multiple modules |  | ||||||
| are independent is typically enough to achieve this. |  | ||||||
| 
 |  | ||||||
| To request multi-phase initialization, the initialization function |  | ||||||
| (PyInit_modulename) returns a :c:type:`PyModuleDef` instance with non-empty |  | ||||||
| :c:member:`~PyModuleDef.m_slots`. Before it is returned, the ``PyModuleDef`` |  | ||||||
| instance must be initialized with the following function: |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyModuleDef_Init(PyModuleDef *def) |  | ||||||
| 
 |  | ||||||
|    Ensures a module definition is a properly initialized Python object that |  | ||||||
|    correctly reports its type and reference count. |  | ||||||
| 
 |  | ||||||
|    Returns *def* cast to ``PyObject*``, or *NULL* if an error occurred. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.5 |  | ||||||
| 
 |  | ||||||
| The *m_slots* member of the module definition must point to an array of |  | ||||||
| ``PyModuleDef_Slot`` structures: |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyModuleDef_Slot |  | ||||||
| 
 |  | ||||||
|    .. c:member:: int slot |  | ||||||
| 
 |  | ||||||
|       A slot ID, chosen from the available values explained below. |  | ||||||
| 
 |  | ||||||
|    .. c:member:: void* value |  | ||||||
| 
 |  | ||||||
|       Value of the slot, whose meaning depends on the slot ID. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.5 |  | ||||||
| 
 |  | ||||||
| The *m_slots* array must be terminated by a slot with id 0. |  | ||||||
| 
 |  | ||||||
| The available slot types are: |  | ||||||
| 
 |  | ||||||
| .. c:var:: Py_mod_create |  | ||||||
| 
 |  | ||||||
|    Specifies a function that is called to create the module object itself. |  | ||||||
|    The *value* pointer of this slot must point to a function of the signature: |  | ||||||
| 
 |  | ||||||
|    .. c:function:: PyObject* create_module(PyObject *spec, PyModuleDef *def) |  | ||||||
| 
 |  | ||||||
|    The function receives a :py:class:`~importlib.machinery.ModuleSpec` |  | ||||||
|    instance, as defined in :PEP:`451`, and the module definition. |  | ||||||
|    It should return a new module object, or set an error |  | ||||||
|    and return *NULL*. |  | ||||||
| 
 |  | ||||||
|    This function should be kept minimal. In particular, it should not |  | ||||||
|    call arbitrary Python code, as trying to import the same module again may |  | ||||||
|    result in an infinite loop. |  | ||||||
| 
 |  | ||||||
|    Multiple ``Py_mod_create`` slots may not be specified in one module |  | ||||||
|    definition. |  | ||||||
| 
 |  | ||||||
|    If ``Py_mod_create`` is not specified, the import machinery will create |  | ||||||
|    a normal module object using :c:func:`PyModule_New`. The name is taken from |  | ||||||
|    *spec*, not the definition, to allow extension modules to dynamically adjust |  | ||||||
|    to their place in the module hierarchy and be imported under different |  | ||||||
|    names through symlinks, all while sharing a single module definition. |  | ||||||
| 
 |  | ||||||
|    There is no requirement for the returned object to be an instance of |  | ||||||
|    :c:type:`PyModule_Type`. Any type can be used, as long as it supports |  | ||||||
|    setting and getting import-related attributes. |  | ||||||
|    However, only ``PyModule_Type`` instances may be returned if the |  | ||||||
|    ``PyModuleDef`` has non-*NULL* ``m_traverse``, ``m_clear``, |  | ||||||
|    ``m_free``; non-zero ``m_size``; or slots other than ``Py_mod_create``. |  | ||||||
| 
 |  | ||||||
| .. c:var:: Py_mod_exec |  | ||||||
| 
 |  | ||||||
|    Specifies a function that is called to *execute* the module. |  | ||||||
|    This is equivalent to executing the code of a Python module: typically, |  | ||||||
|    this function adds classes and constants to the module. |  | ||||||
|    The signature of the function is: |  | ||||||
| 
 |  | ||||||
|    .. c:function:: int exec_module(PyObject* module) |  | ||||||
| 
 |  | ||||||
|    If multiple ``Py_mod_exec`` slots are specified, they are processed in the |  | ||||||
|    order they appear in the *m_slots* array. |  | ||||||
| 
 |  | ||||||
| See :PEP:`489` for more details on multi-phase initialization. |  | ||||||
| 
 |  | ||||||
| Low-level module creation functions |  | ||||||
| ................................... |  | ||||||
| 
 |  | ||||||
| The following functions are called under the hood when using multi-phase |  | ||||||
| initialization. They can be used directly, for example when creating module |  | ||||||
| objects dynamically. Note that both ``PyModule_FromDefAndSpec`` and |  | ||||||
| ``PyModule_ExecDef`` must be called to fully initialize a module. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject * PyModule_FromDefAndSpec(PyModuleDef *def, PyObject *spec) |  | ||||||
| 
 |  | ||||||
|    Create a new module object, given the definition in *module* and the |  | ||||||
|    ModuleSpec *spec*.  This behaves like :c:func:`PyModule_FromDefAndSpec2` |  | ||||||
|    with *module_api_version* set to :const:`PYTHON_API_VERSION`. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.5 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject * PyModule_FromDefAndSpec2(PyModuleDef *def, PyObject *spec, int module_api_version) |  | ||||||
| 
 |  | ||||||
|    Create a new module object, given the definition in *module* and the |  | ||||||
|    ModuleSpec *spec*, assuming the API version *module_api_version*. |  | ||||||
|    If that version does not match the version of the running interpreter, |  | ||||||
|    a :exc:`RuntimeWarning` is emitted. |  | ||||||
| 
 |  | ||||||
|    .. note:: |  | ||||||
| 
 |  | ||||||
|       Most uses of this function should be using :c:func:`PyModule_FromDefAndSpec` |  | ||||||
|       instead; only use this if you are sure you need it. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.5 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyModule_ExecDef(PyObject *module, PyModuleDef *def) |  | ||||||
| 
 |  | ||||||
|    Process any execution slots (:c:data:`Py_mod_exec`) given in *def*. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.5 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyModule_SetDocString(PyObject *module, const char *docstring) |  | ||||||
| 
 |  | ||||||
|    Set the docstring for *module* to *docstring*. |  | ||||||
|    This function is called automatically when creating a module from |  | ||||||
|    ``PyModuleDef``, using either ``PyModule_Create`` or |  | ||||||
|    ``PyModule_FromDefAndSpec``. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.5 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyModule_AddFunctions(PyObject *module, PyMethodDef *functions) |  | ||||||
| 
 |  | ||||||
|    Add the functions from the *NULL* terminated *functions* array to *module*. |  | ||||||
|    Refer to the :c:type:`PyMethodDef` documentation for details on individual |  | ||||||
|    entries (due to the lack of a shared module namespace, module level |  | ||||||
|    "functions" implemented in C typically receive the module as their first |  | ||||||
|    parameter, making them similar to instance methods on Python classes). |  | ||||||
|    This function is called automatically when creating a module from |  | ||||||
|    ``PyModuleDef``, using either ``PyModule_Create`` or |  | ||||||
|    ``PyModule_FromDefAndSpec``. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.5 |  | ||||||
| 
 |  | ||||||
| Support functions |  | ||||||
| ................. |  | ||||||
| 
 |  | ||||||
| The module initialization function (if using single phase initialization) or |  | ||||||
| a function called from a module execution slot (if using multi-phase |  | ||||||
| initialization), can use the following functions to help initialize the module |  | ||||||
| state: |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyModule_AddObject(PyObject *module, const char *name, PyObject *value) |  | ||||||
| 
 |  | ||||||
|    Add an object to *module* as *name*.  This is a convenience function which can |  | ||||||
|    be used from the module's initialization function.  This steals a reference to |  | ||||||
|    *value*.  Return ``-1`` on error, ``0`` on success. |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyModule_AddIntConstant(PyObject *module, const char *name, long value) |  | ||||||
| 
 |  | ||||||
|    Add an integer constant to *module* as *name*.  This convenience function can be |  | ||||||
|    used from the module's initialization function. Return ``-1`` on error, ``0`` on |  | ||||||
|    success. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyModule_AddStringConstant(PyObject *module, const char *name, const char *value) |  | ||||||
| 
 |  | ||||||
|    Add a string constant to *module* as *name*.  This convenience function can be |  | ||||||
|    used from the module's initialization function.  The string *value* must be |  | ||||||
|    *NULL*-terminated.  Return ``-1`` on error, ``0`` on success. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyModule_AddIntMacro(PyObject *module, macro) |  | ||||||
| 
 |  | ||||||
|    Add an int constant to *module*. The name and the value are taken from |  | ||||||
|    *macro*. For example ``PyModule_AddIntMacro(module, AF_INET)`` adds the int |  | ||||||
|    constant *AF_INET* with the value of *AF_INET* to *module*. |  | ||||||
|    Return ``-1`` on error, ``0`` on success. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyModule_AddStringMacro(PyObject *module, macro) |  | ||||||
| 
 |  | ||||||
|    Add a string constant to *module*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Module lookup |  | ||||||
| ^^^^^^^^^^^^^ |  | ||||||
| 
 |  | ||||||
| Single-phase initialization creates singleton modules that can be looked up |  | ||||||
| in the context of the current interpreter. This allows the module object to be |  | ||||||
| retrieved later with only a reference to the module definition. |  | ||||||
| 
 |  | ||||||
| These functions will not work on modules created using multi-phase initialization, |  | ||||||
| since multiple such modules can be created from a single definition. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyState_FindModule(PyModuleDef *def) |  | ||||||
| 
 |  | ||||||
|    Returns the module object that was created from *def* for the current interpreter. |  | ||||||
|    This method requires that the module object has been attached to the interpreter state with |  | ||||||
|    :c:func:`PyState_AddModule` beforehand. In case the corresponding module object is not |  | ||||||
|    found or has not been attached to the interpreter state yet, it returns *NULL*. |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyState_AddModule(PyObject *module, PyModuleDef *def) |  | ||||||
| 
 |  | ||||||
|    Attaches the module object passed to the function to the interpreter state. This allows |  | ||||||
|    the module object to be accessible via :c:func:`PyState_FindModule`. |  | ||||||
| 
 |  | ||||||
|    Only effective on modules created using single-phase initialization. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyState_RemoveModule(PyModuleDef *def) |  | ||||||
| 
 |  | ||||||
|    Removes the module object created from *def* from the interpreter state. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
							
								
								
									
										26
									
								
								third_party/python/Doc/c-api/none.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										26
									
								
								third_party/python/Doc/c-api/none.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,26 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _noneobject: |  | ||||||
| 
 |  | ||||||
| The ``None`` Object |  | ||||||
| ------------------- |  | ||||||
| 
 |  | ||||||
| .. index:: object: None |  | ||||||
| 
 |  | ||||||
| Note that the :c:type:`PyTypeObject` for ``None`` is not directly exposed in the |  | ||||||
| Python/C API.  Since ``None`` is a singleton, testing for object identity (using |  | ||||||
| ``==`` in C) is sufficient. There is no :c:func:`PyNone_Check` function for the |  | ||||||
| same reason. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyObject* Py_None |  | ||||||
| 
 |  | ||||||
|    The Python ``None`` object, denoting lack of value.  This object has no methods. |  | ||||||
|    It needs to be treated just like any other object with respect to reference |  | ||||||
|    counts. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:macro:: Py_RETURN_NONE |  | ||||||
| 
 |  | ||||||
|    Properly handle returning :c:data:`Py_None` from within a C function (that is, |  | ||||||
|    increment the reference count of ``None`` and return it.) |  | ||||||
							
								
								
									
										283
									
								
								third_party/python/Doc/c-api/number.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										283
									
								
								third_party/python/Doc/c-api/number.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,283 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _number: |  | ||||||
| 
 |  | ||||||
| Number Protocol |  | ||||||
| =============== |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyNumber_Check(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Returns ``1`` if the object *o* provides numeric protocols, and false otherwise. |  | ||||||
|    This function always succeeds. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_Add(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the result of adding *o1* and *o2*, or *NULL* on failure.  This is the |  | ||||||
|    equivalent of the Python expression ``o1 + o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_Subtract(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the result of subtracting *o2* from *o1*, or *NULL* on failure.  This is |  | ||||||
|    the equivalent of the Python expression ``o1 - o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_Multiply(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the result of multiplying *o1* and *o2*, or *NULL* on failure.  This is |  | ||||||
|    the equivalent of the Python expression ``o1 * o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_MatrixMultiply(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the result of matrix multiplication on *o1* and *o2*, or *NULL* on |  | ||||||
|    failure.  This is the equivalent of the Python expression ``o1 @ o2``. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.5 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_FloorDivide(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Return the floor of *o1* divided by *o2*, or *NULL* on failure.  This is |  | ||||||
|    equivalent to the "classic" division of integers. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_TrueDivide(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Return a reasonable approximation for the mathematical value of *o1* divided by |  | ||||||
|    *o2*, or *NULL* on failure.  The return value is "approximate" because binary |  | ||||||
|    floating point numbers are approximate; it is not possible to represent all real |  | ||||||
|    numbers in base two.  This function can return a floating point value when |  | ||||||
|    passed two integers. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_Remainder(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the remainder of dividing *o1* by *o2*, or *NULL* on failure.  This is |  | ||||||
|    the equivalent of the Python expression ``o1 % o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_Divmod(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: divmod |  | ||||||
| 
 |  | ||||||
|    See the built-in function :func:`divmod`. Returns *NULL* on failure.  This is |  | ||||||
|    the equivalent of the Python expression ``divmod(o1, o2)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_Power(PyObject *o1, PyObject *o2, PyObject *o3) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: pow |  | ||||||
| 
 |  | ||||||
|    See the built-in function :func:`pow`. Returns *NULL* on failure.  This is the |  | ||||||
|    equivalent of the Python expression ``pow(o1, o2, o3)``, where *o3* is optional. |  | ||||||
|    If *o3* is to be ignored, pass :c:data:`Py_None` in its place (passing *NULL* for |  | ||||||
|    *o3* would cause an illegal memory access). |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_Negative(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Returns the negation of *o* on success, or *NULL* on failure. This is the |  | ||||||
|    equivalent of the Python expression ``-o``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_Positive(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Returns *o* on success, or *NULL* on failure.  This is the equivalent of the |  | ||||||
|    Python expression ``+o``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_Absolute(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: abs |  | ||||||
| 
 |  | ||||||
|    Returns the absolute value of *o*, or *NULL* on failure.  This is the equivalent |  | ||||||
|    of the Python expression ``abs(o)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_Invert(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Returns the bitwise negation of *o* on success, or *NULL* on failure.  This is |  | ||||||
|    the equivalent of the Python expression ``~o``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_Lshift(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the result of left shifting *o1* by *o2* on success, or *NULL* on |  | ||||||
|    failure.  This is the equivalent of the Python expression ``o1 << o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_Rshift(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the result of right shifting *o1* by *o2* on success, or *NULL* on |  | ||||||
|    failure.  This is the equivalent of the Python expression ``o1 >> o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_And(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the "bitwise and" of *o1* and *o2* on success and *NULL* on failure. |  | ||||||
|    This is the equivalent of the Python expression ``o1 & o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_Xor(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the "bitwise exclusive or" of *o1* by *o2* on success, or *NULL* on |  | ||||||
|    failure.  This is the equivalent of the Python expression ``o1 ^ o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_Or(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the "bitwise or" of *o1* and *o2* on success, or *NULL* on failure. |  | ||||||
|    This is the equivalent of the Python expression ``o1 | o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_InPlaceAdd(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the result of adding *o1* and *o2*, or *NULL* on failure.  The operation |  | ||||||
|    is done *in-place* when *o1* supports it.  This is the equivalent of the Python |  | ||||||
|    statement ``o1 += o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_InPlaceSubtract(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the result of subtracting *o2* from *o1*, or *NULL* on failure.  The |  | ||||||
|    operation is done *in-place* when *o1* supports it.  This is the equivalent of |  | ||||||
|    the Python statement ``o1 -= o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_InPlaceMultiply(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the result of multiplying *o1* and *o2*, or *NULL* on failure.  The |  | ||||||
|    operation is done *in-place* when *o1* supports it.  This is the equivalent of |  | ||||||
|    the Python statement ``o1 *= o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_InPlaceMatrixMultiply(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the result of matrix multiplication on *o1* and *o2*, or *NULL* on |  | ||||||
|    failure.  The operation is done *in-place* when *o1* supports it.  This is |  | ||||||
|    the equivalent of the Python statement ``o1 @= o2``. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.5 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_InPlaceFloorDivide(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the mathematical floor of dividing *o1* by *o2*, or *NULL* on failure. |  | ||||||
|    The operation is done *in-place* when *o1* supports it.  This is the equivalent |  | ||||||
|    of the Python statement ``o1 //= o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_InPlaceTrueDivide(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Return a reasonable approximation for the mathematical value of *o1* divided by |  | ||||||
|    *o2*, or *NULL* on failure.  The return value is "approximate" because binary |  | ||||||
|    floating point numbers are approximate; it is not possible to represent all real |  | ||||||
|    numbers in base two.  This function can return a floating point value when |  | ||||||
|    passed two integers.  The operation is done *in-place* when *o1* supports it. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_InPlaceRemainder(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the remainder of dividing *o1* by *o2*, or *NULL* on failure.  The |  | ||||||
|    operation is done *in-place* when *o1* supports it.  This is the equivalent of |  | ||||||
|    the Python statement ``o1 %= o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_InPlacePower(PyObject *o1, PyObject *o2, PyObject *o3) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: pow |  | ||||||
| 
 |  | ||||||
|    See the built-in function :func:`pow`. Returns *NULL* on failure.  The operation |  | ||||||
|    is done *in-place* when *o1* supports it.  This is the equivalent of the Python |  | ||||||
|    statement ``o1 **= o2`` when o3 is :c:data:`Py_None`, or an in-place variant of |  | ||||||
|    ``pow(o1, o2, o3)`` otherwise. If *o3* is to be ignored, pass :c:data:`Py_None` |  | ||||||
|    in its place (passing *NULL* for *o3* would cause an illegal memory access). |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_InPlaceLshift(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the result of left shifting *o1* by *o2* on success, or *NULL* on |  | ||||||
|    failure.  The operation is done *in-place* when *o1* supports it.  This is the |  | ||||||
|    equivalent of the Python statement ``o1 <<= o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_InPlaceRshift(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the result of right shifting *o1* by *o2* on success, or *NULL* on |  | ||||||
|    failure.  The operation is done *in-place* when *o1* supports it.  This is the |  | ||||||
|    equivalent of the Python statement ``o1 >>= o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_InPlaceAnd(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the "bitwise and" of *o1* and *o2* on success and *NULL* on failure. The |  | ||||||
|    operation is done *in-place* when *o1* supports it.  This is the equivalent of |  | ||||||
|    the Python statement ``o1 &= o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_InPlaceXor(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the "bitwise exclusive or" of *o1* by *o2* on success, or *NULL* on |  | ||||||
|    failure.  The operation is done *in-place* when *o1* supports it.  This is the |  | ||||||
|    equivalent of the Python statement ``o1 ^= o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_InPlaceOr(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Returns the "bitwise or" of *o1* and *o2* on success, or *NULL* on failure.  The |  | ||||||
|    operation is done *in-place* when *o1* supports it.  This is the equivalent of |  | ||||||
|    the Python statement ``o1 |= o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_Long(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: int |  | ||||||
| 
 |  | ||||||
|    Returns the *o* converted to an integer object on success, or *NULL* on |  | ||||||
|    failure.  This is the equivalent of the Python expression ``int(o)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_Float(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: float |  | ||||||
| 
 |  | ||||||
|    Returns the *o* converted to a float object on success, or *NULL* on failure. |  | ||||||
|    This is the equivalent of the Python expression ``float(o)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_Index(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Returns the *o* converted to a Python int on success or *NULL* with a |  | ||||||
|    :exc:`TypeError` exception raised on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyNumber_ToBase(PyObject *n, int base) |  | ||||||
| 
 |  | ||||||
|    Returns the integer *n* converted to base *base* as a string.  The *base* |  | ||||||
|    argument must be one of 2, 8, 10, or 16.  For base 2, 8, or 16, the |  | ||||||
|    returned string is prefixed with a base marker of ``'0b'``, ``'0o'``, or |  | ||||||
|    ``'0x'``, respectively.  If *n* is not a Python int, it is converted with |  | ||||||
|    :c:func:`PyNumber_Index` first. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PyNumber_AsSsize_t(PyObject *o, PyObject *exc) |  | ||||||
| 
 |  | ||||||
|    Returns *o* converted to a Py_ssize_t value if *o* can be interpreted as an |  | ||||||
|    integer.  If the call fails, an exception is raised and ``-1`` is returned. |  | ||||||
| 
 |  | ||||||
|    If *o* can be converted to a Python int but the attempt to |  | ||||||
|    convert to a Py_ssize_t value would raise an :exc:`OverflowError`, then the |  | ||||||
|    *exc* argument is the type of exception that will be raised (usually |  | ||||||
|    :exc:`IndexError` or :exc:`OverflowError`).  If *exc* is *NULL*, then the |  | ||||||
|    exception is cleared and the value is clipped to *PY_SSIZE_T_MIN* for a negative |  | ||||||
|    integer or *PY_SSIZE_T_MAX* for a positive integer. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyIndex_Check(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Returns ``1`` if *o* is an index integer (has the nb_index slot of  the |  | ||||||
|    tp_as_number structure filled in), and ``0`` otherwise. |  | ||||||
|    This function always succeeds. |  | ||||||
							
								
								
									
										55
									
								
								third_party/python/Doc/c-api/objbuffer.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										55
									
								
								third_party/python/Doc/c-api/objbuffer.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,55 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| Old Buffer Protocol |  | ||||||
| ------------------- |  | ||||||
| 
 |  | ||||||
| .. deprecated:: 3.0 |  | ||||||
| 
 |  | ||||||
| These functions were part of the "old buffer protocol" API in Python 2. |  | ||||||
| In Python 3, this protocol doesn't exist anymore but the functions are still |  | ||||||
| exposed to ease porting 2.x code.  They act as a compatibility wrapper |  | ||||||
| around the :ref:`new buffer protocol <bufferobjects>`, but they don't give |  | ||||||
| you control over the lifetime of the resources acquired when a buffer is |  | ||||||
| exported. |  | ||||||
| 
 |  | ||||||
| Therefore, it is recommended that you call :c:func:`PyObject_GetBuffer` |  | ||||||
| (or the ``y*`` or ``w*`` :ref:`format codes <arg-parsing>` with the |  | ||||||
| :c:func:`PyArg_ParseTuple` family of functions) to get a buffer view over |  | ||||||
| an object, and :c:func:`PyBuffer_Release` when the buffer view can be released. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_AsCharBuffer(PyObject *obj, const char **buffer, Py_ssize_t *buffer_len) |  | ||||||
| 
 |  | ||||||
|    Returns a pointer to a read-only memory location usable as character-based |  | ||||||
|    input.  The *obj* argument must support the single-segment character buffer |  | ||||||
|    interface.  On success, returns ``0``, sets *buffer* to the memory location |  | ||||||
|    and *buffer_len* to the buffer length.  Returns ``-1`` and sets a |  | ||||||
|    :exc:`TypeError` on error. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_AsReadBuffer(PyObject *obj, const void **buffer, Py_ssize_t *buffer_len) |  | ||||||
| 
 |  | ||||||
|    Returns a pointer to a read-only memory location containing arbitrary data. |  | ||||||
|    The *obj* argument must support the single-segment readable buffer |  | ||||||
|    interface.  On success, returns ``0``, sets *buffer* to the memory location |  | ||||||
|    and *buffer_len* to the buffer length.  Returns ``-1`` and sets a |  | ||||||
|    :exc:`TypeError` on error. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_CheckReadBuffer(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Returns ``1`` if *o* supports the single-segment readable buffer interface. |  | ||||||
|    Otherwise returns ``0``.  This function always succeeds. |  | ||||||
| 
 |  | ||||||
|    Note that this function tries to get and release a buffer, and exceptions |  | ||||||
|    which occur while calling correspoding functions will get suppressed. |  | ||||||
|    To get error reporting use :c:func:`PyObject_GetBuffer()` instead. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_AsWriteBuffer(PyObject *obj, void **buffer, Py_ssize_t *buffer_len) |  | ||||||
| 
 |  | ||||||
|    Returns a pointer to a writable memory location.  The *obj* argument must |  | ||||||
|    support the single-segment, character buffer interface.  On success, |  | ||||||
|    returns ``0``, sets *buffer* to the memory location and *buffer_len* to the |  | ||||||
|    buffer length.  Returns ``-1`` and sets a :exc:`TypeError` on error. |  | ||||||
| 
 |  | ||||||
							
								
								
									
										425
									
								
								third_party/python/Doc/c-api/object.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										425
									
								
								third_party/python/Doc/c-api/object.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,425 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _object: |  | ||||||
| 
 |  | ||||||
| Object Protocol |  | ||||||
| =============== |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyObject* Py_NotImplemented |  | ||||||
| 
 |  | ||||||
|    The ``NotImplemented`` singleton, used to signal that an operation is |  | ||||||
|    not implemented for the given type combination. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:macro:: Py_RETURN_NOTIMPLEMENTED |  | ||||||
| 
 |  | ||||||
|    Properly handle returning :c:data:`Py_NotImplemented` from within a C |  | ||||||
|    function (that is, increment the reference count of NotImplemented and |  | ||||||
|    return it). |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_Print(PyObject *o, FILE *fp, int flags) |  | ||||||
| 
 |  | ||||||
|    Print an object *o*, on file *fp*.  Returns ``-1`` on error.  The flags argument |  | ||||||
|    is used to enable certain printing options.  The only option currently supported |  | ||||||
|    is :const:`Py_PRINT_RAW`; if given, the :func:`str` of the object is written |  | ||||||
|    instead of the :func:`repr`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_HasAttr(PyObject *o, PyObject *attr_name) |  | ||||||
| 
 |  | ||||||
|    Returns ``1`` if *o* has the attribute *attr_name*, and ``0`` otherwise.  This |  | ||||||
|    is equivalent to the Python expression ``hasattr(o, attr_name)``.  This function |  | ||||||
|    always succeeds. |  | ||||||
| 
 |  | ||||||
|    Note that exceptions which occur while calling :meth:`__getattr__` and |  | ||||||
|    :meth:`__getattribute__` methods will get suppressed. |  | ||||||
|    To get error reporting use :c:func:`PyObject_GetAttr()` instead. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_HasAttrString(PyObject *o, const char *attr_name) |  | ||||||
| 
 |  | ||||||
|    Returns ``1`` if *o* has the attribute *attr_name*, and ``0`` otherwise.  This |  | ||||||
|    is equivalent to the Python expression ``hasattr(o, attr_name)``.  This function |  | ||||||
|    always succeeds. |  | ||||||
| 
 |  | ||||||
|    Note that exceptions which occur while calling :meth:`__getattr__` and |  | ||||||
|    :meth:`__getattribute__` methods and creating a temporary string object |  | ||||||
|    will get suppressed. |  | ||||||
|    To get error reporting use :c:func:`PyObject_GetAttrString()` instead. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_GetAttr(PyObject *o, PyObject *attr_name) |  | ||||||
| 
 |  | ||||||
|    Retrieve an attribute named *attr_name* from object *o*. Returns the attribute |  | ||||||
|    value on success, or *NULL* on failure.  This is the equivalent of the Python |  | ||||||
|    expression ``o.attr_name``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_GetAttrString(PyObject *o, const char *attr_name) |  | ||||||
| 
 |  | ||||||
|    Retrieve an attribute named *attr_name* from object *o*. Returns the attribute |  | ||||||
|    value on success, or *NULL* on failure. This is the equivalent of the Python |  | ||||||
|    expression ``o.attr_name``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_GenericGetAttr(PyObject *o, PyObject *name) |  | ||||||
| 
 |  | ||||||
|    Generic attribute getter function that is meant to be put into a type |  | ||||||
|    object's ``tp_getattro`` slot.  It looks for a descriptor in the dictionary |  | ||||||
|    of classes in the object's MRO as well as an attribute in the object's |  | ||||||
|    :attr:`~object.__dict__` (if present).  As outlined in :ref:`descriptors`, |  | ||||||
|    data descriptors take preference over instance attributes, while non-data |  | ||||||
|    descriptors don't.  Otherwise, an :exc:`AttributeError` is raised. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_SetAttr(PyObject *o, PyObject *attr_name, PyObject *v) |  | ||||||
| 
 |  | ||||||
|    Set the value of the attribute named *attr_name*, for object *o*, to the value |  | ||||||
|    *v*. Raise an exception and return ``-1`` on failure; |  | ||||||
|    return ``0`` on success.  This is the equivalent of the Python statement |  | ||||||
|    ``o.attr_name = v``. |  | ||||||
| 
 |  | ||||||
|    If *v* is *NULL*, the attribute is deleted, however this feature is |  | ||||||
|    deprecated in favour of using :c:func:`PyObject_DelAttr`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_SetAttrString(PyObject *o, const char *attr_name, PyObject *v) |  | ||||||
| 
 |  | ||||||
|    Set the value of the attribute named *attr_name*, for object *o*, to the value |  | ||||||
|    *v*. Raise an exception and return ``-1`` on failure; |  | ||||||
|    return ``0`` on success.  This is the equivalent of the Python statement |  | ||||||
|    ``o.attr_name = v``. |  | ||||||
| 
 |  | ||||||
|    If *v* is *NULL*, the attribute is deleted, however this feature is |  | ||||||
|    deprecated in favour of using :c:func:`PyObject_DelAttrString`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_GenericSetAttr(PyObject *o, PyObject *name, PyObject *value) |  | ||||||
| 
 |  | ||||||
|    Generic attribute setter and deleter function that is meant |  | ||||||
|    to be put into a type object's :c:member:`~PyTypeObject.tp_setattro` |  | ||||||
|    slot.  It looks for a data descriptor in the |  | ||||||
|    dictionary of classes in the object's MRO, and if found it takes preference |  | ||||||
|    over setting or deleting the attribute in the instance dictionary. Otherwise, the |  | ||||||
|    attribute is set or deleted in the object's :attr:`~object.__dict__` (if present). |  | ||||||
|    On success, ``0`` is returned, otherwise an :exc:`AttributeError` |  | ||||||
|    is raised and ``-1`` is returned. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_DelAttr(PyObject *o, PyObject *attr_name) |  | ||||||
| 
 |  | ||||||
|    Delete attribute named *attr_name*, for object *o*. Returns ``-1`` on failure. |  | ||||||
|    This is the equivalent of the Python statement ``del o.attr_name``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_DelAttrString(PyObject *o, const char *attr_name) |  | ||||||
| 
 |  | ||||||
|    Delete attribute named *attr_name*, for object *o*. Returns ``-1`` on failure. |  | ||||||
|    This is the equivalent of the Python statement ``del o.attr_name``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_GenericGetDict(PyObject *o, void *context) |  | ||||||
| 
 |  | ||||||
|    A generic implementation for the getter of a ``__dict__`` descriptor. It |  | ||||||
|    creates the dictionary if necessary. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_GenericSetDict(PyObject *o, void *context) |  | ||||||
| 
 |  | ||||||
|    A generic implementation for the setter of a ``__dict__`` descriptor. This |  | ||||||
|    implementation does not allow the dictionary to be deleted. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_RichCompare(PyObject *o1, PyObject *o2, int opid) |  | ||||||
| 
 |  | ||||||
|    Compare the values of *o1* and *o2* using the operation specified by *opid*, |  | ||||||
|    which must be one of :const:`Py_LT`, :const:`Py_LE`, :const:`Py_EQ`, |  | ||||||
|    :const:`Py_NE`, :const:`Py_GT`, or :const:`Py_GE`, corresponding to ``<``, |  | ||||||
|    ``<=``, ``==``, ``!=``, ``>``, or ``>=`` respectively. This is the equivalent of |  | ||||||
|    the Python expression ``o1 op o2``, where ``op`` is the operator corresponding |  | ||||||
|    to *opid*. Returns the value of the comparison on success, or *NULL* on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_RichCompareBool(PyObject *o1, PyObject *o2, int opid) |  | ||||||
| 
 |  | ||||||
|    Compare the values of *o1* and *o2* using the operation specified by *opid*, |  | ||||||
|    which must be one of :const:`Py_LT`, :const:`Py_LE`, :const:`Py_EQ`, |  | ||||||
|    :const:`Py_NE`, :const:`Py_GT`, or :const:`Py_GE`, corresponding to ``<``, |  | ||||||
|    ``<=``, ``==``, ``!=``, ``>``, or ``>=`` respectively. Returns ``-1`` on error, |  | ||||||
|    ``0`` if the result is false, ``1`` otherwise. This is the equivalent of the |  | ||||||
|    Python expression ``o1 op o2``, where ``op`` is the operator corresponding to |  | ||||||
|    *opid*. |  | ||||||
| 
 |  | ||||||
| .. note:: |  | ||||||
|    If *o1* and *o2* are the same object, :c:func:`PyObject_RichCompareBool` |  | ||||||
|    will always return ``1`` for :const:`Py_EQ` and ``0`` for :const:`Py_NE`. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_Repr(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: repr |  | ||||||
| 
 |  | ||||||
|    Compute a string representation of object *o*.  Returns the string |  | ||||||
|    representation on success, *NULL* on failure.  This is the equivalent of the |  | ||||||
|    Python expression ``repr(o)``.  Called by the :func:`repr` built-in function. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.4 |  | ||||||
|       This function now includes a debug assertion to help ensure that it |  | ||||||
|       does not silently discard an active exception. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_ASCII(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: ascii |  | ||||||
| 
 |  | ||||||
|    As :c:func:`PyObject_Repr`, compute a string representation of object *o*, but |  | ||||||
|    escape the non-ASCII characters in the string returned by |  | ||||||
|    :c:func:`PyObject_Repr` with ``\x``, ``\u`` or ``\U`` escapes.  This generates |  | ||||||
|    a string similar to that returned by :c:func:`PyObject_Repr` in Python 2. |  | ||||||
|    Called by the :func:`ascii` built-in function. |  | ||||||
| 
 |  | ||||||
|    .. index:: string; PyObject_Str (C function) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_Str(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Compute a string representation of object *o*.  Returns the string |  | ||||||
|    representation on success, *NULL* on failure.  This is the equivalent of the |  | ||||||
|    Python expression ``str(o)``.  Called by the :func:`str` built-in function |  | ||||||
|    and, therefore, by the :func:`print` function. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.4 |  | ||||||
|       This function now includes a debug assertion to help ensure that it |  | ||||||
|       does not silently discard an active exception. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_Bytes(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: bytes |  | ||||||
| 
 |  | ||||||
|    Compute a bytes representation of object *o*.  *NULL* is returned on |  | ||||||
|    failure and a bytes object on success.  This is equivalent to the Python |  | ||||||
|    expression ``bytes(o)``, when *o* is not an integer.  Unlike ``bytes(o)``, |  | ||||||
|    a TypeError is raised when *o* is an integer instead of a zero-initialized |  | ||||||
|    bytes object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_IsSubclass(PyObject *derived, PyObject *cls) |  | ||||||
| 
 |  | ||||||
|    Return ``1`` if the class *derived* is identical to or derived from the class |  | ||||||
|    *cls*, otherwise return ``0``.  In case of an error, return ``-1``. |  | ||||||
| 
 |  | ||||||
|    If *cls* is a tuple, the check will be done against every entry in *cls*. |  | ||||||
|    The result will be ``1`` when at least one of the checks returns ``1``, |  | ||||||
|    otherwise it will be ``0``. |  | ||||||
| 
 |  | ||||||
|    If *cls* has a :meth:`~class.__subclasscheck__` method, it will be called to |  | ||||||
|    determine the subclass status as described in :pep:`3119`.  Otherwise, |  | ||||||
|    *derived* is a subclass of *cls* if it is a direct or indirect subclass, |  | ||||||
|    i.e. contained in ``cls.__mro__``. |  | ||||||
| 
 |  | ||||||
|    Normally only class objects, i.e. instances of :class:`type` or a derived |  | ||||||
|    class, are considered classes.  However, objects can override this by having |  | ||||||
|    a :attr:`__bases__` attribute (which must be a tuple of base classes). |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_IsInstance(PyObject *inst, PyObject *cls) |  | ||||||
| 
 |  | ||||||
|    Return ``1`` if *inst* is an instance of the class *cls* or a subclass of |  | ||||||
|    *cls*, or ``0`` if not.  On error, returns ``-1`` and sets an exception. |  | ||||||
| 
 |  | ||||||
|    If *cls* is a tuple, the check will be done against every entry in *cls*. |  | ||||||
|    The result will be ``1`` when at least one of the checks returns ``1``, |  | ||||||
|    otherwise it will be ``0``. |  | ||||||
| 
 |  | ||||||
|    If *cls* has a :meth:`~class.__instancecheck__` method, it will be called to |  | ||||||
|    determine the subclass status as described in :pep:`3119`.  Otherwise, *inst* |  | ||||||
|    is an instance of *cls* if its class is a subclass of *cls*. |  | ||||||
| 
 |  | ||||||
|    An instance *inst* can override what is considered its class by having a |  | ||||||
|    :attr:`__class__` attribute. |  | ||||||
| 
 |  | ||||||
|    An object *cls* can override if it is considered a class, and what its base |  | ||||||
|    classes are, by having a :attr:`__bases__` attribute (which must be a tuple |  | ||||||
|    of base classes). |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyCallable_Check(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Determine if the object *o* is callable.  Return ``1`` if the object is callable |  | ||||||
|    and ``0`` otherwise.  This function always succeeds. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_Call(PyObject *callable_object, PyObject *args, PyObject *kw) |  | ||||||
| 
 |  | ||||||
|    Call a callable Python object *callable_object*, with arguments given by the |  | ||||||
|    tuple *args*, and named arguments given by the dictionary *kw*. If no named |  | ||||||
|    arguments are needed, *kw* may be *NULL*. *args* must not be *NULL*, use an |  | ||||||
|    empty tuple if no arguments are needed. Returns the result of the call on |  | ||||||
|    success, or *NULL* on failure.  This is the equivalent of the Python expression |  | ||||||
|    ``callable_object(*args, **kw)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_CallObject(PyObject *callable_object, PyObject *args) |  | ||||||
| 
 |  | ||||||
|    Call a callable Python object *callable_object*, with arguments given by the |  | ||||||
|    tuple *args*.  If no arguments are needed, then *args* may be *NULL*.  Returns |  | ||||||
|    the result of the call on success, or *NULL* on failure.  This is the equivalent |  | ||||||
|    of the Python expression ``callable_object(*args)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_CallFunction(PyObject *callable, const char *format, ...) |  | ||||||
| 
 |  | ||||||
|    Call a callable Python object *callable*, with a variable number of C arguments. |  | ||||||
|    The C arguments are described using a :c:func:`Py_BuildValue` style format |  | ||||||
|    string.  The format may be *NULL*, indicating that no arguments are provided. |  | ||||||
|    Returns the result of the call on success, or *NULL* on failure.  This is the |  | ||||||
|    equivalent of the Python expression ``callable(*args)``. Note that if you only |  | ||||||
|    pass :c:type:`PyObject \*` args, :c:func:`PyObject_CallFunctionObjArgs` is a |  | ||||||
|    faster alternative. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.4 |  | ||||||
|       The type of *format* was changed from ``char *``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_CallMethod(PyObject *o, const char *method, const char *format, ...) |  | ||||||
| 
 |  | ||||||
|    Call the method named *method* of object *o* with a variable number of C |  | ||||||
|    arguments.  The C arguments are described by a :c:func:`Py_BuildValue` format |  | ||||||
|    string that should  produce a tuple.  The format may be *NULL*, indicating that |  | ||||||
|    no arguments are provided. Returns the result of the call on success, or *NULL* |  | ||||||
|    on failure.  This is the equivalent of the Python expression ``o.method(args)``. |  | ||||||
|    Note that if you only pass :c:type:`PyObject \*` args, |  | ||||||
|    :c:func:`PyObject_CallMethodObjArgs` is a faster alternative. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.4 |  | ||||||
|       The types of *method* and *format* were changed from ``char *``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_CallFunctionObjArgs(PyObject *callable, ..., NULL) |  | ||||||
| 
 |  | ||||||
|    Call a callable Python object *callable*, with a variable number of |  | ||||||
|    :c:type:`PyObject\*` arguments.  The arguments are provided as a variable number |  | ||||||
|    of parameters followed by *NULL*. Returns the result of the call on success, or |  | ||||||
|    *NULL* on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_CallMethodObjArgs(PyObject *o, PyObject *name, ..., NULL) |  | ||||||
| 
 |  | ||||||
|    Calls a method of the object *o*, where the name of the method is given as a |  | ||||||
|    Python string object in *name*.  It is called with a variable number of |  | ||||||
|    :c:type:`PyObject\*` arguments.  The arguments are provided as a variable number |  | ||||||
|    of parameters followed by *NULL*. Returns the result of the call on success, or |  | ||||||
|    *NULL* on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_hash_t PyObject_Hash(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: hash |  | ||||||
| 
 |  | ||||||
|    Compute and return the hash value of an object *o*.  On failure, return ``-1``. |  | ||||||
|    This is the equivalent of the Python expression ``hash(o)``. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.2 |  | ||||||
|       The return type is now Py_hash_t.  This is a signed integer the same size |  | ||||||
|       as Py_ssize_t. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_hash_t PyObject_HashNotImplemented(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Set a :exc:`TypeError` indicating that ``type(o)`` is not hashable and return ``-1``. |  | ||||||
|    This function receives special treatment when stored in a ``tp_hash`` slot, |  | ||||||
|    allowing a type to explicitly indicate to the interpreter that it is not |  | ||||||
|    hashable. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_IsTrue(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Returns ``1`` if the object *o* is considered to be true, and ``0`` otherwise. |  | ||||||
|    This is equivalent to the Python expression ``not not o``.  On failure, return |  | ||||||
|    ``-1``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_Not(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Returns ``0`` if the object *o* is considered to be true, and ``1`` otherwise. |  | ||||||
|    This is equivalent to the Python expression ``not o``.  On failure, return |  | ||||||
|    ``-1``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_Type(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: type |  | ||||||
| 
 |  | ||||||
|    When *o* is non-*NULL*, returns a type object corresponding to the object type |  | ||||||
|    of object *o*. On failure, raises :exc:`SystemError` and returns *NULL*.  This |  | ||||||
|    is equivalent to the Python expression ``type(o)``. This function increments the |  | ||||||
|    reference count of the return value. There's really no reason to use this |  | ||||||
|    function instead of the common expression ``o->ob_type``, which returns a |  | ||||||
|    pointer of type :c:type:`PyTypeObject\*`, except when the incremented reference |  | ||||||
|    count is needed. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_TypeCheck(PyObject *o, PyTypeObject *type) |  | ||||||
| 
 |  | ||||||
|    Return true if the object *o* is of type *type* or a subtype of *type*.  Both |  | ||||||
|    parameters must be non-*NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PyObject_Size(PyObject *o) |  | ||||||
|                Py_ssize_t PyObject_Length(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: len |  | ||||||
| 
 |  | ||||||
|    Return the length of object *o*.  If the object *o* provides either the sequence |  | ||||||
|    and mapping protocols, the sequence length is returned.  On error, ``-1`` is |  | ||||||
|    returned.  This is the equivalent to the Python expression ``len(o)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PyObject_LengthHint(PyObject *o, Py_ssize_t default) |  | ||||||
| 
 |  | ||||||
|    Return an estimated length for the object *o*. First try to return its |  | ||||||
|    actual length, then an estimate using :meth:`~object.__length_hint__`, and |  | ||||||
|    finally return the default value. On error return ``-1``. This is the |  | ||||||
|    equivalent to the Python expression ``operator.length_hint(o, default)``. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.4 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_GetItem(PyObject *o, PyObject *key) |  | ||||||
| 
 |  | ||||||
|    Return element of *o* corresponding to the object *key* or *NULL* on failure. |  | ||||||
|    This is the equivalent of the Python expression ``o[key]``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_SetItem(PyObject *o, PyObject *key, PyObject *v) |  | ||||||
| 
 |  | ||||||
|    Map the object *key* to the value *v*.  Raise an exception and |  | ||||||
|    return ``-1`` on failure; return ``0`` on success.  This is the |  | ||||||
|    equivalent of the Python statement ``o[key] = v``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyObject_DelItem(PyObject *o, PyObject *key) |  | ||||||
| 
 |  | ||||||
|    Remove the mapping for the object *key* from the object *o*.  Return ``-1`` |  | ||||||
|    on failure.  This is equivalent to the Python statement ``del o[key]``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_Dir(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    This is equivalent to the Python expression ``dir(o)``, returning a (possibly |  | ||||||
|    empty) list of strings appropriate for the object argument, or *NULL* if there |  | ||||||
|    was an error.  If the argument is *NULL*, this is like the Python ``dir()``, |  | ||||||
|    returning the names of the current locals; in this case, if no execution frame |  | ||||||
|    is active then *NULL* is returned but :c:func:`PyErr_Occurred` will return false. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyObject_GetIter(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    This is equivalent to the Python expression ``iter(o)``. It returns a new |  | ||||||
|    iterator for the object argument, or the object  itself if the object is already |  | ||||||
|    an iterator.  Raises :exc:`TypeError` and returns *NULL* if the object cannot be |  | ||||||
|    iterated. |  | ||||||
							
								
								
									
										17
									
								
								third_party/python/Doc/c-api/objimpl.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										17
									
								
								third_party/python/Doc/c-api/objimpl.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,17 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _newtypes: |  | ||||||
| 
 |  | ||||||
| ***************************** |  | ||||||
| Object Implementation Support |  | ||||||
| ***************************** |  | ||||||
| 
 |  | ||||||
| This chapter describes the functions, types, and macros used when defining new |  | ||||||
| object types. |  | ||||||
| 
 |  | ||||||
| .. toctree:: |  | ||||||
| 
 |  | ||||||
|    allocation.rst |  | ||||||
|    structures.rst |  | ||||||
|    typeobj.rst |  | ||||||
|    gcsupport.rst |  | ||||||
							
								
								
									
										73
									
								
								third_party/python/Doc/c-api/refcounting.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										73
									
								
								third_party/python/Doc/c-api/refcounting.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,73 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _countingrefs: |  | ||||||
| 
 |  | ||||||
| ****************** |  | ||||||
| Reference Counting |  | ||||||
| ****************** |  | ||||||
| 
 |  | ||||||
| The macros in this section are used for managing reference counts of Python |  | ||||||
| objects. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void Py_INCREF(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Increment the reference count for object *o*.  The object must not be *NULL*; if |  | ||||||
|    you aren't sure that it isn't *NULL*, use :c:func:`Py_XINCREF`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void Py_XINCREF(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Increment the reference count for object *o*.  The object may be *NULL*, in |  | ||||||
|    which case the macro has no effect. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void Py_DECREF(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Decrement the reference count for object *o*.  The object must not be *NULL*; if |  | ||||||
|    you aren't sure that it isn't *NULL*, use :c:func:`Py_XDECREF`.  If the reference |  | ||||||
|    count reaches zero, the object's type's deallocation function (which must not be |  | ||||||
|    *NULL*) is invoked. |  | ||||||
| 
 |  | ||||||
|    .. warning:: |  | ||||||
| 
 |  | ||||||
|       The deallocation function can cause arbitrary Python code to be invoked (e.g. |  | ||||||
|       when a class instance with a :meth:`__del__` method is deallocated).  While |  | ||||||
|       exceptions in such code are not propagated, the executed code has free access to |  | ||||||
|       all Python global variables.  This means that any object that is reachable from |  | ||||||
|       a global variable should be in a consistent state before :c:func:`Py_DECREF` is |  | ||||||
|       invoked.  For example, code to delete an object from a list should copy a |  | ||||||
|       reference to the deleted object in a temporary variable, update the list data |  | ||||||
|       structure, and then call :c:func:`Py_DECREF` for the temporary variable. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void Py_XDECREF(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Decrement the reference count for object *o*.  The object may be *NULL*, in |  | ||||||
|    which case the macro has no effect; otherwise the effect is the same as for |  | ||||||
|    :c:func:`Py_DECREF`, and the same warning applies. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void Py_CLEAR(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Decrement the reference count for object *o*.  The object may be *NULL*, in |  | ||||||
|    which case the macro has no effect; otherwise the effect is the same as for |  | ||||||
|    :c:func:`Py_DECREF`, except that the argument is also set to *NULL*.  The warning |  | ||||||
|    for :c:func:`Py_DECREF` does not apply with respect to the object passed because |  | ||||||
|    the macro carefully uses a temporary variable and sets the argument to *NULL* |  | ||||||
|    before decrementing its reference count. |  | ||||||
| 
 |  | ||||||
|    It is a good idea to use this macro whenever decrementing the value of a |  | ||||||
|    variable that might be traversed during garbage collection. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| The following functions are for runtime dynamic embedding of Python: |  | ||||||
| ``Py_IncRef(PyObject *o)``, ``Py_DecRef(PyObject *o)``. They are |  | ||||||
| simply exported function versions of :c:func:`Py_XINCREF` and |  | ||||||
| :c:func:`Py_XDECREF`, respectively. |  | ||||||
| 
 |  | ||||||
| The following functions or macros are only for use within the interpreter core: |  | ||||||
| :c:func:`_Py_Dealloc`, :c:func:`_Py_ForgetReference`, :c:func:`_Py_NewReference`, |  | ||||||
| as well as the global variable :c:data:`_Py_RefTotal`. |  | ||||||
| 
 |  | ||||||
							
								
								
									
										49
									
								
								third_party/python/Doc/c-api/reflection.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										49
									
								
								third_party/python/Doc/c-api/reflection.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,49 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _reflection: |  | ||||||
| 
 |  | ||||||
| Reflection |  | ||||||
| ========== |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyEval_GetBuiltins() |  | ||||||
| 
 |  | ||||||
|    Return a dictionary of the builtins in the current execution frame, |  | ||||||
|    or the interpreter of the thread state if no frame is currently executing. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyEval_GetLocals() |  | ||||||
| 
 |  | ||||||
|    Return a dictionary of the local variables in the current execution frame, |  | ||||||
|    or *NULL* if no frame is currently executing. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyEval_GetGlobals() |  | ||||||
| 
 |  | ||||||
|    Return a dictionary of the global variables in the current execution frame, |  | ||||||
|    or *NULL* if no frame is currently executing. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyFrameObject* PyEval_GetFrame() |  | ||||||
| 
 |  | ||||||
|    Return the current thread state's frame, which is *NULL* if no frame is |  | ||||||
|    currently executing. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyFrame_GetLineNumber(PyFrameObject *frame) |  | ||||||
| 
 |  | ||||||
|    Return the line number that *frame* is currently executing. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: const char* PyEval_GetFuncName(PyObject *func) |  | ||||||
| 
 |  | ||||||
|    Return the name of *func* if it is a function, class or instance object, else the |  | ||||||
|    name of *func*\s type. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: const char* PyEval_GetFuncDesc(PyObject *func) |  | ||||||
| 
 |  | ||||||
|    Return a description string, depending on the type of *func*. |  | ||||||
|    Return values include "()" for functions and methods, " constructor", |  | ||||||
|    " instance", and " object".  Concatenated with the result of |  | ||||||
|    :c:func:`PyEval_GetFuncName`, the result will be a description of |  | ||||||
|    *func*. |  | ||||||
							
								
								
									
										169
									
								
								third_party/python/Doc/c-api/sequence.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										169
									
								
								third_party/python/Doc/c-api/sequence.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,169 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _sequence: |  | ||||||
| 
 |  | ||||||
| Sequence Protocol |  | ||||||
| ================= |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PySequence_Check(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return ``1`` if the object provides sequence protocol, and ``0`` otherwise. |  | ||||||
|    Note that it returns ``1`` for Python classes with a :meth:`__getitem__` |  | ||||||
|    method unless they are :class:`dict` subclasses since in general case it |  | ||||||
|    is impossible to determine what the type of keys it supports.  This |  | ||||||
|    function always succeeds. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PySequence_Size(PyObject *o) |  | ||||||
|                Py_ssize_t PySequence_Length(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: len |  | ||||||
| 
 |  | ||||||
|    Returns the number of objects in sequence *o* on success, and ``-1`` on |  | ||||||
|    failure.  This is equivalent to the Python expression ``len(o)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PySequence_Concat(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Return the concatenation of *o1* and *o2* on success, and *NULL* on failure. |  | ||||||
|    This is the equivalent of the Python expression ``o1 + o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PySequence_Repeat(PyObject *o, Py_ssize_t count) |  | ||||||
| 
 |  | ||||||
|    Return the result of repeating sequence object *o* *count* times, or *NULL* on |  | ||||||
|    failure.  This is the equivalent of the Python expression ``o * count``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PySequence_InPlaceConcat(PyObject *o1, PyObject *o2) |  | ||||||
| 
 |  | ||||||
|    Return the concatenation of *o1* and *o2* on success, and *NULL* on failure. |  | ||||||
|    The operation is done *in-place* when *o1* supports it.  This is the equivalent |  | ||||||
|    of the Python expression ``o1 += o2``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PySequence_InPlaceRepeat(PyObject *o, Py_ssize_t count) |  | ||||||
| 
 |  | ||||||
|    Return the result of repeating sequence object *o* *count* times, or *NULL* on |  | ||||||
|    failure.  The operation is done *in-place* when *o* supports it.  This is the |  | ||||||
|    equivalent of the Python expression ``o *= count``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PySequence_GetItem(PyObject *o, Py_ssize_t i) |  | ||||||
| 
 |  | ||||||
|    Return the *i*\ th element of *o*, or *NULL* on failure. This is the equivalent of |  | ||||||
|    the Python expression ``o[i]``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PySequence_GetSlice(PyObject *o, Py_ssize_t i1, Py_ssize_t i2) |  | ||||||
| 
 |  | ||||||
|    Return the slice of sequence object *o* between *i1* and *i2*, or *NULL* on |  | ||||||
|    failure. This is the equivalent of the Python expression ``o[i1:i2]``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PySequence_SetItem(PyObject *o, Py_ssize_t i, PyObject *v) |  | ||||||
| 
 |  | ||||||
|    Assign object *v* to the *i*\ th element of *o*.  Raise an exception |  | ||||||
|    and return ``-1`` on failure; return ``0`` on success.  This |  | ||||||
|    is the equivalent of the Python statement ``o[i] = v``.  This function *does |  | ||||||
|    not* steal a reference to *v*. |  | ||||||
| 
 |  | ||||||
|    If *v* is *NULL*, the element is deleted, however this feature is |  | ||||||
|    deprecated in favour of using :c:func:`PySequence_DelItem`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PySequence_DelItem(PyObject *o, Py_ssize_t i) |  | ||||||
| 
 |  | ||||||
|    Delete the *i*\ th element of object *o*.  Returns ``-1`` on failure.  This is the |  | ||||||
|    equivalent of the Python statement ``del o[i]``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PySequence_SetSlice(PyObject *o, Py_ssize_t i1, Py_ssize_t i2, PyObject *v) |  | ||||||
| 
 |  | ||||||
|    Assign the sequence object *v* to the slice in sequence object *o* from *i1* to |  | ||||||
|    *i2*.  This is the equivalent of the Python statement ``o[i1:i2] = v``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PySequence_DelSlice(PyObject *o, Py_ssize_t i1, Py_ssize_t i2) |  | ||||||
| 
 |  | ||||||
|    Delete the slice in sequence object *o* from *i1* to *i2*.  Returns ``-1`` on |  | ||||||
|    failure.  This is the equivalent of the Python statement ``del o[i1:i2]``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PySequence_Count(PyObject *o, PyObject *value) |  | ||||||
| 
 |  | ||||||
|    Return the number of occurrences of *value* in *o*, that is, return the number |  | ||||||
|    of keys for which ``o[key] == value``.  On failure, return ``-1``.  This is |  | ||||||
|    equivalent to the Python expression ``o.count(value)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PySequence_Contains(PyObject *o, PyObject *value) |  | ||||||
| 
 |  | ||||||
|    Determine if *o* contains *value*.  If an item in *o* is equal to *value*, |  | ||||||
|    return ``1``, otherwise return ``0``. On error, return ``-1``.  This is |  | ||||||
|    equivalent to the Python expression ``value in o``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PySequence_Index(PyObject *o, PyObject *value) |  | ||||||
| 
 |  | ||||||
|    Return the first index *i* for which ``o[i] == value``.  On error, return |  | ||||||
|    ``-1``.    This is equivalent to the Python expression ``o.index(value)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PySequence_List(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return a list object with the same contents as the sequence or iterable *o*, |  | ||||||
|    or *NULL* on failure.  The returned list is guaranteed to be new.  This is |  | ||||||
|    equivalent to the Python expression ``list(o)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PySequence_Tuple(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: tuple |  | ||||||
| 
 |  | ||||||
|    Return a tuple object with the same contents as the sequence or iterable *o*, |  | ||||||
|    or *NULL* on failure.  If *o* is a tuple, a new reference will be returned, |  | ||||||
|    otherwise a tuple will be constructed with the appropriate contents.  This is |  | ||||||
|    equivalent to the Python expression ``tuple(o)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PySequence_Fast(PyObject *o, const char *m) |  | ||||||
| 
 |  | ||||||
|    Return the sequence or iterable *o* as a list, unless it is already a tuple or list, in |  | ||||||
|    which case *o* is returned.  Use :c:func:`PySequence_Fast_GET_ITEM` to access |  | ||||||
|    the members of the result.  Returns *NULL* on failure.  If the object is not |  | ||||||
|    a sequence or iterable, raises :exc:`TypeError` with *m* as the message text. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PySequence_Fast_GET_SIZE(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Returns the length of *o*, assuming that *o* was returned by |  | ||||||
|    :c:func:`PySequence_Fast` and that *o* is not *NULL*.  The size can also be |  | ||||||
|    gotten by calling :c:func:`PySequence_Size` on *o*, but |  | ||||||
|    :c:func:`PySequence_Fast_GET_SIZE` is faster because it can assume *o* is a list |  | ||||||
|    or tuple. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PySequence_Fast_GET_ITEM(PyObject *o, Py_ssize_t i) |  | ||||||
| 
 |  | ||||||
|    Return the *i*\ th element of *o*, assuming that *o* was returned by |  | ||||||
|    :c:func:`PySequence_Fast`, *o* is not *NULL*, and that *i* is within bounds. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject** PySequence_Fast_ITEMS(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return the underlying array of PyObject pointers.  Assumes that *o* was returned |  | ||||||
|    by :c:func:`PySequence_Fast` and *o* is not *NULL*. |  | ||||||
| 
 |  | ||||||
|    Note, if a list gets resized, the reallocation may relocate the items array. |  | ||||||
|    So, only use the underlying array pointer in contexts where the sequence |  | ||||||
|    cannot change. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PySequence_ITEM(PyObject *o, Py_ssize_t i) |  | ||||||
| 
 |  | ||||||
|    Return the *i*\ th element of *o* or *NULL* on failure. Macro form of |  | ||||||
|    :c:func:`PySequence_GetItem` but without checking that |  | ||||||
|    :c:func:`PySequence_Check` on *o* is true and without adjustment for negative |  | ||||||
|    indices. |  | ||||||
							
								
								
									
										166
									
								
								third_party/python/Doc/c-api/set.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										166
									
								
								third_party/python/Doc/c-api/set.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,166 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _setobjects: |  | ||||||
| 
 |  | ||||||
| Set Objects |  | ||||||
| ----------- |  | ||||||
| 
 |  | ||||||
| .. sectionauthor:: Raymond D. Hettinger <python@rcn.com> |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. index:: |  | ||||||
|    object: set |  | ||||||
|    object: frozenset |  | ||||||
| 
 |  | ||||||
| This section details the public API for :class:`set` and :class:`frozenset` |  | ||||||
| objects.  Any functionality not listed below is best accessed using the either |  | ||||||
| the abstract object protocol (including :c:func:`PyObject_CallMethod`, |  | ||||||
| :c:func:`PyObject_RichCompareBool`, :c:func:`PyObject_Hash`, |  | ||||||
| :c:func:`PyObject_Repr`, :c:func:`PyObject_IsTrue`, :c:func:`PyObject_Print`, and |  | ||||||
| :c:func:`PyObject_GetIter`) or the abstract number protocol (including |  | ||||||
| :c:func:`PyNumber_And`, :c:func:`PyNumber_Subtract`, :c:func:`PyNumber_Or`, |  | ||||||
| :c:func:`PyNumber_Xor`, :c:func:`PyNumber_InPlaceAnd`, |  | ||||||
| :c:func:`PyNumber_InPlaceSubtract`, :c:func:`PyNumber_InPlaceOr`, and |  | ||||||
| :c:func:`PyNumber_InPlaceXor`). |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PySetObject |  | ||||||
| 
 |  | ||||||
|    This subtype of :c:type:`PyObject` is used to hold the internal data for both |  | ||||||
|    :class:`set` and :class:`frozenset` objects.  It is like a :c:type:`PyDictObject` |  | ||||||
|    in that it is a fixed size for small sets (much like tuple storage) and will |  | ||||||
|    point to a separate, variable sized block of memory for medium and large sized |  | ||||||
|    sets (much like list storage). None of the fields of this structure should be |  | ||||||
|    considered public and are subject to change.  All access should be done through |  | ||||||
|    the documented API rather than by manipulating the values in the structure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PySet_Type |  | ||||||
| 
 |  | ||||||
|    This is an instance of :c:type:`PyTypeObject` representing the Python |  | ||||||
|    :class:`set` type. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyFrozenSet_Type |  | ||||||
| 
 |  | ||||||
|    This is an instance of :c:type:`PyTypeObject` representing the Python |  | ||||||
|    :class:`frozenset` type. |  | ||||||
| 
 |  | ||||||
| The following type check macros work on pointers to any Python object. Likewise, |  | ||||||
| the constructor functions work with any iterable Python object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PySet_Check(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if *p* is a :class:`set` object or an instance of a subtype. |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyFrozenSet_Check(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if *p* is a :class:`frozenset` object or an instance of a |  | ||||||
|    subtype. |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyAnySet_Check(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if *p* is a :class:`set` object, a :class:`frozenset` object, or an |  | ||||||
|    instance of a subtype. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyAnySet_CheckExact(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if *p* is a :class:`set` object or a :class:`frozenset` object but |  | ||||||
|    not an instance of a subtype. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyFrozenSet_CheckExact(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if *p* is a :class:`frozenset` object but not an instance of a |  | ||||||
|    subtype. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PySet_New(PyObject *iterable) |  | ||||||
| 
 |  | ||||||
|    Return a new :class:`set` containing objects returned by the *iterable*.  The |  | ||||||
|    *iterable* may be *NULL* to create a new empty set.  Return the new set on |  | ||||||
|    success or *NULL* on failure.  Raise :exc:`TypeError` if *iterable* is not |  | ||||||
|    actually iterable.  The constructor is also useful for copying a set |  | ||||||
|    (``c=set(s)``). |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyFrozenSet_New(PyObject *iterable) |  | ||||||
| 
 |  | ||||||
|    Return a new :class:`frozenset` containing objects returned by the *iterable*. |  | ||||||
|    The *iterable* may be *NULL* to create a new empty frozenset.  Return the new |  | ||||||
|    set on success or *NULL* on failure.  Raise :exc:`TypeError` if *iterable* is |  | ||||||
|    not actually iterable. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| The following functions and macros are available for instances of :class:`set` |  | ||||||
| or :class:`frozenset` or instances of their subtypes. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PySet_Size(PyObject *anyset) |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: len |  | ||||||
| 
 |  | ||||||
|    Return the length of a :class:`set` or :class:`frozenset` object. Equivalent to |  | ||||||
|    ``len(anyset)``.  Raises a :exc:`PyExc_SystemError` if *anyset* is not a |  | ||||||
|    :class:`set`, :class:`frozenset`, or an instance of a subtype. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PySet_GET_SIZE(PyObject *anyset) |  | ||||||
| 
 |  | ||||||
|    Macro form of :c:func:`PySet_Size` without error checking. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PySet_Contains(PyObject *anyset, PyObject *key) |  | ||||||
| 
 |  | ||||||
|    Return ``1`` if found, ``0`` if not found, and ``-1`` if an error is encountered.  Unlike |  | ||||||
|    the Python :meth:`__contains__` method, this function does not automatically |  | ||||||
|    convert unhashable sets into temporary frozensets.  Raise a :exc:`TypeError` if |  | ||||||
|    the *key* is unhashable. Raise :exc:`PyExc_SystemError` if *anyset* is not a |  | ||||||
|    :class:`set`, :class:`frozenset`, or an instance of a subtype. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PySet_Add(PyObject *set, PyObject *key) |  | ||||||
| 
 |  | ||||||
|    Add *key* to a :class:`set` instance.  Also works with :class:`frozenset` |  | ||||||
|    instances (like :c:func:`PyTuple_SetItem` it can be used to fill-in the values |  | ||||||
|    of brand new frozensets before they are exposed to other code).  Return ``0`` on |  | ||||||
|    success or ``-1`` on failure. Raise a :exc:`TypeError` if the *key* is |  | ||||||
|    unhashable. Raise a :exc:`MemoryError` if there is no room to grow.  Raise a |  | ||||||
|    :exc:`SystemError` if *set* is not an instance of :class:`set` or its |  | ||||||
|    subtype. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| The following functions are available for instances of :class:`set` or its |  | ||||||
| subtypes but not for instances of :class:`frozenset` or its subtypes. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PySet_Discard(PyObject *set, PyObject *key) |  | ||||||
| 
 |  | ||||||
|    Return ``1`` if found and removed, ``0`` if not found (no action taken), and ``-1`` if an |  | ||||||
|    error is encountered.  Does not raise :exc:`KeyError` for missing keys.  Raise a |  | ||||||
|    :exc:`TypeError` if the *key* is unhashable.  Unlike the Python :meth:`~set.discard` |  | ||||||
|    method, this function does not automatically convert unhashable sets into |  | ||||||
|    temporary frozensets. Raise :exc:`PyExc_SystemError` if *set* is not an |  | ||||||
|    instance of :class:`set` or its subtype. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PySet_Pop(PyObject *set) |  | ||||||
| 
 |  | ||||||
|    Return a new reference to an arbitrary object in the *set*, and removes the |  | ||||||
|    object from the *set*.  Return *NULL* on failure.  Raise :exc:`KeyError` if the |  | ||||||
|    set is empty. Raise a :exc:`SystemError` if *set* is not an instance of |  | ||||||
|    :class:`set` or its subtype. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PySet_Clear(PyObject *set) |  | ||||||
| 
 |  | ||||||
|    Empty an existing set of all elements. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PySet_ClearFreeList() |  | ||||||
| 
 |  | ||||||
|    Clear the free list. Return the total number of freed items. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
							
								
								
									
										69
									
								
								third_party/python/Doc/c-api/slice.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										69
									
								
								third_party/python/Doc/c-api/slice.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,69 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _slice-objects: |  | ||||||
| 
 |  | ||||||
| Slice Objects |  | ||||||
| ------------- |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PySlice_Type |  | ||||||
| 
 |  | ||||||
|    The type object for slice objects.  This is the same as :class:`slice` in the |  | ||||||
|    Python layer. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PySlice_Check(PyObject *ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob* is a slice object; *ob* must not be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PySlice_New(PyObject *start, PyObject *stop, PyObject *step) |  | ||||||
| 
 |  | ||||||
|    Return a new slice object with the given values.  The *start*, *stop*, and |  | ||||||
|    *step* parameters are used as the values of the slice object attributes of |  | ||||||
|    the same names.  Any of the values may be *NULL*, in which case the |  | ||||||
|    ``None`` will be used for the corresponding attribute.  Return *NULL* if |  | ||||||
|    the new object could not be allocated. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PySlice_GetIndices(PyObject *slice, Py_ssize_t length, Py_ssize_t *start, Py_ssize_t *stop, Py_ssize_t *step) |  | ||||||
| 
 |  | ||||||
|    Retrieve the start, stop and step indices from the slice object *slice*, |  | ||||||
|    assuming a sequence of length *length*. Treats indices greater than |  | ||||||
|    *length* as errors. |  | ||||||
| 
 |  | ||||||
|    Returns ``0`` on success and ``-1`` on error with no exception set (unless one of |  | ||||||
|    the indices was not :const:`None` and failed to be converted to an integer, |  | ||||||
|    in which case ``-1`` is returned with an exception set). |  | ||||||
| 
 |  | ||||||
|    You probably do not want to use this function. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.2 |  | ||||||
|       The parameter type for the *slice* parameter was ``PySliceObject*`` |  | ||||||
|       before. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PySlice_GetIndicesEx(PyObject *slice, Py_ssize_t length, Py_ssize_t *start, Py_ssize_t *stop, Py_ssize_t *step, Py_ssize_t *slicelength) |  | ||||||
| 
 |  | ||||||
|    Usable replacement for :c:func:`PySlice_GetIndices`.  Retrieve the start, |  | ||||||
|    stop, and step indices from the slice object *slice* assuming a sequence of |  | ||||||
|    length *length*, and store the length of the slice in *slicelength*.  Out |  | ||||||
|    of bounds indices are clipped in a manner consistent with the handling of |  | ||||||
|    normal slices. |  | ||||||
| 
 |  | ||||||
|    Returns ``0`` on success and ``-1`` on error with exception set. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.2 |  | ||||||
|       The parameter type for the *slice* parameter was ``PySliceObject*`` |  | ||||||
|       before. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Ellipsis Object |  | ||||||
| --------------- |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyObject *Py_Ellipsis |  | ||||||
| 
 |  | ||||||
|    The Python ``Ellipsis`` object.  This object has no methods.  It needs to be |  | ||||||
|    treated just like any other object with respect to reference counts.  Like |  | ||||||
|    :c:data:`Py_None` it is a singleton object. |  | ||||||
							
								
								
									
										38
									
								
								third_party/python/Doc/c-api/stable.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										38
									
								
								third_party/python/Doc/c-api/stable.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,38 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _stable: |  | ||||||
| 
 |  | ||||||
| *********************************** |  | ||||||
| Stable Application Binary Interface |  | ||||||
| *********************************** |  | ||||||
| 
 |  | ||||||
| Traditionally, the C API of Python will change with every release.  Most changes |  | ||||||
| will be source-compatible, typically by only adding API, rather than changing |  | ||||||
| existing API or removing API (although some interfaces do get removed after |  | ||||||
| being deprecated first). |  | ||||||
| 
 |  | ||||||
| Unfortunately, the API compatibility does not extend to binary compatibility |  | ||||||
| (the ABI). The reason is primarily the evolution of struct definitions, where |  | ||||||
| addition of a new field, or changing the type of a field, might not break the |  | ||||||
| API, but can break the ABI.  As a consequence, extension modules need to be |  | ||||||
| recompiled for every Python release (although an exception is possible on Unix |  | ||||||
| when none of the affected interfaces are used). In addition, on Windows, |  | ||||||
| extension modules link with a specific pythonXY.dll and need to be recompiled to |  | ||||||
| link with a newer one. |  | ||||||
| 
 |  | ||||||
| Since Python 3.2, a subset of the API has been declared to guarantee a stable |  | ||||||
| ABI. Extension modules wishing to use this API (called "limited API") need to |  | ||||||
| define ``Py_LIMITED_API``. A number of interpreter details then become hidden |  | ||||||
| from the extension module; in return, a module is built that works on any 3.x |  | ||||||
| version (x>=2) without recompilation. |  | ||||||
| 
 |  | ||||||
| In some cases, the stable ABI needs to be extended with new functions. |  | ||||||
| Extension modules wishing to use these new APIs need to set ``Py_LIMITED_API`` |  | ||||||
| to the ``PY_VERSION_HEX`` value (see :ref:`apiabiversion`) of the minimum Python |  | ||||||
| version they want to support (e.g. ``0x03030000`` for Python 3.3). Such modules |  | ||||||
| will work on all subsequent Python releases, but fail to load (because of |  | ||||||
| missing symbols) on the older releases. |  | ||||||
| 
 |  | ||||||
| As of Python 3.2, the set of functions available to the limited API is |  | ||||||
| documented in :pep:`384`.  In the C API documentation, API elements that are not |  | ||||||
| part of the limited API are marked as "Not part of the limited API." |  | ||||||
							
								
								
									
										337
									
								
								third_party/python/Doc/c-api/structures.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										337
									
								
								third_party/python/Doc/c-api/structures.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,337 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _common-structs: |  | ||||||
| 
 |  | ||||||
| Common Object Structures |  | ||||||
| ======================== |  | ||||||
| 
 |  | ||||||
| There are a large number of structures which are used in the definition of |  | ||||||
| object types for Python.  This section describes these structures and how they |  | ||||||
| are used. |  | ||||||
| 
 |  | ||||||
| All Python objects ultimately share a small number of fields at the beginning |  | ||||||
| of the object's representation in memory.  These are represented by the |  | ||||||
| :c:type:`PyObject` and :c:type:`PyVarObject` types, which are defined, in turn, |  | ||||||
| by the expansions of some macros also used, whether directly or indirectly, in |  | ||||||
| the definition of all other Python objects. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyObject |  | ||||||
| 
 |  | ||||||
|    All object types are extensions of this type.  This is a type which |  | ||||||
|    contains the information Python needs to treat a pointer to an object as an |  | ||||||
|    object.  In a normal "release" build, it contains only the object's |  | ||||||
|    reference count and a pointer to the corresponding type object. |  | ||||||
|    Nothing is actually declared to be a :c:type:`PyObject`, but every pointer |  | ||||||
|    to a Python object can be cast to a :c:type:`PyObject*`.  Access to the |  | ||||||
|    members must be done by using the macros :c:macro:`Py_REFCNT` and |  | ||||||
|    :c:macro:`Py_TYPE`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyVarObject |  | ||||||
| 
 |  | ||||||
|    This is an extension of :c:type:`PyObject` that adds the :attr:`ob_size` |  | ||||||
|    field.  This is only used for objects that have some notion of *length*. |  | ||||||
|    This type does not often appear in the Python/C API. |  | ||||||
|    Access to the members must be done by using the macros |  | ||||||
|    :c:macro:`Py_REFCNT`, :c:macro:`Py_TYPE`, and :c:macro:`Py_SIZE`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:macro:: PyObject_HEAD |  | ||||||
| 
 |  | ||||||
|    This is a macro used when declaring new types which represent objects |  | ||||||
|    without a varying length.  The PyObject_HEAD macro expands to:: |  | ||||||
| 
 |  | ||||||
|       PyObject ob_base; |  | ||||||
| 
 |  | ||||||
|    See documentation of :c:type:`PyObject` above. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:macro:: PyObject_VAR_HEAD |  | ||||||
| 
 |  | ||||||
|    This is a macro used when declaring new types which represent objects |  | ||||||
|    with a length that varies from instance to instance. |  | ||||||
|    The PyObject_VAR_HEAD macro expands to:: |  | ||||||
| 
 |  | ||||||
|       PyVarObject ob_base; |  | ||||||
| 
 |  | ||||||
|    See documentation of :c:type:`PyVarObject` above. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:macro:: Py_TYPE(o) |  | ||||||
| 
 |  | ||||||
|    This macro is used to access the :attr:`ob_type` member of a Python object. |  | ||||||
|    It expands to:: |  | ||||||
| 
 |  | ||||||
|       (((PyObject*)(o))->ob_type) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:macro:: Py_REFCNT(o) |  | ||||||
| 
 |  | ||||||
|    This macro is used to access the :attr:`ob_refcnt` member of a Python |  | ||||||
|    object. |  | ||||||
|    It expands to:: |  | ||||||
| 
 |  | ||||||
|       (((PyObject*)(o))->ob_refcnt) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:macro:: Py_SIZE(o) |  | ||||||
| 
 |  | ||||||
|    This macro is used to access the :attr:`ob_size` member of a Python object. |  | ||||||
|    It expands to:: |  | ||||||
| 
 |  | ||||||
|       (((PyVarObject*)(o))->ob_size) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:macro:: PyObject_HEAD_INIT(type) |  | ||||||
| 
 |  | ||||||
|    This is a macro which expands to initialization values for a new |  | ||||||
|    :c:type:`PyObject` type.  This macro expands to:: |  | ||||||
| 
 |  | ||||||
|       _PyObject_EXTRA_INIT |  | ||||||
|       1, type, |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:macro:: PyVarObject_HEAD_INIT(type, size) |  | ||||||
| 
 |  | ||||||
|    This is a macro which expands to initialization values for a new |  | ||||||
|    :c:type:`PyVarObject` type, including the :attr:`ob_size` field. |  | ||||||
|    This macro expands to:: |  | ||||||
| 
 |  | ||||||
|       _PyObject_EXTRA_INIT |  | ||||||
|       1, type, size, |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyCFunction |  | ||||||
| 
 |  | ||||||
|    Type of the functions used to implement most Python callables in C. |  | ||||||
|    Functions of this type take two :c:type:`PyObject\*` parameters and return |  | ||||||
|    one such value.  If the return value is *NULL*, an exception shall have |  | ||||||
|    been set.  If not *NULL*, the return value is interpreted as the return |  | ||||||
|    value of the function as exposed in Python.  The function must return a new |  | ||||||
|    reference. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyCFunctionWithKeywords |  | ||||||
| 
 |  | ||||||
|    Type of the functions used to implement Python callables in C that take |  | ||||||
|    keyword arguments: they take three :c:type:`PyObject\*` parameters and return |  | ||||||
|    one such value.  See :c:type:`PyCFunction` above for the meaning of the return |  | ||||||
|    value. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyMethodDef |  | ||||||
| 
 |  | ||||||
|    Structure used to describe a method of an extension type.  This structure has |  | ||||||
|    four fields: |  | ||||||
| 
 |  | ||||||
|    +------------------+-------------+-------------------------------+ |  | ||||||
|    | Field            | C Type      | Meaning                       | |  | ||||||
|    +==================+=============+===============================+ |  | ||||||
|    | :attr:`ml_name`  | char \*     | name of the method            | |  | ||||||
|    +------------------+-------------+-------------------------------+ |  | ||||||
|    | :attr:`ml_meth`  | PyCFunction | pointer to the C              | |  | ||||||
|    |                  |             | implementation                | |  | ||||||
|    +------------------+-------------+-------------------------------+ |  | ||||||
|    | :attr:`ml_flags` | int         | flag bits indicating how the  | |  | ||||||
|    |                  |             | call should be constructed    | |  | ||||||
|    +------------------+-------------+-------------------------------+ |  | ||||||
|    | :attr:`ml_doc`   | char \*     | points to the contents of the | |  | ||||||
|    |                  |             | docstring                     | |  | ||||||
|    +------------------+-------------+-------------------------------+ |  | ||||||
| 
 |  | ||||||
| The :attr:`ml_meth` is a C function pointer.  The functions may be of different |  | ||||||
| types, but they always return :c:type:`PyObject\*`.  If the function is not of |  | ||||||
| the :c:type:`PyCFunction`, the compiler will require a cast in the method table. |  | ||||||
| Even though :c:type:`PyCFunction` defines the first parameter as |  | ||||||
| :c:type:`PyObject\*`, it is common that the method implementation uses the |  | ||||||
| specific C type of the *self* object. |  | ||||||
| 
 |  | ||||||
| The :attr:`ml_flags` field is a bitfield which can include the following flags. |  | ||||||
| The individual flags indicate either a calling convention or a binding |  | ||||||
| convention.  Of the calling convention flags, only :const:`METH_VARARGS` and |  | ||||||
| :const:`METH_KEYWORDS` can be combined. Any of the calling convention flags |  | ||||||
| can be combined with a binding flag. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. data:: METH_VARARGS |  | ||||||
| 
 |  | ||||||
|    This is the typical calling convention, where the methods have the type |  | ||||||
|    :c:type:`PyCFunction`. The function expects two :c:type:`PyObject\*` values. |  | ||||||
|    The first one is the *self* object for methods; for module functions, it is |  | ||||||
|    the module object.  The second parameter (often called *args*) is a tuple |  | ||||||
|    object representing all arguments. This parameter is typically processed |  | ||||||
|    using :c:func:`PyArg_ParseTuple` or :c:func:`PyArg_UnpackTuple`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. data:: METH_KEYWORDS |  | ||||||
| 
 |  | ||||||
|    Methods with these flags must be of type :c:type:`PyCFunctionWithKeywords`. |  | ||||||
|    The function expects three parameters: *self*, *args*, and a dictionary of |  | ||||||
|    all the keyword arguments.  The flag must be combined with |  | ||||||
|    :const:`METH_VARARGS`, and the parameters are typically processed using |  | ||||||
|    :c:func:`PyArg_ParseTupleAndKeywords`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. data:: METH_NOARGS |  | ||||||
| 
 |  | ||||||
|    Methods without parameters don't need to check whether arguments are given if |  | ||||||
|    they are listed with the :const:`METH_NOARGS` flag.  They need to be of type |  | ||||||
|    :c:type:`PyCFunction`.  The first parameter is typically named *self* and will |  | ||||||
|    hold a reference to the module or object instance.  In all cases the second |  | ||||||
|    parameter will be *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. data:: METH_O |  | ||||||
| 
 |  | ||||||
|    Methods with a single object argument can be listed with the :const:`METH_O` |  | ||||||
|    flag, instead of invoking :c:func:`PyArg_ParseTuple` with a ``"O"`` argument. |  | ||||||
|    They have the type :c:type:`PyCFunction`, with the *self* parameter, and a |  | ||||||
|    :c:type:`PyObject\*` parameter representing the single argument. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| These two constants are not used to indicate the calling convention but the |  | ||||||
| binding when use with methods of classes.  These may not be used for functions |  | ||||||
| defined for modules.  At most one of these flags may be set for any given |  | ||||||
| method. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. data:: METH_CLASS |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: classmethod |  | ||||||
| 
 |  | ||||||
|    The method will be passed the type object as the first parameter rather |  | ||||||
|    than an instance of the type.  This is used to create *class methods*, |  | ||||||
|    similar to what is created when using the :func:`classmethod` built-in |  | ||||||
|    function. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. data:: METH_STATIC |  | ||||||
| 
 |  | ||||||
|    .. index:: builtin: staticmethod |  | ||||||
| 
 |  | ||||||
|    The method will be passed *NULL* as the first parameter rather than an |  | ||||||
|    instance of the type.  This is used to create *static methods*, similar to |  | ||||||
|    what is created when using the :func:`staticmethod` built-in function. |  | ||||||
| 
 |  | ||||||
| One other constant controls whether a method is loaded in place of another |  | ||||||
| definition with the same method name. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. data:: METH_COEXIST |  | ||||||
| 
 |  | ||||||
|    The method will be loaded in place of existing definitions.  Without |  | ||||||
|    *METH_COEXIST*, the default is to skip repeated definitions.  Since slot |  | ||||||
|    wrappers are loaded before the method table, the existence of a |  | ||||||
|    *sq_contains* slot, for example, would generate a wrapped method named |  | ||||||
|    :meth:`__contains__` and preclude the loading of a corresponding |  | ||||||
|    PyCFunction with the same name.  With the flag defined, the PyCFunction |  | ||||||
|    will be loaded in place of the wrapper object and will co-exist with the |  | ||||||
|    slot.  This is helpful because calls to PyCFunctions are optimized more |  | ||||||
|    than wrapper object calls. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyMemberDef |  | ||||||
| 
 |  | ||||||
|    Structure which describes an attribute of a type which corresponds to a C |  | ||||||
|    struct member.  Its fields are: |  | ||||||
| 
 |  | ||||||
|    +------------------+-------------+-------------------------------+ |  | ||||||
|    | Field            | C Type      | Meaning                       | |  | ||||||
|    +==================+=============+===============================+ |  | ||||||
|    | :attr:`name`     | char \*     | name of the member            | |  | ||||||
|    +------------------+-------------+-------------------------------+ |  | ||||||
|    | :attr:`!type`    | int         | the type of the member in the | |  | ||||||
|    |                  |             | C struct                      | |  | ||||||
|    +------------------+-------------+-------------------------------+ |  | ||||||
|    | :attr:`offset`   | Py_ssize_t  | the offset in bytes that the  | |  | ||||||
|    |                  |             | member is located on the      | |  | ||||||
|    |                  |             | type's object struct          | |  | ||||||
|    +------------------+-------------+-------------------------------+ |  | ||||||
|    | :attr:`flags`    | int         | flag bits indicating if the   | |  | ||||||
|    |                  |             | field should be read-only or  | |  | ||||||
|    |                  |             | writable                      | |  | ||||||
|    +------------------+-------------+-------------------------------+ |  | ||||||
|    | :attr:`doc`      | char \*     | points to the contents of the | |  | ||||||
|    |                  |             | docstring                     | |  | ||||||
|    +------------------+-------------+-------------------------------+ |  | ||||||
| 
 |  | ||||||
|    :attr:`!type` can be one of many ``T_`` macros corresponding to various C |  | ||||||
|    types.  When the member is accessed in Python, it will be converted to the |  | ||||||
|    equivalent Python type. |  | ||||||
| 
 |  | ||||||
|    =============== ================== |  | ||||||
|    Macro name      C type |  | ||||||
|    =============== ================== |  | ||||||
|    T_SHORT         short |  | ||||||
|    T_INT           int |  | ||||||
|    T_LONG          long |  | ||||||
|    T_FLOAT         float |  | ||||||
|    T_DOUBLE        double |  | ||||||
|    T_STRING        char \* |  | ||||||
|    T_OBJECT        PyObject \* |  | ||||||
|    T_OBJECT_EX     PyObject \* |  | ||||||
|    T_CHAR          char |  | ||||||
|    T_BYTE          char |  | ||||||
|    T_UBYTE         unsigned char |  | ||||||
|    T_UINT          unsigned int |  | ||||||
|    T_USHORT        unsigned short |  | ||||||
|    T_ULONG         unsigned long |  | ||||||
|    T_BOOL          char |  | ||||||
|    T_LONGLONG      long long |  | ||||||
|    T_ULONGLONG     unsigned long long |  | ||||||
|    T_PYSSIZET      Py_ssize_t |  | ||||||
|    =============== ================== |  | ||||||
| 
 |  | ||||||
|    :c:macro:`T_OBJECT` and :c:macro:`T_OBJECT_EX` differ in that |  | ||||||
|    :c:macro:`T_OBJECT` returns ``None`` if the member is *NULL* and |  | ||||||
|    :c:macro:`T_OBJECT_EX` raises an :exc:`AttributeError`.  Try to use |  | ||||||
|    :c:macro:`T_OBJECT_EX` over :c:macro:`T_OBJECT` because :c:macro:`T_OBJECT_EX` |  | ||||||
|    handles use of the :keyword:`del` statement on that attribute more correctly |  | ||||||
|    than :c:macro:`T_OBJECT`. |  | ||||||
| 
 |  | ||||||
|    :attr:`flags` can be ``0`` for write and read access or :c:macro:`READONLY` for |  | ||||||
|    read-only access.  Using :c:macro:`T_STRING` for :attr:`type` implies |  | ||||||
|    :c:macro:`READONLY`.  :c:macro:`T_STRING` data is interpreted as UTF-8. |  | ||||||
|    Only :c:macro:`T_OBJECT` and :c:macro:`T_OBJECT_EX` |  | ||||||
|    members can be deleted.  (They are set to *NULL*). |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyGetSetDef |  | ||||||
| 
 |  | ||||||
|    Structure to define property-like access for a type. See also description of |  | ||||||
|    the :c:member:`PyTypeObject.tp_getset` slot. |  | ||||||
| 
 |  | ||||||
|    +-------------+------------------+-----------------------------------+ |  | ||||||
|    | Field       | C Type           | Meaning                           | |  | ||||||
|    +=============+==================+===================================+ |  | ||||||
|    | name        | char \*          | attribute name                    | |  | ||||||
|    +-------------+------------------+-----------------------------------+ |  | ||||||
|    | get         | getter           | C Function to get the attribute   | |  | ||||||
|    +-------------+------------------+-----------------------------------+ |  | ||||||
|    | set         | setter           | optional C function to set or     | |  | ||||||
|    |             |                  | delete the attribute, if omitted  | |  | ||||||
|    |             |                  | the attribute is readonly         | |  | ||||||
|    +-------------+------------------+-----------------------------------+ |  | ||||||
|    | doc         | char \*          | optional docstring                | |  | ||||||
|    +-------------+------------------+-----------------------------------+ |  | ||||||
|    | closure     | void \*          | optional function pointer,        | |  | ||||||
|    |             |                  | providing additional data for     | |  | ||||||
|    |             |                  | getter and setter                 | |  | ||||||
|    +-------------+------------------+-----------------------------------+ |  | ||||||
| 
 |  | ||||||
|    The ``get`` function takes one :c:type:`PyObject\*` parameter (the |  | ||||||
|    instance) and a function pointer (the associated ``closure``):: |  | ||||||
| 
 |  | ||||||
|       typedef PyObject *(*getter)(PyObject *, void *); |  | ||||||
| 
 |  | ||||||
|    It should return a new reference on success or *NULL* with a set exception |  | ||||||
|    on failure. |  | ||||||
| 
 |  | ||||||
|    ``set`` functions take two :c:type:`PyObject\*` parameters (the instance and |  | ||||||
|    the value to be set) and a function pointer (the associated ``closure``):: |  | ||||||
| 
 |  | ||||||
|       typedef int (*setter)(PyObject *, PyObject *, void *); |  | ||||||
| 
 |  | ||||||
|    In case the attribute should be deleted the second parameter is *NULL*. |  | ||||||
|    Should return ``0`` on success or ``-1`` with a set exception on failure. |  | ||||||
							
								
								
									
										267
									
								
								third_party/python/Doc/c-api/sys.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										267
									
								
								third_party/python/Doc/c-api/sys.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,267 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _os: |  | ||||||
| 
 |  | ||||||
| Operating System Utilities |  | ||||||
| ========================== |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyOS_FSPath(PyObject *path) |  | ||||||
| 
 |  | ||||||
|    Return the file system representation for *path*. If the object is a |  | ||||||
|    :class:`str` or :class:`bytes` object, then its reference count is |  | ||||||
|    incremented. If the object implements the :class:`os.PathLike` interface, |  | ||||||
|    then :meth:`~os.PathLike.__fspath__` is returned as long as it is a |  | ||||||
|    :class:`str` or :class:`bytes` object. Otherwise :exc:`TypeError` is raised |  | ||||||
|    and ``NULL`` is returned. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.6 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int Py_FdIsInteractive(FILE *fp, const char *filename) |  | ||||||
| 
 |  | ||||||
|    Return true (nonzero) if the standard I/O file *fp* with name *filename* is |  | ||||||
|    deemed interactive.  This is the case for files for which ``isatty(fileno(fp))`` |  | ||||||
|    is true.  If the global flag :c:data:`Py_InteractiveFlag` is true, this function |  | ||||||
|    also returns true if the *filename* pointer is *NULL* or if the name is equal to |  | ||||||
|    one of the strings ``'<stdin>'`` or ``'???'``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyOS_AfterFork() |  | ||||||
| 
 |  | ||||||
|    Function to update some internal state after a process fork; this should be |  | ||||||
|    called in the new process if the Python interpreter will continue to be used. |  | ||||||
|    If a new executable is loaded into the new process, this function does not need |  | ||||||
|    to be called. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyOS_CheckStack() |  | ||||||
| 
 |  | ||||||
|    Return true when the interpreter runs out of stack space.  This is a reliable |  | ||||||
|    check, but is only available when :const:`USE_STACKCHECK` is defined (currently |  | ||||||
|    on Windows using the Microsoft Visual C++ compiler).  :const:`USE_STACKCHECK` |  | ||||||
|    will be defined automatically; you should never change the definition in your |  | ||||||
|    own code. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyOS_sighandler_t PyOS_getsig(int i) |  | ||||||
| 
 |  | ||||||
|    Return the current signal handler for signal *i*.  This is a thin wrapper around |  | ||||||
|    either :c:func:`sigaction` or :c:func:`signal`.  Do not call those functions |  | ||||||
|    directly! :c:type:`PyOS_sighandler_t` is a typedef alias for :c:type:`void |  | ||||||
|    (\*)(int)`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyOS_sighandler_t PyOS_setsig(int i, PyOS_sighandler_t h) |  | ||||||
| 
 |  | ||||||
|    Set the signal handler for signal *i* to be *h*; return the old signal handler. |  | ||||||
|    This is a thin wrapper around either :c:func:`sigaction` or :c:func:`signal`.  Do |  | ||||||
|    not call those functions directly!  :c:type:`PyOS_sighandler_t` is a typedef |  | ||||||
|    alias for :c:type:`void (\*)(int)`. |  | ||||||
| 
 |  | ||||||
| .. c:function:: wchar_t* Py_DecodeLocale(const char* arg, size_t *size) |  | ||||||
| 
 |  | ||||||
|    Decode a byte string from the locale encoding with the :ref:`surrogateescape |  | ||||||
|    error handler <surrogateescape>`: undecodable bytes are decoded as |  | ||||||
|    characters in range U+DC80..U+DCFF. If a byte sequence can be decoded as a |  | ||||||
|    surrogate character, escape the bytes using the surrogateescape error |  | ||||||
|    handler instead of decoding them. |  | ||||||
| 
 |  | ||||||
|    Encoding, highest priority to lowest priority: |  | ||||||
| 
 |  | ||||||
|    * ``UTF-8`` on macOS and Android; |  | ||||||
|    * ``ASCII`` if the ``LC_CTYPE`` locale is ``"C"``, |  | ||||||
|      ``nl_langinfo(CODESET)`` returns the ``ASCII`` encoding (or an alias), |  | ||||||
|      and :c:func:`mbstowcs` and :c:func:`wcstombs` functions use the |  | ||||||
|      ``ISO-8859-1`` encoding. |  | ||||||
|    * the current locale encoding (``LC_CTYPE`` locale). |  | ||||||
| 
 |  | ||||||
|    Return a pointer to a newly allocated wide character string, use |  | ||||||
|    :c:func:`PyMem_RawFree` to free the memory. If size is not ``NULL``, write |  | ||||||
|    the number of wide characters excluding the null character into ``*size``. |  | ||||||
| 
 |  | ||||||
|    Return ``NULL`` on decoding error or memory allocation error. If *size* is |  | ||||||
|    not ``NULL``, ``*size`` is set to ``(size_t)-1`` on memory error or set to |  | ||||||
|    ``(size_t)-2`` on decoding error. |  | ||||||
| 
 |  | ||||||
|    Decoding errors should never happen, unless there is a bug in the C |  | ||||||
|    library. |  | ||||||
| 
 |  | ||||||
|    Use the :c:func:`Py_EncodeLocale` function to encode the character string |  | ||||||
|    back to a byte string. |  | ||||||
| 
 |  | ||||||
|    .. seealso:: |  | ||||||
| 
 |  | ||||||
|       The :c:func:`PyUnicode_DecodeFSDefaultAndSize` and |  | ||||||
|       :c:func:`PyUnicode_DecodeLocaleAndSize` functions. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.5 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: char* Py_EncodeLocale(const wchar_t *text, size_t *error_pos) |  | ||||||
| 
 |  | ||||||
|    Encode a wide character string to the locale encoding with the |  | ||||||
|    :ref:`surrogateescape error handler <surrogateescape>`: surrogate characters |  | ||||||
|    in the range U+DC80..U+DCFF are converted to bytes 0x80..0xFF. |  | ||||||
| 
 |  | ||||||
|    Encoding, highest priority to lowest priority: |  | ||||||
| 
 |  | ||||||
|    * ``UTF-8`` on macOS and Android; |  | ||||||
|    * ``ASCII`` if the ``LC_CTYPE`` locale is ``"C"``, |  | ||||||
|      ``nl_langinfo(CODESET)`` returns the ``ASCII`` encoding (or an alias), |  | ||||||
|      and :c:func:`mbstowcs` and :c:func:`wcstombs` functions uses the |  | ||||||
|      ``ISO-8859-1`` encoding. |  | ||||||
|    * the current locale encoding. |  | ||||||
| 
 |  | ||||||
|    Return a pointer to a newly allocated byte string, use :c:func:`PyMem_Free` |  | ||||||
|    to free the memory. Return ``NULL`` on encoding error or memory allocation |  | ||||||
|    error |  | ||||||
| 
 |  | ||||||
|    If error_pos is not ``NULL``, ``*error_pos`` is set to the index of the |  | ||||||
|    invalid character on encoding error, or set to ``(size_t)-1`` otherwise. |  | ||||||
| 
 |  | ||||||
|    Use the :c:func:`Py_DecodeLocale` function to decode the bytes string back |  | ||||||
|    to a wide character string. |  | ||||||
| 
 |  | ||||||
|    .. seealso:: |  | ||||||
| 
 |  | ||||||
|       The :c:func:`PyUnicode_EncodeFSDefault` and |  | ||||||
|       :c:func:`PyUnicode_EncodeLocale` functions. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.5 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _systemfunctions: |  | ||||||
| 
 |  | ||||||
| System Functions |  | ||||||
| ================ |  | ||||||
| 
 |  | ||||||
| These are utility functions that make functionality from the :mod:`sys` module |  | ||||||
| accessible to C code.  They all work with the current interpreter thread's |  | ||||||
| :mod:`sys` module's dict, which is contained in the internal thread state structure. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject *PySys_GetObject(const char *name) |  | ||||||
| 
 |  | ||||||
|    Return the object *name* from the :mod:`sys` module or *NULL* if it does |  | ||||||
|    not exist, without setting an exception. |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PySys_SetObject(const char *name, PyObject *v) |  | ||||||
| 
 |  | ||||||
|    Set *name* in the :mod:`sys` module to *v* unless *v* is *NULL*, in which |  | ||||||
|    case *name* is deleted from the sys module. Returns ``0`` on success, ``-1`` |  | ||||||
|    on error. |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PySys_ResetWarnOptions() |  | ||||||
| 
 |  | ||||||
|    Reset :data:`sys.warnoptions` to an empty list. |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PySys_AddWarnOption(wchar_t *s) |  | ||||||
| 
 |  | ||||||
|    Append *s* to :data:`sys.warnoptions`. |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PySys_AddWarnOptionUnicode(PyObject *unicode) |  | ||||||
| 
 |  | ||||||
|    Append *unicode* to :data:`sys.warnoptions`. |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PySys_SetPath(wchar_t *path) |  | ||||||
| 
 |  | ||||||
|    Set :data:`sys.path` to a list object of paths found in *path* which should |  | ||||||
|    be a list of paths separated with the platform's search path delimiter |  | ||||||
|    (``:`` on Unix, ``;`` on Windows). |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PySys_WriteStdout(const char *format, ...) |  | ||||||
| 
 |  | ||||||
|    Write the output string described by *format* to :data:`sys.stdout`.  No |  | ||||||
|    exceptions are raised, even if truncation occurs (see below). |  | ||||||
| 
 |  | ||||||
|    *format* should limit the total size of the formatted output string to |  | ||||||
|    1000 bytes or less -- after 1000 bytes, the output string is truncated. |  | ||||||
|    In particular, this means that no unrestricted "%s" formats should occur; |  | ||||||
|    these should be limited using "%.<N>s" where <N> is a decimal number |  | ||||||
|    calculated so that <N> plus the maximum size of other formatted text does not |  | ||||||
|    exceed 1000 bytes.  Also watch out for "%f", which can print hundreds of |  | ||||||
|    digits for very large numbers. |  | ||||||
| 
 |  | ||||||
|    If a problem occurs, or :data:`sys.stdout` is unset, the formatted message |  | ||||||
|    is written to the real (C level) *stdout*. |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PySys_WriteStderr(const char *format, ...) |  | ||||||
| 
 |  | ||||||
|    As :c:func:`PySys_WriteStdout`, but write to :data:`sys.stderr` or *stderr* |  | ||||||
|    instead. |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PySys_FormatStdout(const char *format, ...) |  | ||||||
| 
 |  | ||||||
|    Function similar to PySys_WriteStdout() but format the message using |  | ||||||
|    :c:func:`PyUnicode_FromFormatV` and don't truncate the message to an |  | ||||||
|    arbitrary length. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.2 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PySys_FormatStderr(const char *format, ...) |  | ||||||
| 
 |  | ||||||
|    As :c:func:`PySys_FormatStdout`, but write to :data:`sys.stderr` or *stderr* |  | ||||||
|    instead. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.2 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PySys_AddXOption(const wchar_t *s) |  | ||||||
| 
 |  | ||||||
|    Parse *s* as a set of :option:`-X` options and add them to the current |  | ||||||
|    options mapping as returned by :c:func:`PySys_GetXOptions`. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.2 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject *PySys_GetXOptions() |  | ||||||
| 
 |  | ||||||
|    Return the current dictionary of :option:`-X` options, similarly to |  | ||||||
|    :data:`sys._xoptions`.  On error, *NULL* is returned and an exception is |  | ||||||
|    set. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.2 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _processcontrol: |  | ||||||
| 
 |  | ||||||
| Process Control |  | ||||||
| =============== |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void Py_FatalError(const char *message) |  | ||||||
| 
 |  | ||||||
|    .. index:: single: abort() |  | ||||||
| 
 |  | ||||||
|    Print a fatal error message and kill the process.  No cleanup is performed. |  | ||||||
|    This function should only be invoked when a condition is detected that would |  | ||||||
|    make it dangerous to continue using the Python interpreter; e.g., when the |  | ||||||
|    object administration appears to be corrupted.  On Unix, the standard C library |  | ||||||
|    function :c:func:`abort` is called which will attempt to produce a :file:`core` |  | ||||||
|    file. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void Py_Exit(int status) |  | ||||||
| 
 |  | ||||||
|    .. index:: |  | ||||||
|       single: Py_FinalizeEx() |  | ||||||
|       single: exit() |  | ||||||
| 
 |  | ||||||
|    Exit the current process.  This calls :c:func:`Py_FinalizeEx` and then calls the |  | ||||||
|    standard C library function ``exit(status)``.  If :c:func:`Py_FinalizeEx` |  | ||||||
|    indicates an error, the exit status is set to 120. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.6 |  | ||||||
|       Errors from finalization no longer ignored. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int Py_AtExit(void (*func) ()) |  | ||||||
| 
 |  | ||||||
|    .. index:: |  | ||||||
|       single: Py_FinalizeEx() |  | ||||||
|       single: cleanup functions |  | ||||||
| 
 |  | ||||||
|    Register a cleanup function to be called by :c:func:`Py_FinalizeEx`.  The cleanup |  | ||||||
|    function will be called with no arguments and should return no value.  At most |  | ||||||
|    32 cleanup functions can be registered.  When the registration is successful, |  | ||||||
|    :c:func:`Py_AtExit` returns ``0``; on failure, it returns ``-1``.  The cleanup |  | ||||||
|    function registered last is called first. Each cleanup function will be called |  | ||||||
|    at most once.  Since Python's internal finalization will have completed before |  | ||||||
|    the cleanup function, no Python APIs should be called by *func*. |  | ||||||
							
								
								
									
										218
									
								
								third_party/python/Doc/c-api/tuple.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										218
									
								
								third_party/python/Doc/c-api/tuple.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,218 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _tupleobjects: |  | ||||||
| 
 |  | ||||||
| Tuple Objects |  | ||||||
| ------------- |  | ||||||
| 
 |  | ||||||
| .. index:: object: tuple |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyTupleObject |  | ||||||
| 
 |  | ||||||
|    This subtype of :c:type:`PyObject` represents a Python tuple object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyTypeObject PyTuple_Type |  | ||||||
| 
 |  | ||||||
|    This instance of :c:type:`PyTypeObject` represents the Python tuple type; it |  | ||||||
|    is the same object as :class:`tuple` in the Python layer. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyTuple_Check(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if *p* is a tuple object or an instance of a subtype of the tuple |  | ||||||
|    type. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyTuple_CheckExact(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return true if *p* is a tuple object, but not an instance of a subtype of the |  | ||||||
|    tuple type. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyTuple_New(Py_ssize_t len) |  | ||||||
| 
 |  | ||||||
|    Return a new tuple object of size *len*, or *NULL* on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyTuple_Pack(Py_ssize_t n, ...) |  | ||||||
| 
 |  | ||||||
|    Return a new tuple object of size *n*, or *NULL* on failure. The tuple values |  | ||||||
|    are initialized to the subsequent *n* C arguments pointing to Python objects. |  | ||||||
|    ``PyTuple_Pack(2, a, b)`` is equivalent to ``Py_BuildValue("(OO)", a, b)``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PyTuple_Size(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Take a pointer to a tuple object, and return the size of that tuple. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: Py_ssize_t PyTuple_GET_SIZE(PyObject *p) |  | ||||||
| 
 |  | ||||||
|    Return the size of the tuple *p*, which must be non-*NULL* and point to a tuple; |  | ||||||
|    no error checking is performed. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyTuple_GetItem(PyObject *p, Py_ssize_t pos) |  | ||||||
| 
 |  | ||||||
|    Return the object at position *pos* in the tuple pointed to by *p*.  If *pos* is |  | ||||||
|    out of bounds, return *NULL* and sets an :exc:`IndexError` exception. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyTuple_GET_ITEM(PyObject *p, Py_ssize_t pos) |  | ||||||
| 
 |  | ||||||
|    Like :c:func:`PyTuple_GetItem`, but does no checking of its arguments. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyTuple_GetSlice(PyObject *p, Py_ssize_t low, Py_ssize_t high) |  | ||||||
| 
 |  | ||||||
|    Take a slice of the tuple pointed to by *p* from *low* to *high* and return it |  | ||||||
|    as a new tuple. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyTuple_SetItem(PyObject *p, Py_ssize_t pos, PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Insert a reference to object *o* at position *pos* of the tuple pointed to by |  | ||||||
|    *p*. Return ``0`` on success. |  | ||||||
| 
 |  | ||||||
|    .. note:: |  | ||||||
| 
 |  | ||||||
|       This function "steals" a reference to *o*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyTuple_SET_ITEM(PyObject *p, Py_ssize_t pos, PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Like :c:func:`PyTuple_SetItem`, but does no error checking, and should *only* be |  | ||||||
|    used to fill in brand new tuples. |  | ||||||
| 
 |  | ||||||
|    .. note:: |  | ||||||
| 
 |  | ||||||
|       This function "steals" a reference to *o*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int _PyTuple_Resize(PyObject **p, Py_ssize_t newsize) |  | ||||||
| 
 |  | ||||||
|    Can be used to resize a tuple.  *newsize* will be the new length of the tuple. |  | ||||||
|    Because tuples are *supposed* to be immutable, this should only be used if there |  | ||||||
|    is only one reference to the object.  Do *not* use this if the tuple may already |  | ||||||
|    be known to some other part of the code.  The tuple will always grow or shrink |  | ||||||
|    at the end.  Think of this as destroying the old tuple and creating a new one, |  | ||||||
|    only more efficiently.  Returns ``0`` on success. Client code should never |  | ||||||
|    assume that the resulting value of ``*p`` will be the same as before calling |  | ||||||
|    this function. If the object referenced by ``*p`` is replaced, the original |  | ||||||
|    ``*p`` is destroyed.  On failure, returns ``-1`` and sets ``*p`` to *NULL*, and |  | ||||||
|    raises :exc:`MemoryError` or :exc:`SystemError`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyTuple_ClearFreeList() |  | ||||||
| 
 |  | ||||||
|    Clear the free list. Return the total number of freed items. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Struct Sequence Objects |  | ||||||
| ----------------------- |  | ||||||
| 
 |  | ||||||
| Struct sequence objects are the C equivalent of :func:`~collections.namedtuple` |  | ||||||
| objects, i.e. a sequence whose items can also be accessed through attributes. |  | ||||||
| To create a struct sequence, you first have to create a specific struct sequence |  | ||||||
| type. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyTypeObject* PyStructSequence_NewType(PyStructSequence_Desc *desc) |  | ||||||
| 
 |  | ||||||
|    Create a new struct sequence type from the data in *desc*, described below. Instances |  | ||||||
|    of the resulting type can be created with :c:func:`PyStructSequence_New`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyStructSequence_InitType(PyTypeObject *type, PyStructSequence_Desc *desc) |  | ||||||
| 
 |  | ||||||
|    Initializes a struct sequence type *type* from *desc* in place. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyStructSequence_InitType2(PyTypeObject *type, PyStructSequence_Desc *desc) |  | ||||||
| 
 |  | ||||||
|    The same as ``PyStructSequence_InitType``, but returns ``0`` on success and ``-1`` on |  | ||||||
|    failure. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.4 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyStructSequence_Desc |  | ||||||
| 
 |  | ||||||
|    Contains the meta information of a struct sequence type to create. |  | ||||||
| 
 |  | ||||||
|    +-------------------+------------------------------+------------------------------------+ |  | ||||||
|    | Field             | C Type                       | Meaning                            | |  | ||||||
|    +===================+==============================+====================================+ |  | ||||||
|    | ``name``          | ``char *``                   | name of the struct sequence type   | |  | ||||||
|    +-------------------+------------------------------+------------------------------------+ |  | ||||||
|    | ``doc``           | ``char *``                   | pointer to docstring for the type  | |  | ||||||
|    |                   |                              | or NULL to omit                    | |  | ||||||
|    +-------------------+------------------------------+------------------------------------+ |  | ||||||
|    | ``fields``        | ``PyStructSequence_Field *`` | pointer to *NULL*-terminated array | |  | ||||||
|    |                   |                              | with field names of the new type   | |  | ||||||
|    +-------------------+------------------------------+------------------------------------+ |  | ||||||
|    | ``n_in_sequence`` | ``int``                      | number of fields visible to the    | |  | ||||||
|    |                   |                              | Python side (if used as tuple)     | |  | ||||||
|    +-------------------+------------------------------+------------------------------------+ |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyStructSequence_Field |  | ||||||
| 
 |  | ||||||
|    Describes a field of a struct sequence. As a struct sequence is modeled as a |  | ||||||
|    tuple, all fields are typed as :c:type:`PyObject\*`.  The index in the |  | ||||||
|    :attr:`fields` array of the :c:type:`PyStructSequence_Desc` determines which |  | ||||||
|    field of the struct sequence is described. |  | ||||||
| 
 |  | ||||||
|    +-----------+---------------+--------------------------------------+ |  | ||||||
|    | Field     | C Type        | Meaning                              | |  | ||||||
|    +===========+===============+======================================+ |  | ||||||
|    | ``name``  | ``char *``    | name for the field or *NULL* to end  | |  | ||||||
|    |           |               | the list of named fields, set to     | |  | ||||||
|    |           |               | PyStructSequence_UnnamedField to     | |  | ||||||
|    |           |               | leave unnamed                        | |  | ||||||
|    +-----------+---------------+--------------------------------------+ |  | ||||||
|    | ``doc``   | ``char *``    | field docstring or *NULL* to omit    | |  | ||||||
|    +-----------+---------------+--------------------------------------+ |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: char* PyStructSequence_UnnamedField |  | ||||||
| 
 |  | ||||||
|    Special value for a field name to leave it unnamed. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyStructSequence_New(PyTypeObject *type) |  | ||||||
| 
 |  | ||||||
|    Creates an instance of *type*, which must have been created with |  | ||||||
|    :c:func:`PyStructSequence_NewType`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyStructSequence_GetItem(PyObject *p, Py_ssize_t pos) |  | ||||||
| 
 |  | ||||||
|    Return the object at position *pos* in the struct sequence pointed to by *p*. |  | ||||||
|    No bounds checking is performed. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyStructSequence_GET_ITEM(PyObject *p, Py_ssize_t pos) |  | ||||||
| 
 |  | ||||||
|    Macro equivalent of :c:func:`PyStructSequence_GetItem`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyStructSequence_SetItem(PyObject *p, Py_ssize_t pos, PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Sets the field at index *pos* of the struct sequence *p* to value *o*.  Like |  | ||||||
|    :c:func:`PyTuple_SET_ITEM`, this should only be used to fill in brand new |  | ||||||
|    instances. |  | ||||||
| 
 |  | ||||||
|    .. note:: |  | ||||||
| 
 |  | ||||||
|       This function "steals" a reference to *o*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyStructSequence_SET_ITEM(PyObject *p, Py_ssize_t *pos, PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Macro equivalent of :c:func:`PyStructSequence_SetItem`. |  | ||||||
| 
 |  | ||||||
|    .. note:: |  | ||||||
| 
 |  | ||||||
|       This function "steals" a reference to *o*. |  | ||||||
							
								
								
									
										118
									
								
								third_party/python/Doc/c-api/type.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										118
									
								
								third_party/python/Doc/c-api/type.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,118 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _typeobjects: |  | ||||||
| 
 |  | ||||||
| Type Objects |  | ||||||
| ------------ |  | ||||||
| 
 |  | ||||||
| .. index:: object: type |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyTypeObject |  | ||||||
| 
 |  | ||||||
|    The C structure of the objects used to describe built-in types. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: PyObject* PyType_Type |  | ||||||
| 
 |  | ||||||
|    This is the type object for type objects; it is the same object as |  | ||||||
|    :class:`type` in the Python layer. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyType_Check(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return true if the object *o* is a type object, including instances of types |  | ||||||
|    derived from the standard type object.  Return false in all other cases. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyType_CheckExact(PyObject *o) |  | ||||||
| 
 |  | ||||||
|    Return true if the object *o* is a type object, but not a subtype of the |  | ||||||
|    standard type object.  Return false in all other cases. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: unsigned int PyType_ClearCache() |  | ||||||
| 
 |  | ||||||
|    Clear the internal lookup cache. Return the current version tag. |  | ||||||
| 
 |  | ||||||
| .. c:function:: unsigned long PyType_GetFlags(PyTypeObject* type) |  | ||||||
| 
 |  | ||||||
|    Return the :c:member:`~PyTypeObject.tp_flags` member of *type*. This function is primarily |  | ||||||
|    meant for use with `Py_LIMITED_API`; the individual flag bits are |  | ||||||
|    guaranteed to be stable across Python releases, but access to |  | ||||||
|    :c:member:`~PyTypeObject.tp_flags` itself is not part of the limited API. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.2 |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.4 |  | ||||||
|       The return type is now ``unsigned long`` rather than ``long``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void PyType_Modified(PyTypeObject *type) |  | ||||||
| 
 |  | ||||||
|    Invalidate the internal lookup cache for the type and all of its |  | ||||||
|    subtypes.  This function must be called after any manual |  | ||||||
|    modification of the attributes or base classes of the type. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyType_HasFeature(PyTypeObject *o, int feature) |  | ||||||
| 
 |  | ||||||
|    Return true if the type object *o* sets the feature *feature*.  Type features |  | ||||||
|    are denoted by single bit flags. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyType_IS_GC(PyTypeObject *o) |  | ||||||
| 
 |  | ||||||
|    Return true if the type object includes support for the cycle detector; this |  | ||||||
|    tests the type flag :const:`Py_TPFLAGS_HAVE_GC`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyType_IsSubtype(PyTypeObject *a, PyTypeObject *b) |  | ||||||
| 
 |  | ||||||
|    Return true if *a* is a subtype of *b*. |  | ||||||
| 
 |  | ||||||
|    This function only checks for actual subtypes, which means that |  | ||||||
|    :meth:`~class.__subclasscheck__` is not called on *b*.  Call |  | ||||||
|    :c:func:`PyObject_IsSubclass` to do the same check that :func:`issubclass` |  | ||||||
|    would do. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyType_GenericAlloc(PyTypeObject *type, Py_ssize_t nitems) |  | ||||||
| 
 |  | ||||||
|    Generic handler for the :c:member:`~PyTypeObject.tp_alloc` slot of a type object.  Use |  | ||||||
|    Python's default memory allocation mechanism to allocate a new instance and |  | ||||||
|    initialize all its contents to *NULL*. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyType_GenericNew(PyTypeObject *type, PyObject *args, PyObject *kwds) |  | ||||||
| 
 |  | ||||||
|    Generic handler for the :c:member:`~PyTypeObject.tp_new` slot of a type object.  Create a |  | ||||||
|    new instance using the type's :c:member:`~PyTypeObject.tp_alloc` slot. |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyType_Ready(PyTypeObject *type) |  | ||||||
| 
 |  | ||||||
|    Finalize a type object.  This should be called on all type objects to finish |  | ||||||
|    their initialization.  This function is responsible for adding inherited slots |  | ||||||
|    from a type's base class.  Return ``0`` on success, or return ``-1`` and sets an |  | ||||||
|    exception on error. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyType_FromSpec(PyType_Spec *spec) |  | ||||||
| 
 |  | ||||||
|    Creates and returns a heap type object from the *spec* passed to the function. |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyType_FromSpecWithBases(PyType_Spec *spec, PyObject *bases) |  | ||||||
| 
 |  | ||||||
|    Creates and returns a heap type object from the *spec*. In addition to that, |  | ||||||
|    the created heap type contains all types contained by the *bases* tuple as base |  | ||||||
|    types. This allows the caller to reference other heap types as base types. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.3 |  | ||||||
| 
 |  | ||||||
| .. c:function:: void* PyType_GetSlot(PyTypeObject *type, int slot) |  | ||||||
| 
 |  | ||||||
|    Return the function pointer stored in the given slot. If the |  | ||||||
|    result is *NULL*, this indicates that either the slot is *NULL*, |  | ||||||
|    or that the function was called with invalid parameters. |  | ||||||
|    Callers will typically cast the result pointer into the appropriate |  | ||||||
|    function type. |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.4 |  | ||||||
							
								
								
									
										1402
									
								
								third_party/python/Doc/c-api/typeobj.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										1402
									
								
								third_party/python/Doc/c-api/typeobj.rst
									
										
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										1701
									
								
								third_party/python/Doc/c-api/unicode.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										1701
									
								
								third_party/python/Doc/c-api/unicode.rst
									
										
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										21
									
								
								third_party/python/Doc/c-api/utilities.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										21
									
								
								third_party/python/Doc/c-api/utilities.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,21 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _utilities: |  | ||||||
| 
 |  | ||||||
| ********* |  | ||||||
| Utilities |  | ||||||
| ********* |  | ||||||
| 
 |  | ||||||
| The functions in this chapter perform various utility tasks, ranging from |  | ||||||
| helping C code be more portable across platforms, using Python modules from C, |  | ||||||
| and parsing function arguments and constructing Python values from C values. |  | ||||||
| 
 |  | ||||||
| .. toctree:: |  | ||||||
| 
 |  | ||||||
|    sys.rst |  | ||||||
|    import.rst |  | ||||||
|    marshal.rst |  | ||||||
|    arg.rst |  | ||||||
|    conversion.rst |  | ||||||
|    reflection.rst |  | ||||||
|    codec.rst |  | ||||||
							
								
								
									
										390
									
								
								third_party/python/Doc/c-api/veryhigh.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										390
									
								
								third_party/python/Doc/c-api/veryhigh.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,390 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _veryhigh: |  | ||||||
| 
 |  | ||||||
| ************************* |  | ||||||
| The Very High Level Layer |  | ||||||
| ************************* |  | ||||||
| 
 |  | ||||||
| The functions in this chapter will let you execute Python source code given in a |  | ||||||
| file or a buffer, but they will not let you interact in a more detailed way with |  | ||||||
| the interpreter. |  | ||||||
| 
 |  | ||||||
| Several of these functions accept a start symbol from the grammar as a |  | ||||||
| parameter.  The available start symbols are :const:`Py_eval_input`, |  | ||||||
| :const:`Py_file_input`, and :const:`Py_single_input`.  These are described |  | ||||||
| following the functions which accept them as parameters. |  | ||||||
| 
 |  | ||||||
| Note also that several of these functions take :c:type:`FILE\*` parameters.  One |  | ||||||
| particular issue which needs to be handled carefully is that the :c:type:`FILE` |  | ||||||
| structure for different C libraries can be different and incompatible.  Under |  | ||||||
| Windows (at least), it is possible for dynamically linked extensions to actually |  | ||||||
| use different libraries, so care should be taken that :c:type:`FILE\*` parameters |  | ||||||
| are only passed to these functions if it is certain that they were created by |  | ||||||
| the same library that the Python runtime is using. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int Py_Main(int argc, wchar_t **argv) |  | ||||||
| 
 |  | ||||||
|    The main program for the standard interpreter.  This is made available for |  | ||||||
|    programs which embed Python.  The *argc* and *argv* parameters should be |  | ||||||
|    prepared exactly as those which are passed to a C program's :c:func:`main` |  | ||||||
|    function (converted to wchar_t according to the user's locale).  It is |  | ||||||
|    important to note that the argument list may be modified (but the contents of |  | ||||||
|    the strings pointed to by the argument list are not). The return value will |  | ||||||
|    be ``0`` if the interpreter exits normally (i.e., without an exception), |  | ||||||
|    ``1`` if the interpreter exits due to an exception, or ``2`` if the parameter |  | ||||||
|    list does not represent a valid Python command line. |  | ||||||
| 
 |  | ||||||
|    Note that if an otherwise unhandled :exc:`SystemExit` is raised, this |  | ||||||
|    function will not return ``1``, but exit the process, as long as |  | ||||||
|    ``Py_InspectFlag`` is not set. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyRun_AnyFile(FILE *fp, const char *filename) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to :c:func:`PyRun_AnyFileExFlags` below, leaving |  | ||||||
|    *closeit* set to ``0`` and *flags* set to *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyRun_AnyFileFlags(FILE *fp, const char *filename, PyCompilerFlags *flags) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to :c:func:`PyRun_AnyFileExFlags` below, leaving |  | ||||||
|    the *closeit* argument set to ``0``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyRun_AnyFileEx(FILE *fp, const char *filename, int closeit) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to :c:func:`PyRun_AnyFileExFlags` below, leaving |  | ||||||
|    the *flags* argument set to *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyRun_AnyFileExFlags(FILE *fp, const char *filename, int closeit, PyCompilerFlags *flags) |  | ||||||
| 
 |  | ||||||
|    If *fp* refers to a file associated with an interactive device (console or |  | ||||||
|    terminal input or Unix pseudo-terminal), return the value of |  | ||||||
|    :c:func:`PyRun_InteractiveLoop`, otherwise return the result of |  | ||||||
|    :c:func:`PyRun_SimpleFile`.  *filename* is decoded from the filesystem |  | ||||||
|    encoding (:func:`sys.getfilesystemencoding`).  If *filename* is *NULL*, this |  | ||||||
|    function uses ``"???"`` as the filename. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyRun_SimpleString(const char *command) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to :c:func:`PyRun_SimpleStringFlags` below, |  | ||||||
|    leaving the *PyCompilerFlags\** argument set to NULL. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyRun_SimpleStringFlags(const char *command, PyCompilerFlags *flags) |  | ||||||
| 
 |  | ||||||
|    Executes the Python source code from *command* in the :mod:`__main__` module |  | ||||||
|    according to the *flags* argument. If :mod:`__main__` does not already exist, it |  | ||||||
|    is created.  Returns ``0`` on success or ``-1`` if an exception was raised.  If |  | ||||||
|    there was an error, there is no way to get the exception information. For the |  | ||||||
|    meaning of *flags*, see below. |  | ||||||
| 
 |  | ||||||
|    Note that if an otherwise unhandled :exc:`SystemExit` is raised, this |  | ||||||
|    function will not return ``-1``, but exit the process, as long as |  | ||||||
|    ``Py_InspectFlag`` is not set. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyRun_SimpleFile(FILE *fp, const char *filename) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to :c:func:`PyRun_SimpleFileExFlags` below, |  | ||||||
|    leaving *closeit* set to ``0`` and *flags* set to *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyRun_SimpleFileEx(FILE *fp, const char *filename, int closeit) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to :c:func:`PyRun_SimpleFileExFlags` below, |  | ||||||
|    leaving *flags* set to *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyRun_SimpleFileExFlags(FILE *fp, const char *filename, int closeit, PyCompilerFlags *flags) |  | ||||||
| 
 |  | ||||||
|    Similar to :c:func:`PyRun_SimpleStringFlags`, but the Python source code is read |  | ||||||
|    from *fp* instead of an in-memory string. *filename* should be the name of |  | ||||||
|    the file, it is decoded from the filesystem encoding |  | ||||||
|    (:func:`sys.getfilesystemencoding`).  If *closeit* is true, the file is |  | ||||||
|    closed before PyRun_SimpleFileExFlags returns. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyRun_InteractiveOne(FILE *fp, const char *filename) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to :c:func:`PyRun_InteractiveOneFlags` below, |  | ||||||
|    leaving *flags* set to *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyRun_InteractiveOneFlags(FILE *fp, const char *filename, PyCompilerFlags *flags) |  | ||||||
| 
 |  | ||||||
|    Read and execute a single statement from a file associated with an |  | ||||||
|    interactive device according to the *flags* argument.  The user will be |  | ||||||
|    prompted using ``sys.ps1`` and ``sys.ps2``.  *filename* is decoded from the |  | ||||||
|    filesystem encoding (:func:`sys.getfilesystemencoding`). |  | ||||||
| 
 |  | ||||||
|    Returns ``0`` when the input was |  | ||||||
|    executed successfully, ``-1`` if there was an exception, or an error code |  | ||||||
|    from the :file:`errcode.h` include file distributed as part of Python if |  | ||||||
|    there was a parse error.  (Note that :file:`errcode.h` is not included by |  | ||||||
|    :file:`Python.h`, so must be included specifically if needed.) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyRun_InteractiveLoop(FILE *fp, const char *filename) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to :c:func:`PyRun_InteractiveLoopFlags` below, |  | ||||||
|    leaving *flags* set to *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyRun_InteractiveLoopFlags(FILE *fp, const char *filename, PyCompilerFlags *flags) |  | ||||||
| 
 |  | ||||||
|    Read and execute statements from a file associated with an interactive device |  | ||||||
|    until EOF is reached.  The user will be prompted using ``sys.ps1`` and |  | ||||||
|    ``sys.ps2``.  *filename* is decoded from the filesystem encoding |  | ||||||
|    (:func:`sys.getfilesystemencoding`).  Returns ``0`` at EOF or a negative |  | ||||||
|    number upon failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: int (*PyOS_InputHook)(void) |  | ||||||
| 
 |  | ||||||
|    Can be set to point to a function with the prototype |  | ||||||
|    ``int func(void)``.  The function will be called when Python's |  | ||||||
|    interpreter prompt is about to become idle and wait for user input |  | ||||||
|    from the terminal.  The return value is ignored.  Overriding this |  | ||||||
|    hook can be used to integrate the interpreter's prompt with other |  | ||||||
|    event loops, as done in the :file:`Modules/_tkinter.c` in the |  | ||||||
|    Python source code. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: char* (*PyOS_ReadlineFunctionPointer)(FILE *, FILE *, const char *) |  | ||||||
| 
 |  | ||||||
|    Can be set to point to a function with the prototype |  | ||||||
|    ``char *func(FILE *stdin, FILE *stdout, char *prompt)``, |  | ||||||
|    overriding the default function used to read a single line of input |  | ||||||
|    at the interpreter's prompt.  The function is expected to output |  | ||||||
|    the string *prompt* if it's not *NULL*, and then read a line of |  | ||||||
|    input from the provided standard input file, returning the |  | ||||||
|    resulting string.  For example, The :mod:`readline` module sets |  | ||||||
|    this hook to provide line-editing and tab-completion features. |  | ||||||
| 
 |  | ||||||
|    The result must be a string allocated by :c:func:`PyMem_RawMalloc` or |  | ||||||
|    :c:func:`PyMem_RawRealloc`, or *NULL* if an error occurred. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.4 |  | ||||||
|       The result must be allocated by :c:func:`PyMem_RawMalloc` or |  | ||||||
|       :c:func:`PyMem_RawRealloc`, instead of being allocated by |  | ||||||
|       :c:func:`PyMem_Malloc` or :c:func:`PyMem_Realloc`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: struct _node* PyParser_SimpleParseString(const char *str, int start) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to |  | ||||||
|    :c:func:`PyParser_SimpleParseStringFlagsFilename` below, leaving  *filename* set |  | ||||||
|    to *NULL* and *flags* set to ``0``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: struct _node* PyParser_SimpleParseStringFlags( const char *str, int start, int flags) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to |  | ||||||
|    :c:func:`PyParser_SimpleParseStringFlagsFilename` below, leaving  *filename* set |  | ||||||
|    to *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: struct _node* PyParser_SimpleParseStringFlagsFilename( const char *str, const char *filename, int start, int flags) |  | ||||||
| 
 |  | ||||||
|    Parse Python source code from *str* using the start token *start* according to |  | ||||||
|    the *flags* argument.  The result can be used to create a code object which can |  | ||||||
|    be evaluated efficiently. This is useful if a code fragment must be evaluated |  | ||||||
|    many times. *filename* is decoded from the filesystem encoding |  | ||||||
|    (:func:`sys.getfilesystemencoding`). |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: struct _node* PyParser_SimpleParseFile(FILE *fp, const char *filename, int start) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to :c:func:`PyParser_SimpleParseFileFlags` below, |  | ||||||
|    leaving *flags* set to ``0``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: struct _node* PyParser_SimpleParseFileFlags(FILE *fp, const char *filename, int start, int flags) |  | ||||||
| 
 |  | ||||||
|    Similar to :c:func:`PyParser_SimpleParseStringFlagsFilename`, but the Python |  | ||||||
|    source code is read from *fp* instead of an in-memory string. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyRun_String(const char *str, int start, PyObject *globals, PyObject *locals) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to :c:func:`PyRun_StringFlags` below, leaving |  | ||||||
|    *flags* set to *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyRun_StringFlags(const char *str, int start, PyObject *globals, PyObject *locals, PyCompilerFlags *flags) |  | ||||||
| 
 |  | ||||||
|    Execute Python source code from *str* in the context specified by the |  | ||||||
|    objects *globals* and *locals* with the compiler flags specified by |  | ||||||
|    *flags*.  *globals* must be a dictionary; *locals* can be any object |  | ||||||
|    that implements the mapping protocol.  The parameter *start* specifies |  | ||||||
|    the start token that should be used to parse the source code. |  | ||||||
| 
 |  | ||||||
|    Returns the result of executing the code as a Python object, or *NULL* if an |  | ||||||
|    exception was raised. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyRun_File(FILE *fp, const char *filename, int start, PyObject *globals, PyObject *locals) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to :c:func:`PyRun_FileExFlags` below, leaving |  | ||||||
|    *closeit* set to ``0`` and *flags* set to *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyRun_FileEx(FILE *fp, const char *filename, int start, PyObject *globals, PyObject *locals, int closeit) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to :c:func:`PyRun_FileExFlags` below, leaving |  | ||||||
|    *flags* set to *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyRun_FileFlags(FILE *fp, const char *filename, int start, PyObject *globals, PyObject *locals, PyCompilerFlags *flags) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to :c:func:`PyRun_FileExFlags` below, leaving |  | ||||||
|    *closeit* set to ``0``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyRun_FileExFlags(FILE *fp, const char *filename, int start, PyObject *globals, PyObject *locals, int closeit, PyCompilerFlags *flags) |  | ||||||
| 
 |  | ||||||
|    Similar to :c:func:`PyRun_StringFlags`, but the Python source code is read from |  | ||||||
|    *fp* instead of an in-memory string. *filename* should be the name of the file, |  | ||||||
|    it is decoded from the filesystem encoding (:func:`sys.getfilesystemencoding`). |  | ||||||
|    If *closeit* is true, the file is closed before :c:func:`PyRun_FileExFlags` |  | ||||||
|    returns. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* Py_CompileString(const char *str, const char *filename, int start) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to :c:func:`Py_CompileStringFlags` below, leaving |  | ||||||
|    *flags* set to *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* Py_CompileStringFlags(const char *str, const char *filename, int start, PyCompilerFlags *flags) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to :c:func:`Py_CompileStringExFlags` below, with |  | ||||||
|    *optimize* set to ``-1``. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* Py_CompileStringObject(const char *str, PyObject *filename, int start, PyCompilerFlags *flags, int optimize) |  | ||||||
| 
 |  | ||||||
|    Parse and compile the Python source code in *str*, returning the resulting code |  | ||||||
|    object.  The start token is given by *start*; this can be used to constrain the |  | ||||||
|    code which can be compiled and should be :const:`Py_eval_input`, |  | ||||||
|    :const:`Py_file_input`, or :const:`Py_single_input`.  The filename specified by |  | ||||||
|    *filename* is used to construct the code object and may appear in tracebacks or |  | ||||||
|    :exc:`SyntaxError` exception messages.  This returns *NULL* if the code |  | ||||||
|    cannot be parsed or compiled. |  | ||||||
| 
 |  | ||||||
|    The integer *optimize* specifies the optimization level of the compiler; a |  | ||||||
|    value of ``-1`` selects the optimization level of the interpreter as given by |  | ||||||
|    :option:`-O` options.  Explicit levels are ``0`` (no optimization; |  | ||||||
|    ``__debug__`` is true), ``1`` (asserts are removed, ``__debug__`` is false) |  | ||||||
|    or ``2`` (docstrings are removed too). |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.4 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* Py_CompileStringExFlags(const char *str, const char *filename, int start, PyCompilerFlags *flags, int optimize) |  | ||||||
| 
 |  | ||||||
|    Like :c:func:`Py_CompileStringObject`, but *filename* is a byte string |  | ||||||
|    decoded from the filesystem encoding (:func:`os.fsdecode`). |  | ||||||
| 
 |  | ||||||
|    .. versionadded:: 3.2 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyEval_EvalCode(PyObject *co, PyObject *globals, PyObject *locals) |  | ||||||
| 
 |  | ||||||
|    This is a simplified interface to :c:func:`PyEval_EvalCodeEx`, with just |  | ||||||
|    the code object, and global and local variables.  The other arguments are |  | ||||||
|    set to *NULL*. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyEval_EvalCodeEx(PyObject *co, PyObject *globals, PyObject *locals, PyObject **args, int argcount, PyObject **kws, int kwcount, PyObject **defs, int defcount, PyObject *kwdefs, PyObject *closure) |  | ||||||
| 
 |  | ||||||
|    Evaluate a precompiled code object, given a particular environment for its |  | ||||||
|    evaluation.  This environment consists of a dictionary of global variables, |  | ||||||
|    a mapping object of local variables, arrays of arguments, keywords and |  | ||||||
|    defaults, a dictionary of default values for :ref:`keyword-only |  | ||||||
|    <keyword-only_parameter>` arguments and a closure tuple of cells. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: PyFrameObject |  | ||||||
| 
 |  | ||||||
|    The C structure of the objects used to describe frame objects. The |  | ||||||
|    fields of this type are subject to change at any time. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyEval_EvalFrame(PyFrameObject *f) |  | ||||||
| 
 |  | ||||||
|    Evaluate an execution frame.  This is a simplified interface to |  | ||||||
|    :c:func:`PyEval_EvalFrameEx`, for backward compatibility. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyEval_EvalFrameEx(PyFrameObject *f, int throwflag) |  | ||||||
| 
 |  | ||||||
|    This is the main, unvarnished function of Python interpretation.  It is |  | ||||||
|    literally 2000 lines long.  The code object associated with the execution |  | ||||||
|    frame *f* is executed, interpreting bytecode and executing calls as needed. |  | ||||||
|    The additional *throwflag* parameter can mostly be ignored - if true, then |  | ||||||
|    it causes an exception to immediately be thrown; this is used for the |  | ||||||
|    :meth:`~generator.throw` methods of generator objects. |  | ||||||
| 
 |  | ||||||
|    .. versionchanged:: 3.4 |  | ||||||
|       This function now includes a debug assertion to help ensure that it |  | ||||||
|       does not silently discard an active exception. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyEval_MergeCompilerFlags(PyCompilerFlags *cf) |  | ||||||
| 
 |  | ||||||
|    This function changes the flags of the current evaluation frame, and returns |  | ||||||
|    true on success, false on failure. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: int Py_eval_input |  | ||||||
| 
 |  | ||||||
|    .. index:: single: Py_CompileString() |  | ||||||
| 
 |  | ||||||
|    The start symbol from the Python grammar for isolated expressions; for use with |  | ||||||
|    :c:func:`Py_CompileString`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: int Py_file_input |  | ||||||
| 
 |  | ||||||
|    .. index:: single: Py_CompileString() |  | ||||||
| 
 |  | ||||||
|    The start symbol from the Python grammar for sequences of statements as read |  | ||||||
|    from a file or other source; for use with :c:func:`Py_CompileString`.  This is |  | ||||||
|    the symbol to use when compiling arbitrarily long Python source code. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: int Py_single_input |  | ||||||
| 
 |  | ||||||
|    .. index:: single: Py_CompileString() |  | ||||||
| 
 |  | ||||||
|    The start symbol from the Python grammar for a single statement; for use with |  | ||||||
|    :c:func:`Py_CompileString`. This is the symbol used for the interactive |  | ||||||
|    interpreter loop. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:type:: struct PyCompilerFlags |  | ||||||
| 
 |  | ||||||
|    This is the structure used to hold compiler flags.  In cases where code is only |  | ||||||
|    being compiled, it is passed as ``int flags``, and in cases where code is being |  | ||||||
|    executed, it is passed as ``PyCompilerFlags *flags``.  In this case, ``from |  | ||||||
|    __future__ import`` can modify *flags*. |  | ||||||
| 
 |  | ||||||
|    Whenever ``PyCompilerFlags *flags`` is *NULL*, :attr:`cf_flags` is treated as |  | ||||||
|    equal to ``0``, and any modification due to ``from __future__ import`` is |  | ||||||
|    discarded.  :: |  | ||||||
| 
 |  | ||||||
|       struct PyCompilerFlags { |  | ||||||
|           int cf_flags; |  | ||||||
|       } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:var:: int CO_FUTURE_DIVISION |  | ||||||
| 
 |  | ||||||
|    This bit can be set in *flags* to cause division operator ``/`` to be |  | ||||||
|    interpreted as "true division" according to :pep:`238`. |  | ||||||
							
								
								
									
										69
									
								
								third_party/python/Doc/c-api/weakref.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										69
									
								
								third_party/python/Doc/c-api/weakref.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,69 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _weakrefobjects: |  | ||||||
| 
 |  | ||||||
| Weak Reference Objects |  | ||||||
| ---------------------- |  | ||||||
| 
 |  | ||||||
| Python supports *weak references* as first-class objects.  There are two |  | ||||||
| specific object types which directly implement weak references.  The first is a |  | ||||||
| simple reference object, and the second acts as a proxy for the original object |  | ||||||
| as much as it can. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyWeakref_Check(ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob* is either a reference or proxy object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyWeakref_CheckRef(ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob* is a reference object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: int PyWeakref_CheckProxy(ob) |  | ||||||
| 
 |  | ||||||
|    Return true if *ob* is a proxy object. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyWeakref_NewRef(PyObject *ob, PyObject *callback) |  | ||||||
| 
 |  | ||||||
|    Return a weak reference object for the object *ob*.  This will always return |  | ||||||
|    a new reference, but is not guaranteed to create a new object; an existing |  | ||||||
|    reference object may be returned.  The second parameter, *callback*, can be a |  | ||||||
|    callable object that receives notification when *ob* is garbage collected; it |  | ||||||
|    should accept a single parameter, which will be the weak reference object |  | ||||||
|    itself. *callback* may also be ``None`` or *NULL*.  If *ob* is not a |  | ||||||
|    weakly-referencable object, or if *callback* is not callable, ``None``, or |  | ||||||
|    *NULL*, this will return *NULL* and raise :exc:`TypeError`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyWeakref_NewProxy(PyObject *ob, PyObject *callback) |  | ||||||
| 
 |  | ||||||
|    Return a weak reference proxy object for the object *ob*.  This will always |  | ||||||
|    return a new reference, but is not guaranteed to create a new object; an |  | ||||||
|    existing proxy object may be returned.  The second parameter, *callback*, can |  | ||||||
|    be a callable object that receives notification when *ob* is garbage |  | ||||||
|    collected; it should accept a single parameter, which will be the weak |  | ||||||
|    reference object itself. *callback* may also be ``None`` or *NULL*.  If *ob* |  | ||||||
|    is not a weakly-referencable object, or if *callback* is not callable, |  | ||||||
|    ``None``, or *NULL*, this will return *NULL* and raise :exc:`TypeError`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyWeakref_GetObject(PyObject *ref) |  | ||||||
| 
 |  | ||||||
|    Return the referenced object from a weak reference, *ref*.  If the referent is |  | ||||||
|    no longer live, returns :const:`Py_None`. |  | ||||||
| 
 |  | ||||||
|    .. note:: |  | ||||||
| 
 |  | ||||||
|       This function returns a **borrowed reference** to the referenced object. |  | ||||||
|       This means that you should always call :c:func:`Py_INCREF` on the object |  | ||||||
|       except if you know that it cannot be destroyed while you are still |  | ||||||
|       using it. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyWeakref_GET_OBJECT(PyObject *ref) |  | ||||||
| 
 |  | ||||||
|    Similar to :c:func:`PyWeakref_GetObject`, but implemented as a macro that does no |  | ||||||
|    error checking. |  | ||||||
							
								
								
									
										206
									
								
								third_party/python/Doc/conf.py
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										206
									
								
								third_party/python/Doc/conf.py
									
										
									
									
										vendored
									
									
								
							|  | @ -1,206 +0,0 @@ | ||||||
| # |  | ||||||
| # Python documentation build configuration file |  | ||||||
| # |  | ||||||
| # This file is execfile()d with the current directory set to its containing dir. |  | ||||||
| # |  | ||||||
| # The contents of this file are pickled, so don't put values in the namespace |  | ||||||
| # that aren't pickleable (module imports are okay, they're removed automatically). |  | ||||||
| 
 |  | ||||||
| import sys, os, time |  | ||||||
| sys.path.append(os.path.abspath('tools/extensions')) |  | ||||||
| 
 |  | ||||||
| # General configuration |  | ||||||
| # --------------------- |  | ||||||
| 
 |  | ||||||
| extensions = ['sphinx.ext.coverage', 'sphinx.ext.doctest', |  | ||||||
|               'pyspecific', 'c_annotations', 'escape4chm'] |  | ||||||
| 
 |  | ||||||
| # General substitutions. |  | ||||||
| project = 'Python' |  | ||||||
| copyright = '2001-%s, Python Software Foundation' % time.strftime('%Y') |  | ||||||
| 
 |  | ||||||
| # We look for the Include/patchlevel.h file in the current Python source tree |  | ||||||
| # and replace the values accordingly. |  | ||||||
| import patchlevel |  | ||||||
| version, release = patchlevel.get_version_info() |  | ||||||
| 
 |  | ||||||
| # There are two options for replacing |today|: either, you set today to some |  | ||||||
| # non-false value, then it is used: |  | ||||||
| today = '' |  | ||||||
| # Else, today_fmt is used as the format for a strftime call. |  | ||||||
| today_fmt = '%B %d, %Y' |  | ||||||
| 
 |  | ||||||
| # By default, highlight as Python 3. |  | ||||||
| highlight_language = 'python3' |  | ||||||
| 
 |  | ||||||
| # Require Sphinx 1.2 for build. |  | ||||||
| needs_sphinx = '1.2' |  | ||||||
| 
 |  | ||||||
| # Ignore any .rst files in the venv/ directory. |  | ||||||
| venvdir = os.getenv('VENVDIR', 'venv') |  | ||||||
| exclude_patterns = [venvdir+'/*', 'README.rst'] |  | ||||||
| 
 |  | ||||||
| # Avoid a warning with Sphinx >= 2.0 |  | ||||||
| master_doc = 'contents' |  | ||||||
| 
 |  | ||||||
| # Options for HTML output |  | ||||||
| # ----------------------- |  | ||||||
| 
 |  | ||||||
| # Use our custom theme. |  | ||||||
| html_theme = 'pydoctheme' |  | ||||||
| html_theme_path = ['tools'] |  | ||||||
| html_theme_options = {'collapsiblesidebar': True} |  | ||||||
| 
 |  | ||||||
| # Short title used e.g. for <title> HTML tags. |  | ||||||
| html_short_title = '%s Documentation' % release |  | ||||||
| 
 |  | ||||||
| # If not '', a 'Last updated on:' timestamp is inserted at every page bottom, |  | ||||||
| # using the given strftime format. |  | ||||||
| html_last_updated_fmt = '%b %d, %Y' |  | ||||||
| 
 |  | ||||||
| # Path to find HTML templates. |  | ||||||
| templates_path = ['tools/templates'] |  | ||||||
| 
 |  | ||||||
| # Custom sidebar templates, filenames relative to this file. |  | ||||||
| html_sidebars = { |  | ||||||
|     # Defaults taken from http://www.sphinx-doc.org/en/stable/config.html#confval-html_sidebars |  | ||||||
|     # Removes the quick search block |  | ||||||
|     '**': ['localtoc.html', 'relations.html', 'customsourcelink.html'], |  | ||||||
|     'index': ['indexsidebar.html'], |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| # Additional templates that should be rendered to pages. |  | ||||||
| html_additional_pages = { |  | ||||||
|     'download': 'download.html', |  | ||||||
|     'index': 'indexcontent.html', |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| # Output an OpenSearch description file. |  | ||||||
| html_use_opensearch = 'https://docs.python.org/' + version |  | ||||||
| 
 |  | ||||||
| # Additional static files. |  | ||||||
| html_static_path = ['tools/static'] |  | ||||||
| 
 |  | ||||||
| # Output file base name for HTML help builder. |  | ||||||
| htmlhelp_basename = 'python' + release.replace('.', '') |  | ||||||
| 
 |  | ||||||
| # Split the index |  | ||||||
| html_split_index = True |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| # Options for LaTeX output |  | ||||||
| # ------------------------ |  | ||||||
| 
 |  | ||||||
| latex_engine = 'xelatex' |  | ||||||
| 
 |  | ||||||
| # Get LaTeX to handle Unicode correctly |  | ||||||
| latex_elements = { |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| # Additional stuff for the LaTeX preamble. |  | ||||||
| latex_elements['preamble'] = r''' |  | ||||||
| \authoraddress{ |  | ||||||
|   \sphinxstrong{Python Software Foundation}\\ |  | ||||||
|   Email: \sphinxemail{docs@python.org} |  | ||||||
| } |  | ||||||
| \let\Verbatim=\OriginalVerbatim |  | ||||||
| \let\endVerbatim=\endOriginalVerbatim |  | ||||||
| ''' |  | ||||||
| 
 |  | ||||||
| # The paper size ('letter' or 'a4'). |  | ||||||
| latex_elements['papersize'] = 'a4' |  | ||||||
| 
 |  | ||||||
| # The font size ('10pt', '11pt' or '12pt'). |  | ||||||
| latex_elements['pointsize'] = '10pt' |  | ||||||
| 
 |  | ||||||
| # Grouping the document tree into LaTeX files. List of tuples |  | ||||||
| # (source start file, target name, title, author, document class [howto/manual]). |  | ||||||
| _stdauthor = r'Guido van Rossum\\and the Python development team' |  | ||||||
| latex_documents = [ |  | ||||||
|     ('c-api/index', 'c-api.tex', |  | ||||||
|      'The Python/C API', _stdauthor, 'manual'), |  | ||||||
|     ('distributing/index', 'distributing.tex', |  | ||||||
|      'Distributing Python Modules', _stdauthor, 'manual'), |  | ||||||
|     ('extending/index', 'extending.tex', |  | ||||||
|      'Extending and Embedding Python', _stdauthor, 'manual'), |  | ||||||
|     ('installing/index', 'installing.tex', |  | ||||||
|      'Installing Python Modules', _stdauthor, 'manual'), |  | ||||||
|     ('library/index', 'library.tex', |  | ||||||
|      'The Python Library Reference', _stdauthor, 'manual'), |  | ||||||
|     ('reference/index', 'reference.tex', |  | ||||||
|      'The Python Language Reference', _stdauthor, 'manual'), |  | ||||||
|     ('tutorial/index', 'tutorial.tex', |  | ||||||
|      'Python Tutorial', _stdauthor, 'manual'), |  | ||||||
|     ('using/index', 'using.tex', |  | ||||||
|      'Python Setup and Usage', _stdauthor, 'manual'), |  | ||||||
|     ('faq/index', 'faq.tex', |  | ||||||
|      'Python Frequently Asked Questions', _stdauthor, 'manual'), |  | ||||||
|     ('whatsnew/' + version, 'whatsnew.tex', |  | ||||||
|      'What\'s New in Python', 'A. M. Kuchling', 'howto'), |  | ||||||
| ] |  | ||||||
| # Collect all HOWTOs individually |  | ||||||
| latex_documents.extend(('howto/' + fn[:-4], 'howto-' + fn[:-4] + '.tex', |  | ||||||
|                         '', _stdauthor, 'howto') |  | ||||||
|                        for fn in os.listdir('howto') |  | ||||||
|                        if fn.endswith('.rst') and fn != 'index.rst') |  | ||||||
| 
 |  | ||||||
| # Documents to append as an appendix to all manuals. |  | ||||||
| latex_appendices = ['glossary', 'about', 'license', 'copyright'] |  | ||||||
| 
 |  | ||||||
| # Options for Epub output |  | ||||||
| # ----------------------- |  | ||||||
| 
 |  | ||||||
| epub_author = 'Python Documentation Authors' |  | ||||||
| epub_publisher = 'Python Software Foundation' |  | ||||||
| 
 |  | ||||||
| # Options for the coverage checker |  | ||||||
| # -------------------------------- |  | ||||||
| 
 |  | ||||||
| # The coverage checker will ignore all modules/functions/classes whose names |  | ||||||
| # match any of the following regexes (using re.match). |  | ||||||
| coverage_ignore_modules = [ |  | ||||||
|     r'[T|t][k|K]', |  | ||||||
|     r'Tix', |  | ||||||
|     r'distutils.*', |  | ||||||
| ] |  | ||||||
| 
 |  | ||||||
| coverage_ignore_functions = [ |  | ||||||
|     'test($|_)', |  | ||||||
| ] |  | ||||||
| 
 |  | ||||||
| coverage_ignore_classes = [ |  | ||||||
| ] |  | ||||||
| 
 |  | ||||||
| # Glob patterns for C source files for C API coverage, relative to this directory. |  | ||||||
| coverage_c_path = [ |  | ||||||
|     '../Include/*.h', |  | ||||||
| ] |  | ||||||
| 
 |  | ||||||
| # Regexes to find C items in the source files. |  | ||||||
| coverage_c_regexes = { |  | ||||||
|     'cfunction': (r'^PyAPI_FUNC\(.*\)\s+([^_][\w_]+)'), |  | ||||||
|     'data': (r'^PyAPI_DATA\(.*\)\s+([^_][\w_]+)'), |  | ||||||
|     'macro': (r'^#define ([^_][\w_]+)\(.*\)[\s|\\]'), |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| # The coverage checker will ignore all C items whose names match these regexes |  | ||||||
| # (using re.match) -- the keys must be the same as in coverage_c_regexes. |  | ||||||
| coverage_ignore_c_items = { |  | ||||||
| #    'cfunction': [...] |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| # Options for the link checker |  | ||||||
| # ---------------------------- |  | ||||||
| 
 |  | ||||||
| # Ignore certain URLs. |  | ||||||
| linkcheck_ignore = [r'https://bugs.python.org/(issue)?\d+', |  | ||||||
|                     # Ignore PEPs for now, they all have permanent redirects. |  | ||||||
|                     r'http://www.python.org/dev/peps/pep-\d+'] |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| # Options for extensions |  | ||||||
| # ---------------------- |  | ||||||
| 
 |  | ||||||
| # Relative filename of the reference count data file. |  | ||||||
| refcount_file = 'data/refcounts.dat' |  | ||||||
							
								
								
									
										31
									
								
								third_party/python/Doc/contents.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										31
									
								
								third_party/python/Doc/contents.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,31 +0,0 @@ | ||||||
| %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% |  | ||||||
|  Python Documentation contents |  | ||||||
| %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% |  | ||||||
| 
 |  | ||||||
| .. toctree:: |  | ||||||
| 
 |  | ||||||
|    whatsnew/index.rst |  | ||||||
|    tutorial/index.rst |  | ||||||
|    using/index.rst |  | ||||||
|    reference/index.rst |  | ||||||
|    library/index.rst |  | ||||||
|    extending/index.rst |  | ||||||
|    c-api/index.rst |  | ||||||
|    distributing/index.rst |  | ||||||
|    installing/index.rst |  | ||||||
|    howto/index.rst |  | ||||||
|    faq/index.rst |  | ||||||
|    glossary.rst |  | ||||||
| 
 |  | ||||||
|    about.rst |  | ||||||
|    bugs.rst |  | ||||||
|    copyright.rst |  | ||||||
|    license.rst |  | ||||||
| 
 |  | ||||||
| .. to include legacy packaging docs in build |  | ||||||
| 
 |  | ||||||
| .. toctree:: |  | ||||||
|    :hidden: |  | ||||||
| 
 |  | ||||||
|    distutils/index.rst |  | ||||||
|    install/index.rst |  | ||||||
							
								
								
									
										19
									
								
								third_party/python/Doc/copyright.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										19
									
								
								third_party/python/Doc/copyright.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,19 +0,0 @@ | ||||||
| ********* |  | ||||||
| Copyright |  | ||||||
| ********* |  | ||||||
| 
 |  | ||||||
| Python and this documentation is: |  | ||||||
| 
 |  | ||||||
| Copyright © 2001-2021 Python Software Foundation. All rights reserved. |  | ||||||
| 
 |  | ||||||
| Copyright © 2000 BeOpen.com. All rights reserved. |  | ||||||
| 
 |  | ||||||
| Copyright © 1995-2000 Corporation for National Research Initiatives. All rights |  | ||||||
| reserved. |  | ||||||
| 
 |  | ||||||
| Copyright © 1991-1995 Stichting Mathematisch Centrum. All rights reserved. |  | ||||||
| 
 |  | ||||||
| ------- |  | ||||||
| 
 |  | ||||||
| See :ref:`history-and-license` for complete license and permissions information. |  | ||||||
| 
 |  | ||||||
							
								
								
									
										1881
									
								
								third_party/python/Doc/data/refcounts.dat
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										1881
									
								
								third_party/python/Doc/data/refcounts.dat
									
										
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										170
									
								
								third_party/python/Doc/distributing/index.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										170
									
								
								third_party/python/Doc/distributing/index.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,170 +0,0 @@ | ||||||
| .. _distributing-index: |  | ||||||
| 
 |  | ||||||
| ############################### |  | ||||||
|   Distributing Python Modules |  | ||||||
| ############################### |  | ||||||
| 
 |  | ||||||
| :Email: distutils-sig@python.org |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| As a popular open source development project, Python has an active |  | ||||||
| supporting community of contributors and users that also make their software |  | ||||||
| available for other Python developers to use under open source license terms. |  | ||||||
| 
 |  | ||||||
| This allows Python users to share and collaborate effectively, benefiting |  | ||||||
| from the solutions others have already created to common (and sometimes |  | ||||||
| even rare!) problems, as well as potentially contributing their own |  | ||||||
| solutions to the common pool. |  | ||||||
| 
 |  | ||||||
| This guide covers the distribution part of the process. For a guide to |  | ||||||
| installing other Python projects, refer to the |  | ||||||
| :ref:`installation guide <installing-index>`. |  | ||||||
| 
 |  | ||||||
| .. note:: |  | ||||||
| 
 |  | ||||||
|    For corporate and other institutional users, be aware that many |  | ||||||
|    organisations have their own policies around using and contributing to |  | ||||||
|    open source software. Please take such policies into account when making |  | ||||||
|    use of the distribution and installation tools provided with Python. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Key terms |  | ||||||
| ========= |  | ||||||
| 
 |  | ||||||
| * the `Python Packaging Index <https://pypi.org>`__ is a public |  | ||||||
|   repository of open source licensed packages made available for use by |  | ||||||
|   other Python users |  | ||||||
| * the `Python Packaging Authority |  | ||||||
|   <https://www.pypa.io/>`__ are the group of |  | ||||||
|   developers and documentation authors responsible for the maintenance and |  | ||||||
|   evolution of the standard packaging tools and the associated metadata and |  | ||||||
|   file format standards. They maintain a variety of tools, documentation |  | ||||||
|   and issue trackers on both `GitHub <https://github.com/pypa>`__ and |  | ||||||
|   `BitBucket <https://bitbucket.org/pypa/>`__. |  | ||||||
| * :mod:`distutils` is the original build and distribution system first added |  | ||||||
|   to the Python standard library in 1998. While direct use of :mod:`distutils` |  | ||||||
|   is being phased out, it still laid the foundation for the current packaging |  | ||||||
|   and distribution infrastructure, and it not only remains part of the |  | ||||||
|   standard library, but its name lives on in other ways (such as the name |  | ||||||
|   of the mailing list used to coordinate Python packaging standards |  | ||||||
|   development). |  | ||||||
| * `setuptools`_ is a (largely) drop-in replacement for :mod:`distutils` first |  | ||||||
|   published in 2004. Its most notable addition over the unmodified |  | ||||||
|   :mod:`distutils` tools was the ability to declare dependencies on other |  | ||||||
|   packages. It is currently recommended as a more regularly updated |  | ||||||
|   alternative to :mod:`distutils` that offers consistent support for more |  | ||||||
|   recent packaging standards across a wide range of Python versions. |  | ||||||
| * `wheel`_ (in this context) is a project that adds the ``bdist_wheel`` |  | ||||||
|   command to :mod:`distutils`/`setuptools`_. This produces a cross platform |  | ||||||
|   binary packaging format (called "wheels" or "wheel files" and defined in |  | ||||||
|   :pep:`427`) that allows Python libraries, even those including binary |  | ||||||
|   extensions, to be installed on a system without needing to be built |  | ||||||
|   locally. |  | ||||||
| 
 |  | ||||||
| .. _setuptools: https://setuptools.readthedocs.io/en/latest/ |  | ||||||
| .. _wheel: https://wheel.readthedocs.org |  | ||||||
| 
 |  | ||||||
| Open source licensing and collaboration |  | ||||||
| ======================================= |  | ||||||
| 
 |  | ||||||
| In most parts of the world, software is automatically covered by copyright. |  | ||||||
| This means that other developers require explicit permission to copy, use, |  | ||||||
| modify and redistribute the software. |  | ||||||
| 
 |  | ||||||
| Open source licensing is a way of explicitly granting such permission in a |  | ||||||
| relatively consistent way, allowing developers to share and collaborate |  | ||||||
| efficiently by making common solutions to various problems freely available. |  | ||||||
| This leaves many developers free to spend more time focusing on the problems |  | ||||||
| that are relatively unique to their specific situation. |  | ||||||
| 
 |  | ||||||
| The distribution tools provided with Python are designed to make it |  | ||||||
| reasonably straightforward for developers to make their own contributions |  | ||||||
| back to that common pool of software if they choose to do so. |  | ||||||
| 
 |  | ||||||
| The same distribution tools can also be used to distribute software within |  | ||||||
| an organisation, regardless of whether that software is published as open |  | ||||||
| source software or not. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Installing the tools |  | ||||||
| ==================== |  | ||||||
| 
 |  | ||||||
| The standard library does not include build tools that support modern |  | ||||||
| Python packaging standards, as the core development team has found that it |  | ||||||
| is important to have standard tools that work consistently, even on older |  | ||||||
| versions of Python. |  | ||||||
| 
 |  | ||||||
| The currently recommended build and distribution tools can be installed |  | ||||||
| by invoking the ``pip`` module at the command line:: |  | ||||||
| 
 |  | ||||||
|     python -m pip install setuptools wheel twine |  | ||||||
| 
 |  | ||||||
| .. note:: |  | ||||||
| 
 |  | ||||||
|    For POSIX users (including Mac OS X and Linux users), these instructions |  | ||||||
|    assume the use of a :term:`virtual environment`. |  | ||||||
| 
 |  | ||||||
|    For Windows users, these instructions assume that the option to |  | ||||||
|    adjust the system PATH environment variable was selected when installing |  | ||||||
|    Python. |  | ||||||
| 
 |  | ||||||
| The Python Packaging User Guide includes more details on the `currently |  | ||||||
| recommended tools`_. |  | ||||||
| 
 |  | ||||||
| .. _currently recommended tools: https://packaging.python.org/en/latest/current/#packaging-tool-recommendations |  | ||||||
| 
 |  | ||||||
| Reading the guide |  | ||||||
| ================= |  | ||||||
| 
 |  | ||||||
| The Python Packaging User Guide covers the various key steps and elements |  | ||||||
| involved in creating a project: |  | ||||||
| 
 |  | ||||||
| * `Project structure`_ |  | ||||||
| * `Building and packaging the project`_ |  | ||||||
| * `Uploading the project to the Python Packaging Index`_ |  | ||||||
| 
 |  | ||||||
| .. _Project structure: \ |  | ||||||
|    https://packaging.python.org/en/latest/distributing/ |  | ||||||
| .. _Building and packaging the project: \ |  | ||||||
|    https://packaging.python.org/en/latest/distributing/#packaging-your-project |  | ||||||
| .. _Uploading the project to the Python Packaging Index: \ |  | ||||||
|    https://packaging.python.org/en/latest/distributing/#uploading-your-project-to-pypi |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| How do I...? |  | ||||||
| ============ |  | ||||||
| 
 |  | ||||||
| These are quick answers or links for some common tasks. |  | ||||||
| 
 |  | ||||||
| ... choose a name for my project? |  | ||||||
| --------------------------------- |  | ||||||
| 
 |  | ||||||
| This isn't an easy topic, but here are a few tips: |  | ||||||
| 
 |  | ||||||
| * check the Python Packaging Index to see if the name is already in use |  | ||||||
| * check popular hosting sites like GitHub, BitBucket, etc to see if there |  | ||||||
|   is already a project with that name |  | ||||||
| * check what comes up in a web search for the name you're considering |  | ||||||
| * avoid particularly common words, especially ones with multiple meanings, |  | ||||||
|   as they can make it difficult for users to find your software when |  | ||||||
|   searching for it |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| ... create and distribute binary extensions? |  | ||||||
| -------------------------------------------- |  | ||||||
| 
 |  | ||||||
| This is actually quite a complex topic, with a variety of alternatives |  | ||||||
| available depending on exactly what you're aiming to achieve. See the |  | ||||||
| Python Packaging User Guide for more information and recommendations. |  | ||||||
| 
 |  | ||||||
| .. seealso:: |  | ||||||
| 
 |  | ||||||
|    `Python Packaging User Guide: Binary Extensions |  | ||||||
|    <https://packaging.python.org/en/latest/extensions>`__ |  | ||||||
| 
 |  | ||||||
| .. other topics: |  | ||||||
| 
 |  | ||||||
|    Once the Development & Deployment part of PPUG is fleshed out, some of |  | ||||||
|    those sections should be linked from new questions here (most notably, |  | ||||||
|    we should have a question about avoiding depending on PyPI that links to |  | ||||||
|    https://packaging.python.org/en/latest/mirrors/) |  | ||||||
							
								
								
									
										2030
									
								
								third_party/python/Doc/distutils/apiref.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										2030
									
								
								third_party/python/Doc/distutils/apiref.rst
									
										
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										459
									
								
								third_party/python/Doc/distutils/builtdist.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										459
									
								
								third_party/python/Doc/distutils/builtdist.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,459 +0,0 @@ | ||||||
| .. _built-dist: |  | ||||||
| 
 |  | ||||||
| **************************** |  | ||||||
| Creating Built Distributions |  | ||||||
| **************************** |  | ||||||
| 
 |  | ||||||
| A "built distribution" is what you're probably used to thinking of either as a |  | ||||||
| "binary package" or an "installer" (depending on your background).  It's not |  | ||||||
| necessarily binary, though, because it might contain only Python source code |  | ||||||
| and/or byte-code; and we don't call it a package, because that word is already |  | ||||||
| spoken for in Python.  (And "installer" is a term specific to the world of |  | ||||||
| mainstream desktop systems.) |  | ||||||
| 
 |  | ||||||
| A built distribution is how you make life as easy as possible for installers of |  | ||||||
| your module distribution: for users of RPM-based Linux systems, it's a binary |  | ||||||
| RPM; for Windows users, it's an executable installer; for Debian-based Linux |  | ||||||
| users, it's a Debian package; and so forth.  Obviously, no one person will be |  | ||||||
| able to create built distributions for every platform under the sun, so the |  | ||||||
| Distutils are designed to enable module developers to concentrate on their |  | ||||||
| specialty---writing code and creating source distributions---while an |  | ||||||
| intermediary species called *packagers* springs up to turn source distributions |  | ||||||
| into built distributions for as many platforms as there are packagers. |  | ||||||
| 
 |  | ||||||
| Of course, the module developer could be their own packager; or the packager could |  | ||||||
| be a volunteer "out there" somewhere who has access to a platform which the |  | ||||||
| original developer does not; or it could be software periodically grabbing new |  | ||||||
| source distributions and turning them into built distributions for as many |  | ||||||
| platforms as the software has access to.  Regardless of who they are, a packager |  | ||||||
| uses the setup script and the :command:`bdist` command family to generate built |  | ||||||
| distributions. |  | ||||||
| 
 |  | ||||||
| As a simple example, if I run the following command in the Distutils source |  | ||||||
| tree:: |  | ||||||
| 
 |  | ||||||
|    python setup.py bdist |  | ||||||
| 
 |  | ||||||
| then the Distutils builds my module distribution (the Distutils itself in this |  | ||||||
| case), does a "fake" installation (also in the :file:`build` directory), and |  | ||||||
| creates the default type of built distribution for my platform.  The default |  | ||||||
| format for built distributions is a "dumb" tar file on Unix, and a simple |  | ||||||
| executable installer on Windows.  (That tar file is considered "dumb" because it |  | ||||||
| has to be unpacked in a specific location to work.) |  | ||||||
| 
 |  | ||||||
| Thus, the above command on a Unix system creates |  | ||||||
| :file:`Distutils-1.0.{plat}.tar.gz`; unpacking this tarball from the right place |  | ||||||
| installs the Distutils just as though you had downloaded the source distribution |  | ||||||
| and run ``python setup.py install``.  (The "right place" is either the root of |  | ||||||
| the filesystem or  Python's :file:`{prefix}` directory, depending on the options |  | ||||||
| given to the :command:`bdist_dumb` command; the default is to make dumb |  | ||||||
| distributions relative to :file:`{prefix}`.) |  | ||||||
| 
 |  | ||||||
| Obviously, for pure Python distributions, this isn't any simpler than just |  | ||||||
| running ``python setup.py install``\ ---but for non-pure distributions, which |  | ||||||
| include extensions that would need to be compiled, it can mean the difference |  | ||||||
| between someone being able to use your extensions or not.  And creating "smart" |  | ||||||
| built distributions, such as an RPM package or an executable installer for |  | ||||||
| Windows, is far more convenient for users even if your distribution doesn't |  | ||||||
| include any extensions. |  | ||||||
| 
 |  | ||||||
| The :command:`bdist` command has a :option:`!--formats` option, similar to the |  | ||||||
| :command:`sdist` command, which you can use to select the types of built |  | ||||||
| distribution to generate: for example, :: |  | ||||||
| 
 |  | ||||||
|    python setup.py bdist --format=zip |  | ||||||
| 
 |  | ||||||
| would, when run on a Unix system, create |  | ||||||
| :file:`Distutils-1.0.{plat}.zip`\ ---again, this archive would be unpacked |  | ||||||
| from the root directory to install the Distutils. |  | ||||||
| 
 |  | ||||||
| The available formats for built distributions are: |  | ||||||
| 
 |  | ||||||
| +-------------+------------------------------+---------+ |  | ||||||
| | Format      | Description                  | Notes   | |  | ||||||
| +=============+==============================+=========+ |  | ||||||
| | ``gztar``   | gzipped tar file             | \(1)    | |  | ||||||
| |             | (:file:`.tar.gz`)            |         | |  | ||||||
| +-------------+------------------------------+---------+ |  | ||||||
| | ``bztar``   | bzipped tar file             |         | |  | ||||||
| |             | (:file:`.tar.bz2`)           |         | |  | ||||||
| +-------------+------------------------------+---------+ |  | ||||||
| | ``xztar``   | xzipped tar file             |         | |  | ||||||
| |             | (:file:`.tar.xz`)            |         | |  | ||||||
| +-------------+------------------------------+---------+ |  | ||||||
| | ``ztar``    | compressed tar file          | \(3)    | |  | ||||||
| |             | (:file:`.tar.Z`)             |         | |  | ||||||
| +-------------+------------------------------+---------+ |  | ||||||
| | ``tar``     | tar file (:file:`.tar`)      |         | |  | ||||||
| +-------------+------------------------------+---------+ |  | ||||||
| | ``zip``     | zip file (:file:`.zip`)      | (2),(4) | |  | ||||||
| +-------------+------------------------------+---------+ |  | ||||||
| | ``rpm``     | RPM                          | \(5)    | |  | ||||||
| +-------------+------------------------------+---------+ |  | ||||||
| | ``pkgtool`` | Solaris :program:`pkgtool`   |         | |  | ||||||
| +-------------+------------------------------+---------+ |  | ||||||
| | ``sdux``    | HP-UX :program:`swinstall`   |         | |  | ||||||
| +-------------+------------------------------+---------+ |  | ||||||
| | ``wininst`` | self-extracting ZIP file for | \(4)    | |  | ||||||
| |             | Windows                      |         | |  | ||||||
| +-------------+------------------------------+---------+ |  | ||||||
| | ``msi``     | Microsoft Installer.         |         | |  | ||||||
| +-------------+------------------------------+---------+ |  | ||||||
| 
 |  | ||||||
| .. versionchanged:: 3.5 |  | ||||||
|    Added support for the ``xztar`` format. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Notes: |  | ||||||
| 
 |  | ||||||
| (1) |  | ||||||
|    default on Unix |  | ||||||
| 
 |  | ||||||
| (2) |  | ||||||
|    default on Windows |  | ||||||
| 
 |  | ||||||
| (3) |  | ||||||
|    requires external :program:`compress` utility. |  | ||||||
| 
 |  | ||||||
| (4) |  | ||||||
|    requires either external :program:`zip` utility or :mod:`zipfile` module (part |  | ||||||
|    of the standard Python library since Python 1.6) |  | ||||||
| 
 |  | ||||||
| (5) |  | ||||||
|    requires external :program:`rpm` utility, version 3.0.4 or better (use ``rpm |  | ||||||
|    --version`` to find out which version you have) |  | ||||||
| 
 |  | ||||||
| You don't have to use the :command:`bdist` command with the :option:`!--formats` |  | ||||||
| option; you can also use the command that directly implements the format you're |  | ||||||
| interested in.  Some of these :command:`bdist` "sub-commands" actually generate |  | ||||||
| several similar formats; for instance, the :command:`bdist_dumb` command |  | ||||||
| generates all the "dumb" archive formats (``tar``, ``gztar``, ``bztar``, |  | ||||||
| ``xztar``, ``ztar``, and ``zip``), and :command:`bdist_rpm` generates both |  | ||||||
| binary and source RPMs.  The :command:`bdist` sub-commands, and the formats |  | ||||||
| generated by each, are: |  | ||||||
| 
 |  | ||||||
| +--------------------------+-------------------------------------+ |  | ||||||
| | Command                  | Formats                             | |  | ||||||
| +==========================+=====================================+ |  | ||||||
| | :command:`bdist_dumb`    | tar, gztar, bztar, xztar, ztar, zip | |  | ||||||
| +--------------------------+-------------------------------------+ |  | ||||||
| | :command:`bdist_rpm`     | rpm, srpm                           | |  | ||||||
| +--------------------------+-------------------------------------+ |  | ||||||
| | :command:`bdist_wininst` | wininst                             | |  | ||||||
| +--------------------------+-------------------------------------+ |  | ||||||
| | :command:`bdist_msi`     | msi                                 | |  | ||||||
| +--------------------------+-------------------------------------+ |  | ||||||
| 
 |  | ||||||
| The following sections give details on the individual :command:`bdist_\*` |  | ||||||
| commands. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. .. _creating-dumb: |  | ||||||
| 
 |  | ||||||
| .. Creating dumb built distributions |  | ||||||
| .. ================================= |  | ||||||
| 
 |  | ||||||
| .. XXX Need to document absolute vs. prefix-relative packages here, but first |  | ||||||
|    I have to implement it! |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _creating-rpms: |  | ||||||
| 
 |  | ||||||
| Creating RPM packages |  | ||||||
| ===================== |  | ||||||
| 
 |  | ||||||
| The RPM format is used by many popular Linux distributions, including Red Hat, |  | ||||||
| SuSE, and Mandrake.  If one of these (or any of the other RPM-based Linux |  | ||||||
| distributions) is your usual environment, creating RPM packages for other users |  | ||||||
| of that same distribution is trivial. Depending on the complexity of your module |  | ||||||
| distribution and differences between Linux distributions, you may also be able |  | ||||||
| to create RPMs that work on different RPM-based distributions. |  | ||||||
| 
 |  | ||||||
| The usual way to create an RPM of your module distribution is to run the |  | ||||||
| :command:`bdist_rpm` command:: |  | ||||||
| 
 |  | ||||||
|    python setup.py bdist_rpm |  | ||||||
| 
 |  | ||||||
| or the :command:`bdist` command with the :option:`!--format` option:: |  | ||||||
| 
 |  | ||||||
|    python setup.py bdist --formats=rpm |  | ||||||
| 
 |  | ||||||
| The former allows you to specify RPM-specific options; the latter allows  you to |  | ||||||
| easily specify multiple formats in one run.  If you need to do both, you can |  | ||||||
| explicitly specify multiple :command:`bdist_\*` commands and their options:: |  | ||||||
| 
 |  | ||||||
|    python setup.py bdist_rpm --packager="John Doe <jdoe@example.org>" \ |  | ||||||
|                    bdist_wininst --target-version="2.0" |  | ||||||
| 
 |  | ||||||
| Creating RPM packages is driven by a :file:`.spec` file, much as using the |  | ||||||
| Distutils is driven by the setup script.  To make your life easier, the |  | ||||||
| :command:`bdist_rpm` command normally creates a :file:`.spec` file based on the |  | ||||||
| information you supply in the setup script, on the command line, and in any |  | ||||||
| Distutils configuration files.  Various options and sections in the |  | ||||||
| :file:`.spec` file are derived from options in the setup script as follows: |  | ||||||
| 
 |  | ||||||
| +------------------------------------------+----------------------------------------------+ |  | ||||||
| | RPM :file:`.spec` file option or section | Distutils setup script option                | |  | ||||||
| +==========================================+==============================================+ |  | ||||||
| | Name                                     | ``name``                                     | |  | ||||||
| +------------------------------------------+----------------------------------------------+ |  | ||||||
| | Summary (in preamble)                    | ``description``                              | |  | ||||||
| +------------------------------------------+----------------------------------------------+ |  | ||||||
| | Version                                  | ``version``                                  | |  | ||||||
| +------------------------------------------+----------------------------------------------+ |  | ||||||
| | Vendor                                   | ``author`` and ``author_email``,             | |  | ||||||
| |                                          | or  --- & ``maintainer`` and                 | |  | ||||||
| |                                          | ``maintainer_email``                         | |  | ||||||
| +------------------------------------------+----------------------------------------------+ |  | ||||||
| | Copyright                                | ``license``                                  | |  | ||||||
| +------------------------------------------+----------------------------------------------+ |  | ||||||
| | Url                                      | ``url``                                      | |  | ||||||
| +------------------------------------------+----------------------------------------------+ |  | ||||||
| | %description (section)                   | ``long_description``                         | |  | ||||||
| +------------------------------------------+----------------------------------------------+ |  | ||||||
| 
 |  | ||||||
| Additionally, there are many options in :file:`.spec` files that don't have |  | ||||||
| corresponding options in the setup script.  Most of these are handled through |  | ||||||
| options to the :command:`bdist_rpm` command as follows: |  | ||||||
| 
 |  | ||||||
| +-------------------------------+-----------------------------+-------------------------+ |  | ||||||
| | RPM :file:`.spec` file option | :command:`bdist_rpm` option | default value           | |  | ||||||
| | or section                    |                             |                         | |  | ||||||
| +===============================+=============================+=========================+ |  | ||||||
| | Release                       | ``release``                 | "1"                     | |  | ||||||
| +-------------------------------+-----------------------------+-------------------------+ |  | ||||||
| | Group                         | ``group``                   | "Development/Libraries" | |  | ||||||
| +-------------------------------+-----------------------------+-------------------------+ |  | ||||||
| | Vendor                        | ``vendor``                  | (see above)             | |  | ||||||
| +-------------------------------+-----------------------------+-------------------------+ |  | ||||||
| | Packager                      | ``packager``                | (none)                  | |  | ||||||
| +-------------------------------+-----------------------------+-------------------------+ |  | ||||||
| | Provides                      | ``provides``                | (none)                  | |  | ||||||
| +-------------------------------+-----------------------------+-------------------------+ |  | ||||||
| | Requires                      | ``requires``                | (none)                  | |  | ||||||
| +-------------------------------+-----------------------------+-------------------------+ |  | ||||||
| | Conflicts                     | ``conflicts``               | (none)                  | |  | ||||||
| +-------------------------------+-----------------------------+-------------------------+ |  | ||||||
| | Obsoletes                     | ``obsoletes``               | (none)                  | |  | ||||||
| +-------------------------------+-----------------------------+-------------------------+ |  | ||||||
| | Distribution                  | ``distribution_name``       | (none)                  | |  | ||||||
| +-------------------------------+-----------------------------+-------------------------+ |  | ||||||
| | BuildRequires                 | ``build_requires``          | (none)                  | |  | ||||||
| +-------------------------------+-----------------------------+-------------------------+ |  | ||||||
| | Icon                          | ``icon``                    | (none)                  | |  | ||||||
| +-------------------------------+-----------------------------+-------------------------+ |  | ||||||
| 
 |  | ||||||
| Obviously, supplying even a few of these options on the command-line would be |  | ||||||
| tedious and error-prone, so it's usually best to put them in the setup |  | ||||||
| configuration file, :file:`setup.cfg`\ ---see section :ref:`setup-config`.  If |  | ||||||
| you distribute or package many Python module distributions, you might want to |  | ||||||
| put options that apply to all of them in your personal Distutils configuration |  | ||||||
| file (:file:`~/.pydistutils.cfg`).  If you want to temporarily disable |  | ||||||
| this file, you can pass the :option:`!--no-user-cfg` option to :file:`setup.py`. |  | ||||||
| 
 |  | ||||||
| There are three steps to building a binary RPM package, all of which are |  | ||||||
| handled automatically by the Distutils: |  | ||||||
| 
 |  | ||||||
| #. create a :file:`.spec` file, which describes the package (analogous  to the |  | ||||||
|    Distutils setup script; in fact, much of the information in the  setup script |  | ||||||
|    winds up in the :file:`.spec` file) |  | ||||||
| 
 |  | ||||||
| #. create the source RPM |  | ||||||
| 
 |  | ||||||
| #. create the "binary" RPM (which may or may not contain binary code, depending |  | ||||||
|    on whether your module distribution contains Python extensions) |  | ||||||
| 
 |  | ||||||
| Normally, RPM bundles the last two steps together; when you use the Distutils, |  | ||||||
| all three steps are typically bundled together. |  | ||||||
| 
 |  | ||||||
| If you wish, you can separate these three steps.  You can use the |  | ||||||
| :option:`!--spec-only` option to make :command:`bdist_rpm` just create the |  | ||||||
| :file:`.spec` file and exit; in this case, the :file:`.spec` file will be |  | ||||||
| written to the "distribution directory"---normally :file:`dist/`, but |  | ||||||
| customizable with the :option:`!--dist-dir` option.  (Normally, the :file:`.spec` |  | ||||||
| file winds up deep in the "build tree," in a temporary directory created by |  | ||||||
| :command:`bdist_rpm`.) |  | ||||||
| 
 |  | ||||||
| .. % \XXX{this isn't implemented yet---is it needed?!} |  | ||||||
| .. % You can also specify a custom \file{.spec} file with the |  | ||||||
| .. % \longprogramopt{spec-file} option; used in conjunction with |  | ||||||
| .. % \longprogramopt{spec-only}, this gives you an opportunity to customize |  | ||||||
| .. % the \file{.spec} file manually: |  | ||||||
| .. % |  | ||||||
| .. % \ begin{verbatim} |  | ||||||
| .. % > python setup.py bdist_rpm --spec-only |  | ||||||
| .. % # ...edit dist/FooBar-1.0.spec |  | ||||||
| .. % > python setup.py bdist_rpm --spec-file=dist/FooBar-1.0.spec |  | ||||||
| .. % \ end{verbatim} |  | ||||||
| .. % |  | ||||||
| .. % (Although a better way to do this is probably to override the standard |  | ||||||
| .. % \command{bdist\_rpm} command with one that writes whatever else you want |  | ||||||
| .. % to the \file{.spec} file.) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _creating-wininst: |  | ||||||
| 
 |  | ||||||
| Creating Windows Installers |  | ||||||
| =========================== |  | ||||||
| 
 |  | ||||||
| Executable installers are the natural format for binary distributions on |  | ||||||
| Windows.  They display a nice graphical user interface, display some information |  | ||||||
| about the module distribution to be installed taken from the metadata in the |  | ||||||
| setup script, let the user select a few options, and start or cancel the |  | ||||||
| installation. |  | ||||||
| 
 |  | ||||||
| Since the metadata is taken from the setup script, creating Windows installers |  | ||||||
| is usually as easy as running:: |  | ||||||
| 
 |  | ||||||
|    python setup.py bdist_wininst |  | ||||||
| 
 |  | ||||||
| or the :command:`bdist` command with the :option:`!--formats` option:: |  | ||||||
| 
 |  | ||||||
|    python setup.py bdist --formats=wininst |  | ||||||
| 
 |  | ||||||
| If you have a pure module distribution (only containing pure Python modules and |  | ||||||
| packages), the resulting installer will be version independent and have a name |  | ||||||
| like :file:`foo-1.0.win32.exe`.  These installers can even be created on Unix |  | ||||||
| platforms or Mac OS X. |  | ||||||
| 
 |  | ||||||
| If you have a non-pure distribution, the extensions can only be created on a |  | ||||||
| Windows platform, and will be Python version dependent. The installer filename |  | ||||||
| will reflect this and now has the form :file:`foo-1.0.win32-py2.0.exe`.  You |  | ||||||
| have to create a separate installer for every Python version you want to |  | ||||||
| support. |  | ||||||
| 
 |  | ||||||
| The installer will try to compile pure modules into :term:`bytecode` after installation |  | ||||||
| on the target system in normal and optimizing mode.  If you don't want this to |  | ||||||
| happen for some reason, you can run the :command:`bdist_wininst` command with |  | ||||||
| the :option:`!--no-target-compile` and/or the :option:`!--no-target-optimize` |  | ||||||
| option. |  | ||||||
| 
 |  | ||||||
| By default the installer will display the cool "Python Powered" logo when it is |  | ||||||
| run, but you can also supply your own 152x261 bitmap which must be a Windows |  | ||||||
| :file:`.bmp` file with the :option:`!--bitmap` option. |  | ||||||
| 
 |  | ||||||
| The installer will also display a large title on the desktop background window |  | ||||||
| when it is run, which is constructed from the name of your distribution and the |  | ||||||
| version number.  This can be changed to another text by using the |  | ||||||
| :option:`!--title` option. |  | ||||||
| 
 |  | ||||||
| The installer file will be written to the "distribution directory" --- normally |  | ||||||
| :file:`dist/`, but customizable with the :option:`!--dist-dir` option. |  | ||||||
| 
 |  | ||||||
| .. _cross-compile-windows: |  | ||||||
| 
 |  | ||||||
| Cross-compiling on Windows |  | ||||||
| ========================== |  | ||||||
| 
 |  | ||||||
| Starting with Python 2.6, distutils is capable of cross-compiling between |  | ||||||
| Windows platforms.  In practice, this means that with the correct tools |  | ||||||
| installed, you can use a 32bit version of Windows to create 64bit extensions |  | ||||||
| and vice-versa. |  | ||||||
| 
 |  | ||||||
| To build for an alternate platform, specify the :option:`!--plat-name` option |  | ||||||
| to the build command.  Valid values are currently 'win32', 'win-amd64' and |  | ||||||
| 'win-ia64'.  For example, on a 32bit version of Windows, you could execute:: |  | ||||||
| 
 |  | ||||||
|    python setup.py build --plat-name=win-amd64 |  | ||||||
| 
 |  | ||||||
| to build a 64bit version of your extension.  The Windows Installers also |  | ||||||
| support this option, so the command:: |  | ||||||
| 
 |  | ||||||
|    python setup.py build --plat-name=win-amd64 bdist_wininst |  | ||||||
| 
 |  | ||||||
| would create a 64bit installation executable on your 32bit version of Windows. |  | ||||||
| 
 |  | ||||||
| To cross-compile, you must download the Python source code and cross-compile |  | ||||||
| Python itself for the platform you are targeting - it is not possible from a |  | ||||||
| binary installation of Python (as the .lib etc file for other platforms are |  | ||||||
| not included.)  In practice, this means the user of a 32 bit operating |  | ||||||
| system will need to use Visual Studio 2008 to open the |  | ||||||
| :file:`PCBuild/PCbuild.sln` solution in the Python source tree and build the |  | ||||||
| "x64" configuration of the 'pythoncore' project before cross-compiling |  | ||||||
| extensions is possible. |  | ||||||
| 
 |  | ||||||
| Note that by default, Visual Studio 2008 does not install 64bit compilers or |  | ||||||
| tools.  You may need to reexecute the Visual Studio setup process and select |  | ||||||
| these tools (using Control Panel->[Add/Remove] Programs is a convenient way to |  | ||||||
| check or modify your existing install.) |  | ||||||
| 
 |  | ||||||
| .. _postinstallation-script: |  | ||||||
| 
 |  | ||||||
| The Postinstallation script |  | ||||||
| --------------------------- |  | ||||||
| 
 |  | ||||||
| Starting with Python 2.3, a postinstallation script can be specified with the |  | ||||||
| :option:`!--install-script` option.  The basename of the script must be |  | ||||||
| specified, and the script filename must also be listed in the scripts argument |  | ||||||
| to the setup function. |  | ||||||
| 
 |  | ||||||
| This script will be run at installation time on the target system after all the |  | ||||||
| files have been copied, with ``argv[1]`` set to :option:`!-install`, and again at |  | ||||||
| uninstallation time before the files are removed with ``argv[1]`` set to |  | ||||||
| :option:`!-remove`. |  | ||||||
| 
 |  | ||||||
| The installation script runs embedded in the windows installer, every output |  | ||||||
| (``sys.stdout``, ``sys.stderr``) is redirected into a buffer and will be |  | ||||||
| displayed in the GUI after the script has finished. |  | ||||||
| 
 |  | ||||||
| Some functions especially useful in this context are available as additional |  | ||||||
| built-in functions in the installation script. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. function:: directory_created(path) |  | ||||||
|               file_created(path) |  | ||||||
| 
 |  | ||||||
|    These functions should be called when a directory or file is created by the |  | ||||||
|    postinstall script at installation time.  It will register *path* with the |  | ||||||
|    uninstaller, so that it will be removed when the distribution is uninstalled. |  | ||||||
|    To be safe, directories are only removed if they are empty. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. function:: get_special_folder_path(csidl_string) |  | ||||||
| 
 |  | ||||||
|    This function can be used to retrieve special folder locations on Windows like |  | ||||||
|    the Start Menu or the Desktop.  It returns the full path to the folder. |  | ||||||
|    *csidl_string* must be one of the following strings:: |  | ||||||
| 
 |  | ||||||
|       "CSIDL_APPDATA" |  | ||||||
| 
 |  | ||||||
|       "CSIDL_COMMON_STARTMENU" |  | ||||||
|       "CSIDL_STARTMENU" |  | ||||||
| 
 |  | ||||||
|       "CSIDL_COMMON_DESKTOPDIRECTORY" |  | ||||||
|       "CSIDL_DESKTOPDIRECTORY" |  | ||||||
| 
 |  | ||||||
|       "CSIDL_COMMON_STARTUP" |  | ||||||
|       "CSIDL_STARTUP" |  | ||||||
| 
 |  | ||||||
|       "CSIDL_COMMON_PROGRAMS" |  | ||||||
|       "CSIDL_PROGRAMS" |  | ||||||
| 
 |  | ||||||
|       "CSIDL_FONTS" |  | ||||||
| 
 |  | ||||||
|    If the folder cannot be retrieved, :exc:`OSError` is raised. |  | ||||||
| 
 |  | ||||||
|    Which folders are available depends on the exact Windows version, and probably |  | ||||||
|    also the configuration.  For details refer to Microsoft's documentation of the |  | ||||||
|    :c:func:`SHGetSpecialFolderPath` function. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. function:: create_shortcut(target, description, filename[, arguments[, workdir[, iconpath[, iconindex]]]]) |  | ||||||
| 
 |  | ||||||
|    This function creates a shortcut. *target* is the path to the program to be |  | ||||||
|    started by the shortcut. *description* is the description of the shortcut. |  | ||||||
|    *filename* is the title of the shortcut that the user will see. *arguments* |  | ||||||
|    specifies the command line arguments, if any. *workdir* is the working directory |  | ||||||
|    for the program. *iconpath* is the file containing the icon for the shortcut, |  | ||||||
|    and *iconindex* is the index of the icon in the file *iconpath*.  Again, for |  | ||||||
|    details consult the Microsoft documentation for the :class:`IShellLink` |  | ||||||
|    interface. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Vista User Access Control (UAC) |  | ||||||
| =============================== |  | ||||||
| 
 |  | ||||||
| Starting with Python 2.6, bdist_wininst supports a :option:`!--user-access-control` |  | ||||||
| option.  The default is 'none' (meaning no UAC handling is done), and other |  | ||||||
| valid values are 'auto' (meaning prompt for UAC elevation if Python was |  | ||||||
| installed for all users) and 'force' (meaning always prompt for elevation). |  | ||||||
							
								
								
									
										104
									
								
								third_party/python/Doc/distutils/commandref.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										104
									
								
								third_party/python/Doc/distutils/commandref.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,104 +0,0 @@ | ||||||
| .. _reference: |  | ||||||
| 
 |  | ||||||
| ***************** |  | ||||||
| Command Reference |  | ||||||
| ***************** |  | ||||||
| 
 |  | ||||||
| .. % \section{Building modules: the \protect\command{build} command family} |  | ||||||
| .. % \label{build-cmds} |  | ||||||
| .. % \subsubsection{\protect\command{build}} |  | ||||||
| .. % \label{build-cmd} |  | ||||||
| .. % \subsubsection{\protect\command{build\_py}} |  | ||||||
| .. % \label{build-py-cmd} |  | ||||||
| .. % \subsubsection{\protect\command{build\_ext}} |  | ||||||
| .. % \label{build-ext-cmd} |  | ||||||
| .. % \subsubsection{\protect\command{build\_clib}} |  | ||||||
| .. % \label{build-clib-cmd} |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _install-cmd: |  | ||||||
| 
 |  | ||||||
| Installing modules: the :command:`install` command family |  | ||||||
| ========================================================= |  | ||||||
| 
 |  | ||||||
| The install command ensures that the build commands have been run and then runs |  | ||||||
| the subcommands :command:`install_lib`, :command:`install_data` and |  | ||||||
| :command:`install_scripts`. |  | ||||||
| 
 |  | ||||||
| .. % \subsubsection{\protect\command{install\_lib}} |  | ||||||
| .. % \label{install-lib-cmd} |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _install-data-cmd: |  | ||||||
| 
 |  | ||||||
| :command:`install_data` |  | ||||||
| ----------------------- |  | ||||||
| 
 |  | ||||||
| This command installs all data files provided with the distribution. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _install-scripts-cmd: |  | ||||||
| 
 |  | ||||||
| :command:`install_scripts` |  | ||||||
| -------------------------- |  | ||||||
| 
 |  | ||||||
| This command installs all (Python) scripts in the distribution. |  | ||||||
| 
 |  | ||||||
| .. % \subsection{Cleaning up: the \protect\command{clean} command} |  | ||||||
| .. % \label{clean-cmd} |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _sdist-cmd: |  | ||||||
| 
 |  | ||||||
| Creating a source distribution: the :command:`sdist` command |  | ||||||
| ============================================================ |  | ||||||
| 
 |  | ||||||
| .. XXX fragment moved down from above: needs context! |  | ||||||
| 
 |  | ||||||
| The manifest template commands are: |  | ||||||
| 
 |  | ||||||
| +-------------------------------------------+-----------------------------------------------+ |  | ||||||
| | Command                                   | Description                                   | |  | ||||||
| +===========================================+===============================================+ |  | ||||||
| | :command:`include pat1 pat2 ...`          | include all files matching any of the listed  | |  | ||||||
| |                                           | patterns                                      | |  | ||||||
| +-------------------------------------------+-----------------------------------------------+ |  | ||||||
| | :command:`exclude pat1 pat2 ...`          | exclude all files matching any of the listed  | |  | ||||||
| |                                           | patterns                                      | |  | ||||||
| +-------------------------------------------+-----------------------------------------------+ |  | ||||||
| | :command:`recursive-include dir pat1 pat2 | include all files under *dir* matching any of | |  | ||||||
| | ...`                                      | the listed patterns                           | |  | ||||||
| +-------------------------------------------+-----------------------------------------------+ |  | ||||||
| | :command:`recursive-exclude dir pat1 pat2 | exclude all files under *dir* matching any of | |  | ||||||
| | ...`                                      | the listed patterns                           | |  | ||||||
| +-------------------------------------------+-----------------------------------------------+ |  | ||||||
| | :command:`global-include pat1 pat2 ...`   | include all files anywhere in the source tree | |  | ||||||
| |                                           | matching --- & any of the listed patterns     | |  | ||||||
| +-------------------------------------------+-----------------------------------------------+ |  | ||||||
| | :command:`global-exclude pat1 pat2 ...`   | exclude all files anywhere in the source tree | |  | ||||||
| |                                           | matching --- & any of the listed patterns     | |  | ||||||
| +-------------------------------------------+-----------------------------------------------+ |  | ||||||
| | :command:`prune dir`                      | exclude all files under *dir*                 | |  | ||||||
| +-------------------------------------------+-----------------------------------------------+ |  | ||||||
| | :command:`graft dir`                      | include all files under *dir*                 | |  | ||||||
| +-------------------------------------------+-----------------------------------------------+ |  | ||||||
| 
 |  | ||||||
| The patterns here are Unix-style "glob" patterns: ``*`` matches any sequence of |  | ||||||
| regular filename characters, ``?`` matches any single regular filename |  | ||||||
| character, and ``[range]`` matches any of the characters in *range* (e.g., |  | ||||||
| ``a-z``, ``a-zA-Z``, ``a-f0-9_.``).  The definition of "regular filename |  | ||||||
| character" is platform-specific: on Unix it is anything except slash; on Windows |  | ||||||
| anything except backslash or colon. |  | ||||||
| 
 |  | ||||||
| .. XXX Windows support not there yet |  | ||||||
| 
 |  | ||||||
| .. % \section{Creating a built distribution: the |  | ||||||
| .. % \protect\command{bdist} command family} |  | ||||||
| .. % \label{bdist-cmds} |  | ||||||
| 
 |  | ||||||
| .. % \subsection{\protect\command{bdist}} |  | ||||||
| .. % \subsection{\protect\command{bdist\_dumb}} |  | ||||||
| .. % \subsection{\protect\command{bdist\_rpm}} |  | ||||||
| .. % \subsection{\protect\command{bdist\_wininst}} |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
							
								
								
									
										142
									
								
								third_party/python/Doc/distutils/configfile.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										142
									
								
								third_party/python/Doc/distutils/configfile.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,142 +0,0 @@ | ||||||
| .. _setup-config: |  | ||||||
| 
 |  | ||||||
| ************************************ |  | ||||||
| Writing the Setup Configuration File |  | ||||||
| ************************************ |  | ||||||
| 
 |  | ||||||
| Often, it's not possible to write down everything needed to build a distribution |  | ||||||
| *a priori*: you may need to get some information from the user, or from the |  | ||||||
| user's system, in order to proceed.  As long as that information is fairly |  | ||||||
| simple---a list of directories to search for C header files or libraries, for |  | ||||||
| example---then providing a configuration file, :file:`setup.cfg`, for users to |  | ||||||
| edit is a cheap and easy way to solicit it.  Configuration files also let you |  | ||||||
| provide default values for any command option, which the installer can then |  | ||||||
| override either on the command-line or by editing the config file. |  | ||||||
| 
 |  | ||||||
| The setup configuration file is a useful middle-ground between the setup |  | ||||||
| script---which, ideally, would be opaque to installers [#]_---and the command-line to |  | ||||||
| the setup script, which is outside of your control and entirely up to the |  | ||||||
| installer.  In fact, :file:`setup.cfg` (and any other Distutils configuration |  | ||||||
| files present on the target system) are processed after the contents of the |  | ||||||
| setup script, but before the command-line.  This has  several useful |  | ||||||
| consequences: |  | ||||||
| 
 |  | ||||||
| .. % (If you have more advanced needs, such as determining which extensions |  | ||||||
| .. % to build based on what capabilities are present on the target system, |  | ||||||
| .. % then you need the Distutils ``auto-configuration'' facility.  This |  | ||||||
| .. % started to appear in Distutils 0.9 but, as of this writing, isn't mature |  | ||||||
| .. % or stable enough yet for real-world use.) |  | ||||||
| 
 |  | ||||||
| * installers can override some of what you put in :file:`setup.py` by editing |  | ||||||
|   :file:`setup.cfg` |  | ||||||
| 
 |  | ||||||
| * you can provide non-standard defaults for options that are not easily set in |  | ||||||
|   :file:`setup.py` |  | ||||||
| 
 |  | ||||||
| * installers can override anything in :file:`setup.cfg` using the command-line |  | ||||||
|   options to :file:`setup.py` |  | ||||||
| 
 |  | ||||||
| The basic syntax of the configuration file is simple: |  | ||||||
| 
 |  | ||||||
| .. code-block:: ini |  | ||||||
| 
 |  | ||||||
|    [command] |  | ||||||
|    option=value |  | ||||||
|    ... |  | ||||||
| 
 |  | ||||||
| where *command* is one of the Distutils commands (e.g. :command:`build_py`, |  | ||||||
| :command:`install`), and *option* is one of the options that command supports. |  | ||||||
| Any number of options can be supplied for each command, and any number of |  | ||||||
| command sections can be included in the file.  Blank lines are ignored, as are |  | ||||||
| comments, which run from a ``'#'`` character until the end of the line.  Long |  | ||||||
| option values can be split across multiple lines simply by indenting the |  | ||||||
| continuation lines. |  | ||||||
| 
 |  | ||||||
| You can find out the list of options supported by a particular command with the |  | ||||||
| universal :option:`!--help` option, e.g. |  | ||||||
| 
 |  | ||||||
| .. code-block:: shell-session |  | ||||||
| 
 |  | ||||||
|    $ python setup.py --help build_ext |  | ||||||
|    [...] |  | ||||||
|    Options for 'build_ext' command: |  | ||||||
|      --build-lib (-b)     directory for compiled extension modules |  | ||||||
|      --build-temp (-t)    directory for temporary files (build by-products) |  | ||||||
|      --inplace (-i)       ignore build-lib and put compiled extensions into the |  | ||||||
|                           source directory alongside your pure Python modules |  | ||||||
|      --include-dirs (-I)  list of directories to search for header files |  | ||||||
|      --define (-D)        C preprocessor macros to define |  | ||||||
|      --undef (-U)         C preprocessor macros to undefine |  | ||||||
|      --swig-opts          list of SWIG command line options |  | ||||||
|    [...] |  | ||||||
| 
 |  | ||||||
| Note that an option spelled :option:`!--foo-bar` on the command-line  is spelled |  | ||||||
| ``foo_bar`` in configuration files. |  | ||||||
| 
 |  | ||||||
| .. _distutils-build-ext-inplace: |  | ||||||
| 
 |  | ||||||
| For example, say you want your extensions to be built "in-place"---that is, you |  | ||||||
| have an extension :mod:`pkg.ext`, and you want the compiled extension file |  | ||||||
| (:file:`ext.so` on Unix, say) to be put in the same source directory as your |  | ||||||
| pure Python modules :mod:`pkg.mod1` and :mod:`pkg.mod2`.  You can always use the |  | ||||||
| :option:`!--inplace` option on the command-line to ensure this: |  | ||||||
| 
 |  | ||||||
| .. code-block:: sh |  | ||||||
| 
 |  | ||||||
|    python setup.py build_ext --inplace |  | ||||||
| 
 |  | ||||||
| But this requires that you always specify the :command:`build_ext` command |  | ||||||
| explicitly, and remember to provide :option:`!--inplace`. An easier way is to |  | ||||||
| "set and forget" this option, by encoding it in :file:`setup.cfg`, the |  | ||||||
| configuration file for this distribution: |  | ||||||
| 
 |  | ||||||
| .. code-block:: ini |  | ||||||
| 
 |  | ||||||
|    [build_ext] |  | ||||||
|    inplace=1 |  | ||||||
| 
 |  | ||||||
| This will affect all builds of this module distribution, whether or not you |  | ||||||
| explicitly specify :command:`build_ext`.  If you include :file:`setup.cfg` in |  | ||||||
| your source distribution, it will also affect end-user builds---which is |  | ||||||
| probably a bad idea for this option, since always building extensions in-place |  | ||||||
| would break installation of the module distribution.  In certain peculiar cases, |  | ||||||
| though, modules are built right in their installation directory, so this is |  | ||||||
| conceivably a useful ability.  (Distributing extensions that expect to be built |  | ||||||
| in their installation directory is almost always a bad idea, though.) |  | ||||||
| 
 |  | ||||||
| Another example: certain commands take a lot of options that don't change from |  | ||||||
| run to run; for example, :command:`bdist_rpm` needs to know everything required |  | ||||||
| to generate a "spec" file for creating an RPM distribution.  Some of this |  | ||||||
| information comes from the setup script, and some is automatically generated by |  | ||||||
| the Distutils (such as the list of files installed).  But some of it has to be |  | ||||||
| supplied as options to :command:`bdist_rpm`, which would be very tedious to do |  | ||||||
| on the command-line for every run.  Hence, here is a snippet from the Distutils' |  | ||||||
| own :file:`setup.cfg`: |  | ||||||
| 
 |  | ||||||
| .. code-block:: ini |  | ||||||
| 
 |  | ||||||
|    [bdist_rpm] |  | ||||||
|    release = 1 |  | ||||||
|    packager = Greg Ward <gward@python.net> |  | ||||||
|    doc_files = CHANGES.txt |  | ||||||
|                README.txt |  | ||||||
|                USAGE.txt |  | ||||||
|                doc/ |  | ||||||
|                examples/ |  | ||||||
| 
 |  | ||||||
| Note that the ``doc_files`` option is simply a whitespace-separated string |  | ||||||
| split across multiple lines for readability. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. seealso:: |  | ||||||
| 
 |  | ||||||
|    :ref:`inst-config-syntax` in "Installing Python Modules" |  | ||||||
|       More information on the configuration files is available in the manual for |  | ||||||
|       system administrators. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. rubric:: Footnotes |  | ||||||
| 
 |  | ||||||
| .. [#] This ideal probably won't be achieved until auto-configuration is fully |  | ||||||
|    supported by the Distutils. |  | ||||||
| 
 |  | ||||||
							
								
								
									
										338
									
								
								third_party/python/Doc/distutils/examples.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										338
									
								
								third_party/python/Doc/distutils/examples.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,338 +0,0 @@ | ||||||
| .. _examples: |  | ||||||
| 
 |  | ||||||
| ******** |  | ||||||
| Examples |  | ||||||
| ******** |  | ||||||
| 
 |  | ||||||
| This chapter provides a number of basic examples to help get started with |  | ||||||
| distutils.  Additional information about using distutils can be found in the |  | ||||||
| Distutils Cookbook. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. seealso:: |  | ||||||
| 
 |  | ||||||
|    `Distutils Cookbook <https://wiki.python.org/moin/Distutils/Cookbook>`_ |  | ||||||
|       Collection of recipes showing how to achieve more control over distutils. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _pure-mod: |  | ||||||
| 
 |  | ||||||
| Pure Python distribution (by module) |  | ||||||
| ==================================== |  | ||||||
| 
 |  | ||||||
| If you're just distributing a couple of modules, especially if they don't live |  | ||||||
| in a particular package, you can specify them individually using the |  | ||||||
| ``py_modules`` option in the setup script. |  | ||||||
| 
 |  | ||||||
| In the simplest case, you'll have two files to worry about: a setup script and |  | ||||||
| the single module you're distributing, :file:`foo.py` in this example:: |  | ||||||
| 
 |  | ||||||
|    <root>/ |  | ||||||
|            setup.py |  | ||||||
|            foo.py |  | ||||||
| 
 |  | ||||||
| (In all diagrams in this section, *<root>* will refer to the distribution root |  | ||||||
| directory.)  A minimal setup script to describe this situation would be:: |  | ||||||
| 
 |  | ||||||
|    from distutils.core import setup |  | ||||||
|    setup(name='foo', |  | ||||||
|          version='1.0', |  | ||||||
|          py_modules=['foo'], |  | ||||||
|          ) |  | ||||||
| 
 |  | ||||||
| Note that the name of the distribution is specified independently with the |  | ||||||
| ``name`` option, and there's no rule that says it has to be the same as |  | ||||||
| the name of the sole module in the distribution (although that's probably a good |  | ||||||
| convention to follow).  However, the distribution name is used to generate |  | ||||||
| filenames, so you should stick to letters, digits, underscores, and hyphens. |  | ||||||
| 
 |  | ||||||
| Since ``py_modules`` is a list, you can of course specify multiple |  | ||||||
| modules, eg. if you're distributing modules :mod:`foo` and :mod:`bar`, your |  | ||||||
| setup might look like this:: |  | ||||||
| 
 |  | ||||||
|    <root>/ |  | ||||||
|            setup.py |  | ||||||
|            foo.py |  | ||||||
|            bar.py |  | ||||||
| 
 |  | ||||||
| and the setup script might be  :: |  | ||||||
| 
 |  | ||||||
|    from distutils.core import setup |  | ||||||
|    setup(name='foobar', |  | ||||||
|          version='1.0', |  | ||||||
|          py_modules=['foo', 'bar'], |  | ||||||
|          ) |  | ||||||
| 
 |  | ||||||
| You can put module source files into another directory, but if you have enough |  | ||||||
| modules to do that, it's probably easier to specify modules by package rather |  | ||||||
| than listing them individually. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _pure-pkg: |  | ||||||
| 
 |  | ||||||
| Pure Python distribution (by package) |  | ||||||
| ===================================== |  | ||||||
| 
 |  | ||||||
| If you have more than a couple of modules to distribute, especially if they are |  | ||||||
| in multiple packages, it's probably easier to specify whole packages rather than |  | ||||||
| individual modules.  This works even if your modules are not in a package; you |  | ||||||
| can just tell the Distutils to process modules from the root package, and that |  | ||||||
| works the same as any other package (except that you don't have to have an |  | ||||||
| :file:`__init__.py` file). |  | ||||||
| 
 |  | ||||||
| The setup script from the last example could also be written as  :: |  | ||||||
| 
 |  | ||||||
|    from distutils.core import setup |  | ||||||
|    setup(name='foobar', |  | ||||||
|          version='1.0', |  | ||||||
|          packages=[''], |  | ||||||
|          ) |  | ||||||
| 
 |  | ||||||
| (The empty string stands for the root package.) |  | ||||||
| 
 |  | ||||||
| If those two files are moved into a subdirectory, but remain in the root |  | ||||||
| package, e.g.:: |  | ||||||
| 
 |  | ||||||
|    <root>/ |  | ||||||
|            setup.py |  | ||||||
|            src/      foo.py |  | ||||||
|                      bar.py |  | ||||||
| 
 |  | ||||||
| then you would still specify the root package, but you have to tell the |  | ||||||
| Distutils where source files in the root package live:: |  | ||||||
| 
 |  | ||||||
|    from distutils.core import setup |  | ||||||
|    setup(name='foobar', |  | ||||||
|          version='1.0', |  | ||||||
|          package_dir={'': 'src'}, |  | ||||||
|          packages=[''], |  | ||||||
|          ) |  | ||||||
| 
 |  | ||||||
| More typically, though, you will want to distribute multiple modules in the same |  | ||||||
| package (or in sub-packages).  For example, if the :mod:`foo`  and :mod:`bar` |  | ||||||
| modules belong in package :mod:`foobar`, one way to layout your source tree is |  | ||||||
| :: |  | ||||||
| 
 |  | ||||||
|    <root>/ |  | ||||||
|            setup.py |  | ||||||
|            foobar/ |  | ||||||
|                     __init__.py |  | ||||||
|                     foo.py |  | ||||||
|                     bar.py |  | ||||||
| 
 |  | ||||||
| This is in fact the default layout expected by the Distutils, and the one that |  | ||||||
| requires the least work to describe in your setup script:: |  | ||||||
| 
 |  | ||||||
|    from distutils.core import setup |  | ||||||
|    setup(name='foobar', |  | ||||||
|          version='1.0', |  | ||||||
|          packages=['foobar'], |  | ||||||
|          ) |  | ||||||
| 
 |  | ||||||
| If you want to put modules in directories not named for their package, then you |  | ||||||
| need to use the ``package_dir`` option again.  For example, if the |  | ||||||
| :file:`src` directory holds modules in the :mod:`foobar` package:: |  | ||||||
| 
 |  | ||||||
|    <root>/ |  | ||||||
|            setup.py |  | ||||||
|            src/ |  | ||||||
|                     __init__.py |  | ||||||
|                     foo.py |  | ||||||
|                     bar.py |  | ||||||
| 
 |  | ||||||
| an appropriate setup script would be  :: |  | ||||||
| 
 |  | ||||||
|    from distutils.core import setup |  | ||||||
|    setup(name='foobar', |  | ||||||
|          version='1.0', |  | ||||||
|          package_dir={'foobar': 'src'}, |  | ||||||
|          packages=['foobar'], |  | ||||||
|          ) |  | ||||||
| 
 |  | ||||||
| Or, you might put modules from your main package right in the distribution |  | ||||||
| root:: |  | ||||||
| 
 |  | ||||||
|    <root>/ |  | ||||||
|            setup.py |  | ||||||
|            __init__.py |  | ||||||
|            foo.py |  | ||||||
|            bar.py |  | ||||||
| 
 |  | ||||||
| in which case your setup script would be  :: |  | ||||||
| 
 |  | ||||||
|    from distutils.core import setup |  | ||||||
|    setup(name='foobar', |  | ||||||
|          version='1.0', |  | ||||||
|          package_dir={'foobar': ''}, |  | ||||||
|          packages=['foobar'], |  | ||||||
|          ) |  | ||||||
| 
 |  | ||||||
| (The empty string also stands for the current directory.) |  | ||||||
| 
 |  | ||||||
| If you have sub-packages, they must be explicitly listed in ``packages``, |  | ||||||
| but any entries in ``package_dir`` automatically extend to sub-packages. |  | ||||||
| (In other words, the Distutils does *not* scan your source tree, trying to |  | ||||||
| figure out which directories correspond to Python packages by looking for |  | ||||||
| :file:`__init__.py` files.)  Thus, if the default layout grows a sub-package:: |  | ||||||
| 
 |  | ||||||
|    <root>/ |  | ||||||
|            setup.py |  | ||||||
|            foobar/ |  | ||||||
|                     __init__.py |  | ||||||
|                     foo.py |  | ||||||
|                     bar.py |  | ||||||
|                     subfoo/ |  | ||||||
|                               __init__.py |  | ||||||
|                               blah.py |  | ||||||
| 
 |  | ||||||
| then the corresponding setup script would be  :: |  | ||||||
| 
 |  | ||||||
|    from distutils.core import setup |  | ||||||
|    setup(name='foobar', |  | ||||||
|          version='1.0', |  | ||||||
|          packages=['foobar', 'foobar.subfoo'], |  | ||||||
|          ) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _single-ext: |  | ||||||
| 
 |  | ||||||
| Single extension module |  | ||||||
| ======================= |  | ||||||
| 
 |  | ||||||
| Extension modules are specified using the ``ext_modules`` option. |  | ||||||
| ``package_dir`` has no effect on where extension source files are found; |  | ||||||
| it only affects the source for pure Python modules.  The simplest  case, a |  | ||||||
| single extension module in a single C source file, is:: |  | ||||||
| 
 |  | ||||||
|    <root>/ |  | ||||||
|            setup.py |  | ||||||
|            foo.c |  | ||||||
| 
 |  | ||||||
| If the :mod:`foo` extension belongs in the root package, the setup script for |  | ||||||
| this could be  :: |  | ||||||
| 
 |  | ||||||
|    from distutils.core import setup |  | ||||||
|    from distutils.extension import Extension |  | ||||||
|    setup(name='foobar', |  | ||||||
|          version='1.0', |  | ||||||
|          ext_modules=[Extension('foo', ['foo.c'])], |  | ||||||
|          ) |  | ||||||
| 
 |  | ||||||
| If the extension actually belongs in a package, say :mod:`foopkg`, then |  | ||||||
| 
 |  | ||||||
| With exactly the same source tree layout, this extension can be put in the |  | ||||||
| :mod:`foopkg` package simply by changing the name of the extension:: |  | ||||||
| 
 |  | ||||||
|    from distutils.core import setup |  | ||||||
|    from distutils.extension import Extension |  | ||||||
|    setup(name='foobar', |  | ||||||
|          version='1.0', |  | ||||||
|          ext_modules=[Extension('foopkg.foo', ['foo.c'])], |  | ||||||
|          ) |  | ||||||
| 
 |  | ||||||
| Checking a package |  | ||||||
| ================== |  | ||||||
| 
 |  | ||||||
| The ``check`` command allows you to verify if your package meta-data |  | ||||||
| meet the minimum requirements to build a distribution. |  | ||||||
| 
 |  | ||||||
| To run it, just call it using your :file:`setup.py` script. If something is |  | ||||||
| missing, ``check`` will display a warning. |  | ||||||
| 
 |  | ||||||
| Let's take an example with a simple script:: |  | ||||||
| 
 |  | ||||||
|     from distutils.core import setup |  | ||||||
| 
 |  | ||||||
|     setup(name='foobar') |  | ||||||
| 
 |  | ||||||
| Running the ``check`` command will display some warnings: |  | ||||||
| 
 |  | ||||||
| .. code-block:: shell-session |  | ||||||
| 
 |  | ||||||
|     $ python setup.py check |  | ||||||
|     running check |  | ||||||
|     warning: check: missing required meta-data: version, url |  | ||||||
|     warning: check: missing meta-data: either (author and author_email) or |  | ||||||
|              (maintainer and maintainer_email) must be supplied |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| If you use the reStructuredText syntax in the ``long_description`` field and |  | ||||||
| `docutils`_  is installed you can check if the syntax is fine with the |  | ||||||
| ``check`` command, using the ``restructuredtext`` option. |  | ||||||
| 
 |  | ||||||
| For example, if the :file:`setup.py` script is changed like this:: |  | ||||||
| 
 |  | ||||||
|     from distutils.core import setup |  | ||||||
| 
 |  | ||||||
|     desc = """\ |  | ||||||
|     My description |  | ||||||
|     ============== |  | ||||||
| 
 |  | ||||||
|     This is the description of the ``foobar`` package. |  | ||||||
|     """ |  | ||||||
| 
 |  | ||||||
|     setup(name='foobar', version='1', author='tarek', |  | ||||||
|         author_email='tarek@ziade.org', |  | ||||||
|         url='http://example.com', long_description=desc) |  | ||||||
| 
 |  | ||||||
| Where the long description is broken, ``check`` will be able to detect it |  | ||||||
| by using the :mod:`docutils` parser: |  | ||||||
| 
 |  | ||||||
| .. code-block:: shell-session |  | ||||||
| 
 |  | ||||||
|     $ python setup.py check --restructuredtext |  | ||||||
|     running check |  | ||||||
|     warning: check: Title underline too short. (line 2) |  | ||||||
|     warning: check: Could not finish the parsing. |  | ||||||
| 
 |  | ||||||
| Reading the metadata |  | ||||||
| ===================== |  | ||||||
| 
 |  | ||||||
| The :func:`distutils.core.setup` function provides a command-line interface |  | ||||||
| that allows you to query the metadata fields of a project through the |  | ||||||
| ``setup.py`` script of a given project: |  | ||||||
| 
 |  | ||||||
| .. code-block:: shell-session |  | ||||||
| 
 |  | ||||||
|     $ python setup.py --name |  | ||||||
|     distribute |  | ||||||
| 
 |  | ||||||
| This call reads the ``name`` metadata by running the |  | ||||||
| :func:`distutils.core.setup`  function. Although, when a source or binary |  | ||||||
| distribution is created with Distutils, the metadata fields are written |  | ||||||
| in a static file called :file:`PKG-INFO`. When a Distutils-based project is |  | ||||||
| installed in Python, the :file:`PKG-INFO` file is copied alongside the modules |  | ||||||
| and packages of the distribution under :file:`NAME-VERSION-pyX.X.egg-info`, |  | ||||||
| where ``NAME`` is the name of the project, ``VERSION`` its version as defined |  | ||||||
| in the Metadata, and ``pyX.X`` the major and minor version of Python like |  | ||||||
| ``2.7`` or ``3.2``. |  | ||||||
| 
 |  | ||||||
| You can read back this static file, by using the |  | ||||||
| :class:`distutils.dist.DistributionMetadata` class and its |  | ||||||
| :func:`read_pkg_file` method:: |  | ||||||
| 
 |  | ||||||
|     >>> from distutils.dist import DistributionMetadata |  | ||||||
|     >>> metadata = DistributionMetadata() |  | ||||||
|     >>> metadata.read_pkg_file(open('distribute-0.6.8-py2.7.egg-info')) |  | ||||||
|     >>> metadata.name |  | ||||||
|     'distribute' |  | ||||||
|     >>> metadata.version |  | ||||||
|     '0.6.8' |  | ||||||
|     >>> metadata.description |  | ||||||
|     'Easily download, build, install, upgrade, and uninstall Python packages' |  | ||||||
| 
 |  | ||||||
| Notice that the class can also be instantiated with a metadata file path to |  | ||||||
| loads its values:: |  | ||||||
| 
 |  | ||||||
|     >>> pkg_info_path = 'distribute-0.6.8-py2.7.egg-info' |  | ||||||
|     >>> DistributionMetadata(pkg_info_path).name |  | ||||||
|     'distribute' |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. % \section{Multiple extension modules} |  | ||||||
| .. % \label{multiple-ext} |  | ||||||
| 
 |  | ||||||
| .. % \section{Putting it all together} |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _docutils: http://docutils.sourceforge.net |  | ||||||
							
								
								
									
										96
									
								
								third_party/python/Doc/distutils/extending.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										96
									
								
								third_party/python/Doc/distutils/extending.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,96 +0,0 @@ | ||||||
| .. _extending-distutils: |  | ||||||
| 
 |  | ||||||
| ******************* |  | ||||||
| Extending Distutils |  | ||||||
| ******************* |  | ||||||
| 
 |  | ||||||
| Distutils can be extended in various ways.  Most extensions take the form of new |  | ||||||
| commands or replacements for existing commands.  New commands may be written to |  | ||||||
| support new types of platform-specific packaging, for example, while |  | ||||||
| replacements for existing commands may be made to modify details of how the |  | ||||||
| command operates on a package. |  | ||||||
| 
 |  | ||||||
| Most extensions of the distutils are made within :file:`setup.py` scripts that |  | ||||||
| want to modify existing commands; many simply add a few file extensions that |  | ||||||
| should be copied into packages in addition to :file:`.py` files as a |  | ||||||
| convenience. |  | ||||||
| 
 |  | ||||||
| Most distutils command implementations are subclasses of the |  | ||||||
| :class:`distutils.cmd.Command` class.  New commands may directly inherit from |  | ||||||
| :class:`Command`, while replacements often derive from :class:`Command` |  | ||||||
| indirectly, directly subclassing the command they are replacing.  Commands are |  | ||||||
| required to derive from :class:`Command`. |  | ||||||
| 
 |  | ||||||
| .. % \section{Extending existing commands} |  | ||||||
| .. % \label{extend-existing} |  | ||||||
| 
 |  | ||||||
| .. % \section{Writing new commands} |  | ||||||
| .. % \label{new-commands} |  | ||||||
| .. % \XXX{Would an uninstall command be a good example here?} |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Integrating new commands |  | ||||||
| ======================== |  | ||||||
| 
 |  | ||||||
| There are different ways to integrate new command implementations into |  | ||||||
| distutils.  The most difficult is to lobby for the inclusion of the new features |  | ||||||
| in distutils itself, and wait for (and require) a version of Python that |  | ||||||
| provides that support.  This is really hard for many reasons. |  | ||||||
| 
 |  | ||||||
| The most common, and possibly the most reasonable for most needs, is to include |  | ||||||
| the new implementations with your :file:`setup.py` script, and cause the |  | ||||||
| :func:`distutils.core.setup` function use them:: |  | ||||||
| 
 |  | ||||||
|    from distutils.command.build_py import build_py as _build_py |  | ||||||
|    from distutils.core import setup |  | ||||||
| 
 |  | ||||||
|    class build_py(_build_py): |  | ||||||
|        """Specialized Python source builder.""" |  | ||||||
| 
 |  | ||||||
|        # implement whatever needs to be different... |  | ||||||
| 
 |  | ||||||
|    setup(cmdclass={'build_py': build_py}, |  | ||||||
|          ...) |  | ||||||
| 
 |  | ||||||
| This approach is most valuable if the new implementations must be used to use a |  | ||||||
| particular package, as everyone interested in the package will need to have the |  | ||||||
| new command implementation. |  | ||||||
| 
 |  | ||||||
| Beginning with Python 2.4, a third option is available, intended to allow new |  | ||||||
| commands to be added which can support existing :file:`setup.py` scripts without |  | ||||||
| requiring modifications to the Python installation.  This is expected to allow |  | ||||||
| third-party extensions to provide support for additional packaging systems, but |  | ||||||
| the commands can be used for anything distutils commands can be used for.  A new |  | ||||||
| configuration option, ``command_packages`` (command-line option |  | ||||||
| :option:`!--command-packages`), can be used to specify additional packages to be |  | ||||||
| searched for modules implementing commands.  Like all distutils options, this |  | ||||||
| can be specified on the command line or in a configuration file.  This option |  | ||||||
| can only be set in the ``[global]`` section of a configuration file, or before |  | ||||||
| any commands on the command line.  If set in a configuration file, it can be |  | ||||||
| overridden from the command line; setting it to an empty string on the command |  | ||||||
| line causes the default to be used.  This should never be set in a configuration |  | ||||||
| file provided with a package. |  | ||||||
| 
 |  | ||||||
| This new option can be used to add any number of packages to the list of |  | ||||||
| packages searched for command implementations; multiple package names should be |  | ||||||
| separated by commas.  When not specified, the search is only performed in the |  | ||||||
| :mod:`distutils.command` package.  When :file:`setup.py` is run with the option |  | ||||||
| ``--command-packages distcmds,buildcmds``, however, the packages |  | ||||||
| :mod:`distutils.command`, :mod:`distcmds`, and :mod:`buildcmds` will be searched |  | ||||||
| in that order.  New commands are expected to be implemented in modules of the |  | ||||||
| same name as the command by classes sharing the same name.  Given the example |  | ||||||
| command line option above, the command :command:`bdist_openpkg` could be |  | ||||||
| implemented by the class :class:`distcmds.bdist_openpkg.bdist_openpkg` or |  | ||||||
| :class:`buildcmds.bdist_openpkg.bdist_openpkg`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Adding new distribution types |  | ||||||
| ============================= |  | ||||||
| 
 |  | ||||||
| Commands that create distributions (files in the :file:`dist/` directory) need |  | ||||||
| to add ``(command, filename)`` pairs to ``self.distribution.dist_files`` so that |  | ||||||
| :command:`upload` can upload it to PyPI.  The *filename* in the pair contains no |  | ||||||
| path information, only the name of the file itself.  In dry-run mode, pairs |  | ||||||
| should still be added to represent what would have been created. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
							
								
								
									
										41
									
								
								third_party/python/Doc/distutils/index.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										41
									
								
								third_party/python/Doc/distutils/index.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,41 +0,0 @@ | ||||||
| .. _distutils-index: |  | ||||||
| 
 |  | ||||||
| ############################################## |  | ||||||
|   Distributing Python Modules (Legacy version) |  | ||||||
| ############################################## |  | ||||||
| 
 |  | ||||||
| :Authors: Greg Ward, Anthony Baxter |  | ||||||
| :Email: distutils-sig@python.org |  | ||||||
| 
 |  | ||||||
| .. seealso:: |  | ||||||
| 
 |  | ||||||
|    :ref:`distributing-index` |  | ||||||
|       The up to date module distribution documentations |  | ||||||
| 
 |  | ||||||
| This document describes the Python Distribution Utilities ("Distutils") from |  | ||||||
| the module developer's point of view, describing how to use the Distutils to |  | ||||||
| make Python modules and extensions easily available to a wider audience with |  | ||||||
| very little overhead for build/release/install mechanics. |  | ||||||
| 
 |  | ||||||
| .. note:: |  | ||||||
| 
 |  | ||||||
|    This guide only covers the basic tools for building and distributing |  | ||||||
|    extensions that are provided as part of this version of Python. Third party |  | ||||||
|    tools offer easier to use and more secure alternatives. Refer to the `quick |  | ||||||
|    recommendations section <https://packaging.python.org/en/latest/current/>`__ |  | ||||||
|    in the Python Packaging User Guide for more information. |  | ||||||
| 
 |  | ||||||
| .. toctree:: |  | ||||||
|    :maxdepth: 2 |  | ||||||
|    :numbered: |  | ||||||
| 
 |  | ||||||
|    introduction.rst |  | ||||||
|    setupscript.rst |  | ||||||
|    configfile.rst |  | ||||||
|    sourcedist.rst |  | ||||||
|    builtdist.rst |  | ||||||
|    packageindex.rst |  | ||||||
|    examples.rst |  | ||||||
|    extending.rst |  | ||||||
|    commandref.rst |  | ||||||
|    apiref.rst |  | ||||||
							
								
								
									
										212
									
								
								third_party/python/Doc/distutils/introduction.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										212
									
								
								third_party/python/Doc/distutils/introduction.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,212 +0,0 @@ | ||||||
| .. _distutils-intro: |  | ||||||
| 
 |  | ||||||
| **************************** |  | ||||||
| An Introduction to Distutils |  | ||||||
| **************************** |  | ||||||
| 
 |  | ||||||
| This document covers using the Distutils to distribute your Python modules, |  | ||||||
| concentrating on the role of developer/distributor: if you're looking for |  | ||||||
| information on installing Python modules, you should refer to the |  | ||||||
| :ref:`install-index` chapter. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _distutils-concepts: |  | ||||||
| 
 |  | ||||||
| Concepts & Terminology |  | ||||||
| ====================== |  | ||||||
| 
 |  | ||||||
| Using the Distutils is quite simple, both for module developers and for |  | ||||||
| users/administrators installing third-party modules.  As a developer, your |  | ||||||
| responsibilities (apart from writing solid, well-documented and well-tested |  | ||||||
| code, of course!) are: |  | ||||||
| 
 |  | ||||||
| * write a setup script (:file:`setup.py` by convention) |  | ||||||
| 
 |  | ||||||
| * (optional) write a setup configuration file |  | ||||||
| 
 |  | ||||||
| * create a source distribution |  | ||||||
| 
 |  | ||||||
| * (optional) create one or more built (binary) distributions |  | ||||||
| 
 |  | ||||||
| Each of these tasks is covered in this document. |  | ||||||
| 
 |  | ||||||
| Not all module developers have access to a multitude of platforms, so it's not |  | ||||||
| always feasible to expect them to create a multitude of built distributions.  It |  | ||||||
| is hoped that a class of intermediaries, called *packagers*, will arise to |  | ||||||
| address this need.  Packagers will take source distributions released by module |  | ||||||
| developers, build them on one or more platforms, and release the resulting built |  | ||||||
| distributions.  Thus, users on the most popular platforms will be able to |  | ||||||
| install most popular Python module distributions in the most natural way for |  | ||||||
| their platform, without having to run a single setup script or compile a line of |  | ||||||
| code. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _distutils-simple-example: |  | ||||||
| 
 |  | ||||||
| A Simple Example |  | ||||||
| ================ |  | ||||||
| 
 |  | ||||||
| The setup script is usually quite simple, although since it's written in Python, |  | ||||||
| there are no arbitrary limits to what you can do with it, though you should be |  | ||||||
| careful about putting arbitrarily expensive operations in your setup script. |  | ||||||
| Unlike, say, Autoconf-style configure scripts, the setup script may be run |  | ||||||
| multiple times in the course of building and installing your module |  | ||||||
| distribution. |  | ||||||
| 
 |  | ||||||
| If all you want to do is distribute a module called :mod:`foo`, contained in a |  | ||||||
| file :file:`foo.py`, then your setup script can be as simple as this:: |  | ||||||
| 
 |  | ||||||
|    from distutils.core import setup |  | ||||||
|    setup(name='foo', |  | ||||||
|          version='1.0', |  | ||||||
|          py_modules=['foo'], |  | ||||||
|          ) |  | ||||||
| 
 |  | ||||||
| Some observations: |  | ||||||
| 
 |  | ||||||
| * most information that you supply to the Distutils is supplied as keyword |  | ||||||
|   arguments to the :func:`setup` function |  | ||||||
| 
 |  | ||||||
| * those keyword arguments fall into two categories: package metadata (name, |  | ||||||
|   version number) and information about what's in the package (a list of pure |  | ||||||
|   Python modules, in this case) |  | ||||||
| 
 |  | ||||||
| * modules are specified by module name, not filename (the same will hold true |  | ||||||
|   for packages and extensions) |  | ||||||
| 
 |  | ||||||
| * it's recommended that you supply a little more metadata, in particular your |  | ||||||
|   name, email address and a URL for the project (see section :ref:`setup-script` |  | ||||||
|   for an example) |  | ||||||
| 
 |  | ||||||
| To create a source distribution for this module, you would create a setup |  | ||||||
| script, :file:`setup.py`, containing the above code, and run this command from a |  | ||||||
| terminal:: |  | ||||||
| 
 |  | ||||||
|    python setup.py sdist |  | ||||||
| 
 |  | ||||||
| For Windows, open a command prompt window (:menuselection:`Start --> |  | ||||||
| Accessories`) and change the command to:: |  | ||||||
| 
 |  | ||||||
|    setup.py sdist |  | ||||||
| 
 |  | ||||||
| :command:`sdist` will create an archive file (e.g., tarball on Unix, ZIP file on Windows) |  | ||||||
| containing your setup script :file:`setup.py`, and your module :file:`foo.py`. |  | ||||||
| The archive file will be named :file:`foo-1.0.tar.gz` (or :file:`.zip`), and |  | ||||||
| will unpack into a directory :file:`foo-1.0`. |  | ||||||
| 
 |  | ||||||
| If an end-user wishes to install your :mod:`foo` module, all they have to do is |  | ||||||
| download :file:`foo-1.0.tar.gz` (or :file:`.zip`), unpack it, and---from the |  | ||||||
| :file:`foo-1.0` directory---run :: |  | ||||||
| 
 |  | ||||||
|    python setup.py install |  | ||||||
| 
 |  | ||||||
| which will ultimately copy :file:`foo.py` to the appropriate directory for |  | ||||||
| third-party modules in their Python installation. |  | ||||||
| 
 |  | ||||||
| This simple example demonstrates some fundamental concepts of the Distutils. |  | ||||||
| First, both developers and installers have the same basic user interface, i.e. |  | ||||||
| the setup script.  The difference is which Distutils *commands* they use: the |  | ||||||
| :command:`sdist` command is almost exclusively for module developers, while |  | ||||||
| :command:`install` is more often for installers (although most developers will |  | ||||||
| want to install their own code occasionally). |  | ||||||
| 
 |  | ||||||
| If you want to make things really easy for your users, you can create one or |  | ||||||
| more built distributions for them.  For instance, if you are running on a |  | ||||||
| Windows machine, and want to make things easy for other Windows users, you can |  | ||||||
| create an executable installer (the most appropriate type of built distribution |  | ||||||
| for this platform) with the :command:`bdist_wininst` command.  For example:: |  | ||||||
| 
 |  | ||||||
|    python setup.py bdist_wininst |  | ||||||
| 
 |  | ||||||
| will create an executable installer, :file:`foo-1.0.win32.exe`, in the current |  | ||||||
| directory. |  | ||||||
| 
 |  | ||||||
| Other useful built distribution formats are RPM, implemented by the |  | ||||||
| :command:`bdist_rpm` command, Solaris :program:`pkgtool` |  | ||||||
| (:command:`bdist_pkgtool`), and HP-UX :program:`swinstall` |  | ||||||
| (:command:`bdist_sdux`).  For example, the following command will create an RPM |  | ||||||
| file called :file:`foo-1.0.noarch.rpm`:: |  | ||||||
| 
 |  | ||||||
|    python setup.py bdist_rpm |  | ||||||
| 
 |  | ||||||
| (The :command:`bdist_rpm` command uses the :command:`rpm` executable, therefore |  | ||||||
| this has to be run on an RPM-based system such as Red Hat Linux, SuSE Linux, or |  | ||||||
| Mandrake Linux.) |  | ||||||
| 
 |  | ||||||
| You can find out what distribution formats are available at any time by running |  | ||||||
| :: |  | ||||||
| 
 |  | ||||||
|    python setup.py bdist --help-formats |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _python-terms: |  | ||||||
| 
 |  | ||||||
| General Python terminology |  | ||||||
| ========================== |  | ||||||
| 
 |  | ||||||
| If you're reading this document, you probably have a good idea of what modules, |  | ||||||
| extensions, and so forth are.  Nevertheless, just to be sure that everyone is |  | ||||||
| operating from a common starting point, we offer the following glossary of |  | ||||||
| common Python terms: |  | ||||||
| 
 |  | ||||||
| module |  | ||||||
|    the basic unit of code reusability in Python: a block of code imported by some |  | ||||||
|    other code.  Three types of modules concern us here: pure Python modules, |  | ||||||
|    extension modules, and packages. |  | ||||||
| 
 |  | ||||||
| pure Python module |  | ||||||
|    a module written in Python and contained in a single :file:`.py` file (and |  | ||||||
|    possibly associated :file:`.pyc` files).  Sometimes referred to as a |  | ||||||
|    "pure module." |  | ||||||
| 
 |  | ||||||
| extension module |  | ||||||
|    a module written in the low-level language of the Python implementation: C/C++ |  | ||||||
|    for Python, Java for Jython. Typically contained in a single dynamically |  | ||||||
|    loadable pre-compiled file, e.g. a shared object (:file:`.so`) file for Python |  | ||||||
|    extensions on Unix, a DLL (given the :file:`.pyd` extension) for Python |  | ||||||
|    extensions on Windows, or a Java class file for Jython extensions.  (Note that |  | ||||||
|    currently, the Distutils only handles C/C++ extensions for Python.) |  | ||||||
| 
 |  | ||||||
| package |  | ||||||
|    a module that contains other modules; typically contained in a directory in the |  | ||||||
|    filesystem and distinguished from other directories by the presence of a file |  | ||||||
|    :file:`__init__.py`. |  | ||||||
| 
 |  | ||||||
| root package |  | ||||||
|    the root of the hierarchy of packages.  (This isn't really a package, since it |  | ||||||
|    doesn't have an :file:`__init__.py` file.  But we have to call it something.) |  | ||||||
|    The vast majority of the standard library is in the root package, as are many |  | ||||||
|    small, standalone third-party modules that don't belong to a larger module |  | ||||||
|    collection. Unlike regular packages, modules in the root package can be found in |  | ||||||
|    many directories: in fact, every directory listed in ``sys.path`` contributes |  | ||||||
|    modules to the root package. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _distutils-term: |  | ||||||
| 
 |  | ||||||
| Distutils-specific terminology |  | ||||||
| ============================== |  | ||||||
| 
 |  | ||||||
| The following terms apply more specifically to the domain of distributing Python |  | ||||||
| modules using the Distutils: |  | ||||||
| 
 |  | ||||||
| module distribution |  | ||||||
|    a collection of Python modules distributed together as a single downloadable |  | ||||||
|    resource and meant to be installed *en masse*.  Examples of some well-known |  | ||||||
|    module distributions are NumPy, SciPy, Pillow, |  | ||||||
|    or mxBase.  (This would be called a *package*, except that term is |  | ||||||
|    already taken in the Python context: a single module distribution may contain |  | ||||||
|    zero, one, or many Python packages.) |  | ||||||
| 
 |  | ||||||
| pure module distribution |  | ||||||
|    a module distribution that contains only pure Python modules and packages. |  | ||||||
|    Sometimes referred to as a "pure distribution." |  | ||||||
| 
 |  | ||||||
| non-pure module distribution |  | ||||||
|    a module distribution that contains at least one extension module.  Sometimes |  | ||||||
|    referred to as a "non-pure distribution." |  | ||||||
| 
 |  | ||||||
| distribution root |  | ||||||
|    the top-level directory of your source tree (or  source distribution); the |  | ||||||
|    directory where :file:`setup.py` exists.  Generally  :file:`setup.py` will be |  | ||||||
|    run from this directory. |  | ||||||
							
								
								
									
										253
									
								
								third_party/python/Doc/distutils/packageindex.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										253
									
								
								third_party/python/Doc/distutils/packageindex.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,253 +0,0 @@ | ||||||
| .. index:: |  | ||||||
|    single: Python Package Index (PyPI) |  | ||||||
|    single: PyPI; (see Python Package Index (PyPI)) |  | ||||||
| 
 |  | ||||||
| .. _package-index: |  | ||||||
| 
 |  | ||||||
| ******************************* |  | ||||||
| The Python Package Index (PyPI) |  | ||||||
| ******************************* |  | ||||||
| 
 |  | ||||||
| The `Python Package Index (PyPI)`_ stores :ref:`meta-data <meta-data>` |  | ||||||
| describing distributions packaged with distutils, as well as package data like |  | ||||||
| distribution files if a package author wishes. |  | ||||||
| 
 |  | ||||||
| Distutils provides the :command:`register` and :command:`upload` commands for |  | ||||||
| pushing meta-data and distribution files to PyPI, respectively.  See |  | ||||||
| :ref:`package-commands` for information on these commands. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| PyPI overview |  | ||||||
| ============= |  | ||||||
| 
 |  | ||||||
| PyPI lets you submit any number of versions of your distribution to the index. |  | ||||||
| If you alter the meta-data for a particular version, you can submit it again |  | ||||||
| and the index will be updated. |  | ||||||
| 
 |  | ||||||
| PyPI holds a record for each (name, version) combination submitted.  The first |  | ||||||
| user to submit information for a given name is designated the Owner of that |  | ||||||
| name.  Changes can be submitted through the :command:`register` command or |  | ||||||
| through the web interface.  Owners can designate other users as Owners or |  | ||||||
| Maintainers.  Maintainers can edit the package information, but not designate |  | ||||||
| new Owners or Maintainers. |  | ||||||
| 
 |  | ||||||
| By default PyPI displays only the newest version of a given package.  The web |  | ||||||
| interface lets one change this default behavior and manually select which |  | ||||||
| versions to display and hide. |  | ||||||
| 
 |  | ||||||
| For each version, PyPI displays a home page.  The home page is created from |  | ||||||
| the ``long_description`` which can be submitted via the :command:`register` |  | ||||||
| command.  See :ref:`package-display` for more information. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _package-commands: |  | ||||||
| 
 |  | ||||||
| Distutils commands |  | ||||||
| ================== |  | ||||||
| 
 |  | ||||||
| Distutils exposes two commands for submitting package data to PyPI: the |  | ||||||
| :ref:`register <package-register>` command for submitting meta-data to PyPI |  | ||||||
| and the :ref:`upload <package-upload>` command for submitting distribution |  | ||||||
| files.  Both commands read configuration data from a special file called a |  | ||||||
| :ref:`.pypirc file <pypirc>`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _package-register: |  | ||||||
| 
 |  | ||||||
| The ``register`` command |  | ||||||
| ------------------------ |  | ||||||
| 
 |  | ||||||
| The distutils command :command:`register` is used to submit your distribution's |  | ||||||
| meta-data to an index server. It is invoked as follows:: |  | ||||||
| 
 |  | ||||||
|     python setup.py register |  | ||||||
| 
 |  | ||||||
| Distutils will respond with the following prompt:: |  | ||||||
| 
 |  | ||||||
|     running register |  | ||||||
|     We need to know who you are, so please choose either: |  | ||||||
|         1. use your existing login, |  | ||||||
|         2. register as a new user, |  | ||||||
|         3. have the server generate a new password for you (and email it to you), or |  | ||||||
|         4. quit |  | ||||||
|     Your selection [default 1]: |  | ||||||
| 
 |  | ||||||
| Note: if your username and password are saved locally, you will not see this |  | ||||||
| menu.  Also, refer to :ref:`pypirc` for how to store your credentials in a |  | ||||||
| :file:`.pypirc` file. |  | ||||||
| 
 |  | ||||||
| If you have not registered with PyPI, then you will need to do so now. You |  | ||||||
| should choose option 2, and enter your details as required. Soon after |  | ||||||
| submitting your details, you will receive an email which will be used to confirm |  | ||||||
| your registration. |  | ||||||
| 
 |  | ||||||
| Once you are registered, you may choose option 1 from the menu. You will be |  | ||||||
| prompted for your PyPI username and password, and :command:`register` will then |  | ||||||
| submit your meta-data to the index. |  | ||||||
| 
 |  | ||||||
| See :ref:`package-cmdoptions` for options to the :command:`register` command. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _package-upload: |  | ||||||
| 
 |  | ||||||
| The ``upload`` command |  | ||||||
| ---------------------- |  | ||||||
| 
 |  | ||||||
| The distutils command :command:`upload` pushes the distribution files to PyPI. |  | ||||||
| 
 |  | ||||||
| The command is invoked immediately after building one or more distribution |  | ||||||
| files.  For example, the command :: |  | ||||||
| 
 |  | ||||||
|     python setup.py sdist bdist_wininst upload |  | ||||||
| 
 |  | ||||||
| will cause the source distribution and the Windows installer to be uploaded to |  | ||||||
| PyPI.  Note that these will be uploaded even if they are built using an earlier |  | ||||||
| invocation of :file:`setup.py`, but that only distributions named on the command |  | ||||||
| line for the invocation including the :command:`upload` command are uploaded. |  | ||||||
| 
 |  | ||||||
| If a :command:`register` command was previously called in the same command, |  | ||||||
| and if the password was entered in the prompt, :command:`upload` will reuse the |  | ||||||
| entered password.  This is useful if you do not want to store a password in |  | ||||||
| clear text in a :file:`.pypirc` file. |  | ||||||
| 
 |  | ||||||
| You can use the ``--sign`` option to tell :command:`upload` to sign each |  | ||||||
| uploaded file using GPG (GNU Privacy Guard).  The  :program:`gpg` program must |  | ||||||
| be available for execution on the system :envvar:`PATH`.  You can also specify |  | ||||||
| which key to use for signing using the ``--identity=name`` option. |  | ||||||
| 
 |  | ||||||
| See :ref:`package-cmdoptions` for additional options to the :command:`upload` |  | ||||||
| command. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _package-cmdoptions: |  | ||||||
| 
 |  | ||||||
| Additional command options |  | ||||||
| -------------------------- |  | ||||||
| 
 |  | ||||||
| This section describes options common to both the :command:`register` and |  | ||||||
| :command:`upload` commands. |  | ||||||
| 
 |  | ||||||
| The ``--repository`` or ``-r`` option lets you specify a PyPI server |  | ||||||
| different from the default.  For example:: |  | ||||||
| 
 |  | ||||||
|     python setup.py sdist bdist_wininst upload -r https://example.com/pypi |  | ||||||
| 
 |  | ||||||
| For convenience, a name can be used in place of the URL when the |  | ||||||
| :file:`.pypirc` file is configured to do so.  For example:: |  | ||||||
| 
 |  | ||||||
|     python setup.py register -r other |  | ||||||
| 
 |  | ||||||
| See :ref:`pypirc` for more information on defining alternate servers. |  | ||||||
| 
 |  | ||||||
| The ``--show-response`` option displays the full response text from the PyPI |  | ||||||
| server, which is useful when debugging problems with registering and uploading. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. index:: |  | ||||||
|    single: .pypirc file |  | ||||||
|    single: Python Package Index (PyPI); .pypirc file |  | ||||||
| 
 |  | ||||||
| .. _pypirc: |  | ||||||
| 
 |  | ||||||
| The ``.pypirc`` file |  | ||||||
| -------------------- |  | ||||||
| 
 |  | ||||||
| The :command:`register` and :command:`upload` commands both check for the |  | ||||||
| existence of a :file:`.pypirc` file at the location :file:`$HOME/.pypirc`. |  | ||||||
| If this file exists, the command uses the username, password, and repository |  | ||||||
| URL configured in the file.  The format of a :file:`.pypirc` file is as |  | ||||||
| follows: |  | ||||||
| 
 |  | ||||||
| .. code-block:: ini |  | ||||||
| 
 |  | ||||||
|     [distutils] |  | ||||||
|     index-servers = |  | ||||||
|         pypi |  | ||||||
| 
 |  | ||||||
|     [pypi] |  | ||||||
|     repository: <repository-url> |  | ||||||
|     username: <username> |  | ||||||
|     password: <password> |  | ||||||
| 
 |  | ||||||
| The *distutils* section defines an *index-servers* variable that lists the |  | ||||||
| name of all sections describing a repository. |  | ||||||
| 
 |  | ||||||
| Each section describing a repository defines three variables: |  | ||||||
| 
 |  | ||||||
| - *repository*, that defines the url of the PyPI server. Defaults to |  | ||||||
|     ``https://upload.pypi.org/legacy/``. |  | ||||||
| - *username*, which is the registered username on the PyPI server. |  | ||||||
| - *password*, that will be used to authenticate. If omitted the user |  | ||||||
|     will be prompt to type it when needed. |  | ||||||
| 
 |  | ||||||
| If you want to define another server a new section can be created and |  | ||||||
| listed in the *index-servers* variable: |  | ||||||
| 
 |  | ||||||
| .. code-block:: ini |  | ||||||
| 
 |  | ||||||
|     [distutils] |  | ||||||
|     index-servers = |  | ||||||
|         pypi |  | ||||||
|         other |  | ||||||
| 
 |  | ||||||
|     [pypi] |  | ||||||
|     repository: <repository-url> |  | ||||||
|     username: <username> |  | ||||||
|     password: <password> |  | ||||||
| 
 |  | ||||||
|     [other] |  | ||||||
|     repository: https://example.com/pypi |  | ||||||
|     username: <username> |  | ||||||
|     password: <password> |  | ||||||
| 
 |  | ||||||
| This allows the :command:`register` and :command:`upload` commands to be |  | ||||||
| called with the ``--repository`` option as described in |  | ||||||
| :ref:`package-cmdoptions`. |  | ||||||
| 
 |  | ||||||
| Specifically, you might want to add the `PyPI Test Repository |  | ||||||
| <https://wiki.python.org/moin/TestPyPI>`_ to your ``.pypirc`` to facilitate |  | ||||||
| testing before doing your first upload to ``PyPI`` itself. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _package-display: |  | ||||||
| 
 |  | ||||||
| PyPI package display |  | ||||||
| ==================== |  | ||||||
| 
 |  | ||||||
| The ``long_description`` field plays a special role at PyPI. It is used by |  | ||||||
| the server to display a home page for the registered package. |  | ||||||
| 
 |  | ||||||
| If you use the `reStructuredText <http://docutils.sourceforge.net/rst.html>`_ |  | ||||||
| syntax for this field, PyPI will parse it and display an HTML output for |  | ||||||
| the package home page. |  | ||||||
| 
 |  | ||||||
| The ``long_description`` field can be attached to a text file located |  | ||||||
| in the package:: |  | ||||||
| 
 |  | ||||||
|     from distutils.core import setup |  | ||||||
| 
 |  | ||||||
|     with open('README.txt') as file: |  | ||||||
|         long_description = file.read() |  | ||||||
| 
 |  | ||||||
|     setup(name='Distutils', |  | ||||||
|           long_description=long_description) |  | ||||||
| 
 |  | ||||||
| In that case, :file:`README.txt` is a regular reStructuredText text file located |  | ||||||
| in the root of the package besides :file:`setup.py`. |  | ||||||
| 
 |  | ||||||
| To prevent registering broken reStructuredText content, you can use the |  | ||||||
| :program:`rst2html` program that is provided by the :mod:`docutils` package and |  | ||||||
| check the ``long_description`` from the command line: |  | ||||||
| 
 |  | ||||||
| .. code-block:: shell-session |  | ||||||
| 
 |  | ||||||
|     $ python setup.py --long-description | rst2html.py > output.html |  | ||||||
| 
 |  | ||||||
| :mod:`docutils` will display a warning if there's something wrong with your |  | ||||||
| syntax.  Because PyPI applies additional checks (e.g. by passing ``--no-raw`` |  | ||||||
| to ``rst2html.py`` in the command above), being able to run the command above |  | ||||||
| without warnings does not guarantee that PyPI will convert the content |  | ||||||
| successfully. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _Python Package Index (PyPI): https://pypi.org |  | ||||||
							
								
								
									
										695
									
								
								third_party/python/Doc/distutils/setupscript.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										695
									
								
								third_party/python/Doc/distutils/setupscript.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,695 +0,0 @@ | ||||||
| .. _setup-script: |  | ||||||
| 
 |  | ||||||
| ************************ |  | ||||||
| Writing the Setup Script |  | ||||||
| ************************ |  | ||||||
| 
 |  | ||||||
| The setup script is the centre of all activity in building, distributing, and |  | ||||||
| installing modules using the Distutils.  The main purpose of the setup script is |  | ||||||
| to describe your module distribution to the Distutils, so that the various |  | ||||||
| commands that operate on your modules do the right thing.  As we saw in section |  | ||||||
| :ref:`distutils-simple-example` above, the setup script consists mainly of a call to |  | ||||||
| :func:`setup`, and most information supplied to the Distutils by the module |  | ||||||
| developer is supplied as keyword arguments to :func:`setup`. |  | ||||||
| 
 |  | ||||||
| Here's a slightly more involved example, which we'll follow for the next couple |  | ||||||
| of sections: the Distutils' own setup script.  (Keep in mind that although the |  | ||||||
| Distutils are included with Python 1.6 and later, they also have an independent |  | ||||||
| existence so that Python 1.5.2 users can use them to install other module |  | ||||||
| distributions.  The Distutils' own setup script, shown here, is used to install |  | ||||||
| the package into Python 1.5.2.) :: |  | ||||||
| 
 |  | ||||||
|     #!/usr/bin/env python |  | ||||||
| 
 |  | ||||||
|     from distutils.core import setup |  | ||||||
| 
 |  | ||||||
|     setup(name='Distutils', |  | ||||||
|           version='1.0', |  | ||||||
|           description='Python Distribution Utilities', |  | ||||||
|           author='Greg Ward', |  | ||||||
|           author_email='gward@python.net', |  | ||||||
|           url='https://www.python.org/sigs/distutils-sig/', |  | ||||||
|           packages=['distutils', 'distutils.command'], |  | ||||||
|          ) |  | ||||||
| 
 |  | ||||||
| There are only two differences between this and the trivial one-file |  | ||||||
| distribution presented in section :ref:`distutils-simple-example`: more metadata, and the |  | ||||||
| specification of pure Python modules by package, rather than by module.  This is |  | ||||||
| important since the Distutils consist of a couple of dozen modules split into |  | ||||||
| (so far) two packages; an explicit list of every module would be tedious to |  | ||||||
| generate and difficult to maintain.  For more information on the additional |  | ||||||
| meta-data, see section :ref:`meta-data`. |  | ||||||
| 
 |  | ||||||
| Note that any pathnames (files or directories) supplied in the setup script |  | ||||||
| should be written using the Unix convention, i.e. slash-separated.  The |  | ||||||
| Distutils will take care of converting this platform-neutral representation into |  | ||||||
| whatever is appropriate on your current platform before actually using the |  | ||||||
| pathname.  This makes your setup script portable across operating systems, which |  | ||||||
| of course is one of the major goals of the Distutils.  In this spirit, all |  | ||||||
| pathnames in this document are slash-separated. |  | ||||||
| 
 |  | ||||||
| This, of course, only applies to pathnames given to Distutils functions.  If |  | ||||||
| you, for example, use standard Python functions such as :func:`glob.glob` or |  | ||||||
| :func:`os.listdir` to specify files, you should be careful to write portable |  | ||||||
| code instead of hardcoding path separators:: |  | ||||||
| 
 |  | ||||||
|     glob.glob(os.path.join('mydir', 'subdir', '*.html')) |  | ||||||
|     os.listdir(os.path.join('mydir', 'subdir')) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _listing-packages: |  | ||||||
| 
 |  | ||||||
| Listing whole packages |  | ||||||
| ====================== |  | ||||||
| 
 |  | ||||||
| The ``packages`` option tells the Distutils to process (build, distribute, |  | ||||||
| install, etc.) all pure Python modules found in each package mentioned in the |  | ||||||
| ``packages`` list.  In order to do this, of course, there has to be a |  | ||||||
| correspondence between package names and directories in the filesystem.  The |  | ||||||
| default correspondence is the most obvious one, i.e. package :mod:`distutils` is |  | ||||||
| found in the directory :file:`distutils` relative to the distribution root. |  | ||||||
| Thus, when you say ``packages = ['foo']`` in your setup script, you are |  | ||||||
| promising that the Distutils will find a file :file:`foo/__init__.py` (which |  | ||||||
| might be spelled differently on your system, but you get the idea) relative to |  | ||||||
| the directory where your setup script lives.  If you break this promise, the |  | ||||||
| Distutils will issue a warning but still process the broken package anyway. |  | ||||||
| 
 |  | ||||||
| If you use a different convention to lay out your source directory, that's no |  | ||||||
| problem: you just have to supply the ``package_dir`` option to tell the |  | ||||||
| Distutils about your convention.  For example, say you keep all Python source |  | ||||||
| under :file:`lib`, so that modules in the "root package" (i.e., not in any |  | ||||||
| package at all) are in :file:`lib`, modules in the :mod:`foo` package are in |  | ||||||
| :file:`lib/foo`, and so forth.  Then you would put :: |  | ||||||
| 
 |  | ||||||
|     package_dir = {'': 'lib'} |  | ||||||
| 
 |  | ||||||
| in your setup script.  The keys to this dictionary are package names, and an |  | ||||||
| empty package name stands for the root package.  The values are directory names |  | ||||||
| relative to your distribution root.  In this case, when you say ``packages = |  | ||||||
| ['foo']``, you are promising that the file :file:`lib/foo/__init__.py` exists. |  | ||||||
| 
 |  | ||||||
| Another possible convention is to put the :mod:`foo` package right in |  | ||||||
| :file:`lib`, the :mod:`foo.bar` package in :file:`lib/bar`, etc.  This would be |  | ||||||
| written in the setup script as :: |  | ||||||
| 
 |  | ||||||
|     package_dir = {'foo': 'lib'} |  | ||||||
| 
 |  | ||||||
| A ``package: dir`` entry in the ``package_dir`` dictionary implicitly |  | ||||||
| applies to all packages below *package*, so the :mod:`foo.bar` case is |  | ||||||
| automatically handled here.  In this example, having ``packages = ['foo', |  | ||||||
| 'foo.bar']`` tells the Distutils to look for :file:`lib/__init__.py` and |  | ||||||
| :file:`lib/bar/__init__.py`.  (Keep in mind that although ``package_dir`` |  | ||||||
| applies recursively, you must explicitly list all packages in |  | ||||||
| ``packages``: the Distutils will *not* recursively scan your source tree |  | ||||||
| looking for any directory with an :file:`__init__.py` file.) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _listing-modules: |  | ||||||
| 
 |  | ||||||
| Listing individual modules |  | ||||||
| ========================== |  | ||||||
| 
 |  | ||||||
| For a small module distribution, you might prefer to list all modules rather |  | ||||||
| than listing packages---especially the case of a single module that goes in the |  | ||||||
| "root package" (i.e., no package at all).  This simplest case was shown in |  | ||||||
| section :ref:`distutils-simple-example`; here is a slightly more involved example:: |  | ||||||
| 
 |  | ||||||
|     py_modules = ['mod1', 'pkg.mod2'] |  | ||||||
| 
 |  | ||||||
| This describes two modules, one of them in the "root" package, the other in the |  | ||||||
| :mod:`pkg` package.  Again, the default package/directory layout implies that |  | ||||||
| these two modules can be found in :file:`mod1.py` and :file:`pkg/mod2.py`, and |  | ||||||
| that :file:`pkg/__init__.py` exists as well. And again, you can override the |  | ||||||
| package/directory correspondence using the ``package_dir`` option. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _describing-extensions: |  | ||||||
| 
 |  | ||||||
| Describing extension modules |  | ||||||
| ============================ |  | ||||||
| 
 |  | ||||||
| Just as writing Python extension modules is a bit more complicated than writing |  | ||||||
| pure Python modules, describing them to the Distutils is a bit more complicated. |  | ||||||
| Unlike pure modules, it's not enough just to list modules or packages and expect |  | ||||||
| the Distutils to go out and find the right files; you have to specify the |  | ||||||
| extension name, source file(s), and any compile/link requirements (include |  | ||||||
| directories, libraries to link with, etc.). |  | ||||||
| 
 |  | ||||||
| .. XXX read over this section |  | ||||||
| 
 |  | ||||||
| All of this is done through another keyword argument to :func:`setup`, the |  | ||||||
| ``ext_modules`` option.  ``ext_modules`` is just a list of |  | ||||||
| :class:`~distutils.core.Extension` instances, each of which describes a |  | ||||||
| single extension module. |  | ||||||
| Suppose your distribution includes a single extension, called :mod:`foo` and |  | ||||||
| implemented by :file:`foo.c`.  If no additional instructions to the |  | ||||||
| compiler/linker are needed, describing this extension is quite simple:: |  | ||||||
| 
 |  | ||||||
|     Extension('foo', ['foo.c']) |  | ||||||
| 
 |  | ||||||
| The :class:`Extension` class can be imported from :mod:`distutils.core` along |  | ||||||
| with :func:`setup`.  Thus, the setup script for a module distribution that |  | ||||||
| contains only this one extension and nothing else might be:: |  | ||||||
| 
 |  | ||||||
|     from distutils.core import setup, Extension |  | ||||||
|     setup(name='foo', |  | ||||||
|           version='1.0', |  | ||||||
|           ext_modules=[Extension('foo', ['foo.c'])], |  | ||||||
|           ) |  | ||||||
| 
 |  | ||||||
| The :class:`Extension` class (actually, the underlying extension-building |  | ||||||
| machinery implemented by the :command:`build_ext` command) supports a great deal |  | ||||||
| of flexibility in describing Python extensions, which is explained in the |  | ||||||
| following sections. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Extension names and packages |  | ||||||
| ---------------------------- |  | ||||||
| 
 |  | ||||||
| The first argument to the :class:`~distutils.core.Extension` constructor is |  | ||||||
| always the name of the extension, including any package names.  For example, :: |  | ||||||
| 
 |  | ||||||
|     Extension('foo', ['src/foo1.c', 'src/foo2.c']) |  | ||||||
| 
 |  | ||||||
| describes an extension that lives in the root package, while :: |  | ||||||
| 
 |  | ||||||
|     Extension('pkg.foo', ['src/foo1.c', 'src/foo2.c']) |  | ||||||
| 
 |  | ||||||
| describes the same extension in the :mod:`pkg` package.  The source files and |  | ||||||
| resulting object code are identical in both cases; the only difference is where |  | ||||||
| in the filesystem (and therefore where in Python's namespace hierarchy) the |  | ||||||
| resulting extension lives. |  | ||||||
| 
 |  | ||||||
| If you have a number of extensions all in the same package (or all under the |  | ||||||
| same base package), use the ``ext_package`` keyword argument to |  | ||||||
| :func:`setup`.  For example, :: |  | ||||||
| 
 |  | ||||||
|     setup(..., |  | ||||||
|           ext_package='pkg', |  | ||||||
|           ext_modules=[Extension('foo', ['foo.c']), |  | ||||||
|                        Extension('subpkg.bar', ['bar.c'])], |  | ||||||
|          ) |  | ||||||
| 
 |  | ||||||
| will compile :file:`foo.c` to the extension :mod:`pkg.foo`, and :file:`bar.c` to |  | ||||||
| :mod:`pkg.subpkg.bar`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Extension source files |  | ||||||
| ---------------------- |  | ||||||
| 
 |  | ||||||
| The second argument to the :class:`~distutils.core.Extension` constructor is |  | ||||||
| a list of source |  | ||||||
| files.  Since the Distutils currently only support C, C++, and Objective-C |  | ||||||
| extensions, these are normally C/C++/Objective-C source files.  (Be sure to use |  | ||||||
| appropriate extensions to distinguish C++ source files: :file:`.cc` and |  | ||||||
| :file:`.cpp` seem to be recognized by both Unix and Windows compilers.) |  | ||||||
| 
 |  | ||||||
| However, you can also include SWIG interface (:file:`.i`) files in the list; the |  | ||||||
| :command:`build_ext` command knows how to deal with SWIG extensions: it will run |  | ||||||
| SWIG on the interface file and compile the resulting C/C++ file into your |  | ||||||
| extension. |  | ||||||
| 
 |  | ||||||
| .. XXX SWIG support is rough around the edges and largely untested! |  | ||||||
| 
 |  | ||||||
| This warning notwithstanding, options to SWIG can be currently passed like |  | ||||||
| this:: |  | ||||||
| 
 |  | ||||||
|     setup(..., |  | ||||||
|           ext_modules=[Extension('_foo', ['foo.i'], |  | ||||||
|                                  swig_opts=['-modern', '-I../include'])], |  | ||||||
|           py_modules=['foo'], |  | ||||||
|          ) |  | ||||||
| 
 |  | ||||||
| Or on the commandline like this:: |  | ||||||
| 
 |  | ||||||
|     > python setup.py build_ext --swig-opts="-modern -I../include" |  | ||||||
| 
 |  | ||||||
| On some platforms, you can include non-source files that are processed by the |  | ||||||
| compiler and included in your extension.  Currently, this just means Windows |  | ||||||
| message text (:file:`.mc`) files and resource definition (:file:`.rc`) files for |  | ||||||
| Visual C++. These will be compiled to binary resource (:file:`.res`) files and |  | ||||||
| linked into the executable. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Preprocessor options |  | ||||||
| -------------------- |  | ||||||
| 
 |  | ||||||
| Three optional arguments to :class:`~distutils.core.Extension` will help if |  | ||||||
| you need to specify include directories to search or preprocessor macros to |  | ||||||
| define/undefine: ``include_dirs``, ``define_macros``, and ``undef_macros``. |  | ||||||
| 
 |  | ||||||
| For example, if your extension requires header files in the :file:`include` |  | ||||||
| directory under your distribution root, use the ``include_dirs`` option:: |  | ||||||
| 
 |  | ||||||
|     Extension('foo', ['foo.c'], include_dirs=['include']) |  | ||||||
| 
 |  | ||||||
| You can specify absolute directories there; if you know that your extension will |  | ||||||
| only be built on Unix systems with X11R6 installed to :file:`/usr`, you can get |  | ||||||
| away with :: |  | ||||||
| 
 |  | ||||||
|     Extension('foo', ['foo.c'], include_dirs=['/usr/include/X11']) |  | ||||||
| 
 |  | ||||||
| You should avoid this sort of non-portable usage if you plan to distribute your |  | ||||||
| code: it's probably better to write C code like  :: |  | ||||||
| 
 |  | ||||||
|     #include <X11/Xlib.h> |  | ||||||
| 
 |  | ||||||
| If you need to include header files from some other Python extension, you can |  | ||||||
| take advantage of the fact that header files are installed in a consistent way |  | ||||||
| by the Distutils :command:`install_headers` command.  For example, the Numerical |  | ||||||
| Python header files are installed (on a standard Unix installation) to |  | ||||||
| :file:`/usr/local/include/python1.5/Numerical`. (The exact location will differ |  | ||||||
| according to your platform and Python installation.)  Since the Python include |  | ||||||
| directory---\ :file:`/usr/local/include/python1.5` in this case---is always |  | ||||||
| included in the search path when building Python extensions, the best approach |  | ||||||
| is to write C code like  :: |  | ||||||
| 
 |  | ||||||
|     #include <Numerical/arrayobject.h> |  | ||||||
| 
 |  | ||||||
| If you must put the :file:`Numerical` include directory right into your header |  | ||||||
| search path, though, you can find that directory using the Distutils |  | ||||||
| :mod:`distutils.sysconfig` module:: |  | ||||||
| 
 |  | ||||||
|     from distutils.sysconfig import get_python_inc |  | ||||||
|     incdir = os.path.join(get_python_inc(plat_specific=1), 'Numerical') |  | ||||||
|     setup(..., |  | ||||||
|           Extension(..., include_dirs=[incdir]), |  | ||||||
|           ) |  | ||||||
| 
 |  | ||||||
| Even though this is quite portable---it will work on any Python installation, |  | ||||||
| regardless of platform---it's probably easier to just write your C code in the |  | ||||||
| sensible way. |  | ||||||
| 
 |  | ||||||
| You can define and undefine pre-processor macros with the ``define_macros`` and |  | ||||||
| ``undef_macros`` options. ``define_macros`` takes a list of ``(name, value)`` |  | ||||||
| tuples, where ``name`` is the name of the macro to define (a string) and |  | ||||||
| ``value`` is its value: either a string or ``None``.  (Defining a macro ``FOO`` |  | ||||||
| to ``None`` is the equivalent of a bare ``#define FOO`` in your C source: with |  | ||||||
| most compilers, this sets ``FOO`` to the string ``1``.)  ``undef_macros`` is |  | ||||||
| just a list of macros to undefine. |  | ||||||
| 
 |  | ||||||
| For example:: |  | ||||||
| 
 |  | ||||||
|     Extension(..., |  | ||||||
|               define_macros=[('NDEBUG', '1'), |  | ||||||
|                              ('HAVE_STRFTIME', None)], |  | ||||||
|               undef_macros=['HAVE_FOO', 'HAVE_BAR']) |  | ||||||
| 
 |  | ||||||
| is the equivalent of having this at the top of every C source file:: |  | ||||||
| 
 |  | ||||||
|     #define NDEBUG 1 |  | ||||||
|     #define HAVE_STRFTIME |  | ||||||
|     #undef HAVE_FOO |  | ||||||
|     #undef HAVE_BAR |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Library options |  | ||||||
| --------------- |  | ||||||
| 
 |  | ||||||
| You can also specify the libraries to link against when building your extension, |  | ||||||
| and the directories to search for those libraries.  The ``libraries`` option is |  | ||||||
| a list of libraries to link against, ``library_dirs`` is a list of directories |  | ||||||
| to search for libraries at  link-time, and ``runtime_library_dirs`` is a list of |  | ||||||
| directories to  search for shared (dynamically loaded) libraries at run-time. |  | ||||||
| 
 |  | ||||||
| For example, if you need to link against libraries known to be in the standard |  | ||||||
| library search path on target systems :: |  | ||||||
| 
 |  | ||||||
|     Extension(..., |  | ||||||
|               libraries=['gdbm', 'readline']) |  | ||||||
| 
 |  | ||||||
| If you need to link with libraries in a non-standard location, you'll have to |  | ||||||
| include the location in ``library_dirs``:: |  | ||||||
| 
 |  | ||||||
|     Extension(..., |  | ||||||
|               library_dirs=['/usr/X11R6/lib'], |  | ||||||
|               libraries=['X11', 'Xt']) |  | ||||||
| 
 |  | ||||||
| (Again, this sort of non-portable construct should be avoided if you intend to |  | ||||||
| distribute your code.) |  | ||||||
| 
 |  | ||||||
| .. XXX Should mention clib libraries here or somewhere else! |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| Other options |  | ||||||
| ------------- |  | ||||||
| 
 |  | ||||||
| There are still some other options which can be used to handle special cases. |  | ||||||
| 
 |  | ||||||
| The ``optional`` option is a boolean; if it is true, |  | ||||||
| a build failure in the extension will not abort the build process, but |  | ||||||
| instead simply not install the failing extension. |  | ||||||
| 
 |  | ||||||
| The ``extra_objects`` option is a list of object files to be passed to the |  | ||||||
| linker. These files must not have extensions, as the default extension for the |  | ||||||
| compiler is used. |  | ||||||
| 
 |  | ||||||
| ``extra_compile_args`` and ``extra_link_args`` can be used to |  | ||||||
| specify additional command line options for the respective compiler and linker |  | ||||||
| command lines. |  | ||||||
| 
 |  | ||||||
| ``export_symbols`` is only useful on Windows.  It can contain a list of |  | ||||||
| symbols (functions or variables) to be exported. This option is not needed when |  | ||||||
| building compiled extensions: Distutils  will automatically add ``initmodule`` |  | ||||||
| to the list of exported symbols. |  | ||||||
| 
 |  | ||||||
| The ``depends`` option is a list of files that the extension depends on |  | ||||||
| (for example header files). The build command will call the compiler on the |  | ||||||
| sources to rebuild extension if any on this files has been modified since the |  | ||||||
| previous build. |  | ||||||
| 
 |  | ||||||
| Relationships between Distributions and Packages |  | ||||||
| ================================================ |  | ||||||
| 
 |  | ||||||
| A distribution may relate to packages in three specific ways: |  | ||||||
| 
 |  | ||||||
| #. It can require packages or modules. |  | ||||||
| 
 |  | ||||||
| #. It can provide packages or modules. |  | ||||||
| 
 |  | ||||||
| #. It can obsolete packages or modules. |  | ||||||
| 
 |  | ||||||
| These relationships can be specified using keyword arguments to the |  | ||||||
| :func:`distutils.core.setup` function. |  | ||||||
| 
 |  | ||||||
| Dependencies on other Python modules and packages can be specified by supplying |  | ||||||
| the *requires* keyword argument to :func:`setup`. The value must be a list of |  | ||||||
| strings.  Each string specifies a package that is required, and optionally what |  | ||||||
| versions are sufficient. |  | ||||||
| 
 |  | ||||||
| To specify that any version of a module or package is required, the string |  | ||||||
| should consist entirely of the module or package name. Examples include |  | ||||||
| ``'mymodule'`` and ``'xml.parsers.expat'``. |  | ||||||
| 
 |  | ||||||
| If specific versions are required, a sequence of qualifiers can be supplied in |  | ||||||
| parentheses.  Each qualifier may consist of a comparison operator and a version |  | ||||||
| number.  The accepted comparison operators are:: |  | ||||||
| 
 |  | ||||||
|     <    >    == |  | ||||||
|     <=   >=   != |  | ||||||
| 
 |  | ||||||
| These can be combined by using multiple qualifiers separated by commas (and |  | ||||||
| optional whitespace).  In this case, all of the qualifiers must be matched; a |  | ||||||
| logical AND is used to combine the evaluations. |  | ||||||
| 
 |  | ||||||
| Let's look at a bunch of examples: |  | ||||||
| 
 |  | ||||||
| +-------------------------+----------------------------------------------+ |  | ||||||
| | Requires Expression     | Explanation                                  | |  | ||||||
| +=========================+==============================================+ |  | ||||||
| | ``==1.0``               | Only version ``1.0`` is compatible           | |  | ||||||
| +-------------------------+----------------------------------------------+ |  | ||||||
| | ``>1.0, !=1.5.1, <2.0`` | Any version after ``1.0`` and before ``2.0`` | |  | ||||||
| |                         | is compatible, except ``1.5.1``              | |  | ||||||
| +-------------------------+----------------------------------------------+ |  | ||||||
| 
 |  | ||||||
| Now that we can specify dependencies, we also need to be able to specify what we |  | ||||||
| provide that other distributions can require.  This is done using the *provides* |  | ||||||
| keyword argument to :func:`setup`. The value for this keyword is a list of |  | ||||||
| strings, each of which names a Python module or package, and optionally |  | ||||||
| identifies the version.  If the version is not specified, it is assumed to match |  | ||||||
| that of the distribution. |  | ||||||
| 
 |  | ||||||
| Some examples: |  | ||||||
| 
 |  | ||||||
| +---------------------+----------------------------------------------+ |  | ||||||
| | Provides Expression | Explanation                                  | |  | ||||||
| +=====================+==============================================+ |  | ||||||
| | ``mypkg``           | Provide ``mypkg``, using the distribution    | |  | ||||||
| |                     | version                                      | |  | ||||||
| +---------------------+----------------------------------------------+ |  | ||||||
| | ``mypkg (1.1)``     | Provide ``mypkg`` version 1.1, regardless of | |  | ||||||
| |                     | the distribution version                     | |  | ||||||
| +---------------------+----------------------------------------------+ |  | ||||||
| 
 |  | ||||||
| A package can declare that it obsoletes other packages using the *obsoletes* |  | ||||||
| keyword argument.  The value for this is similar to that of the *requires* |  | ||||||
| keyword: a list of strings giving module or package specifiers.  Each specifier |  | ||||||
| consists of a module or package name optionally followed by one or more version |  | ||||||
| qualifiers.  Version qualifiers are given in parentheses after the module or |  | ||||||
| package name. |  | ||||||
| 
 |  | ||||||
| The versions identified by the qualifiers are those that are obsoleted by the |  | ||||||
| distribution being described.  If no qualifiers are given, all versions of the |  | ||||||
| named module or package are understood to be obsoleted. |  | ||||||
| 
 |  | ||||||
| .. _distutils-installing-scripts: |  | ||||||
| 
 |  | ||||||
| Installing Scripts |  | ||||||
| ================== |  | ||||||
| 
 |  | ||||||
| So far we have been dealing with pure and non-pure Python modules, which are |  | ||||||
| usually not run by themselves but imported by scripts. |  | ||||||
| 
 |  | ||||||
| Scripts are files containing Python source code, intended to be started from the |  | ||||||
| command line.  Scripts don't require Distutils to do anything very complicated. |  | ||||||
| The only clever feature is that if the first line of the script starts with |  | ||||||
| ``#!`` and contains the word "python", the Distutils will adjust the first line |  | ||||||
| to refer to the current interpreter location. By default, it is replaced with |  | ||||||
| the current interpreter location.  The :option:`!--executable` (or :option:`!-e`) |  | ||||||
| option will allow the interpreter path to be explicitly overridden. |  | ||||||
| 
 |  | ||||||
| The ``scripts`` option simply is a list of files to be handled in this |  | ||||||
| way.  From the PyXML setup script:: |  | ||||||
| 
 |  | ||||||
|     setup(..., |  | ||||||
|           scripts=['scripts/xmlproc_parse', 'scripts/xmlproc_val'] |  | ||||||
|           ) |  | ||||||
| 
 |  | ||||||
| .. versionchanged:: 3.1 |  | ||||||
|    All the scripts will also be added to the ``MANIFEST`` file if no template is |  | ||||||
|    provided.  See :ref:`manifest`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _distutils-installing-package-data: |  | ||||||
| 
 |  | ||||||
| Installing Package Data |  | ||||||
| ======================= |  | ||||||
| 
 |  | ||||||
| Often, additional files need to be installed into a package.  These files are |  | ||||||
| often data that's closely related to the package's implementation, or text files |  | ||||||
| containing documentation that might be of interest to programmers using the |  | ||||||
| package.  These files are called :dfn:`package data`. |  | ||||||
| 
 |  | ||||||
| Package data can be added to packages using the ``package_data`` keyword |  | ||||||
| argument to the :func:`setup` function.  The value must be a mapping from |  | ||||||
| package name to a list of relative path names that should be copied into the |  | ||||||
| package.  The paths are interpreted as relative to the directory containing the |  | ||||||
| package (information from the ``package_dir`` mapping is used if appropriate); |  | ||||||
| that is, the files are expected to be part of the package in the source |  | ||||||
| directories. They may contain glob patterns as well. |  | ||||||
| 
 |  | ||||||
| The path names may contain directory portions; any necessary directories will be |  | ||||||
| created in the installation. |  | ||||||
| 
 |  | ||||||
| For example, if a package should contain a subdirectory with several data files, |  | ||||||
| the files can be arranged like this in the source tree:: |  | ||||||
| 
 |  | ||||||
|     setup.py |  | ||||||
|     src/ |  | ||||||
|         mypkg/ |  | ||||||
|             __init__.py |  | ||||||
|             module.py |  | ||||||
|             data/ |  | ||||||
|                 tables.dat |  | ||||||
|                 spoons.dat |  | ||||||
|                 forks.dat |  | ||||||
| 
 |  | ||||||
| The corresponding call to :func:`setup` might be:: |  | ||||||
| 
 |  | ||||||
|     setup(..., |  | ||||||
|           packages=['mypkg'], |  | ||||||
|           package_dir={'mypkg': 'src/mypkg'}, |  | ||||||
|           package_data={'mypkg': ['data/*.dat']}, |  | ||||||
|           ) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. versionchanged:: 3.1 |  | ||||||
|    All the files that match ``package_data`` will be added to the ``MANIFEST`` |  | ||||||
|    file if no template is provided.  See :ref:`manifest`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _distutils-additional-files: |  | ||||||
| 
 |  | ||||||
| Installing Additional Files |  | ||||||
| =========================== |  | ||||||
| 
 |  | ||||||
| The ``data_files`` option can be used to specify additional files needed |  | ||||||
| by the module distribution: configuration files, message catalogs, data files, |  | ||||||
| anything which doesn't fit in the previous categories. |  | ||||||
| 
 |  | ||||||
| ``data_files`` specifies a sequence of (*directory*, *files*) pairs in the |  | ||||||
| following way:: |  | ||||||
| 
 |  | ||||||
|     setup(..., |  | ||||||
|           data_files=[('bitmaps', ['bm/b1.gif', 'bm/b2.gif']), |  | ||||||
|                       ('config', ['cfg/data.cfg']), |  | ||||||
|                       ('/etc/init.d', ['init-script'])] |  | ||||||
|          ) |  | ||||||
| 
 |  | ||||||
| Note that you can specify the directory names where the data files will be |  | ||||||
| installed, but you cannot rename the data files themselves. |  | ||||||
| 
 |  | ||||||
| Each (*directory*, *files*) pair in the sequence specifies the installation |  | ||||||
| directory and the files to install there.  If *directory* is a relative path, it |  | ||||||
| is interpreted relative to the installation prefix (Python's ``sys.prefix`` for |  | ||||||
| pure-Python packages, ``sys.exec_prefix`` for packages that contain extension |  | ||||||
| modules).  Each file name in *files* is interpreted relative to the |  | ||||||
| :file:`setup.py` script at the top of the package source distribution.  No |  | ||||||
| directory information from *files* is used to determine the final location of |  | ||||||
| the installed file; only the name of the file is used. |  | ||||||
| 
 |  | ||||||
| You can specify the ``data_files`` options as a simple sequence of files |  | ||||||
| without specifying a target directory, but this is not recommended, and the |  | ||||||
| :command:`install` command will print a warning in this case. To install data |  | ||||||
| files directly in the target directory, an empty string should be given as the |  | ||||||
| directory. |  | ||||||
| 
 |  | ||||||
| .. versionchanged:: 3.1 |  | ||||||
|    All the files that match ``data_files`` will be added to the ``MANIFEST`` |  | ||||||
|    file if no template is provided.  See :ref:`manifest`. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _meta-data: |  | ||||||
| 
 |  | ||||||
| Additional meta-data |  | ||||||
| ==================== |  | ||||||
| 
 |  | ||||||
| The setup script may include additional meta-data beyond the name and version. |  | ||||||
| This information includes: |  | ||||||
| 
 |  | ||||||
| +----------------------+---------------------------+-----------------+--------+ |  | ||||||
| | Meta-Data            | Description               | Value           | Notes  | |  | ||||||
| +======================+===========================+=================+========+ |  | ||||||
| | ``name``             | name of the package       | short string    | \(1)   | |  | ||||||
| +----------------------+---------------------------+-----------------+--------+ |  | ||||||
| | ``version``          | version of this release   | short string    | (1)(2) | |  | ||||||
| +----------------------+---------------------------+-----------------+--------+ |  | ||||||
| | ``author``           | package author's name     | short string    | \(3)   | |  | ||||||
| +----------------------+---------------------------+-----------------+--------+ |  | ||||||
| | ``author_email``     | email address of the      | email address   | \(3)   | |  | ||||||
| |                      | package author            |                 |        | |  | ||||||
| +----------------------+---------------------------+-----------------+--------+ |  | ||||||
| | ``maintainer``       | package maintainer's name | short string    | \(3)   | |  | ||||||
| +----------------------+---------------------------+-----------------+--------+ |  | ||||||
| | ``maintainer_email`` | email address of the      | email address   | \(3)   | |  | ||||||
| |                      | package maintainer        |                 |        | |  | ||||||
| +----------------------+---------------------------+-----------------+--------+ |  | ||||||
| | ``url``              | home page for the package | URL             | \(1)   | |  | ||||||
| +----------------------+---------------------------+-----------------+--------+ |  | ||||||
| | ``description``      | short, summary            | short string    |        | |  | ||||||
| |                      | description of the        |                 |        | |  | ||||||
| |                      | package                   |                 |        | |  | ||||||
| +----------------------+---------------------------+-----------------+--------+ |  | ||||||
| | ``long_description`` | longer description of the | long string     | \(5)   | |  | ||||||
| |                      | package                   |                 |        | |  | ||||||
| +----------------------+---------------------------+-----------------+--------+ |  | ||||||
| | ``download_url``     | location where the        | URL             | \(4)   | |  | ||||||
| |                      | package may be downloaded |                 |        | |  | ||||||
| +----------------------+---------------------------+-----------------+--------+ |  | ||||||
| | ``classifiers``      | a list of classifiers     | list of strings | \(4)   | |  | ||||||
| +----------------------+---------------------------+-----------------+--------+ |  | ||||||
| | ``platforms``        | a list of platforms       | list of strings |        | |  | ||||||
| +----------------------+---------------------------+-----------------+--------+ |  | ||||||
| | ``license``          | license for the package   | short string    | \(6)   | |  | ||||||
| +----------------------+---------------------------+-----------------+--------+ |  | ||||||
| 
 |  | ||||||
| Notes: |  | ||||||
| 
 |  | ||||||
| (1) |  | ||||||
|     These fields are required. |  | ||||||
| 
 |  | ||||||
| (2) |  | ||||||
|     It is recommended that versions take the form *major.minor[.patch[.sub]]*. |  | ||||||
| 
 |  | ||||||
| (3) |  | ||||||
|     Either the author or the maintainer must be identified. If maintainer is |  | ||||||
|     provided, distutils lists it as the author in :file:`PKG-INFO`. |  | ||||||
| 
 |  | ||||||
| (4) |  | ||||||
|     These fields should not be used if your package is to be compatible with Python |  | ||||||
|     versions prior to 2.2.3 or 2.3.  The list is available from the `PyPI website |  | ||||||
|     <https://pypi.org/>`_. |  | ||||||
| 
 |  | ||||||
| (5) |  | ||||||
|     The ``long_description`` field is used by PyPI when you are |  | ||||||
|     :ref:`registering <package-register>` a package, to |  | ||||||
|     :ref:`build its home page <package-display>`. |  | ||||||
| 
 |  | ||||||
| (6) |  | ||||||
|     The ``license`` field is a text indicating the license covering the |  | ||||||
|     package where the license is not a selection from the "License" Trove |  | ||||||
|     classifiers. See the ``Classifier`` field. Notice that |  | ||||||
|     there's a ``licence`` distribution option which is deprecated but still |  | ||||||
|     acts as an alias for ``license``. |  | ||||||
| 
 |  | ||||||
| 'short string' |  | ||||||
|     A single line of text, not more than 200 characters. |  | ||||||
| 
 |  | ||||||
| 'long string' |  | ||||||
|     Multiple lines of plain text in reStructuredText format (see |  | ||||||
|     http://docutils.sourceforge.net/). |  | ||||||
| 
 |  | ||||||
| 'list of strings' |  | ||||||
|     See below. |  | ||||||
| 
 |  | ||||||
| Encoding the version information is an art in itself. Python packages generally |  | ||||||
| adhere to the version format *major.minor[.patch][sub]*. The major number is 0 |  | ||||||
| for initial, experimental releases of software. It is incremented for releases |  | ||||||
| that represent major milestones in a package. The minor number is incremented |  | ||||||
| when important new features are added to the package. The patch number |  | ||||||
| increments when bug-fix releases are made. Additional trailing version |  | ||||||
| information is sometimes used to indicate sub-releases.  These are |  | ||||||
| "a1,a2,...,aN" (for alpha releases, where functionality and API may change), |  | ||||||
| "b1,b2,...,bN" (for beta releases, which only fix bugs) and "pr1,pr2,...,prN" |  | ||||||
| (for final pre-release release testing). Some examples: |  | ||||||
| 
 |  | ||||||
| 0.1.0 |  | ||||||
|     the first, experimental release of a package |  | ||||||
| 
 |  | ||||||
| 1.0.1a2 |  | ||||||
|     the second alpha release of the first patch version of 1.0 |  | ||||||
| 
 |  | ||||||
| ``classifiers`` are specified in a Python list:: |  | ||||||
| 
 |  | ||||||
|     setup(..., |  | ||||||
|           classifiers=[ |  | ||||||
|               'Development Status :: 4 - Beta', |  | ||||||
|               'Environment :: Console', |  | ||||||
|               'Environment :: Web Environment', |  | ||||||
|               'Intended Audience :: End Users/Desktop', |  | ||||||
|               'Intended Audience :: Developers', |  | ||||||
|               'Intended Audience :: System Administrators', |  | ||||||
|               'License :: OSI Approved :: Python Software Foundation License', |  | ||||||
|               'Operating System :: MacOS :: MacOS X', |  | ||||||
|               'Operating System :: Microsoft :: Windows', |  | ||||||
|               'Operating System :: POSIX', |  | ||||||
|               'Programming Language :: Python', |  | ||||||
|               'Topic :: Communications :: Email', |  | ||||||
|               'Topic :: Office/Business', |  | ||||||
|               'Topic :: Software Development :: Bug Tracking', |  | ||||||
|               ], |  | ||||||
|           ) |  | ||||||
| 
 |  | ||||||
| .. _debug-setup-script: |  | ||||||
| 
 |  | ||||||
| Debugging the setup script |  | ||||||
| ========================== |  | ||||||
| 
 |  | ||||||
| Sometimes things go wrong, and the setup script doesn't do what the developer |  | ||||||
| wants. |  | ||||||
| 
 |  | ||||||
| Distutils catches any exceptions when running the setup script, and print a |  | ||||||
| simple error message before the script is terminated.  The motivation for this |  | ||||||
| behaviour is to not confuse administrators who don't know much about Python and |  | ||||||
| are trying to install a package.  If they get a big long traceback from deep |  | ||||||
| inside the guts of Distutils, they may think the package or the Python |  | ||||||
| installation is broken because they don't read all the way down to the bottom |  | ||||||
| and see that it's a permission problem. |  | ||||||
| 
 |  | ||||||
| On the other hand, this doesn't help the developer to find the cause of the |  | ||||||
| failure. For this purpose, the :envvar:`DISTUTILS_DEBUG` environment variable can be set |  | ||||||
| to anything except an empty string, and distutils will now print detailed |  | ||||||
| information about what it is doing, dump the full traceback when an exception |  | ||||||
| occurs, and print the whole command line when an external program (like a C |  | ||||||
| compiler) fails. |  | ||||||
							
								
								
									
										236
									
								
								third_party/python/Doc/distutils/sourcedist.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										236
									
								
								third_party/python/Doc/distutils/sourcedist.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,236 +0,0 @@ | ||||||
| .. _source-dist: |  | ||||||
| 
 |  | ||||||
| ****************************** |  | ||||||
| Creating a Source Distribution |  | ||||||
| ****************************** |  | ||||||
| 
 |  | ||||||
| As shown in section :ref:`distutils-simple-example`, you use the :command:`sdist` command |  | ||||||
| to create a source distribution.  In the simplest case, :: |  | ||||||
| 
 |  | ||||||
|    python setup.py sdist |  | ||||||
| 
 |  | ||||||
| (assuming you haven't specified any :command:`sdist` options in the setup script |  | ||||||
| or config file), :command:`sdist` creates the archive of the default format for |  | ||||||
| the current platform.  The default format is a gzip'ed tar file |  | ||||||
| (:file:`.tar.gz`) on Unix, and ZIP file on Windows. |  | ||||||
| 
 |  | ||||||
| You can specify as many formats as you like using the :option:`!--formats` |  | ||||||
| option, for example:: |  | ||||||
| 
 |  | ||||||
|    python setup.py sdist --formats=gztar,zip |  | ||||||
| 
 |  | ||||||
| to create a gzipped tarball and a zip file.  The available formats are: |  | ||||||
| 
 |  | ||||||
| +-----------+-------------------------+---------+ |  | ||||||
| | Format    | Description             | Notes   | |  | ||||||
| +===========+=========================+=========+ |  | ||||||
| | ``zip``   | zip file (:file:`.zip`) | (1),(3) | |  | ||||||
| +-----------+-------------------------+---------+ |  | ||||||
| | ``gztar`` | gzip'ed tar file        | \(2)    | |  | ||||||
| |           | (:file:`.tar.gz`)       |         | |  | ||||||
| +-----------+-------------------------+---------+ |  | ||||||
| | ``bztar`` | bzip2'ed tar file       |         | |  | ||||||
| |           | (:file:`.tar.bz2`)      |         | |  | ||||||
| +-----------+-------------------------+---------+ |  | ||||||
| | ``xztar`` | xz'ed tar file          |         | |  | ||||||
| |           | (:file:`.tar.xz`)       |         | |  | ||||||
| +-----------+-------------------------+---------+ |  | ||||||
| | ``ztar``  | compressed tar file     | \(4)    | |  | ||||||
| |           | (:file:`.tar.Z`)        |         | |  | ||||||
| +-----------+-------------------------+---------+ |  | ||||||
| | ``tar``   | tar file (:file:`.tar`) |         | |  | ||||||
| +-----------+-------------------------+---------+ |  | ||||||
| 
 |  | ||||||
| .. versionchanged:: 3.5 |  | ||||||
|    Added support for the ``xztar`` format. |  | ||||||
| 
 |  | ||||||
| Notes: |  | ||||||
| 
 |  | ||||||
| (1) |  | ||||||
|    default on Windows |  | ||||||
| 
 |  | ||||||
| (2) |  | ||||||
|    default on Unix |  | ||||||
| 
 |  | ||||||
| (3) |  | ||||||
|    requires either external :program:`zip` utility or :mod:`zipfile` module (part |  | ||||||
|    of the standard Python library since Python 1.6) |  | ||||||
| 
 |  | ||||||
| (4) |  | ||||||
|    requires the :program:`compress` program. Notice that this format is now |  | ||||||
|    pending for deprecation and will be removed in the future versions of Python. |  | ||||||
| 
 |  | ||||||
| When using any ``tar`` format (``gztar``, ``bztar``, ``xztar``, ``ztar`` or |  | ||||||
| ``tar``), under Unix you can specify the ``owner`` and ``group`` names |  | ||||||
| that will be set for each member of the archive. |  | ||||||
| 
 |  | ||||||
| For example, if you want all files of the archive to be owned by root:: |  | ||||||
| 
 |  | ||||||
|     python setup.py sdist --owner=root --group=root |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _manifest: |  | ||||||
| 
 |  | ||||||
| Specifying the files to distribute |  | ||||||
| ================================== |  | ||||||
| 
 |  | ||||||
| If you don't supply an explicit list of files (or instructions on how to |  | ||||||
| generate one), the :command:`sdist` command puts a minimal default set into the |  | ||||||
| source distribution: |  | ||||||
| 
 |  | ||||||
| * all Python source files implied by the ``py_modules`` and |  | ||||||
|   ``packages`` options |  | ||||||
| 
 |  | ||||||
| * all C source files mentioned in the ``ext_modules`` or |  | ||||||
|   ``libraries`` options |  | ||||||
| 
 |  | ||||||
|   .. XXX getting C library sources currently broken---no |  | ||||||
|          :meth:`get_source_files` method in :file:`build_clib.py`! |  | ||||||
| 
 |  | ||||||
| * scripts identified by the ``scripts`` option |  | ||||||
|   See :ref:`distutils-installing-scripts`. |  | ||||||
| 
 |  | ||||||
| * anything that looks like a test script: :file:`test/test\*.py` (currently, the |  | ||||||
|   Distutils don't do anything with test scripts except include them in source |  | ||||||
|   distributions, but in the future there will be a standard for testing Python |  | ||||||
|   module distributions) |  | ||||||
| 
 |  | ||||||
| * :file:`README.txt` (or :file:`README`), :file:`setup.py` (or whatever  you |  | ||||||
|   called your setup script), and :file:`setup.cfg` |  | ||||||
| 
 |  | ||||||
| * all files that matches the ``package_data`` metadata. |  | ||||||
|   See :ref:`distutils-installing-package-data`. |  | ||||||
| 
 |  | ||||||
| * all files that matches the ``data_files`` metadata. |  | ||||||
|   See :ref:`distutils-additional-files`. |  | ||||||
| 
 |  | ||||||
| Sometimes this is enough, but usually you will want to specify additional files |  | ||||||
| to distribute.  The typical way to do this is to write a *manifest template*, |  | ||||||
| called :file:`MANIFEST.in` by default.  The manifest template is just a list of |  | ||||||
| instructions for how to generate your manifest file, :file:`MANIFEST`, which is |  | ||||||
| the exact list of files to include in your source distribution.  The |  | ||||||
| :command:`sdist` command processes this template and generates a manifest based |  | ||||||
| on its instructions and what it finds in the filesystem. |  | ||||||
| 
 |  | ||||||
| If you prefer to roll your own manifest file, the format is simple: one filename |  | ||||||
| per line, regular files (or symlinks to them) only.  If you do supply your own |  | ||||||
| :file:`MANIFEST`, you must specify everything: the default set of files |  | ||||||
| described above does not apply in this case. |  | ||||||
| 
 |  | ||||||
| .. versionchanged:: 3.1 |  | ||||||
|    An existing generated :file:`MANIFEST` will be regenerated without |  | ||||||
|    :command:`sdist` comparing its modification time to the one of |  | ||||||
|    :file:`MANIFEST.in` or :file:`setup.py`. |  | ||||||
| 
 |  | ||||||
| .. versionchanged:: 3.1.3 |  | ||||||
|    :file:`MANIFEST` files start with a comment indicating they are generated. |  | ||||||
|    Files without this comment are not overwritten or removed. |  | ||||||
| 
 |  | ||||||
| .. versionchanged:: 3.2.2 |  | ||||||
|    :command:`sdist` will read a :file:`MANIFEST` file if no :file:`MANIFEST.in` |  | ||||||
|    exists, like it used to do. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| The manifest template has one command per line, where each command specifies a |  | ||||||
| set of files to include or exclude from the source distribution.  For an |  | ||||||
| example, again we turn to the Distutils' own manifest template: |  | ||||||
| 
 |  | ||||||
| .. code-block:: none |  | ||||||
| 
 |  | ||||||
|    include *.txt |  | ||||||
|    recursive-include examples *.txt *.py |  | ||||||
|    prune examples/sample?/build |  | ||||||
| 
 |  | ||||||
| The meanings should be fairly clear: include all files in the distribution root |  | ||||||
| matching :file:`\*.txt`, all files anywhere under the :file:`examples` directory |  | ||||||
| matching :file:`\*.txt` or :file:`\*.py`, and exclude all directories matching |  | ||||||
| :file:`examples/sample?/build`.  All of this is done *after* the standard |  | ||||||
| include set, so you can exclude files from the standard set with explicit |  | ||||||
| instructions in the manifest template.  (Or, you can use the |  | ||||||
| :option:`!--no-defaults` option to disable the standard set entirely.)  There are |  | ||||||
| several other commands available in the manifest template mini-language; see |  | ||||||
| section :ref:`sdist-cmd`. |  | ||||||
| 
 |  | ||||||
| The order of commands in the manifest template matters: initially, we have the |  | ||||||
| list of default files as described above, and each command in the template adds |  | ||||||
| to or removes from that list of files.  Once we have fully processed the |  | ||||||
| manifest template, we remove files that should not be included in the source |  | ||||||
| distribution: |  | ||||||
| 
 |  | ||||||
| * all files in the Distutils "build" tree (default :file:`build/`) |  | ||||||
| 
 |  | ||||||
| * all files in directories named :file:`RCS`, :file:`CVS`, :file:`.svn`, |  | ||||||
|   :file:`.hg`, :file:`.git`, :file:`.bzr` or :file:`_darcs` |  | ||||||
| 
 |  | ||||||
| Now we have our complete list of files, which is written to the manifest for |  | ||||||
| future reference, and then used to build the source distribution archive(s). |  | ||||||
| 
 |  | ||||||
| You can disable the default set of included files with the |  | ||||||
| :option:`!--no-defaults` option, and you can disable the standard exclude set |  | ||||||
| with :option:`!--no-prune`. |  | ||||||
| 
 |  | ||||||
| Following the Distutils' own manifest template, let's trace how the |  | ||||||
| :command:`sdist` command builds the list of files to include in the Distutils |  | ||||||
| source distribution: |  | ||||||
| 
 |  | ||||||
| #. include all Python source files in the :file:`distutils` and |  | ||||||
|    :file:`distutils/command` subdirectories (because packages corresponding to |  | ||||||
|    those two directories were mentioned in the ``packages`` option in the |  | ||||||
|    setup script---see section :ref:`setup-script`) |  | ||||||
| 
 |  | ||||||
| #. include :file:`README.txt`, :file:`setup.py`, and :file:`setup.cfg` (standard |  | ||||||
|    files) |  | ||||||
| 
 |  | ||||||
| #. include :file:`test/test\*.py` (standard files) |  | ||||||
| 
 |  | ||||||
| #. include :file:`\*.txt` in the distribution root (this will find |  | ||||||
|    :file:`README.txt` a second time, but such redundancies are weeded out later) |  | ||||||
| 
 |  | ||||||
| #. include anything matching :file:`\*.txt` or :file:`\*.py` in the sub-tree |  | ||||||
|    under :file:`examples`, |  | ||||||
| 
 |  | ||||||
| #. exclude all files in the sub-trees starting at directories matching |  | ||||||
|    :file:`examples/sample?/build`\ ---this may exclude files included by the |  | ||||||
|    previous two steps, so it's important that the ``prune`` command in the manifest |  | ||||||
|    template comes after the ``recursive-include`` command |  | ||||||
| 
 |  | ||||||
| #. exclude the entire :file:`build` tree, and any :file:`RCS`, :file:`CVS`, |  | ||||||
|    :file:`.svn`, :file:`.hg`, :file:`.git`, :file:`.bzr` and :file:`_darcs` |  | ||||||
|    directories |  | ||||||
| 
 |  | ||||||
| Just like in the setup script, file and directory names in the manifest template |  | ||||||
| should always be slash-separated; the Distutils will take care of converting |  | ||||||
| them to the standard representation on your platform. That way, the manifest |  | ||||||
| template is portable across operating systems. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _manifest-options: |  | ||||||
| 
 |  | ||||||
| Manifest-related options |  | ||||||
| ======================== |  | ||||||
| 
 |  | ||||||
| The normal course of operations for the :command:`sdist` command is as follows: |  | ||||||
| 
 |  | ||||||
| * if the manifest file (:file:`MANIFEST` by default) exists and the first line |  | ||||||
|   does not have a comment indicating it is generated from :file:`MANIFEST.in`, |  | ||||||
|   then it is used as is, unaltered |  | ||||||
| 
 |  | ||||||
| * if the manifest file doesn't exist or has been previously automatically |  | ||||||
|   generated, read :file:`MANIFEST.in` and create the manifest |  | ||||||
| 
 |  | ||||||
| * if neither :file:`MANIFEST` nor :file:`MANIFEST.in` exist, create a manifest |  | ||||||
|   with just the default file set |  | ||||||
| 
 |  | ||||||
| * use the list of files now in :file:`MANIFEST` (either just generated or read |  | ||||||
|   in) to create the source distribution archive(s) |  | ||||||
| 
 |  | ||||||
| There are a couple of options that modify this behaviour.  First, use the |  | ||||||
| :option:`!--no-defaults` and :option:`!--no-prune` to disable the standard |  | ||||||
| "include" and "exclude" sets. |  | ||||||
| 
 |  | ||||||
| Second, you might just want to (re)generate the manifest, but not create a source |  | ||||||
| distribution:: |  | ||||||
| 
 |  | ||||||
|    python setup.py sdist --manifest-only |  | ||||||
| 
 |  | ||||||
| :option:`!-o` is a shortcut for :option:`!--manifest-only`. |  | ||||||
|  | @ -1,7 +0,0 @@ | ||||||
| :orphan: |  | ||||||
| 
 |  | ||||||
| *************************************** |  | ||||||
| Uploading Packages to the Package Index |  | ||||||
| *************************************** |  | ||||||
| 
 |  | ||||||
| The contents of this page have moved to the section :ref:`package-index`. |  | ||||||
							
								
								
									
										2
									
								
								third_party/python/Doc/docutils.conf
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								third_party/python/Doc/docutils.conf
									
										
									
									
										vendored
									
									
								
							|  | @ -1,2 +0,0 @@ | ||||||
| [restructuredtext parser] |  | ||||||
| smartquotes-locales: ja: ""'' |  | ||||||
							
								
								
									
										167
									
								
								third_party/python/Doc/extending/building.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										167
									
								
								third_party/python/Doc/extending/building.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,167 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| .. _building: |  | ||||||
| 
 |  | ||||||
| ***************************** |  | ||||||
| Building C and C++ Extensions |  | ||||||
| ***************************** |  | ||||||
| 
 |  | ||||||
| A C extension for CPython is a shared library (e.g. a ``.so`` file on Linux, |  | ||||||
| ``.pyd`` on Windows), which exports an *initialization function*. |  | ||||||
| 
 |  | ||||||
| To be importable, the shared library must be available on :envvar:`PYTHONPATH`, |  | ||||||
| and must be named after the module name, with an appropriate extension. |  | ||||||
| When using distutils, the correct filename is generated automatically. |  | ||||||
| 
 |  | ||||||
| The initialization function has the signature: |  | ||||||
| 
 |  | ||||||
| .. c:function:: PyObject* PyInit_modulename(void) |  | ||||||
| 
 |  | ||||||
| It returns either a fully-initialized module, or a :c:type:`PyModuleDef` |  | ||||||
| instance. See :ref:`initializing-modules` for details. |  | ||||||
| 
 |  | ||||||
| .. highlightlang:: python |  | ||||||
| 
 |  | ||||||
| For modules with ASCII-only names, the function must be named |  | ||||||
| ``PyInit_<modulename>``, with ``<modulename>`` replaced by the name of the |  | ||||||
| module. When using :ref:`multi-phase-initialization`, non-ASCII module names |  | ||||||
| are allowed. In this case, the initialization function name is |  | ||||||
| ``PyInitU_<modulename>``, with ``<modulename>`` encoded using Python's |  | ||||||
| *punycode* encoding with hyphens replaced by underscores. In Python:: |  | ||||||
| 
 |  | ||||||
|     def initfunc_name(name): |  | ||||||
|         try: |  | ||||||
|             suffix = b'_' + name.encode('ascii') |  | ||||||
|         except UnicodeEncodeError: |  | ||||||
|             suffix = b'U_' + name.encode('punycode').replace(b'-', b'_') |  | ||||||
|         return b'PyInit' + suffix |  | ||||||
| 
 |  | ||||||
| It is possible to export multiple modules from a single shared library by |  | ||||||
| defining multiple initialization functions. However, importing them requires |  | ||||||
| using symbolic links or a custom importer, because by default only the |  | ||||||
| function corresponding to the filename is found. |  | ||||||
| See the *"Multiple modules in one library"* section in :pep:`489` for details. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| Building C and C++ Extensions with distutils |  | ||||||
| ============================================ |  | ||||||
| 
 |  | ||||||
| .. sectionauthor:: Martin v. Löwis <martin@v.loewis.de> |  | ||||||
| 
 |  | ||||||
| Extension modules can be built using distutils,  which is included in Python. |  | ||||||
| Since distutils also supports creation of binary packages, users don't |  | ||||||
| necessarily need a compiler and distutils to install the extension. |  | ||||||
| 
 |  | ||||||
| A distutils package contains a driver script, :file:`setup.py`. This is a plain |  | ||||||
| Python file, which, in the most simple case, could look like this: |  | ||||||
| 
 |  | ||||||
| .. code-block:: python3 |  | ||||||
| 
 |  | ||||||
|    from distutils.core import setup, Extension |  | ||||||
| 
 |  | ||||||
|    module1 = Extension('demo', |  | ||||||
|                        sources = ['demo.c']) |  | ||||||
| 
 |  | ||||||
|    setup (name = 'PackageName', |  | ||||||
|           version = '1.0', |  | ||||||
|           description = 'This is a demo package', |  | ||||||
|           ext_modules = [module1]) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| With this :file:`setup.py`, and a file :file:`demo.c`, running :: |  | ||||||
| 
 |  | ||||||
|    python setup.py build |  | ||||||
| 
 |  | ||||||
| will compile :file:`demo.c`, and produce an extension module named ``demo`` in |  | ||||||
| the :file:`build` directory. Depending on the system, the module file will end |  | ||||||
| up in a subdirectory :file:`build/lib.system`, and may have a name like |  | ||||||
| :file:`demo.so` or :file:`demo.pyd`. |  | ||||||
| 
 |  | ||||||
| In the :file:`setup.py`, all execution is performed by calling the ``setup`` |  | ||||||
| function. This takes a variable number of keyword arguments, of which the |  | ||||||
| example above uses only a subset. Specifically, the example specifies |  | ||||||
| meta-information to build packages, and it specifies the contents of the |  | ||||||
| package.  Normally, a package will contain additional modules, like Python |  | ||||||
| source modules, documentation, subpackages, etc. Please refer to the distutils |  | ||||||
| documentation in :ref:`distutils-index` to learn more about the features of |  | ||||||
| distutils; this section explains building extension modules only. |  | ||||||
| 
 |  | ||||||
| It is common to pre-compute arguments to :func:`setup`, to better structure the |  | ||||||
| driver script. In the example above, the ``ext_modules`` argument to |  | ||||||
| :func:`~distutils.core.setup` is a list of extension modules, each of which is |  | ||||||
| an instance of |  | ||||||
| the :class:`~distutils.extension.Extension`. In the example, the instance |  | ||||||
| defines an extension named ``demo`` which is build by compiling a single source |  | ||||||
| file, :file:`demo.c`. |  | ||||||
| 
 |  | ||||||
| In many cases, building an extension is more complex, since additional |  | ||||||
| preprocessor defines and libraries may be needed. This is demonstrated in the |  | ||||||
| example below. |  | ||||||
| 
 |  | ||||||
| .. code-block:: python3 |  | ||||||
| 
 |  | ||||||
|    from distutils.core import setup, Extension |  | ||||||
| 
 |  | ||||||
|    module1 = Extension('demo', |  | ||||||
|                        define_macros = [('MAJOR_VERSION', '1'), |  | ||||||
|                                         ('MINOR_VERSION', '0')], |  | ||||||
|                        include_dirs = ['/usr/local/include'], |  | ||||||
|                        libraries = ['tcl83'], |  | ||||||
|                        library_dirs = ['/usr/local/lib'], |  | ||||||
|                        sources = ['demo.c']) |  | ||||||
| 
 |  | ||||||
|    setup (name = 'PackageName', |  | ||||||
|           version = '1.0', |  | ||||||
|           description = 'This is a demo package', |  | ||||||
|           author = 'Martin v. Loewis', |  | ||||||
|           author_email = 'martin@v.loewis.de', |  | ||||||
|           url = 'https://docs.python.org/extending/building', |  | ||||||
|           long_description = ''' |  | ||||||
|    This is really just a demo package. |  | ||||||
|    ''', |  | ||||||
|           ext_modules = [module1]) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| In this example, :func:`~distutils.core.setup` is called with additional |  | ||||||
| meta-information, which |  | ||||||
| is recommended when distribution packages have to be built. For the extension |  | ||||||
| itself, it specifies preprocessor defines, include directories, library |  | ||||||
| directories, and libraries. Depending on the compiler, distutils passes this |  | ||||||
| information in different ways to the compiler. For example, on Unix, this may |  | ||||||
| result in the compilation commands :: |  | ||||||
| 
 |  | ||||||
|    gcc -DNDEBUG -g -O3 -Wall -Wstrict-prototypes -fPIC -DMAJOR_VERSION=1 -DMINOR_VERSION=0 -I/usr/local/include -I/usr/local/include/python2.2 -c demo.c -o build/temp.linux-i686-2.2/demo.o |  | ||||||
| 
 |  | ||||||
|    gcc -shared build/temp.linux-i686-2.2/demo.o -L/usr/local/lib -ltcl83 -o build/lib.linux-i686-2.2/demo.so |  | ||||||
| 
 |  | ||||||
| These lines are for demonstration purposes only; distutils users should trust |  | ||||||
| that distutils gets the invocations right. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _distributing: |  | ||||||
| 
 |  | ||||||
| Distributing your extension modules |  | ||||||
| =================================== |  | ||||||
| 
 |  | ||||||
| When an extension has been successfully build, there are three ways to use it. |  | ||||||
| 
 |  | ||||||
| End-users will typically want to install the module, they do so by running :: |  | ||||||
| 
 |  | ||||||
|    python setup.py install |  | ||||||
| 
 |  | ||||||
| Module maintainers should produce source packages; to do so, they run :: |  | ||||||
| 
 |  | ||||||
|    python setup.py sdist |  | ||||||
| 
 |  | ||||||
| In some cases, additional files need to be included in a source distribution; |  | ||||||
| this is done through a :file:`MANIFEST.in` file; see :ref:`manifest` for details. |  | ||||||
| 
 |  | ||||||
| If the source distribution has been build successfully, maintainers can also |  | ||||||
| create binary distributions. Depending on the platform, one of the following |  | ||||||
| commands can be used to do so. :: |  | ||||||
| 
 |  | ||||||
|    python setup.py bdist_wininst |  | ||||||
|    python setup.py bdist_rpm |  | ||||||
|    python setup.py bdist_dumb |  | ||||||
							
								
								
									
										335
									
								
								third_party/python/Doc/extending/embedding.rst
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										335
									
								
								third_party/python/Doc/extending/embedding.rst
									
										
									
									
										vendored
									
									
								
							|  | @ -1,335 +0,0 @@ | ||||||
| .. highlightlang:: c |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _embedding: |  | ||||||
| 
 |  | ||||||
| *************************************** |  | ||||||
| Embedding Python in Another Application |  | ||||||
| *************************************** |  | ||||||
| 
 |  | ||||||
| The previous chapters discussed how to extend Python, that is, how to extend the |  | ||||||
| functionality of Python by attaching a library of C functions to it.  It is also |  | ||||||
| possible to do it the other way around: enrich your C/C++ application by |  | ||||||
| embedding Python in it.  Embedding provides your application with the ability to |  | ||||||
| implement some of the functionality of your application in Python rather than C |  | ||||||
| or C++. This can be used for many purposes; one example would be to allow users |  | ||||||
| to tailor the application to their needs by writing some scripts in Python.  You |  | ||||||
| can also use it yourself if some of the functionality can be written in Python |  | ||||||
| more easily. |  | ||||||
| 
 |  | ||||||
| Embedding Python is similar to extending it, but not quite.  The difference is |  | ||||||
| that when you extend Python, the main program of the application is still the |  | ||||||
| Python interpreter, while if you embed Python, the main program may have nothing |  | ||||||
| to do with Python --- instead, some parts of the application occasionally call |  | ||||||
| the Python interpreter to run some Python code. |  | ||||||
| 
 |  | ||||||
| So if you are embedding Python, you are providing your own main program.  One of |  | ||||||
| the things this main program has to do is initialize the Python interpreter.  At |  | ||||||
| the very least, you have to call the function :c:func:`Py_Initialize`.  There are |  | ||||||
| optional calls to pass command line arguments to Python.  Then later you can |  | ||||||
| call the interpreter from any part of the application. |  | ||||||
| 
 |  | ||||||
| There are several different ways to call the interpreter: you can pass a string |  | ||||||
| containing Python statements to :c:func:`PyRun_SimpleString`, or you can pass a |  | ||||||
| stdio file pointer and a file name (for identification in error messages only) |  | ||||||
| to :c:func:`PyRun_SimpleFile`.  You can also call the lower-level operations |  | ||||||
| described in the previous chapters to construct and use Python objects. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. seealso:: |  | ||||||
| 
 |  | ||||||
|    :ref:`c-api-index` |  | ||||||
|       The details of Python's C interface are given in this manual. A great deal of |  | ||||||
|       necessary information can be found here. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _high-level-embedding: |  | ||||||
| 
 |  | ||||||
| Very High Level Embedding |  | ||||||
| ========================= |  | ||||||
| 
 |  | ||||||
| The simplest form of embedding Python is the use of the very high level |  | ||||||
| interface. This interface is intended to execute a Python script without needing |  | ||||||
| to interact with the application directly. This can for example be used to |  | ||||||
| perform some operation on a file. :: |  | ||||||
| 
 |  | ||||||
|    #include <Python.h> |  | ||||||
| 
 |  | ||||||
|    int |  | ||||||
|    main(int argc, char *argv[]) |  | ||||||
|    { |  | ||||||
|        wchar_t *program = Py_DecodeLocale(argv[0], NULL); |  | ||||||
|        if (program == NULL) { |  | ||||||
|            fprintf(stderr, "Fatal error: cannot decode argv[0]\n"); |  | ||||||
|            exit(1); |  | ||||||
|        } |  | ||||||
|        Py_SetProgramName(program);  /* optional but recommended */ |  | ||||||
|        Py_Initialize(); |  | ||||||
|        PyRun_SimpleString("from time import time,ctime\n" |  | ||||||
|                           "print('Today is', ctime(time()))\n"); |  | ||||||
|        if (Py_FinalizeEx() < 0) { |  | ||||||
|            exit(120); |  | ||||||
|        } |  | ||||||
|        PyMem_RawFree(program); |  | ||||||
|        return 0; |  | ||||||
|    } |  | ||||||
| 
 |  | ||||||
| The :c:func:`Py_SetProgramName` function should be called before |  | ||||||
| :c:func:`Py_Initialize` to inform the interpreter about paths to Python run-time |  | ||||||
| libraries.  Next, the Python interpreter is initialized with |  | ||||||
| :c:func:`Py_Initialize`, followed by the execution of a hard-coded Python script |  | ||||||
| that prints the date and time.  Afterwards, the :c:func:`Py_FinalizeEx` call shuts |  | ||||||
| the interpreter down, followed by the end of the program.  In a real program, |  | ||||||
| you may want to get the Python script from another source, perhaps a text-editor |  | ||||||
| routine, a file, or a database.  Getting the Python code from a file can better |  | ||||||
| be done by using the :c:func:`PyRun_SimpleFile` function, which saves you the |  | ||||||
| trouble of allocating memory space and loading the file contents. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _lower-level-embedding: |  | ||||||
| 
 |  | ||||||
| Beyond Very High Level Embedding: An overview |  | ||||||
| ============================================= |  | ||||||
| 
 |  | ||||||
| The high level interface gives you the ability to execute arbitrary pieces of |  | ||||||
| Python code from your application, but exchanging data values is quite |  | ||||||
| cumbersome to say the least. If you want that, you should use lower level calls. |  | ||||||
| At the cost of having to write more C code, you can achieve almost anything. |  | ||||||
| 
 |  | ||||||
| It should be noted that extending Python and embedding Python is quite the same |  | ||||||
| activity, despite the different intent. Most topics discussed in the previous |  | ||||||
| chapters are still valid. To show this, consider what the extension code from |  | ||||||
| Python to C really does: |  | ||||||
| 
 |  | ||||||
| #. Convert data values from Python to C, |  | ||||||
| 
 |  | ||||||
| #. Perform a function call to a C routine using the converted values, and |  | ||||||
| 
 |  | ||||||
| #. Convert the data values from the call from C to Python. |  | ||||||
| 
 |  | ||||||
| When embedding Python, the interface code does: |  | ||||||
| 
 |  | ||||||
| #. Convert data values from C to Python, |  | ||||||
| 
 |  | ||||||
| #. Perform a function call to a Python interface routine using the converted |  | ||||||
|    values, and |  | ||||||
| 
 |  | ||||||
| #. Convert the data values from the call from Python to C. |  | ||||||
| 
 |  | ||||||
| As you can see, the data conversion steps are simply swapped to accommodate the |  | ||||||
| different direction of the cross-language transfer. The only difference is the |  | ||||||
| routine that you call between both data conversions. When extending, you call a |  | ||||||
| C routine, when embedding, you call a Python routine. |  | ||||||
| 
 |  | ||||||
| This chapter will not discuss how to convert data from Python to C and vice |  | ||||||
| versa.  Also, proper use of references and dealing with errors is assumed to be |  | ||||||
| understood.  Since these aspects do not differ from extending the interpreter, |  | ||||||
| you can refer to earlier chapters for the required information. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _pure-embedding: |  | ||||||
| 
 |  | ||||||
| Pure Embedding |  | ||||||
| ============== |  | ||||||
| 
 |  | ||||||
| The first program aims to execute a function in a Python script. Like in the |  | ||||||
| section about the very high level interface, the Python interpreter does not |  | ||||||
| directly interact with the application (but that will change in the next |  | ||||||
| section). |  | ||||||
| 
 |  | ||||||
| The code to run a function defined in a Python script is: |  | ||||||
| 
 |  | ||||||
| .. literalinclude:: ../includes/run-func.c |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| This code loads a Python script using ``argv[1]``, and calls the function named |  | ||||||
| in ``argv[2]``.  Its integer arguments are the other values of the ``argv`` |  | ||||||
| array.  If you :ref:`compile and link <compiling>` this program (let's call |  | ||||||
| the finished executable :program:`call`), and use it to execute a Python |  | ||||||
| script, such as: |  | ||||||
| 
 |  | ||||||
| .. code-block:: python |  | ||||||
| 
 |  | ||||||
|    def multiply(a,b): |  | ||||||
|        print("Will compute", a, "times", b) |  | ||||||
|        c = 0 |  | ||||||
|        for i in range(0, a): |  | ||||||
|            c = c + b |  | ||||||
|        return c |  | ||||||
| 
 |  | ||||||
| then the result should be: |  | ||||||
| 
 |  | ||||||
| .. code-block:: shell-session |  | ||||||
| 
 |  | ||||||
|    $ call multiply multiply 3 2 |  | ||||||
|    Will compute 3 times 2 |  | ||||||
|    Result of call: 6 |  | ||||||
| 
 |  | ||||||
| Although the program is quite large for its functionality, most of the code is |  | ||||||
| for data conversion between Python and C, and for error reporting.  The |  | ||||||
| interesting part with respect to embedding Python starts with :: |  | ||||||
| 
 |  | ||||||
|    Py_Initialize(); |  | ||||||
|    pName = PyUnicode_DecodeFSDefault(argv[1]); |  | ||||||
|    /* Error checking of pName left out */ |  | ||||||
|    pModule = PyImport_Import(pName); |  | ||||||
| 
 |  | ||||||
| After initializing the interpreter, the script is loaded using |  | ||||||
| :c:func:`PyImport_Import`.  This routine needs a Python string as its argument, |  | ||||||
| which is constructed using the :c:func:`PyUnicode_FromString` data conversion |  | ||||||
| routine. :: |  | ||||||
| 
 |  | ||||||
|    pFunc = PyObject_GetAttrString(pModule, argv[2]); |  | ||||||
|    /* pFunc is a new reference */ |  | ||||||
| 
 |  | ||||||
|    if (pFunc && PyCallable_Check(pFunc)) { |  | ||||||
|        ... |  | ||||||
|    } |  | ||||||
|    Py_XDECREF(pFunc); |  | ||||||
| 
 |  | ||||||
| Once the script is loaded, the name we're looking for is retrieved using |  | ||||||
| :c:func:`PyObject_GetAttrString`.  If the name exists, and the object returned is |  | ||||||
| callable, you can safely assume that it is a function.  The program then |  | ||||||
| proceeds by constructing a tuple of arguments as normal.  The call to the Python |  | ||||||
| function is then made with:: |  | ||||||
| 
 |  | ||||||
|    pValue = PyObject_CallObject(pFunc, pArgs); |  | ||||||
| 
 |  | ||||||
| Upon return of the function, ``pValue`` is either *NULL* or it contains a |  | ||||||
| reference to the return value of the function.  Be sure to release the reference |  | ||||||
| after examining the value. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _extending-with-embedding: |  | ||||||
| 
 |  | ||||||
| Extending Embedded Python |  | ||||||
| ========================= |  | ||||||
| 
 |  | ||||||
| Until now, the embedded Python interpreter had no access to functionality from |  | ||||||
| the application itself.  The Python API allows this by extending the embedded |  | ||||||
| interpreter.  That is, the embedded interpreter gets extended with routines |  | ||||||
| provided by the application. While it sounds complex, it is not so bad.  Simply |  | ||||||
| forget for a while that the application starts the Python interpreter.  Instead, |  | ||||||
| consider the application to be a set of subroutines, and write some glue code |  | ||||||
| that gives Python access to those routines, just like you would write a normal |  | ||||||
| Python extension.  For example:: |  | ||||||
| 
 |  | ||||||
|    static int numargs=0; |  | ||||||
| 
 |  | ||||||
|    /* Return the number of arguments of the application command line */ |  | ||||||
|    static PyObject* |  | ||||||
|    emb_numargs(PyObject *self, PyObject *args) |  | ||||||
|    { |  | ||||||
|        if(!PyArg_ParseTuple(args, ":numargs")) |  | ||||||
|            return NULL; |  | ||||||
|        return PyLong_FromLong(numargs); |  | ||||||
|    } |  | ||||||
| 
 |  | ||||||
|    static PyMethodDef EmbMethods[] = { |  | ||||||
|        {"numargs", emb_numargs, METH_VARARGS, |  | ||||||
|         "Return the number of arguments received by the process."}, |  | ||||||
|        {NULL, NULL, 0, NULL} |  | ||||||
|    }; |  | ||||||
| 
 |  | ||||||
|    static PyModuleDef EmbModule = { |  | ||||||
|        PyModuleDef_HEAD_INIT, "emb", NULL, -1, EmbMethods, |  | ||||||
|        NULL, NULL, NULL, NULL |  | ||||||
|    }; |  | ||||||
| 
 |  | ||||||
|    static PyObject* |  | ||||||
|    PyInit_emb(void) |  | ||||||
|    { |  | ||||||
|        return PyModule_Create(&EmbModule); |  | ||||||
|    } |  | ||||||
| 
 |  | ||||||
| Insert the above code just above the :c:func:`main` function. Also, insert the |  | ||||||
| following two statements before the call to :c:func:`Py_Initialize`:: |  | ||||||
| 
 |  | ||||||
|    numargs = argc; |  | ||||||
|    PyImport_AppendInittab("emb", &PyInit_emb); |  | ||||||
| 
 |  | ||||||
| These two lines initialize the ``numargs`` variable, and make the |  | ||||||
| :func:`emb.numargs` function accessible to the embedded Python interpreter. |  | ||||||
| With these extensions, the Python script can do things like |  | ||||||
| 
 |  | ||||||
| .. code-block:: python |  | ||||||
| 
 |  | ||||||
|    import emb |  | ||||||
|    print("Number of arguments", emb.numargs()) |  | ||||||
| 
 |  | ||||||
| In a real application, the methods will expose an API of the application to |  | ||||||
| Python. |  | ||||||
| 
 |  | ||||||
| .. TODO: threads, code examples do not really behave well if errors happen |  | ||||||
|    (what to watch out for) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _embeddingincplusplus: |  | ||||||
| 
 |  | ||||||
| Embedding Python in C++ |  | ||||||
| ======================= |  | ||||||
| 
 |  | ||||||
| It is also possible to embed Python in a C++ program; precisely how this is done |  | ||||||
| will depend on the details of the C++ system used; in general you will need to |  | ||||||
| write the main program in C++, and use the C++ compiler to compile and link your |  | ||||||
| program.  There is no need to recompile Python itself using C++. |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. _compiling: |  | ||||||
| 
 |  | ||||||
| Compiling and Linking under Unix-like systems |  | ||||||
| ============================================= |  | ||||||
| 
 |  | ||||||
| It is not necessarily trivial to find the right flags to pass to your |  | ||||||
| compiler (and linker) in order to embed the Python interpreter into your |  | ||||||
| application, particularly because Python needs to load library modules |  | ||||||
| implemented as C dynamic extensions (:file:`.so` files) linked against |  | ||||||
| it. |  | ||||||
| 
 |  | ||||||
| To find out the required compiler and linker flags, you can execute the |  | ||||||
| :file:`python{X.Y}-config` script which is generated as part of the |  | ||||||
| installation process (a :file:`python3-config` script may also be |  | ||||||
| available).  This script has several options, of which the following will |  | ||||||
| be directly useful to you: |  | ||||||
| 
 |  | ||||||
| * ``pythonX.Y-config --cflags`` will give you the recommended flags when |  | ||||||
|   compiling: |  | ||||||
| 
 |  | ||||||
|   .. code-block:: shell-session |  | ||||||
| 
 |  | ||||||
|      $ /opt/bin/python3.4-config --cflags |  | ||||||
|      -I/opt/include/python3.4m -I/opt/include/python3.4m -DNDEBUG -g -fwrapv -O3 -Wall -Wstrict-prototypes |  | ||||||
| 
 |  | ||||||
| * ``pythonX.Y-config --ldflags`` will give you the recommended flags when |  | ||||||
|   linking: |  | ||||||
| 
 |  | ||||||
|   .. code-block:: shell-session |  | ||||||
| 
 |  | ||||||
|      $ /opt/bin/python3.4-config --ldflags |  | ||||||
|      -L/opt/lib/python3.4/config-3.4m -lpthread -ldl -lutil -lm -lpython3.4m -Xlinker -export-dynamic |  | ||||||
| 
 |  | ||||||
| .. note:: |  | ||||||
|    To avoid confusion between several Python installations (and especially |  | ||||||
|    between the system Python and your own compiled Python), it is recommended |  | ||||||
|    that you use the absolute path to :file:`python{X.Y}-config`, as in the above |  | ||||||
|    example. |  | ||||||
| 
 |  | ||||||
| If this procedure doesn't work for you (it is not guaranteed to work for |  | ||||||
| all Unix-like platforms; however, we welcome :ref:`bug reports <reporting-bugs>`) |  | ||||||
| you will have to read your system's documentation about dynamic linking and/or |  | ||||||
| examine Python's :file:`Makefile` (use :func:`sysconfig.get_makefile_filename` |  | ||||||
| to find its location) and compilation |  | ||||||
| options.  In this case, the :mod:`sysconfig` module is a useful tool to |  | ||||||
| programmatically extract the configuration values that you will want to |  | ||||||
| combine together.  For example: |  | ||||||
| 
 |  | ||||||
| .. code-block:: pycon |  | ||||||
| 
 |  | ||||||
|    >>> import sysconfig |  | ||||||
|    >>> sysconfig.get_config_var('LIBS') |  | ||||||
|    '-lpthread -ldl  -lutil' |  | ||||||
|    >>> sysconfig.get_config_var('LINKFORSHARED') |  | ||||||
|    '-Xlinker -export-dynamic' |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| .. XXX similar documentation for Windows missing |  | ||||||
Some files were not shown because too many files have changed in this diff Show more
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue