about summary refs log tree commit diff
path: root/users/Profpatsch/aerc.dhall
diff options
context:
space:
mode:
authorProfpatsch <mail@profpatsch.de>2022-06-19T13·07+0200
committerProfpatsch <mail@profpatsch.de>2022-06-19T13·29+0000
commit3c3713c69f9a7fb0c14ef463ab520de7f601e1e9 (patch)
tree927dcba81970893fab3be1f1020a258837c75633 /users/Profpatsch/aerc.dhall
parent2cf67e113e94435c0169141d0d7f5cf6b63f6655 (diff)
refactor(users/Profpatsch/aerc): move ini stuff out r/4247
First shot at generating a dhall FFI standard.

Change-Id: I1cdf7eeaa6b2668a49282315f308a8e51abd0cf6
Reviewed-on: https://cl.tvl.fyi/c/depot/+/5887
Reviewed-by: Profpatsch <mail@profpatsch.de>
Tested-by: BuildkiteCI
Diffstat (limited to 'users/Profpatsch/aerc.dhall')
-rw-r--r--users/Profpatsch/aerc.dhall268
1 files changed, 125 insertions, 143 deletions
diff --git a/users/Profpatsch/aerc.dhall b/users/Profpatsch/aerc.dhall
index fb63f7044be8..2a02b418ddd6 100644
--- a/users/Profpatsch/aerc.dhall
+++ b/users/Profpatsch/aerc.dhall
@@ -1,157 +1,139 @@
-let NameVal = λ(T : Type) → { name : Text, value : T }
+let Lib = ./dhall/lib.dhall
+
+let List/map = Lib.List/map
+
+let Ini = ./ini/ini.dhall
 
 in  λ ( imports
       : { -- Take an aerc filter from the aerc distribution /share directory
           aercFilter : Text → Text
-        , -- given a dsl of functions to create an Ini, render the ini file
-          toIni :
-            { globalSection : List (NameVal Text)
-            , sections : List (NameVal (List (NameVal Text)))
-            } →
-              Text
+        , Ini/externs : Ini.Externs
         }
       ) →
