Documentation ¶
Index ¶
- func ExtractGitBranch(conf *DarknessConfig) (string, error)
- func ExtractGitLastModified(conf *DarknessConfig, path yunyun.RelativePathFile) (time.Time, error)
- func ExtractGitRemote(conf *DarknessConfig) (string, string, error)
- type AuthorConfig
- type DarknessConfig
- type ExternalConfig
- type NavigationConfig
- type Options
- type ProjectConfig
- type RSSConfig
- type RuntimeConfig
- func (conf RuntimeConfig) Join(relative ...yunyun.RelativePathFile) yunyun.FullPathFile
- func (conf RuntimeConfig) JoinDir(relative ...yunyun.RelativePathDir) yunyun.FullPathFile
- func (conf RuntimeConfig) JoinGeneric(what ...string) string
- func (conf RuntimeConfig) Rel(filename yunyun.FullPathFile) yunyun.RelativePathFile
- type WebsiteConfig
- type WorkingDirectory
- func (workDir WorkingDirectory) Join(target yunyun.RelativePathFile) yunyun.FullPathFile
- func (workDir WorkingDirectory) JoinGeneric(target string) string
- func (workDir WorkingDirectory) PackRel(filename yunyun.FullPathFile, data string) (yunyun.RelativePathFile, string)
- func (workDir WorkingDirectory) PackRelRef(filename *yunyun.FullPathFile, data *string) (yunyun.RelativePathFile, string)
- func (workDir WorkingDirectory) Rel(filename yunyun.FullPathFile) yunyun.RelativePathFile
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func ExtractGitBranch ¶ added in v3.1.0
func ExtractGitBranch(conf *DarknessConfig) (string, error)
ExtractGitBranch extracts the current working git branch.
func ExtractGitLastModified ¶ added in v3.1.0
func ExtractGitLastModified(conf *DarknessConfig, path yunyun.RelativePathFile) (time.Time, error)
ExtractGitLastModified will give the git date of when the file was last modified.
func ExtractGitRemote ¶ added in v3.1.0
func ExtractGitRemote(conf *DarknessConfig) (string, string, error)
ExtractGitRemote gets the remote and path, like github.com and thecsw/repo.
Types ¶
type AuthorConfig ¶
type AuthorConfig struct { // AuthorImage is the header image (can be empty) Image yunyun.RelativePathFile `toml:"image"` // ImagePreComputed is what actually gets stubbed in. ImagePreComputed yunyun.FullPathFile `toml:"-"` // Name is the name of the author Name string `toml:"name"` // Email is the email of the author Email string `toml:"email"` // NameEnable will not show the name in the menu // if disabled, but will use it for metadata. NameEnable bool `toml:"name_enable"` // EmailEnable will hide the email if false. EmailEnable bool `toml:"email_enable"` }
AuthorConfig is the author section of the config
type DarknessConfig ¶
type DarknessConfig struct { string]NavigationConfig `toml:"navigation"` // Title is the title of the site. Title string `toml:"title"` // Url is the Url of the site. Url string `toml:"url"` // RSS is the rss config. RSS RSSConfig `toml:"rss"` // Author is the author section of the config. Author AuthorConfig `toml:"author"` // Project is the project section of the config. Project ProjectConfig `toml:"project"` // Website is the website section of the config. Website WebsiteConfig `toml:"website"` // Runtime holds the state we use during the runtime. Runtime RuntimeConfig `toml:"-"` // External is config for external services. External ExternalConfig `toml:"external"` }Navigation map[
DarknessConfig is the global darkness config.
func BuildConfig ¶
func BuildConfig(options Options) *DarknessConfig
BuildConfig builds the config from the passed options.
type ExternalConfig ¶ added in v3.1.0
type ExternalConfig struct { // SearchEngines is the list of search engines to notify of // new and refreshed content. SearchEngines []string `toml:"search_engines"` // GitRemoteService would be like github.com and // GitRemotePath would be thecsw/whatever. GitRemoteService string `toml:"git_remote_service"` GitRemotePath string `toml:"git_remote_path"` GitBranch string `toml:"git_branch"` GitRemotesAreValid bool `toml:"-"` }
ExternalConfig is config for external services.
type NavigationConfig ¶
type NavigationConfig struct { yunyun.RelativePathDir `toml:"link"` Title string `toml:"title"` Hide yunyun.RelativePathDir `toml:"hide"` HideIf yunyun.RelativePathDir `toml:"hide_if"` }Link
NavigationConfig is the navigation section of the config
type Options ¶
type Options struct { // DarknessConfig is the location of darkness's toml config file. DarknessConfig string // Url is a custom website url, usually used for serving from localhost. Url string // OutputExtension overrides whatever is in the file. OutputExtension string // WorkDir is the working directory of the darkness project. WorkDir string // Dev enables Url generation through local paths. Dev bool // Test enables test environment, where darkness config is not needed. Test bool // VendorGalleries dictates whether we should stub in local gallery images. VendorGalleries bool }
Options is used for passing options when initiating emilia.
type ProjectConfig ¶
type ProjectConfig struct { ExcludeRegex *regexp.Regexp `toml:"-"` // Input is the input format (default ".org") Input string `toml:"input"` // Output is the output format (defaulte ".html") Output string `toml:"output"` // DarknessVendorDirectory where to vendor, default to `darkness_vendor`. DarknessVendorDirectory yunyun.RelativePathDir `toml:"vendor_directory"` // DarknessPreviewDirectory where to store previews, default to `darkness_preview`. DarknessPreviewDirectory yunyun.RelativePathDir `toml:"preview_directory"` // Excludes is the list of relative paths to exclude from the project Exclude []yunyun.RelativePathDir `toml:"exclude"` ExcludeEnabled bool `toml:"-"` }
ProjectConfig is the project section of the config
func (ProjectConfig) InputFilenameToOutput ¶
func (p ProjectConfig) InputFilenameToOutput(file yunyun.FullPathFile) string
InputFilenameToOutput converts input filename to the filename to write.
type RSSConfig ¶
type RSSConfig struct { // The language the channel is written in. This allows // aggregators to group all Italian language sites, for // example, on a single page. A list of allowable values // for this element, as provided by Netscape, is here. // You may also use values defined by the W3C. // // Example: "en-us" Language string `toml:"language"` // Phrase or sentence describing the channel. // // The latest news from GoUpstate.com, a Spartanburg // Herald-Journal Web site. Description string `toml:"description"` // Copyright notice for content in the channel. // // Example: "Copyright 2002, Spartanburg Herald-Journal" Copyright string `toml:"copyright"` // Email address for person responsible for editorial content. // // Example: "geo@herald.com (George Matesky)" ManagingEditor string `toml:"managing_editor"` // DefaultAuthor name to use for posts. Overwritten by posts' // author directives. // // Example: "Sandy Urazayev" DefaultAuthor string `toml:"default_author"` // Email address for person responsible for technical issues // relating to channel. // // Example: "betty@herald.com (Betty Guernsey)" WebMaster string `toml:"web_master"` // Specify one or more categories that the channel belongs to. // Follows the same rules as the <item>-level category element. // // Example: "<category>Newspapers</category>" Category string `toml:"category"` // If true, darkness will add the rss icon to the menu. Enable bool `toml:"enable"` // Timezone sets the default timezone for RSS timestamps. Timezone string `toml:"timezone"` // DefaultHour defines the hour value in RSS timestamp if one // is not provided. Use the 24 hrs. DefaultHour int `toml:"default_hour"` }
RSSConfig is for filling out rss stuff.
type RuntimeConfig ¶
type RuntimeConfig struct { // WorkDir is the directory of where darkness project lives. WorkDir WorkingDirectory // UrlPath is the parsed Url of the site UrlPath *url.URL // VendorGalleries tells us if we need to stub local copies // of remote links in galleries. VendorGalleries bool // HtmlHighlightLanguages is a map of languages that we want to // highlight in HTML. HtmlHighlightLanguages map[string]struct{} // Logger is the logger that we use. Logger *l.Logger // contains filtered or unexported fields }
RuntimeConfig the config that is not a part of the config file, but us building when processing stuff.
func (RuntimeConfig) Join ¶
func (conf RuntimeConfig) Join(relative ...yunyun.RelativePathFile) yunyun.FullPathFile
Join joins the target path with the final root path (url or local).
func (RuntimeConfig) JoinDir ¶ added in v3.1.0
func (conf RuntimeConfig) JoinDir(relative ...yunyun.RelativePathDir) yunyun.FullPathFile
Join joins the target path with the final root path (url or local).
func (RuntimeConfig) JoinGeneric ¶
func (conf RuntimeConfig) JoinGeneric(what ...string) string
JoinGeneric joins the target path with the final root path (url or local).
func (RuntimeConfig) Rel ¶
func (conf RuntimeConfig) Rel(filename yunyun.FullPathFile) yunyun.RelativePathFile
Rel returns path trimmed by the workspace or url.
type WebsiteConfig ¶
type WebsiteConfig struct { // SyntaxHighlightingLanguages is the location of highlight.js languages SyntaxHighlightingLanguages yunyun.RelativePathDir `toml:"syntax_highlighting_languages"` // Color is the color of the site Color string `toml:"color"` // Twitter is the twitter handle of the site Twitter string `toml:"twitter"` // Preview is the filename of the picture in the // same directory to use as a page preview. defaults to preview.png Preview yunyun.RelativePathFile `toml:"preview"` // Locale is the locale of the site Locale string `toml:"locale"` // SyntaxHighlightingTheme decides what theme to use from highlight.js SyntaxHighlightingTheme yunyun.RelativePathFile `toml:"syntax_highlighting_theme"` // Styles is the list of relative paths to css files for the site Styles []yunyun.RelativePathFile `toml:"styles"` // Tombs is the list of relative paths where to include the tombstones Tombs []yunyun.RelativePathDir `toml:"tombs"` // ExtraHead is the list of html directives to insert in <head> ExtraHead []string `toml:"extra_head"` // Description length dictates on how many characters do we extract // from the page to show in the web prewies, like OpenGraph and Twitter DescriptionLength int `toml:"description_length"` // SyntaxHighlighting decides whether to enable code blocks' // syntax highlighting with highlight.js SyntaxHighlighting bool `toml:"syntax_highlighting"` // ClickableImages marks whether the images should href to the img link. ClickableImages bool `toml:"clickable_images"` // FootnoteBrackets decides whether to use brackets on footnotes FootnoteBrackets bool `toml:"footnote_brackets"` // RomanFootnotes tells if we have to use roman numerals for footnotes RomanFootnotes bool `toml:"roman_footnotes"` // What to put in <meta name="robots" content="VALUE"> // By default, it's "nofollow, noindex" RobotsMeta string `toml:"robots_meta"` }
WebsiteConfig is the website section of the config
type WorkingDirectory ¶
type WorkingDirectory string
WorkingDirectory is the directory of where darkness project lives.
func (WorkingDirectory) Join ¶
func (workDir WorkingDirectory) Join(target yunyun.RelativePathFile) yunyun.FullPathFile
Join joins target path with the working directory.
func (WorkingDirectory) JoinGeneric ¶
func (workDir WorkingDirectory) JoinGeneric(target string) string
JoinGeneric joins target path with the working directory.
func (WorkingDirectory) PackRel ¶
func (workDir WorkingDirectory) PackRel(filename yunyun.FullPathFile, data string) (yunyun.RelativePathFile, string)
PackRel cleans the filename from absolute workspace prefix.
func (WorkingDirectory) PackRelRef ¶
func (workDir WorkingDirectory) PackRelRef(filename *yunyun.FullPathFile, data *string) (yunyun.RelativePathFile, string)
PackRelRef cleans the filename from absolute workspace prefix by refs.
func (WorkingDirectory) Rel ¶
func (workDir WorkingDirectory) Rel(filename yunyun.FullPathFile) yunyun.RelativePathFile
Rel returns path trimmed by the workspace