filter.c
author viric@llimona
Sun, 05 Aug 2007 23:06:42 +0200
changeset 0 7f37716d4f1e
child 1 5af08d964c9e
permissions -rw-r--r--
Initial. Awful makefile.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
     1
#include <stdio.h>
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
     2
#include <stdlib.h>
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
     3
#include <sys/select.h>
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
     4
#include <sys/types.h>
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
     5
#include <sys/wait.h>
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
     6
#include <unistd.h>
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
     7
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
     8
#include "dictre.h"
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
     9
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    10
extern struct Def defs[];
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    11
extern int ndefs;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    12
extern int dont_touch[];
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    13
extern int ndont_touch;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    14
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    15
static void more_memory(void **ptr, int size)
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    16
{
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    17
    void *new;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    18
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    19
    new = realloc(*ptr, size);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    20
    *ptr = new;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    21
}
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    22
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    23
static
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    24
char * manage_filter(const char *def, int deflen, int writeto, int readfrom,
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    25
        int *outlen)
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    26
{
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    27
    int maxfd;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    28
    int defptr;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    29
    int outptr;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    30
    char *out;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    31
    int outsize;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    32
    int outrest;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    33
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    34
    out = 0;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    35
    outsize = 1000;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    36
    outptr = 0;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    37
    more_memory((void **) &out, outsize);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    38
    outrest = 1000;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    39
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    40
    maxfd = writeto;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    41
    if (readfrom > maxfd)
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    42
        maxfd = readfrom;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    43
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    44
    defptr = 0;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    45
    do
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    46
    {
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    47
        fd_set writeset, readset;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    48
        FD_ZERO(&writeset);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    49
        FD_ZERO(&readset);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    50
        if (defptr < deflen)
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    51
            FD_SET(writeto, &writeset);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    52
        FD_SET(readfrom, &readset);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    53
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    54
        select(maxfd+1, &readset, &writeset, 0, 0);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    55
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    56
        if (FD_ISSET(readfrom, &readset))
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    57
        {
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    58
            int res;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    59
            res = read(readfrom, out + outptr, outrest);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    60
            if (res == 0)
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    61
            {
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    62
                close(readfrom);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    63
                break;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    64
            }
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    65
            outrest -= res;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    66
            outptr += res;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    67
            if (outrest == 0)
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    68
            {
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    69
                outrest = 1000;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    70
                outsize += 1000;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    71
                more_memory((void **) &out, outsize);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    72
            }
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    73
        }
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    74
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    75
        if (FD_ISSET(writeto, &writeset))
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    76
        {
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    77
            int res;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    78
            res = write(writeto, def+defptr, 1);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    79
            defptr++;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    80
            if (defptr >= deflen)
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    81
                close(writeto);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    82
        }
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    83
    } while(1);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    84
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    85
    if (defptr < deflen)
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    86
    {
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    87
        fprintf(stderr, "Error in filter! not all written.\n");
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    88
        exit(-1);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    89
    }
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    90
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    91
    *outlen = outptr;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    92
    return out;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    93
}
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    94
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    95
static char * filter(char *def, int deflen, const char *filter_par, int *outlen)
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    96
{
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    97
    int write_pipe[2];
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    98
    int read_pipe[2];
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
    99
    int pid;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   100
    int res;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   101
    int status;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   102
    char *out;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   103
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   104
    pipe(write_pipe);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   105
    pipe(read_pipe);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   106
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   107
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   108
    pid = fork();
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   109
    switch(pid)
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   110
    {
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   111
        case 0:  /* child */
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   112
            close(0);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   113
            dup(write_pipe[0]);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   114
            close(write_pipe[0]);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   115
            close(write_pipe[1]);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   116
            close(1);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   117
            dup(read_pipe[1]);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   118
            close(read_pipe[1]);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   119
            close(read_pipe[0]);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   120
            execlp("bash", "bash", "-c", filter_par, 0);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   121
            perror("execlp");
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   122
            exit(-1);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   123
            break;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   124
        case -1:
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   125
            perror("fork");
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   126
            exit(-1);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   127
            break;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   128
        default:  /* parent */
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   129
            close(write_pipe[0]);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   130
            close(read_pipe[1]);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   131
            break;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   132
    }
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   133
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   134
    /* parent */
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   135
    out = manage_filter(def, deflen, write_pipe[1], read_pipe[0], outlen);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   136
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   137
    res = wait(&status);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   138
    if (res != pid || WEXITSTATUS(status) != 0)
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   139
    {
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   140
        fprintf(stderr, "Error filtering: pid=%i status=%i",
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   141
                pid, WEXITSTATUS(status));
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   142
        exit(-1);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   143
    }
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   144
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   145
    return out;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   146
}
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   147
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   148
static int in_dont_touch(int n)
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   149
{
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   150
    int i;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   151
    for(i =0; i < ndont_touch; ++i)
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   152
    {
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   153
        if (n == dont_touch[i])
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   154
        {
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   155
            return 1;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   156
        }
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   157
    }
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   158
    return 0;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   159
}
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   160
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   161
void filter_all(const char *filter_par)
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   162
{
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   163
    int i;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   164
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   165
    for(i=0; i < ndefs; ++i)
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   166
    {
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   167
        char *newdef;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   168
        int newdeflen;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   169
        if (!in_dont_touch(i))
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   170
        {
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   171
            newdef = filter(defs[i].d, defs[i].length,
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   172
                    filter_par, &newdeflen);
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   173
            defs[i].length = newdeflen;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   174
            defs[i].d = newdef;
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   175
        }
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   176
    }
7f37716d4f1e Initial. Awful makefile.
viric@llimona
parents:
diff changeset
   177
}