All enabled tests pass again

This commit is contained in:
Holger Rapp 2012-01-16 22:25:12 +01:00
parent a47f6ab98a
commit 9cc97cd7cb
3 changed files with 125 additions and 68 deletions

View File

@ -331,8 +331,10 @@ class TextObject(CheapTotalOrdering):
for c in self._childs: for c in self._childs:
if c in skip: continue if c in skip: continue
debug("b4: c.abs_span: %r" % (c.abs_span))
_move_start(c) _move_start(c)
_move_end(c) _move_end(c)
debug("a4: c.abs_span: %r" % (c.abs_span))
if self._parent and self._parent not in skip: if self._parent and self._parent not in skip:
self._parent.child_end_moved(sp, diff, set((self,))) self._parent.child_end_moved(sp, diff, set((self,)))
@ -402,14 +404,22 @@ class TextObject(CheapTotalOrdering):
self.child_end_moved(old_end, delta, set((self,))) self.child_end_moved(old_end, delta, set((self,)))
return True
def edited(self, cmds): def edited(self, cmds):
debug("begin: self.current_text: %r" % (self.current_text)) debug("begin: self.current_text: %r" % (self.current_text))
debug("self.abs_start: %r, self.abs_end: %r" % (self.abs_start, self.abs_end)) debug("self.abs_start: %r, self.abs_end: %r" % (self.abs_start, self.abs_end))
for cmd in cmds: for cmd in cmds:
self._do_edit(cmd) self._do_edit(cmd)
# Update all referers # TODO: maybe in a function of its own
def _do_it(obj):
if isinstance(obj, TabStop):
obj.update_referencers()
for c in obj._childs:
_do_it(c)
_do_it(self)
debug("end: self.current_text: %r" % (self.current_text)) debug("end: self.current_text: %r" % (self.current_text))
debug("self.abs_start: %r, self.abs_end: %r" % (self.abs_start, self.abs_end)) debug("self.abs_start: %r, self.abs_end: %r" % (self.abs_start, self.abs_end))
debug("self._childs: %r" % (self._childs)) debug("self._childs: %r" % (self._childs))
@ -559,10 +569,18 @@ class Mirror(TextObject):
""" """
A Mirror object mirrors a TabStop that is, text is repeated here A Mirror object mirrors a TabStop that is, text is repeated here
""" """
def new_text(self, tb): def new_text(self, tb): # TODO: function has a stupid name
debug("new_text, self: %r" % (self)) debug("new_text, self: %r" % (self))
debug("self.abs_start: %r, self.abs_end: %r, self.current_text: %r" % (self.abs_start, self.abs_end, self.current_text)) debug("self.abs_start: %r, self.abs_end: %r, self.current_text: %r" % (self.abs_start, self.abs_end, self.current_text))
self.initial_replace(tb) # TODO: initial replace does not need to take an argument
old_end = self.abs_end
tb.to_vim(self.abs_start, self.abs_end) # TODO: to vim returns something unused
debug("self.abs_end: %r" % (self.abs_end))
self._end = tb.calc_end(self._start)
debug("self.abs_start: %r, self.abs_end: %r" % (self.abs_start, self.abs_end))
if self.abs_end != old_end:
# TODO: child_end_moved is a stupid name for this function
self.child_end_moved(old_end, self.abs_end - old_end, set((self,)))
def __repr__(self): def __repr__(self):
return "Mirror(%s -> %s)" % (self.abs_start, self.abs_end) return "Mirror(%s -> %s)" % (self.abs_start, self.abs_end)
@ -876,16 +894,6 @@ class TabStop(TextObject):
TextObject.__init__(self, parent, token) TextObject.__init__(self, parent, token)
self._no = token.no self._no = token.no
# debug("In Referencer: %r" % (r))
# for r in self._referencer:
# r.new_text(TextBuffer(self.current_text))
def _do_edit(self, *args, **kwargs):
TextObject._do_edit(self, *args, **kwargs)
self.update_referencers()
def update_referencers(self): def update_referencers(self):
for r in self._referencer: for r in self._referencer:
debug("r: %r" % (r)) debug("r: %r" % (r))

View File

@ -789,11 +789,9 @@ class SnippetManager(object):
debug("self._lvb: %r, cb: %r" % (self._lvb, cb)) debug("self._lvb: %r, cb: %r" % (self._lvb, cb))
rv = edit_distance.edit_script(self._lvb, cb) rv = edit_distance.edit_script(self._lvb, cb)
debug("rv: %r" % (rv,)) debug("rv: %r" % (rv,))
cv = edit_distance.compactify(rv) self._csnippets[0].edited(rv)
debug("cv: %r" % (cv)) debug("## self._csnippets: %r" % (self._csnippets[0]))
self._csnippets[0].edited(cv) debug("## self._cnsippets._childs: %r" % (self._csnippets[0]._childs))
# debug("rv: %r" % (rv,))
self._lvb = as_unicode('\n'.join(vim.current.buffer)) self._lvb = as_unicode('\n'.join(vim.current.buffer))
return return
self._vstate.update() self._vstate.update()

