richardblythman
commited on
Upload folder using huggingface_hub
Browse filesThis view is limited to 50 files because it contains too many changes.
See raw diff
- .gitattributes +1 -0
- .venv/.gitignore +2 -0
- .venv/bin/activate +87 -0
- .venv/bin/activate.csh +55 -0
- .venv/bin/activate.fish +103 -0
- .venv/bin/activate.nu +96 -0
- .venv/bin/activate.ps1 +61 -0
- .venv/bin/activate_this.py +38 -0
- .venv/bin/dotenv +8 -0
- .venv/bin/httpx +8 -0
- .venv/bin/huggingface-cli +8 -0
- .venv/bin/naptha +8 -0
- .venv/bin/normalizer +8 -0
- .venv/bin/pip +8 -0
- .venv/bin/pip-3.12 +8 -0
- .venv/bin/pip3 +8 -0
- .venv/bin/pip3.12 +8 -0
- .venv/bin/python +0 -0
- .venv/bin/python3 +0 -0
- .venv/bin/python3.12 +0 -0
- .venv/bin/tqdm +8 -0
- .venv/lib/python3.12/site-packages/PyJWT-2.9.0.dist-info/AUTHORS.rst +7 -0
- .venv/lib/python3.12/site-packages/PyJWT-2.9.0.dist-info/INSTALLER +1 -0
- .venv/lib/python3.12/site-packages/PyJWT-2.9.0.dist-info/LICENSE +21 -0
- .venv/lib/python3.12/site-packages/PyJWT-2.9.0.dist-info/METADATA +97 -0
- .venv/lib/python3.12/site-packages/PyJWT-2.9.0.dist-info/RECORD +20 -0
- .venv/lib/python3.12/site-packages/PyJWT-2.9.0.dist-info/WHEEL +5 -0
- .venv/lib/python3.12/site-packages/PyJWT-2.9.0.dist-info/top_level.txt +1 -0
- .venv/lib/python3.12/site-packages/PyYAML-6.0.2.dist-info/INSTALLER +1 -0
- .venv/lib/python3.12/site-packages/PyYAML-6.0.2.dist-info/LICENSE +20 -0
- .venv/lib/python3.12/site-packages/PyYAML-6.0.2.dist-info/METADATA +46 -0
- .venv/lib/python3.12/site-packages/PyYAML-6.0.2.dist-info/RECORD +25 -0
- .venv/lib/python3.12/site-packages/PyYAML-6.0.2.dist-info/WHEEL +5 -0
- .venv/lib/python3.12/site-packages/PyYAML-6.0.2.dist-info/top_level.txt +2 -0
- .venv/lib/python3.12/site-packages/__pycache__/_virtualenv.cpython-312.pyc +0 -0
- .venv/lib/python3.12/site-packages/_virtualenv.pth +3 -0
- .venv/lib/python3.12/site-packages/_virtualenv.py +103 -0
- .venv/lib/python3.12/site-packages/_yaml/__init__.py +33 -0
- .venv/lib/python3.12/site-packages/annotated_types-0.7.0.dist-info/INSTALLER +1 -0
- .venv/lib/python3.12/site-packages/annotated_types-0.7.0.dist-info/METADATA +295 -0
- .venv/lib/python3.12/site-packages/annotated_types-0.7.0.dist-info/RECORD +8 -0
- .venv/lib/python3.12/site-packages/annotated_types-0.7.0.dist-info/WHEEL +4 -0
- .venv/lib/python3.12/site-packages/annotated_types-0.7.0.dist-info/licenses/LICENSE +21 -0
- .venv/lib/python3.12/site-packages/annotated_types/__init__.py +432 -0
- .venv/lib/python3.12/site-packages/annotated_types/py.typed +0 -0
- .venv/lib/python3.12/site-packages/annotated_types/test_cases.py +151 -0
- .venv/lib/python3.12/site-packages/anyio-4.4.0.dist-info/INSTALLER +1 -0
- .venv/lib/python3.12/site-packages/anyio-4.4.0.dist-info/LICENSE +20 -0
- .venv/lib/python3.12/site-packages/anyio-4.4.0.dist-info/METADATA +104 -0
- .venv/lib/python3.12/site-packages/anyio-4.4.0.dist-info/RECORD +45 -0
.gitattributes
CHANGED
@@ -33,3 +33,4 @@ saved_model/**/* filter=lfs diff=lfs merge=lfs -text
|
|
33 |
*.zip filter=lfs diff=lfs merge=lfs -text
|
34 |
*.zst filter=lfs diff=lfs merge=lfs -text
|
35 |
*tfevents* filter=lfs diff=lfs merge=lfs -text
|
|
|
|
33 |
*.zip filter=lfs diff=lfs merge=lfs -text
|
34 |
*.zst filter=lfs diff=lfs merge=lfs -text
|
35 |
*tfevents* filter=lfs diff=lfs merge=lfs -text
|
36 |
+
.venv/lib/python3.12/site-packages/pydantic_core/_pydantic_core.cpython-312-darwin.so filter=lfs diff=lfs merge=lfs -text
|
.venv/.gitignore
ADDED
@@ -0,0 +1,2 @@
|
|
|
|
|
|
|
1 |
+
# created by virtualenv automatically
|
2 |
+
*
|
.venv/bin/activate
ADDED
@@ -0,0 +1,87 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
# This file must be used with "source bin/activate" *from bash*
|
2 |
+
# you cannot run it directly
|
3 |
+
|
4 |
+
|
5 |
+
if [ "${BASH_SOURCE-}" = "$0" ]; then
|
6 |
+
echo "You must source this script: \$ source $0" >&2
|
7 |
+
exit 33
|
8 |
+
fi
|
9 |
+
|
10 |
+
deactivate () {
|
11 |
+
unset -f pydoc >/dev/null 2>&1 || true
|
12 |
+
|
13 |
+
# reset old environment variables
|
14 |
+
# ! [ -z ${VAR+_} ] returns true if VAR is declared at all
|
15 |
+
if ! [ -z "${_OLD_VIRTUAL_PATH:+_}" ] ; then
|
16 |
+
PATH="$_OLD_VIRTUAL_PATH"
|
17 |
+
export PATH
|
18 |
+
unset _OLD_VIRTUAL_PATH
|
19 |
+
fi
|
20 |
+
if ! [ -z "${_OLD_VIRTUAL_PYTHONHOME+_}" ] ; then
|
21 |
+
PYTHONHOME="$_OLD_VIRTUAL_PYTHONHOME"
|
22 |
+
export PYTHONHOME
|
23 |
+
unset _OLD_VIRTUAL_PYTHONHOME
|
24 |
+
fi
|
25 |
+
|
26 |
+
# The hash command must be called to get it to forget past
|
27 |
+
# commands. Without forgetting past commands the $PATH changes
|
28 |
+
# we made may not be respected
|
29 |
+
hash -r 2>/dev/null
|
30 |
+
|
31 |
+
if ! [ -z "${_OLD_VIRTUAL_PS1+_}" ] ; then
|
32 |
+
PS1="$_OLD_VIRTUAL_PS1"
|
33 |
+
export PS1
|
34 |
+
unset _OLD_VIRTUAL_PS1
|
35 |
+
fi
|
36 |
+
|
37 |
+
unset VIRTUAL_ENV
|
38 |
+
unset VIRTUAL_ENV_PROMPT
|
39 |
+
if [ ! "${1-}" = "nondestructive" ] ; then
|
40 |
+
# Self destruct!
|
41 |
+
unset -f deactivate
|
42 |
+
fi
|
43 |
+
}
|
44 |
+
|
45 |
+
# unset irrelevant variables
|
46 |
+
deactivate nondestructive
|
47 |
+
|
48 |
+
VIRTUAL_ENV='/Users/richardblythman/code/models/multiplayer_chat_uni/tmp/multiplayer_chat/.venv'
|
49 |
+
if ([ "$OSTYPE" = "cygwin" ] || [ "$OSTYPE" = "msys" ]) && $(command -v cygpath &> /dev/null) ; then
|
50 |
+
VIRTUAL_ENV=$(cygpath -u "$VIRTUAL_ENV")
|
51 |
+
fi
|
52 |
+
export VIRTUAL_ENV
|
53 |
+
|
54 |
+
_OLD_VIRTUAL_PATH="$PATH"
|
55 |
+
PATH="$VIRTUAL_ENV/bin:$PATH"
|
56 |
+
export PATH
|
57 |
+
|
58 |
+
if [ "xmultiplayer-chat-py3.12" != x ] ; then
|
59 |
+
VIRTUAL_ENV_PROMPT="multiplayer-chat-py3.12"
|
60 |
+
else
|
61 |
+
VIRTUAL_ENV_PROMPT=$(basename "$VIRTUAL_ENV")
|
62 |
+
fi
|
63 |
+
export VIRTUAL_ENV_PROMPT
|
64 |
+
|
65 |
+
# unset PYTHONHOME if set
|
66 |
+
if ! [ -z "${PYTHONHOME+_}" ] ; then
|
67 |
+
_OLD_VIRTUAL_PYTHONHOME="$PYTHONHOME"
|
68 |
+
unset PYTHONHOME
|
69 |
+
fi
|
70 |
+
|
71 |
+
if [ -z "${VIRTUAL_ENV_DISABLE_PROMPT-}" ] ; then
|
72 |
+
_OLD_VIRTUAL_PS1="${PS1-}"
|
73 |
+
PS1="(${VIRTUAL_ENV_PROMPT}) ${PS1-}"
|
74 |
+
export PS1
|
75 |
+
fi
|
76 |
+
|
77 |
+
# Make sure to unalias pydoc if it's already there
|
78 |
+
alias pydoc 2>/dev/null >/dev/null && unalias pydoc || true
|
79 |
+
|
80 |
+
pydoc () {
|
81 |
+
python -m pydoc "$@"
|
82 |
+
}
|
83 |
+
|
84 |
+
# The hash command must be called to get it to forget past
|
85 |
+
# commands. Without forgetting past commands the $PATH changes
|
86 |
+
# we made may not be respected
|
87 |
+
hash -r 2>/dev/null || true
|
.venv/bin/activate.csh
ADDED
@@ -0,0 +1,55 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
# This file must be used with "source bin/activate.csh" *from csh*.
|
2 |
+
# You cannot run it directly.
|
3 |
+
# Created by Davide Di Blasi <[email protected]>.
|
4 |
+
|
5 |
+
set newline='\
|
6 |
+
'
|
7 |
+
|
8 |
+
alias deactivate 'test $?_OLD_VIRTUAL_PATH != 0 && setenv PATH "$_OLD_VIRTUAL_PATH:q" && unset _OLD_VIRTUAL_PATH; rehash; test $?_OLD_VIRTUAL_PROMPT != 0 && set prompt="$_OLD_VIRTUAL_PROMPT:q" && unset _OLD_VIRTUAL_PROMPT; unsetenv VIRTUAL_ENV; unsetenv VIRTUAL_ENV_PROMPT; test "\!:*" != "nondestructive" && unalias deactivate && unalias pydoc'
|
9 |
+
|
10 |
+
# Unset irrelevant variables.
|
11 |
+
deactivate nondestructive
|
12 |
+
|
13 |
+
setenv VIRTUAL_ENV '/Users/richardblythman/code/models/multiplayer_chat_uni/tmp/multiplayer_chat/.venv'
|
14 |
+
|
15 |
+
set _OLD_VIRTUAL_PATH="$PATH:q"
|
16 |
+
setenv PATH "$VIRTUAL_ENV:q/bin:$PATH:q"
|
17 |
+
|
18 |
+
|
19 |
+
|
20 |
+
if ('multiplayer-chat-py3.12' != "") then
|
21 |
+
setenv VIRTUAL_ENV_PROMPT 'multiplayer-chat-py3.12'
|
22 |
+
else
|
23 |
+
setenv VIRTUAL_ENV_PROMPT "$VIRTUAL_ENV:t:q"
|
24 |
+
endif
|
25 |
+
|
26 |
+
if ( $?VIRTUAL_ENV_DISABLE_PROMPT ) then
|
27 |
+
if ( $VIRTUAL_ENV_DISABLE_PROMPT == "" ) then
|
28 |
+
set do_prompt = "1"
|
29 |
+
else
|
30 |
+
set do_prompt = "0"
|
31 |
+
endif
|
32 |
+
else
|
33 |
+
set do_prompt = "1"
|
34 |
+
endif
|
35 |
+
|
36 |
+
if ( $do_prompt == "1" ) then
|
37 |
+
# Could be in a non-interactive environment,
|
38 |
+
# in which case, $prompt is undefined and we wouldn't
|
39 |
+
# care about the prompt anyway.
|
40 |
+
if ( $?prompt ) then
|
41 |
+
set _OLD_VIRTUAL_PROMPT="$prompt:q"
|
42 |
+
if ( "$prompt:q" =~ *"$newline:q"* ) then
|
43 |
+
:
|
44 |
+
else
|
45 |
+
set prompt = '('"$VIRTUAL_ENV_PROMPT:q"') '"$prompt:q"
|
46 |
+
endif
|
47 |
+
endif
|
48 |
+
endif
|
49 |
+
|
50 |
+
unset env_name
|
51 |
+
unset do_prompt
|
52 |
+
|
53 |
+
alias pydoc python -m pydoc
|
54 |
+
|
55 |
+
rehash
|
.venv/bin/activate.fish
ADDED
@@ -0,0 +1,103 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
# This file must be used using `source bin/activate.fish` *within a running fish ( http://fishshell.com ) session*.
|
2 |
+
# Do not run it directly.
|
3 |
+
|
4 |
+
function _bashify_path -d "Converts a fish path to something bash can recognize"
|
5 |
+
set fishy_path $argv
|
6 |
+
set bashy_path $fishy_path[1]
|
7 |
+
for path_part in $fishy_path[2..-1]
|
8 |
+
set bashy_path "$bashy_path:$path_part"
|
9 |
+
end
|
10 |
+
echo $bashy_path
|
11 |
+
end
|
12 |
+
|
13 |
+
function _fishify_path -d "Converts a bash path to something fish can recognize"
|
14 |
+
echo $argv | tr ':' '\n'
|
15 |
+
end
|
16 |
+
|
17 |
+
function deactivate -d 'Exit virtualenv mode and return to the normal environment.'
|
18 |
+
# reset old environment variables
|
19 |
+
if test -n "$_OLD_VIRTUAL_PATH"
|
20 |
+
# https://github.com/fish-shell/fish-shell/issues/436 altered PATH handling
|
21 |
+
if test (echo $FISH_VERSION | head -c 1) -lt 3
|
22 |
+
set -gx PATH (_fishify_path "$_OLD_VIRTUAL_PATH")
|
23 |
+
else
|
24 |
+
set -gx PATH $_OLD_VIRTUAL_PATH
|
25 |
+
end
|
26 |
+
set -e _OLD_VIRTUAL_PATH
|
27 |
+
end
|
28 |
+
|
29 |
+
if test -n "$_OLD_VIRTUAL_PYTHONHOME"
|
30 |
+
set -gx PYTHONHOME "$_OLD_VIRTUAL_PYTHONHOME"
|
31 |
+
set -e _OLD_VIRTUAL_PYTHONHOME
|
32 |
+
end
|
33 |
+
|
34 |
+
if test -n "$_OLD_FISH_PROMPT_OVERRIDE"
|
35 |
+
and functions -q _old_fish_prompt
|
36 |
+
# Set an empty local `$fish_function_path` to allow the removal of `fish_prompt` using `functions -e`.
|
37 |
+
set -l fish_function_path
|
38 |
+
|
39 |
+
# Erase virtualenv's `fish_prompt` and restore the original.
|
40 |
+
functions -e fish_prompt
|
41 |
+
functions -c _old_fish_prompt fish_prompt
|
42 |
+
functions -e _old_fish_prompt
|
43 |
+
set -e _OLD_FISH_PROMPT_OVERRIDE
|
44 |
+
end
|
45 |
+
|
46 |
+
set -e VIRTUAL_ENV
|
47 |
+
set -e VIRTUAL_ENV_PROMPT
|
48 |
+
|
49 |
+
if test "$argv[1]" != 'nondestructive'
|
50 |
+
# Self-destruct!
|
51 |
+
functions -e pydoc
|
52 |
+
functions -e deactivate
|
53 |
+
functions -e _bashify_path
|
54 |
+
functions -e _fishify_path
|
55 |
+
end
|
56 |
+
end
|
57 |
+
|
58 |
+
# Unset irrelevant variables.
|
59 |
+
deactivate nondestructive
|
60 |
+
|
61 |
+
set -gx VIRTUAL_ENV '/Users/richardblythman/code/models/multiplayer_chat_uni/tmp/multiplayer_chat/.venv'
|
62 |
+
|
63 |
+
# https://github.com/fish-shell/fish-shell/issues/436 altered PATH handling
|
64 |
+
if test (echo $FISH_VERSION | head -c 1) -lt 3
|
65 |
+
set -gx _OLD_VIRTUAL_PATH (_bashify_path $PATH)
|
66 |
+
else
|
67 |
+
set -gx _OLD_VIRTUAL_PATH $PATH
|
68 |
+
end
|
69 |
+
set -gx PATH "$VIRTUAL_ENV"'/bin' $PATH
|
70 |
+
|
71 |
+
# Prompt override provided?
|
72 |
+
# If not, just use the environment name.
|
73 |
+
if test -n 'multiplayer-chat-py3.12'
|
74 |
+
set -gx VIRTUAL_ENV_PROMPT 'multiplayer-chat-py3.12'
|
75 |
+
else
|
76 |
+
set -gx VIRTUAL_ENV_PROMPT (basename "$VIRTUAL_ENV")
|
77 |
+
end
|
78 |
+
|
79 |
+
# Unset `$PYTHONHOME` if set.
|
80 |
+
if set -q PYTHONHOME
|
81 |
+
set -gx _OLD_VIRTUAL_PYTHONHOME $PYTHONHOME
|
82 |
+
set -e PYTHONHOME
|
83 |
+
end
|
84 |
+
|
85 |
+
function pydoc
|
86 |
+
python -m pydoc $argv
|
87 |
+
end
|
88 |
+
|
89 |
+
if test -z "$VIRTUAL_ENV_DISABLE_PROMPT"
|
90 |
+
# Copy the current `fish_prompt` function as `_old_fish_prompt`.
|
91 |
+
functions -c fish_prompt _old_fish_prompt
|
92 |
+
|
93 |
+
function fish_prompt
|
94 |
+
# Run the user's prompt first; it might depend on (pipe)status.
|
95 |
+
set -l prompt (_old_fish_prompt)
|
96 |
+
|
97 |
+
printf '(%s) ' $VIRTUAL_ENV_PROMPT
|
98 |
+
|
99 |
+
string join -- \n $prompt # handle multi-line prompts
|
100 |
+
end
|
101 |
+
|
102 |
+
set -gx _OLD_FISH_PROMPT_OVERRIDE "$VIRTUAL_ENV"
|
103 |
+
end
|
.venv/bin/activate.nu
ADDED
@@ -0,0 +1,96 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
# virtualenv activation module
|
2 |
+
# Activate with `overlay use activate.nu`
|
3 |
+
# Deactivate with `deactivate`, as usual
|
4 |
+
#
|
5 |
+
# To customize the overlay name, you can call `overlay use activate.nu as foo`,
|
6 |
+
# but then simply `deactivate` won't work because it is just an alias to hide
|
7 |
+
# the "activate" overlay. You'd need to call `overlay hide foo` manually.
|
8 |
+
|
9 |
+
export-env {
|
10 |
+
def is-string [x] {
|
11 |
+
($x | describe) == 'string'
|
12 |
+
}
|
13 |
+
|
14 |
+
def has-env [...names] {
|
15 |
+
$names | each {|n|
|
16 |
+
$n in $env
|
17 |
+
} | all {|i| $i == true}
|
18 |
+
}
|
19 |
+
|
20 |
+
# Emulates a `test -z`, but btter as it handles e.g 'false'
|
21 |
+
def is-env-true [name: string] {
|
22 |
+
if (has-env $name) {
|
23 |
+
# Try to parse 'true', '0', '1', and fail if not convertible
|
24 |
+
let parsed = (do -i { $env | get $name | into bool })
|
25 |
+
if ($parsed | describe) == 'bool' {
|
26 |
+
$parsed
|
27 |
+
} else {
|
28 |
+
not ($env | get -i $name | is-empty)
|
29 |
+
}
|
30 |
+
} else {
|
31 |
+
false
|
32 |
+
}
|
33 |
+
}
|
34 |
+
|
35 |
+
let virtual_env = '/Users/richardblythman/code/models/multiplayer_chat_uni/tmp/multiplayer_chat/.venv'
|
36 |
+
let bin = 'bin'
|
37 |
+
|
38 |
+
let is_windows = ($nu.os-info.family) == 'windows'
|
39 |
+
let path_name = (if (has-env 'Path') {
|
40 |
+
'Path'
|
41 |
+
} else {
|
42 |
+
'PATH'
|
43 |
+
}
|
44 |
+
)
|
45 |
+
|
46 |
+
let venv_path = ([$virtual_env $bin] | path join)
|
47 |
+
let new_path = ($env | get $path_name | prepend $venv_path)
|
48 |
+
|
49 |
+
# If there is no default prompt, then use the env name instead
|
50 |
+
let virtual_env_prompt = (if ('multiplayer-chat-py3.12' | is-empty) {
|
51 |
+
($virtual_env | path basename)
|
52 |
+
} else {
|
53 |
+
'multiplayer-chat-py3.12'
|
54 |
+
})
|
55 |
+
|
56 |
+
let new_env = {
|
57 |
+
$path_name : $new_path
|
58 |
+
VIRTUAL_ENV : $virtual_env
|
59 |
+
VIRTUAL_ENV_PROMPT : $virtual_env_prompt
|
60 |
+
}
|
61 |
+
|
62 |
+
let new_env = (if (is-env-true 'VIRTUAL_ENV_DISABLE_PROMPT') {
|
63 |
+
$new_env
|
64 |
+
} else {
|
65 |
+
# Creating the new prompt for the session
|
66 |
+
let virtual_prefix = $'(char lparen)($virtual_env_prompt)(char rparen) '
|
67 |
+
|
68 |
+
# Back up the old prompt builder
|
69 |
+
let old_prompt_command = (if (has-env 'PROMPT_COMMAND') {
|
70 |
+
$env.PROMPT_COMMAND
|
71 |
+
} else {
|
72 |
+
''
|
73 |
+
})
|
74 |
+
|
75 |
+
let new_prompt = (if (has-env 'PROMPT_COMMAND') {
|
76 |
+
if 'closure' in ($old_prompt_command | describe) {
|
77 |
+
{|| $'($virtual_prefix)(do $old_prompt_command)' }
|
78 |
+
} else {
|
79 |
+
{|| $'($virtual_prefix)($old_prompt_command)' }
|
80 |
+
}
|
81 |
+
} else {
|
82 |
+
{|| $'($virtual_prefix)' }
|
83 |
+
})
|
84 |
+
|
85 |
+
$new_env | merge {
|
86 |
+
PROMPT_COMMAND : $new_prompt
|
87 |
+
VIRTUAL_PREFIX : $virtual_prefix
|
88 |
+
}
|
89 |
+
})
|
90 |
+
|
91 |
+
# Environment variables that will be loaded as the virtual env
|
92 |
+
load-env $new_env
|
93 |
+
}
|
94 |
+
|
95 |
+
export alias pydoc = python -m pydoc
|
96 |
+
export alias deactivate = overlay hide activate
|
.venv/bin/activate.ps1
ADDED
@@ -0,0 +1,61 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
$script:THIS_PATH = $myinvocation.mycommand.path
|
2 |
+
$script:BASE_DIR = Split-Path (Resolve-Path "$THIS_PATH/..") -Parent
|
3 |
+
|
4 |
+
function global:deactivate([switch] $NonDestructive) {
|
5 |
+
if (Test-Path variable:_OLD_VIRTUAL_PATH) {
|
6 |
+
$env:PATH = $variable:_OLD_VIRTUAL_PATH
|
7 |
+
Remove-Variable "_OLD_VIRTUAL_PATH" -Scope global
|
8 |
+
}
|
9 |
+
|
10 |
+
if (Test-Path function:_old_virtual_prompt) {
|
11 |
+
$function:prompt = $function:_old_virtual_prompt
|
12 |
+
Remove-Item function:\_old_virtual_prompt
|
13 |
+
}
|
14 |
+
|
15 |
+
if ($env:VIRTUAL_ENV) {
|
16 |
+
Remove-Item env:VIRTUAL_ENV -ErrorAction SilentlyContinue
|
17 |
+
}
|
18 |
+
|
19 |
+
if ($env:VIRTUAL_ENV_PROMPT) {
|
20 |
+
Remove-Item env:VIRTUAL_ENV_PROMPT -ErrorAction SilentlyContinue
|
21 |
+
}
|
22 |
+
|
23 |
+
if (!$NonDestructive) {
|
24 |
+
# Self destruct!
|
25 |
+
Remove-Item function:deactivate
|
26 |
+
Remove-Item function:pydoc
|
27 |
+
}
|
28 |
+
}
|
29 |
+
|
30 |
+
function global:pydoc {
|
31 |
+
python -m pydoc $args
|
32 |
+
}
|
33 |
+
|
34 |
+
# unset irrelevant variables
|
35 |
+
deactivate -nondestructive
|
36 |
+
|
37 |
+
$VIRTUAL_ENV = $BASE_DIR
|
38 |
+
$env:VIRTUAL_ENV = $VIRTUAL_ENV
|
39 |
+
|
40 |
+
if ("multiplayer-chat-py3.12" -ne "") {
|
41 |
+
$env:VIRTUAL_ENV_PROMPT = "multiplayer-chat-py3.12"
|
42 |
+
}
|
43 |
+
else {
|
44 |
+
$env:VIRTUAL_ENV_PROMPT = $( Split-Path $env:VIRTUAL_ENV -Leaf )
|
45 |
+
}
|
46 |
+
|
47 |
+
New-Variable -Scope global -Name _OLD_VIRTUAL_PATH -Value $env:PATH
|
48 |
+
|
49 |
+
$env:PATH = "$env:VIRTUAL_ENV/bin:" + $env:PATH
|
50 |
+
if (!$env:VIRTUAL_ENV_DISABLE_PROMPT) {
|
51 |
+
function global:_old_virtual_prompt {
|
52 |
+
""
|
53 |
+
}
|
54 |
+
$function:_old_virtual_prompt = $function:prompt
|
55 |
+
|
56 |
+
function global:prompt {
|
57 |
+
# Add the custom prefix to the existing prompt
|
58 |
+
$previous_prompt_value = & $function:_old_virtual_prompt
|
59 |
+
("(" + $env:VIRTUAL_ENV_PROMPT + ") " + $previous_prompt_value)
|
60 |
+
}
|
61 |
+
}
|
.venv/bin/activate_this.py
ADDED
@@ -0,0 +1,38 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
"""
|
2 |
+
Activate virtualenv for current interpreter:
|
3 |
+
|
4 |
+
import runpy
|
5 |
+
runpy.run_path(this_file)
|
6 |
+
|
7 |
+
This can be used when you must use an existing Python interpreter, not the virtualenv bin/python.
|
8 |
+
""" # noqa: D415
|
9 |
+
|
10 |
+
from __future__ import annotations
|
11 |
+
|
12 |
+
import os
|
13 |
+
import site
|
14 |
+
import sys
|
15 |
+
|
16 |
+
try:
|
17 |
+
abs_file = os.path.abspath(__file__)
|
18 |
+
except NameError as exc:
|
19 |
+
msg = "You must use import runpy; runpy.run_path(this_file)"
|
20 |
+
raise AssertionError(msg) from exc
|
21 |
+
|
22 |
+
bin_dir = os.path.dirname(abs_file)
|
23 |
+
base = bin_dir[: -len("bin") - 1] # strip away the bin part from the __file__, plus the path separator
|
24 |
+
|
25 |
+
# prepend bin to PATH (this file is inside the bin directory)
|
26 |
+
os.environ["PATH"] = os.pathsep.join([bin_dir, *os.environ.get("PATH", "").split(os.pathsep)])
|
27 |
+
os.environ["VIRTUAL_ENV"] = base # virtual env is right above bin directory
|
28 |
+
os.environ["VIRTUAL_ENV_PROMPT"] = "multiplayer-chat-py3.12" or os.path.basename(base) # noqa: SIM222
|
29 |
+
|
30 |
+
# add the virtual environments libraries to the host python import mechanism
|
31 |
+
prev_length = len(sys.path)
|
32 |
+
for lib in "../lib/python3.12/site-packages".split(os.pathsep):
|
33 |
+
path = os.path.realpath(os.path.join(bin_dir, lib))
|
34 |
+
site.addsitedir(path.decode("utf-8") if "" else path)
|
35 |
+
sys.path[:] = sys.path[prev_length:] + sys.path[0:prev_length]
|
36 |
+
|
37 |
+
sys.real_prefix = sys.prefix
|
38 |
+
sys.prefix = base
|
.venv/bin/dotenv
ADDED
@@ -0,0 +1,8 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/Users/richardblythman/code/models/multiplayer_chat_uni/tmp/multiplayer_chat/.venv/bin/python
|
2 |
+
# -*- coding: utf-8 -*-
|
3 |
+
import re
|
4 |
+
import sys
|
5 |
+
from dotenv.__main__ import cli
|
6 |
+
if __name__ == "__main__":
|
7 |
+
sys.argv[0] = re.sub(r"(-script\.pyw|\.exe)?$", "", sys.argv[0])
|
8 |
+
sys.exit(cli())
|
.venv/bin/httpx
ADDED
@@ -0,0 +1,8 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/Users/richardblythman/code/models/multiplayer_chat_uni/tmp/multiplayer_chat/.venv/bin/python
|
2 |
+
# -*- coding: utf-8 -*-
|
3 |
+
import re
|
4 |
+
import sys
|
5 |
+
from httpx import main
|
6 |
+
if __name__ == "__main__":
|
7 |
+
sys.argv[0] = re.sub(r"(-script\.pyw|\.exe)?$", "", sys.argv[0])
|
8 |
+
sys.exit(main())
|
.venv/bin/huggingface-cli
ADDED
@@ -0,0 +1,8 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/Users/richardblythman/code/models/multiplayer_chat_uni/tmp/multiplayer_chat/.venv/bin/python
|
2 |
+
# -*- coding: utf-8 -*-
|
3 |
+
import re
|
4 |
+
import sys
|
5 |
+
from huggingface_hub.commands.huggingface_cli import main
|
6 |
+
if __name__ == "__main__":
|
7 |
+
sys.argv[0] = re.sub(r"(-script\.pyw|\.exe)?$", "", sys.argv[0])
|
8 |
+
sys.exit(main())
|
.venv/bin/naptha
ADDED
@@ -0,0 +1,8 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/Users/richardblythman/code/models/multiplayer_chat_uni/tmp/multiplayer_chat/.venv/bin/python
|
2 |
+
# -*- coding: utf-8 -*-
|
3 |
+
import re
|
4 |
+
import sys
|
5 |
+
from cli import cli
|
6 |
+
if __name__ == "__main__":
|
7 |
+
sys.argv[0] = re.sub(r"(-script\.pyw|\.exe)?$", "", sys.argv[0])
|
8 |
+
sys.exit(cli())
|
.venv/bin/normalizer
ADDED
@@ -0,0 +1,8 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/Users/richardblythman/code/models/multiplayer_chat_uni/tmp/multiplayer_chat/.venv/bin/python
|
2 |
+
# -*- coding: utf-8 -*-
|
3 |
+
import re
|
4 |
+
import sys
|
5 |
+
from charset_normalizer.cli import cli_detect
|
6 |
+
if __name__ == "__main__":
|
7 |
+
sys.argv[0] = re.sub(r"(-script\.pyw|\.exe)?$", "", sys.argv[0])
|
8 |
+
sys.exit(cli_detect())
|
.venv/bin/pip
ADDED
@@ -0,0 +1,8 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/Users/richardblythman/code/models/multiplayer_chat_uni/tmp/multiplayer_chat/.venv/bin/python
|
2 |
+
# -*- coding: utf-8 -*-
|
3 |
+
import re
|
4 |
+
import sys
|
5 |
+
from pip._internal.cli.main import main
|
6 |
+
if __name__ == '__main__':
|
7 |
+
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
|
8 |
+
sys.exit(main())
|
.venv/bin/pip-3.12
ADDED
@@ -0,0 +1,8 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/Users/richardblythman/code/models/multiplayer_chat_uni/tmp/multiplayer_chat/.venv/bin/python
|
2 |
+
# -*- coding: utf-8 -*-
|
3 |
+
import re
|
4 |
+
import sys
|
5 |
+
from pip._internal.cli.main import main
|
6 |
+
if __name__ == '__main__':
|
7 |
+
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
|
8 |
+
sys.exit(main())
|
.venv/bin/pip3
ADDED
@@ -0,0 +1,8 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/Users/richardblythman/code/models/multiplayer_chat_uni/tmp/multiplayer_chat/.venv/bin/python
|
2 |
+
# -*- coding: utf-8 -*-
|
3 |
+
import re
|
4 |
+
import sys
|
5 |
+
from pip._internal.cli.main import main
|
6 |
+
if __name__ == '__main__':
|
7 |
+
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
|
8 |
+
sys.exit(main())
|
.venv/bin/pip3.12
ADDED
@@ -0,0 +1,8 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/Users/richardblythman/code/models/multiplayer_chat_uni/tmp/multiplayer_chat/.venv/bin/python
|
2 |
+
# -*- coding: utf-8 -*-
|
3 |
+
import re
|
4 |
+
import sys
|
5 |
+
from pip._internal.cli.main import main
|
6 |
+
if __name__ == '__main__':
|
7 |
+
sys.argv[0] = re.sub(r'(-script\.pyw|\.exe)?$', '', sys.argv[0])
|
8 |
+
sys.exit(main())
|
.venv/bin/python
ADDED
Binary file (52.6 kB). View file
|
|
.venv/bin/python3
ADDED
Binary file (52.6 kB). View file
|
|
.venv/bin/python3.12
ADDED
Binary file (52.6 kB). View file
|
|
.venv/bin/tqdm
ADDED
@@ -0,0 +1,8 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/Users/richardblythman/code/models/multiplayer_chat_uni/tmp/multiplayer_chat/.venv/bin/python
|
2 |
+
# -*- coding: utf-8 -*-
|
3 |
+
import re
|
4 |
+
import sys
|
5 |
+
from tqdm.cli import main
|
6 |
+
if __name__ == "__main__":
|
7 |
+
sys.argv[0] = re.sub(r"(-script\.pyw|\.exe)?$", "", sys.argv[0])
|
8 |
+
sys.exit(main())
|
.venv/lib/python3.12/site-packages/PyJWT-2.9.0.dist-info/AUTHORS.rst
ADDED
@@ -0,0 +1,7 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
Authors
|
2 |
+
=======
|
3 |
+
|
4 |
+
``pyjwt`` is currently written and maintained by `Jose Padilla <https://github.com/jpadilla>`_.
|
5 |
+
Originally written and maintained by `Jeff Lindsay <https://github.com/progrium>`_.
|
6 |
+
|
7 |
+
A full list of contributors can be found on GitHub’s `overview <https://github.com/jpadilla/pyjwt/graphs/contributors>`_.
|
.venv/lib/python3.12/site-packages/PyJWT-2.9.0.dist-info/INSTALLER
ADDED
@@ -0,0 +1 @@
|
|
|
|
|
1 |
+
Poetry 1.8.3
|
.venv/lib/python3.12/site-packages/PyJWT-2.9.0.dist-info/LICENSE
ADDED
@@ -0,0 +1,21 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
The MIT License (MIT)
|
2 |
+
|
3 |
+
Copyright (c) 2015-2022 José Padilla
|
4 |
+
|
5 |
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
6 |
+
of this software and associated documentation files (the "Software"), to deal
|
7 |
+
in the Software without restriction, including without limitation the rights
|
8 |
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
9 |
+
copies of the Software, and to permit persons to whom the Software is
|
10 |
+
furnished to do so, subject to the following conditions:
|
11 |
+
|
12 |
+
The above copyright notice and this permission notice shall be included in all
|
13 |
+
copies or substantial portions of the Software.
|
14 |
+
|
15 |
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
16 |
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
17 |
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
18 |
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
19 |
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
20 |
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
21 |
+
SOFTWARE.
|
.venv/lib/python3.12/site-packages/PyJWT-2.9.0.dist-info/METADATA
ADDED
@@ -0,0 +1,97 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
Metadata-Version: 2.1
|
2 |
+
Name: PyJWT
|
3 |
+
Version: 2.9.0
|
4 |
+
Summary: JSON Web Token implementation in Python
|
5 |
+
Home-page: https://github.com/jpadilla/pyjwt
|
6 |
+
Author: Jose Padilla
|
7 |
+
Author-email: [email protected]
|
8 |
+
License: MIT
|
9 |
+
Keywords: json,jwt,security,signing,token,web
|
10 |
+
Classifier: Development Status :: 5 - Production/Stable
|
11 |
+
Classifier: Intended Audience :: Developers
|
12 |
+
Classifier: Natural Language :: English
|
13 |
+
Classifier: License :: OSI Approved :: MIT License
|
14 |
+
Classifier: Programming Language :: Python
|
15 |
+
Classifier: Programming Language :: Python :: 3
|
16 |
+
Classifier: Programming Language :: Python :: 3 :: Only
|
17 |
+
Classifier: Programming Language :: Python :: 3.8
|
18 |
+
Classifier: Programming Language :: Python :: 3.9
|
19 |
+
Classifier: Programming Language :: Python :: 3.10
|
20 |
+
Classifier: Programming Language :: Python :: 3.11
|
21 |
+
Classifier: Programming Language :: Python :: 3.12
|
22 |
+
Classifier: Topic :: Utilities
|
23 |
+
Requires-Python: >=3.8
|
24 |
+
Description-Content-Type: text/x-rst
|
25 |
+
License-File: LICENSE
|
26 |
+
License-File: AUTHORS.rst
|
27 |
+
Provides-Extra: crypto
|
28 |
+
Requires-Dist: cryptography >=3.4.0 ; extra == 'crypto'
|
29 |
+
Provides-Extra: dev
|
30 |
+
Requires-Dist: sphinx ; extra == 'dev'
|
31 |
+
Requires-Dist: sphinx-rtd-theme ; extra == 'dev'
|
32 |
+
Requires-Dist: zope.interface ; extra == 'dev'
|
33 |
+
Requires-Dist: cryptography >=3.4.0 ; extra == 'dev'
|
34 |
+
Requires-Dist: pytest <7.0.0,>=6.0.0 ; extra == 'dev'
|
35 |
+
Requires-Dist: coverage[toml] ==5.0.4 ; extra == 'dev'
|
36 |
+
Requires-Dist: pre-commit ; extra == 'dev'
|
37 |
+
Provides-Extra: docs
|
38 |
+
Requires-Dist: sphinx ; extra == 'docs'
|
39 |
+
Requires-Dist: sphinx-rtd-theme ; extra == 'docs'
|
40 |
+
Requires-Dist: zope.interface ; extra == 'docs'
|
41 |
+
Provides-Extra: tests
|
42 |
+
Requires-Dist: pytest <7.0.0,>=6.0.0 ; extra == 'tests'
|
43 |
+
Requires-Dist: coverage[toml] ==5.0.4 ; extra == 'tests'
|
44 |
+
|
45 |
+
PyJWT
|
46 |
+
=====
|
47 |
+
|
48 |
+
.. image:: https://github.com/jpadilla/pyjwt/workflows/CI/badge.svg
|
49 |
+
:target: https://github.com/jpadilla/pyjwt/actions?query=workflow%3ACI
|
50 |
+
|
51 |
+
.. image:: https://img.shields.io/pypi/v/pyjwt.svg
|
52 |
+
:target: https://pypi.python.org/pypi/pyjwt
|
53 |
+
|
54 |
+
.. image:: https://codecov.io/gh/jpadilla/pyjwt/branch/master/graph/badge.svg
|
55 |
+
:target: https://codecov.io/gh/jpadilla/pyjwt
|
56 |
+
|
57 |
+
.. image:: https://readthedocs.org/projects/pyjwt/badge/?version=stable
|
58 |
+
:target: https://pyjwt.readthedocs.io/en/stable/
|
59 |
+
|
60 |
+
A Python implementation of `RFC 7519 <https://tools.ietf.org/html/rfc7519>`_. Original implementation was written by `@progrium <https://github.com/progrium>`_.
|
61 |
+
|
62 |
+
Installing
|
63 |
+
----------
|
64 |
+
|
65 |
+
Install with **pip**:
|
66 |
+
|
67 |
+
.. code-block:: console
|
68 |
+
|
69 |
+
$ pip install PyJWT
|
70 |
+
|
71 |
+
|
72 |
+
Usage
|
73 |
+
-----
|
74 |
+
|
75 |
+
.. code-block:: pycon
|
76 |
+
|
77 |
+
>>> import jwt
|
78 |
+
>>> encoded = jwt.encode({"some": "payload"}, "secret", algorithm="HS256")
|
79 |
+
>>> print(encoded)
|
80 |
+
eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzb21lIjoicGF5bG9hZCJ9.4twFt5NiznN84AWoo1d7KO1T_yoc0Z6XOpOVswacPZg
|
81 |
+
>>> jwt.decode(encoded, "secret", algorithms=["HS256"])
|
82 |
+
{'some': 'payload'}
|
83 |
+
|
84 |
+
Documentation
|
85 |
+
-------------
|
86 |
+
|
87 |
+
View the full docs online at https://pyjwt.readthedocs.io/en/stable/
|
88 |
+
|
89 |
+
|
90 |
+
Tests
|
91 |
+
-----
|
92 |
+
|
93 |
+
You can run tests from the project root after cloning with:
|
94 |
+
|
95 |
+
.. code-block:: console
|
96 |
+
|
97 |
+
$ tox
|
.venv/lib/python3.12/site-packages/PyJWT-2.9.0.dist-info/RECORD
ADDED
@@ -0,0 +1,20 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
jwt/__init__.py,sha256=TlvdnR8JPnAKjXE3Yt4qSA4AApcb0_9fh4RppJfnMcU,1670
|
2 |
+
jwt/algorithms.py,sha256=5MLQ2WIhHPiN--67afLk4yXOLsYfx2OiNeLVORZT3G8,29851
|
3 |
+
jwt/api_jwk.py,sha256=6F1r7rmm8V5qEnBKA_xMjS9R7VoANe1_BL1oD2FrAjE,4451
|
4 |
+
jwt/api_jws.py,sha256=1cBVJuYxo6UrDU6UH4VTA2EqctBj1x7mNlnNb-Ocn4g,11425
|
5 |
+
jwt/api_jwt.py,sha256=gsmF7wVxKFfsDBjrMq-M2UiyUBzl6U6YwaEqNdN1zkM,12875
|
6 |
+
jwt/exceptions.py,sha256=xaWnosa-cREyXMyb7PYmLfQv9weZ7Q9XUYMiLJvN0hA,1101
|
7 |
+
jwt/help.py,sha256=Jrp84fG43sCwmSIaDtY08I6ZR2VE7NhrTff89tYSE40,1749
|
8 |
+
jwt/jwk_set_cache.py,sha256=hBKmN-giU7-G37L_XKgc_OZu2ah4wdbj1ZNG_GkoSE8,959
|
9 |
+
jwt/jwks_client.py,sha256=9W8JVyGByQgoLbBN1u5iY1_jlgfnnukeOBTpqaM_9SE,4222
|
10 |
+
jwt/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
11 |
+
jwt/types.py,sha256=VnhGv_VFu5a7_mrPoSCB7HaNLrJdhM8Sq1sSfEg0gLU,99
|
12 |
+
jwt/utils.py,sha256=efS6RKCALEBeBw-uZj8VtzfZFFcECTd28q9ndNn9huw,3544
|
13 |
+
jwt/warnings.py,sha256=50XWOnyNsIaqzUJTk6XHNiIDykiL763GYA92MjTKmok,59
|
14 |
+
PyJWT-2.9.0.dist-info/AUTHORS.rst,sha256=klzkNGECnu2_VY7At89_xLBF3vUSDruXk3xwgUBxzwc,322
|
15 |
+
PyJWT-2.9.0.dist-info/LICENSE,sha256=eXp6ICMdTEM-nxkR2xcx0GtYKLmPSZgZoDT3wPVvXOU,1085
|
16 |
+
PyJWT-2.9.0.dist-info/METADATA,sha256=YRmm4Pcq065Rja5Gzuh80YA2groQSgOR8I1Cx0MF8EM,3048
|
17 |
+
PyJWT-2.9.0.dist-info/WHEEL,sha256=R0nc6qTxuoLk7ShA2_Y-UWkN8ZdfDBG2B6Eqpz2WXbs,91
|
18 |
+
PyJWT-2.9.0.dist-info/top_level.txt,sha256=RP5DHNyJbMq2ka0FmfTgoSaQzh7e3r5XuCWCO8a00k8,4
|
19 |
+
PyJWT-2.9.0.dist-info/INSTALLER,sha256=HLHRd3rVxZqLVn0Nby492_jJUNACT5LifwfFYrwaW0E,12
|
20 |
+
PyJWT-2.9.0.dist-info/RECORD,,
|
.venv/lib/python3.12/site-packages/PyJWT-2.9.0.dist-info/WHEEL
ADDED
@@ -0,0 +1,5 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
Wheel-Version: 1.0
|
2 |
+
Generator: setuptools (72.1.0)
|
3 |
+
Root-Is-Purelib: true
|
4 |
+
Tag: py3-none-any
|
5 |
+
|
.venv/lib/python3.12/site-packages/PyJWT-2.9.0.dist-info/top_level.txt
ADDED
@@ -0,0 +1 @@
|
|
|
|
|
1 |
+
jwt
|
.venv/lib/python3.12/site-packages/PyYAML-6.0.2.dist-info/INSTALLER
ADDED
@@ -0,0 +1 @@
|
|
|
|
|
1 |
+
Poetry 1.8.3
|
.venv/lib/python3.12/site-packages/PyYAML-6.0.2.dist-info/LICENSE
ADDED
@@ -0,0 +1,20 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
Copyright (c) 2017-2021 Ingy döt Net
|
2 |
+
Copyright (c) 2006-2016 Kirill Simonov
|
3 |
+
|
4 |
+
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
5 |
+
this software and associated documentation files (the "Software"), to deal in
|
6 |
+
the Software without restriction, including without limitation the rights to
|
7 |
+
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
8 |
+
of the Software, and to permit persons to whom the Software is furnished to do
|
9 |
+
so, subject to the following conditions:
|
10 |
+
|
11 |
+
The above copyright notice and this permission notice shall be included in all
|
12 |
+
copies or substantial portions of the Software.
|
13 |
+
|
14 |
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
15 |
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
16 |
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
17 |
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
18 |
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
19 |
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
20 |
+
SOFTWARE.
|
.venv/lib/python3.12/site-packages/PyYAML-6.0.2.dist-info/METADATA
ADDED
@@ -0,0 +1,46 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
Metadata-Version: 2.1
|
2 |
+
Name: PyYAML
|
3 |
+
Version: 6.0.2
|
4 |
+
Summary: YAML parser and emitter for Python
|
5 |
+
Home-page: https://pyyaml.org/
|
6 |
+
Download-URL: https://pypi.org/project/PyYAML/
|
7 |
+
Author: Kirill Simonov
|
8 |
+
Author-email: [email protected]
|
9 |
+
License: MIT
|
10 |
+
Project-URL: Bug Tracker, https://github.com/yaml/pyyaml/issues
|
11 |
+
Project-URL: CI, https://github.com/yaml/pyyaml/actions
|
12 |
+
Project-URL: Documentation, https://pyyaml.org/wiki/PyYAMLDocumentation
|
13 |
+
Project-URL: Mailing lists, http://lists.sourceforge.net/lists/listinfo/yaml-core
|
14 |
+
Project-URL: Source Code, https://github.com/yaml/pyyaml
|
15 |
+
Platform: Any
|
16 |
+
Classifier: Development Status :: 5 - Production/Stable
|
17 |
+
Classifier: Intended Audience :: Developers
|
18 |
+
Classifier: License :: OSI Approved :: MIT License
|
19 |
+
Classifier: Operating System :: OS Independent
|
20 |
+
Classifier: Programming Language :: Cython
|
21 |
+
Classifier: Programming Language :: Python
|
22 |
+
Classifier: Programming Language :: Python :: 3
|
23 |
+
Classifier: Programming Language :: Python :: 3.8
|
24 |
+
Classifier: Programming Language :: Python :: 3.9
|
25 |
+
Classifier: Programming Language :: Python :: 3.10
|
26 |
+
Classifier: Programming Language :: Python :: 3.11
|
27 |
+
Classifier: Programming Language :: Python :: 3.12
|
28 |
+
Classifier: Programming Language :: Python :: 3.13
|
29 |
+
Classifier: Programming Language :: Python :: Implementation :: CPython
|
30 |
+
Classifier: Programming Language :: Python :: Implementation :: PyPy
|
31 |
+
Classifier: Topic :: Software Development :: Libraries :: Python Modules
|
32 |
+
Classifier: Topic :: Text Processing :: Markup
|
33 |
+
Requires-Python: >=3.8
|
34 |
+
License-File: LICENSE
|
35 |
+
|
36 |
+
YAML is a data serialization format designed for human readability
|
37 |
+
and interaction with scripting languages. PyYAML is a YAML parser
|
38 |
+
and emitter for Python.
|
39 |
+
|
40 |
+
PyYAML features a complete YAML 1.1 parser, Unicode support, pickle
|
41 |
+
support, capable extension API, and sensible error messages. PyYAML
|
42 |
+
supports standard YAML tags and provides Python-specific tags that
|
43 |
+
allow to represent an arbitrary Python object.
|
44 |
+
|
45 |
+
PyYAML is applicable for a broad range of tasks from complex
|
46 |
+
configuration files to object serialization and persistence.
|
.venv/lib/python3.12/site-packages/PyYAML-6.0.2.dist-info/RECORD
ADDED
@@ -0,0 +1,25 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
_yaml/__init__.py,sha256=04Ae_5osxahpJHa3XBZUAf4wi6XX32gR8D6X6p64GEA,1402
|
2 |
+
yaml/scanner.py,sha256=YEM3iLZSaQwXcQRg2l2R4MdT0zGP2F9eHkKGKnHyWQY,51279
|
3 |
+
yaml/error.py,sha256=Ah9z-toHJUbE9j-M8YpxgSRM5CgLCcwVzJgLLRF2Fxo,2533
|
4 |
+
yaml/constructor.py,sha256=kNgkfaeLUkwQYY_Q6Ff1Tz2XVw_pG1xVE9Ak7z-viLA,28639
|
5 |
+
yaml/composer.py,sha256=_Ko30Wr6eDWUeUpauUGT3Lcg9QPBnOPVlTnIMRGJ9FM,4883
|
6 |
+
yaml/events.py,sha256=50_TksgQiE4up-lKo_V-nBy-tAIxkIPQxY5qDhKCeHw,2445
|
7 |
+
yaml/__init__.py,sha256=N35S01HMesFTe0aRRMWkPj0Pa8IEbHpE9FK7cr5Bdtw,12311
|
8 |
+
yaml/representer.py,sha256=IuWP-cAW9sHKEnS0gCqSa894k1Bg4cgTxaDwIcbRQ-Y,14190
|
9 |
+
yaml/_yaml.cpython-312-darwin.so,sha256=kJhYpZpKSMBUaR-esOCOg7Ao1QLyNGl3tVdptwNUd6Y,375656
|
10 |
+
yaml/tokens.py,sha256=lTQIzSVw8Mg9wv459-TjiOQe6wVziqaRlqX2_89rp54,2573
|
11 |
+
yaml/dumper.py,sha256=PLctZlYwZLp7XmeUdwRuv4nYOZ2UBnDIUy8-lKfLF-o,2837
|
12 |
+
yaml/cyaml.py,sha256=6ZrAG9fAYvdVe2FK_w0hmXoG7ZYsoYUwapG8CiC72H0,3851
|
13 |
+
yaml/parser.py,sha256=ilWp5vvgoHFGzvOZDItFoGjD6D42nhlZrZyjAwa0oJo,25495
|
14 |
+
yaml/reader.py,sha256=0dmzirOiDG4Xo41RnuQS7K9rkY3xjHiVasfDMNTqCNw,6794
|
15 |
+
yaml/loader.py,sha256=UVa-zIqmkFSCIYq_PgSGm4NSJttHY2Rf_zQ4_b1fHN0,2061
|
16 |
+
yaml/resolver.py,sha256=9L-VYfm4mWHxUD1Vg4X7rjDRK_7VZd6b92wzq7Y2IKY,9004
|
17 |
+
yaml/serializer.py,sha256=ChuFgmhU01hj4xgI8GaKv6vfM2Bujwa9i7d2FAHj7cA,4165
|
18 |
+
yaml/nodes.py,sha256=gPKNj8pKCdh2d4gr3gIYINnPOaOxGhJAUiYhGRnPE84,1440
|
19 |
+
yaml/emitter.py,sha256=jghtaU7eFwg31bG0B7RZea_29Adi9CKmXq_QjgQpCkQ,43006
|
20 |
+
PyYAML-6.0.2.dist-info/LICENSE,sha256=jTko-dxEkP1jVwfLiOsmvXZBAqcoKVQwfT5RZ6V36KQ,1101
|
21 |
+
PyYAML-6.0.2.dist-info/WHEEL,sha256=h9jBNgvnuEaix45NgESHvfNcOPGGNEywrbP9Un7hZlk,110
|
22 |
+
PyYAML-6.0.2.dist-info/top_level.txt,sha256=rpj0IVMTisAjh_1vG3Ccf9v5jpCQwAz6cD1IVU5ZdhQ,11
|
23 |
+
PyYAML-6.0.2.dist-info/METADATA,sha256=9-odFB5seu4pGPcEv7E8iyxNF51_uKnaNGjLAhz2lto,2060
|
24 |
+
PyYAML-6.0.2.dist-info/INSTALLER,sha256=HLHRd3rVxZqLVn0Nby492_jJUNACT5LifwfFYrwaW0E,12
|
25 |
+
PyYAML-6.0.2.dist-info/RECORD,,
|
.venv/lib/python3.12/site-packages/PyYAML-6.0.2.dist-info/WHEEL
ADDED
@@ -0,0 +1,5 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
Wheel-Version: 1.0
|
2 |
+
Generator: bdist_wheel (0.44.0)
|
3 |
+
Root-Is-Purelib: false
|
4 |
+
Tag: cp312-cp312-macosx_11_0_arm64
|
5 |
+
|
.venv/lib/python3.12/site-packages/PyYAML-6.0.2.dist-info/top_level.txt
ADDED
@@ -0,0 +1,2 @@
|
|
|
|
|
|
|
1 |
+
_yaml
|
2 |
+
yaml
|
.venv/lib/python3.12/site-packages/__pycache__/_virtualenv.cpython-312.pyc
ADDED
Binary file (4.21 kB). View file
|
|
.venv/lib/python3.12/site-packages/_virtualenv.pth
ADDED
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
1 |
+
version https://git-lfs.github.com/spec/v1
|
2 |
+
oid sha256:69ac3d8f27e679c81b94ab30b3b56e9cd138219b1ba94a1fa3606d5a76a1433d
|
3 |
+
size 18
|
.venv/lib/python3.12/site-packages/_virtualenv.py
ADDED
@@ -0,0 +1,103 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
"""Patches that are applied at runtime to the virtual environment."""
|
2 |
+
|
3 |
+
from __future__ import annotations
|
4 |
+
|
5 |
+
import os
|
6 |
+
import sys
|
7 |
+
|
8 |
+
VIRTUALENV_PATCH_FILE = os.path.join(__file__)
|
9 |
+
|
10 |
+
|
11 |
+
def patch_dist(dist):
|
12 |
+
"""
|
13 |
+
Distutils allows user to configure some arguments via a configuration file:
|
14 |
+
https://docs.python.org/3/install/index.html#distutils-configuration-files.
|
15 |
+
|
16 |
+
Some of this arguments though don't make sense in context of the virtual environment files, let's fix them up.
|
17 |
+
""" # noqa: D205
|
18 |
+
# we cannot allow some install config as that would get packages installed outside of the virtual environment
|
19 |
+
old_parse_config_files = dist.Distribution.parse_config_files
|
20 |
+
|
21 |
+
def parse_config_files(self, *args, **kwargs):
|
22 |
+
result = old_parse_config_files(self, *args, **kwargs)
|
23 |
+
install = self.get_option_dict("install")
|
24 |
+
|
25 |
+
if "prefix" in install: # the prefix governs where to install the libraries
|
26 |
+
install["prefix"] = VIRTUALENV_PATCH_FILE, os.path.abspath(sys.prefix)
|
27 |
+
for base in ("purelib", "platlib", "headers", "scripts", "data"):
|
28 |
+
key = f"install_{base}"
|
29 |
+
if key in install: # do not allow global configs to hijack venv paths
|
30 |
+
install.pop(key, None)
|
31 |
+
return result
|
32 |
+
|
33 |
+
dist.Distribution.parse_config_files = parse_config_files
|
34 |
+
|
35 |
+
|
36 |
+
# Import hook that patches some modules to ignore configuration values that break package installation in case
|
37 |
+
# of virtual environments.
|
38 |
+
_DISTUTILS_PATCH = "distutils.dist", "setuptools.dist"
|
39 |
+
# https://docs.python.org/3/library/importlib.html#setting-up-an-importer
|
40 |
+
|
41 |
+
|
42 |
+
class _Finder:
|
43 |
+
"""A meta path finder that allows patching the imported distutils modules."""
|
44 |
+
|
45 |
+
fullname = None
|
46 |
+
|
47 |
+
# lock[0] is threading.Lock(), but initialized lazily to avoid importing threading very early at startup,
|
48 |
+
# because there are gevent-based applications that need to be first to import threading by themselves.
|
49 |
+
# See https://github.com/pypa/virtualenv/issues/1895 for details.
|
50 |
+
lock = [] # noqa: RUF012
|
51 |
+
|
52 |
+
def find_spec(self, fullname, path, target=None): # noqa: ARG002
|
53 |
+
if fullname in _DISTUTILS_PATCH and self.fullname is None: # noqa: PLR1702
|
54 |
+
# initialize lock[0] lazily
|
55 |
+
if len(self.lock) == 0:
|
56 |
+
import threading # noqa: PLC0415
|
57 |
+
|
58 |
+
lock = threading.Lock()
|
59 |
+
# there is possibility that two threads T1 and T2 are simultaneously running into find_spec,
|
60 |
+
# observing .lock as empty, and further going into hereby initialization. However due to the GIL,
|
61 |
+
# list.append() operation is atomic and this way only one of the threads will "win" to put the lock
|
62 |
+
# - that every thread will use - into .lock[0].
|
63 |
+
# https://docs.python.org/3/faq/library.html#what-kinds-of-global-value-mutation-are-thread-safe
|
64 |
+
self.lock.append(lock)
|
65 |
+
|
66 |
+
from functools import partial # noqa: PLC0415
|
67 |
+
from importlib.util import find_spec # noqa: PLC0415
|
68 |
+
|
69 |
+
with self.lock[0]:
|
70 |
+
self.fullname = fullname
|
71 |
+
try:
|
72 |
+
spec = find_spec(fullname, path)
|
73 |
+
if spec is not None:
|
74 |
+
# https://www.python.org/dev/peps/pep-0451/#how-loading-will-work
|
75 |
+
is_new_api = hasattr(spec.loader, "exec_module")
|
76 |
+
func_name = "exec_module" if is_new_api else "load_module"
|
77 |
+
old = getattr(spec.loader, func_name)
|
78 |
+
func = self.exec_module if is_new_api else self.load_module
|
79 |
+
if old is not func:
|
80 |
+
try: # noqa: SIM105
|
81 |
+
setattr(spec.loader, func_name, partial(func, old))
|
82 |
+
except AttributeError:
|
83 |
+
pass # C-Extension loaders are r/o such as zipimporter with <3.7
|
84 |
+
return spec
|
85 |
+
finally:
|
86 |
+
self.fullname = None
|
87 |
+
return None
|
88 |
+
|
89 |
+
@staticmethod
|
90 |
+
def exec_module(old, module):
|
91 |
+
old(module)
|
92 |
+
if module.__name__ in _DISTUTILS_PATCH:
|
93 |
+
patch_dist(module)
|
94 |
+
|
95 |
+
@staticmethod
|
96 |
+
def load_module(old, name):
|
97 |
+
module = old(name)
|
98 |
+
if module.__name__ in _DISTUTILS_PATCH:
|
99 |
+
patch_dist(module)
|
100 |
+
return module
|
101 |
+
|
102 |
+
|
103 |
+
sys.meta_path.insert(0, _Finder())
|
.venv/lib/python3.12/site-packages/_yaml/__init__.py
ADDED
@@ -0,0 +1,33 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
# This is a stub package designed to roughly emulate the _yaml
|
2 |
+
# extension module, which previously existed as a standalone module
|
3 |
+
# and has been moved into the `yaml` package namespace.
|
4 |
+
# It does not perfectly mimic its old counterpart, but should get
|
5 |
+
# close enough for anyone who's relying on it even when they shouldn't.
|
6 |
+
import yaml
|
7 |
+
|
8 |
+
# in some circumstances, the yaml module we imoprted may be from a different version, so we need
|
9 |
+
# to tread carefully when poking at it here (it may not have the attributes we expect)
|
10 |
+
if not getattr(yaml, '__with_libyaml__', False):
|
11 |
+
from sys import version_info
|
12 |
+
|
13 |
+
exc = ModuleNotFoundError if version_info >= (3, 6) else ImportError
|
14 |
+
raise exc("No module named '_yaml'")
|
15 |
+
else:
|
16 |
+
from yaml._yaml import *
|
17 |
+
import warnings
|
18 |
+
warnings.warn(
|
19 |
+
'The _yaml extension module is now located at yaml._yaml'
|
20 |
+
' and its location is subject to change. To use the'
|
21 |
+
' LibYAML-based parser and emitter, import from `yaml`:'
|
22 |
+
' `from yaml import CLoader as Loader, CDumper as Dumper`.',
|
23 |
+
DeprecationWarning
|
24 |
+
)
|
25 |
+
del warnings
|
26 |
+
# Don't `del yaml` here because yaml is actually an existing
|
27 |
+
# namespace member of _yaml.
|
28 |
+
|
29 |
+
__name__ = '_yaml'
|
30 |
+
# If the module is top-level (i.e. not a part of any specific package)
|
31 |
+
# then the attribute should be set to ''.
|
32 |
+
# https://docs.python.org/3.8/library/types.html
|
33 |
+
__package__ = ''
|
.venv/lib/python3.12/site-packages/annotated_types-0.7.0.dist-info/INSTALLER
ADDED
@@ -0,0 +1 @@
|
|
|
|
|
1 |
+
Poetry 1.8.3
|
.venv/lib/python3.12/site-packages/annotated_types-0.7.0.dist-info/METADATA
ADDED
@@ -0,0 +1,295 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
Metadata-Version: 2.3
|
2 |
+
Name: annotated-types
|
3 |
+
Version: 0.7.0
|
4 |
+
Summary: Reusable constraint types to use with typing.Annotated
|
5 |
+
Project-URL: Homepage, https://github.com/annotated-types/annotated-types
|
6 |
+
Project-URL: Source, https://github.com/annotated-types/annotated-types
|
7 |
+
Project-URL: Changelog, https://github.com/annotated-types/annotated-types/releases
|
8 |
+
Author-email: Adrian Garcia Badaracco <[email protected]>, Samuel Colvin <[email protected]>, Zac Hatfield-Dodds <[email protected]>
|
9 |
+
License-File: LICENSE
|
10 |
+
Classifier: Development Status :: 4 - Beta
|
11 |
+
Classifier: Environment :: Console
|
12 |
+
Classifier: Environment :: MacOS X
|
13 |
+
Classifier: Intended Audience :: Developers
|
14 |
+
Classifier: Intended Audience :: Information Technology
|
15 |
+
Classifier: License :: OSI Approved :: MIT License
|
16 |
+
Classifier: Operating System :: POSIX :: Linux
|
17 |
+
Classifier: Operating System :: Unix
|
18 |
+
Classifier: Programming Language :: Python :: 3 :: Only
|
19 |
+
Classifier: Programming Language :: Python :: 3.8
|
20 |
+
Classifier: Programming Language :: Python :: 3.9
|
21 |
+
Classifier: Programming Language :: Python :: 3.10
|
22 |
+
Classifier: Programming Language :: Python :: 3.11
|
23 |
+
Classifier: Programming Language :: Python :: 3.12
|
24 |
+
Classifier: Topic :: Software Development :: Libraries :: Python Modules
|
25 |
+
Classifier: Typing :: Typed
|
26 |
+
Requires-Python: >=3.8
|
27 |
+
Requires-Dist: typing-extensions>=4.0.0; python_version < '3.9'
|
28 |
+
Description-Content-Type: text/markdown
|
29 |
+
|
30 |
+
# annotated-types
|
31 |
+
|
32 |
+
[![CI](https://github.com/annotated-types/annotated-types/workflows/CI/badge.svg?event=push)](https://github.com/annotated-types/annotated-types/actions?query=event%3Apush+branch%3Amain+workflow%3ACI)
|
33 |
+
[![pypi](https://img.shields.io/pypi/v/annotated-types.svg)](https://pypi.python.org/pypi/annotated-types)
|
34 |
+
[![versions](https://img.shields.io/pypi/pyversions/annotated-types.svg)](https://github.com/annotated-types/annotated-types)
|
35 |
+
[![license](https://img.shields.io/github/license/annotated-types/annotated-types.svg)](https://github.com/annotated-types/annotated-types/blob/main/LICENSE)
|
36 |
+
|
37 |
+
[PEP-593](https://peps.python.org/pep-0593/) added `typing.Annotated` as a way of
|
38 |
+
adding context-specific metadata to existing types, and specifies that
|
39 |
+
`Annotated[T, x]` _should_ be treated as `T` by any tool or library without special
|
40 |
+
logic for `x`.
|
41 |
+
|
42 |
+
This package provides metadata objects which can be used to represent common
|
43 |
+
constraints such as upper and lower bounds on scalar values and collection sizes,
|
44 |
+
a `Predicate` marker for runtime checks, and
|
45 |
+
descriptions of how we intend these metadata to be interpreted. In some cases,
|
46 |
+
we also note alternative representations which do not require this package.
|
47 |
+
|
48 |
+
## Install
|
49 |
+
|
50 |
+
```bash
|
51 |
+
pip install annotated-types
|
52 |
+
```
|
53 |
+
|
54 |
+
## Examples
|
55 |
+
|
56 |
+
```python
|
57 |
+
from typing import Annotated
|
58 |
+
from annotated_types import Gt, Len, Predicate
|
59 |
+
|
60 |
+
class MyClass:
|
61 |
+
age: Annotated[int, Gt(18)] # Valid: 19, 20, ...
|
62 |
+
# Invalid: 17, 18, "19", 19.0, ...
|
63 |
+
factors: list[Annotated[int, Predicate(is_prime)]] # Valid: 2, 3, 5, 7, 11, ...
|
64 |
+
# Invalid: 4, 8, -2, 5.0, "prime", ...
|
65 |
+
|
66 |
+
my_list: Annotated[list[int], Len(0, 10)] # Valid: [], [10, 20, 30, 40, 50]
|
67 |
+
# Invalid: (1, 2), ["abc"], [0] * 20
|
68 |
+
```
|
69 |
+
|
70 |
+
## Documentation
|
71 |
+
|
72 |
+
_While `annotated-types` avoids runtime checks for performance, users should not
|
73 |
+
construct invalid combinations such as `MultipleOf("non-numeric")` or `Annotated[int, Len(3)]`.
|
74 |
+
Downstream implementors may choose to raise an error, emit a warning, silently ignore
|
75 |
+
a metadata item, etc., if the metadata objects described below are used with an
|
76 |
+
incompatible type - or for any other reason!_
|
77 |
+
|
78 |
+
### Gt, Ge, Lt, Le
|
79 |
+
|
80 |
+
Express inclusive and/or exclusive bounds on orderable values - which may be numbers,
|
81 |
+
dates, times, strings, sets, etc. Note that the boundary value need not be of the
|
82 |
+
same type that was annotated, so long as they can be compared: `Annotated[int, Gt(1.5)]`
|
83 |
+
is fine, for example, and implies that the value is an integer x such that `x > 1.5`.
|
84 |
+
|
85 |
+
We suggest that implementors may also interpret `functools.partial(operator.le, 1.5)`
|
86 |
+
as being equivalent to `Gt(1.5)`, for users who wish to avoid a runtime dependency on
|
87 |
+
the `annotated-types` package.
|
88 |
+
|
89 |
+
To be explicit, these types have the following meanings:
|
90 |
+
|
91 |
+
* `Gt(x)` - value must be "Greater Than" `x` - equivalent to exclusive minimum
|
92 |
+
* `Ge(x)` - value must be "Greater than or Equal" to `x` - equivalent to inclusive minimum
|
93 |
+
* `Lt(x)` - value must be "Less Than" `x` - equivalent to exclusive maximum
|
94 |
+
* `Le(x)` - value must be "Less than or Equal" to `x` - equivalent to inclusive maximum
|
95 |
+
|
96 |
+
### Interval
|
97 |
+
|
98 |
+
`Interval(gt, ge, lt, le)` allows you to specify an upper and lower bound with a single
|
99 |
+
metadata object. `None` attributes should be ignored, and non-`None` attributes
|
100 |
+
treated as per the single bounds above.
|
101 |
+
|
102 |
+
### MultipleOf
|
103 |
+
|
104 |
+
`MultipleOf(multiple_of=x)` might be interpreted in two ways:
|
105 |
+
|
106 |
+
1. Python semantics, implying `value % multiple_of == 0`, or
|
107 |
+
2. [JSONschema semantics](https://json-schema.org/draft/2020-12/json-schema-validation.html#rfc.section.6.2.1),
|
108 |
+
where `int(value / multiple_of) == value / multiple_of`.
|
109 |
+
|
110 |
+
We encourage users to be aware of these two common interpretations and their
|
111 |
+
distinct behaviours, especially since very large or non-integer numbers make
|
112 |
+
it easy to cause silent data corruption due to floating-point imprecision.
|
113 |
+
|
114 |
+
We encourage libraries to carefully document which interpretation they implement.
|
115 |
+
|
116 |
+
### MinLen, MaxLen, Len
|
117 |
+
|
118 |
+
`Len()` implies that `min_length <= len(value) <= max_length` - lower and upper bounds are inclusive.
|
119 |
+
|
120 |
+
As well as `Len()` which can optionally include upper and lower bounds, we also
|
121 |
+
provide `MinLen(x)` and `MaxLen(y)` which are equivalent to `Len(min_length=x)`
|
122 |
+
and `Len(max_length=y)` respectively.
|
123 |
+
|
124 |
+
`Len`, `MinLen`, and `MaxLen` may be used with any type which supports `len(value)`.
|
125 |
+
|
126 |
+
Examples of usage:
|
127 |
+
|
128 |
+
* `Annotated[list, MaxLen(10)]` (or `Annotated[list, Len(max_length=10))`) - list must have a length of 10 or less
|
129 |
+
* `Annotated[str, MaxLen(10)]` - string must have a length of 10 or less
|
130 |
+
* `Annotated[list, MinLen(3))` (or `Annotated[list, Len(min_length=3))`) - list must have a length of 3 or more
|
131 |
+
* `Annotated[list, Len(4, 6)]` - list must have a length of 4, 5, or 6
|
132 |
+
* `Annotated[list, Len(8, 8)]` - list must have a length of exactly 8
|
133 |
+
|
134 |
+
#### Changed in v0.4.0
|
135 |
+
|
136 |
+
* `min_inclusive` has been renamed to `min_length`, no change in meaning
|
137 |
+
* `max_exclusive` has been renamed to `max_length`, upper bound is now **inclusive** instead of **exclusive**
|
138 |
+
* The recommendation that slices are interpreted as `Len` has been removed due to ambiguity and different semantic
|
139 |
+
meaning of the upper bound in slices vs. `Len`
|
140 |
+
|
141 |
+
See [issue #23](https://github.com/annotated-types/annotated-types/issues/23) for discussion.
|
142 |
+
|
143 |
+
### Timezone
|
144 |
+
|
145 |
+
`Timezone` can be used with a `datetime` or a `time` to express which timezones
|
146 |
+
are allowed. `Annotated[datetime, Timezone(None)]` must be a naive datetime.
|
147 |
+
`Timezone[...]` ([literal ellipsis](https://docs.python.org/3/library/constants.html#Ellipsis))
|
148 |
+
expresses that any timezone-aware datetime is allowed. You may also pass a specific
|
149 |
+
timezone string or [`tzinfo`](https://docs.python.org/3/library/datetime.html#tzinfo-objects)
|
150 |
+
object such as `Timezone(timezone.utc)` or `Timezone("Africa/Abidjan")` to express that you only
|
151 |
+
allow a specific timezone, though we note that this is often a symptom of fragile design.
|
152 |
+
|
153 |
+
#### Changed in v0.x.x
|
154 |
+
|
155 |
+
* `Timezone` accepts [`tzinfo`](https://docs.python.org/3/library/datetime.html#tzinfo-objects) objects instead of
|
156 |
+
`timezone`, extending compatibility to [`zoneinfo`](https://docs.python.org/3/library/zoneinfo.html) and third party libraries.
|
157 |
+
|
158 |
+
### Unit
|
159 |
+
|
160 |
+
`Unit(unit: str)` expresses that the annotated numeric value is the magnitude of
|
161 |
+
a quantity with the specified unit. For example, `Annotated[float, Unit("m/s")]`
|
162 |
+
would be a float representing a velocity in meters per second.
|
163 |
+
|
164 |
+
Please note that `annotated_types` itself makes no attempt to parse or validate
|
165 |
+
the unit string in any way. That is left entirely to downstream libraries,
|
166 |
+
such as [`pint`](https://pint.readthedocs.io) or
|
167 |
+
[`astropy.units`](https://docs.astropy.org/en/stable/units/).
|
168 |
+
|
169 |
+
An example of how a library might use this metadata:
|
170 |
+
|
171 |
+
```python
|
172 |
+
from annotated_types import Unit
|
173 |
+
from typing import Annotated, TypeVar, Callable, Any, get_origin, get_args
|
174 |
+
|
175 |
+
# given a type annotated with a unit:
|
176 |
+
Meters = Annotated[float, Unit("m")]
|
177 |
+
|
178 |
+
|
179 |
+
# you can cast the annotation to a specific unit type with any
|
180 |
+
# callable that accepts a string and returns the desired type
|
181 |
+
T = TypeVar("T")
|
182 |
+
def cast_unit(tp: Any, unit_cls: Callable[[str], T]) -> T | None:
|
183 |
+
if get_origin(tp) is Annotated:
|
184 |
+
for arg in get_args(tp):
|
185 |
+
if isinstance(arg, Unit):
|
186 |
+
return unit_cls(arg.unit)
|
187 |
+
return None
|
188 |
+
|
189 |
+
|
190 |
+
# using `pint`
|
191 |
+
import pint
|
192 |
+
pint_unit = cast_unit(Meters, pint.Unit)
|
193 |
+
|
194 |
+
|
195 |
+
# using `astropy.units`
|
196 |
+
import astropy.units as u
|
197 |
+
astropy_unit = cast_unit(Meters, u.Unit)
|
198 |
+
```
|
199 |
+
|
200 |
+
### Predicate
|
201 |
+
|
202 |
+
`Predicate(func: Callable)` expresses that `func(value)` is truthy for valid values.
|
203 |
+
Users should prefer the statically inspectable metadata above, but if you need
|
204 |
+
the full power and flexibility of arbitrary runtime predicates... here it is.
|
205 |
+
|
206 |
+
For some common constraints, we provide generic types:
|
207 |
+
|
208 |
+
* `IsLower = Annotated[T, Predicate(str.islower)]`
|
209 |
+
* `IsUpper = Annotated[T, Predicate(str.isupper)]`
|
210 |
+
* `IsDigit = Annotated[T, Predicate(str.isdigit)]`
|
211 |
+
* `IsFinite = Annotated[T, Predicate(math.isfinite)]`
|
212 |
+
* `IsNotFinite = Annotated[T, Predicate(Not(math.isfinite))]`
|
213 |
+
* `IsNan = Annotated[T, Predicate(math.isnan)]`
|
214 |
+
* `IsNotNan = Annotated[T, Predicate(Not(math.isnan))]`
|
215 |
+
* `IsInfinite = Annotated[T, Predicate(math.isinf)]`
|
216 |
+
* `IsNotInfinite = Annotated[T, Predicate(Not(math.isinf))]`
|
217 |
+
|
218 |
+
so that you can write e.g. `x: IsFinite[float] = 2.0` instead of the longer
|
219 |
+
(but exactly equivalent) `x: Annotated[float, Predicate(math.isfinite)] = 2.0`.
|
220 |
+
|
221 |
+
Some libraries might have special logic to handle known or understandable predicates,
|
222 |
+
for example by checking for `str.isdigit` and using its presence to both call custom
|
223 |
+
logic to enforce digit-only strings, and customise some generated external schema.
|
224 |
+
Users are therefore encouraged to avoid indirection like `lambda s: s.lower()`, in
|
225 |
+
favor of introspectable methods such as `str.lower` or `re.compile("pattern").search`.
|
226 |
+
|
227 |
+
To enable basic negation of commonly used predicates like `math.isnan` without introducing introspection that makes it impossible for implementers to introspect the predicate we provide a `Not` wrapper that simply negates the predicate in an introspectable manner. Several of the predicates listed above are created in this manner.
|
228 |
+
|
229 |
+
We do not specify what behaviour should be expected for predicates that raise
|
230 |
+
an exception. For example `Annotated[int, Predicate(str.isdigit)]` might silently
|
231 |
+
skip invalid constraints, or statically raise an error; or it might try calling it
|
232 |
+
and then propagate or discard the resulting
|
233 |
+
`TypeError: descriptor 'isdigit' for 'str' objects doesn't apply to a 'int' object`
|
234 |
+
exception. We encourage libraries to document the behaviour they choose.
|
235 |
+
|
236 |
+
### Doc
|
237 |
+
|
238 |
+
`doc()` can be used to add documentation information in `Annotated`, for function and method parameters, variables, class attributes, return types, and any place where `Annotated` can be used.
|
239 |
+
|
240 |
+
It expects a value that can be statically analyzed, as the main use case is for static analysis, editors, documentation generators, and similar tools.
|
241 |
+
|
242 |
+
It returns a `DocInfo` class with a single attribute `documentation` containing the value passed to `doc()`.
|
243 |
+
|
244 |
+
This is the early adopter's alternative form of the [`typing-doc` proposal](https://github.com/tiangolo/fastapi/blob/typing-doc/typing_doc.md).
|
245 |
+
|
246 |
+
### Integrating downstream types with `GroupedMetadata`
|
247 |
+
|
248 |
+
Implementers may choose to provide a convenience wrapper that groups multiple pieces of metadata.
|
249 |
+
This can help reduce verbosity and cognitive overhead for users.
|
250 |
+
For example, an implementer like Pydantic might provide a `Field` or `Meta` type that accepts keyword arguments and transforms these into low-level metadata:
|
251 |
+
|
252 |
+
```python
|
253 |
+
from dataclasses import dataclass
|
254 |
+
from typing import Iterator
|
255 |
+
from annotated_types import GroupedMetadata, Ge
|
256 |
+
|
257 |
+
@dataclass
|
258 |
+
class Field(GroupedMetadata):
|
259 |
+
ge: int | None = None
|
260 |
+
description: str | None = None
|
261 |
+
|
262 |
+
def __iter__(self) -> Iterator[object]:
|
263 |
+
# Iterating over a GroupedMetadata object should yield annotated-types
|
264 |
+
# constraint metadata objects which describe it as fully as possible,
|
265 |
+
# and may include other unknown objects too.
|
266 |
+
if self.ge is not None:
|
267 |
+
yield Ge(self.ge)
|
268 |
+
if self.description is not None:
|
269 |
+
yield Description(self.description)
|
270 |
+
```
|
271 |
+
|
272 |
+
Libraries consuming annotated-types constraints should check for `GroupedMetadata` and unpack it by iterating over the object and treating the results as if they had been "unpacked" in the `Annotated` type. The same logic should be applied to the [PEP 646 `Unpack` type](https://peps.python.org/pep-0646/), so that `Annotated[T, Field(...)]`, `Annotated[T, Unpack[Field(...)]]` and `Annotated[T, *Field(...)]` are all treated consistently.
|
273 |
+
|
274 |
+
Libraries consuming annotated-types should also ignore any metadata they do not recongize that came from unpacking a `GroupedMetadata`, just like they ignore unrecognized metadata in `Annotated` itself.
|
275 |
+
|
276 |
+
Our own `annotated_types.Interval` class is a `GroupedMetadata` which unpacks itself into `Gt`, `Lt`, etc., so this is not an abstract concern. Similarly, `annotated_types.Len` is a `GroupedMetadata` which unpacks itself into `MinLen` (optionally) and `MaxLen`.
|
277 |
+
|
278 |
+
### Consuming metadata
|
279 |
+
|
280 |
+
We intend to not be prescriptive as to _how_ the metadata and constraints are used, but as an example of how one might parse constraints from types annotations see our [implementation in `test_main.py`](https://github.com/annotated-types/annotated-types/blob/f59cf6d1b5255a0fe359b93896759a180bec30ae/tests/test_main.py#L94-L103).
|
281 |
+
|
282 |
+
It is up to the implementer to determine how this metadata is used.
|
283 |
+
You could use the metadata for runtime type checking, for generating schemas or to generate example data, amongst other use cases.
|
284 |
+
|
285 |
+
## Design & History
|
286 |
+
|
287 |
+
This package was designed at the PyCon 2022 sprints by the maintainers of Pydantic
|
288 |
+
and Hypothesis, with the goal of making it as easy as possible for end-users to
|
289 |
+
provide more informative annotations for use by runtime libraries.
|
290 |
+
|
291 |
+
It is deliberately minimal, and following PEP-593 allows considerable downstream
|
292 |
+
discretion in what (if anything!) they choose to support. Nonetheless, we expect
|
293 |
+
that staying simple and covering _only_ the most common use-cases will give users
|
294 |
+
and maintainers the best experience we can. If you'd like more constraints for your
|
295 |
+
types - follow our lead, by defining them and documenting them downstream!
|
.venv/lib/python3.12/site-packages/annotated_types-0.7.0.dist-info/RECORD
ADDED
@@ -0,0 +1,8 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
annotated_types/__init__.py,sha256=RynLsRKUEGI0KimXydlD1fZEfEzWwDo0Uon3zOKhG1Q,13819
|
2 |
+
annotated_types/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
3 |
+
annotated_types/test_cases.py,sha256=zHFX6EpcMbGJ8FzBYDbO56bPwx_DYIVSKbZM-4B3_lg,6421
|
4 |
+
annotated_types-0.7.0.dist-info/METADATA,sha256=7ltqxksJJ0wCYFGBNIQCWTlWQGeAH0hRFdnK3CB895E,15046
|
5 |
+
annotated_types-0.7.0.dist-info/WHEEL,sha256=zEMcRr9Kr03x1ozGwg5v9NQBKn3kndp6LSoSlVg-jhU,87
|
6 |
+
annotated_types-0.7.0.dist-info/licenses/LICENSE,sha256=_hBJiEsaDZNCkB6I4H8ykl0ksxIdmXK2poBfuYJLCV0,1083
|
7 |
+
annotated_types-0.7.0.dist-info/INSTALLER,sha256=HLHRd3rVxZqLVn0Nby492_jJUNACT5LifwfFYrwaW0E,12
|
8 |
+
annotated_types-0.7.0.dist-info/RECORD,,
|
.venv/lib/python3.12/site-packages/annotated_types-0.7.0.dist-info/WHEEL
ADDED
@@ -0,0 +1,4 @@
|
|
|
|
|
|
|
|
|
|
|
1 |
+
Wheel-Version: 1.0
|
2 |
+
Generator: hatchling 1.24.2
|
3 |
+
Root-Is-Purelib: true
|
4 |
+
Tag: py3-none-any
|
.venv/lib/python3.12/site-packages/annotated_types-0.7.0.dist-info/licenses/LICENSE
ADDED
@@ -0,0 +1,21 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
The MIT License (MIT)
|
2 |
+
|
3 |
+
Copyright (c) 2022 the contributors
|
4 |
+
|
5 |
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
6 |
+
of this software and associated documentation files (the "Software"), to deal
|
7 |
+
in the Software without restriction, including without limitation the rights
|
8 |
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
9 |
+
copies of the Software, and to permit persons to whom the Software is
|
10 |
+
furnished to do so, subject to the following conditions:
|
11 |
+
|
12 |
+
The above copyright notice and this permission notice shall be included in all
|
13 |
+
copies or substantial portions of the Software.
|
14 |
+
|
15 |
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
16 |
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
17 |
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
18 |
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
19 |
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
20 |
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
21 |
+
SOFTWARE.
|
.venv/lib/python3.12/site-packages/annotated_types/__init__.py
ADDED
@@ -0,0 +1,432 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import math
|
2 |
+
import sys
|
3 |
+
import types
|
4 |
+
from dataclasses import dataclass
|
5 |
+
from datetime import tzinfo
|
6 |
+
from typing import TYPE_CHECKING, Any, Callable, Iterator, Optional, SupportsFloat, SupportsIndex, TypeVar, Union
|
7 |
+
|
8 |
+
if sys.version_info < (3, 8):
|
9 |
+
from typing_extensions import Protocol, runtime_checkable
|
10 |
+
else:
|
11 |
+
from typing import Protocol, runtime_checkable
|
12 |
+
|
13 |
+
if sys.version_info < (3, 9):
|
14 |
+
from typing_extensions import Annotated, Literal
|
15 |
+
else:
|
16 |
+
from typing import Annotated, Literal
|
17 |
+
|
18 |
+
if sys.version_info < (3, 10):
|
19 |
+
EllipsisType = type(Ellipsis)
|
20 |
+
KW_ONLY = {}
|
21 |
+
SLOTS = {}
|
22 |
+
else:
|
23 |
+
from types import EllipsisType
|
24 |
+
|
25 |
+
KW_ONLY = {"kw_only": True}
|
26 |
+
SLOTS = {"slots": True}
|
27 |
+
|
28 |
+
|
29 |
+
__all__ = (
|
30 |
+
'BaseMetadata',
|
31 |
+
'GroupedMetadata',
|
32 |
+
'Gt',
|
33 |
+
'Ge',
|
34 |
+
'Lt',
|
35 |
+
'Le',
|
36 |
+
'Interval',
|
37 |
+
'MultipleOf',
|
38 |
+
'MinLen',
|
39 |
+
'MaxLen',
|
40 |
+
'Len',
|
41 |
+
'Timezone',
|
42 |
+
'Predicate',
|
43 |
+
'LowerCase',
|
44 |
+
'UpperCase',
|
45 |
+
'IsDigits',
|
46 |
+
'IsFinite',
|
47 |
+
'IsNotFinite',
|
48 |
+
'IsNan',
|
49 |
+
'IsNotNan',
|
50 |
+
'IsInfinite',
|
51 |
+
'IsNotInfinite',
|
52 |
+
'doc',
|
53 |
+
'DocInfo',
|
54 |
+
'__version__',
|
55 |
+
)
|
56 |
+
|
57 |
+
__version__ = '0.7.0'
|
58 |
+
|
59 |
+
|
60 |
+
T = TypeVar('T')
|
61 |
+
|
62 |
+
|
63 |
+
# arguments that start with __ are considered
|
64 |
+
# positional only
|
65 |
+
# see https://peps.python.org/pep-0484/#positional-only-arguments
|
66 |
+
|
67 |
+
|
68 |
+
class SupportsGt(Protocol):
|
69 |
+
def __gt__(self: T, __other: T) -> bool:
|
70 |
+
...
|
71 |
+
|
72 |
+
|
73 |
+
class SupportsGe(Protocol):
|
74 |
+
def __ge__(self: T, __other: T) -> bool:
|
75 |
+
...
|
76 |
+
|
77 |
+
|
78 |
+
class SupportsLt(Protocol):
|
79 |
+
def __lt__(self: T, __other: T) -> bool:
|
80 |
+
...
|
81 |
+
|
82 |
+
|
83 |
+
class SupportsLe(Protocol):
|
84 |
+
def __le__(self: T, __other: T) -> bool:
|
85 |
+
...
|
86 |
+
|
87 |
+
|
88 |
+
class SupportsMod(Protocol):
|
89 |
+
def __mod__(self: T, __other: T) -> T:
|
90 |
+
...
|
91 |
+
|
92 |
+
|
93 |
+
class SupportsDiv(Protocol):
|
94 |
+
def __div__(self: T, __other: T) -> T:
|
95 |
+
...
|
96 |
+
|
97 |
+
|
98 |
+
class BaseMetadata:
|
99 |
+
"""Base class for all metadata.
|
100 |
+
|
101 |
+
This exists mainly so that implementers
|
102 |
+
can do `isinstance(..., BaseMetadata)` while traversing field annotations.
|
103 |
+
"""
|
104 |
+
|
105 |
+
__slots__ = ()
|
106 |
+
|
107 |
+
|
108 |
+
@dataclass(frozen=True, **SLOTS)
|
109 |
+
class Gt(BaseMetadata):
|
110 |
+
"""Gt(gt=x) implies that the value must be greater than x.
|
111 |
+
|
112 |
+
It can be used with any type that supports the ``>`` operator,
|
113 |
+
including numbers, dates and times, strings, sets, and so on.
|
114 |
+
"""
|
115 |
+
|
116 |
+
gt: SupportsGt
|
117 |
+
|
118 |
+
|
119 |
+
@dataclass(frozen=True, **SLOTS)
|
120 |
+
class Ge(BaseMetadata):
|
121 |
+
"""Ge(ge=x) implies that the value must be greater than or equal to x.
|
122 |
+
|
123 |
+
It can be used with any type that supports the ``>=`` operator,
|
124 |
+
including numbers, dates and times, strings, sets, and so on.
|
125 |
+
"""
|
126 |
+
|
127 |
+
ge: SupportsGe
|
128 |
+
|
129 |
+
|
130 |
+
@dataclass(frozen=True, **SLOTS)
|
131 |
+
class Lt(BaseMetadata):
|
132 |
+
"""Lt(lt=x) implies that the value must be less than x.
|
133 |
+
|
134 |
+
It can be used with any type that supports the ``<`` operator,
|
135 |
+
including numbers, dates and times, strings, sets, and so on.
|
136 |
+
"""
|
137 |
+
|
138 |
+
lt: SupportsLt
|
139 |
+
|
140 |
+
|
141 |
+
@dataclass(frozen=True, **SLOTS)
|
142 |
+
class Le(BaseMetadata):
|
143 |
+
"""Le(le=x) implies that the value must be less than or equal to x.
|
144 |
+
|
145 |
+
It can be used with any type that supports the ``<=`` operator,
|
146 |
+
including numbers, dates and times, strings, sets, and so on.
|
147 |
+
"""
|
148 |
+
|
149 |
+
le: SupportsLe
|
150 |
+
|
151 |
+
|
152 |
+
@runtime_checkable
|
153 |
+
class GroupedMetadata(Protocol):
|
154 |
+
"""A grouping of multiple objects, like typing.Unpack.
|
155 |
+
|
156 |
+
`GroupedMetadata` on its own is not metadata and has no meaning.
|
157 |
+
All of the constraints and metadata should be fully expressable
|
158 |
+
in terms of the `BaseMetadata`'s returned by `GroupedMetadata.__iter__()`.
|
159 |
+
|
160 |
+
Concrete implementations should override `GroupedMetadata.__iter__()`
|
161 |
+
to add their own metadata.
|
162 |
+
For example:
|
163 |
+
|
164 |
+
>>> @dataclass
|
165 |
+
>>> class Field(GroupedMetadata):
|
166 |
+
>>> gt: float | None = None
|
167 |
+
>>> description: str | None = None
|
168 |
+
...
|
169 |
+
>>> def __iter__(self) -> Iterable[object]:
|
170 |
+
>>> if self.gt is not None:
|
171 |
+
>>> yield Gt(self.gt)
|
172 |
+
>>> if self.description is not None:
|
173 |
+
>>> yield Description(self.gt)
|
174 |
+
|
175 |
+
Also see the implementation of `Interval` below for an example.
|
176 |
+
|
177 |
+
Parsers should recognize this and unpack it so that it can be used
|
178 |
+
both with and without unpacking:
|
179 |
+
|
180 |
+
- `Annotated[int, Field(...)]` (parser must unpack Field)
|
181 |
+
- `Annotated[int, *Field(...)]` (PEP-646)
|
182 |
+
""" # noqa: trailing-whitespace
|
183 |
+
|
184 |
+
@property
|
185 |
+
def __is_annotated_types_grouped_metadata__(self) -> Literal[True]:
|
186 |
+
return True
|
187 |
+
|
188 |
+
def __iter__(self) -> Iterator[object]:
|
189 |
+
...
|
190 |
+
|
191 |
+
if not TYPE_CHECKING:
|
192 |
+
__slots__ = () # allow subclasses to use slots
|
193 |
+
|
194 |
+
def __init_subclass__(cls, *args: Any, **kwargs: Any) -> None:
|
195 |
+
# Basic ABC like functionality without the complexity of an ABC
|
196 |
+
super().__init_subclass__(*args, **kwargs)
|
197 |
+
if cls.__iter__ is GroupedMetadata.__iter__:
|
198 |
+
raise TypeError("Can't subclass GroupedMetadata without implementing __iter__")
|
199 |
+
|
200 |
+
def __iter__(self) -> Iterator[object]: # noqa: F811
|
201 |
+
raise NotImplementedError # more helpful than "None has no attribute..." type errors
|
202 |
+
|
203 |
+
|
204 |
+
@dataclass(frozen=True, **KW_ONLY, **SLOTS)
|
205 |
+
class Interval(GroupedMetadata):
|
206 |
+
"""Interval can express inclusive or exclusive bounds with a single object.
|
207 |
+
|
208 |
+
It accepts keyword arguments ``gt``, ``ge``, ``lt``, and/or ``le``, which
|
209 |
+
are interpreted the same way as the single-bound constraints.
|
210 |
+
"""
|
211 |
+
|
212 |
+
gt: Union[SupportsGt, None] = None
|
213 |
+
ge: Union[SupportsGe, None] = None
|
214 |
+
lt: Union[SupportsLt, None] = None
|
215 |
+
le: Union[SupportsLe, None] = None
|
216 |
+
|
217 |
+
def __iter__(self) -> Iterator[BaseMetadata]:
|
218 |
+
"""Unpack an Interval into zero or more single-bounds."""
|
219 |
+
if self.gt is not None:
|
220 |
+
yield Gt(self.gt)
|
221 |
+
if self.ge is not None:
|
222 |
+
yield Ge(self.ge)
|
223 |
+
if self.lt is not None:
|
224 |
+
yield Lt(self.lt)
|
225 |
+
if self.le is not None:
|
226 |
+
yield Le(self.le)
|
227 |
+
|
228 |
+
|
229 |
+
@dataclass(frozen=True, **SLOTS)
|
230 |
+
class MultipleOf(BaseMetadata):
|
231 |
+
"""MultipleOf(multiple_of=x) might be interpreted in two ways:
|
232 |
+
|
233 |
+
1. Python semantics, implying ``value % multiple_of == 0``, or
|
234 |
+
2. JSONschema semantics, where ``int(value / multiple_of) == value / multiple_of``
|
235 |
+
|
236 |
+
We encourage users to be aware of these two common interpretations,
|
237 |
+
and libraries to carefully document which they implement.
|
238 |
+
"""
|
239 |
+
|
240 |
+
multiple_of: Union[SupportsDiv, SupportsMod]
|
241 |
+
|
242 |
+
|
243 |
+
@dataclass(frozen=True, **SLOTS)
|
244 |
+
class MinLen(BaseMetadata):
|
245 |
+
"""
|
246 |
+
MinLen() implies minimum inclusive length,
|
247 |
+
e.g. ``len(value) >= min_length``.
|
248 |
+
"""
|
249 |
+
|
250 |
+
min_length: Annotated[int, Ge(0)]
|
251 |
+
|
252 |
+
|
253 |
+
@dataclass(frozen=True, **SLOTS)
|
254 |
+
class MaxLen(BaseMetadata):
|
255 |
+
"""
|
256 |
+
MaxLen() implies maximum inclusive length,
|
257 |
+
e.g. ``len(value) <= max_length``.
|
258 |
+
"""
|
259 |
+
|
260 |
+
max_length: Annotated[int, Ge(0)]
|
261 |
+
|
262 |
+
|
263 |
+
@dataclass(frozen=True, **SLOTS)
|
264 |
+
class Len(GroupedMetadata):
|
265 |
+
"""
|
266 |
+
Len() implies that ``min_length <= len(value) <= max_length``.
|
267 |
+
|
268 |
+
Upper bound may be omitted or ``None`` to indicate no upper length bound.
|
269 |
+
"""
|
270 |
+
|
271 |
+
min_length: Annotated[int, Ge(0)] = 0
|
272 |
+
max_length: Optional[Annotated[int, Ge(0)]] = None
|
273 |
+
|
274 |
+
def __iter__(self) -> Iterator[BaseMetadata]:
|
275 |
+
"""Unpack a Len into zone or more single-bounds."""
|
276 |
+
if self.min_length > 0:
|
277 |
+
yield MinLen(self.min_length)
|
278 |
+
if self.max_length is not None:
|
279 |
+
yield MaxLen(self.max_length)
|
280 |
+
|
281 |
+
|
282 |
+
@dataclass(frozen=True, **SLOTS)
|
283 |
+
class Timezone(BaseMetadata):
|
284 |
+
"""Timezone(tz=...) requires a datetime to be aware (or ``tz=None``, naive).
|
285 |
+
|
286 |
+
``Annotated[datetime, Timezone(None)]`` must be a naive datetime.
|
287 |
+
``Timezone[...]`` (the ellipsis literal) expresses that the datetime must be
|
288 |
+
tz-aware but any timezone is allowed.
|
289 |
+
|
290 |
+
You may also pass a specific timezone string or tzinfo object such as
|
291 |
+
``Timezone(timezone.utc)`` or ``Timezone("Africa/Abidjan")`` to express that
|
292 |
+
you only allow a specific timezone, though we note that this is often
|
293 |
+
a symptom of poor design.
|
294 |
+
"""
|
295 |
+
|
296 |
+
tz: Union[str, tzinfo, EllipsisType, None]
|
297 |
+
|
298 |
+
|
299 |
+
@dataclass(frozen=True, **SLOTS)
|
300 |
+
class Unit(BaseMetadata):
|
301 |
+
"""Indicates that the value is a physical quantity with the specified unit.
|
302 |
+
|
303 |
+
It is intended for usage with numeric types, where the value represents the
|
304 |
+
magnitude of the quantity. For example, ``distance: Annotated[float, Unit('m')]``
|
305 |
+
or ``speed: Annotated[float, Unit('m/s')]``.
|
306 |
+
|
307 |
+
Interpretation of the unit string is left to the discretion of the consumer.
|
308 |
+
It is suggested to follow conventions established by python libraries that work
|
309 |
+
with physical quantities, such as
|
310 |
+
|
311 |
+
- ``pint`` : <https://pint.readthedocs.io/en/stable/>
|
312 |
+
- ``astropy.units``: <https://docs.astropy.org/en/stable/units/>
|
313 |
+
|
314 |
+
For indicating a quantity with a certain dimensionality but without a specific unit
|
315 |
+
it is recommended to use square brackets, e.g. `Annotated[float, Unit('[time]')]`.
|
316 |
+
Note, however, ``annotated_types`` itself makes no use of the unit string.
|
317 |
+
"""
|
318 |
+
|
319 |
+
unit: str
|
320 |
+
|
321 |
+
|
322 |
+
@dataclass(frozen=True, **SLOTS)
|
323 |
+
class Predicate(BaseMetadata):
|
324 |
+
"""``Predicate(func: Callable)`` implies `func(value)` is truthy for valid values.
|
325 |
+
|
326 |
+
Users should prefer statically inspectable metadata, but if you need the full
|
327 |
+
power and flexibility of arbitrary runtime predicates... here it is.
|
328 |
+
|
329 |
+
We provide a few predefined predicates for common string constraints:
|
330 |
+
``IsLower = Predicate(str.islower)``, ``IsUpper = Predicate(str.isupper)``, and
|
331 |
+
``IsDigits = Predicate(str.isdigit)``. Users are encouraged to use methods which
|
332 |
+
can be given special handling, and avoid indirection like ``lambda s: s.lower()``.
|
333 |
+
|
334 |
+
Some libraries might have special logic to handle certain predicates, e.g. by
|
335 |
+
checking for `str.isdigit` and using its presence to both call custom logic to
|
336 |
+
enforce digit-only strings, and customise some generated external schema.
|
337 |
+
|
338 |
+
We do not specify what behaviour should be expected for predicates that raise
|
339 |
+
an exception. For example `Annotated[int, Predicate(str.isdigit)]` might silently
|
340 |
+
skip invalid constraints, or statically raise an error; or it might try calling it
|
341 |
+
and then propagate or discard the resulting exception.
|
342 |
+
"""
|
343 |
+
|
344 |
+
func: Callable[[Any], bool]
|
345 |
+
|
346 |
+
def __repr__(self) -> str:
|
347 |
+
if getattr(self.func, "__name__", "<lambda>") == "<lambda>":
|
348 |
+
return f"{self.__class__.__name__}({self.func!r})"
|
349 |
+
if isinstance(self.func, (types.MethodType, types.BuiltinMethodType)) and (
|
350 |
+
namespace := getattr(self.func.__self__, "__name__", None)
|
351 |
+
):
|
352 |
+
return f"{self.__class__.__name__}({namespace}.{self.func.__name__})"
|
353 |
+
if isinstance(self.func, type(str.isascii)): # method descriptor
|
354 |
+
return f"{self.__class__.__name__}({self.func.__qualname__})"
|
355 |
+
return f"{self.__class__.__name__}({self.func.__name__})"
|
356 |
+
|
357 |
+
|
358 |
+
@dataclass
|
359 |
+
class Not:
|
360 |
+
func: Callable[[Any], bool]
|
361 |
+
|
362 |
+
def __call__(self, __v: Any) -> bool:
|
363 |
+
return not self.func(__v)
|
364 |
+
|
365 |
+
|
366 |
+
_StrType = TypeVar("_StrType", bound=str)
|
367 |
+
|
368 |
+
LowerCase = Annotated[_StrType, Predicate(str.islower)]
|
369 |
+
"""
|
370 |
+
Return True if the string is a lowercase string, False otherwise.
|
371 |
+
|
372 |
+
A string is lowercase if all cased characters in the string are lowercase and there is at least one cased character in the string.
|
373 |
+
""" # noqa: E501
|
374 |
+
UpperCase = Annotated[_StrType, Predicate(str.isupper)]
|
375 |
+
"""
|
376 |
+
Return True if the string is an uppercase string, False otherwise.
|
377 |
+
|
378 |
+
A string is uppercase if all cased characters in the string are uppercase and there is at least one cased character in the string.
|
379 |
+
""" # noqa: E501
|
380 |
+
IsDigit = Annotated[_StrType, Predicate(str.isdigit)]
|
381 |
+
IsDigits = IsDigit # type: ignore # plural for backwards compatibility, see #63
|
382 |
+
"""
|
383 |
+
Return True if the string is a digit string, False otherwise.
|
384 |
+
|
385 |
+
A string is a digit string if all characters in the string are digits and there is at least one character in the string.
|
386 |
+
""" # noqa: E501
|
387 |
+
IsAscii = Annotated[_StrType, Predicate(str.isascii)]
|
388 |
+
"""
|
389 |
+
Return True if all characters in the string are ASCII, False otherwise.
|
390 |
+
|
391 |
+
ASCII characters have code points in the range U+0000-U+007F. Empty string is ASCII too.
|
392 |
+
"""
|
393 |
+
|
394 |
+
_NumericType = TypeVar('_NumericType', bound=Union[SupportsFloat, SupportsIndex])
|
395 |
+
IsFinite = Annotated[_NumericType, Predicate(math.isfinite)]
|
396 |
+
"""Return True if x is neither an infinity nor a NaN, and False otherwise."""
|
397 |
+
IsNotFinite = Annotated[_NumericType, Predicate(Not(math.isfinite))]
|
398 |
+
"""Return True if x is one of infinity or NaN, and False otherwise"""
|
399 |
+
IsNan = Annotated[_NumericType, Predicate(math.isnan)]
|
400 |
+
"""Return True if x is a NaN (not a number), and False otherwise."""
|
401 |
+
IsNotNan = Annotated[_NumericType, Predicate(Not(math.isnan))]
|
402 |
+
"""Return True if x is anything but NaN (not a number), and False otherwise."""
|
403 |
+
IsInfinite = Annotated[_NumericType, Predicate(math.isinf)]
|
404 |
+
"""Return True if x is a positive or negative infinity, and False otherwise."""
|
405 |
+
IsNotInfinite = Annotated[_NumericType, Predicate(Not(math.isinf))]
|
406 |
+
"""Return True if x is neither a positive or negative infinity, and False otherwise."""
|
407 |
+
|
408 |
+
try:
|
409 |
+
from typing_extensions import DocInfo, doc # type: ignore [attr-defined]
|
410 |
+
except ImportError:
|
411 |
+
|
412 |
+
@dataclass(frozen=True, **SLOTS)
|
413 |
+
class DocInfo: # type: ignore [no-redef]
|
414 |
+
""" "
|
415 |
+
The return value of doc(), mainly to be used by tools that want to extract the
|
416 |
+
Annotated documentation at runtime.
|
417 |
+
"""
|
418 |
+
|
419 |
+
documentation: str
|
420 |
+
"""The documentation string passed to doc()."""
|
421 |
+
|
422 |
+
def doc(
|
423 |
+
documentation: str,
|
424 |
+
) -> DocInfo:
|
425 |
+
"""
|
426 |
+
Add documentation to a type annotation inside of Annotated.
|
427 |
+
|
428 |
+
For example:
|
429 |
+
|
430 |
+
>>> def hi(name: Annotated[int, doc("The name of the user")]) -> None: ...
|
431 |
+
"""
|
432 |
+
return DocInfo(documentation)
|
.venv/lib/python3.12/site-packages/annotated_types/py.typed
ADDED
File without changes
|
.venv/lib/python3.12/site-packages/annotated_types/test_cases.py
ADDED
@@ -0,0 +1,151 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import math
|
2 |
+
import sys
|
3 |
+
from datetime import date, datetime, timedelta, timezone
|
4 |
+
from decimal import Decimal
|
5 |
+
from typing import Any, Dict, Iterable, Iterator, List, NamedTuple, Set, Tuple
|
6 |
+
|
7 |
+
if sys.version_info < (3, 9):
|
8 |
+
from typing_extensions import Annotated
|
9 |
+
else:
|
10 |
+
from typing import Annotated
|
11 |
+
|
12 |
+
import annotated_types as at
|
13 |
+
|
14 |
+
|
15 |
+
class Case(NamedTuple):
|
16 |
+
"""
|
17 |
+
A test case for `annotated_types`.
|
18 |
+
"""
|
19 |
+
|
20 |
+
annotation: Any
|
21 |
+
valid_cases: Iterable[Any]
|
22 |
+
invalid_cases: Iterable[Any]
|
23 |
+
|
24 |
+
|
25 |
+
def cases() -> Iterable[Case]:
|
26 |
+
# Gt, Ge, Lt, Le
|
27 |
+
yield Case(Annotated[int, at.Gt(4)], (5, 6, 1000), (4, 0, -1))
|
28 |
+
yield Case(Annotated[float, at.Gt(0.5)], (0.6, 0.7, 0.8, 0.9), (0.5, 0.0, -0.1))
|
29 |
+
yield Case(
|
30 |
+
Annotated[datetime, at.Gt(datetime(2000, 1, 1))],
|
31 |
+
[datetime(2000, 1, 2), datetime(2000, 1, 3)],
|
32 |
+
[datetime(2000, 1, 1), datetime(1999, 12, 31)],
|
33 |
+
)
|
34 |
+
yield Case(
|
35 |
+
Annotated[datetime, at.Gt(date(2000, 1, 1))],
|
36 |
+
[date(2000, 1, 2), date(2000, 1, 3)],
|
37 |
+
[date(2000, 1, 1), date(1999, 12, 31)],
|
38 |
+
)
|
39 |
+
yield Case(
|
40 |
+
Annotated[datetime, at.Gt(Decimal('1.123'))],
|
41 |
+
[Decimal('1.1231'), Decimal('123')],
|
42 |
+
[Decimal('1.123'), Decimal('0')],
|
43 |
+
)
|
44 |
+
|
45 |
+
yield Case(Annotated[int, at.Ge(4)], (4, 5, 6, 1000, 4), (0, -1))
|
46 |
+
yield Case(Annotated[float, at.Ge(0.5)], (0.5, 0.6, 0.7, 0.8, 0.9), (0.4, 0.0, -0.1))
|
47 |
+
yield Case(
|
48 |
+
Annotated[datetime, at.Ge(datetime(2000, 1, 1))],
|
49 |
+
[datetime(2000, 1, 2), datetime(2000, 1, 3)],
|
50 |
+
[datetime(1998, 1, 1), datetime(1999, 12, 31)],
|
51 |
+
)
|
52 |
+
|
53 |
+
yield Case(Annotated[int, at.Lt(4)], (0, -1), (4, 5, 6, 1000, 4))
|
54 |
+
yield Case(Annotated[float, at.Lt(0.5)], (0.4, 0.0, -0.1), (0.5, 0.6, 0.7, 0.8, 0.9))
|
55 |
+
yield Case(
|
56 |
+
Annotated[datetime, at.Lt(datetime(2000, 1, 1))],
|
57 |
+
[datetime(1999, 12, 31), datetime(1999, 12, 31)],
|
58 |
+
[datetime(2000, 1, 2), datetime(2000, 1, 3)],
|
59 |
+
)
|
60 |
+
|
61 |
+
yield Case(Annotated[int, at.Le(4)], (4, 0, -1), (5, 6, 1000))
|
62 |
+
yield Case(Annotated[float, at.Le(0.5)], (0.5, 0.0, -0.1), (0.6, 0.7, 0.8, 0.9))
|
63 |
+
yield Case(
|
64 |
+
Annotated[datetime, at.Le(datetime(2000, 1, 1))],
|
65 |
+
[datetime(2000, 1, 1), datetime(1999, 12, 31)],
|
66 |
+
[datetime(2000, 1, 2), datetime(2000, 1, 3)],
|
67 |
+
)
|
68 |
+
|
69 |
+
# Interval
|
70 |
+
yield Case(Annotated[int, at.Interval(gt=4)], (5, 6, 1000), (4, 0, -1))
|
71 |
+
yield Case(Annotated[int, at.Interval(gt=4, lt=10)], (5, 6), (4, 10, 1000, 0, -1))
|
72 |
+
yield Case(Annotated[float, at.Interval(ge=0.5, le=1)], (0.5, 0.9, 1), (0.49, 1.1))
|
73 |
+
yield Case(
|
74 |
+
Annotated[datetime, at.Interval(gt=datetime(2000, 1, 1), le=datetime(2000, 1, 3))],
|
75 |
+
[datetime(2000, 1, 2), datetime(2000, 1, 3)],
|
76 |
+
[datetime(2000, 1, 1), datetime(2000, 1, 4)],
|
77 |
+
)
|
78 |
+
|
79 |
+
yield Case(Annotated[int, at.MultipleOf(multiple_of=3)], (0, 3, 9), (1, 2, 4))
|
80 |
+
yield Case(Annotated[float, at.MultipleOf(multiple_of=0.5)], (0, 0.5, 1, 1.5), (0.4, 1.1))
|
81 |
+
|
82 |
+
# lengths
|
83 |
+
|
84 |
+
yield Case(Annotated[str, at.MinLen(3)], ('123', '1234', 'x' * 10), ('', '1', '12'))
|
85 |
+
yield Case(Annotated[str, at.Len(3)], ('123', '1234', 'x' * 10), ('', '1', '12'))
|
86 |
+
yield Case(Annotated[List[int], at.MinLen(3)], ([1, 2, 3], [1, 2, 3, 4], [1] * 10), ([], [1], [1, 2]))
|
87 |
+
yield Case(Annotated[List[int], at.Len(3)], ([1, 2, 3], [1, 2, 3, 4], [1] * 10), ([], [1], [1, 2]))
|
88 |
+
|
89 |
+
yield Case(Annotated[str, at.MaxLen(4)], ('', '1234'), ('12345', 'x' * 10))
|
90 |
+
yield Case(Annotated[str, at.Len(0, 4)], ('', '1234'), ('12345', 'x' * 10))
|
91 |
+
yield Case(Annotated[List[str], at.MaxLen(4)], ([], ['a', 'bcdef'], ['a', 'b', 'c']), (['a'] * 5, ['b'] * 10))
|
92 |
+
yield Case(Annotated[List[str], at.Len(0, 4)], ([], ['a', 'bcdef'], ['a', 'b', 'c']), (['a'] * 5, ['b'] * 10))
|
93 |
+
|
94 |
+
yield Case(Annotated[str, at.Len(3, 5)], ('123', '12345'), ('', '1', '12', '123456', 'x' * 10))
|
95 |
+
yield Case(Annotated[str, at.Len(3, 3)], ('123',), ('12', '1234'))
|
96 |
+
|
97 |
+
yield Case(Annotated[Dict[int, int], at.Len(2, 3)], [{1: 1, 2: 2}], [{}, {1: 1}, {1: 1, 2: 2, 3: 3, 4: 4}])
|
98 |
+
yield Case(Annotated[Set[int], at.Len(2, 3)], ({1, 2}, {1, 2, 3}), (set(), {1}, {1, 2, 3, 4}))
|
99 |
+
yield Case(Annotated[Tuple[int, ...], at.Len(2, 3)], ((1, 2), (1, 2, 3)), ((), (1,), (1, 2, 3, 4)))
|
100 |
+
|
101 |
+
# Timezone
|
102 |
+
|
103 |
+
yield Case(
|
104 |
+
Annotated[datetime, at.Timezone(None)], [datetime(2000, 1, 1)], [datetime(2000, 1, 1, tzinfo=timezone.utc)]
|
105 |
+
)
|
106 |
+
yield Case(
|
107 |
+
Annotated[datetime, at.Timezone(...)], [datetime(2000, 1, 1, tzinfo=timezone.utc)], [datetime(2000, 1, 1)]
|
108 |
+
)
|
109 |
+
yield Case(
|
110 |
+
Annotated[datetime, at.Timezone(timezone.utc)],
|
111 |
+
[datetime(2000, 1, 1, tzinfo=timezone.utc)],
|
112 |
+
[datetime(2000, 1, 1), datetime(2000, 1, 1, tzinfo=timezone(timedelta(hours=6)))],
|
113 |
+
)
|
114 |
+
yield Case(
|
115 |
+
Annotated[datetime, at.Timezone('Europe/London')],
|
116 |
+
[datetime(2000, 1, 1, tzinfo=timezone(timedelta(0), name='Europe/London'))],
|
117 |
+
[datetime(2000, 1, 1), datetime(2000, 1, 1, tzinfo=timezone(timedelta(hours=6)))],
|
118 |
+
)
|
119 |
+
|
120 |
+
# Quantity
|
121 |
+
|
122 |
+
yield Case(Annotated[float, at.Unit(unit='m')], (5, 4.2), ('5m', '4.2m'))
|
123 |
+
|
124 |
+
# predicate types
|
125 |
+
|
126 |
+
yield Case(at.LowerCase[str], ['abc', 'foobar'], ['', 'A', 'Boom'])
|
127 |
+
yield Case(at.UpperCase[str], ['ABC', 'DEFO'], ['', 'a', 'abc', 'AbC'])
|
128 |
+
yield Case(at.IsDigit[str], ['123'], ['', 'ab', 'a1b2'])
|
129 |
+
yield Case(at.IsAscii[str], ['123', 'foo bar'], ['£100', '😊', 'whatever 👀'])
|
130 |
+
|
131 |
+
yield Case(Annotated[int, at.Predicate(lambda x: x % 2 == 0)], [0, 2, 4], [1, 3, 5])
|
132 |
+
|
133 |
+
yield Case(at.IsFinite[float], [1.23], [math.nan, math.inf, -math.inf])
|
134 |
+
yield Case(at.IsNotFinite[float], [math.nan, math.inf], [1.23])
|
135 |
+
yield Case(at.IsNan[float], [math.nan], [1.23, math.inf])
|
136 |
+
yield Case(at.IsNotNan[float], [1.23, math.inf], [math.nan])
|
137 |
+
yield Case(at.IsInfinite[float], [math.inf], [math.nan, 1.23])
|
138 |
+
yield Case(at.IsNotInfinite[float], [math.nan, 1.23], [math.inf])
|
139 |
+
|
140 |
+
# check stacked predicates
|
141 |
+
yield Case(at.IsInfinite[Annotated[float, at.Predicate(lambda x: x > 0)]], [math.inf], [-math.inf, 1.23, math.nan])
|
142 |
+
|
143 |
+
# doc
|
144 |
+
yield Case(Annotated[int, at.doc("A number")], [1, 2], [])
|
145 |
+
|
146 |
+
# custom GroupedMetadata
|
147 |
+
class MyCustomGroupedMetadata(at.GroupedMetadata):
|
148 |
+
def __iter__(self) -> Iterator[at.Predicate]:
|
149 |
+
yield at.Predicate(lambda x: float(x).is_integer())
|
150 |
+
|
151 |
+
yield Case(Annotated[float, MyCustomGroupedMetadata()], [0, 2.0], [0.01, 1.5])
|
.venv/lib/python3.12/site-packages/anyio-4.4.0.dist-info/INSTALLER
ADDED
@@ -0,0 +1 @@
|
|
|
|
|
1 |
+
Poetry 1.8.3
|
.venv/lib/python3.12/site-packages/anyio-4.4.0.dist-info/LICENSE
ADDED
@@ -0,0 +1,20 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
The MIT License (MIT)
|
2 |
+
|
3 |
+
Copyright (c) 2018 Alex Grönholm
|
4 |
+
|
5 |
+
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
6 |
+
this software and associated documentation files (the "Software"), to deal in
|
7 |
+
the Software without restriction, including without limitation the rights to
|
8 |
+
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
9 |
+
the Software, and to permit persons to whom the Software is furnished to do so,
|
10 |
+
subject to the following conditions:
|
11 |
+
|
12 |
+
The above copyright notice and this permission notice shall be included in all
|
13 |
+
copies or substantial portions of the Software.
|
14 |
+
|
15 |
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
16 |
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
17 |
+
FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
18 |
+
COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
19 |
+
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
20 |
+
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
.venv/lib/python3.12/site-packages/anyio-4.4.0.dist-info/METADATA
ADDED
@@ -0,0 +1,104 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
Metadata-Version: 2.1
|
2 |
+
Name: anyio
|
3 |
+
Version: 4.4.0
|
4 |
+
Summary: High level compatibility layer for multiple asynchronous event loop implementations
|
5 |
+
Author-email: Alex Grönholm <[email protected]>
|
6 |
+
License: MIT
|
7 |
+
Project-URL: Documentation, https://anyio.readthedocs.io/en/latest/
|
8 |
+
Project-URL: Changelog, https://anyio.readthedocs.io/en/stable/versionhistory.html
|
9 |
+
Project-URL: Source code, https://github.com/agronholm/anyio
|
10 |
+
Project-URL: Issue tracker, https://github.com/agronholm/anyio/issues
|
11 |
+
Classifier: Development Status :: 5 - Production/Stable
|
12 |
+
Classifier: Intended Audience :: Developers
|
13 |
+
Classifier: License :: OSI Approved :: MIT License
|
14 |
+
Classifier: Framework :: AnyIO
|
15 |
+
Classifier: Typing :: Typed
|
16 |
+
Classifier: Programming Language :: Python
|
17 |
+
Classifier: Programming Language :: Python :: 3
|
18 |
+
Classifier: Programming Language :: Python :: 3.8
|
19 |
+
Classifier: Programming Language :: Python :: 3.9
|
20 |
+
Classifier: Programming Language :: Python :: 3.10
|
21 |
+
Classifier: Programming Language :: Python :: 3.11
|
22 |
+
Classifier: Programming Language :: Python :: 3.12
|
23 |
+
Requires-Python: >=3.8
|
24 |
+
Description-Content-Type: text/x-rst
|
25 |
+
License-File: LICENSE
|
26 |
+
Requires-Dist: idna >=2.8
|
27 |
+
Requires-Dist: sniffio >=1.1
|
28 |
+
Requires-Dist: exceptiongroup >=1.0.2 ; python_version < "3.11"
|
29 |
+
Requires-Dist: typing-extensions >=4.1 ; python_version < "3.11"
|
30 |
+
Provides-Extra: doc
|
31 |
+
Requires-Dist: packaging ; extra == 'doc'
|
32 |
+
Requires-Dist: Sphinx >=7 ; extra == 'doc'
|
33 |
+
Requires-Dist: sphinx-rtd-theme ; extra == 'doc'
|
34 |
+
Requires-Dist: sphinx-autodoc-typehints >=1.2.0 ; extra == 'doc'
|
35 |
+
Provides-Extra: test
|
36 |
+
Requires-Dist: anyio[trio] ; extra == 'test'
|
37 |
+
Requires-Dist: coverage[toml] >=7 ; extra == 'test'
|
38 |
+
Requires-Dist: exceptiongroup >=1.2.0 ; extra == 'test'
|
39 |
+
Requires-Dist: hypothesis >=4.0 ; extra == 'test'
|
40 |
+
Requires-Dist: psutil >=5.9 ; extra == 'test'
|
41 |
+
Requires-Dist: pytest >=7.0 ; extra == 'test'
|
42 |
+
Requires-Dist: pytest-mock >=3.6.1 ; extra == 'test'
|
43 |
+
Requires-Dist: trustme ; extra == 'test'
|
44 |
+
Requires-Dist: uvloop >=0.17 ; (platform_python_implementation == "CPython" and platform_system != "Windows") and extra == 'test'
|
45 |
+
Provides-Extra: trio
|
46 |
+
Requires-Dist: trio >=0.23 ; extra == 'trio'
|
47 |
+
|
48 |
+
.. image:: https://github.com/agronholm/anyio/actions/workflows/test.yml/badge.svg
|
49 |
+
:target: https://github.com/agronholm/anyio/actions/workflows/test.yml
|
50 |
+
:alt: Build Status
|
51 |
+
.. image:: https://coveralls.io/repos/github/agronholm/anyio/badge.svg?branch=master
|
52 |
+
:target: https://coveralls.io/github/agronholm/anyio?branch=master
|
53 |
+
:alt: Code Coverage
|
54 |
+
.. image:: https://readthedocs.org/projects/anyio/badge/?version=latest
|
55 |
+
:target: https://anyio.readthedocs.io/en/latest/?badge=latest
|
56 |
+
:alt: Documentation
|
57 |
+
.. image:: https://badges.gitter.im/gitterHQ/gitter.svg
|
58 |
+
:target: https://gitter.im/python-trio/AnyIO
|
59 |
+
:alt: Gitter chat
|
60 |
+
|
61 |
+
AnyIO is an asynchronous networking and concurrency library that works on top of either asyncio_ or
|
62 |
+
trio_. It implements trio-like `structured concurrency`_ (SC) on top of asyncio and works in harmony
|
63 |
+
with the native SC of trio itself.
|
64 |
+
|
65 |
+
Applications and libraries written against AnyIO's API will run unmodified on either asyncio_ or
|
66 |
+
trio_. AnyIO can also be adopted into a library or application incrementally – bit by bit, no full
|
67 |
+
refactoring necessary. It will blend in with the native libraries of your chosen backend.
|
68 |
+
|
69 |
+
Documentation
|
70 |
+
-------------
|
71 |
+
|
72 |
+
View full documentation at: https://anyio.readthedocs.io/
|
73 |
+
|
74 |
+
Features
|
75 |
+
--------
|
76 |
+
|
77 |
+
AnyIO offers the following functionality:
|
78 |
+
|
79 |
+
* Task groups (nurseries_ in trio terminology)
|
80 |
+
* High-level networking (TCP, UDP and UNIX sockets)
|
81 |
+
|
82 |
+
* `Happy eyeballs`_ algorithm for TCP connections (more robust than that of asyncio on Python
|
83 |
+
3.8)
|
84 |
+
* async/await style UDP sockets (unlike asyncio where you still have to use Transports and
|
85 |
+
Protocols)
|
86 |
+
|
87 |
+
* A versatile API for byte streams and object streams
|
88 |
+
* Inter-task synchronization and communication (locks, conditions, events, semaphores, object
|
89 |
+
streams)
|
90 |
+
* Worker threads
|
91 |
+
* Subprocesses
|
92 |
+
* Asynchronous file I/O (using worker threads)
|
93 |
+
* Signal handling
|
94 |
+
|
95 |
+
AnyIO also comes with its own pytest_ plugin which also supports asynchronous fixtures.
|
96 |
+
It even works with the popular Hypothesis_ library.
|
97 |
+
|
98 |
+
.. _asyncio: https://docs.python.org/3/library/asyncio.html
|
99 |
+
.. _trio: https://github.com/python-trio/trio
|
100 |
+
.. _structured concurrency: https://en.wikipedia.org/wiki/Structured_concurrency
|
101 |
+
.. _nurseries: https://trio.readthedocs.io/en/stable/reference-core.html#nurseries-and-spawning
|
102 |
+
.. _Happy eyeballs: https://en.wikipedia.org/wiki/Happy_Eyeballs
|
103 |
+
.. _pytest: https://docs.pytest.org/en/latest/
|
104 |
+
.. _Hypothesis: https://hypothesis.works/
|
.venv/lib/python3.12/site-packages/anyio-4.4.0.dist-info/RECORD
ADDED
@@ -0,0 +1,45 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
anyio/__init__.py,sha256=CxUxIHOIONI3KpsDLCg-dI6lQaDkW_4Zhtu5jWt1XO8,4344
|
2 |
+
anyio/from_thread.py,sha256=HtgJ7yZ6RLfRe0l0yyyhpg2mnoax0mqXXgKv8TORUlA,17700
|
3 |
+
anyio/lowlevel.py,sha256=nkgmW--SdxGVp0cmLUYazjkigveRm5HY7-gW8Bpp9oY,4169
|
4 |
+
anyio/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
5 |
+
anyio/pytest_plugin.py,sha256=TBgRAfT-Oxy6efhO1Tziq54NND3Jy4dRmwkMmQXSvhI,5386
|
6 |
+
anyio/to_process.py,sha256=lx_bt0CUJsS1eSlraw662OpCjRgGXowoyf1Q-i-kOxo,9535
|
7 |
+
anyio/to_thread.py,sha256=WM2JQ2MbVsd5D5CM08bQiTwzZIvpsGjfH1Fy247KoDQ,2396
|
8 |
+
anyio/_backends/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
9 |
+
anyio/_backends/_asyncio.py,sha256=CVy87WpTh1URmEjlE-AKTrBoPwsqH_nRxbGkLnTrfeg,83244
|
10 |
+
anyio/_backends/_trio.py,sha256=8gdA930WJFn4xrMNpMH6LrHC9MeyTdZBHsB_W-8HFBw,35909
|
11 |
+
anyio/_core/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
12 |
+
anyio/_core/_eventloop.py,sha256=t_tAwBFPjF8jrZGjlJ6bbYy6KA3bjsbZxV9mvh9t1i0,4695
|
13 |
+
anyio/_core/_exceptions.py,sha256=wUmhDu80qEB7z9EdCqUwVEhNUlNEok4_W2-rC6sCAUQ,2078
|
14 |
+
anyio/_core/_fileio.py,sha256=fC6H6DcueA-2AUaDkP91kmVeqoU7DlWj6O0CCAdnsdM,19456
|
15 |
+
anyio/_core/_resources.py,sha256=NbmU5O5UX3xEyACnkmYX28Fmwdl-f-ny0tHym26e0w0,435
|
16 |
+
anyio/_core/_signals.py,sha256=rDOVxtugZDgC5AhfW3lrwsre2n9Pj_adoRUidBiF6dA,878
|
17 |
+
anyio/_core/_sockets.py,sha256=2jOzi4bXQQYTLr9PSrCaeTgwaU_N7mt0yjHGmX4LvA8,24028
|
18 |
+
anyio/_core/_streams.py,sha256=Z8ZlTY6xom5EszrMsgCT3TphiT4JIlQG-y33CrD0NQY,1811
|
19 |
+
anyio/_core/_subprocesses.py,sha256=ZLLNXAtlRGfbyC4sOIltYB1k3NJa3tqk_x_Fsnbcs1M,5272
|
20 |
+
anyio/_core/_synchronization.py,sha256=h3o6dWWbzVrcNmi7i2mQjEgRtnIxkGtjmYK7KMpdlaE,18444
|
21 |
+
anyio/_core/_tasks.py,sha256=pvVEX2Fw159sf0ypAPerukKsZgRRwvFFedVW52nR2Vk,4764
|
22 |
+
anyio/_core/_testing.py,sha256=YUGwA5cgFFbUTv4WFd7cv_BSVr4ryTtPp8owQA3JdWE,2118
|
23 |
+
anyio/_core/_typedattr.py,sha256=P4ozZikn3-DbpoYcvyghS_FOYAgbmUxeoU8-L_07pZM,2508
|
24 |
+
anyio/abc/__init__.py,sha256=U44_s3BglL8BojWQiq0KuokvCqkunIp-ySH3GyRXxAc,2681
|
25 |
+
anyio/abc/_eventloop.py,sha256=r9pldSu6p-ZsvO6D_brc0EIi1JgZRDbfgVLuy7Q7R6o,10085
|
26 |
+
anyio/abc/_resources.py,sha256=DrYvkNN1hH6Uvv5_5uKySvDsnknGVDe8FCKfko0VtN8,783
|
27 |
+
anyio/abc/_sockets.py,sha256=XdZ42TQ1omZN9Ec3HUfTMWG_i-21yMjXQ_FFslAZtzQ,6269
|
28 |
+
anyio/abc/_streams.py,sha256=GzST5Q2zQmxVzdrAqtbSyHNxkPlIC9AzeZJg_YyPAXw,6598
|
29 |
+
anyio/abc/_subprocesses.py,sha256=cumAPJTktOQtw63IqG0lDpyZqu_l1EElvQHMiwJgL08,2067
|
30 |
+
anyio/abc/_tasks.py,sha256=0Jc6oIwUjMIVReehF6knOZyAqlgwDt4TP1NQkx4IQGw,2731
|
31 |
+
anyio/abc/_testing.py,sha256=tBJUzkSfOXJw23fe8qSJ03kJlShOYjjaEyFB6k6MYT8,1821
|
32 |
+
anyio/streams/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
33 |
+
anyio/streams/buffered.py,sha256=UCldKC168YuLvT7n3HtNPnQ2iWAMSTYQWbZvzLwMwkM,4500
|
34 |
+
anyio/streams/file.py,sha256=6uoTNb5KbMoj-6gS3_xrrL8uZN8Q4iIvOS1WtGyFfKw,4383
|
35 |
+
anyio/streams/memory.py,sha256=Y286x16omNSSGONQx5CBLLNiB3vAJb_vVKt5vb3go-Q,10190
|
36 |
+
anyio/streams/stapled.py,sha256=U09pCrmOw9kkNhe6tKopsm1QIMT1lFTFvtb-A7SIe4k,4302
|
37 |
+
anyio/streams/text.py,sha256=6x8w8xlfCZKTUWQoJiMPoMhSSJFUBRKgoBNSBtbd9yg,5094
|
38 |
+
anyio/streams/tls.py,sha256=ev-6yNOGcIkziIkcIfKj8VmLqQJW-iDBJttaKgKDsF4,12752
|
39 |
+
anyio-4.4.0.dist-info/LICENSE,sha256=U2GsncWPLvX9LpsJxoKXwX8ElQkJu8gCO9uC6s8iwrA,1081
|
40 |
+
anyio-4.4.0.dist-info/METADATA,sha256=sbJaOJ_Ilka4D0U6yKtfOtVrYef7XRFzGjoBEZnRpes,4599
|
41 |
+
anyio-4.4.0.dist-info/WHEEL,sha256=GJ7t_kWBFywbagK5eo9IoUwLW6oyOeTKmQ-9iHFVNxQ,92
|
42 |
+
anyio-4.4.0.dist-info/entry_points.txt,sha256=_d6Yu6uiaZmNe0CydowirE9Cmg7zUL2g08tQpoS3Qvc,39
|
43 |
+
anyio-4.4.0.dist-info/top_level.txt,sha256=QglSMiWX8_5dpoVAEIHdEYzvqFMdSYWmCj6tYw2ITkQ,6
|
44 |
+
anyio-4.4.0.dist-info/INSTALLER,sha256=HLHRd3rVxZqLVn0Nby492_jJUNACT5LifwfFYrwaW0E,12
|
45 |
+
anyio-4.4.0.dist-info/RECORD,,
|