Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
N
news
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Sartika Aritonang
news
Commits
ff3dc088
Commit
ff3dc088
authored
May 29, 2020
by
Sartika Aritonang
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Upload New File
parent
ecb40231
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
181 additions
and
0 deletions
+181
-0
cache.py
stbi/Lib/site-packages/pip/_internal/commands/cache.py
+181
-0
No files found.
stbi/Lib/site-packages/pip/_internal/commands/cache.py
0 → 100644
View file @
ff3dc088
from
__future__
import
absolute_import
import
logging
import
os
import
textwrap
import
pip._internal.utils.filesystem
as
filesystem
from
pip._internal.cli.base_command
import
Command
from
pip._internal.cli.status_codes
import
ERROR
,
SUCCESS
from
pip._internal.exceptions
import
CommandError
,
PipError
from
pip._internal.utils.typing
import
MYPY_CHECK_RUNNING
if
MYPY_CHECK_RUNNING
:
from
optparse
import
Values
from
typing
import
Any
,
List
logger
=
logging
.
getLogger
(
__name__
)
class
CacheCommand
(
Command
):
"""
Inspect and manage pip's wheel cache.
Subcommands:
dir: Show the cache directory.
info: Show information about the cache.
list: List filenames of packages stored in the cache.
remove: Remove one or more package from the cache.
purge: Remove all items from the cache.
<pattern> can be a glob expression or a package name.
"""
ignore_require_venv
=
True
usage
=
"""
%
prog dir
%
prog info
%
prog list [<pattern>]
%
prog remove <pattern>
%
prog purge
"""
def
run
(
self
,
options
,
args
):
# type: (Values, List[Any]) -> int
handlers
=
{
"dir"
:
self
.
get_cache_dir
,
"info"
:
self
.
get_cache_info
,
"list"
:
self
.
list_cache_items
,
"remove"
:
self
.
remove_cache_items
,
"purge"
:
self
.
purge_cache
,
}
if
not
options
.
cache_dir
:
logger
.
error
(
"pip cache commands can not "
"function since cache is disabled."
)
return
ERROR
# Determine action
if
not
args
or
args
[
0
]
not
in
handlers
:
logger
.
error
(
"Need an action ({}) to perform."
.
format
(
", "
.
join
(
sorted
(
handlers
)))
)
return
ERROR
action
=
args
[
0
]
# Error handling happens here, not in the action-handlers.
try
:
handlers
[
action
](
options
,
args
[
1
:])
except
PipError
as
e
:
logger
.
error
(
e
.
args
[
0
])
return
ERROR
return
SUCCESS
def
get_cache_dir
(
self
,
options
,
args
):
# type: (Values, List[Any]) -> None
if
args
:
raise
CommandError
(
'Too many arguments'
)
logger
.
info
(
options
.
cache_dir
)
def
get_cache_info
(
self
,
options
,
args
):
# type: (Values, List[Any]) -> None
if
args
:
raise
CommandError
(
'Too many arguments'
)
num_packages
=
len
(
self
.
_find_wheels
(
options
,
'*'
))
cache_location
=
self
.
_wheels_cache_dir
(
options
)
cache_size
=
filesystem
.
format_directory_size
(
cache_location
)
message
=
textwrap
.
dedent
(
"""
Location: {location}
Size: {size}
Number of wheels: {package_count}
"""
)
.
format
(
location
=
cache_location
,
package_count
=
num_packages
,
size
=
cache_size
,
)
.
strip
()
logger
.
info
(
message
)
def
list_cache_items
(
self
,
options
,
args
):
# type: (Values, List[Any]) -> None
if
len
(
args
)
>
1
:
raise
CommandError
(
'Too many arguments'
)
if
args
:
pattern
=
args
[
0
]
else
:
pattern
=
'*'
files
=
self
.
_find_wheels
(
options
,
pattern
)
if
not
files
:
logger
.
info
(
'Nothing cached.'
)
return
results
=
[]
for
filename
in
files
:
wheel
=
os
.
path
.
basename
(
filename
)
size
=
filesystem
.
format_file_size
(
filename
)
results
.
append
(
' - {} ({})'
.
format
(
wheel
,
size
))
logger
.
info
(
'Cache contents:
\n
'
)
logger
.
info
(
'
\n
'
.
join
(
sorted
(
results
)))
def
remove_cache_items
(
self
,
options
,
args
):
# type: (Values, List[Any]) -> None
if
len
(
args
)
>
1
:
raise
CommandError
(
'Too many arguments'
)
if
not
args
:
raise
CommandError
(
'Please provide a pattern'
)
files
=
self
.
_find_wheels
(
options
,
args
[
0
])
if
not
files
:
raise
CommandError
(
'No matching packages'
)
for
filename
in
files
:
os
.
unlink
(
filename
)
logger
.
debug
(
'Removed
%
s'
,
filename
)
logger
.
info
(
'Files removed:
%
s'
,
len
(
files
))
def
purge_cache
(
self
,
options
,
args
):
# type: (Values, List[Any]) -> None
if
args
:
raise
CommandError
(
'Too many arguments'
)
return
self
.
remove_cache_items
(
options
,
[
'*'
])
def
_wheels_cache_dir
(
self
,
options
):
# type: (Values) -> str
return
os
.
path
.
join
(
options
.
cache_dir
,
'wheels'
)
def
_find_wheels
(
self
,
options
,
pattern
):
# type: (Values, str) -> List[str]
wheel_dir
=
self
.
_wheels_cache_dir
(
options
)
# The wheel filename format, as specified in PEP 427, is:
# {distribution}-{version}(-{build})?-{python}-{abi}-{platform}.whl
#
# Additionally, non-alphanumeric values in the distribution are
# normalized to underscores (_), meaning hyphens can never occur
# before `-{version}`.
#
# Given that information:
# - If the pattern we're given contains a hyphen (-), the user is
# providing at least the version. Thus, we can just append `*.whl`
# to match the rest of it.
# - If the pattern we're given doesn't contain a hyphen (-), the
# user is only providing the name. Thus, we append `-*.whl` to
# match the hyphen before the version, followed by anything else.
#
# PEP 427: https://www.python.org/dev/peps/pep-0427/
pattern
=
pattern
+
(
"*.whl"
if
"-"
in
pattern
else
"-*.whl"
)
return
filesystem
.
find_files
(
wheel_dir
,
pattern
)
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment