2017-06-24 19:30:01 +02:00
|
|
|
package config
|
|
|
|
|
|
|
|
import (
|
|
|
|
"path/filepath"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"github.com/osteele/gojekyll/helpers"
|
|
|
|
)
|
|
|
|
|
|
|
|
// IsMarkdown returns a boolean indicating whether the file is a Markdown file, according to the current project.
|
|
|
|
func (c *Config) IsMarkdown(name string) bool {
|
|
|
|
ext := filepath.Ext(name)
|
|
|
|
return c.markdownExtensions()[strings.TrimLeft(ext, ".")]
|
|
|
|
}
|
|
|
|
|
|
|
|
// IsSassPath returns a boolean indicating whether the file is a Sass (".sass" or ".scss") file.
|
|
|
|
func (c *Config) IsSassPath(name string) bool {
|
|
|
|
return strings.HasSuffix(name, ".sass") || strings.HasSuffix(name, ".scss")
|
|
|
|
}
|
|
|
|
|
2017-07-01 23:46:18 +02:00
|
|
|
// markdownExtensions returns a set of markdown extensions, without the initial dots.
|
2017-06-24 19:30:01 +02:00
|
|
|
func (c *Config) markdownExtensions() map[string]bool {
|
2017-07-01 23:46:18 +02:00
|
|
|
exts := strings.SplitN(c.MarkdownExt, `,`, -1)
|
|
|
|
return helpers.StringArrayToMap(exts)
|
|
|
|
}
|
|
|
|
|
|
|
|
// MarkdownExtensions returns a list of markdown extensions, with dotsa.
|
|
|
|
func (c *Config) MarkdownExtensions() []string {
|
|
|
|
exts := strings.SplitN(c.MarkdownExt, `,`, -1)
|
2017-07-02 02:49:15 +02:00
|
|
|
for i, k := range exts {
|
2017-07-01 23:46:18 +02:00
|
|
|
exts[i] = "." + k
|
|
|
|
}
|
|
|
|
return exts
|
2017-06-24 19:30:01 +02:00
|
|
|
}
|
|
|
|
|
2017-06-24 20:00:19 +02:00
|
|
|
// OutputExt returns the pathname's output extension. This is generally the pathname extension;
|
|
|
|
// exception are *.md -> *.html, and *.{sass,scss} -> *.css.
|
2017-06-24 19:30:01 +02:00
|
|
|
func (c *Config) OutputExt(pathname string) string {
|
|
|
|
switch {
|
|
|
|
case c.IsMarkdown(pathname):
|
|
|
|
return ".html"
|
|
|
|
case c.IsSassPath(pathname):
|
|
|
|
return ".css"
|
|
|
|
default:
|
|
|
|
return filepath.Ext(pathname)
|
|
|
|
}
|
|
|
|
}
|