Removing check for directory: static, layouts
authorNoah Campbell <noahcampbell@gmail.com>
Thu, 31 Oct 2013 22:46:55 +0000 (15:46 -0700)
committerNoah Campbell <noahcampbell@gmail.com>
Thu, 31 Oct 2013 23:06:24 +0000 (16:06 -0700)
Removed these checks so a single file in content can generate a site.

For example, given a site with a content directory and an index.html,
running hugo -s dir will generate a project without any more input.

commands/hugo.go
hugolib/site.go

index 935328b73dafa42d6d2beb061275c8e31449901b..83b3334a7e2184f0bd60fecd12247d32f276bc75 100644 (file)
@@ -100,6 +100,11 @@ func build(watches ...bool) {
 }
 
 func copyStatic() error {
+       staticDir := Config.GetAbsPath(Config.StaticDir + "/")
+       if _, err := os.Stat(staticDir); os.IsNotExist(err) {
+               return nil
+       }
+
        // Copy Static to Destination
        return fsync.Sync(Config.GetAbsPath(Config.PublishDir+"/"), Config.GetAbsPath(Config.StaticDir+"/"))
 }
index eda44fb1c304b11cecabdf19ff9473a78b185e05..05561f85ca20287c0ce3140d49f335c379ec4e19 100644 (file)
@@ -132,11 +132,13 @@ func (s *Site) addTemplate(name, data string) error {
 }
 
 func (s *Site) Process() (err error) {
-       s.initialize()
+       if err = s.initialize(); err != nil {
+               return
+       }
        s.prepTemplates()
        s.timerStep("initialize & template prep")
        if err = s.CreatePages(); err != nil {
-               return err
+               return
        }
        s.setupPrevNext()
        s.timerStep("import pages")
@@ -248,9 +250,11 @@ func (s *Site) absPublishDir() string {
 }
 
 func (s *Site) checkDirectories() (err error) {
-       if b, _ := dirExists(s.absLayoutDir()); !b {
-               return fmt.Errorf("No layout directory found, expecting to find it at " + s.absLayoutDir())
-       }
+       /*
+               if b, _ := dirExists(s.absLayoutDir()); !b {
+                       return fmt.Errorf("No layout directory found, expecting to find it at " + s.absLayoutDir())
+               }
+       */
        if b, _ := dirExists(s.absContentDir()); !b {
                return fmt.Errorf("No source directory found, expecting to find it at " + s.absContentDir())
        }
@@ -266,10 +270,10 @@ func (s *Site) ProcessShortcodes() {
 
 func (s *Site) CreatePages() (err error) {
        if s.Source == nil {
-               return fmt.Errorf("No source files found in", s.absContentDir())
+               panic(fmt.Sprintf("s.Source not set %s", s.absContentDir()))
        }
        if len(s.Source.Files()) < 1 {
-               return fmt.Errorf("No source files found in", s.absContentDir())
+               return fmt.Errorf("No source files found in %s", s.absContentDir())
        }
        for _, file := range s.Source.Files() {
                page, err := ReadFrom(file.Contents, file.LogicalName)