Move isThemeVsHugoVersionMismatch to /commands
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Mon, 14 Sep 2015 15:31:39 +0000 (17:31 +0200)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Mon, 14 Sep 2015 15:31:39 +0000 (17:31 +0200)
To prevent potential package cycles in /helpers.

commands/hugo.go
helpers/hugo.go

index 725591008348f1e881e7b5288e1a1a8646a4a672..8048174784d968a4de7619a8ac862738f165e260 100644 (file)
@@ -17,6 +17,8 @@ package commands
 
 import (
        "fmt"
+       "github.com/spf13/hugo/parser"
+       "io/ioutil"
        "net/http"
        "os"
        "path/filepath"
@@ -292,7 +294,7 @@ func InitializeConfig() {
                }
        }
 
-       themeVersionMismatch, minVersion := helpers.IsThemeVsHugoVersionMismatch()
+       themeVersionMismatch, minVersion := isThemeVsHugoVersionMismatch()
 
        if themeVersionMismatch {
                jww.ERROR.Printf("Current theme does not support Hugo version %s. Minimum version required is %s\n",
@@ -535,3 +537,57 @@ func NewWatcher(port int) error {
        wg.Wait()
        return nil
 }
+
+// isThemeVsHugoVersionMismatch returns whether the current Hugo version is < theme's min_version
+func isThemeVsHugoVersionMismatch() (mismatch bool, requiredMinVersion string) {
+       if !helpers.ThemeSet() {
+               return
+       }
+
+       themeDir := helpers.GetThemeDir()
+
+       fs := hugofs.SourceFs
+       path := filepath.Join(themeDir, "theme.toml")
+
+       exists, err := helpers.Exists(path, fs)
+
+       if err != nil || !exists {
+               return
+       }
+
+       f, err := fs.Open(path)
+
+       if err != nil {
+               return
+       }
+
+       defer f.Close()
+
+       b, err := ioutil.ReadAll(f)
+
+       if err != nil {
+               return
+       }
+
+       c, err := parser.HandleTOMLMetaData(b)
+
+       if err != nil {
+               return
+       }
+
+       config := c.(map[string]interface{})
+
+       if minVersion, ok := config["min_version"]; ok {
+               switch minVersion.(type) {
+               case float32:
+                       return helpers.HugoVersionNumber < minVersion.(float32), fmt.Sprint(minVersion)
+               case float64:
+                       return helpers.HugoVersionNumber < minVersion.(float64), fmt.Sprint(minVersion)
+               default:
+                       return
+               }
+
+       }
+
+       return
+}
index 35466a7dcc742d44e168d2ebfca9934819faec54..2e48ff5c9b7ebb2fe5a7ceb81256605c5d1e78de 100644 (file)
@@ -15,31 +15,26 @@ package helpers
 
 import (
        "fmt"
-       "io/ioutil"
-       "path/filepath"
-
-       "github.com/spf13/hugo/hugofs"
-       "github.com/spf13/hugo/parser"
 )
 
 // this should be the only one
-const hugoVersionMain = 0.15
-const hugoVersionSuffix = "-DEV" // blank this when doing a release
+const HugoVersionNumber = 0.15
+const HugoVersionSuffix = "-DEV" // blank this when doing a release
 
 // HugoVersion returns the current Hugo version. It will include
 // a suffix, typically '-DEV', if it's development version.
 func HugoVersion() string {
-       return hugoVersion(hugoVersionMain, hugoVersionSuffix)
+       return hugoVersion(HugoVersionNumber, HugoVersionSuffix)
 }
 
 // HugoReleaseVersion is same as HugoVersion, but no suffix.
 func HugoReleaseVersion() string {
-       return hugoVersionNoSuffix(hugoVersionMain)
+       return hugoVersionNoSuffix(HugoVersionNumber)
 }
 
 // NextHugoReleaseVersion returns the next Hugo release version.
 func NextHugoReleaseVersion() string {
-       return hugoVersionNoSuffix(hugoVersionMain + 0.01)
+       return hugoVersionNoSuffix(HugoVersionNumber + 0.01)
 }
 
 func hugoVersion(version float32, suffix string) string {
@@ -49,61 +44,3 @@ func hugoVersion(version float32, suffix string) string {
 func hugoVersionNoSuffix(version float32) string {
        return fmt.Sprintf("%.2g", version)
 }
-
-// IsThemeVsHugoVersionMismatch returns whether the current Hugo version is < theme's min_version
-func IsThemeVsHugoVersionMismatch() (mismatch bool, requiredMinVersion string) {
-       if !ThemeSet() {
-               return
-       }
-
-       themeDir, err := getThemeDirPath("")
-
-       if err != nil {
-               return
-       }
-
-       fs := hugofs.SourceFs
-       path := filepath.Join(themeDir, "theme.toml")
-
-       exists, err := Exists(path, fs)
-
-       if err != nil || !exists {
-               return
-       }
-
-       f, err := fs.Open(path)
-
-       if err != nil {
-               return
-       }
-
-       defer f.Close()
-
-       b, err := ioutil.ReadAll(f)
-
-       if err != nil {
-               return
-       }
-
-       c, err := parser.HandleTOMLMetaData(b)
-
-       if err != nil {
-               return
-       }
-
-       config := c.(map[string]interface{})
-
-       if minVersion, ok := config["min_version"]; ok {
-               switch minVersion.(type) {
-               case float32:
-                       return hugoVersionMain < minVersion.(float32), fmt.Sprint(minVersion)
-               case float64:
-                       return hugoVersionMain < minVersion.(float64), fmt.Sprint(minVersion)
-               default:
-                       return
-               }
-
-       }
-
-       return
-}