n->value.str = xstrdup(value);
}
+static size_t cmp_operator(const char **aliases, const char *input)
+{
+ for (; *aliases; aliases++)
+ {
+ const char *cp = *aliases;
+ size_t i;
+ for (i = 0; *cp && *cp == input[i]; i++, cp++)
+ ;
+ if (*cp == '\0')
+ return i;
+ }
+ return 0;
+}
+#define REGEX_CHARS "^[]{}()|.*+?!$"
+#define CCL_CHARS "#?\\"
/**
* search_term: Parse CCL search term.
* cclp: CCL Parser
int left_trunc = 0;
int right_trunc = 0;
int regex_trunc = 0;
+ int z3958_trunc = 0;
size_t max = 200;
if (and_list || or_list || !multi)
max = 1;
{
regex_trunc = 1; /* regex trunc (102) allowed */
}
+ else if (qual_val_type(qa, CCL_BIB1_TRU, CCL_BIB1_TRU_CAN_Z3958,
+ &attset))
+ {
+ z3958_trunc = 1; /* Z39.58 trunc (CCL) trunc allowed */
+ }
/* make the RPN token */
p->u.t.term = (char *)xmalloc(len * 2 + 2);
if (p->u.t.term[0] && cclp->look_token->ws_prefix_len)
{
- size_t len = strlen(p->u.t.term);
- memcpy(p->u.t.term + len, cclp->look_token->ws_prefix_buf,
- cclp->look_token->ws_prefix_len);
- p->u.t.term[len + cclp->look_token->ws_prefix_len] = '\0';
+ strxcat(p->u.t.term, cclp->look_token->ws_prefix_buf,
+ cclp->look_token->ws_prefix_len);
}
for (j = 0; j < src_len; j++)
{
+ size_t op_size;
if (j > 0 && src_str[j-1] == '\\')
{
- if (regex_trunc && strchr("()[]?*.", src_str[j]))
+ if (regex_trunc && strchr(REGEX_CHARS "\\", src_str[j]))
{
regex_trunc = 2;
- strcat(p->u.t.term, "\\\\");
+ strcat(p->u.t.term, "\\");
+ }
+ else if (z3958_trunc && strchr(CCL_CHARS "\\", src_str[j]))
+ {
+ z3958_trunc = 2;
+ strcat(p->u.t.term, "\\");
}
strxcat(p->u.t.term, src_str + j, 1);
}
else if (src_str[j] == '"')
quote_mode = !quote_mode;
- else if (!quote_mode && src_str[j] == '?')
+ else if (!quote_mode &&
+ (op_size = cmp_operator(truncation_aliases,
+ src_str + j))
+ )
{
+ j += (op_size - 1); /* j++ in for loop */
if (regex_trunc)
{
strcat(p->u.t.term, ".*");
regex_trunc = 2; /* regex trunc is really needed */
}
+ else if (z3958_trunc)
+ {
+ strcat(p->u.t.term, "?");
+ z3958_trunc = 2;
+ }
else if (i == 0 && j == 0)
left_trunc = 1;
else if (i == no - 1 && j == src_len - 1)
strcat(p->u.t.term, ".");
regex_trunc = 2; /* regex trunc is really needed */
}
+ else if (z3958_trunc)
+ {
+ strcat(p->u.t.term, "#");
+ z3958_trunc = 2;
+ }
else
{
cclp->error_code = CCL_ERR_TRUNC_NOT_BOTH;
}
else if (src_str[j] != '\\')
{
- if (regex_trunc && strchr("()[]?*.", src_str[j]))
+ if (regex_trunc && strchr(REGEX_CHARS, src_str[j]))
{
regex_trunc = 2;
- strcat(p->u.t.term, "\\\\");
+ strcat(p->u.t.term, "\\");
+ }
+ else if (z3958_trunc && strchr(CCL_CHARS, src_str[j]))
+ {
+ z3958_trunc = 2;
+ strcat(p->u.t.term, "\\");
}
strxcat(p->u.t.term, src_str + j, 1);
}
{
ccl_add_attr_numeric(p, attset, CCL_BIB1_TRU, 102);
}
+ else if (z3958_trunc == 2)
+ {
+ ccl_add_attr_numeric(p, attset, CCL_BIB1_TRU, 104);
+ }
else
{
if (qual_val_type(qa, CCL_BIB1_TRU, CCL_BIB1_TRU_CAN_NONE,