]>
git.saurik.com Git - bison.git/blob - src/location.c
3 Copyright (C) 2002, 2005, 2006, 2007, 2008, 2009, 2010 Free
4 Software Foundation, Inc.
6 This file is part of Bison, the GNU Compiler Compiler.
8 This program is free software: you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation, either version 3 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program. If not, see <http://www.gnu.org/licenses/>. */
30 location
const empty_location
= EMPTY_LOCATION_INIT
;
32 /* If BUF is null, add BUFSIZE (which in this case must be less than
33 INT_MAX) to COLUMN; otherwise, add mbsnwidth (BUF, BUFSIZE, 0) to
34 COLUMN. If an overflow occurs, or might occur but is undetectable,
35 return INT_MAX. Assume COLUMN is nonnegative. */
38 add_column_width (int column
, char const *buf
, size_t bufsize
)
41 unsigned int remaining_columns
= INT_MAX
- column
;
45 if (INT_MAX
/ 2 <= bufsize
)
47 width
= mbsnwidth (buf
, bufsize
, 0);
52 return width
<= remaining_columns
? column
+ width
: INT_MAX
;
55 /* Set *LOC and adjust scanner cursor to account for token TOKEN of
59 location_compute (location
*loc
, boundary
*cur
, char const *token
, size_t size
)
62 int column
= cur
->column
;
63 char const *p0
= token
;
64 char const *p
= token
;
65 char const *lim
= token
+ size
;
69 for (p
= token
; p
< lim
; p
++)
73 line
+= line
< INT_MAX
;
79 column
= add_column_width (column
, p0
, p
- p0
);
80 column
= add_column_width (column
, NULL
, 8 - ((column
- 1) & 7));
89 cur
->column
= column
= add_column_width (column
, p0
, p
- p0
);
93 if (line
== INT_MAX
&& loc
->start
.line
!= INT_MAX
)
94 warn_at (*loc
, _("line number overflow"));
95 if (column
== INT_MAX
&& loc
->start
.column
!= INT_MAX
)
96 warn_at (*loc
, _("column number overflow"));
100 /* Output to OUT the location LOC.
101 Warning: it uses quotearg's slot 3. */
103 location_print (FILE *out
, location loc
)
106 int end_col
= 0 != loc
.end
.column
? loc
.end
.column
- 1 : 0;
107 res
+= fprintf (out
, "%s",
108 quotearg_n_style (3, escape_quoting_style
, loc
.start
.file
));
109 if (0 <= loc
.start
.line
)
111 res
+= fprintf(out
, ":%d", loc
.start
.line
);
112 if (0 <= loc
.start
.column
)
113 res
+= fprintf (out
, ".%d", loc
.start
.column
);
115 if (loc
.start
.file
!= loc
.end
.file
)
117 res
+= fprintf (out
, "-%s",
118 quotearg_n_style (3, escape_quoting_style
,
120 if (0 <= loc
.end
.line
)
122 res
+= fprintf(out
, ":%d", loc
.end
.line
);
124 res
+= fprintf (out
, ".%d", end_col
);
127 else if (0 <= loc
.end
.line
)
129 if (loc
.start
.line
< loc
.end
.line
)
131 res
+= fprintf (out
, "-%d", loc
.end
.line
);
133 res
+= fprintf (out
, ".%d", end_col
);
135 else if (0 <= end_col
&& loc
.start
.column
< end_col
)
136 res
+= fprintf (out
, "-%d", end_col
);
143 boundary_set_from_string (boundary
*bound
, char *loc_str
)
145 /* Must search in reverse since the file name field may
146 * contain `.' or `:'. */
147 char *delim
= strrchr (loc_str
, '.');
150 bound
->column
= atoi (delim
+1);
151 delim
= strrchr (loc_str
, ':');
154 bound
->line
= atoi (delim
+1);
155 bound
->file
= uniqstr_new (loc_str
);