4.7. kink/CONFIG_FUN_RUNNER

Read simple configuration from a config function as a map.

Example:

:CONFIG_FUN_RUNNER.require_from('kink/')

:open_file <- {(:Config.opt)
  :config = Config.just_or{ {} }
  :Map = _run_config_fun($config)

  :Append? = Map.have_key?('append')
  stdout.print('Append? = {}'.format(Append?.repr))

  Map.get_maybe('buffer').with_just_or(
    {(:Buf_size)
      stdout.print(', Buffer size = {}'.format(Buf_size))
    }
    { stdout.print(', No buffer') }
  )

  Map.get_maybe('newline').with_just_or(
    {(:Newline)
      stdout.print_line(', Newline = {}'.format(Newline.repr))
    }
    { stdout.print_line(', No newline') }
  )
}

:_run_config_fun <- CONFIG_FUN_RUNNER.new{(:Rc)
  Rc.no_arg('append')
  Rc.opt_arg('buffer' { 2048 })
  Rc.req_arg('newline')
}

open_file
# => Append? = false, No buffer, No newline

open_file{(:C)
  C.append
  C.buffer(1024)
  C.newline("\n")
}
# => Append? = true, Buffer size = 1024, Newline = "\n"

open_file{(:C)
  C.buffer
}
# => Append? = false, Buffer size = 2048, No newline

4.7.1. CONFIG_FUN_RUNNER.new($runner_config_fun)

`new` makes a function to get simple setup from config functions. Methods of config values are specified by $runner_config_fun.

Precondition:

• $runner_config_fun must be a function which takes a `runner_config` value.

`new` returns a function. Let's call this a runner function. The runner function takes a config function, which takes a config value containing the methods specified by $runner_config_fun. The runner function calls the config function with a config value, and returns a result map. See methods of `runner_config` type for entries of the result map.

4.7.2. type runner_config

Config value for CONFIG_FUN_RUNNER.new.

4.7.2.1. Rc.no_arg(Method_name)

`no_arg` specifies that a config value has a method with the specified `Method_name`, and the method does not take an argument.

Precondition:

• `Method_name` must be a str.

When the created method is called for a config value, an unspecified value is set to the result map associated with `Method_name` as the key.

4.7.2.2. Rc.req_arg(Method_name ...[$validate={}])

`req_arg` specifies that a config value has a method with the specified `Method_name`, and the method takes an argument.

Preconditions:

• `Method_name` must be a str.

• $validate must be a fun which takes an argument.

When the created method is called for a config value, the argument of the method is set to the result map, associated with `Method_name` as the key.

$validate is called with the method argument before the value is set, so that it can validate the argument. If the method argument is not acceptable, $validate can raise an exception. The result of $validate is ignored.

4.7.2.3. Rc.req_fun(Method_name)

`req_fun` specifies that a config value has a method with the specified `Method_name`, the method takes an argument, and the method validates that the argument is a fun.

Besides validation, the behavior of the added method is same with one added by `req_arg`.

Precondition

• `Method_name` must be a str.

4.7.2.4. Rc.opt_arg(Method_name $make_default ...[$validate={}])

`opt_arg` specifies that a config value has a method with the specified `Method_name`, and the method takes an optional argument.

Preconditions:

• `Method_name` must be a str

• $make_default must be a thunk.

• $validate must be a fun which takes an argument.

When the created method is called with an argument, the argument is set to the result map, associated with `Method_name` as the key. If the method is called without an argument, a value created by $make_default is set to the result map, associated with `Method_name` as the key.

$validate is called with the method argument before the value is set, so that it can validate the argument. If the method argument is not acceptable, $validate can raise an exception. The result of $validate is ignored.