2019-05-23 23:55:57 -04:00
|
|
|
class FindShortestID:
|
|
|
|
__slots__ = 'short_id', 'new_id'
|
|
|
|
|
|
|
|
def __init__(self):
|
2019-05-24 22:40:39 -04:00
|
|
|
self.short_id = ''
|
2019-05-23 23:55:57 -04:00
|
|
|
self.new_id = None
|
|
|
|
|
2019-05-24 22:40:39 -04:00
|
|
|
def step(self, other_id, new_id):
|
|
|
|
self.new_id = new_id
|
2019-05-23 23:55:57 -04:00
|
|
|
for i in range(len(self.new_id)):
|
|
|
|
if other_id[i] != self.new_id[i]:
|
|
|
|
if i > len(self.short_id)-1:
|
|
|
|
self.short_id = self.new_id[:i+1]
|
|
|
|
break
|
|
|
|
|
|
|
|
def finalize(self):
|
2019-12-07 18:13:13 -05:00
|
|
|
if self.short_id:
|
2021-05-07 11:30:31 -04:00
|
|
|
return '#'+self.short_id
|
2019-12-07 18:13:13 -05:00
|
|
|
|
2019-05-23 23:55:57 -04:00
|
|
|
|
|
|
|
def register_canonical_functions(connection):
|
2021-06-15 15:05:53 -04:00
|
|
|
connection.create_aggregate("shortest_id", 2, FindShortestID)
|