blob: a51a81f968201a807ce3af5afd9e1f1aabb7e044 (
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
65
66
67
68
69
70
71
|
/* genmddeps.cc - creates a makefile dependency fragment for the md file.
Copyright (C) 2004-2023 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, 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; see the file COPYING3. If not see
<http://www.gnu.org/licenses/>. */
#include "bconfig.h"
#include "system.h"
#include "coretypes.h"
#include "errors.h"
#include "statistics.h"
#include "vec.h"
#include "read-md.h"
struct filedep
{
struct filedep *next;
const char *pathname;
};
static struct filedep *deps, **last = &deps;
static void
add_filedep (const char *pathname)
{
struct filedep *n = XNEW (struct filedep);
n->pathname = pathname;
*last = n;
last = &n->next;
}
int
main (int argc, const char **argv)
{
struct filedep *d;
progname = "genmddeps";
include_callback = add_filedep;
noop_reader reader;
if (!reader.read_md_files (argc, argv, NULL))
return FATAL_EXIT_CODE;
*last = NULL;
/* Output a variable containing all of the include files. */
fputs ("MD_INCLUDES =", stdout);
for (d = deps; d ; d = d->next)
printf (" \\\n\t%s", d->pathname);
putchar ('\n');
/* Output make targets for these includes with empty actions. This
will guard against make errors when includes are removed. */
for (d = deps; d ; d = d->next)
printf ("\n%s:\n", d->pathname);
fflush (stdout);
return (ferror (stdout) != 0 ? FATAL_EXIT_CODE : SUCCESS_EXIT_CODE);
}
|