summaryrefslogtreecommitdiff
path: root/lib/cmdline.c
blob: 393f7d300b742c022b708230c73506bb3a7bd565 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
# cmdline.c: routines to help in parsing command lines.
#
# Copyright (C) 1992, 2011 Free Software Foundation, Inc.
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
#


#include "config.h"

#include "cmdline.h"


/* This routine takes a string L consisting of unsigned integers
   separated by commas and returns a vector of the integers, as numbers.
   A element is appended to the vector.  */

int *
scan_unsigned_list (string l)
{
  string map;
  unsigned length = 1;
  int *vector = xmalloc (sizeof (int));
  
  for (map = strtok (l, ","); map != NULL; map = strtok (NULL, ","))
    {
      length++;
      vector = xrealloc (vector, length * sizeof (int));
      vector[length - 2] = atou (map);
      if (vector[length - 2] < 0)
        WARNING1 ("Unsigned number %u is too large", vector[length - 2]);
    }
  
  vector[length - 1] = -1;
  return vector;
}


/* Return the <number> substring in `<name>.<number><stuff>', if S has
   that form.  If it doesn't, return NULL.  */

string
find_dpi (string s)
{
  unsigned dpi_number;
  string extension = strrchr (s, '.');
  
  if (extension != NULL)
    if (sscanf (extension + 1, "%u", &dpi_number) == 1)
      return utoa (dpi_number);

  return NULL;
}