40
46
template_path = 'loggerhead.templates.inventory'
42
def get_values(self, h, args, kw, headers):
44
revid = h.fix_revid(args[0])
48
def get_filelist(self, inv, path, sort_type):
50
return the list of all files (and their attributes) within a given
53
@param inv: The inventory.
54
@param path: The path of a directory within the inventory.
55
@param sort_type: How to sort the results... XXX.
57
file_id = inv.path2id(path)
63
for filename, entry in dir_ie.children.iteritems():
64
revid_set.add(entry.revision)
67
for change in self._history.get_changes(list(revid_set)):
68
change_dict[change.revid] = change
70
for filename, entry in dir_ie.children.iteritems():
72
if entry.kind == 'directory':
75
absolutepath = pathname
77
absolutepath = path + '/' + pathname
78
revid = entry.revision
80
file = util.Container(
81
filename=filename, executable=entry.executable,
82
kind=entry.kind, absolutepath=absolutepath,
83
file_id=entry.file_id, size=entry.text_size, revid=revid,
84
change=change_dict[revid])
85
file_list.append(file)
87
if sort_type == 'filename':
88
file_list.sort(key=lambda x: x.filename.lower()) # case-insensitive
89
elif sort_type == 'size':
90
file_list.sort(key=lambda x: x.size)
91
elif sort_type == 'date':
92
file_list.sort(key=lambda x: x.change.date)
94
# Always sort directories first.
95
file_list.sort(key=lambda x: x.kind != 'directory')
99
def get_values(self, path, kwargs, headers):
100
history = self._history
101
branch = history._branch
49
inv = h.get_inventory(revid)
51
self.log.exception('Exception fetching changes')
52
raise HTTPServerError('Could not fetch changes')
103
revid = self.get_revid()
104
rev_tree = branch.repository.revision_tree(revid)
105
except errors.NoSuchRevision:
54
file_id = kw.get('file_id', inv.root.file_id)
55
start_revid = kw.get('start_revid', None)
56
sort_type = kw.get('sort', None)
108
file_id = kwargs.get('file_id', None)
109
start_revid = kwargs.get('start_revid', None)
110
sort_type = kwargs.get('sort', 'filename')
58
112
# no navbar for revisions
59
113
navigation = util.Container()
61
change = h.get_changes([ revid ])[0]
62
# add parent & merge-point branch-nick info, in case it's useful
63
h.get_branch_nicks([ change ])
116
path = path.rstrip('/')
117
file_id = rev_tree.path2id(path)
125
path = rev_tree.id2path(file_id)
126
except errors.NoSuchId:
65
path = inv.id2path(file_id)
66
if not path.startswith('/'):
68
idpath = inv.get_idpath(file_id)
129
# Are we at the top of the tree
130
if path in ['/', '']:
70
133
updir = dirname(path)
71
updir_file_id = idpath[-2]
135
# Directory Breadcrumbs
136
directory_breadcrumbs = util.directory_breadcrumbs(
137
self._branch.friendly_name,
138
self._branch.is_root,
141
if not is_null_rev(revid):
143
change = history.get_changes([ revid ])[0]
144
# If we're looking at the tip, use head: in the URL instead
145
if revid == branch.last_revision():
148
revno_url = history.get_revno(revid)
149
history.add_branch_nicks(change)
151
# Create breadcrumb trail for the path within the branch
152
branch_breadcrumbs = util.branch_breadcrumbs(path, rev_tree, 'files')
153
filelist = self.get_filelist(rev_tree.inventory, path, sort_type)
160
branch_breadcrumbs = []
79
164
'branch': self._branch,
167
'revno_url': revno_url,
86
'updir_file_id': updir_file_id,
87
'filelist': h.get_filelist(inv, file_id, sort_type),
89
'posixpath': posixpath,
171
'filelist': filelist,
90
172
'navigation': navigation,
91
173
'url': self._branch.context_url,
92
174
'start_revid': start_revid,
93
175
'fileview_active': True,
176
'directory_breadcrumbs': directory_breadcrumbs,
177
'branch_breadcrumbs': branch_breadcrumbs,