feat(sterni/nix/html): make <html> also emit doctype
This makes the awkward withDoctype utility obsolete which is much nicer.
Technically, this is a BREAKING CHANGE since it was possible to create
valid documents without an <html> tag before:
    withDoctype (lib.concatStrings [ (<head> { } …) (<body> { } …) ])
I don't think this usecase is worth preserving since this can just be
written as
    <html> { } [ (<head> { } …) (<body> { } …) ]
and omitting the <html> tag is not recommended since it should be used
to set the language of the document (which we didn't in the example
above).
Change-Id: Idc5104ce88fe8bee965c076229b79387915c3605
Reviewed-on: https://cl.tvl.fyi/c/depot/+/12907
Autosubmit: sterni <sternenseemann@systemli.org>
Reviewed-by: sterni <sternenseemann@systemli.org>
Tested-by: BuildkiteCI
Reviewed-by: tazjin <tazjin@tvl.su>
			
			
This commit is contained in:
		
							parent
							
								
									9fa198f9ae
								
							
						
					
					
						commit
						d47c7fa12b
					
				
					 5 changed files with 20 additions and 24 deletions
				
			
		|  | @ -3,7 +3,6 @@ | |||
| let | ||||
|   inherit (depot.users.sterni.nix.html) | ||||
|     __findFile | ||||
|     withDoctype | ||||
|     ; | ||||
| in | ||||
| 
 | ||||
|  | @ -19,13 +18,13 @@ in | |||
|       root = pkgs.writeTextFile { | ||||
|         name = "sterni.lv-http-root"; | ||||
|         destination = "/index.html"; | ||||
|         text = withDoctype (<html> { } [ | ||||
|         text = <html> { } [ | ||||
|           (<head> { } [ | ||||
|             (<meta> { charset = "utf-8"; } null) | ||||
|             (<title> { } "no thoughts") | ||||
|           ]) | ||||
|           (<body> { } "🦩") | ||||
|         ]); | ||||
|         ]; | ||||
|       }; | ||||
|       # TODO(sterni): tmp.sterni.lv | ||||
|       locations."/tmp/".root = toString /srv/http; | ||||
|  |  | |||
|  | @ -11,10 +11,10 @@ let | |||
|   htmlNix = import ./path/to/html.nix { }; | ||||
| 
 | ||||
|   # make the magic work | ||||
|   inherit (htmlNix) __findFile esc withDoctype; | ||||
|   inherit (htmlNix) __findFile esc; | ||||
| in | ||||
| 
 | ||||
| pkgs.writeText "example.html" (withDoctype (<html> {} [ | ||||
| pkgs.writeText "example.html" (<html> {} [ | ||||
|   (<head> {} [ | ||||
|     (<meta> { charset = "utf-8"; } null) | ||||
|     (<title> {} (esc "hello world")) | ||||
|  | @ -35,7 +35,7 @@ pkgs.writeText "example.html" (withDoctype (<html> {} [ | |||
|       ]) | ||||
|     ]) | ||||
|   ]) | ||||
| ])) | ||||
| ]) | ||||
| ``` | ||||
| 
 | ||||
| Convince yourself it works: | ||||
|  |  | |||
|  | @ -1,4 +1,4 @@ | |||
| # Copyright © 2021 sterni | ||||
| # SPDX-FileCopyrightText: Copyright © 2021, 2024 sterni | ||||
| # SPDX-License-Identifier: MIT | ||||
| # | ||||
| # This file provides a cursed HTML DSL for nix which works by overloading | ||||
|  | @ -58,6 +58,9 @@ let | |||
|      calls, we can't escape it automatically. Instead this must be done manually | ||||
|      using `esc`. | ||||
| 
 | ||||
|      If the tag is "html", e.g. in case of `<html> { } …`, "<!DOCTYPE html> will | ||||
|      be prepended to the normal rendering of the text. | ||||
| 
 | ||||
|      Type: string -> attrs<string> -> (list<string> | string | null) -> string | ||||
| 
 | ||||
|      Example: | ||||
|  | @ -98,20 +101,16 @@ let | |||
|         then builtins.concatStringsSep "" (flatten content) | ||||
|         else content; | ||||
|     in | ||||
|     if content == null | ||||
|     (if tag == "html" then "<!DOCTYPE html>" else "") + | ||||
|     (if content == null | ||||
|     then "<${tag}${attrs'}/>" | ||||
|     else "<${tag}${attrs'}>${content'}</${tag}>"; | ||||
|     else "<${tag}${attrs'}>${content'}</${tag}>"); | ||||
| 
 | ||||
|   /* Prepend "<!DOCTYPE html>" to a string. | ||||
| 
 | ||||
|      Type: string -> string | ||||
| 
 | ||||
|      Example: | ||||
| 
 | ||||
|      withDoctype (<body> {} (esc "hello")) | ||||
|      => "<!DOCTYPE html><body>hello</body>" | ||||
|   /* Deprecated, does nothing. | ||||
|   */ | ||||
|   withDoctype = doc: "<!DOCTYPE html>" + doc; | ||||
|   withDoctype = doc: builtins.trace | ||||
|     "WARN: withDoctype no longer does anything, `<html> { } [ … ]` takes care of rendering <!DOCTYPE html>" | ||||
|     doc; | ||||
| 
 | ||||
|   /* Taken from <nixpkgs/lib/lists.nix>. */ | ||||
|   flatten = x: | ||||
|  |  | |||
|  | @ -4,10 +4,9 @@ let | |||
|   inherit (depot.users.sterni.nix.html) | ||||
|     __findFile | ||||
|     esc | ||||
|     withDoctype | ||||
|     ; | ||||
| 
 | ||||
|   exampleDocument = withDoctype (<html> { lang = "en"; } [ | ||||
|   exampleDocument = <html> { lang = "en"; } [ | ||||
|     (<head> { } [ | ||||
|       (<meta> { charset = "utf-8"; } null) | ||||
|       (<title> { } "html.nix example document") | ||||
|  | @ -78,7 +77,7 @@ let | |||
|         ]) | ||||
|       ]) | ||||
|     ]) | ||||
|   ]); | ||||
|   ]; | ||||
| in | ||||
| 
 | ||||
| pkgs.runCommand "html.nix.html" | ||||
|  |  | |||
|  | @ -4,7 +4,6 @@ let | |||
|   inherit (depot.users.sterni.nix.html) | ||||
|     __findFile | ||||
|     esc | ||||
|     withDoctype | ||||
|     ; | ||||
| 
 | ||||
|   # CGI envvars: https://www.instanet.com/cgi/env.html | ||||
|  | @ -24,7 +23,7 @@ let | |||
| 
 | ||||
|   default = let { | ||||
|   hasQuery = if builtins.length (builtins.attrNames query) > 0 then "?" else ""; | ||||
|   body = (withDoctype (<html> { lang = "en"; } [ | ||||
|   body = <html> { lang = "en"; } [ | ||||
|     (<head> { } [ | ||||
|       (<title> { } "some cursed nix") | ||||
|     ]) | ||||
|  | @ -33,7 +32,7 @@ let | |||
|       (<p> { } [ method " " path hasQuery rawQuery ]) | ||||
|       (<p> { } (builtins.toJSON query)) | ||||
|     ]) | ||||
|   ])); | ||||
|   ]; | ||||
|   }; | ||||
| 
 | ||||
|   greeter = withDoctype (<html> { lang = "en"; } [ | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue