summaryrefslogtreecommitdiffstats
path: root/1/24.c
blob: 0e8e53f60b4a1151b1a07daab925804661c84288 (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
#include <stdio.h>

#define MAXLEN 1000
#define TRUE 1
#define FALSE 0

#define INLINE 2
#define MULTILINE 3

/* checks c program for unbalanced parentheses, brackets and braces */
int main(int argc, char *argv[]) {
  int p, c, i, comment, quote, parens, bracks, braces;

  p = 0;
  comment = quote = FALSE;
  parens = bracks = braces = 0;

  for (i = 0; i < MAXLEN - 1 && (c = getchar()) != EOF; i++) {
    if (!comment && !quote && (c == '/' || c == '*') && p == '/') {
      comment = c == '/' ? INLINE : MULTILINE;
    } else if (!comment && !quote && c == '"') {
      quote = TRUE;
    } else if (comment == INLINE && c == '\n') {
      comment = FALSE;
    } else if (comment == MULTILINE && c == '/' && p == '*') {
      comment = FALSE;
    }
    if (!comment && quote && c == '"' && p != '\\') {
      quote = FALSE;
    } else if (!comment && !quote) {
      if (c == '{')
        braces++;
      else if (c == '(')
        parens++;
      else if (c == '[')
        bracks++;
      else if (c == '}')
        braces--;
      else if (c == ')')
        parens--;
      else if (c == ']')
        bracks--;
    }

    p = c;
  }

  if (braces != 0)
    printf("err: input contains %d open braces\n", braces);
  if (parens != 0)
    printf("err: input contains %d open parentheses\n", parens);
  if (bracks != 0)
    printf("err: input contains %d open brackets\n", bracks);

  if (braces == 0 && parens == 0 && bracks == 0)
    printf("no basic syntax errors!\n");

  return 0;
}