diff options
| -rw-r--r-- | archetypes/default.md | 5 | ||||
| -rw-r--r-- | assets/style.css | 87 | ||||
| -rw-r--r-- | assets/syntax.css | 110 | ||||
| -rw-r--r-- | content/_index.md | 8 | ||||
| -rw-r--r-- | hugo.toml | 15 | ||||
| -rw-r--r-- | layouts/_default/_markup/render-codeblock.html | 1 | ||||
| -rw-r--r-- | layouts/_default/baseof.html | 29 | ||||
| -rw-r--r-- | layouts/_default/list.html | 10 | ||||
| -rw-r--r-- | layouts/_default/single.html | 16 | ||||
| -rw-r--r-- | layouts/index.html | 14 | ||||
| -rw-r--r-- | layouts/partials/footer.html | 5 | ||||
| -rw-r--r-- | layouts/partials/head.html | 28 | ||||
| -rw-r--r-- | layouts/partials/header.html | 0 | ||||
| -rw-r--r-- | layouts/partials/tags.html | 5 | 
14 files changed, 327 insertions, 6 deletions
| diff --git a/archetypes/default.md b/archetypes/default.md new file mode 100644 index 0000000..baf3fce --- /dev/null +++ b/archetypes/default.md @@ -0,0 +1,5 @@ ++++ +title = {{ replace .File.ContentBaseName "-" " " | title }} +date = {{ .Date }} +draft = true ++++ diff --git a/assets/style.css b/assets/style.css new file mode 100644 index 0000000..b1b8d23 --- /dev/null +++ b/assets/style.css @@ -0,0 +1,87 @@ +.skip { + position: absolute; + left: -10000px; + top: auto; + width: 1px; + height: 1px; + overflow: hidden; +} + +.skip:focus { + position: static; + width: auto; + height: auto; +} + +body { + max-width: 45rem; + padding: 0 2rem; + margin: 2rem auto 0; + line-height: 1.6; + background: #11111b; + color: white; +} + +h1, h2, h3 { + margin-bottom: 0.25em; + line-height: 1.3; +} + +p { + margin-top: 0; +} + +p + p { + text-indent: 2em; +} + +ul { + margin-top: 0; +} + +#main-nav { + font-size: 125%; +} + +#main-nav ul { + padding: 0; + margin: 0 0 1em; +} + +#main-nav li { + display: inline-block; +} + +#main-nav li::before { + content: '/ '; +} + +#main-nav li:first-child::before { + content: ''; +} + +#site-title { + font-weight: bold; + color: inherit; + text-decoration: none; +} + +#site-title:hover { + text-decoration: underline; +} + +footer { + margin: 2em 0 0; +} + +header h1 { + margin: 0; +} + +header { + margin-bottom: 1em; +} + +a, a:visited { + color: #8ef; +} diff --git a/assets/syntax.css b/assets/syntax.css new file mode 100644 index 0000000..96128f9 --- /dev/null +++ b/assets/syntax.css @@ -0,0 +1,110 @@ +:root { + --chroma-bg: #111; + --comment: #9e9e9e; + --cyan: #8be9fd; + --green: #50fa7b; + --orange: #ffb86c; + --pink: #f5a; + --purple: #bd93f9; + --red: #f55; + --yellow: #f1fa8c; +} +/* @media (prefers-color-scheme: light) { + :root { + --chroma-bg: #eee; + --comment: #666; + --cyan: #04a5e5; + --green: #40a02b; + --orange: #fe640b; + --pink: #ea76cb; + --purple: #8839ef; + --red: #d20f39; + --yellow: #df8e1d; + } +} */ +/* Background */ .bg, +/* PreWrapper */ .chroma { background-color:var(--chroma-bg); } +/* Other */ .chroma .x { } +/* Error */ .chroma .err { } +/* CodeLine */ .chroma .cl { } +/* LineLink */ .chroma .lnlinks { outline:none;text-decoration:none;color:inherit } +/* LineTableTD */ .chroma .lntd { vertical-align:top;padding:0;margin:0;border:0; } +/* LineTable */ .chroma .lntable { border-spacing:0;padding:0;margin:0;border:0; } +/* LineHighlight */ .chroma .hl { background-color:#3d3f4a } +/* LineNumbersTable */ .chroma .lnt, +/* LineNumbers */ .chroma .ln { white-space:pre;-webkit-user-select:none;user-select:none;margin-right:0.4em;padding:0 0.4em 0 0.4em;color:var(--comment) } +/* Line */ .chroma .line { display:flex; } +/* Keyword */ .chroma .k, +/* KeywordConstant */ .chroma .kc, +/* KeywordNamespace */ .chroma .kn, +/* KeywordPseudo */ .chroma .kp, +/* KeywordReserved */ .chroma .kr { color:var(--pink) } +/* KeywordType */ .chroma .kt { color:var(--cyan) } +/* KeywordDeclaration */ .chroma .kd { color:var(--cyan);font-style:italic } +/* Name */ .chroma .n { } +/* NameBuiltinPseudo */ .chroma .bp { } +/* NameConstant */ .chroma .no { } +/* NameDecorator */ .chroma .nd { } +/* NameEntity */ .chroma .ni { } +/* NameException */ .chroma .ne { } +/* NameAttribute */ .chroma .na, +/* NameClass */ .chroma .nc, +/* NameFunctionMagic */ .chroma .fm, +/* NameFunction */ .chroma .nf { color:var(--green) } +/* NameNamespace */ .chroma .nn { } +/* NameOther */ .chroma .nx { } +/* NameProperty */ .chroma .py { } +/* NameTag */ .chroma .nt { color:var(--pink) } +/* NameBuiltin */ .chroma .nb, +/* NameLabel */ .chroma .nl, +/* NameVariable */ .chroma .nv, +/* NameVariableClass */ .chroma .vc, +/* NameVariableGlobal */ .chroma .vg, +/* NameVariableInstance */ .chroma .vi { color:var(--cyan);font-style:italic } +/* NameVariableMagic */ .chroma .vm { } +/* Literal */ .chroma .l { } +/* LiteralDate */ .chroma .ld { } +/* LiteralString */ .chroma .s, +/* LiteralStringAffix */ .chroma .sa, +/* LiteralStringBacktick */ .chroma .sb, +/* LiteralStringChar */ .chroma .sc, +/* LiteralStringDelimiter */ .chroma .dl, +/* LiteralStringDoc */ .chroma .sd, +/* LiteralStringDouble */ .chroma .s2, +/* LiteralStringEscape */ .chroma .se, +/* LiteralStringHeredoc */ .chroma .sh, +/* LiteralStringInterpol */ .chroma .si, +/* LiteralStringOther */ .chroma .sx, +/* LiteralStringRegex */ .chroma .sr, +/* LiteralStringSingle */ .chroma .s1, +/* LiteralStringSymbol */ .chroma .ss { color:var(--yellow) } +/* LiteralNumber */ .chroma .m, +/* LiteralNumberBin */ .chroma .mb, +/* LiteralNumberFloat */ .chroma .mf, +/* LiteralNumberHex */ .chroma .mh, +/* LiteralNumberInteger */ .chroma .mi, +/* LiteralNumberIntegerLong */ .chroma .il, +/* LiteralNumberOct */ .chroma .mo { color:var(--purple) } +/* Operator */ .chroma .o, +/* OperatorWord */ .chroma .ow { color:var(--pink) } +/* Punctuation */ .chroma .p { } +/* Comment */ .chroma .c, +/* CommentHashbang */ .chroma .ch, +/* CommentMultiline */ .chroma .cm, +/* CommentSingle */ .chroma .c1, +/* CommentSpecial */ .chroma .cs { color:var(--comment) } +/* CommentPreproc */ .chroma .cp, +/* CommentPreprocFile */ .chroma .cpf { color:var(--pink) } +/* Generic */ .chroma .g { } +/* GenericDeleted */ .chroma .gd { color:var(--red) } +/* GenericEmph */ .chroma .ge { text-decoration:underline } +/* GenericError */ .chroma .gr { } +/* GenericHeading */ .chroma .gh { font-weight:bold } +/* GenericInserted */ .chroma .gi { color:var(--green);font-weight:bold } +/* GenericOutput */ .chroma .go { color:var(--comment) } +/* GenericPrompt */ .chroma .gp { } +/* GenericStrong */ .chroma .gs { } +/* GenericSubheading */ .chroma .gu { font-weight:bold } +/* GenericTraceback */ .chroma .gt { } +/* GenericUnderline */ .chroma .gl { text-decoration:underline } +/* TextWhitespace */ .chroma .w { } diff --git a/content/_index.md b/content/_index.md new file mode 100644 index 0000000..1c8905b --- /dev/null +++ b/content/_index.md @@ -0,0 +1,8 @@ +I'm a computer science graduate with an affinity for systems programming and +functional languages. I think C, Rust and Zig all have their merits and am +comfortable working with all 3. When I don't need to work at such a low level, +I like to work with Elixir and Erlang. + +I'm passionate about building performant, fault-tolerant and scalable systems and +making the web a more free and decentralized place. All my projects can be found +on [my forgejo instance](https://git.wires.systems) diff --git a/hugo.toml b/hugo.toml index 3c4aff7..2199c34 100644 --- a/hugo.toml +++ b/hugo.toml @@ -1,9 +1,13 @@ baseURL = 'https://wires.systems' languageCode = 'en-us' -title = "wires" +title = "~wires" uglyurls = true enableGitInfo = true -disableKinds = ['taxonomy', 'term', 'section'] +disableKinds = ['section', 'taxonomy'] +summaryLength = 10 + +[taxonomies] + tag = 'tags' [markup] highlight.noClasses = false @@ -13,11 +17,10 @@ disableKinds = ['taxonomy', 'term', 'section'] [outputFormats.rss] baseName = 'feed' -[params] - description = "wires within wires, systems within systems" +[[menu.main]] + name = "rss" + url = "/feed.xml" [[menu.main]] name = "git" url = "https://git.wires.systems/wires" - [menu.main.params] - rel = "me" diff --git a/layouts/_default/_markup/render-codeblock.html b/layouts/_default/_markup/render-codeblock.html new file mode 100644 index 0000000..9bfc3b1 --- /dev/null +++ b/layouts/_default/_markup/render-codeblock.html @@ -0,0 +1 @@ +<pre class="chroma"><code class="language-{{ .Type }}" data-lang="{{ .Type }}">{{ (transform.HighlightCodeBlock .).Inner }}</code></pre> diff --git a/layouts/_default/baseof.html b/layouts/_default/baseof.html new file mode 100644 index 0000000..ecac3b1 --- /dev/null +++ b/layouts/_default/baseof.html @@ -0,0 +1,29 @@ +<!DOCTYPE html> +<html lang="{{ .Site.Language.LanguageCode }}"> + <head> + {{ partial "head.html" . }} + <!-- this is here to make sure that if we can't load CSS the icons don't totally fuck up layout --> + <style>.icon svg { width: 1.25em; height: 1.25em; }</style> +{{ range .AlternativeOutputFormats -}} +{{ printf `<link rel="%s" type="%s" href="%s" title="%s" />` .Rel .MediaType.Type .Permalink $.Site.Title | safeHTML }} +{{ end -}} +</head> +<body> +<a href="#main" class="skip">Skip to content</a> +<nav id="main-nav"> +<ul> +<li><a href="{{.Site.BaseURL}}" id="site-title">{{.Site.Title}}</a></li> +{{ with .Site.Menus.main }} + {{ range . }} + <li><a href="{{ .URL }}">{{ .Name }}</a></li> + {{ end }} +{{ end }} +</ul> +</nav> + +<main id="main"> +{{ block "main" . }}{{ end }} +</main> +{{ partial "footer.html" . }} +</body> +</html> diff --git a/layouts/_default/list.html b/layouts/_default/list.html new file mode 100644 index 0000000..ea76a24 --- /dev/null +++ b/layouts/_default/list.html @@ -0,0 +1,10 @@ +{{ define "main" }} +<h2>{{ .Title }}</h2> +<ul> +{{ range .Pages }} +<li> +<a href="{{ .Permalink }}">{{ .Title }}</a> +</li> +{{ end }} +</ul> +{{ end }} diff --git a/layouts/_default/single.html b/layouts/_default/single.html new file mode 100644 index 0000000..60d1b41 --- /dev/null +++ b/layouts/_default/single.html @@ -0,0 +1,16 @@ +{{ define "main" }} +<header> + <h1>{{ .Title }}</h1> + <time datetime="{{ .Lastmod }}">{{ .Lastmod.Format "January 2, 2006" }}</time> +</header> + {{ if .Params.toc }} + <aside id="toc"> + <a class="skip" href="#post">Skip table of contents</a> + <h2 id="toc-title">Contents</h2> + {{ .TableOfContents }} + </aside> + <a id="post"></a> + {{ end }} + {{ .Content }} + {{ partial "tags.html" . }} +{{ end }} diff --git a/layouts/index.html b/layouts/index.html new file mode 100644 index 0000000..fd3d675 --- /dev/null +++ b/layouts/index.html @@ -0,0 +1,14 @@ +{{ define "main" }} +{{ .Content }} +{{ with .Site.RegularPages }} +<h2>Posts</h2> +<ul> +{{ range . }} +<li> +<a href="{{ .Permalink }}">{{ .Title }}</a> +{{ partial "tags.html" . }} +</li> +{{ end }} +</ul> +{{ end }} +{{ end }} diff --git a/layouts/partials/footer.html b/layouts/partials/footer.html new file mode 100644 index 0000000..99d42f9 --- /dev/null +++ b/layouts/partials/footer.html @@ -0,0 +1,5 @@ +<footer> +All content is openly licensed via <a href="http://creativecommons.org/licenses/by-sa/4.0/" target="_blank" rel="license noopener noreferrer">CC BY-SA 4.0</a> +<br> +Made with <a href="https://gohugo.io">Hugo</a> +</footer> diff --git a/layouts/partials/head.html b/layouts/partials/head.html new file mode 100644 index 0000000..ce38afc --- /dev/null +++ b/layouts/partials/head.html @@ -0,0 +1,28 @@ +<meta charset="utf-8"/> +<meta name="viewport" content="width=device-width, initial-scale=1.0"> +{{ with (or .Description .Site.Params.description) }} +<meta name="description" content="{{ . }}"/> +{{ end }} +{{ with .Keywords }}<meta name="keywords" content="{{ delimit . ", " }}"/>{{ end }} +<link rel="license" href="https://creativecommons.org/licenses/by-sa/4.0/"/> +<link rel="canonical" href="{{ .Permalink }}"/> +{{- with resources.Get "style.css" }} + {{- if eq hugo.Environment "development" }} + <link rel="stylesheet" href="{{ .RelPermalink }}"> + {{- else }} + {{- with . | minify | fingerprint }} + <link rel="stylesheet" href="{{ .RelPermalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"> + {{- end }} + {{- end }} +{{- end }} +{{- with resources.Get "syntax.css" }} + {{- if eq hugo.Environment "development" }} + <link rel="stylesheet" href="{{ .RelPermalink }}"> + {{- else }} + {{- with . | minify | fingerprint }} + <link rel="stylesheet" href="{{ .RelPermalink }}" integrity="{{ .Data.Integrity }}" crossorigin="anonymous"> + {{- end }} + {{- end }} +{{- end }} +<title>{{ if .IsHome }}{{ site.Title }}{{ else }}{{ printf "%s | %s" .Title site.Title }}{{ end }}</title> + diff --git a/layouts/partials/header.html b/layouts/partials/header.html new file mode 100644 index 0000000..e69de29 --- /dev/null +++ b/layouts/partials/header.html diff --git a/layouts/partials/tags.html b/layouts/partials/tags.html new file mode 100644 index 0000000..8062534 --- /dev/null +++ b/layouts/partials/tags.html @@ -0,0 +1,5 @@ +{{ with .GetTerms "tags" }} +<br> +tags: +{{ range $i, $e := . }}{{- if $i -}}, {{ end -}}{{ with $e }}<a class="tag" href="{{.Permalink}}">{{lower .Title}}</a>{{end}}{{ end }} +{{ end }} |