From 16bbd13af7244cc0967d9f12327f63ffcaeac4bd Mon Sep 17 00:00:00 2001 From: Daniel Stenberg Date: Wed, 13 Jul 2005 18:06:40 +0000 Subject: Diego Casorran patches to make (lib)curl build fine on Amiga again --- lib/amigaos.c | 55 ++++++++++++++++++++++++++++++++++++++-------------- lib/amigaos.h | 14 +++++++++---- lib/config-amigaos.h | 5 ++++- lib/if2ip.c | 3 ++- lib/makefile.amiga | 6 +++--- lib/mprintf.c | 3 +++ 6 files changed, 62 insertions(+), 24 deletions(-) (limited to 'lib') diff --git a/lib/amigaos.c b/lib/amigaos.c index 13336ce05..95442a533 100644 --- a/lib/amigaos.c +++ b/lib/amigaos.c @@ -22,28 +22,53 @@ ***************************************************************************/ #include "amigaos.h" -#include /* for stderr */ +#include struct Library *SocketBase = NULL; +extern int errno, h_errno; + +#ifdef __libnix__ +#include +void __request(const char *msg); +#else +# define __request( msg ) Printf( msg "\n\a") +#endif void amiga_cleanup() { - if(SocketBase) - CloseLibrary(SocketBase); - - SocketBase = NULL; + if(SocketBase) { + CloseLibrary(SocketBase); + SocketBase = NULL; + } } BOOL amiga_init() { - if(!SocketBase) - SocketBase = OpenLibrary("bsdsocket.library", 4); - - if(!SocketBase) { - fprintf(stderr, "No TCP/IP Stack running!\n\a"); - return FALSE; - } - - atexit(amiga_cleanup); - return TRUE; + if(!SocketBase) + SocketBase = OpenLibrary("bsdsocket.library", 4); + + if(!SocketBase) { + __request("No TCP/IP Stack running!"); + return FALSE; + } + + if(SocketBaseTags( + SBTM_SETVAL(SBTC_ERRNOPTR(sizeof(errno))), (ULONG) &errno, +// SBTM_SETVAL(SBTC_HERRNOLONGPTR), (ULONG) &h_errno, + SBTM_SETVAL(SBTC_LOGTAGPTR), (ULONG) "cURL", + TAG_DONE)) { + + __request("SocketBaseTags ERROR"); + return FALSE; + } + +#ifndef __libnix__ + atexit(amiga_cleanup); +#endif + + return TRUE; } + +#ifdef __libnix__ +ADD2EXIT(amiga_cleanup,-50); +#endif diff --git a/lib/amigaos.h b/lib/amigaos.h index 0196eece7..a859ef77c 100644 --- a/lib/amigaos.h +++ b/lib/amigaos.h @@ -32,13 +32,19 @@ #include #include -#include +#include #include "config-amigaos.h" -#define select(args...) WaitSelect( args, NULL) -#define inet_ntoa(x) Inet_NtoA( x ## .s_addr) -#define ioctl(a,b,c,d) IoctlSocket( (LONG)a, (ULONG)b, (char*)c) +#ifndef select +# define select(args...) WaitSelect( args, NULL) +#endif +#ifndef inet_ntoa +# define inet_ntoa(x) Inet_NtoA( x ## .s_addr) +#endif +#ifndef ioctl +# define ioctl(a,b,c,d) IoctlSocket( (LONG)a, (ULONG)b, (char*)c) +#endif #define _AMIGASF 1 extern void amiga_cleanup(); diff --git a/lib/config-amigaos.h b/lib/config-amigaos.h index 88779753d..2bc7c424a 100644 --- a/lib/config-amigaos.h +++ b/lib/config-amigaos.h @@ -54,6 +54,7 @@ #define HAVE_UTIME_H 1 #define HAVE_WRITABLE_ARGV 1 #define HAVE_ZLIB_H 1 +#define HAVE_SYS_IOCTL_H 1 #define USE_OPENSSL 1 #define USE_SSLEAY 1 @@ -80,7 +81,9 @@ #define TIME_WITH_SYS_TIME 1 #define in_addr_t int -#define socklen_t int +#ifndef socklen_t +# define socklen_t int +#endif #ifndef O_RDONLY # define O_RDONLY 0x0000 diff --git a/lib/if2ip.c b/lib/if2ip.c index 26b4fae0a..c975ae200 100644 --- a/lib/if2ip.c +++ b/lib/if2ip.c @@ -34,7 +34,8 @@ #include "if2ip.h" #if !defined(WIN32) && !defined(__BEOS__) && !defined(__CYGWIN32__) && \ - !defined(__riscos__) && !defined(__INTERIX) && !defined(NETWARE) + !defined(__riscos__) && !defined(__INTERIX) && !defined(NETWARE) && \ + !defined(_AMIGASF) #ifdef HAVE_SYS_SOCKET_H #include diff --git a/lib/makefile.amiga b/lib/makefile.amiga index 71a172979..49cb80cf1 100644 --- a/lib/makefile.amiga +++ b/lib/makefile.amiga @@ -7,8 +7,8 @@ ATCPSDKI= /GG/netinclude -CC = gcc -CFLAGS = -I$(ATCPSDKI) -m68020-60 -noixemul -I. -I../include -W -Wall +CC = m68k-amigaos-gcc +CFLAGS = -I$(ATCPSDKI) -m68020-60 -O2 -msoft-float -noixemul -g -I. -I../include -W -Wall OBJS = amigaos.c base64.c connect.c content_encoding.c cookie.c dict.c easy.c \ escape.c file.c formdata.c ftp.c getenv.c getinfo.c hash.c hostip.c \ @@ -17,7 +17,7 @@ OBJS = amigaos.c base64.c connect.c content_encoding.c cookie.c dict.c easy.c \ ldap.c llist.c md5.c memdebug.c mprintf.c multi.c netrc.c parsedate.c \ progress.c security.c select.c sendf.c share.c speedcheck.c ssluse.c \ strequal.c strtok.c telnet.c timeval.c transfer.c url.c version.c \ - sslgen.c gtls.c + sslgen.c gtls.c strerror.c all: $(OBJS:.c=.o) ar cru libcurl.a $(OBJS:.c=.o) diff --git a/lib/mprintf.c b/lib/mprintf.c index b9fe238f9..598ea7626 100644 --- a/lib/mprintf.c +++ b/lib/mprintf.c @@ -75,6 +75,9 @@ # define BOOL char #endif +#ifdef _AMIGASF +# undef FORMAT_INT +#endif /* Lower-case digits. */ static const char lower_digits[] = "0123456789abcdefghijklmnopqrstuvwxyz"; -- cgit v1.2.3