mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-26 03:52:24 +00:00 
			
		
		
		
	Backport #28019 by @anudeepreddy Hi, This PR fixes #27988. The use of `path.join`(which uses `/` as the file separator) to construct paths and comparing them with paths constructed using `filepath.join`(which uses platform specific file separator) is the root cause of this issue. The desired behavior is to ignore attachments when dumping data directory. Due to the what's mentioned above, the function `addRecursiveExclude` is not actually ignoring the attachments directory and is being written to the archive. The attachment directory is again added to the archive (with different file separator as mentioned in the issue) causing a duplicate entry on windows. The solution is to use `filepath.join` in `addResursiveExclude` to construct `currentAbsPath`. Co-authored-by: Anudeep Reddy <anudeepc85@gmail.com>
This commit is contained in:
		
					parent
					
						
							
								eef4148935
							
						
					
				
			
			
				commit
				
					
						00cd5ba6f4
					
				
			
		
					 1 changed files with 1 additions and 1 deletions
				
			
		|  | @ -452,7 +452,7 @@ func addRecursiveExclude(w archiver.Writer, insidePath, absPath string, excludeA | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 	for _, file := range files { | 	for _, file := range files { | ||||||
| 		currentAbsPath := path.Join(absPath, file.Name()) | 		currentAbsPath := filepath.Join(absPath, file.Name()) | ||||||
| 		currentInsidePath := path.Join(insidePath, file.Name()) | 		currentInsidePath := path.Join(insidePath, file.Name()) | ||||||
| 		if file.IsDir() { | 		if file.IsDir() { | ||||||
| 			if !util.SliceContainsString(excludeAbsPath, currentAbsPath) { | 			if !util.SliceContainsString(excludeAbsPath, currentAbsPath) { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue