mirror of
https://github.com/gohugoio/hugo.git
synced 2025-01-09 14:31:11 +00:00
Support index.html indexes in content directory
If a file named index.html exists in a directory, or root, it will be rendered as if ugly urls are turned on. This allows for top level content to not need a supporting layout file and content in content. This change should not affect anyone who is using the perscribed way. I also cleaned up a bunch of one off functions in site.go.
This commit is contained in:
parent
4250bf8e30
commit
db50154e75
4 changed files with 49 additions and 28 deletions
|
@ -30,6 +30,7 @@ import (
|
||||||
"sort"
|
"sort"
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
"net/url"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Page struct {
|
type Page struct {
|
||||||
|
@ -191,7 +192,7 @@ func (p *Page) analyzePage() {
|
||||||
p.FuzzyWordCount = int((p.WordCount+100)/100) * 100
|
p.FuzzyWordCount = int((p.WordCount+100)/100) * 100
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Page) Permalink() template.HTML {
|
func (p *Page) Permalink() (string, error) {
|
||||||
baseUrl := string(p.Site.BaseUrl)
|
baseUrl := string(p.Site.BaseUrl)
|
||||||
section := strings.TrimSpace(p.Section)
|
section := strings.TrimSpace(p.Section)
|
||||||
pSlug := strings.TrimSpace(p.Slug)
|
pSlug := strings.TrimSpace(p.Slug)
|
||||||
|
@ -215,7 +216,18 @@ func (p *Page) Permalink() template.HTML {
|
||||||
permalink = section + "/" + file
|
permalink = section + "/" + file
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return template.HTML(MakePermalink(baseUrl, permalink))
|
|
||||||
|
base, err := url.Parse(baseUrl)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
path, err := url.Parse(permalink)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
|
||||||
|
return MakePermalink(base, path).String(), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (page *Page) handleTomlMetaData(datum []byte) (interface{}, error) {
|
func (page *Page) handleTomlMetaData(datum []byte) (interface{}, error) {
|
||||||
|
|
|
@ -28,21 +28,13 @@ import (
|
||||||
"os"
|
"os"
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
"net/url"
|
||||||
)
|
)
|
||||||
|
|
||||||
var DefaultTimer = nitro.Initalize()
|
var DefaultTimer = nitro.Initalize()
|
||||||
|
|
||||||
func MakePermalink(domain string, path string) string {
|
func MakePermalink(base *url.URL, path *url.URL) (*url.URL) {
|
||||||
return strings.TrimRight(domain, "/") + "/" + strings.TrimLeft(path, "/")
|
return base.ResolveReference(path)
|
||||||
}
|
|
||||||
|
|
||||||
func FatalErr(str string) {
|
|
||||||
fmt.Println(str)
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
|
|
||||||
func PrintErr(str string, a ...interface{}) {
|
|
||||||
fmt.Fprintln(os.Stderr, str, a)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Site contains all the information relevent for constructing a static
|
// Site contains all the information relevent for constructing a static
|
||||||
|
@ -86,10 +78,6 @@ type SiteInfo struct {
|
||||||
Config *Config
|
Config *Config
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Site) getFromIndex(kind string, name string) Pages {
|
|
||||||
return s.Indexes[kind][name]
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *Site) timerStep(step string) {
|
func (s *Site) timerStep(step string) {
|
||||||
if s.timer == nil {
|
if s.timer == nil {
|
||||||
s.timer = DefaultTimer
|
s.timer = DefaultTimer
|
||||||
|
@ -191,8 +179,10 @@ func (s *Site) checkDescriptions() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Site) initialize() {
|
func (s *Site) initialize() (err error) {
|
||||||
s.checkDirectories()
|
if err = s.checkDirectories(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
staticDir := s.Config.GetAbsPath(s.Config.StaticDir + "/")
|
staticDir := s.Config.GetAbsPath(s.Config.StaticDir + "/")
|
||||||
|
|
||||||
|
@ -204,6 +194,7 @@ func (s *Site) initialize() {
|
||||||
s.initializeSiteInfo()
|
s.initializeSiteInfo()
|
||||||
|
|
||||||
s.Shortcodes = make(map[string]ShortcodeFunc)
|
s.Shortcodes = make(map[string]ShortcodeFunc)
|
||||||
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Site) initializeSiteInfo() {
|
func (s *Site) initializeSiteInfo() {
|
||||||
|
@ -239,13 +230,14 @@ func (s *Site) absPublishDir() string {
|
||||||
return s.Config.GetAbsPath(s.Config.PublishDir)
|
return s.Config.GetAbsPath(s.Config.PublishDir)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Site) checkDirectories() {
|
func (s *Site) checkDirectories() (err error) {
|
||||||
if b, _ := dirExists(s.absLayoutDir()); !b {
|
if b, _ := dirExists(s.absLayoutDir()); !b {
|
||||||
FatalErr("No layout directory found, expecting to find it at " + s.absLayoutDir())
|
return fmt.Errorf("No layout directory found, expecting to find it at " + s.absLayoutDir())
|
||||||
}
|
}
|
||||||
if b, _ := dirExists(s.absContentDir()); !b {
|
if b, _ := dirExists(s.absContentDir()); !b {
|
||||||
FatalErr("No source directory found, expecting to find it at " + s.absContentDir())
|
return fmt.Errorf("No source directory found, expecting to find it at " + s.absContentDir())
|
||||||
}
|
}
|
||||||
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Site) ProcessShortcodes() {
|
func (s *Site) ProcessShortcodes() {
|
||||||
|
@ -289,7 +281,9 @@ func (s *Site) BuildSiteMeta() (err error) {
|
||||||
s.Indexes[plural].Add(idx, p)
|
s.Indexes[plural].Add(idx, p)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
PrintErr("Invalid " + plural + " in " + p.File.FileName)
|
if s.Config.Verbose {
|
||||||
|
fmt.Fprintf(os.Stderr, "Invalid %s in %s\n", plural, p.File.FileName)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -344,7 +338,11 @@ func inStringArray(arr []string, el string) bool {
|
||||||
func (s *Site) RenderAliases() error {
|
func (s *Site) RenderAliases() error {
|
||||||
for _, p := range s.Pages {
|
for _, p := range s.Pages {
|
||||||
for _, a := range p.Aliases {
|
for _, a := range p.Aliases {
|
||||||
if err := s.WriteAlias(a, p.Permalink()); err != nil {
|
plink, err := p.Permalink()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if err := s.WriteAlias(a, template.HTML(plink)); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -538,8 +536,18 @@ func (s *Site) Stats() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func permalink(s *Site, plink string) template.HTML {
|
func permalink(s *Site, plink string) (template.HTML) {
|
||||||
return template.HTML(MakePermalink(string(s.Info.BaseUrl), plink))
|
base, err := url.Parse(string(s.Config.BaseUrl))
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
path, err := url.Parse(plink)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return template.HTML(MakePermalink(base, path).String())
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Site) NewNode() *Node {
|
func (s *Site) NewNode() *Node {
|
||||||
|
|
|
@ -73,7 +73,7 @@ func (fs *Filesystem) Translate(src string) (dest string, err error) {
|
||||||
dir = path.Join(fs.PublishDir, dir)
|
dir = path.Join(fs.PublishDir, dir)
|
||||||
}
|
}
|
||||||
|
|
||||||
if fs.UglyUrls {
|
if fs.UglyUrls || file == "index.html" {
|
||||||
return path.Join(dir, fmt.Sprintf("%s%s", name, ext)), nil
|
return path.Join(dir, fmt.Sprintf("%s%s", name, ext)), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -10,7 +10,8 @@ func TestFileTranslator(t *testing.T) {
|
||||||
expected string
|
expected string
|
||||||
}{
|
}{
|
||||||
{"/", "index.html"},
|
{"/", "index.html"},
|
||||||
{"index.html", "index/index.html"},
|
{"index.html", "index.html"},
|
||||||
|
{"bar/index.html", "bar/index.html"},
|
||||||
{"foo", "foo/index.html"},
|
{"foo", "foo/index.html"},
|
||||||
{"foo.html", "foo/index.html"},
|
{"foo.html", "foo/index.html"},
|
||||||
{"foo.xhtml", "foo/index.xhtml"},
|
{"foo.xhtml", "foo/index.xhtml"},
|
||||||
|
|
Loading…
Reference in a new issue