-/** Read a sequence of key / value pairs from a text stream;
- * the keys are the first words on the line, and the values are
- * the remainder of the line following the key. Lines beginning
- * with # are ignored.
- * @param s Stream to read.
- * @return key/value pairs.
- */
-multimap<string, string>
-read_key_value (istream &s)
-{
- multimap<string, string> kv;
-
- string line;
- while (getline (s, line)) {
- if (line.empty ()) {
- continue;
- }
-
- if (line[0] == '#') {
- continue;
- }
-
- if (line[line.size() - 1] == '\r') {
- line = line.substr (0, line.size() - 1);
- }
-
- size_t const s = line.find (' ');
- if (s == string::npos) {
- continue;
- }
-
- kv.insert (make_pair (line.substr (0, s), line.substr (s + 1)));
- }
-
- return kv;
-}
-
-string
-get_required_string (multimap<string, string> const & kv, string k)
-{
- if (kv.count (k) > 1) {
- throw StringError (N_("unexpected multiple keys in key-value set"));
- }
-
- multimap<string, string>::const_iterator i = kv.find (k);
-
- if (i == kv.end ()) {
- throw StringError (String::compose (_("missing key %1 in key-value set"), k));
- }
-
- return i->second;
-}
-
-int
-get_required_int (multimap<string, string> const & kv, string k)
-{
- string const v = get_required_string (kv, k);
- return raw_convert<int> (v);
-}
-
-float
-get_required_float (multimap<string, string> const & kv, string k)
-{
- string const v = get_required_string (kv, k);
- return raw_convert<float> (v);
-}
-
-string
-get_optional_string (multimap<string, string> const & kv, string k)
-{
- if (kv.count (k) > 1) {
- throw StringError (N_("unexpected multiple keys in key-value set"));
- }
-
- multimap<string, string>::const_iterator i = kv.find (k);
- if (i == kv.end ()) {
- return N_("");
- }
-
- return i->second;
-}
-
-int
-get_optional_int (multimap<string, string> const & kv, string k)
-{
- if (kv.count (k) > 1) {
- throw StringError (N_("unexpected multiple keys in key-value set"));
- }
-
- multimap<string, string>::const_iterator i = kv.find (k);
- if (i == kv.end ()) {
- return 0;
- }
-
- return raw_convert<int> (i->second);
-}
-