mirror of
				https://github.com/gohugoio/hugo.git
				synced 2024-05-11 05:54:58 +00:00 
			
		
		
		
	@@ -14,13 +14,11 @@
 | 
				
			|||||||
package hugolib
 | 
					package hugolib
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
	"path"
 | 
					 | 
				
			||||||
	"path/filepath"
 | 
						"path/filepath"
 | 
				
			||||||
	"strings"
 | 
						"strings"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	"github.com/bep/gitmap"
 | 
						"github.com/bep/gitmap"
 | 
				
			||||||
	"github.com/gohugoio/hugo/config"
 | 
						"github.com/gohugoio/hugo/config"
 | 
				
			||||||
	"github.com/gohugoio/hugo/helpers"
 | 
					 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
type gitInfo struct {
 | 
					type gitInfo struct {
 | 
				
			||||||
@@ -32,28 +30,20 @@ func (g *gitInfo) forPage(p *Page) (*gitmap.GitInfo, bool) {
 | 
				
			|||||||
	if g == nil {
 | 
						if g == nil {
 | 
				
			||||||
		return nil, false
 | 
							return nil, false
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	name := path.Join(g.contentDir, filepath.ToSlash(p.Path()))
 | 
					
 | 
				
			||||||
 | 
						name := strings.TrimPrefix(filepath.ToSlash(p.Filename()), g.contentDir)
 | 
				
			||||||
 | 
						name = strings.TrimPrefix(name, "/")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return g.repo.Files[name], true
 | 
						return g.repo.Files[name], true
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func newGitInfo(cfg config.Provider) (*gitInfo, error) {
 | 
					func newGitInfo(cfg config.Provider) (*gitInfo, error) {
 | 
				
			||||||
	var (
 | 
						workingDir := cfg.GetString("workingDir")
 | 
				
			||||||
		workingDir = cfg.GetString("workingDir")
 | 
					 | 
				
			||||||
		contentDir = cfg.GetString("contentDir")
 | 
					 | 
				
			||||||
	)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	gitRepo, err := gitmap.Map(workingDir, "")
 | 
						gitRepo, err := gitmap.Map(workingDir, "")
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		return nil, err
 | 
							return nil, err
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	repoPath := filepath.FromSlash(gitRepo.TopLevelAbsPath)
 | 
						return &gitInfo{contentDir: gitRepo.TopLevelAbsPath, repo: gitRepo}, nil
 | 
				
			||||||
	// The Hugo site may be placed in a sub folder in the Git repo,
 | 
					 | 
				
			||||||
	// one example being the Hugo docs.
 | 
					 | 
				
			||||||
	// We have to find the root folder to the Hugo site below the Git root.
 | 
					 | 
				
			||||||
	contentRoot := strings.TrimPrefix(workingDir, repoPath)
 | 
					 | 
				
			||||||
	contentRoot = strings.TrimPrefix(contentRoot, helpers.FilePathSeparator)
 | 
					 | 
				
			||||||
	contentDir = path.Join(filepath.ToSlash(contentRoot), contentDir)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	return &gitInfo{contentDir: contentDir, repo: gitRepo}, nil
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -921,21 +921,50 @@ func TestPageWithLastmodFromGitInfo(t *testing.T) {
 | 
				
			|||||||
	cfg.Set("frontmatter", map[string]interface{}{
 | 
						cfg.Set("frontmatter", map[string]interface{}{
 | 
				
			||||||
		"lastmod": []string{":git", "lastmod"},
 | 
							"lastmod": []string{":git", "lastmod"},
 | 
				
			||||||
	})
 | 
						})
 | 
				
			||||||
 | 
						cfg.Set("defaultContentLanguage", "en")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						langConfig := map[string]interface{}{
 | 
				
			||||||
 | 
							"en": map[string]interface{}{
 | 
				
			||||||
 | 
								"weight":       1,
 | 
				
			||||||
 | 
								"languageName": "English",
 | 
				
			||||||
 | 
								"contentDir":   "content",
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							"nn": map[string]interface{}{
 | 
				
			||||||
 | 
								"weight":       2,
 | 
				
			||||||
 | 
								"languageName": "Nynorsk",
 | 
				
			||||||
 | 
								"contentDir":   "content_nn",
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						cfg.Set("languages", langConfig)
 | 
				
			||||||
	cfg.Set("enableGitInfo", true)
 | 
						cfg.Set("enableGitInfo", true)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	assrt.NoError(loadDefaultSettingsFor(cfg))
 | 
						assrt.NoError(loadDefaultSettingsFor(cfg))
 | 
				
			||||||
 | 
						assrt.NoError(loadLanguageSettings(cfg, nil))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	wd, err := os.Getwd()
 | 
						wd, err := os.Getwd()
 | 
				
			||||||
	assrt.NoError(err)
 | 
						assrt.NoError(err)
 | 
				
			||||||
	cfg.Set("workingDir", filepath.Join(wd, "testsite"))
 | 
						cfg.Set("workingDir", filepath.Join(wd, "testsite"))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	s := buildSingleSite(t, deps.DepsCfg{Fs: fs, Cfg: cfg}, BuildCfg{SkipRender: true})
 | 
						h, err := NewHugoSites(deps.DepsCfg{Fs: fs, Cfg: cfg})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	assrt.Len(s.RegularPages, 1)
 | 
						assrt.NoError(err)
 | 
				
			||||||
 | 
						assrt.Len(h.Sites, 2)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						require.NoError(t, h.Build(BuildCfg{SkipRender: true}))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						enSite := h.Sites[0]
 | 
				
			||||||
 | 
						assrt.Len(enSite.RegularPages, 1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	// 2018-03-11 is the Git author date for testsite/content/first-post.md
 | 
						// 2018-03-11 is the Git author date for testsite/content/first-post.md
 | 
				
			||||||
	assrt.Equal("2018-03-11", s.RegularPages[0].Lastmod.Format("2006-01-02"))
 | 
						assrt.Equal("2018-03-11", enSite.RegularPages[0].Lastmod.Format("2006-01-02"))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						nnSite := h.Sites[1]
 | 
				
			||||||
 | 
						assrt.Len(nnSite.RegularPages, 1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// 2018-08-11 is the Git author date for testsite/content_nn/first-post.md
 | 
				
			||||||
 | 
						assrt.Equal("2018-08-11", nnSite.RegularPages[0].Lastmod.Format("2006-01-02"))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func TestPageWithFrontMatterConfig(t *testing.T) {
 | 
					func TestPageWithFrontMatterConfig(t *testing.T) {
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user