tinrsenritr

This commit is contained in:
2026-01-23 18:32:00 +02:00
parent 97f5d2da3e
commit 74e4fcdc3c
2 changed files with 90 additions and 132 deletions

89
.config/create-work.nu Executable file
View File

@@ -0,0 +1,89 @@
#!/usr/bin/env nu
# Configuration
let template_dir = ".typst-template"
let config_dir = ".config"
let out_dir = "."
def main [subject: string, shortcode: string, number: string = ""] {
let subject_lower = ($subject | str downcase)
let shortcode_lower = ($shortcode | str downcase)
validate-input $subject $shortcode $number
let temp_dir = (mktemp -d)
let final_dir = $"($out_dir)/($subject_lower)/($shortcode_lower)($number)"
let subject_dir = $"($out_dir)/($subject_lower)"
copy-template $temp_dir
generate-doc-toml $shortcode_lower $subject_lower $temp_dir $number
if not ($final_dir | path exists) {
error make -u {msg: $"Directory ($final_dir) already exists"}
}
mkdir $subject_dir
cp -r $temp_dir $final_dir
print $"=> Created new work: ($final_dir)"
rm -rf $temp_dir
}
def validate-input [subject: string, shortcode: string, number: string] {
if not ($config_dir | path exists) {
error make -u {msg: "Config directory not found"}
}
let defaults_toml = $"($config_dir)/defaults.toml"
let subjects_toml = $"($config_dir)/subjects.toml"
if not ($defaults_toml | path exists) {
error make -u {msg: $"defaults.toml not found in config directory"}
}
if not ($subjects_toml | path exists) {
error make -u {msg: "subjects.toml not found in config directory"}
}
if $out_dir != "." and not ($out_dir | path exists) {
mkdir $out_dir
}
# Check subject exists (case insensitive)
let subject_lower = ($subject | str downcase)
let subjects = (open $subjects_toml | get subjects | columns)
if $subject_lower not-in $subjects {
error make -u {
msg: $"Subject '($subject)' not found in configuration"
help: $"Available subjects: ($subjects | str join ', ')"
}
}
}
def copy-template [target_dir: string] {
if not ($template_dir | path exists) {
error make -u {msg: $"Template directory ($template_dir) not found"}
}
cd $template_dir
cp -r * $target_dir
}
def generate-doc-toml [shortcode: string, subject: string, target_dir: string, number: string] {
let defaults = (open $"($config_dir)/defaults.toml")
let subjects = (open $"($config_dir)/subjects.toml")
let subject_data = ($subjects | get subjects | get $subject)
let work_type = ($defaults | get work_types | try { get $shortcode } catch { $shortcode })
let number = if $number != "" { $number | into int } else { "" }
{
university: ($defaults | get university)
subject: ($subject_data | get name)
type: $work_type
number: $number
mentors: ($subject_data | get mentors)
authors: [($defaults | get default_author)]
} | compact --empty | to toml | save $"($target_dir)/src/doc.toml" --force
}

133
justfile
View File

@@ -9,135 +9,4 @@ default:
# Create new work from template
new subject shortcode number="":
#!/usr/bin/env nu
# Convert to lowercase for config lookup
let subject_lower = ("{{subject}}" | str downcase)
let shortcode_lower = ("{{shortcode}}" | str downcase)
# Use number if provided, otherwise empty string
let number = "{{number}}"
just _validate-input "{{shortcode}}" $number "{{subject}}"
# Create temporary directory first
let temp_dir = (mktemp -d)
let final_dir = if "{{out_dir}}" != "" {
$"{{out_dir}}/($subject_lower)/($shortcode_lower)($number)"
} else {
$"($subject_lower)/($shortcode_lower)"
}
let subject_dir = if "{{out_dir}}" != "" {
$"{{out_dir}}/($subject_lower)"
} else {
$"($subject_lower)"
}
# Copy template to temp
just _copy-template $temp_dir
# Generate customized files in temp
just _generate-doc-toml $shortcode_lower $subject_lower $temp_dir $number
# Move to final location
# NOTE: mkdir then cp: that way it copies to final_dir and not final_dir/temp_dir
if "{{out_dir}}" != "" and not ("{{out_dir}}" | path exists) {
mkdir {{out_dir}}
}
mkdir $subject_dir
cp -r $temp_dir $final_dir
print $"=> Created new work: ($final_dir)"
# rm -rf $temp_dir
# Validation helper
_validate-input shortcode number subject:
#!/usr/bin/env nu
if not ("{{config_dir}}" | path exists) {
error make -u {msg: "Config directory not found"}
}
let defaults_toml = "{{config_dir}}/defaults.toml"
let subjects_toml = "{{config_dir}}/subjects.toml"
if not ($defaults_toml | path exists) {
error make -u {msg: $"defaults.toml not found in config directory"}
}
if not ($subjects_toml | path exists) {
error make -u {msg: "subjects.toml not found in config directory"}
}
if "{{number}}" != "" {
if ("{{number}}" | into int) <= 0 {
error make -u {msg: "Number must be positive integer"}
}
}
# Check subject exists (case insensitive)
let subject_lower = ("{{subject}}" | str downcase)
let subjects = (open $subjects_toml | get subjects | columns)
if $subject_lower not-in $subjects {
error make -u {
msg: $"Subject '{{subject}}' not found in configuration"
help: $"Available subjects: ($subjects | str join ', ')"
}
}
# Directory creation
_create-dir target_dir:
#!/usr/bin/env nu
if ("{{target_dir}}" | path exists) {
error make -u {msg: $"Directory {{target_dir}} already exists"}
}
mkdir "{{target_dir}}"
# Copy template files
_copy-template target_dir:
#!/usr/bin/env nu
if not ("{{template_dir}}" | path exists) {
error make -u {msg: $"Template directory {{template_dir}} not found"}
}
cd {{template_dir}}; cp -r * {{target_dir}}/
# Generate customized doc.toml
_generate-doc-toml shortcode subject target_dir number="":
#!/usr/bin/env nu
let defaults_toml = $"{{config_dir}}/defaults.toml"
let subjects_toml = $"{{config_dir}}/subjects.toml"
# Extract data using Nushell's builtin TOML parsing
let defaults = (open $defaults_toml)
let subjects = (open $subjects_toml)
let university = ($defaults | get university)
let subject_data = ($subjects | get subjects | get {{subject}})
let subject_name = ($subject_data | get name)
# Get work type, with fallback for unknown shortcodes
let work_type = ($defaults | get work_types | try { get "{{shortcode}}" } catch { "{{shortcode}}" })
let author = ($defaults | get default_author)
# Get mentors directly from the subject
let mentors_data = ($subject_data | get mentors)
# Build the complete TOML structure as a record
let base_config = {
university: $university
subject: $subject_name
type: $work_type
mentors: $mentors_data
authors: [$author]
}
let doc_config = if "{{number}}" != "" {
$base_config | merge {number: ("{{number}}" | into int)}
} else {
$base_config
}
# Output directly to TOML format
$doc_config | to toml | save $"{{target_dir}}/src/doc.toml" --force
./.config/create-work.nu {{subject}} {{shortcode}} {{number}}