Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(587)

Side by Side Diff: chrome/common/extensions/docs/server2/local_file_system.py

Issue 10826037: Extensions Docs Server: Fix zipper (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 # Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 # Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be 2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file. 3 # found in the LICENSE file.
4 4
5 import os 5 import os
6 6
7 import file_system 7 import file_system
8 from future import Future 8 from future import Future
9 9
10 class LocalFileSystem(file_system.FileSystem): 10 class LocalFileSystem(file_system.FileSystem):
11 """FileSystem implementation which fetches resources from the local 11 """FileSystem implementation which fetches resources from the local
12 filesystem. 12 filesystem.
13 """ 13 """
14 def __init__(self, base_path): 14 def __init__(self, base_path):
15 self._base_path = self._ConvertToFilepath(base_path) 15 self._base_path = self._ConvertToFilepath(base_path)
16 16
17 def _ConvertToFilepath(self, path): 17 def _ConvertToFilepath(self, path):
18 return path.replace('/', os.sep) 18 return path.replace('/', os.sep)
19 19
20 def _ReadFile(self, filename): 20 def _ReadFile(self, filename, process):
21 with open(os.path.join(self._base_path, filename), 'r') as f: 21 with open(os.path.join(self._base_path, filename), 'r') as f:
22 return file_system._ProcessFileData(f.read(), filename) 22 if process:
not at google - send to devlin 2012/07/27 04:54:36 Safer to make it clear that f is only being read o
cduvall 2012/07/27 18:12:28 Done.
23 return file_system._ProcessFileData(f.read(), filename)
24 return f.read()
23 25
24 def _ListDir(self, dir_name): 26 def _ListDir(self, dir_name):
25 all_files = [] 27 all_files = []
26 full_path = os.path.join(self._base_path, dir_name) 28 full_path = os.path.join(self._base_path, dir_name)
27 for path in os.listdir(full_path): 29 for path in os.listdir(full_path):
28 if path.startswith('.'): 30 if path.startswith('.'):
29 continue 31 continue
30 if os.path.isdir(os.path.join(full_path, path)): 32 if os.path.isdir(os.path.join(full_path, path)):
31 all_files.append(path + '/') 33 all_files.append(path + '/')
32 else: 34 else:
33 all_files.append(path) 35 all_files.append(path)
34 return all_files 36 return all_files
35 37
36 def Read(self, paths): 38 def Read(self, paths, process=True):
37 result = {} 39 result = {}
38 for path in paths: 40 for path in paths:
39 if path.endswith('/'): 41 if path.endswith('/'):
40 result[path] = self._ListDir(self._ConvertToFilepath(path)) 42 result[path] = self._ListDir(self._ConvertToFilepath(path))
41 else: 43 else:
42 result[path] = self._ReadFile(self._ConvertToFilepath(path)) 44 result[path] = self._ReadFile(self._ConvertToFilepath(path), process)
43 return Future(value=result) 45 return Future(value=result)
44 46
45 def Stat(self, path): 47 def Stat(self, path):
46 return self.StatInfo(os.stat(os.path.join(self._base_path, path)).st_mtime) 48 return self.StatInfo(os.stat(os.path.join(self._base_path, path)).st_mtime)
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698