pychecker-inspired cleanup

--HG--
branch : pmacs2
This commit is contained in:
Erik Osheim 2009-11-10 00:30:55 -05:00
parent 67d13d0559
commit 6d3eab1a47
7 changed files with 68 additions and 85 deletions

View File

@ -170,7 +170,6 @@ class Buffer(object):
def remove_window(self, w): def remove_window(self, w):
if w in self.windows: if w in self.windows:
self.windows.remove(w) self.windows.remove(w)
modename = w.mode.name
if w.mode.name in self.highlights: if w.mode.name in self.highlights:
for w2 in self.windows: for w2 in self.windows:
if w2.mode.name == w.mode.name: if w2.mode.name == w.mode.name:
@ -244,7 +243,7 @@ class Buffer(object):
mode = None mode = None
if os.path.exists(path): if os.path.exists(path):
if force: if force:
mode = os.stat(self.path)[0] mode = os.stat(path)[0]
else: else:
# XYZ # XYZ
raise Exception("oh no! %r already exists" % path) raise Exception("oh no! %r already exists" % path)
@ -253,7 +252,7 @@ class Buffer(object):
data = self.write_filter(self.make_string()) data = self.write_filter(self.make_string())
# create a safe temporary path to write to, and write out data to it # create a safe temporary path to write to, and write out data to it
temp_path = self._temp_path() temp_path = self._temp_path(path)
f2 = self._open_file_w(temp_path) f2 = self._open_file_w(temp_path)
f2.write(data) f2.write(data)
f2.close() f2.close()
@ -362,7 +361,6 @@ class Buffer(object):
self.delete_char(p, act=act, force=force) self.delete_char(p, act=act, force=force)
self.insert_string(p, c, act=act, force=force) self.insert_string(p, c, act=act, force=force)
def delete_line(self, y, act=ACT_NORM, force=False): def delete_line(self, y, act=ACT_NORM, force=False):
line = self.lines[y]
p1 = Point(0, y) p1 = Point(0, y)
if y < len(self.lines) - 1: if y < len(self.lines) - 1:
p2 = Point(0, y + 1) p2 = Point(0, y + 1)
@ -526,10 +524,10 @@ class IperlBuffer(InterpreterBuffer):
return '*%s*' % cls._basename return '*%s*' % cls._basename
create_name = classmethod(create_name) create_name = classmethod(create_name)
def get_cmd(self): def get_cmd(self):
cmd = ['iperl', '-p']
if self.parent: if self.parent:
return ('iperl', '-p', '-r', self.parent.path) cmd.extend(['-r', self.parent.path])
else: return cmd
return ('iperl', '-p')
def get_env(self): def get_env(self):
lib = ':'.join(self.application.config.get('perl.libs', [])) lib = ':'.join(self.application.config.get('perl.libs', []))
return {'PERL5LIB': lib} return {'PERL5LIB': lib}

View File

@ -29,7 +29,7 @@ def find_common_string(candidates):
class Completer(object): class Completer(object):
def __init__(self, application): def __init__(self, application):
self.application = application self.application = application
def get_candidates(self, s): def get_candidates(self, s, w=None):
assert "Not implemented" assert "Not implemented"
def tab_string(self, s, w=None): def tab_string(self, s, w=None):
'''returns a tuple of three things: '''returns a tuple of three things:

39
lex.py
View File

@ -6,22 +6,19 @@ def escape(s):
return re.escape(s) return re.escape(s)
class Token(object): class Token(object):
def __init__(self, name, rule, y, x, s, color=None, parent=None, matchd={}, link=None): def __init__(self, name, rule, y, x, s, color=None, parent=None,
self.name = name matchd={}, link=None):
self.rule = rule self.name = name
self.y = y self.rule = rule
self.x = x self.y = y
self.string = s self.x = x
self.color = color self.string = s
self.parent = parent self.color = color
self.matchd = matchd self.parent = parent
self.link = link self.matchd = matchd
self._debug = False self.link = link
#self._fqlist = None self._debug = False
#self._fqname = None assert not parent or parent.name
#self._fqlist = self.mkfqlist()
#self._fqname = self.mkfqname()
assert parent is None or hasattr(parent, 'name'), 'oh no %r' % parent
def isa(self, *names): def isa(self, *names):
return self.name in names return self.name in names
@ -62,11 +59,6 @@ class Token(object):
if self.link and not self.link.startswith('middle'): if self.link and not self.link.startswith('middle'):
names.append(self.rule.name) names.append(self.rule.name)
return names return names
#def fqlist(self):
# if self._fqlist is None:
# self._fqlist = self.mkfqlist()
# return self._fqlist
#def mkfqlist(self):
def fqlist(self): def fqlist(self):
if self.parent is not None: if self.parent is not None:
names = self.parent.domain() names = self.parent.domain()
@ -76,11 +68,6 @@ class Token(object):
names.append(self.rule.name) names.append(self.rule.name)
names.append(self.name) names.append(self.name)
return names return names
#def fqname(self):
# if self._fqname is None:
# self._fqname = self.mkfqname()
# return self._fqname
#def mkfqname(self):
def fqname(self): def fqname(self):
names = self.fqlist() names = self.fqlist()
return '.'.join(names) return '.'.join(names)

