- Solves issue whereby global cheatsheets fail to save after editing

- `cheat` no longer asks a user if a global cheatsheet should be copied
  locally before editing, and instead just silently does so.
This commit is contained in:
Chris Lane 2015-02-10 19:35:14 -05:00
parent 3d8343a878
commit 718ec4f685
5 changed files with 7 additions and 29 deletions

1
.gitignore vendored
View File

@ -1,4 +1,5 @@
*.pyc
MANIFEST
build
cheat.egg-info
dist

View File

@ -38,7 +38,7 @@ from docopt import docopt
if __name__ == '__main__':
# parse the command-line options
options = docopt(__doc__, version='cheat 2.1.4')
options = docopt(__doc__, version='cheat 2.1.5')
# list directories
if options['--directories']:

View File

@ -32,22 +32,10 @@ def create_or_edit(sheet):
# if the cheatsheet exists but is not writable...
elif exists(sheet) and not is_writable(sheet):
# ... ask the user if we should copy the cheatsheet to her home directory for editing
yes = prompt_yes_or_no(
'The ' + sheet + ' sheet is not editable. Do you want to copy it to '
'your user cheatsheets directory before editing? Keep in mind that '
'your sheet will always be used before system-wide one.'
)
# if yes, copy the cheatsheet to the home directory before editing
if yes:
# copy the cheatsheet to the home directory before editing
copy(path(sheet), os.path.join(sheets.default_path(), sheet))
edit(sheet)
# if no, just abort
else:
die('Aborting.')
def create(sheet):
""" Creates a cheatsheet """

View File

@ -2,13 +2,6 @@ from cheat import cheatsheets
from cheat.utils import *
import os
# @kludge: it breaks the functional paradigm to a degree, but declaring this
# var here (versus within get()) gives us a "poor man's" memoization on the
# call to get(). This, in turn, spares us from having to call out to the
# filesystem more than once.
cheats = {}
def default_path():
""" Returns the default cheatsheet path """
@ -37,11 +30,7 @@ def default_path():
def get():
""" Assembles a dictionary of cheatsheets as name => file-path """
# if we've already reached out to the filesystem, just return the result
# from memory
if cheats:
return cheats
cheats = {}
# otherwise, scan the filesystem
for cheat_dir in reversed(paths()):

View File

@ -3,7 +3,7 @@ import os
setup(
name = 'cheat',
version = '2.1.4',
version = '2.1.5',
author = 'Chris Lane',
author_email = 'chris@chris-allen-lane.com',
license = 'GPL3',