1
0
mirror of https://github.com/wting/autojump synced 2024-10-27 20:34:07 +00:00

redo previlege check except in windows

This commit is contained in:
xiaonaitong 2011-09-15 16:05:51 +08:00
parent a6410994c2
commit d9a423370a

View File

@ -55,24 +55,25 @@ def save(path_dict, dic_file):
a backup file.""" a backup file."""
# If the dic_file exists, check that it belongs to us # If the dic_file exists, check that it belongs to us
# Otherwise, fail quietly # Otherwise, fail quietly
temp = NamedTemporaryFile(dir=CONFIG_DIR, delete=False) if (not os.path.exists(dic_file)) or os.name == 'nt' or os.getuid() == os.stat(dic_file)[4]:
pickle.dump(path_dict, temp, 2) temp = NamedTemporaryFile(dir=CONFIG_DIR, delete=False)
temp.flush() pickle.dump(path_dict, temp, 2)
os.fsync(temp) temp.flush()
temp.close() os.fsync(temp)
#cf. http://thunk.org/tytso/blog/2009/03/15/dont-fear-the-fsync/ temp.close()
#os.rename(temp.name, dic_file) #cf. http://thunk.org/tytso/blog/2009/03/15/dont-fear-the-fsync/
import shutil #os.rename(temp.name, dic_file)
shutil.copy(temp.name, dic_file) import shutil
try: #backup file shutil.copy(temp.name, dic_file)
import time try: #backup file
if (not os.path.exists(dic_file+".bak") or import time
time.time()-os.path.getmtime(dic_file+".bak")>86400): if (not os.path.exists(dic_file+".bak") or
import shutil time.time()-os.path.getmtime(dic_file+".bak")>86400):
shutil.copy(dic_file, dic_file+".bak") import shutil
except OSError as ex: shutil.copy(dic_file, dic_file+".bak")
print("Error while creating backup autojump file. (%s)" % except OSError as ex:
ex, file=stderr) print("Error while creating backup autojump file. (%s)" %
ex, file=stderr)
def forget(path_dict, dic_file): def forget(path_dict, dic_file):
"""Gradually forget about directories. Only call """Gradually forget about directories. Only call