1 /* $NetBSD: yacc.y,v 1.9 2015/06/16 23:44:44 christos Exp $ */
5 * Copyright (c)2003 Citrus Project,
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions
11 * 1. Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
18 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
21 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30 #if HAVE_NBTOOL_CONFIG_H
31 #include "nbtool_config.h"
34 #include <sys/cdefs.h>
36 __RCSID
("$NetBSD: yacc.y,v 1.9 2015/06/16 23:44:44 christos Exp $");
47 #include <sys/types.h>
48 #include <sys/queue.h>
50 #include "citrus_namespace.h"
51 #include "citrus_types.h"
52 #include "citrus_region.h"
53 #include "citrus_esdb_file.h"
54 #include "citrus_db_hash.h"
55 #include "citrus_db_factory.h"
56 #include "citrus_lookup_factory.h"
60 static int debug
= 0, num_csids
= 0;
61 static char *output
= NULL
;
62 static char *name
, *encoding
, *variable
;
63 static u_int32_t invalid
;
64 static int use_invalid
= 0;
65 static struct named_csid_list named_csids
;
67 static void dump_file
(void);
68 static void register_named_csid
(char *, u_int32_t
);
69 static void set_prop_string
(const char *, char **, char **);
70 static void set_invalid
(u_int32_t
);
77 %token R_NAME R_ENCODING R_VARIABLE R_DEFCSID R_INVALID
79 %token
<i_value
> L_IMM
80 %token
<s_value
> L_STRING
87 property
: /* empty */
90 | property encoding R_LN
91 | property variable R_LN
92 | property defcsid R_LN
93 | property invalid R_LN
95 name
: R_NAME L_STRING
97 set_prop_string
("NAME", &name
, &$2);
100 encoding
: R_ENCODING L_STRING
102 set_prop_string
("ENCODING", &encoding
, &$2);
104 variable
: R_VARIABLE L_STRING
106 set_prop_string
("VARIABLE", &variable
, &$2);
108 defcsid
: R_DEFCSID L_STRING L_IMM
110 register_named_csid
($2, $3);
113 invalid
: R_INVALID L_IMM
120 yyerror(const char *s
)
122 fprintf
(stderr
, "%s in %d\n", s
, line_number
);
127 #define CHKERR(ret, func, a) \
131 errx
(EXIT_FAILURE
, "%s: %s", #func, strerror(ret)); \
132 } while
(/*CONSTCOND*/0)
138 struct _db_factory
*df
;
140 struct named_csid
*csid
;
148 fprintf
(stderr
, "NAME is mandatory.\n");
152 fprintf
(stderr
, "ENCODING is mandatory.\n");
161 CHKERR
(ret
, _db_factory_create
, (&df
, _db_hash_std
, NULL
));
164 CHKERR
(ret
, _db_factory_add32_by_s
, (df
, _CITRUS_ESDB_SYM_VERSION
,
165 _CITRUS_ESDB_VERSION
));
168 CHKERR
(ret
, _db_factory_addstr_by_s
, (df
, _CITRUS_ESDB_SYM_ENCODING
,
173 CHKERR
(ret
, _db_factory_addstr_by_s
,
174 (df
, _CITRUS_ESDB_SYM_VARIABLE
, variable
));
178 CHKERR
(ret
, _db_factory_add32_by_s
, (df
,
179 _CITRUS_ESDB_SYM_INVALID
,
182 /* store num of charsets */
183 CHKERR
(ret
, _db_factory_add32_by_s
, (df
, _CITRUS_ESDB_SYM_NUM_CHARSETS
,
186 SIMPLEQ_FOREACH
(csid
, &named_csids
, ci_entry
) {
187 snprintf
(buf
, sizeof
(buf
), _CITRUS_ESDB_SYM_CSNAME_PREFIX
"%d",
189 CHKERR
(ret
, _db_factory_addstr_by_s
,
190 (df
, buf
, csid
->ci_symbol
));
191 snprintf
(buf
, sizeof
(buf
), _CITRUS_ESDB_SYM_CSID_PREFIX
"%d",
193 CHKERR
(ret
, _db_factory_add32_by_s
, (df
, buf
, csid
->ci_csid
));
198 * dump database to file
201 fp
= fopen
(output
, "wb");
210 /* dump database body */
211 size
= _db_factory_calc_size
(df
);
212 serialized
= malloc
(size
);
213 _region_init
(&data
, serialized
, size
);
214 CHKERR
(ret
, _db_factory_serialize
, (df
, _CITRUS_ESDB_MAGIC
, &data
));
215 if
(fwrite
(serialized
, size
, 1, fp
) != 1)
216 err
(EXIT_FAILURE
, "fwrite");
222 set_prop_string
(const char *res
, char **store
, char **data
)
227 snprintf
(buf
, sizeof
(buf
),
228 "%s is duplicated. ignored the one", res
);
238 set_invalid
(u_int32_t inv
)
245 register_named_csid
(char *sym
, u_int32_t val
)
247 struct named_csid
*csid
;
249 SIMPLEQ_FOREACH
(csid
, &named_csids
, ci_entry
) {
250 if
(strcmp
(csid
->ci_symbol
, sym
) == 0) {
251 yyerror("multiply defined CSID");
256 csid
= malloc
(sizeof
(*csid
));
261 csid
->ci_symbol
= sym
;
263 SIMPLEQ_INSERT_TAIL
(&named_csids
, csid
, ci_entry
);
273 /* dump DB to file */
275 out
= fopen
(output
, "wb");
280 err
(EXIT_FAILURE
, "fopen");
282 ret
= _lookup_factory_convert
(out
, in
);
285 unlink
(output
); /* dump failure */
287 errc
(EXIT_FAILURE
, ret
, NULL
);
293 fprintf
(stderr
, "Usage: %s [-m] [-o outfile] [infile]\n",
299 main
(int argc
, char **argv
)
307 while
((ch
=getopt
(argc
, argv
, "do:m")) != EOF
) {
313 output
= strdup
(optarg
);
330 in
= fopen
(argv
[0], "r");
332 err
(EXIT_FAILURE
, "%s", argv
[0]);
341 SIMPLEQ_INIT
(&named_csids
);