From 52db4cbf9a68fb21d30dafdcd87b82079ddf9925 Mon Sep 17 00:00:00 2001 From: wxiaoguang Date: Wed, 20 Nov 2024 18:55:24 +0800 Subject: [PATCH 1/3] fix --- modules/git/commit.go | 23 +++++++++++++++-------- 1 file changed, 15 insertions(+), 8 deletions(-) diff --git a/modules/git/commit.go b/modules/git/commit.go index 86adaa79a667c..14ade2737d765 100644 --- a/modules/git/commit.go +++ b/modules/git/commit.go @@ -379,24 +379,31 @@ func (c *Commit) GetSubModules() (*ObjectCache, error) { defer rd.Close() scanner := bufio.NewScanner(rd) c.submoduleCache = newObjectCache() - var ismodule bool - var path string + var subModule *SubModule for scanner.Scan() { - if strings.HasPrefix(scanner.Text(), "[submodule") { - ismodule = true + if strings.HasPrefix(scanner.Text(), "[") { + if subModule != nil { + c.submoduleCache.Set(subModule.Name, subModule) + subModule = nil + } + if strings.HasPrefix(scanner.Text(), "[submodule") { + subModule = &SubModule{} + } continue } - if ismodule { + if subModule != nil { fields := strings.Split(scanner.Text(), "=") k := strings.TrimSpace(fields[0]) if k == "path" { - path = strings.TrimSpace(fields[1]) + subModule.Name = strings.TrimSpace(fields[1]) } else if k == "url" { - c.submoduleCache.Set(path, &SubModule{path, strings.TrimSpace(fields[1])}) - ismodule = false + subModule.URL = strings.TrimSpace(fields[1]) } } } + if subModule != nil { + c.submoduleCache.Set(subModule.Name, subModule) + } if err = scanner.Err(); err != nil { return nil, fmt.Errorf("GetSubModules scan: %w", err) } From adb668a82d4b51f785a807b098a6dbefc3ee4396 Mon Sep 17 00:00:00 2001 From: wxiaoguang Date: Thu, 21 Nov 2024 09:54:17 +0800 Subject: [PATCH 2/3] add tests --- modules/git/commit.go | 14 ++++++++----- modules/git/commit_test.go | 42 ++++++++++++++++++++++++++++++++++++-- 2 files changed, 49 insertions(+), 7 deletions(-) diff --git a/modules/git/commit.go b/modules/git/commit.go index 14ade2737d765..885c47c57254f 100644 --- a/modules/git/commit.go +++ b/modules/git/commit.go @@ -377,13 +377,17 @@ func (c *Commit) GetSubModules() (*ObjectCache, error) { } defer rd.Close() + return configParseSubModules(rd) +} + +func configParseSubModules(rd io.Reader) (*ObjectCache, error) { scanner := bufio.NewScanner(rd) - c.submoduleCache = newObjectCache() + submoduleCache := newObjectCache() var subModule *SubModule for scanner.Scan() { if strings.HasPrefix(scanner.Text(), "[") { if subModule != nil { - c.submoduleCache.Set(subModule.Name, subModule) + submoduleCache.Set(subModule.Name, subModule) subModule = nil } if strings.HasPrefix(scanner.Text(), "[submodule") { @@ -402,13 +406,13 @@ func (c *Commit) GetSubModules() (*ObjectCache, error) { } } if subModule != nil { - c.submoduleCache.Set(subModule.Name, subModule) + submoduleCache.Set(subModule.Name, subModule) } - if err = scanner.Err(); err != nil { + if err := scanner.Err(); err != nil { return nil, fmt.Errorf("GetSubModules scan: %w", err) } - return c.submoduleCache, nil + return submoduleCache, nil } // GetSubModule get the sub module according entryname diff --git a/modules/git/commit_test.go b/modules/git/commit_test.go index 0ddeb182ef839..8ed30262f7094 100644 --- a/modules/git/commit_test.go +++ b/modules/git/commit_test.go @@ -135,7 +135,7 @@ author KN4CK3R 1711702962 +0100 committer KN4CK3R 1711702962 +0100 encoding ISO-8859-1 gpgsig -----BEGIN PGP SIGNATURE----- - + iQGzBAABCgAdFiEE9HRrbqvYxPT8PXbefPSEkrowAa8FAmYGg7IACgkQfPSEkrow Aa9olwv+P0HhtCM6CRvlUmPaqswRsDPNR4i66xyXGiSxdI9V5oJL7HLiQIM7KrFR gizKa2COiGtugv8fE+TKqXKaJx6uJUJEjaBd8E9Af9PrAzjWj+A84lU6/PgPS8hq @@ -150,7 +150,7 @@ gpgsig -----BEGIN PGP SIGNATURE----- -----END PGP SIGNATURE----- ISO-8859-1` - + commitString = strings.ReplaceAll(commitString, "", " ") sha := &Sha1Hash{0xfe, 0xaf, 0x4b, 0xa6, 0xbc, 0x63, 0x5f, 0xec, 0x44, 0x2f, 0x46, 0xdd, 0xd4, 0x51, 0x24, 0x16, 0xec, 0x43, 0xc2, 0xc2} gitRepo, err := openRepositoryWithDefaultContext(filepath.Join(testReposDir, "repo1_bare")) assert.NoError(t, err) @@ -362,3 +362,41 @@ func Test_GetCommitBranchStart(t *testing.T) { assert.NotEmpty(t, startCommitID) assert.EqualValues(t, "9c9aef8dd84e02bc7ec12641deb4c930a7c30185", startCommitID) } + +func TestConfigSubModule(t *testing.T) { + input := ` +[core] +path = test + +[submodule "submodule1"] + path = path1 + url = https://gitea.io/foo/foo + #branch = b1 + +[other1] +branch = master + +[submodule "submodule2"] + path = path2 + url = https://gitea.io/bar/bar + branch = b2 + +[other2] +branch = main + +[submodule "submodule3"] + path = path3 + url = https://gitea.io/xxx/xxx +` + + subModules, err := configParseSubModules(strings.NewReader(input)) + assert.NoError(t, err) + assert.Len(t, subModules.cache, 3) + + sm1, _ := subModules.Get("path1") + assert.Equal(t, &SubModule{Name: "path1", URL: "https://gitea.io/foo/foo"}, sm1) + sm2, _ := subModules.Get("path2") + assert.Equal(t, &SubModule{Name: "path2", URL: "https://gitea.io/bar/bar"}, sm2) + sm3, _ := subModules.Get("path3") + assert.Equal(t, &SubModule{Name: "path3", URL: "https://gitea.io/xxx/xxx"}, sm3) +} From 29e5cc3c8870d828f1338e14752c7e5d550e2648 Mon Sep 17 00:00:00 2001 From: wxiaoguang Date: Thu, 21 Nov 2024 09:57:14 +0800 Subject: [PATCH 3/3] fine tune --- modules/git/commit.go | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/modules/git/commit.go b/modules/git/commit.go index 885c47c57254f..5f52a9d1ab3f6 100644 --- a/modules/git/commit.go +++ b/modules/git/commit.go @@ -385,18 +385,19 @@ func configParseSubModules(rd io.Reader) (*ObjectCache, error) { submoduleCache := newObjectCache() var subModule *SubModule for scanner.Scan() { - if strings.HasPrefix(scanner.Text(), "[") { + line := strings.TrimSpace(scanner.Text()) + if strings.HasPrefix(line, "[") { if subModule != nil { submoduleCache.Set(subModule.Name, subModule) subModule = nil } - if strings.HasPrefix(scanner.Text(), "[submodule") { + if strings.HasPrefix(line, "[submodule") { subModule = &SubModule{} } continue } if subModule != nil { - fields := strings.Split(scanner.Text(), "=") + fields := strings.Split(line, "=") k := strings.TrimSpace(fields[0]) if k == "path" { subModule.Name = strings.TrimSpace(fields[1])