You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
zapashcanon 21bea19dab
4 months ago
doc add Query module 1 year ago
example add an example 1 year ago
src add `get_param_bool`, `get_param_int` and `get_param_pos_int` to the `Query` 4 months ago
test fix bug with newlines at the start of the file 1 year ago
.gitignore first commit 1 year ago
.ocamlformat update ocamlformat version 4 months ago 0.2 4 months ago add missing deps, fix license 1 year ago clean stuff 1 year ago
dune-project fix menhir lower bound 1 year ago
scfg.opam update opam file 1 year ago


scfg is an OCaml executable and library to work with the scfg configuration file format.


scfg can be installed with opam:

opam install scfg

If you don't have opam, you can install it following the how to install opam guide.

If you can't or don't want to use opam, consult the opam file for build instructions.


Using the library to parse a scfg file and reprint nicely:

open Scfg

let config =
  match Parse.from_file "config.scfg" with
  | Ok config -> config
  | Error e -> begin
    Format.eprintf "error: %s@." e;
    exit 1

let () =
  Format.printf "%a@." Pp.config config

The provided binary does exactly this. If you have the following config.scfg file:

   name "a"        "b b b" 'c' {

       child1       ""    "I'm léo"

                child2 'nono'

Running the binary on it will reprint it trying to make the output pretty:

$ scfg config.scfg
name a "b b b" c {
  child1 "" "I'm léo"
  child2 nono

For more, have a look at the example folder, at the documentation or at the test suite.