Skip to content

Commit

Permalink
Merge pull request #2502 from pypa/clear
Browse files Browse the repository at this point in the history
--clear
  • Loading branch information
kennethreitz authored Jul 3, 2018
2 parents 779d247 + d6dd412 commit 7daedb0
Show file tree
Hide file tree
Showing 3 changed files with 79 additions and 27 deletions.
13 changes: 11 additions & 2 deletions pipenv/cli.py
Original file line number Diff line number Diff line change
Expand Up @@ -136,6 +136,7 @@ def validate_pypi_mirror(ctx, param, value):
is_flag=True,
help="Output diagnostic information for use in Github issues.",
)
@option("--clear", is_flag=True, help="Clears caches (pipenv, pip, and pip-tools).")
@version_option(prog_name=crayons.normal("pipenv", bold=True), version=__version__)
@pass_context
def cli(
Expand All @@ -154,6 +155,7 @@ def cli(
completion=False,
pypi_mirror=None,
support=None,
clear=False,
):
if completion: # Handle this ASAP to make shell startup fast.
from . import shells
Expand All @@ -180,6 +182,7 @@ def cli(
cleanup_virtualenv,
ensure_project,
format_help,
do_clear,
)

if man:
Expand All @@ -203,19 +206,24 @@ def cli(
sys.exit(0)
warn_in_virtualenv()
if ctx.invoked_subcommand is None:
# --where was passed...
# --where was passed
if where:
do_where(bare=True)
sys.exit(0)
elif py:
do_py()
sys.exit()
# --support was passed...
# --support was passed
elif support:
from .help import get_pipenv_diagnostics

get_pipenv_diagnostics()
sys.exit(0)
# --clear was passed…
elif clear:
do_clear()
sys.exit(0)

# --venv was passed...
elif venv:
# There is no virtualenv yet.
Expand Down Expand Up @@ -270,6 +278,7 @@ def cli(
warn=True,
site_packages=site_packages,
pypi_mirror=pypi_mirror,
clear=clear,
)
# Check this again before exiting for empty ``pipenv`` command.
elif ctx.invoked_subcommand is None:
Expand Down
18 changes: 18 additions & 0 deletions pipenv/core.py
Original file line number Diff line number Diff line change
Expand Up @@ -122,6 +122,18 @@ def which(command, location=None, allow_global=False):
project = Project(which=which)


def do_clear():
click.echo(crayons.white("Clearing caches…", bold=True))
import pip._internal.locations
import piptools

try:
shutil.rmtree(PIPENV_CACHE_DIR)
shutil.rmtree(pip._internal.locations.USER_CACHE_DIR)
except FileNotFoundError:
pass


def load_dot_env():
"""Loads .env file into sys.environ."""
if not PIPENV_DONT_LOAD_ENV:
Expand Down Expand Up @@ -582,10 +594,16 @@ def ensure_project(
deploy=False,
skip_requirements=False,
pypi_mirror=None,
clear=False,
):
"""Ensures both Pipfile and virtualenv exist for the project."""
from .environments import PIPENV_USE_SYSTEM

# Clear the caches, if appropriate.
if clear:
print("clearing")
sys.exit(1)

# Automatically use an activated virtualenv.
if PIPENV_USE_SYSTEM:
system = True
Expand Down
75 changes: 50 additions & 25 deletions pipenv/patched/crayons.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,21 +12,35 @@
import re
import sys

import shellingham
import colorama

PY3 = sys.version_info[0] >= 3

__all__ = (
'red', 'green', 'yellow', 'blue',
'black', 'magenta', 'cyan', 'white', 'normal',
'clean', 'disable',
"red",
"green",
"yellow",
"blue",
"black",
"magenta",
"cyan",
"white",
"normal",
"clean",
"disable",
)

COLORS = __all__[:-2]

if 'get_ipython' in dir():
"""
when ipython is fired lot of variables like _oh, etc are used.
is_ipython = "get_ipython" in dir()
try:
is_powershell = "powershell" in shellingham.detect_shell()[0]
except shellingham.ShellDetectionFailure:
is_powershell = False

if is_ipython or is_powershell:
"""when ipython is fired lot of variables like _oh, etc are used.
There are so many ways to find current python interpreter is ipython.
get_ipython is easiest is most appealing for readers to understand.
"""
Expand All @@ -37,16 +51,17 @@

class ColoredString(object):
"""Enhanced string for __len__ operations on Colored output."""

def __init__(self, color, s, always_color=False, bold=False):
super(ColoredString, self).__init__()
if not PY3 and isinstance(s, unicode):
self.s = s.encode('utf-8')
self.s = s.encode("utf-8")
else:
self.s = s
self.color = color
self.always_color = always_color
self.bold = bold
if os.environ.get('PIPENV_FORCE_COLOR'):
if os.environ.get("PIPENV_FORCE_COLOR"):
self.always_color = True

def __getattr__(self, att):
Expand All @@ -62,12 +77,19 @@ def func_help(*args, **kwargs):
return [self._new(x) for x in result]
else:
return result

return func_help

@property
def color_str(self):
style = 'BRIGHT' if self.bold else 'NORMAL'
c = '%s%s%s%s%s' % (getattr(colorama.Fore, self.color), getattr(colorama.Style, style), self.s, colorama.Fore.RESET, getattr(colorama.Style, 'NORMAL'))
style = "BRIGHT" if self.bold else "NORMAL"
c = "%s%s%s%s%s" % (
getattr(colorama.Fore, self.color),
getattr(colorama.Style, style),
self.s,
colorama.Fore.RESET,
getattr(colorama.Style, "NORMAL"),
)

if self.always_color:
return c
Expand All @@ -85,12 +107,13 @@ def __repr__(self):
def __unicode__(self):
value = self.color_str
if isinstance(value, bytes):
return value.decode('utf8')
return value.decode("utf8")
return value

if PY3:
__str__ = __unicode__
else:

def __str__(self):
return self.color_str

Expand All @@ -104,57 +127,59 @@ def __radd__(self, other):
return str(other) + str(self.color_str)

def __mul__(self, other):
return (self.color_str * other)
return self.color_str * other

def _new(self, s):
return ColoredString(self.color, s)


def clean(s):
strip = re.compile("([^-_a-zA-Z0-9!@#%&=,/'\";:~`\$\^\*\(\)\+\[\]\.\{\}\|\?\<\>\\]+|[^\s]+)")
txt = strip.sub('', str(s))
strip = re.compile(
"([^-_a-zA-Z0-9!@#%&=,/'\";:~`\$\^\*\(\)\+\[\]\.\{\}\|\?\<\>\\]+|[^\s]+)"
)
txt = strip.sub("", str(s))

strip = re.compile(r'\[\d+m')
txt = strip.sub('', txt)
strip = re.compile(r"\[\d+m")
txt = strip.sub("", txt)

return txt


def normal(string, always=False, bold=False):
return ColoredString('RESET', string, always_color=always, bold=bold)
return ColoredString("RESET", string, always_color=always, bold=bold)


def black(string, always=False, bold=False):
return ColoredString('BLACK', string, always_color=always, bold=bold)
return ColoredString("BLACK", string, always_color=always, bold=bold)


def red(string, always=False, bold=False):
return ColoredString('RED', string, always_color=always, bold=bold)
return ColoredString("RED", string, always_color=always, bold=bold)


def green(string, always=False, bold=False):
return ColoredString('GREEN', string, always_color=always, bold=bold)
return ColoredString("GREEN", string, always_color=always, bold=bold)


def yellow(string, always=False, bold=False):
return ColoredString('YELLOW', string, always_color=always, bold=bold)
return ColoredString("YELLOW", string, always_color=always, bold=bold)


def blue(string, always=False, bold=False):
return ColoredString('BLUE', string, always_color=always, bold=bold)
return ColoredString("BLUE", string, always_color=always, bold=bold)


def magenta(string, always=False, bold=False):
return ColoredString('MAGENTA', string, always_color=always, bold=bold)
return ColoredString("MAGENTA", string, always_color=always, bold=bold)


def cyan(string, always=False, bold=False):
return ColoredString('CYAN', string, always_color=always, bold=bold)
return ColoredString("CYAN", string, always_color=always, bold=bold)


def white(string, always=False, bold=False):
# This upsets people...
return ColoredString('WHITE', string, always_color=always, bold=bold)
return ColoredString("WHITE", string, always_color=always, bold=bold)


def disable():
Expand Down

0 comments on commit 7daedb0

Please sign in to comment.