summaryrefslogtreecommitdiff
path: root/contrib/tsearch2/snowball/api.c
diff options
context:
space:
mode:
Diffstat (limited to 'contrib/tsearch2/snowball/api.c')
-rw-r--r--contrib/tsearch2/snowball/api.c42
1 files changed, 33 insertions, 9 deletions
diff --git a/contrib/tsearch2/snowball/api.c b/contrib/tsearch2/snowball/api.c
index 5cbf37d73bf..426341a360b 100644
--- a/contrib/tsearch2/snowball/api.c
+++ b/contrib/tsearch2/snowball/api.c
@@ -6,39 +6,63 @@ extern struct SN_env *
SN_create_env(int S_size, int I_size, int B_size)
{
struct SN_env *z = (struct SN_env *) calloc(1, sizeof(struct SN_env));
+ struct SN_env *z2 = z;
+
+ if (!z)
+ return z;
z->p = create_s();
- if (S_size)
+ if (!z->p)
+ z = NULL;
+
+ if (z && S_size)
{
- z->S = (symbol * *) calloc(S_size, sizeof(symbol *));
+ if ((z->S = (symbol * *) calloc(S_size, sizeof(symbol *))))
{
int i;
for (i = 0; i < S_size; i++)
- z->S[i] = create_s();
+ {
+ if (!(z->S[i] = create_s()))
+ {
+ z = NULL;
+ break;
+ }
+ }
+ z2->S_size = i;
}
- z->S_size = S_size;
+ else
+ z = NULL;
}
- if (I_size)
+ if (z && I_size)
{
z->I = (int *) calloc(I_size, sizeof(int));
- z->I_size = I_size;
+ if (z->I)
+ z->I_size = I_size;
+ else
+ z = NULL;
}
- if (B_size)
+ if (z && B_size)
{
z->B = (symbol *) calloc(B_size, sizeof(symbol));
- z->B_size = B_size;
+ if (z->B)
+ z->B_size = B_size;
+ else
+ z = NULL;
}
+ if (!z)
+ SN_close_env(z2);
+
return z;
}
extern void
SN_close_env(struct SN_env * z)
{
- if (z->S_size)
+ if (z->S && z->S_size)
{
{
int i;