From be0d9770095a6497a69a610783a5710982591084 Mon Sep 17 00:00:00 2001 From: bep Date: Thu, 16 Apr 2015 02:27:37 +0200 Subject: [PATCH] Only write highlight to cache when CacheDir is set To avoid writing cache files when testing. --- helpers/pygments.go | 45 ++++++++++++++++++++++++++------------------- 1 file changed, 26 insertions(+), 19 deletions(-) diff --git a/helpers/pygments.go b/helpers/pygments.go index 74327c6f..11b0f23d 100644 --- a/helpers/pygments.go +++ b/helpers/pygments.go @@ -60,29 +60,34 @@ func Highlight(code, lang, optsStr string) string { io.WriteString(hash, lang) io.WriteString(hash, options) - cachefile := filepath.Join(viper.GetString("CacheDir"), fmt.Sprintf("pygments-%x", hash.Sum(nil))) - fs := hugofs.OsFs - exists, err := Exists(cachefile, fs) - if err != nil { - jww.ERROR.Print(err.Error()) - return code - } - if exists { - f, err := fs.Open(cachefile) - if err != nil { - jww.ERROR.Print(err.Error()) - return code - } + cacheDir := viper.GetString("CacheDir") + var cachefile string - s, err := ioutil.ReadAll(f) + if cacheDir != "" { + cachefile = filepath.Join(cacheDir, fmt.Sprintf("pygments-%x", hash.Sum(nil))) + + exists, err := Exists(cachefile, fs) if err != nil { jww.ERROR.Print(err.Error()) return code } - - return string(s) + if exists { + f, err := fs.Open(cachefile) + if err != nil { + jww.ERROR.Print(err.Error()) + return code + } + + s, err := ioutil.ReadAll(f) + if err != nil { + jww.ERROR.Print(err.Error()) + return code + } + + return string(s) + } } // No cache file, render and cache it @@ -99,9 +104,11 @@ func Highlight(code, lang, optsStr string) string { return code } - // Write cache file - if err := WriteToDisk(cachefile, bytes.NewReader(out.Bytes()), fs); err != nil { - jww.ERROR.Print(stderr.String()) + if cachefile != "" { + // Write cache file + if err := WriteToDisk(cachefile, bytes.NewReader(out.Bytes()), fs); err != nil { + jww.ERROR.Print(stderr.String()) + } } return out.String() -- 2.30.2