Misc depreation updates
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Tue, 4 Jan 2022 12:07:10 +0000 (13:07 +0100)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Tue, 4 Jan 2022 16:10:39 +0000 (17:10 +0100)
* Deprecate .Page.Path when backed by a file
* site.Permalinks
* --ignoreVendor (use --ignoreVendorPaths)

Closes #9348
Closes #9349

19 files changed:
commands/commands.go
commands/commands_test.go
commands/convert.go
commands/hugo.go
commands/mod.go
hugofs/files/classifier.go
hugolib/config.go
hugolib/content_map_page.go
hugolib/page.go
hugolib/page__meta.go
hugolib/site.go
hugolib/site_test.go
hugolib/testhelpers_test.go
modules/client.go
resources/page/page.go
resources/page/page_marshaljson.autogen.go
resources/page/page_matcher.go
resources/page/page_nop.go
resources/page/testhelpers_test.go

index 4153c3cdf2c136b3db12d5d37c5e01b72e1234d8..b6e8dd469d1b9ae1943507c5d8e5f4649c176dc2 100644 (file)
@@ -131,8 +131,7 @@ type hugoCmd struct {
 
 var _ cmder = (*nilCommand)(nil)
 
-type nilCommand struct {
-}
+type nilCommand struct{}
 
 func (c *nilCommand) getCommand() *cobra.Command {
        return nil
@@ -281,7 +280,6 @@ func (cc *hugoBuilderCommon) handleCommonBuilderFlags(cmd *cobra.Command) {
        cmd.PersistentFlags().SetAnnotation("source", cobra.BashCompSubdirsInDir, []string{})
        cmd.PersistentFlags().StringVarP(&cc.environment, "environment", "e", "", "build environment")
        cmd.PersistentFlags().StringP("themesDir", "", "", "filesystem path to themes directory")
-       cmd.PersistentFlags().BoolP("ignoreVendor", "", false, "ignores any _vendor directory")
        cmd.PersistentFlags().StringP("ignoreVendorPaths", "", "", "ignores any _vendor for module paths matching the given Glob pattern")
 }
 
index ef61dc7a5e7dab52178f1103e88fefd2dedf6329..9966cd93787a38519e08e9053b96be2b3409034b 100644 (file)
@@ -162,16 +162,6 @@ func TestFlags(t *testing.T) {
                args  []string
                check func(c *qt.C, cmd *serverCmd)
        }{
-               {
-                       // https://github.com/gohugoio/hugo/issues/7642
-                       name: "ignoreVendor as bool",
-                       args: []string{"server", "--ignoreVendor"},
-                       check: func(c *qt.C, cmd *serverCmd) {
-                               cfg := config.New()
-                               cmd.flagsToConfig(cfg)
-                               c.Assert(cfg.Get("ignoreVendor"), qt.Equals, true)
-                       },
-               },
                {
                        // https://github.com/gohugoio/hugo/issues/7642
                        name: "ignoreVendorPaths",
index e2bd4307fad1c80c9200af73e107bf2c3c193345..8c84423f5871f4925d31be7a2f1844d3f9a763fc 100644 (file)
@@ -142,7 +142,7 @@ func (cc *convertCmd) convertAndSavePage(p page.Page, site *hugolib.Site, target
                return nil
        }
 
-       errMsg := fmt.Errorf("Error processing file %q", p.Path())
+       errMsg := fmt.Errorf("Error processing file %q", p.File().Path())
 
        site.Log.Infoln("Attempting to convert", p.File().Filename())
 
@@ -185,10 +185,10 @@ func (cc *convertCmd) convertAndSavePage(p page.Page, site *hugolib.Site, target
        newFilename := p.File().Filename()
 
        if cc.outputDir != "" {
-               contentDir := strings.TrimSuffix(newFilename, p.Path())
+               contentDir := strings.TrimSuffix(newFilename, p.File().Path())
                contentDir = filepath.Base(contentDir)
 
-               newFilename = filepath.Join(cc.outputDir, contentDir, p.Path())
+               newFilename = filepath.Join(cc.outputDir, contentDir, p.File().Path())
        }
 
        fs := hugofs.Os
index d442a62b5045510c36b0d04d1911983bfba4332c..b954bf13cbf047d194919ec769ae8687e017a342 100644 (file)
@@ -199,7 +199,6 @@ func initializeFlags(cmd *cobra.Command, cfg config.Provider) {
                "forceSyncStatic",
                "noTimes",
                "noChmod",
-               "ignoreVendor",
                "ignoreVendorPaths",
                "templateMetrics",
                "templateMetricsHints",
@@ -281,7 +280,6 @@ func isTerminal() bool {
 }
 
 func (c *commandeer) fullBuild(noBuildLock bool) error {
-
        var (
                g         errgroup.Group
                langCount map[string]uint64
@@ -542,7 +540,6 @@ func (c *commandeer) build() error {
 }
 
 func (c *commandeer) serverBuild() error {
-
        stopProfiling, err := c.initProfiling()
        if err != nil {
                return err
@@ -739,7 +736,6 @@ func (c *commandeer) handleBuildErr(err error, msg string) {
 }
 
 func (c *commandeer) rebuildSites(events []fsnotify.Event) error {
-
        c.buildErr = nil
        visited := c.visitedURLs.PeekAllSet()
        if c.fastRenderMode {
index eb6b1a4404241df20de3022e8b89029e3091fd6e..44a48bf7913b2bc263b22ae08a44dda62e9f791a 100644 (file)
@@ -96,7 +96,7 @@ func (b *commandsBuilder) newModCmd() *modCmd {
 
        const commonUsage = `
 Note that Hugo will always start out by resolving the components defined in the site
-configuration, provided by a _vendor directory (if no --ignoreVendor flag provided),
+configuration, provided by a _vendor directory (if no --ignoreVendorPaths flag provided),
 Go Modules, or a folder inside the themes directory, in that order.
 
 See https://gohugo.io/hugo-modules/ for more information.
index aab199850b2cd381013e72a5d5b44c90085fc328..09b239c21a990ce48dbc75fff59a1d102692ff65 100644 (file)
@@ -40,7 +40,6 @@ var (
                "mdown", "markdown", "md",
                "asciidoc", "adoc", "ad",
                "rest", "rst",
-               "mmark",
                "org",
                "pandoc", "pdc",
        }
index e79899b94c0ba346c344c1970e0ef5c38c76e125..dffecd9a3df0420323a46a929c2d45d7be717e62 100644 (file)
@@ -53,7 +53,6 @@ var ErrNoConfigFile = errors.New("Unable to locate config file or config directo
 // LoadConfig loads Hugo configuration into a new Viper and then adds
 // a set of defaults.
 func LoadConfig(d ConfigSourceDescriptor, doWithConfig ...func(cfg config.Provider) error) (config.Provider, []string, error) {
-
        if d.Environment == "" {
                d.Environment = hugo.EnvironmentProduction
        }
@@ -110,15 +109,8 @@ func LoadConfig(d ConfigSourceDescriptor, doWithConfig ...func(cfg config.Provid
        }
 
        // Config deprecations.
-       // We made this a Glob pattern in Hugo 0.75, we don't need both.
-       if l.cfg.GetBool("ignoreVendor") {
-               helpers.Deprecated("--ignoreVendor", "Use --ignoreVendorPaths \"**\"", true)
-               l.cfg.Set("ignoreVendorPaths", "**")
-       }
-
        if l.cfg.GetString("markup.defaultMarkdownHandler") == "blackfriday" {
                helpers.Deprecated("markup.defaultMarkdownHandler=blackfriday", "See https://gohugo.io//content-management/formats/#list-of-content-formats", false)
-
        }
 
        // Some settings are used before we're done collecting all settings,
index 698c96cff7ac301630e2c4ebce645a4872bf3c01..228564351e345f53233ee4c030c681d238c8f47d 100644 (file)
@@ -403,7 +403,7 @@ func (m *pageMap) assembleResources(s string, p *pageState, parentBucket *pagesM
                        if err != nil {
                                return true
                        }
-                       rp.m.resourcePath = filepath.ToSlash(strings.TrimPrefix(rp.Path(), p.File().Dir()))
+                       rp.m.resourcePath = filepath.ToSlash(strings.TrimPrefix(rp.File().Path(), p.File().Dir()))
                        r = rp
 
                case files.ContentClassFile:
@@ -468,7 +468,6 @@ func (m *pageMap) assembleSections() error {
 
                kind := page.KindSection
                if s == "/" {
-
                        kind = page.KindHome
                }
 
@@ -580,7 +579,7 @@ func (m *pageMap) attachPageToViews(s string, b *contentNode) {
                w := getParamToLower(b.p, viewName.plural+"_weight")
                weight, err := cast.ToIntE(w)
                if err != nil {
-                       m.s.Log.Errorf("Unable to convert taxonomy weight %#v to int for %q", w, b.p.Path())
+                       m.s.Log.Errorf("Unable to convert taxonomy weight %#v to int for %q", w, b.p.Pathc())
                        // weight will equal zero, so let the flow continue
                }
 
index f35865cf0c999e772b2cb296fecffae4133a1528..d2d962044087147295f433fc77fe811d9d025289 100644 (file)
@@ -145,7 +145,7 @@ func (p *pageState) Eq(other interface{}) bool {
 }
 
 func (p *pageState) GetIdentity() identity.Identity {
-       return identity.NewPathIdentity(files.ComponentFolderContent, filepath.FromSlash(p.Path()))
+       return identity.NewPathIdentity(files.ComponentFolderContent, filepath.FromSlash(p.Pathc()))
 }
 
 func (p *pageState) GitInfo() *gitmap.GitInfo {
@@ -895,8 +895,8 @@ func (p *pageState) pathOrTitle() string {
                return p.File().Filename()
        }
 
-       if p.Path() != "" {
-               return p.Path()
+       if p.Pathc() != "" {
+               return p.Pathc()
        }
 
        return p.Title()
index 7bd9f6ac791814200f0a3921c2934fad04c05e0e..6a10b1d36a845bb024e041218bb0c67b4f4b9421 100644 (file)
@@ -232,6 +232,24 @@ func (p *pageMeta) Params() maps.Params {
 }
 
 func (p *pageMeta) Path() string {
+       if !p.File().IsZero() {
+               const example = `
+  {{ $path := "" }}
+  {{ with .File }}
+       {{ $path = .Path }}
+  {{ else }}
+       {{ $path = .Path }}
+  {{ end }}
+`
+               helpers.Deprecated(".Path when the page is backed by a file", "We plan to use Path for a canonical source path and you probably want to check the source is a file. To get the current behaviour, you can use a construct simlar to the below:\n"+example, false)
+
+       }
+
+       return p.Pathc()
+}
+
+// This is just a bridge method, use Path in templates.
+func (p *pageMeta) Pathc() string {
        if !p.File().IsZero() {
                return p.File().Path()
        }
@@ -759,7 +777,7 @@ func (p *pageMeta) newContentConverter(ps *pageState, markup string, renderingCo
                converter.DocumentContext{
                        Document:        newPageForRenderHook(ps),
                        DocumentID:      id,
-                       DocumentName:    p.Path(),
+                       DocumentName:    p.File().Path(),
                        Filename:        filename,
                        ConfigOverrides: renderingConfigOverrides,
                },
index dce4b8d2548642d1ebbe74411c3ba6b440f7d69f..bde8a2199a574e0e776d850609e87f18a616b110 100644 (file)
@@ -689,12 +689,6 @@ func (s *SiteInfo) AllRegularPages() page.Pages {
        return s.s.AllRegularPages()
 }
 
-func (s *SiteInfo) Permalinks() map[string]string {
-       // Remove in 0.61
-       helpers.Deprecated(".Site.Permalinks", "", true)
-       return s.permalinks
-}
-
 func (s *SiteInfo) LastChange() time.Time {
        return s.s.lastmod
 }
@@ -825,7 +819,7 @@ func (s siteRefLinker) logNotFound(ref, what string, p page.Page, position text.
        } else if p == nil {
                s.errorLogger.Printf("[%s] REF_NOT_FOUND: Ref %q: %s", s.s.Lang(), ref, what)
        } else {
-               s.errorLogger.Printf("[%s] REF_NOT_FOUND: Ref %q from page %q: %s", s.s.Lang(), ref, p.Path(), what)
+               s.errorLogger.Printf("[%s] REF_NOT_FOUND: Ref %q from page %q: %s", s.s.Lang(), ref, p.Pathc(), what)
        }
 }
 
@@ -1402,7 +1396,6 @@ func (s *Site) getMenusFromConfig() navigation.Menus {
                                        }
                                        s.Log.Errorf("unable to process menus in site config\n")
                                        s.Log.Errorln(err)
-
                                }
 
                                for _, entry := range m {
index e259911643f462b5a50c4cd56326980f7cee4847..73cea855a5f5da67469144ffdcc35acfca6bc087 100644 (file)
@@ -957,7 +957,7 @@ func TestRefLinking(t *testing.T) {
 func checkLinkCase(site *Site, link string, currentPage page.Page, relative bool, outputFormat string, expected string, t *testing.T, i int) {
        t.Helper()
        if out, err := site.refLink(link, currentPage, relative, outputFormat); err != nil || out != expected {
-               t.Fatalf("[%d] Expected %q from %q to resolve to %q, got %q - error: %s", i, link, currentPage.Path(), expected, out, err)
+               t.Fatalf("[%d] Expected %q from %q to resolve to %q, got %q - error: %s", i, link, currentPage.Pathc(), expected, out, err)
        }
 }
 
index 72e22ed1d8598d9876e199869f6a5647bd8f4460..105654c4f3015d1a4d329d535c41600048e75cee 100644 (file)
@@ -800,7 +800,6 @@ func (s *sitesBuilder) NpmInstall() hexec.Runner {
        command, err := ex.New("npm", "install")
        s.Assert(err, qt.IsNil)
        return command
-
 }
 
 func newTestHelper(cfg config.Provider, fs *hugofs.Fs, t testing.TB) testHelper {
@@ -998,7 +997,7 @@ func content(c resource.ContentProvider) string {
 func pagesToString(pages ...page.Page) string {
        var paths []string
        for _, p := range pages {
-               paths = append(paths, p.Path())
+               paths = append(paths, p.Pathc())
        }
        sort.Strings(paths)
        return strings.Join(paths, "|")
@@ -1020,7 +1019,7 @@ func dumpPages(pages ...page.Page) {
        fmt.Println("---------")
        for _, p := range pages {
                fmt.Printf("Kind: %s Title: %-10s RelPermalink: %-10s Path: %-10s sections: %s Lang: %s\n",
-                       p.Kind(), p.Title(), p.RelPermalink(), p.Path(), p.SectionsPath(), p.Lang())
+                       p.Kind(), p.Title(), p.RelPermalink(), p.Pathc(), p.SectionsPath(), p.Lang())
        }
 }
 
@@ -1028,7 +1027,7 @@ func dumpSPages(pages ...*pageState) {
        for i, p := range pages {
                fmt.Printf("%d: Kind: %s Title: %-10s RelPermalink: %-10s Path: %-10s sections: %s\n",
                        i+1,
-                       p.Kind(), p.Title(), p.RelPermalink(), p.Path(), p.SectionsPath())
+                       p.Kind(), p.Title(), p.RelPermalink(), p.Pathc(), p.SectionsPath())
        }
 }
 
index 5b61e5644329938a1759f71a79c3202954811548..17e149ecfb8379dc6734a9b259179746f236752c 100644 (file)
@@ -191,7 +191,7 @@ func (c *Client) Tidy() error {
 //
 // We, by default, use the /_vendor folder first, if found. To disable,
 // run with
-//    hugo --ignoreVendor
+//    hugo --ignoreVendorPaths=".*"
 //
 // Given a module tree, Hugo will pick the first module for a given path,
 // meaning that if the top-level module is vendored, that will be the full
index 0b402c4e78fc3a2e24db6049f2107df00db38f49..f23069a68de93e4b7a31025d0c3ee832aa5fca93 100644 (file)
@@ -180,6 +180,9 @@ type PageMetaProvider interface {
        // to the source of this Page. It will be relative to any content root.
        Path() string
 
+       // This is just a temporary bridge method. Use Path in templates.
+       Pathc() string
+
        // The slug, typically defined in front matter.
        Slug() string
 
@@ -392,5 +395,4 @@ type DeprecatedWarningPageMethods1 interface {
 
 // Move here to trigger ERROR instead of WARNING.
 // TODO(bep) create wrappers and put into the Page once it has some methods.
-type DeprecatedErrorPageMethods interface {
-}
+type DeprecatedErrorPageMethods interface{}
index 2286f1e633f31ea1e02670512ef03d9c2be93e74..6cfa411e21a049435b5d2e7e4cd1ed3f8a818946 100644 (file)
@@ -17,6 +17,9 @@ package page
 
 import (
        "encoding/json"
+       "html/template"
+       "time"
+
        "github.com/bep/gitmap"
        "github.com/gohugoio/hugo/common/maps"
        "github.com/gohugoio/hugo/config"
@@ -26,8 +29,6 @@ import (
        "github.com/gohugoio/hugo/media"
        "github.com/gohugoio/hugo/navigation"
        "github.com/gohugoio/hugo/source"
-       "html/template"
-       "time"
 )
 
 func MarshalPageToJSON(p Page) ([]byte, error) {
@@ -68,7 +69,7 @@ func MarshalPageToJSON(p Page) ([]byte, error) {
        linkTitle := p.LinkTitle()
        isNode := p.IsNode()
        isPage := p.IsPage()
-       path := p.Path()
+       path := p.Pathc()
        slug := p.Slug()
        lang := p.Lang()
        isSection := p.IsSection()
index 8e81f810d8413216c992c8655c5cd6e13c10d52c..0c4c2d0e29e5bfa10de0e377c40630e530da71ab 100644 (file)
@@ -59,7 +59,7 @@ func (m PageMatcher) Matches(p Page) bool {
        if m.Path != "" {
                g, err := glob.GetGlob(m.Path)
                // TODO(bep) Path() vs filepath vs leading slash.
-               p := strings.ToLower(filepath.ToSlash(p.Path()))
+               p := strings.ToLower(filepath.ToSlash(p.Pathc()))
                if !(strings.HasPrefix(p, "/")) {
                        p = "/" + p
                }
@@ -104,7 +104,6 @@ func DecodeCascade(in interface{}) (map[PageMatcher]maps.Params, error) {
        }
 
        return cascade, nil
-
 }
 
 // DecodePageMatcher decodes m into v.
index 4f91883a0b95ff8ae6c7b305bf9df9807119d29d..011fabfc05cdd10bcffc3b1c77dc55293e2bebcf 100644 (file)
@@ -338,6 +338,10 @@ func (p *nopPage) Path() string {
        return ""
 }
 
+func (p *nopPage) Pathc() string {
+       return ""
+}
+
 func (p *nopPage) Permalink() string {
        return ""
 }
index a21ab2ff30d1b0782be0dc1b964612b891eaf3f2..57077ecf8710e90a96933709113294bc17508e15 100644 (file)
@@ -414,6 +414,10 @@ func (p *testPage) Path() string {
        return p.path
 }
 
+func (p *testPage) Pathc() string {
+       return p.path
+}
+
 func (p *testPage) Permalink() string {
        panic("not implemented")
 }