mirror of
				https://github.com/lleene/hugo-site.git
				synced 2025-10-26 17:59:03 +01:00 
			
		
		
		
	content update October
This commit is contained in:
		| @ -6,8 +6,8 @@ toc: true | |||||||
| tags: | tags: | ||||||
|   - svg |   - svg | ||||||
|   - xml |   - xml | ||||||
|   - hugo |   - python | ||||||
|   - golang |   - code | ||||||
| --- | --- | ||||||
| 
 | 
 | ||||||
| SVG is generally my image format of choice having used it for illustrations, | SVG is generally my image format of choice having used it for illustrations, | ||||||
| @ -130,17 +130,3 @@ The final result is shown below. | |||||||
| Note that this figure is quite a bit more compact but adding additional labels | Note that this figure is quite a bit more compact but adding additional labels | ||||||
| or customizations outside the scope of the library will probably require | or customizations outside the scope of the library will probably require | ||||||
| quite a bit of manual work. This could be a fun side project though. | quite a bit of manual work. This could be a fun side project though. | ||||||
| 
 |  | ||||||
| ## Mermaid CLI |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| # Hugo Integration |  | ||||||
| 
 |  | ||||||
| The hope here is that we can call a predefined go procedure that parses |  | ||||||
| some section of markdown source code and instantiates the corresponding svg file |  | ||||||
| under our static folder that is then referenced. |  | ||||||
| 
 |  | ||||||
| ``` go |  | ||||||
| {{/* a comment */}} |  | ||||||
| ``` |  | ||||||
							
								
								
									
										11
									
								
								content/posts/2021/configure-nginx.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								content/posts/2021/configure-nginx.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | |||||||
|  | --- | ||||||
|  | title: "Configure Nginx 🧩" | ||||||
|  | date: 2021-10-31T15:08:33+01:00 | ||||||
|  | draft: false | ||||||
|  | toc: false | ||||||
|  | images: | ||||||
|  | tags: | ||||||
|  |   - untagged | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | This is a test | ||||||
							
								
								
									
										19
									
								
								content/posts/2021/hugo-integration.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								content/posts/2021/hugo-integration.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,19 @@ | |||||||
|  | --- | ||||||
|  | title: "Hugo Integration 🧭" | ||||||
|  | date: 2021-10-30T15:42:22+02:00 | ||||||
|  | draft: true | ||||||
|  | toc: false | ||||||
|  | images: | ||||||
|  | tags: | ||||||
|  |   - untagged | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | ## This is Word in Progress | ||||||
|  |  | ||||||
|  | The hope here is that we can call a predefined go procedure that parses | ||||||
|  | some section of markdown source code and instantiates the corresponding svg file | ||||||
|  | under our static folder that is then referenced. | ||||||
|  |  | ||||||
|  | ``` go | ||||||
|  | {{/* a comment */}} | ||||||
|  | ``` | ||||||
							
								
								
									
										122
									
								
								content/posts/2021/mermaid-uml.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										122
									
								
								content/posts/2021/mermaid-uml.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,122 @@ | |||||||
