]> git.saurik.com Git - bison.git/blame - src/location.h
Use ASCII for Sebastien Fricker's name.
[bison.git] / src / location.h
CommitLineData
0c15323d 1/* Locations for Bison
28e52c0d 2 Copyright (C) 2002, 2004, 2005, 2006, 2007 Free Software Foundation, Inc.
0c15323d
AD
3
4 This file is part of Bison, the GNU Compiler Compiler.
5
6 Bison is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2, or (at your option)
9 any later version.
10
11 Bison is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with Bison; see the file COPYING. If not, write to
0fb669f9
PE
18 the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
19 Boston, MA 02110-1301, USA. */
0c15323d
AD
20
21#ifndef LOCATION_H_
22# define LOCATION_H_
23
dca81a78
PE
24# include "uniqstr.h"
25
8f759107
PE
26/* A boundary between two characters. */
27typedef struct
0c15323d 28{
8f759107 29 /* The name of the file that contains the boundary. */
dca81a78 30 uniqstr file;
8f759107 31
4517da37
PE
32 /* The (origin-1) line that contains the boundary.
33 If this is INT_MAX, the line number has overflowed. */
8f759107
PE
34 int line;
35
36 /* The (origin-1) column just after the boundary. This is neither a
4517da37
PE
37 byte count, nor a character count; it is a column count.
38 If this is INT_MAX, the column number has overflowed. */
8f759107
PE
39 int column;
40
41} boundary;
42
e9071366
AD
43/* Set the position of \a a. */
44static inline void
45boundary_set (boundary *b, const char *f, int l, int c)
46{
db06f0ce
PE
47 b->file = f;
48 b->line = l;
49 b->column = c;
e9071366
AD
50}
51
8f759107
PE
52/* Return nonzero if A and B are equal boundaries. */
53static inline bool
54equal_boundaries (boundary a, boundary b)
55{
56 return (a.column == b.column
57 && a.line == b.line
dca81a78 58 && UNIQSTR_EQ (a.file, b.file));
8f759107
PE
59}
60
61/* A location, that is, a region of source code. */
62typedef struct
63{
64 /* Boundary just before the location starts. */
65 boundary start;
66
67 /* Boundary just after the location ends. */
68 boundary end;
69
69b8cc09 70} location;
8f759107 71
69b8cc09 72#define YYLTYPE location
0c15323d 73
28e52c0d 74#define EMPTY_LOCATION_INIT {{NULL, 0, 0}, {NULL, 0, 0}}
69b8cc09 75extern location const empty_location;
8f759107 76
e9071366
AD
77/* Set *LOC and adjust scanner cursor to account for token TOKEN of
78 size SIZE. */
79void location_compute (location *loc,
80 boundary *cur, char const *token, size_t size);
81
6e0f8287 82void location_print (FILE *out, location loc);
8f759107 83
3fc65ead
JD
84/* LOC_STR must be formatted as `file:line.column', it will be modified. */
85void boundary_set_from_string (boundary *bound, char *loc_str);
86
8f759107 87#endif /* ! defined LOCATION_H_ */