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
|
#! @PERL@
# -*- Perl -*-
# @configure_input@
eval 'case $# in 0) exec @PERL@ -S "$0";; *) exec @PERL@ -S "$0" "$@";; esac'
if 0;
# Convert an ASCII text into the declaration of a C++ array.
# Copyright (C) 2001-2010 Roberto Bagnara <bagnara@cs.unipr.it>
# Copyright (C) 2010-2011 BUGSENG srl (http://bugseng.com)
#
# This file is part of the Parma Polyhedra Library (PPL).
#
# The PPL 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.
#
# The PPL 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, write to the Free Software Foundation,
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1307, USA.
#
# For the most up-to-date information see the Parma Polyhedra Library
# site: http://www.cs.unipr.it/ppl/ .
use Getopt::Long;
sub usage {
print STDERR <<EOF;
Convert ASCII text into the declaration of a C++ array.
Usage: text2cxxarray [OPTIONS] [FILE ...]
[FILE ...] ASCII text file(s) to convert.
[OPTIONS]
--name=NAME Use NAME as the array name.
-h, --help Display this help message.
EOF
exit 1;
}
my $array_name = "a";
GetOptions(
'name=s' => \$array_name,
'help|h' => \&usage,
) || usage();
print "extern const char* const $array_name" . "[] = {\n";
while (<>) {
chop;
s/\\/\\\\/g;
s/\t/\\t/g;
s/\"/\\"/g;
print " \"$_\",\n";
}
print " 0";
print "};\n";
|