mirror of
https://github.com/danog/gojekyll.git
synced 2025-01-23 10:21:12 +01:00
39 lines
1.1 KiB
Go
39 lines
1.1 KiB
Go
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")
|
|
}
|
|
|
|
// MarkdownExtensions returns a set of markdown extensions, without the initial dots.
|
|
func (c *Config) markdownExtensions() map[string]bool {
|
|
extns := strings.SplitN(c.MarkdownExt, `,`, -1)
|
|
return helpers.StringArrayToMap(extns)
|
|
}
|
|
|
|
// OutputExt returns the pathname's output extension. This is generally the pathname extension;
|
|
// exception are *.md -> *.html, and *.{sass,scss} -> *.css.
|
|
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)
|
|
}
|
|
}
|