move symlinks as-is; don't expand into full files
previously, when moving or renaming a symlink to a file (or a folder with symlinks inside), the dedup setting would decide whether those links would be expanded into full files or not with dedup disabled (which is the default), all symlinks would be expanded during a move operation now, the dedup-setting is ignored when files/folders are moved, but it still applies when uploading or copying files/folders * absolute symlinks are moved as-is * relative symlinks are rewritten as necessary, assuming both source and destination is known in db
This commit is contained in:
		
							parent
							
								
									782084056d
								
							
						
					
					
						commit
						5ab09769e1
					
				| @ -1606,7 +1606,8 @@ class AuthSrv(object): | |||||||
|         if enshare: |         if enshare: | ||||||
|             import sqlite3 |             import sqlite3 | ||||||
| 
 | 
 | ||||||
|             shv = VFS(self.log_func, "", shr, shr, AXS(), {}) |             zsd = {"d2d": True, "tcolor": self.args.tcolor} | ||||||
|  |             shv = VFS(self.log_func, "", shr, shr, AXS(), zsd) | ||||||
| 
 | 
 | ||||||
|             db_path = self.args.shr_db |             db_path = self.args.shr_db | ||||||
|             db = sqlite3.connect(db_path) |             db = sqlite3.connect(db_path) | ||||||
|  | |||||||
| @ -3426,6 +3426,7 @@ class Up2k(object): | |||||||
|         rm: bool = False, |         rm: bool = False, | ||||||
|         lmod: float = 0, |         lmod: float = 0, | ||||||
|         fsrc: Optional[str] = None, |         fsrc: Optional[str] = None, | ||||||
|  |         is_mv: bool = False, | ||||||
|     ) -> None: |     ) -> None: | ||||||
|         if src == dst or (fsrc and fsrc == dst): |         if src == dst or (fsrc and fsrc == dst): | ||||||
|             t = "symlinking a file to itself?? orig(%s) fsrc(%s) link(%s)" |             t = "symlinking a file to itself?? orig(%s) fsrc(%s) link(%s)" | ||||||
| @ -3442,7 +3443,7 @@ class Up2k(object): | |||||||
| 
 | 
 | ||||||
|         linked = False |         linked = False | ||||||
|         try: |         try: | ||||||
|             if not flags.get("dedup"): |             if not is_mv and not flags.get("dedup"): | ||||||
|                 raise Exception("dedup is disabled in config") |                 raise Exception("dedup is disabled in config") | ||||||
| 
 | 
 | ||||||
|             lsrc = src |             lsrc = src | ||||||
| @ -4601,7 +4602,7 @@ class Up2k(object): | |||||||
|                 dlink = bos.readlink(sabs) |                 dlink = bos.readlink(sabs) | ||||||
|                 dlink = os.path.join(os.path.dirname(sabs), dlink) |                 dlink = os.path.join(os.path.dirname(sabs), dlink) | ||||||
|                 dlink = bos.path.abspath(dlink) |                 dlink = bos.path.abspath(dlink) | ||||||
|                 self._symlink(dlink, dabs, dvn.flags, lmod=ftime) |                 self._symlink(dlink, dabs, dvn.flags, lmod=ftime, is_mv=True) | ||||||
|                 wunlink(self.log, sabs, svn.flags) |                 wunlink(self.log, sabs, svn.flags) | ||||||
|             else: |             else: | ||||||
|                 atomic_move(self.log, sabs, dabs, svn.flags) |                 atomic_move(self.log, sabs, dabs, svn.flags) | ||||||
| @ -4820,7 +4821,7 @@ class Up2k(object): | |||||||
|             flags = self.flags.get(ptop) or {} |             flags = self.flags.get(ptop) or {} | ||||||
|             atomic_move(self.log, sabs, slabs, flags) |             atomic_move(self.log, sabs, slabs, flags) | ||||||
|             bos.utime(slabs, (int(time.time()), int(mt)), False) |             bos.utime(slabs, (int(time.time()), int(mt)), False) | ||||||
|             self._symlink(slabs, sabs, flags, False) |             self._symlink(slabs, sabs, flags, False, is_mv=True) | ||||||
|             full[slabs] = (ptop, rem) |             full[slabs] = (ptop, rem) | ||||||
|             sabs = slabs |             sabs = slabs | ||||||
| 
 | 
 | ||||||
| @ -4879,7 +4880,9 @@ class Up2k(object): | |||||||
|             # (for example a volume with symlinked dupes but no --dedup); |             # (for example a volume with symlinked dupes but no --dedup); | ||||||
|             # fsrc=sabs is then a source that currently resolves to copy |             # fsrc=sabs is then a source that currently resolves to copy | ||||||
| 
 | 
 | ||||||
|             self._symlink(dabs, alink, flags, False, lmod=lmod or 0, fsrc=sabs) |             self._symlink( | ||||||
|  |                 dabs, alink, flags, False, lmod=lmod or 0, fsrc=sabs, is_mv=True | ||||||
|  |             ) | ||||||
| 
 | 
 | ||||||
|         return len(full) + len(links) |         return len(full) + len(links) | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 ed
						ed