Support non-md files as archetype files
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Tue, 20 Jun 2017 10:46:03 +0000 (12:46 +0200)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Tue, 20 Jun 2017 11:41:48 +0000 (13:41 +0200)
It now properly uses the extension of the target file to determine archetype file.

Fixes #3597
Fixes #3618

create/content.go
create/content_test.go
helpers/path.go

index e992b08364adffabcc95ea40a65129408f3eeb86..e584df73e065ad815167f3dd7aed1a0c12ac0c64 100644 (file)
@@ -30,10 +30,11 @@ import (
 func NewContent(
        ps *helpers.PathSpec,
        siteFactory func(filename string, siteUsed bool) (*hugolib.Site, error), kind, targetPath string) error {
+       ext := helpers.Ext(targetPath)
 
-       jww.INFO.Println("attempting to create ", targetPath, "of", kind)
+       jww.INFO.Printf("attempting to create %q of %q of ext %q", targetPath, kind, ext)
 
-       archetypeFilename := findArchetype(ps, kind)
+       archetypeFilename := findArchetype(ps, kind, ext)
 
        f, err := ps.Fs.Source.Open(archetypeFilename)
        if err != nil {
@@ -84,7 +85,7 @@ func NewContent(
 // FindArchetype takes a given kind/archetype of content and returns an output
 // path for that archetype.  If no archetype is found, an empty string is
 // returned.
-func findArchetype(ps *helpers.PathSpec, kind string) (outpath string) {
+func findArchetype(ps *helpers.PathSpec, kind, ext string) (outpath string) {
        search := []string{ps.AbsPathify(ps.Cfg.GetString("archetypeDir"))}
 
        if ps.Cfg.GetString("theme") != "" {
@@ -100,13 +101,16 @@ func findArchetype(ps *helpers.PathSpec, kind string) (outpath string) {
                // If the new content isn't in a subdirectory, kind == "".
                // Therefore it should be excluded otherwise `is a directory`
                // error will occur. github.com/gohugoio/hugo/issues/411
-               var pathsToCheck []string
+               var pathsToCheck = []string{"default"}
 
-               if kind == "" {
-                       pathsToCheck = []string{"default.md", "default"}
-               } else {
-                       pathsToCheck = []string{kind + ".md", kind, "default.md", "default"}
+               if ext != "" {
+                       if kind != "" {
+                               pathsToCheck = append([]string{kind + ext, "default" + ext}, pathsToCheck...)
+                       } else {
+                               pathsToCheck = append([]string{"default" + ext}, pathsToCheck...)
+                       }
                }
+
                for _, p := range pathsToCheck {
                        curpath := filepath.Join(x, p)
                        jww.DEBUG.Println("checking", curpath, "for archetypes")
index 8b6c2c12c5cbe629cb53a68761de5908f887cb68..e8857baf235d8185d52e9695165f47137b32f704 100644 (file)
@@ -44,6 +44,7 @@ func TestNewContent(t *testing.T) {
                expected []string
        }{
                {"post", "post/sample-1.md", []string{`title = "Post Arch title"`, `test = "test1"`, "date = \"2015-01-12T19:20:04-07:00\""}},
+               {"post", "post/org-1.org", []string{`#+title: ORG-1`}},
                {"emptydate", "post/sample-ed.md", []string{`title = "Empty Date Arch title"`, `test = "test1"`}},
                {"stump", "stump/sample-2.md", []string{`title = "Sample 2"`}},     // no archetype file
                {"", "sample-3.md", []string{`title = "Sample 3"`}},                // no archetype
@@ -111,6 +112,10 @@ func initFs(fs *hugofs.Fs) error {
                        path:    filepath.Join("archetypes", "post.md"),
                        content: "+++\ndate = \"2015-01-12T19:20:04-07:00\"\ntitle = \"Post Arch title\"\ntest = \"test1\"\n+++\n",
                },
+               {
+                       path:    filepath.Join("archetypes", "post.org"),
+                       content: "#+title: {{ .BaseFileName  | upper }}",
+               },
                {
                        path: filepath.Join("archetypes", "product.md"),
                        content: `+++
index 679740de9daa7d8e0c93a25051f192a013129545..640c97aa2fbdd55b457fe063d71b6a7a7f774961 100644 (file)
@@ -287,6 +287,12 @@ func GetDottedRelativePath(inPath string) string {
        return dottedPath
 }
 
+// Ext takes a path and returns the extension, including the delmiter, i.e. ".md".
+func Ext(in string) string {
+       _, ext := fileAndExt(in, fpb)
+       return ext
+}
+
 // Filename takes a path, strips out the extension,
 // and returns the name of the file.
 func Filename(in string) (name string) {