Return to structs_type_regex.c CVS log | Up to [ELWIX - Embedded LightWeight unIX -] / embedaddon / libpdel / structs / type |
1.1 ! misho 1: ! 2: /* ! 3: * Copyright (c) 2001-2002 Packet Design, LLC. ! 4: * All rights reserved. ! 5: * ! 6: * Subject to the following obligations and disclaimer of warranty, ! 7: * use and redistribution of this software, in source or object code ! 8: * forms, with or without modifications are expressly permitted by ! 9: * Packet Design; provided, however, that: ! 10: * ! 11: * (i) Any and all reproductions of the source or object code ! 12: * must include the copyright notice above and the following ! 13: * disclaimer of warranties; and ! 14: * (ii) No rights are granted, in any manner or form, to use ! 15: * Packet Design trademarks, including the mark "PACKET DESIGN" ! 16: * on advertising, endorsements, or otherwise except as such ! 17: * appears in the above copyright notice or in the software. ! 18: * ! 19: * THIS SOFTWARE IS BEING PROVIDED BY PACKET DESIGN "AS IS", AND ! 20: * TO THE MAXIMUM EXTENT PERMITTED BY LAW, PACKET DESIGN MAKES NO ! 21: * REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED, REGARDING ! 22: * THIS SOFTWARE, INCLUDING WITHOUT LIMITATION, ANY AND ALL IMPLIED ! 23: * WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, ! 24: * OR NON-INFRINGEMENT. PACKET DESIGN DOES NOT WARRANT, GUARANTEE, ! 25: * OR MAKE ANY REPRESENTATIONS REGARDING THE USE OF, OR THE RESULTS ! 26: * OF THE USE OF THIS SOFTWARE IN TERMS OF ITS CORRECTNESS, ACCURACY, ! 27: * RELIABILITY OR OTHERWISE. IN NO EVENT SHALL PACKET DESIGN BE ! 28: * LIABLE FOR ANY DAMAGES RESULTING FROM OR ARISING OUT OF ANY USE ! 29: * OF THIS SOFTWARE, INCLUDING WITHOUT LIMITATION, ANY DIRECT, ! 30: * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, PUNITIVE, OR CONSEQUENTIAL ! 31: * DAMAGES, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES, LOSS OF ! 32: * USE, DATA OR PROFITS, HOWEVER CAUSED AND UNDER ANY THEORY OF ! 33: * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT ! 34: * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF ! 35: * THE USE OF THIS SOFTWARE, EVEN IF PACKET DESIGN IS ADVISED OF ! 36: * THE POSSIBILITY OF SUCH DAMAGE. ! 37: * ! 38: * Author: Archie Cobbs <archie@freebsd.org> ! 39: */ ! 40: ! 41: #include <sys/types.h> ! 42: ! 43: #include <stdlib.h> ! 44: #include <stdio.h> ! 45: #include <stdarg.h> ! 46: #include <string.h> ! 47: #include <errno.h> ! 48: #include <regex.h> ! 49: ! 50: #include "structs/structs.h" ! 51: #include "structs/type/array.h" ! 52: #include "structs/type/string.h" ! 53: #include "structs/type/regex.h" ! 54: #include "util/typed_mem.h" ! 55: ! 56: /* Pre-defined types */ ! 57: const struct structs_type structs_type_regex = ! 58: STRUCTS_REGEX_TYPE(STRUCTS_REGEX_MTYPE, REG_EXTENDED); ! 59: const struct structs_type structs_type_regex_icase = ! 60: STRUCTS_REGEX_TYPE(STRUCTS_REGEX_MTYPE, REG_EXTENDED | REG_ICASE); ! 61: ! 62: int ! 63: structs_regex_equal(const struct structs_type *type, ! 64: const void *v1, const void *v2) ! 65: { ! 66: const struct structs_regex *const r1 = v1; ! 67: const struct structs_regex *const r2 = v2; ! 68: ! 69: if (r1->pat == NULL) ! 70: return (r2->pat == NULL); ! 71: if (r2->pat == NULL) ! 72: return (0); ! 73: return (strcmp(r1->pat, r2->pat) == 0); ! 74: } ! 75: ! 76: char * ! 77: structs_regex_ascify(const struct structs_type *type, ! 78: const char *mtype, const void *data) ! 79: { ! 80: const struct structs_regex *const r = data; ! 81: ! 82: return (STRDUP(mtype, (r->pat != NULL) ? r->pat : "")); ! 83: } ! 84: ! 85: int ! 86: structs_regex_binify(const struct structs_type *type, ! 87: const char *ascii, void *data, char *ebuf, size_t emax) ! 88: { ! 89: struct structs_regex *const r = data; ! 90: const char *mtype = type->args[0].s; ! 91: const int flags = type->args[1].i; ! 92: int errno_save; ! 93: int err; ! 94: ! 95: /* Empty string? */ ! 96: if (*ascii == '\0') { ! 97: memset(r, 0, sizeof(*r)); ! 98: return (0); ! 99: } ! 100: ! 101: /* Compile pattern */ ! 102: if ((err = regcomp(&r->reg, ascii, flags)) != 0) { ! 103: regerror(err, &r->reg, ebuf, emax); ! 104: switch (err) { ! 105: case REG_ESPACE: ! 106: errno = ENOMEM; ! 107: break; ! 108: default: ! 109: errno = EINVAL; ! 110: break; ! 111: } ! 112: return (-1); ! 113: } ! 114: ! 115: /* Save a copy of the pattern string */ ! 116: if ((r->pat = STRDUP(mtype, ascii)) == NULL) { ! 117: errno_save = errno; ! 118: regfree(&r->reg); ! 119: errno = errno_save; ! 120: return (-1); ! 121: } ! 122: ! 123: /* OK */ ! 124: return (0); ! 125: } ! 126: ! 127: void ! 128: structs_regex_free(const struct structs_type *type, void *data) ! 129: { ! 130: const char *mtype = type->args[0].s; ! 131: struct structs_regex *const r = data; ! 132: ! 133: if (r->pat != NULL) { ! 134: FREE(mtype, (char *)r->pat); ! 135: regfree(&r->reg); ! 136: memset(r, 0, sizeof(*r)); ! 137: } ! 138: } ! 139: