Annotation of embedaddon/mpd/src/contrib/libpdel/structs/structs_generic.c, revision 1.1
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: #ifdef __linux__
! 43: #include <endian.h>
! 44: #else
! 45: #include <machine/endian.h>
! 46: #endif
! 47:
! 48: #include <stdio.h>
! 49: #include <stdlib.h>
! 50: #include <stdarg.h>
! 51: #include <string.h>
! 52: #include <errno.h>
! 53:
! 54: #include "structs/structs.h"
! 55: #include "structs/type/array.h"
! 56: #include "util/typed_mem.h"
! 57:
! 58: #ifndef BYTE_ORDER
! 59: #error BYTE_ORDER is undefined
! 60: #endif
! 61:
! 62: /*********************************************************************
! 63: GENERIC FUNCTIONS
! 64: *********************************************************************/
! 65:
! 66: int
! 67: structs_region_init(const struct structs_type *type, void *data)
! 68: {
! 69: memset(data, 0, type->size);
! 70: return (0);
! 71: }
! 72:
! 73: int
! 74: structs_region_copy(const struct structs_type *type, const void *from, void *to)
! 75: {
! 76: memcpy(to, from, type->size);
! 77: return (0);
! 78: }
! 79:
! 80: int
! 81: structs_region_equal(const struct structs_type *type,
! 82: const void *v1, const void *v2)
! 83: {
! 84: return (memcmp(v1, v2, type->size) == 0);
! 85: }
! 86:
! 87: int
! 88: structs_region_encode(const struct structs_type *type, const char *mtype,
! 89: struct structs_data *code, const void *data)
! 90: {
! 91: if ((code->data = MALLOC(mtype, type->size)) == NULL)
! 92: return (-1);
! 93: memcpy(code->data, data, type->size);
! 94: code->length = type->size;
! 95: return (0);
! 96: }
! 97:
! 98: int
! 99: structs_region_decode(const struct structs_type *type,
! 100: const u_char *code, size_t cmax, void *data, char *ebuf, size_t emax)
! 101: {
! 102: if (cmax < type->size) {
! 103: strlcpy(ebuf, "encoded data is truncated", emax);
! 104: errno = EINVAL;
! 105: return (-1);
! 106: }
! 107: memcpy(data, code, type->size);
! 108: return (type->size);
! 109: }
! 110:
! 111: int
! 112: structs_region_encode_netorder(const struct structs_type *type,
! 113: const char *mtype, struct structs_data *code, const void *data)
! 114: {
! 115: if (structs_region_encode(type, mtype, code, data) == -1)
! 116: return (-1);
! 117: #if BYTE_ORDER == LITTLE_ENDIAN
! 118: {
! 119: u_char temp;
! 120: u_int i;
! 121:
! 122: for (i = 0; i < code->length / 2; i++) {
! 123: temp = code->data[i];
! 124: code->data[i] = code->data[code->length - 1 - i];
! 125: code->data[code->length - 1 - i] = temp;
! 126: }
! 127: }
! 128: #endif
! 129: return (0);
! 130: }
! 131:
! 132: int
! 133: structs_region_decode_netorder(const struct structs_type *type,
! 134: const u_char *code, size_t cmax, void *data, char *ebuf, size_t emax)
! 135: {
! 136: #if BYTE_ORDER == LITTLE_ENDIAN
! 137: u_char buf[16];
! 138: u_char temp;
! 139: u_int i;
! 140:
! 141: if (type->size > sizeof(buf)) {
! 142: errno = ERANGE; /* XXX oops fixed buffer is too small */
! 143: return (-1);
! 144: }
! 145: if (cmax > type->size)
! 146: cmax = type->size;
! 147: memcpy(buf, code, cmax);
! 148: for (i = 0; i < type->size / 2; i++) {
! 149: temp = buf[i];
! 150: buf[i] = buf[type->size - 1 - i];
! 151: buf[type->size - 1 - i] = temp;
! 152: }
! 153: code = buf;
! 154: #endif
! 155: return (structs_region_decode(type, code, cmax, data, ebuf, emax));
! 156: }
! 157:
! 158: char *
! 159: structs_notsupp_ascify(const struct structs_type *type,
! 160: const char *mtype, const void *data)
! 161: {
! 162: errno = EOPNOTSUPP;
! 163: return (NULL);
! 164: }
! 165:
! 166: int
! 167: structs_notsupp_init(const struct structs_type *type, void *data)
! 168: {
! 169: errno = EOPNOTSUPP;
! 170: return (-1);
! 171: }
! 172:
! 173: int
! 174: structs_notsupp_copy(const struct structs_type *type,
! 175: const void *from, void *to)
! 176: {
! 177: errno = EOPNOTSUPP;
! 178: return (-1);
! 179: }
! 180:
! 181: int
! 182: structs_notsupp_equal(const struct structs_type *type,
! 183: const void *v1, const void *v2)
! 184: {
! 185: errno = EOPNOTSUPP;
! 186: return (-1);
! 187: }
! 188:
! 189:
! 190: int
! 191: structs_notsupp_binify(const struct structs_type *type,
! 192: const char *ascii, void *data, char *ebuf, size_t emax)
! 193: {
! 194: strlcpy(ebuf,
! 195: "parsing from ASCII is not supported by this structs type", emax);
! 196: errno = EOPNOTSUPP;
! 197: return (-1);
! 198: }
! 199:
! 200: int
! 201: structs_notsupp_encode(const struct structs_type *type, const char *mtype,
! 202: struct structs_data *code, const void *data)
! 203: {
! 204: errno = EOPNOTSUPP;
! 205: return (-1);
! 206: }
! 207:
! 208: int
! 209: structs_notsupp_decode(const struct structs_type *type,
! 210: const u_char *code, size_t cmax, void *data, char *ebuf, size_t emax)
! 211: {
! 212: strlcpy(ebuf,
! 213: "binary decoding is not supported by this structs type", emax);
! 214: errno = EOPNOTSUPP;
! 215: return (-1);
! 216: }
! 217:
! 218: void
! 219: structs_nothing_free(const struct structs_type *type, void *data)
! 220: {
! 221: return;
! 222: }
! 223:
! 224: int
! 225: structs_ascii_copy(const struct structs_type *type, const void *from, void *to)
! 226: {
! 227: char *ascii;
! 228: int rtn;
! 229:
! 230: if ((ascii = (*type->ascify)(type, TYPED_MEM_TEMP, from)) == NULL)
! 231: return (-1);
! 232: rtn = (*type->binify)(type, ascii, to, NULL, 0);
! 233: FREE(TYPED_MEM_TEMP, ascii);
! 234: return (rtn);
! 235: }
! 236:
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>