View File

@ -27,7 +27,7 @@ def edit_script(a, b):
# TODO: needs some doku # TODO: needs some doku
cost = 0 cost = 0
DI_COST = 1000 # len(a)+len(b) Fix this up DI_COST = len(a)+len(b) # Fix this up
while True: while True:
while len(d[cost]): while len(d[cost]):
#sumarized = [ compactify(what) for c, x, line, col, what in d[cost] ] # TODO: not needed #sumarized = [ compactify(what) for c, x, line, col, what in d[cost] ] # TODO: not needed
@ -44,43 +44,45 @@ def edit_script(a, b):
if a[x] == '\n': if a[x] == '\n':
ncol = 0 ncol = 0
nline +=1 nline +=1
if seen[x+1,y+1] > cost + len(a) - x: if seen[x+1,y+1] > cost:
d[cost + len(a) - x].append((x+1,y+1, nline, ncol, what)) # TODO: slow! d[cost].append((x+1,y+1, nline, ncol, what)) # TODO: slow!
seen[x+1,y+1] = cost + len(a) - x seen[x+1,y+1] = cost
if y < len(b):
if y < len(b): # INSERT
ncol = col + 1 ncol = col + 1
nline = line nline = line
if b[y] == '\n': if b[y] == '\n':
ncol = 0 ncol = 0
nline += 1 nline += 1
if seen[x,y+1] > cost + DI_COST: if (what and what[-1][0] == "I" and what[-1][1] == nline and
seen[x,y+1] = cost + DI_COST what[-1][2]+len(what[-1][-1]) == col and b[y] != '\n' and
d[cost + DI_COST].append((x,y+1, nline, ncol, what + (("I", line, col,b[y]),))) seen[x,y+1] > cost + (DI_COST + x) // 2
if x < len(a): ):
if seen[x+1,y] > cost + DI_COST: seen[x,y+1] = cost + (DI_COST + x) // 2
d[cost + (DI_COST + x) // 2].append((x,y+1, line, ncol, what[:-1] + (("I", what[-1][1], what[-1][2], what[-1][-1] + b[y]),) ))
elif seen[x,y+1] > cost + DI_COST + x:
seen[x,y+1] = cost + DI_COST + x
d[cost + x + DI_COST].append((x,y+1, nline, ncol, what + (("I", line, col,b[y]),)))
if x < len(a): # DELETE
if (what and what[-1][0] == "D" and what[-1][1] == line and
what[-1][2] == col and a[x] != '\n' and
seen[x+1,y] > cost + DI_COST // 2
):
seen[x+1,y] = cost + DI_COST // 2
d[cost + DI_COST // 2].append((x+1,y, line, col, what[:-1] + (("D",line, col, what[-1][-1] + a[x]),) ))
elif seen[x+1,y] > cost + DI_COST:
seen[x+1,y] = cost + DI_COST seen[x+1,y] = cost + DI_COST
d[cost + DI_COST].append((x+1,y, line, col, what + (("D",line, col, a[x]),) )) d[cost + DI_COST].append((x+1,y, line, col, what + (("D",line, col, a[x]),) ))
cost += 1 cost += 1
def compactify(es):
cmds = []
for cmd in es:
ctype, line, col, char = cmd
if (cmds and ctype == "D" and cmds[-1][1] == cmd[1] and cmds[-1][2] == cmd[2] and char != '\n'):
cmds[-1][-1] += char
elif (cmds and ctype == "I" and cmds[-1][1] == cmd[1] and cmds[-1][2]+1 == cmd[2] and char != '\n'):
cmds[-1][-1] += char
else:
cmds.append(list(cmd))
return cmds
def transform(a, cmds): def transform(a, cmds):
buf = a.split("\n") buf = a.split("\n")
for cmd in cmds: for cmd in cmds:
ctype, line, col, char = cmd ctype, line, col, char = cmd
if ctype == "D": if ctype == "D":
buf[line] = buf[line][:col] + buf[line][col+1:] buf[line] = buf[line][:col] + buf[line][col+len(char):]
elif ctype == "I": elif ctype == "I":
buf[line] = buf[line][:col] + char + buf[line][col:] buf[line] = buf[line][:col] + char + buf[line][col:]
buf = '\n'.join(buf).split('\n') buf = '\n'.join(buf).split('\n')
@ -92,45 +94,94 @@ import unittest
class _Base(object): class _Base(object):
def runTest(self): def runTest(self):
es = edit_script(self.a, self.b) es = edit_script(self.a, self.b)
print "compactify(es: %r" % (compactify(es))
tr = transform(self.a, es) tr = transform(self.a, es)
self.assertEqual(self.b, tr) self.assertEqual(self.b, tr)
self.assertEqual(self.wanted, es)
# class TestEmptyString(_Base, unittest.TestCase): class TestEmptyString(_Base, unittest.TestCase):
# a, b = "", "" a, b = "", ""
wanted = ()
# class TestAllMatch(_Base, unittest.TestCase): class TestAllMatch(_Base, unittest.TestCase):
# a, b = "abcdef", "abcdef" a, b = "abcdef", "abcdef"
wanted = ()
# class TestLotsaNewlines(_Base, unittest.TestCase): class TestLotsaNewlines(_Base, unittest.TestCase):
# a, b = "Hello", "Hello\nWorld\nWorld\nWorld" a, b = "Hello", "Hello\nWorld\nWorld\nWorld"
wanted = (
("I", 0, 5, "\n"),
("I", 1, 0, "World"),
("I", 1, 5, "\n"),
("I", 2, 0, "World"),
("I", 2, 5, "\n"),
("I", 3, 0, "World"),
)
# class TestCrash(_Base, unittest.TestCase): class TestCrash(_Base, unittest.TestCase):
# a = 'hallo Blah mitte=sdfdsfsd\nhallo kjsdhfjksdhfkjhsdfkh mittekjshdkfhkhsdfdsf' a = 'hallo Blah mitte=sdfdsfsd\nhallo kjsdhfjksdhfkjhsdfkh mittekjshdkfhkhsdfdsf'
# b = 'hallo Blah mitte=sdfdsfsd\nhallo b mittekjshdkfhkhsdfdsf' b = 'hallo Blah mitte=sdfdsfsd\nhallo b mittekjshdkfhkhsdfdsf'
wanted = (
("I", 1, 6, "b"),
("D", 1, 7, "kjsdhfjksdhfkjhsdfkh"),
)
# class TestRealLife(_Base, unittest.TestCase): class TestRealLife(_Base, unittest.TestCase):
# a = 'hallo End Beginning' a = 'hallo End Beginning'
# b = 'hallo End t' b = 'hallo End t'
wanted = (
("I", 0, 10, "t"),
("D", 0, 11, "Beginning"),
)
class TestRealLife1(_Base, unittest.TestCase): class TestRealLife1(_Base, unittest.TestCase):
a = 'Vorne hallo Hinten' a = 'Vorne hallo Hinten'
b = 'Vorne hallo Hinten' b = 'Vorne hallo Hinten'
# def test_all_match(self): wanted = (
# rv = edit_script("abcdef", "abcdef") ("I", 0, 11, " "),
# self.assertEqual("MMMMMM", rv) )
# def test_no_substr(self): class TestCheapDelete(_Base, unittest.TestCase):
# rv = edit_script("abc", "def") a = 'Vorne hallo Hinten'
# self.assertEqual("SSS", rv) b = 'Vorne Hinten'
wanted = (
("D", 0, 5, " hallo"),
)
# def test_paper_example(self): class TestNoSubstring(_Base, unittest.TestCase):
# rv = edit_script("abcabba","cbabac") a,b = "abc", "def"
# self.assertEqual(rv, "SMDMMDMI") wanted = (
("I", 0, 0, "def"),
("D", 0, 3, "abc"),
)
# TODO: quote the correct paper
#
class TestPaperExample(_Base, unittest.TestCase):
a,b = "abcabba", "cbabac"
wanted = (
("I", 0, 0, "cb"),
("I", 0, 4, "a"),
("D", 0, 6, "abba"),
)
class TestSKienaExample(_Base, unittest.TestCase):
a, b = "thou shalt not", "you should not"
wanted = (
('I', 0, 0, 'y'),
('D', 0, 1, 'th'),
('I', 0, 6, 'ou'),
('D', 0, 8, 'a'),
('I', 0, 9, 'd'),
('D', 0, 10, 't'),
)
class TestUltiSnipsProblem(_Base, unittest.TestCase):
a = "this is it this is it this is it"
b = "this is it a this is it"
wanted = (
("I", 0, 11, "a"),
("D", 0, 12, "this is it")
)
# def test_skiena_example(self):
# rv = edit_script("thou shalt not", "you should not")
# self.assertEqual(rv, "DSMMMMMISMSMMMM")
if __name__ == '__main__': if __name__ == '__main__':
unittest.main() unittest.main()
# k = TestEditScript() # k = TestEditScript()