瀏覽代碼

Merge pull request #79 from compressed/null_handling

swap \n for \000, update len check, when reading receive-pack input
Lunny Xiao 11 年之前
父節點
當前提交
9e047cdbbb
共有 1 個文件被更改,包括 2 次插入2 次删除
  1. 2 2
      routers/repo/http.go

+ 2 - 2
routers/repo/http.go

@@ -119,10 +119,10 @@ func Http(ctx *middleware.Context, params martini.Params) {
 
 
 	config := Config{base.RepoRootPath, "git", true, true, func(rpc string, input []byte) {
 	config := Config{base.RepoRootPath, "git", true, true, func(rpc string, input []byte) {
 		if rpc == "receive-pack" {
 		if rpc == "receive-pack" {
-			firstLine := bytes.IndexRune(input, '\n')
+			firstLine := bytes.IndexRune(input, '\000')
 			if firstLine > -1 {
 			if firstLine > -1 {
 				fields := strings.Fields(string(input[:firstLine]))
 				fields := strings.Fields(string(input[:firstLine]))
-				if len(fields) > 3 {
+				if len(fields) == 3 {
 					oldCommitId := fields[0][4:]
 					oldCommitId := fields[0][4:]
 					newCommitId := fields[1]
 					newCommitId := fields[1]
 					refName := fields[2]
 					refName := fields[2]