2022-08-20 02:34:02 +02:00
|
|
|
{-# LANGUAGE QuasiQuotes #-}
|
|
|
|
|
|
|
|
module ArglibNetencode where
|
|
|
|
|
2023-05-28 20:58:20 +02:00
|
|
|
import Data.Attoparsec.ByteString qualified as Atto
|
2022-08-20 02:34:02 +02:00
|
|
|
import ExecHelpers
|
2023-05-28 20:58:20 +02:00
|
|
|
import Label
|
|
|
|
import Netencode qualified
|
|
|
|
import PossehlAnalyticsPrelude
|
|
|
|
import System.Posix.Env.ByteString qualified as ByteEnv
|
2022-08-20 02:34:02 +02:00
|
|
|
|
2023-05-28 20:58:20 +02:00
|
|
|
arglibNetencode :: CurrentProgramName -> Maybe (Label "arglibEnvvar" Text) -> IO Netencode.T
|
2022-08-20 02:34:02 +02:00
|
|
|
arglibNetencode progName mEnvvar = do
|
2023-05-28 20:58:20 +02:00
|
|
|
let envvar = mEnvvar <&> (.arglibEnvvar) & fromMaybe "ARGLIB_NETENCODE" & textToBytesUtf8
|
2022-08-20 02:34:02 +02:00
|
|
|
ByteEnv.getEnv envvar >>= \case
|
|
|
|
Nothing -> dieUserError progName [fmt|could not read args, envvar {envvar} not set|]
|
|
|
|
Just bytes ->
|
|
|
|
case Atto.parseOnly (Netencode.netencodeParser <* Atto.endOfInput) bytes of
|
|
|
|
Left err -> dieEnvironmentProblem progName [fmt|arglib parsing error: {err}|]
|
|
|
|
Right t -> do
|
|
|
|
ByteEnv.unsetEnv envvar
|
|
|
|
pure t
|