From bbb11a4a0f9b4673ecba52d349e90db8c352e444 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Bj=C3=B8rn=20Erik=20Pedersen?= Date: Wed, 14 Sep 2016 18:51:34 +0200 Subject: [PATCH] Do not add lang prefix in URL when set in frontmatter Fixes #2450 --- hugolib/hugo_sites_test.go | 9 +++++++-- hugolib/page.go | 10 ++++++++++ 2 files changed, 17 insertions(+), 2 deletions(-) diff --git a/hugolib/hugo_sites_test.go b/hugolib/hugo_sites_test.go index 3b5bf1cf..52a3910a 100644 --- a/hugolib/hugo_sites_test.go +++ b/hugolib/hugo_sites_test.go @@ -211,10 +211,13 @@ func doTestMultiSitesBuild(t *testing.T, configContent, configSuffix string) { doc3 := enSite.Pages[2] permalink, err = doc3.Permalink() assert.NoError(t, err, "permalink call failed") + // Note that /superbob is a custom URL set in frontmatter. + // We respect that URL literally (it can be /search.json) + // and do no not do any language code prefixing. assert.Equal(t, "http://example.com/blog/superbob", permalink, "invalid doc3 permalink") - assert.Equal(t, "/en/superbob", doc3.URL(), "invalid url, was specified on doc3") - + assert.Equal(t, "/superbob", doc3.URL(), "invalid url, was specified on doc3") + assertFileContent(t, "public/superbob/index.html", true, "doc3|Hello|en") assert.Equal(t, doc2.Next, doc3, "doc3 should follow doc2, in .Next") doc1fr := doc1en.Translations()[0] @@ -230,6 +233,8 @@ func doTestMultiSitesBuild(t *testing.T, configContent, configSuffix string) { permalink, err = doc4.Permalink() assert.NoError(t, err, "permalink call failed") assert.Equal(t, "http://example.com/blog/fr/sect/doc4/", permalink, "invalid doc4 permalink") + assert.Equal(t, "/blog/fr/sect/doc4/", doc4.URL()) + assert.Len(t, doc4.Translations(), 0, "found translations for doc4") doc5 := enSite.AllPages[5] diff --git a/hugolib/page.go b/hugolib/page.go index a76c157b..fe4cd077 100644 --- a/hugolib/page.go +++ b/hugolib/page.go @@ -644,6 +644,16 @@ func (p *Page) Permalink() (string, error) { return link.String(), nil } +func (p *Page) URL() string { + if p.URLPath.URL != "" { + // This is the url set in front matter + return p.URLPath.URL + } + // Fall back to the relative permalink. + u, _ := p.RelPermalink() + return u +} + func (p *Page) RelPermalink() (string, error) { link, err := p.permalink() if err != nil { -- 2.30.2