View File

@ -13,19 +13,17 @@ def arg(n, t=type(''), dt=None, p=None, h='', dv=default.none, ld=False, q='defa
return Argument(n, type=t, datatype=dt, prompt=p, help=h, default=dv, return Argument(n, type=t, datatype=dt, prompt=p, help=h, default=dv,
load_default=ld, queue=q) load_default=ld, queue=q)
class Argument(object): class Argument(object):
def __init__(self, name, type=type(""), datatype=None, prompt=None, help='', def __init__(self, name, type=type(""), datatype=None, prompt=None,
default=default.none, load_default=False, queue='default'): help='', default=default.none, load_default=False,
self.name = name queue='default'):
self.type = type self.name = name
self.datatype = datatype self.type = type
if prompt is None: self.datatype = datatype
self.prompt = "%s: " % (name) self.prompt = prompt or name + ': '
else: self.help = help
self.prompt = prompt
self.help = help
self.load_default = load_default self.load_default = load_default
self.default = default self.default = default
self.queue = queue self.queue = queue
def coerce_to_type(self, value): def coerce_to_type(self, value):
if self.type == type(0): if self.type == type(0):

View File

@ -261,8 +261,6 @@ class Fundamental(Handler):
self.add_bindings('uppercase-word', ('M-u',)) self.add_bindings('uppercase-word', ('M-u',))
self.add_bindings('lowercase-word', ('M-l',)) self.add_bindings('lowercase-word', ('M-l',))
i = 31
# used for all word operations # used for all word operations
if not self.word_letters: if not self.word_letters:
self.word_letters = w.application.config['word_letters'] self.word_letters = w.application.config['word_letters']
@ -342,7 +340,7 @@ class Fundamental(Handler):
y = self.window.first.y y = self.window.first.y
if self.window.first.x > 0: if self.window.first.x > 0:
y += 1 y += 1
lvl = self.tabber.get_level(y) #lvl = self.tabber.get_level(y)
markers = self.tabber.record[y] markers = self.tabber.record[y]
if w.buffer.is_whitespace(y): if w.buffer.is_whitespace(y):
ws = None ws = None
@ -464,8 +462,6 @@ class Fundamental(Handler):
self.window.set_error(str(e)) self.window.set_error(str(e))
def region_added(self, p, newlines): def region_added(self, p, newlines):
mname = self.name
if self.lexer is not None: if self.lexer is not None:
ydelta = len(newlines) - 1 ydelta = len(newlines) - 1
xdelta = len(newlines[-1]) xdelta = len(newlines[-1])

View File

@ -424,26 +424,28 @@ class PerlQuoteWord(Method):
class PerlDequoteWord(Method): class PerlDequoteWord(Method):
word_re = re.compile('^[a-zA-Z0-9_]+$') word_re = re.compile('^[a-zA-Z0-9_]+$')
def _execute(self, w, **vargs): def _execute(self, w, **vargs):
p = w.logical_cursor() p = w.logical_cursor()
x1, x2 = p.x, p.end_x() tokens = w.get_token_list_at_point(p)
tokens = w.get_line_token_list_at_point(p) token = None
data_token = None seen = False
saw_start = False for t in tokens:
for token in tokens: if t.end_x() < p.x:
if token.end_x() < x1: pass
continue elif t.fqname().endswith('string.start'):
elif token.fqname().endswith('string.start'): seen = True
saw_start = True elif t.fqname().endswith('string.data'):
elif token.fqname().endswith('string.data'): token = t
data_token = token elif token and t.fqname().endswith('string.end'):
elif saw_start: break
elif seen:
token = None
break break
if not data_token: if not token:
w.set_error('no suitable quoted word found!') w.set_error('no suitable quoted word found!')
return return
w.delete_char(Point(token.end_x(), token.y))
w.set_error('going to dequote %r' % token.data) w.delete_char(Point(token.x - 1, token.y))
class PerlInitFunctions(Method): class PerlInitFunctions(Method):
'''Jump to a function defined in this module''' '''Jump to a function defined in this module'''
@ -502,7 +504,7 @@ class PerlHashCleanup(Method):
myregex = r myregex = r
if myregex is None: if myregex is None:
raise Exception, "Not a perl hash line" raise Exception("Not a perl hash line")
groups_by_line[cursor.y] = myregex.match(line).groups() groups_by_line[cursor.y] = myregex.match(line).groups()
@ -596,7 +598,6 @@ class PerlWrapParagraph(WrapParagraph):
return ltype return ltype
def _fix_comments(self, c, w): def _fix_comments(self, c, w):
h = w.buffer.highlights[w.mode.name]
y1 = c.y y1 = c.y
y2 = c.y y2 = c.y
while y2 < len(w.buffer.lines) - 1: while y2 < len(w.buffer.lines) - 1:
@ -776,7 +777,7 @@ class PerlContext(context.Context):
i += 1 i += 1
# white is for delimiters, operators, numbers # white is for delimiters, operators, numbers
default = ('default', 'default') c_default = ('default', 'default')
# magenta is for keywords/builtins, translation, globs # magenta is for keywords/builtins, translation, globs
lo_magenta = ('magenta202', 'default') lo_magenta = ('magenta202', 'default')
@ -872,7 +873,7 @@ class Perl(Fundamental):
'evaldoc.null': hi_cyan, 'evaldoc.null': hi_cyan,
# numbers # numbers
'perl.number': default, 'perl.number': c_default,
# strings # strings
'perl.string.start': lo_green, 'perl.string.start': lo_green,
@ -933,7 +934,6 @@ class Perl(Fundamental):
'perl-hash-cleanup': ('C-c h',), 'perl-hash-cleanup': ('C-c h',),
'perl-open-module': ('C-c C-f',), 'perl-open-module': ('C-c C-f',),
'perl-open-module-word': ('C-c M-f',), 'perl-open-module-word': ('C-c M-f',),
#'perl-run': ('C-c r',),
'perl-semantic-complete': ('C-c TAB',), 'perl-semantic-complete': ('C-c TAB',),
'perl-set-lib': ('C-c l',), 'perl-set-lib': ('C-c l',),
'perl-wrap-paragraph': ('M-q',), 'perl-wrap-paragraph': ('M-q',),
@ -942,6 +942,8 @@ class Perl(Fundamental):
'close-paren': (')'), 'close-paren': (')'),
'close-bracket': (']'), 'close-bracket': (']'),
'close-brace': ('}'), 'close-brace': ('}'),
'perl-quote-word': ("C-c '",),
'perl-dequote-word': ("C-u '",),
} }
def __init__(self, w): def __init__(self, w):
Fundamental.__init__(self, w) Fundamental.__init__(self, w)
@ -974,7 +976,7 @@ class Perl(Fundamental):
data = p.stdout.read() data = p.stdout.read()
status = p.wait() status = p.wait()
if status != 0: raise Exception, "%r failed" % cmd if status != 0: raise Exception("%r failed" % cmd)
self.perlinc = data.split('\n') self.perlinc = data.split('\n')
return self.perlinc return self.perlinc

