aboutsummaryrefslogtreecommitdiff
path: root/etc/flncat.c
blob: d8b6f5848cdd0fe72bfd04569d75782fd9027159 (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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
/* This file is part of Eclat.
   Copyright (C) 2012-2021 Sergey Poznyakoff.
 
   Eclat 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.
 
   Eclat 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 Eclat.  If not, see <http://www.gnu.org/licenses/>. */

#include <stdio.h>
#include <ctype.h>
#include <assert.h>

int
comment(FILE *fp, int c, int echo)
{
	if (c != '/') {
		ungetc(c, fp);
		return 0;
	} else if (echo)
		fputc(c, stdout);
	
	if ((c = getc(fp)) == '/') {
		do
			if (echo) fputc(c, stdout);
		while ((c = getc(fp)) != EOF && c != '\n');
		return 1;
	}

	if (echo)
		fputc(c, stdout);
	
	if (c == '*') {
		do {
			do {
				c = getc(fp);
				if (c == EOF)
					return 0;
				else if (echo)
					fputc(c, stdout);
			} while (c != '*');
			c = getc(fp);
			if (echo)
				fputc(c, stdout);
		} while (c != '/');
		return 1;
	} else 

	if (!echo) {
		ungetc(c, fp);
		ungetc('/', fp);
	}
	return 0;
}

int
main(int argc, char **argv)
{
	int i;
	FILE *fp;
	int c;
	char buf[128];
	size_t lev = 0;
	int outchars = 0;
	
	for (i = 1; i < argc; i++) {
		fp = fopen(*++argv, "r");
		if (!fp) {
			perror(*argv);
			return 1;
		}

		/* Skip initial whitespace and comment lines, unless it is the
		   first file we process. */
		do {
			while ((c = fgetc(fp)) != EOF && isspace(c))
				if (i == 1) fputc(c, stdout);
		} while (c != EOF && comment(fp, c, i == 1));

		if (c != EOF) {
			if (outchars) {
				printf(" else ");
				outchars = 0;
			}

			while ((c = fgetc(fp)) != EOF) {
				outchars = 1;
				putchar(c);
				if (c == '}') {
					lev = 0;
					while ((c = fgetc(fp)) != EOF &&
					       isspace(c)) {
						assert(lev < sizeof(buf));
						buf[lev++] = c;
					}
					if (c == EOF)
						break;
					else {
						assert(lev < sizeof(buf));
						buf[lev++] = c;
						fwrite(buf, lev, 1, stdout);
					}
				}
			}
		}
		fclose(fp);
	}
	return 0;
}

Return to:

Send suggestions and report system problems to the System administrator.