-      let List/map
-          : ∀(a : Type) → ∀(b : Type) → (a → b) → List a → List b
-          = λ(a : Type) →
-            λ(b : Type) →
-            λ(f : a → b) →
-            λ(xs : List a) →
-              List/build
-                b
-                ( λ(list : Type) →
-                  λ(cons : b → list → list) →
-                    List/fold a xs list (λ(x : a) → cons (f x))
-                )
-
-      in  { accounts =
-              imports.toIni
-                { globalSection = [] : List (NameVal Text)
-                , sections =
-                  [ { name = "mail"
-                    , value =
-                      [ { name = "archive", value = "Archive" }
-                      , { name = "copy-to", value = "Sent" }
-                      , { name = "default", value = "INBOX" }
-                      , { name = "from"
-                        , value = "Profpatsch <mail@profpatsch.de>"
-                        }
-                      , { name = "source", value = "maildir://~/.Mail/mail" }
-                      , { name = "postpone", value = "Drafts" }
-                      ]
-                    }
+      { accounts =
+          imports.Ini/externs.renderIni
+            { globalSection = [] : Ini.Section
+            , sections =
+              [ { name = "mail"
+                , value =
+                  [ { name = "archive", value = "Archive" }
+                  , { name = "copy-to", value = "Sent" }
+                  , { name = "default", value = "INBOX" }
+                  , { name = "from", value = "Profpatsch <mail@profpatsch.de>" }
+                  , { name = "source", value = "maildir://~/.Mail/mail" }
+                  , { name = "postpone", value = "Drafts" }
                   ]
                 }
-          , aerc =
-              imports.toIni
-                { globalSection = [] : List (NameVal Text)
-                , sections =
-                  [ { name = "filters"
-                    , value =
-                      [ { name = "text/html"
-                        , value = imports.aercFilter "html"
+              ]
+            }
+      , aerc =
+          imports.Ini/externs.renderIni
+            { globalSection = [] : Ini.Section
+            , sections =
+              [ { name = "filters"
+                , value =
+                  [ { name = "text/html", value = imports.aercFilter "html" }
+                  , let _ = "-- TODO: this awk should be taken from nix!"
+
+                    in  { name = "text/*"
+                        , value = "awk -f ${imports.aercFilter "plaintext"}"
                         }
-                      , let _ = "-- TODO: this awk should be taken from nix!"
-
-                        in  { name = "text/*"
-                            , value = "awk -f ${imports.aercFilter "plaintext"}"
-                            }
-                      ]
-                    }
                   ]
                 }
-          , binds =
+              ]
+            }
+      , binds =
+          let
+              -- keybinding and command to run
+              Key =
+                { ctrl : Bool, key : Text, cmd : Text }
+
+          in  let
+                  -- render a key to config format
+                  renderKey =
+                    λ(k : Key) →
+                      if    k.ctrl
+                      then  { name = "<C-${k.key}>", value = k.cmd }
+                      else  { name = k.key, value = k.cmd }
+
+              let
+
+                  -- render a list of keys to config format
+                  renderKeys =
+                    λ(keys : List Key) →
+                      List/map Key (Ini.NameVal Text) renderKey keys
+
               let
-                  -- keybinding and command to run
-                  Key =
-                    { ctrl : Bool, key : Text, cmd : Text }
-
-              in  let
-                      -- render a key to config format
-                      renderKey =
-                        λ(k : Key) →
-                          if    k.ctrl
-                          then  { name = "<C-${k.key}>", value = k.cmd }
-                          else  { name = k.key, value = k.cmd }
-
-                  let
-
-                      -- render a list of keys to config format
-                      renderKeys =
-                        λ(keys : List Key) →
-                          List/map Key (NameVal Text) renderKey keys
-
-                  let
-                      -- create a section whith a name and a list of keys
-                      sect =
-                        λ(section : Text) →
-                        λ(keys : List Key) →
-                          { name = section, value = renderKeys keys }
-
-                  let
-
-                      -- set key without modifiers
-                      key =
-                        λ(key : Text) → { key }
-
-                  let
-                      -- set special key without modifiers
-                      special =
-                        λ(key : Text) → { key = "<${key}>" }
-
-                  let
-                      -- no modifier
-                      none =
-                        { ctrl = False }
-
-                  let
-                      -- set control key
-                      ctrl =
-                        { ctrl = True }
-
-                  let
-                      -- set a command to execute
-                      cmd =
-                        λ(cmd : Text) → { cmd = ":${cmd}<Enter>" }
-
-                  let
-                      -- set a command, but stay on the prompt
-                      prompt =
-                        λ(cmd : Text) → { cmd = ":${cmd}<Space>" }
-
-                  let config =
-                        { globalSection =
-                            renderKeys
-                              [ ctrl ∧ key "p" ∧ cmd "prev-tab"
-                              , ctrl ∧ key "n" ∧ cmd "next-tab"
-                              , ctrl ∧ key "t" ∧ cmd "term"
-                              ]
-                        , sections =
-                          [ sect
-                              "messages"
-                              [ ctrl ∧ key "q" ∧ cmd "quit"
-                              , none ∧ special "Up" ∧ cmd "prev"
-                              , none ∧ special "Down" ∧ cmd "next"
-                              , none ∧ special "PgUp" ∧ cmd "prev 100%"
-                              , none ∧ special "PgDn" ∧ cmd "next 100%"
-                              , none ∧ key "g" ∧ cmd "select 0"
-                              , none ∧ key "G" ∧ cmd "select -1"
-                              , ctrl ∧ key "Up" ∧ cmd "prev-folder"
-                              , ctrl ∧ key "Down" ∧ cmd "next-folder"
-                              , none ∧ key "v" ∧ cmd "mark -t"
-                              , none ∧ key "V" ∧ cmd "mark -v"
-                              , none ∧ special "Enter" ∧ cmd "view"
-                              , none ∧ key "c" ∧ cmd "compose"
-                              , none ∧ key "|" ∧ prompt "pipe"
-                              , none ∧ key "t" ∧ prompt "term"
-                              , none ∧ key "/" ∧ prompt "search"
-                              , none ∧ key "n" ∧ cmd "next-result"
-                              , none ∧ key "N" ∧ cmd "prev-result"
-                              , none ∧ special "Esc" ∧ cmd "clear"
-                              ]
-                          , sect "view" [ none ∧ key "q" ∧ cmd "close" ]
+                  -- create a section whith a name and a list of keys
+                  sect =
+                    λ(section : Text) →
+                    λ(keys : List Key) →
+                      { name = section, value = renderKeys keys }
+
+              let
+
+                  -- set key without modifiers
+                  key =
+                    λ(key : Text) → { key }
+
+              let
+                  -- set special key without modifiers
+                  special =
+                    λ(key : Text) → { key = "<${key}>" }
+
+              let
+                  -- no modifier
+                  none =
+                    { ctrl = False }
+
+              let
+                  -- set control key
+                  ctrl =
+                    { ctrl = True }
+
+              let
+                  -- set a command to execute
+                  cmd =
+                    λ(cmd : Text) → { cmd = ":${cmd}<Enter>" }
+
+              let
+                  -- set a command, but stay on the prompt
+                  prompt =
+                    λ(cmd : Text) → { cmd = ":${cmd}<Space>" }
+
+              let config =
+                    { globalSection =
+                        renderKeys
+                          [ ctrl ∧ key "p" ∧ cmd "prev-tab"
+                          , ctrl ∧ key "n" ∧ cmd "next-tab"
+                          , ctrl ∧ key "t" ∧ cmd "term"
                           ]
-                        }
+                    , sections =
+                      [ sect
+                          "messages"
+                          [ ctrl ∧ key "q" ∧ cmd "quit"
+                          , none ∧ special "Up" ∧ cmd "prev"
+                          , none ∧ special "Down" ∧ cmd "next"
+                          , none ∧ special "PgUp" ∧ cmd "prev 100%"
+                          , none ∧ special "PgDn" ∧ cmd "next 100%"
+                          , none ∧ key "g" ∧ cmd "select 0"
+                          , none ∧ key "G" ∧ cmd "select -1"
+                          , ctrl ∧ key "Up" ∧ cmd "prev-folder"
+                          , ctrl ∧ key "Down" ∧ cmd "next-folder"
+                          , none ∧ key "v" ∧ cmd "mark -t"
+                          , none ∧ key "V" ∧ cmd "mark -v"
+                          , none ∧ special "Enter" ∧ cmd "view"
+                          , none ∧ key "c" ∧ cmd "compose"
+                          , none ∧ key "|" ∧ prompt "pipe"
+                          , none ∧ key "t" ∧ prompt "term"
+                          , none ∧ key "/" ∧ prompt "search"
+                          , none ∧ key "n" ∧ cmd "next-result"
+                          , none ∧ key "N" ∧ cmd "prev-result"
+                          , none ∧ special "Esc" ∧ cmd "clear"
+                          ]
+                      , sect "view" [ none ∧ key "q" ∧ cmd "close" ]
+                      ]
+                    }
 
-                  in  imports.toIni config
-          }
+              in  imports.Ini/externs.renderIni config
+      }