Create a TargetPath() method that provides OutFile
Moved the generation of the target path to the page breaking all dependecies on Site.
This commit is contained in:
parent
52e8c7a0ac
commit
bffe4baf42
4 changed files with 34 additions and 44 deletions
|
@ -52,7 +52,7 @@ type Page struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
type File struct {
|
type File struct {
|
||||||
FileName, OutFile, Extension, Dir string
|
FileName, Extension, Dir string
|
||||||
}
|
}
|
||||||
|
|
||||||
type PageMeta struct {
|
type PageMeta struct {
|
||||||
|
@ -432,3 +432,27 @@ func (page *Page) convertRestructuredText(lines io.Reader) {
|
||||||
page.Summary = template.HTML(getRstContent(summary))
|
page.Summary = template.HTML(getRstContent(summary))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (p *Page) TargetPath() (outfile string) {
|
||||||
|
|
||||||
|
// Always use Url if it's specified
|
||||||
|
if len(strings.TrimSpace(p.Url)) > 2 {
|
||||||
|
outfile = strings.TrimSpace(p.Url)
|
||||||
|
|
||||||
|
if strings.HasSuffix(outfile, "/") {
|
||||||
|
outfile = outfile + "index.html"
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(strings.TrimSpace(p.Slug)) > 0 {
|
||||||
|
outfile = strings.TrimSpace(p.Slug) + "." + p.Extension
|
||||||
|
} else {
|
||||||
|
// Fall back to filename
|
||||||
|
_, t := path.Split(p.FileName)
|
||||||
|
outfile = replaceExtension(strings.TrimSpace(t), p.Extension)
|
||||||
|
}
|
||||||
|
|
||||||
|
return path.Join(p.Dir, strings.TrimSpace(outfile))
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,7 @@ func (s *Site) ShowPlan(out io.Writer) (err error) {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
trns, err := s.Target.Translate(p.OutFile)
|
trns, err := s.Target.Translate(p.TargetPath())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,7 +26,6 @@ import (
|
||||||
"html/template"
|
"html/template"
|
||||||
"io"
|
"io"
|
||||||
"os"
|
"os"
|
||||||
"path"
|
|
||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
@ -265,9 +264,6 @@ func (s *Site) CreatePages() (err error) {
|
||||||
page.Tmpl = s.Tmpl
|
page.Tmpl = s.Tmpl
|
||||||
page.Section = file.Section
|
page.Section = file.Section
|
||||||
page.Dir = file.Dir
|
page.Dir = file.Dir
|
||||||
if err = s.setUrlPath(page); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if s.Config.BuildDrafts || !page.Draft {
|
if s.Config.BuildDrafts || !page.Draft {
|
||||||
s.Pages = append(s.Pages, page)
|
s.Pages = append(s.Pages, page)
|
||||||
}
|
}
|
||||||
|
@ -277,34 +273,6 @@ func (s *Site) CreatePages() (err error) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set p.Section and p.OutFile relying on p.FileName as the source.
|
|
||||||
// Filename is broken apart for a "Section" which basically equates to
|
|
||||||
// the folder the file exists in.
|
|
||||||
func (s *Site) setUrlPath(p *Page) (err error) {
|
|
||||||
|
|
||||||
// Always use Url if it's specified
|
|
||||||
if len(strings.TrimSpace(p.Url)) > 2 {
|
|
||||||
p.OutFile = strings.TrimSpace(p.Url)
|
|
||||||
|
|
||||||
if strings.HasSuffix(p.OutFile, "/") {
|
|
||||||
p.OutFile = p.OutFile + "index.html"
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
var outfile string
|
|
||||||
if len(strings.TrimSpace(p.Slug)) > 0 {
|
|
||||||
outfile = strings.TrimSpace(p.Slug) + "." + p.Extension
|
|
||||||
} else {
|
|
||||||
// Fall back to filename
|
|
||||||
_, t := path.Split(p.FileName)
|
|
||||||
outfile = replaceExtension(strings.TrimSpace(t), p.Extension)
|
|
||||||
}
|
|
||||||
|
|
||||||
p.OutFile = p.Dir + "/" + strings.TrimSpace(outfile)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *Site) BuildSiteMeta() (err error) {
|
func (s *Site) BuildSiteMeta() (err error) {
|
||||||
s.Indexes = make(IndexList)
|
s.Indexes = make(IndexList)
|
||||||
s.Sections = make(Index)
|
s.Sections = make(Index)
|
||||||
|
@ -389,7 +357,7 @@ func (s *Site) RenderPages() (err error) {
|
||||||
var layout string
|
var layout string
|
||||||
|
|
||||||
if !p.IsRenderable() {
|
if !p.IsRenderable() {
|
||||||
layout = "__" + p.FileName
|
layout = "__" + p.TargetPath()
|
||||||
_, err := s.Tmpl.New(layout).Parse(string(p.Content))
|
_, err := s.Tmpl.New(layout).Parse(string(p.Content))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
|
@ -402,7 +370,7 @@ func (s *Site) RenderPages() (err error) {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
err = s.WritePublic(p.OutFile, content)
|
err = s.WritePublic(p.TargetPath(), content)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -514,6 +482,8 @@ func (s *Site) RenderLists() error {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Site) RenderHomePage() error {
|
func (s *Site) RenderHomePage() error {
|
||||||
|
return nil
|
||||||
|
|
||||||
n := s.NewNode()
|
n := s.NewNode()
|
||||||
n.Title = n.Site.Title
|
n.Title = n.Site.Title
|
||||||
n.Url = helpers.Urlize(string(n.Site.BaseUrl))
|
n.Url = helpers.Urlize(string(n.Site.BaseUrl))
|
||||||
|
|
|
@ -158,7 +158,7 @@ func TestRenderThingOrDefault(t *testing.T) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestSetOutFile(t *testing.T) {
|
func TestTargetPath(t *testing.T) {
|
||||||
tests := []struct {
|
tests := []struct {
|
||||||
doc string
|
doc string
|
||||||
content string
|
content string
|
||||||
|
@ -175,19 +175,15 @@ func TestSetOutFile(t *testing.T) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
var err error
|
|
||||||
s := &Site{
|
s := &Site{
|
||||||
Config: Config{ContentDir: "content"},
|
Config: Config{ContentDir: "content"},
|
||||||
}
|
}
|
||||||
p := pageMust(ReadFrom(strings.NewReader(test.content), s.Config.GetAbsPath(test.doc)))
|
p := pageMust(ReadFrom(strings.NewReader(test.content), s.Config.GetAbsPath(test.doc)))
|
||||||
if err = s.setUrlPath(p); err != nil {
|
|
||||||
t.Fatalf("Unable to set urlpath: %s", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
expected := test.expectedOutFile
|
expected := test.expectedOutFile
|
||||||
|
|
||||||
if p.OutFile != expected {
|
if p.TargetPath() != expected {
|
||||||
t.Errorf("%s => p.OutFile expected: '%s', got: '%s'", test.doc, expected, p.OutFile)
|
t.Errorf("%s => OutFile expected: '%s', got: '%s'", test.doc, expected, p.TargetPath())
|
||||||
}
|
}
|
||||||
|
|
||||||
if p.Section != test.expectedSection {
|
if p.Section != test.expectedSection {
|
||||||
|
@ -240,7 +236,7 @@ func TestSkipRender(t *testing.T) {
|
||||||
{"sect/doc3.html", "<html><head></head><body><h1>doc3</h1>\n\n<p><em>some</em> content</p>\n</body></html>"},
|
{"sect/doc3.html", "<html><head></head><body><h1>doc3</h1>\n\n<p><em>some</em> content</p>\n</body></html>"},
|
||||||
{"sect/doc4.html", "<html><head></head><body><h1>doc4</h1>\n\n<p><em>some content</em></p>\n</body></html>"},
|
{"sect/doc4.html", "<html><head></head><body><h1>doc4</h1>\n\n<p><em>some content</em></p>\n</body></html>"},
|
||||||
{"sect/doc5.html", "<!DOCTYPE html><html><head><script src=\"http://auth/bub/script.js\"></script></head><body>body5</body></html>"},
|
{"sect/doc5.html", "<!DOCTYPE html><html><head><script src=\"http://auth/bub/script.js\"></script></head><body>body5</body></html>"},
|
||||||
{"./doc7.html", "<html><head></head><body>doc7 content</body></html>"},
|
{"doc7.html", "<html><head></head><body>doc7 content</body></html>"},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
|
|
Loading…
Add table
Reference in a new issue