1#include "header.h"
2
3extern struct SN_env * SN_create_env(int S_size, int I_size, int B_size)
4{
5 struct SN_env * z = (struct SN_env *) calloc(1, sizeof(struct SN_env));
6 if (z == NULL) return NULL;
7 z->p = create_s();
8 if (z->p == NULL) goto error;
9 if (S_size)
10 {
11 int i;
12 z->S = (symbol * *) calloc(S_size, sizeof(symbol *));
13 if (z->S == NULL) goto error;
14
15 for (i = 0; i < S_size; i++)
16 {
17 z->S[i] = create_s();
18 if (z->S[i] == NULL) goto error;
19 }
20 }
21
22 if (I_size)
23 {
24 z->I = (int *) calloc(I_size, sizeof(int));
25 if (z->I == NULL) goto error;
26 }
27
28 if (B_size)
29 {
30 z->B = (unsigned char *) calloc(B_size, sizeof(unsigned char));
31 if (z->B == NULL) goto error;
32 }
33
34 return z;
35error:
36 SN_close_env(z, S_size);
37 return NULL;
38}
39
40extern void SN_close_env(struct SN_env * z, int S_size)
41{
42 if (z == NULL) return;
43 if (S_size)
44 {
45 int i;
46 for (i = 0; i < S_size; i++)
47 {
48 lose_s(z->S[i]);
49 }
50 free(z->S);
51 }
52 free(z->I);
53 free(z->B);
54 if (z->p) lose_s(z->p);
55 free(z);
56}
57
58extern int SN_set_current(struct SN_env * z, int size, const symbol * s)
59{
60 int err = replace_s(z, 0, z->l, size, s, NULL);
61 z->c = 0;
62 return err;
63}
64
65