View File

@ -34,10 +34,10 @@ class Names(Rule):
def __init__(self, names): def __init__(self, names):
self.names = names self.names = names
def _match(self, tokens): def _match(self, tokens):
if token.name in self.names: for token in tokens:
return [1] if token.name in self.names:
else: return [1]
return [] return []
class String(Rule): class String(Rule):
def __init__(self, s): def __init__(self, s):
@ -51,18 +51,18 @@ class Strings(Rule):
def __init__(self, ss): def __init__(self, ss):
self.strings = ss self.strings = ss
def _match(self, tokens): def _match(self, tokens):
if token.string in self.strings: for token in tokens:
return [1] if token.string in self.strings:
else: return [1]
return [] return []
class Stringre(Rule): class Stringre(Rule):
def __init__(self, r): def __init__(self, r):
self.regex = re.compile(r) self.regex = re.compile(r)
def _match(self, tokens): def _match(self, tokens):
if self.regex.match(token.string): for token in tokens:
return [1] if self.regex.match(token.string):
else: return [1]
return [] return []
class Match(Rule): class Match(Rule):
method = lex.Token.match method = lex.Token.match
@ -98,10 +98,12 @@ class And(Rule):
return [n] return [n]
class Or(Rule): class Or(Rule):
def match(self, tokens): def match(self, tokens):
n = 0
for r in self.rules: for r in self.rules:
result = r.match(tokens[n:]) result = r.match(tokens[n:])
if result: if result:
return result return result
n += result[0]
return [] return []
class Repeat(Rule): class Repeat(Rule):