- Add central `process_site_from_path` function - Recursively process heroscript files in `cfg` directory - Remove duplicated site processing from `run` and `add` commands - Respect `play` parameter from heroscript `define` block
179 lines
5.7 KiB
V
179 lines
5.7 KiB
V
module docusaurus
|
|
|
|
import os
|
|
import freeflowuniverse.herolib.core.pathlib
|
|
import freeflowuniverse.herolib.core.texttools
|
|
import freeflowuniverse.herolib.develop.gittools
|
|
import freeflowuniverse.herolib.web.site
|
|
import freeflowuniverse.herolib.ui.console
|
|
import freeflowuniverse.herolib.osal.core as osal
|
|
import freeflowuniverse.herolib.core.playbook
|
|
// import freeflowuniverse.herolib.data.doctree
|
|
|
|
// Recursively process heroscript files in a directory
|
|
fn process_heroscript_files_recursive(dir_path string) !string {
|
|
mut combined_heroscript := ''
|
|
files := os.ls(dir_path) or { return combined_heroscript }
|
|
|
|
for file in files {
|
|
file_path := os.join_path(dir_path, file)
|
|
|
|
if os.is_dir(file_path) {
|
|
// Recursively process subdirectories
|
|
subdir_content := process_heroscript_files_recursive(file_path)!
|
|
combined_heroscript += subdir_content
|
|
} else if file.ends_with('.heroscript') {
|
|
content := os.read_file(file_path) or { continue }
|
|
|
|
// Filter out only the play.include lines while keeping all other content
|
|
lines := content.split('\n')
|
|
mut filtered_lines := []string{}
|
|
for line in lines {
|
|
trimmed := line.trim_space()
|
|
if !trimmed.starts_with('!!play.include') {
|
|
filtered_lines << line
|
|
}
|
|
}
|
|
filtered_content := filtered_lines.join('\n')
|
|
|
|
// Only add if there's meaningful content after filtering
|
|
if filtered_content.trim_space().len > 0 {
|
|
combined_heroscript += filtered_content + '\n\n'
|
|
}
|
|
}
|
|
}
|
|
return combined_heroscript
|
|
}
|
|
|
|
// Central function to process site configuration from a path
|
|
// This is the single point of use for all site processing logic
|
|
// If sitename is empty, it will return the first available site
|
|
pub fn process_site_from_path(path string, sitename string) !&site.Site {
|
|
console.print_debug('Processing site configuration from: ${path}')
|
|
|
|
// Process the site configuration recursively (excluding global includes)
|
|
combined_heroscript := process_heroscript_files_recursive('${path}/cfg')!
|
|
console.print_debug('Combined heroscript length: ${combined_heroscript.len} characters')
|
|
|
|
if combined_heroscript.trim_space().len == 0 {
|
|
return error('No valid heroscript files found in ${path}/cfg')
|
|
}
|
|
|
|
// Create playbook and process site configuration
|
|
mut plbook := playbook.new(text: combined_heroscript)!
|
|
console.print_debug('Created playbook with ${plbook.actions.len} actions')
|
|
site.play(mut plbook)!
|
|
|
|
// Check what sites were created
|
|
available_sites := site.list()
|
|
console.print_debug('Available sites after site.play(): ${available_sites}')
|
|
|
|
if available_sites.len == 0 {
|
|
return error('No sites were created from the configuration')
|
|
}
|
|
|
|
// Determine which site to return
|
|
target_sitename := if sitename.len == 0 {
|
|
console.print_debug('No specific site requested, using first available: ${available_sites[0]}')
|
|
available_sites[0] // Use the first (and likely only) site
|
|
} else {
|
|
console.print_debug('Looking for specific site: ${sitename}')
|
|
sitename
|
|
}
|
|
|
|
mysite := site.get(name: target_sitename) or {
|
|
return error('Failed to get site after playing playbook: ${target_sitename}. Available sites: ${available_sites}')
|
|
}
|
|
|
|
console.print_debug('Site processed successfully: ${mysite.siteconfig.name} with ${mysite.pages.len} pages')
|
|
return mysite
|
|
}
|
|
|
|
@[params]
|
|
pub struct AddArgs {
|
|
pub mut:
|
|
sitename string // needs to exist in web.site module
|
|
path string // site of the docusaurus site with the config as is needed to populate the docusaurus site
|
|
git_url string
|
|
git_reset bool
|
|
git_root string
|
|
git_pull bool
|
|
path_publish string
|
|
play bool = true
|
|
}
|
|
|
|
pub fn dsite_add(args_ AddArgs) !&DocSite {
|
|
mut args := args_
|
|
args.sitename = texttools.name_fix(args_.sitename)
|
|
|
|
console.print_header('Add Docusaurus Site: ${args.sitename}')
|
|
|
|
if args.sitename in docusaurus_sites {
|
|
return error('Docusaurus site ${args.sitename} already exists, returning existing.')
|
|
}
|
|
|
|
mut path := gittools.path(
|
|
path: args.path
|
|
git_url: args.git_url
|
|
git_reset: args.git_reset
|
|
git_root: args.git_root
|
|
git_pull: args.git_pull
|
|
currentdir: false
|
|
)!
|
|
args.path = path.path
|
|
if !path.is_dir() {
|
|
return error('path is not a directory')
|
|
}
|
|
|
|
if !os.exists('${args.path}/cfg') {
|
|
return error('config directory for docusaurus does not exist in ${args.path}/cfg.\n${args}')
|
|
}
|
|
|
|
configpath := '${args.path}/cfg'
|
|
if !os.exists(configpath) {
|
|
return error("can't find config file for docusaurus in ${configpath}")
|
|
}
|
|
|
|
osal.rm('${args.path}/cfg/main.json')!
|
|
osal.rm('${args.path}/cfg/footer.json')!
|
|
osal.rm('${args.path}/cfg/navbar.json')!
|
|
osal.rm('${args.path}/build.sh')!
|
|
osal.rm('${args.path}/develop.sh')!
|
|
osal.rm('${args.path}/sync.sh')!
|
|
osal.rm('${args.path}/.DS_Store')!
|
|
|
|
mut f := factory_get()!
|
|
|
|
if args.path_publish == '' {
|
|
args.path_publish = '${f.path_publish.path}/${args.sitename}'
|
|
}
|
|
|
|
path_build_ := '${f.path_build.path}/${args.sitename}'
|
|
|
|
// get our website
|
|
mut mysite := &site.Site{}
|
|
if site.exists(name: args.sitename) {
|
|
// Site already exists (likely processed by hero command), use existing site
|
|
mysite = site.get(name: args.sitename)!
|
|
} else {
|
|
if !args.play {
|
|
return error('Docusaurus site ${args.sitename} does not exist, please set play to true to create it.')
|
|
}
|
|
// Use the centralized site processing function
|
|
mysite = process_site_from_path(args.path, args.sitename)!
|
|
}
|
|
|
|
// Create the DocSite instance
|
|
mut dsite := &DocSite{
|
|
name: args.sitename
|
|
path_src: pathlib.get_dir(path: args.path, create: false)!
|
|
path_publish: pathlib.get_dir(path: args.path_publish, create: true)!
|
|
path_build: pathlib.get_dir(path: path_build_, create: true)!
|
|
config: new_configuration(mysite.siteconfig)!
|
|
website: mysite
|
|
}
|
|
|
|
docusaurus_sites[args.sitename] = dsite
|
|
return dsite
|
|
}
|