/* * Copyright (c) 2015 Carsten Larsen * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * */ #ifndef NTIMED_COMPILER_H #define NTIMED_COMPILER_H /* * See alse: * http://codewiz.org/projects/amiga/Headers/CompilerSpecific.h * */ #ifdef __VBCC__ #include #include #define nan(p) NAN #define __inline #define __printflike(a, b) #define round(x) x > 0.0 ? floor(x + 0.5) : ceil(x - 0.5) typedef uint32_t register_t; #endif #ifdef __GNUC__ #ifdef AOS3 /* * GCC 2.95.3 */ #include #include #include typedef unsigned char uint8_t; typedef unsigned short uint16_t; typedef unsigned int uint32_t; typedef unsigned long long uint64_t; typedef uint32_t uintptr_t; static inline double round(double x) { return x > 0.0 ? floor(x + 0.5) : ceil(x - 0.5); } #define nan(p) 0./0. #endif #ifdef AROS #include typedef uint32_t register_t; #endif #endif #ifndef _ALIGNBYTES #define _ALIGNBYTES (sizeof(register_t) - 1) #define ALIGN(p) (((uintptr_t)(p) + _ALIGNBYTES) & ~_ALIGNBYTES) #endif #ifdef __GNUC__ typedef unsigned int sa_family_t; typedef unsigned int socklen_t; typedef uint16_t in_port_t; #endif // General socket address holding structure, big enough to hold either // struct sockaddr_in or struct sockaddr_in6 data: struct sockaddr_storage { sa_family_t ss_family; // address family // all this is padding, implementation specific, ignore it: char __ss_pad1[128 - sizeof(sa_family_t)]; }; #endif