general clean-up, refactoring, commenting
--HG-- branch : pmacs2
This commit is contained in:
parent
94ee3cd017
commit
cdbc5c0c79
|
@ -1,16 +1,33 @@
|
|||
#!/usr/bin/env python
|
||||
import curses, curses.ascii, getpass, os, re, string, sys, termios, time
|
||||
import curses
|
||||
from getpass import getpass
|
||||
import locale
|
||||
import math
|
||||
import traceback
|
||||
import os
|
||||
import string
|
||||
from subprocess import Popen, PIPE, STDOUT
|
||||
import sys
|
||||
import termios
|
||||
import time
|
||||
import traceback
|
||||
|
||||
import buffer, buffer.about, buffer.colors, buffer.console, buffer.data
|
||||
import buffer.fs, buffer.aes
|
||||
import bufferlist, color, completer, ispell, keyinput, method
|
||||
import buffer
|
||||
import buffer.about
|
||||
import buffer.colors
|
||||
import buffer.console
|
||||
import buffer.data
|
||||
import buffer.fs
|
||||
import buffer.aes
|
||||
|
||||
from bufferlist import BufferList
|
||||
import color
|
||||
import completer
|
||||
import keyinput
|
||||
import method
|
||||
from minibuffer import MiniBuffer, MiniBufferError
|
||||
import mode, util, window
|
||||
import mode
|
||||
from point import Point
|
||||
import util
|
||||
from window import Window
|
||||
|
||||
class Application(object):
|
||||
def __init__(self, stdscr, buffers=[], **kwargs):
|
||||
|
@ -142,7 +159,7 @@ class Application(object):
|
|||
# buffer list stuff
|
||||
height = self.y - 1
|
||||
width = self.x
|
||||
self.bufferlist = bufferlist.BufferList(height, width)
|
||||
self.bufferlist = BufferList(height, width)
|
||||
self.active_slot = 0
|
||||
self.complete_slot = None
|
||||
|
||||
|
@ -160,9 +177,9 @@ class Application(object):
|
|||
# build windows for our buffers
|
||||
for b in buffers:
|
||||
if b.modename:
|
||||
window.Window(b, self)
|
||||
Window(b, self)
|
||||
else:
|
||||
window.Window(b, self, mode_name=kwargs.get('init_mode'))
|
||||
Window(b, self, mode_name=kwargs.get('init_mode'))
|
||||
self.bufferlist.add_buffer(b)
|
||||
self.bufferlist.set_slot(self.active_slot, buffers[0])
|
||||
|
||||
|
@ -359,7 +376,7 @@ class Application(object):
|
|||
return name
|
||||
|
||||
def open_path(self, path, binary=False, cipher=None, password=None):
|
||||
path = os.path.abspath(os.path.realpath(util.expand_tilde(path)))
|
||||
path = util.literal_path(path)
|
||||
b = self.get_buffer_by_path(path)
|
||||
if b is None:
|
||||
name = self.make_name(os.path.basename(path))
|
||||
|
@ -394,7 +411,7 @@ class Application(object):
|
|||
b.open()
|
||||
if mode_name is None:
|
||||
mode_name = 'hex'
|
||||
window.Window(b, self, height=0, width=0, mode_name=mode_name)
|
||||
Window(b, self, height=0, width=0, mode_name=mode_name)
|
||||
self.add_buffer(b)
|
||||
return b
|
||||
|
||||
|
@ -413,7 +430,7 @@ class Application(object):
|
|||
parentw)
|
||||
try:
|
||||
w = self.x - 1 - len(self.mini_prompt) - 1
|
||||
window.Window(self.mini_buffer, self, height=1, width=w)
|
||||
Window(self.mini_buffer, self, height=1, width=w)
|
||||
if startvalue:
|
||||
self.mini_buffer.set_data(startvalue)
|
||||
self.arg_history.setdefault(queue, [])
|
||||
|
@ -472,7 +489,7 @@ class Application(object):
|
|||
b = buffer.Binary32Buffer(path)
|
||||
b.open()
|
||||
b.modename = 'hex'
|
||||
window.Window(b, self, height=0, width=0)
|
||||
Window(b, self, height=0, width=0)
|
||||
self.add_buffer(b)
|
||||
if switch_to:
|
||||
self.switch_buffer(b)
|
||||
|
@ -484,7 +501,7 @@ class Application(object):
|
|||
b = buffer.data.DataBuffer(name, data)
|
||||
if modename is not None:
|
||||
b.modename = modename
|
||||
window.Window(b, self, height=0, width=0)
|
||||
Window(b, self, height=0, width=0)
|
||||
self.add_buffer(b)
|
||||
if switch_to:
|
||||
self.switch_buffer(b)
|
||||
|
@ -498,7 +515,7 @@ class Application(object):
|
|||
b = buffer.colors.ColorDataBuffer(name, data)
|
||||
if modename is not None:
|
||||
b.modename = modename
|
||||
window.Window(b, self, height=0, width=0)
|
||||
Window(b, self, height=0, width=0)
|
||||
self.add_buffer(b)
|
||||
if switch_to:
|
||||
self.switch_buffer(b)
|
||||
|
@ -529,7 +546,7 @@ class Application(object):
|
|||
def add_window_to_buffer(self, b, slotname):
|
||||
if not b.has_window(slotname):
|
||||
slot = self.bufferlist.slots[slotname]
|
||||
window.Window(b, self, height=slot.height, width=slot.width)
|
||||
Window(b, self, height=slot.height, width=slot.width)
|
||||
|
||||
# error string handling
|
||||
def set_msg(self, s):
|
||||
|
@ -1038,7 +1055,7 @@ class Application(object):
|
|||
|
||||
def open_aes_file(path, name=None, binary=False):
|
||||
if os.path.isfile(path) or not os.path.exists(path):
|
||||
p = getpass.getpass("Please enter the AES password: ")
|
||||
p = getpass("Please enter the AES password: ")
|
||||
return buffer.aes.AesBuffer(path, p, name)
|
||||
else:
|
||||
raise Exception, "can't open %r; unsupported file type" % path
|
||||
|
@ -1194,5 +1211,4 @@ if __name__ == "__main__":
|
|||
|
||||
# restore terminal state before exiting
|
||||
termios.tcsetattr(sys.stdin, termios.TCSANOW, attr)
|
||||
ispell.free()
|
||||
sys.exit(err)
|
||||
|
|
|
@ -16,6 +16,7 @@ def get_speller():
|
|||
def free():
|
||||
if _speller:
|
||||
_speller.stop()
|
||||
_speller = None
|
||||
|
||||
class Speller(object):
|
||||
def __init__(self, cmd='ispell'):
|
||||
|
|
48
util.py
48
util.py
|
@ -5,9 +5,11 @@ import regex
|
|||
|
||||
cbuf_re = re.compile(r'[\[\]\\]')
|
||||
def cbuf_escape(s):
|
||||
'''escape characters which have special meaning in color buffers'''
|
||||
return cbuf_re.sub(lambda m: '\\' + m.group(0), s)
|
||||
|
||||
def flatzip(a, b):
|
||||
'''interleave two lists, e.g. ((a,b),(1,2)) -> (a,1,b,2)'''
|
||||
l = []
|
||||
for x, y in zip(a, b):
|
||||
l.append(x)
|
||||
|
@ -15,65 +17,57 @@ def flatzip(a, b):
|
|||
return l
|
||||
|
||||
def should_ignore_path(path, suffixes):
|
||||
'''whether file (or any parent) should be ignored based on suffixes '''
|
||||
for name in path.split('/'):
|
||||
for suffix in suffixes:
|
||||
if name.endswith(suffix):
|
||||
return True
|
||||
return False
|
||||
|
||||
def literal_path(path):
|
||||
'''return the system path for the given user path'''
|
||||
path = os.path.realpath(expand_tilde(path))
|
||||
return os.path.abspath(path)
|
||||
|
||||
def normal_path(path):
|
||||
#path = os.path.realpath(path)
|
||||
path = os.path.normpath(path)
|
||||
home = os.getenv('HOME')
|
||||
'''return the user path for the given system path '''
|
||||
path = os.path.normpath(path)
|
||||
home = os.getenv('HOME')
|
||||
isdir = os.path.isdir(path)
|
||||
if path.startswith(home):
|
||||
path = path.replace(home, '~', 1)
|
||||
if isdir and not path.endswith('/'):
|
||||
return path + '/'
|
||||
else:
|
||||
return path
|
||||
path += '/'
|
||||
return path
|
||||
|
||||
def expand_tilde(path):
|
||||
isd = path.endswith('/')
|
||||
'''correctly expand the tilde in the provided path'''
|
||||
isdir = path.endswith('/')
|
||||
if not path.startswith('~'):
|
||||
return path
|
||||
parts = path.split('/', 1)
|
||||
if parts[0] == '~':
|
||||
parts[0] = os.getenv('HOME')
|
||||
elif parts[0].startswith('~'):
|
||||
users = [x[0] for x in pwd.getpwall()]
|
||||
if parts[0][1:] in users:
|
||||
home = pwd.getpwnam(parts[0][1:])[5]
|
||||
parts[0] = home
|
||||
try:
|
||||
parts[0] = pwd.getpwnam(parts[0][1:])[5]
|
||||
except KeyError:
|
||||
pass
|
||||
if len(parts) > 1:
|
||||
s = os.path.join(parts[0], parts[1])
|
||||
else:
|
||||
s = parts[0]
|
||||
s = os.path.realpath(s)
|
||||
if os.path.isdir(s) and isd:
|
||||
if os.path.isdir(s) and isdir:
|
||||
s += '/'
|
||||
return s
|
||||
|
||||
def cleanse(s):
|
||||
s2 = s.replace("\n", "")
|
||||
return s2
|
||||
|
||||
def padtrunc(s, i, c=' '):
|
||||
return s.ljust(i, c)[:i]
|
||||
def pad(s, i, c=' '):
|
||||
return s.ljust(i, c)
|
||||
|
||||
def count_leading_whitespace(s):
|
||||
'''return the amount of leading whitespace of the provided string'''
|
||||
m = regex.leading_whitespace.match(s)
|
||||
assert m, "count leading whitespace failed somehow"
|
||||
return m.end() - m.start()
|
||||
|
||||
def dump(x):
|
||||
d = {}
|
||||
for name in dir(x):
|
||||
d[name] = getattr(x, name)
|
||||
return '%s: %r' % (x, d)
|
||||
|
||||
def get_margin_limit(w, def_limit=80):
|
||||
lname = '%s.margin' % w.mode.name.lower()
|
||||
if lname in w.application.config:
|
||||
|
|
Loading…
Reference in New Issue