|  | --- | ||||||
|  | title: "Unified Modelling Language 🐬" | ||||||
|  | date: 2021-10-30T15:42:47+02:00 | ||||||
|  | draft: false | ||||||
|  | toc: false | ||||||
|  | images: | ||||||
|  | tags: | ||||||
|  |   - svg | ||||||
|  |   - uml | ||||||
|  |   - code | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | ## Mermaid CLI | ||||||
|  |  | ||||||
|  | [Mermaid](https://mermaid-js.github.io/mermaid) is a JS based diagram and | ||||||
|  | charting tool which aspires to generate diagrams in a markdown fashion. The | ||||||
|  | main advantage here is that Mermaid is well integrated into quite a few | ||||||
|  | editing and content management | ||||||
|  | [packages](https://mermaid-js.github.io/mermaid/#/./integrations). | ||||||
|  | There is command-line node-package that installs on both linux and WSL | ||||||
|  | environments. You do need NPM version 10+ so installing in | ||||||
|  | [Windows](https://docs.microsoft.com/en-us/windows/dev-environment/javascript/nodejs-on-wsl) | ||||||
|  | takes a few extra steps in order to get the latest version. | ||||||
|  |  | ||||||
|  | ```bash | ||||||
|  | npm install @mermaid-js/mermaid-cli | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Additionally this | ||||||
|  | package will sandbox a instance of chromium which doesn't operate correctly | ||||||
|  | with WLS version 1. Upgrading to WLS version 2 will allow you to run the | ||||||
|  | following example using `mmdc -i input.mmd -o output.svg -c config.json`. | ||||||
|  |  | ||||||
|  | ```text | ||||||
|  | graph LR | ||||||
|  |     S[fa:fa-dot] --> A | ||||||
|  |     A{foo} | ||||||
|  |     A --> B(bar) | ||||||
|  |     A --> C(baz) | ||||||
|  |     style S fill:none, stroke:none | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | This example generates the diagram show below. | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | There are four base themes: dark, default, forest, neutral. Additional | ||||||
|  | [customization](https://mermaid-js.github.io/mermaid/#/theming) is possible. | ||||||
|  | The `config.json` is shown below which sets similar styling as | ||||||
|  | [before]({{< relref "building-svg.md" >}} "building svg") using the other | ||||||
|  | command-line tools. | ||||||
|  |  | ||||||
|  | ```json | ||||||
|  | { | ||||||
|  |   "theme": "neutral", | ||||||
|  |   "themeVariables": { | ||||||
|  |       "fontFamily":"monospace", | ||||||
|  |       "fontSize":"14px", | ||||||
|  |       "classText" : "white", | ||||||
|  |       "nodeBorder" : "white", | ||||||
|  |       "nodeTextColor" : "white", | ||||||
|  |       "lineColor" : "white", | ||||||
|  |       "arrowheadColor" : "white", | ||||||
|  |       "mainBkg" : "none" | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | ## UML diagrams | ||||||
|  |  | ||||||
|  | Mermaid is quite a bit more versatile and is geared towards making structured | ||||||
|  | diagrams of classes and inter-related structures. For example the UML diagram below presents the overall composition of | ||||||
|  | [pyviewer]({{< relref "pyside.md" >}} "pyside") which is image simple | ||||||
|  | browsing utility for compressed archives. | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  | This does quite well at illustrating how classes are composed and which methods | ||||||
|  | are available at various scopes. It also helps organizing and structuring a | ||||||
|  | code-base when there means to reason in a visual way. The source code for this | ||||||
|  | diagram is shown below for reference. | ||||||
|  |  | ||||||
|  | ```text | ||||||
|  | classDiagram | ||||||
|  |      class ApplicationWindow{ | ||||||
|  |           int[2] layout | ||||||
|  |           int max_count | ||||||
|  |           navigate(keyPress) | ||||||
|  |           update() | ||||||
|  |       } | ||||||
|  |       class PyViewer{ | ||||||
|  |         signal image_changed | ||||||
|  |         load_file_map(str path) | ||||||
|  |         load_archive(int index) | ||||||
|  |         set_max_count(int max_count) | ||||||
|  |       } | ||||||
|  |       class ArchiveLoader{ | ||||||
|  |         generate_map(str path) | ||||||
|  |         extract_current_index() | ||||||
|  |         check_media() | ||||||
|  |       } | ||||||
|  |       class ArchiveManager{ | ||||||
|  |           int max_count | ||||||
|  |           Qbyte[] images | ||||||
|  |           load_archive(str archive_path) | ||||||
|  |       } | ||||||
|  |       class TagManager{ | ||||||
|  |           int index | ||||||
|  |           dict media_map | ||||||
|  |           dict tag_filter | ||||||
|  |           list tag_history | ||||||
|  |           update_filter(str tag, bool state) | ||||||
|  |           undo_last_filter() | ||||||
|  |           adjust_index(int change) | ||||||
|  |           tag_at(int index) | ||||||
|  |           set_index(str tag_name) | ||||||
|  |       } | ||||||
|  |       ArchiveLoader <|-- TagManager | ||||||
|  |       ArchiveLoader <|-- ArchiveManager | ||||||
|  |       PyViewer <-- ArchiveLoader | ||||||
|  |       PyViewer <-- ApplicationWindow | ||||||
|  | ``` | ||||||
							
								
								
									
										1
									
								
								static/images/example_mermaid.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								static/images/example_mermaid.svg
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| After Width: | Height: | Size: 7.4 KiB | 
							
								
								
									
										1
									
								
								static/images/example_pyviewer.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								static/images/example_pyviewer.svg
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| After Width: | Height: | Size: 17 KiB | 
		Reference in New Issue
	
	Block a user