forked from gitea/gitea
		
	Ensure executable bit is kept on the web editor (#10607)
Co-authored-by: Antoine GIRARD <sapk@users.noreply.github.com>
This commit is contained in:
		
							parent
							
								
									3d5d21133c
								
							
						
					
					
						commit
						4e65d2b8ea
					
				| @ -230,6 +230,7 @@ func CreateOrUpdateRepoFile(repo *models.Repository, doer *models.User, opts *Up | ||||
| 
 | ||||
| 	encoding := "UTF-8" | ||||
| 	bom := false | ||||
| 	executable := false | ||||
| 
 | ||||
| 	if !opts.IsNewFile { | ||||
| 		fromEntry, err := commit.GetTreeEntryByPath(fromTreePath) | ||||
| @ -265,6 +266,7 @@ func CreateOrUpdateRepoFile(repo *models.Repository, doer *models.User, opts *Up | ||||
| 			return nil, models.ErrSHAOrCommitIDNotProvided{} | ||||
| 		} | ||||
| 		encoding, bom = detectEncodingAndBOM(fromEntry, repo) | ||||
| 		executable = fromEntry.IsExecutable() | ||||
| 	} | ||||
| 
 | ||||
| 	// For the path where this file will be created/updated, we need to make | ||||
| @ -388,9 +390,15 @@ func CreateOrUpdateRepoFile(repo *models.Repository, doer *models.User, opts *Up | ||||
| 	} | ||||
| 
 | ||||
| 	// Add the object to the index | ||||
| 	if executable { | ||||
| 		if err := t.AddObjectToIndex("100755", objectHash, treePath); err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 	} else { | ||||
| 		if err := t.AddObjectToIndex("100644", objectHash, treePath); err != nil { | ||||
| 			return nil, err | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	// Now write the tree | ||||
| 	treeHash, err := t.WriteTree() | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Antoine GIRARD
						Antoine GIRARD