Skip to content

web.mdbook #

heroscript

config


!!books.config 	coderoot:'/tmp/code' install:true reset:true publishroot:'/tmp/publish'

//DEFAULTS:
// coderoot    '${os.home_dir()}/hero/code'
// buildroot   '${os.home_dir()}/hero/var/mdbuild'
// publishroot '${os.home_dir()}/hero/www/info'
// install     true
// reset       false

fn book_edit #

fn book_edit(name string) !

fn book_open #

fn book_open(name string) !

fn get #

fn get(cfg_ Config) !MDBooks[Config]

fn (MDBooks[Config]) generate #

fn (mut books MDBooks[Config]) generate(args_ MDBookArgs) !&MDBook

struct Config #

@[params]
struct Config {
pub mut:
	path_build   string ='${os.home_dir()}/hero/var/mdbuild'
	path_publish string ='${os.home_dir()}/hero/www/info'
}

struct ErrorArgs #

@[params]
struct ErrorArgs {
pub mut:
	path string
	msg  string
	cat  collection.CollectionErrorCat
}

struct FileLoader #

@[heap]
struct FileLoader {
pub mut:
	embedded_files []embed_file.EmbedFileData @[skip; str: skip]
}

struct MDBook #

@[heap]
struct MDBook {
pub mut:
	name         string
	books        &MDBooks[Config] @[skip; str: skip]
	path_build   pathlib.Path
	path_publish pathlib.Path
	args         MDBookArgs
	errors       []collection.CollectionError
}

fn (MDBook) error #

fn (mut book MDBook) error(args ErrorArgs)

fn (MDBook) generate #

fn (mut book MDBook) generate() !

fn (MDBook) open #

fn (mut book MDBook) open() !

fn (MDBook) summary #

fn (mut book MDBook) summary(production bool) !Summary

struct MDBookArgs #

@[params]
struct MDBookArgs {
pub mut:
	name  string @[required]
	title string

	foldlevel int
	printbook bool
	// summary_url  string // url of the summary.md file
	summary_path string // can also give the path to the summary file (can be the dir or the summary itself)
	// doctree_url  string
	// doctree_path string
	publish_path string
	build_path   string
	production   bool
	collections  []string
	description  string
	export       bool // whether mdbook should be built
}

struct MDBooks #

@[heap]
struct MDBooks[T] {
	base.BaseConfig[T]
}

struct Summary #

@[heap]
struct Summary {
pub mut:
	items       []SummaryItem
	errors      []SummaryItem // means we found errors, so we need to add to summary
	addpages    []SummaryItem // means we found pages as links, so we need to add them to the summary
	collections []string
	production  bool
}

fn (Summary) str #

fn (mut self Summary) str() string

struct SummaryItem #

struct SummaryItem {
pub mut:
	level       int
	description string
	relpath     string // relative path of summary item to source
	collection  string
	pagename    string
}