Skip to content

brainbot-com/clj-iniconfig

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

34 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

iniconfig

A minimal Clojure library designed to read ini files. It uses the number sign # as comment character and allows multi-line values.

Installation

iniconfig artifacts are released to Clojars.

If you are using Leiningen, add the following to your project.clj's dependencies:

	[com.brainbot/iniconfig "0.2.0"]

Usage

iniconfig has only one namespace com.brainbot.iniconfig with two public functions:

=> (require '[com.brainbot.iniconfig :as iniconfig])

read-ini [in] will read an ini file:

=> (spit "test.ini" "[main]\nmsg = foo\n  bar\n[email]\nfrom = [email protected]")
=> (iniconfig/read-ini "test.ini")
{"email" {"from" "[email protected]"}, "main" {"msg" "foo\n  bar"}}

read-ini tries to coerce it's in argument with clojure.java.io/reader. Please consult the io/reader documentaton for further details.

As an example it's also possible to load an ini file via HTTP:

=> (iniconfig/read-ini "https://raw.github.com/brainbot-com/clj-iniconfig/master/example.ini")
{"testenv" {"sitepackages" "False", "commands" "py.test []", "deps" "pytest>=2.3\n\t webtest # this is part of the value, not a comment\n\t beautifulsoup4"}, "tox" {"envlist" "py25,py26,py27,py32,py33"}}

read-ini-string [s] will parse an ini file supplied as string:

=> (iniconfig/read-ini-string "[main]\nmsg = foo\n  bar\n[email]\nfrom = [email protected]")
{"email" {"from" "[email protected]"}, "main" {"msg" "foo\n  bar"}}

Both functions set the metadata field :source, which might be useful for error reporting:

=> (meta (iniconfig/read-ini "test.ini"))
{:source "test.ini"}

=> (meta (iniconfig/read-ini-string "[main]\nmsg = foo\n  bar\n[email]\nfrom = [email protected]"))
{:source string}

ini file syntax

iniconfig uses the following syntax for ini files:

  • The number sign # is used as a comment character. Lines starting with # or whitespace followed by # are interpreted as comments.

  • Lines starting with [, followed by an identifier, followed by ] start a new section. A comment may follow on the same line.

  • Lines starting with an identifier, followed by an equal sign = define a key with it's accompanying value.

  • Lines starting with whitespace, followed by a non-whitespace character that is not the number sign #, continue the previous value declaration, i.e. they can be used for multi-line values.

  • Keys must be unique inside a section. Section identifiers must also be unique.

example configuration file

[tox] # a comment after section declaration is fine
envlist = py25,py26,py27,py32,py33

[testenv]
# deps is a multi-line value
deps=pytest>=2.3
	 webtest # this is part of the value, not a comment
# this is a comment
	 beautifulsoup4
commands=py.test []
sitepackages=False

It's probably best to put comments on a dedicated line with # in the first column.

License

Copyright © 2013 brainbot technologies AG

Distributed under the Eclipse Public License, the same as Clojure.

About

simple .ini file parser in clojure

Resources

Stars

Watchers

Forks

Packages

No packages published