Use simple string interpolation based approach to templating and allow changing the main body, the title and to inject extra HTML into the head element. Additionally we can use `https://tvl.fyi/` instead of `/` when referring to assets. One limitation currently is that the template only works for index pages (it link to self using `href="/"`), but this should be easy to fix. For atward, instead of using the `onload` attribute of `body`, we now register an event listener in JavaScript which makes the template code less complicated. When building the derivation the template is rendered to HTML and injected into the source. Change-Id: I2ea0c5bf5f6286e781285ade7751a348bab3bdc8 Reviewed-on: https://cl.tvl.fyi/c/depot/+/3112 Tested-by: BuildkiteCI Reviewed-by: tazjin <mail@tazj.in>
		
			
				
	
	
		
			50 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Rust
		
	
	
	
	
	
//! Build script that can be used outside of Nix builds to inject the
 | 
						|
//! ATWARD_INDEX_HTML variable when building in development mode.
 | 
						|
//!
 | 
						|
//! Note that this script assumes that atward is in a checkout of the
 | 
						|
//! TVL depot.
 | 
						|
 | 
						|
use std::process::Command;
 | 
						|
 | 
						|
static ATWARD_INDEX_HTML: &str = "ATWARD_INDEX_HTML";
 | 
						|
static ERROR_MESSAGE: &str = r#"Failed to build index page.
 | 
						|
 | 
						|
When building during development, atward expects to be in a checkout
 | 
						|
of the TVL depot. This is required to automatically build the index
 | 
						|
page that is needed at compile time.
 | 
						|
 | 
						|
As atward can not automatically detect the location of the page,
 | 
						|
you must set the `ATWARD_INDEX_HTML` environment variable to the
 | 
						|
right path.
 | 
						|
 | 
						|
The expected page is build using the files in //web/atward/indexHtml
 | 
						|
in the depot."#;
 | 
						|
 | 
						|
fn main() {
 | 
						|
    // Do nothing if the variable is already set (e.g. via Nix)
 | 
						|
    if let Ok(_) = std::env::var(ATWARD_INDEX_HTML) {
 | 
						|
        return;
 | 
						|
    }
 | 
						|
 | 
						|
    // Otherwise ask Nix to build it and inject the result.
 | 
						|
    let output = Command::new("nix-build")
 | 
						|
        .arg("-A").arg("web.atward.indexHtml")
 | 
						|
        // ... assuming atward is at //web/atward ...
 | 
						|
        .arg("../..")
 | 
						|
        .output()
 | 
						|
        .expect(ERROR_MESSAGE);
 | 
						|
 | 
						|
    if !output.status.success() {
 | 
						|
        eprintln!("{}\nNix output: {}", ERROR_MESSAGE, String::from_utf8_lossy(&output.stderr));
 | 
						|
        return;
 | 
						|
    }
 | 
						|
 | 
						|
    let out_path = String::from_utf8(output.stdout)
 | 
						|
        .expect("Nix returned invalid output after building index page");
 | 
						|
 | 
						|
    // Return an instruction to Cargo that will set the environment
 | 
						|
    // variable during rustc calls.
 | 
						|
    //
 | 
						|
    // https://doc.rust-lang.org/cargo/reference/build-scripts.html#cargorustc-envvarvalue
 | 
						|
    println!("cargo:rustc-env={}={}", ATWARD_INDEX_HTML, out_path.trim());
 | 
						|
}
 |