gnunet-svn
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[libextractor] 01/03: mask SIGPIPE to avoid problems with crashing in te


From: gnunet
Subject: [libextractor] 01/03: mask SIGPIPE to avoid problems with crashing in test (should fix #6709)
Date: Sat, 30 Jan 2021 15:28:47 +0100

This is an automated email from the git hooks/post-receive script.

grothoff pushed a commit to branch master
in repository libextractor.

commit ba1b54bd1346278b9f8674aa216ec2c7c16ad32c
Author: Christian Grothoff <christian@grothoff.org>
AuthorDate: Sat Jan 30 14:21:30 2021 +0100

    mask SIGPIPE to avoid problems with crashing in test (should fix #6709)
---
 src/include/plibc.h    | 1092 ------------------------------------------------
 src/plugins/test_lib.c |   33 +-
 2 files changed, 32 insertions(+), 1093 deletions(-)

diff --git a/src/include/plibc.h b/src/include/plibc.h
deleted file mode 100644
index 9199072..0000000
--- a/src/include/plibc.h
+++ /dev/null
@@ -1,1092 +0,0 @@
-/*
-     This file is part of PlibC.
-     Copyright (C) 2005, 2006, 2007, 2008, 2009, 2010 Nils Durner (and other 
contributing authors)
-
-     This library is free software; you can redistribute it and/or
-     modify it under the terms of the GNU Lesser General Public
-     License as published by the Free Software Foundation; either
-     version 2.1 of the License, or (at your option) any later version.
-
-     This library is distributed in the hope that it will be useful,
-     but WITHOUT ANY WARRANTY; without even the implied warranty of
-     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
-     Lesser General Public License for more details.
-
-     You should have received a copy of the GNU Lesser General Public
-     License along with this library; if not, write to the Free Software
-     Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301 
 USA
-*/
-
-/**
- * @file include/plibc.h
- * @brief PlibC header
- * @attention This file is usually not installed under Unix,
- *            so ship it with your application
- * @version $Revision: 158 $
- */
-
-#ifndef _PLIBC_H_
-#define _PLIBC_H_
-
-#ifndef SIGALRM
- #define SIGALRM 14
-#endif
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#include <stddef.h>
-
-#ifdef Q_OS_WIN32
- #define WINDOWS 1
-#endif
-
-#define HAVE_PLIBC_FD 0
-
-#ifdef WINDOWS
-
-#if ENABLE_NLS
-  #include "langinfo.h"
-#endif
-
-#include <ws2tcpip.h>
-#include <windows.h>
-#include <sys/types.h>
-#include <time.h>
-#include <stdio.h>
-#include <sys/types.h>
-#include <sys/stat.h>
-#include <dirent.h>
-#include <errno.h>
-#include <stdarg.h>
-
-#define __BYTE_ORDER BYTE_ORDER
-#define __BIG_ENDIAN BIG_ENDIAN
-
-/* Conflicts with our definitions */
-#define __G_WIN32_H__
-
-/* Convert LARGE_INTEGER to double */
-#define Li2Double(x) ((double) ((x).HighPart) * 4.294967296E9   \
-                      + (double) ((x).LowPart))
-#ifndef HAVE_DECL__STATI64
-struct _stati64
-{
-  _dev_t st_dev;
-  _ino_t st_ino;
-  _mode_t st_mode;
-  short st_nlink;
-  short st_uid;
-  short st_gid;
-  _dev_t st_rdev;
-  __int64 st_size;
-  time_t st_atime;
-  time_t st_mtime;
-  time_t st_ctime;
-};
-#endif
-typedef unsigned int sa_family_t;
-
-struct sockaddr_un
-{
-  short sun_family; /*AF_UNIX*/
-  char sun_path[108]; /*path name */
-};
-
-#ifndef pid_t
-  #define pid_t DWORD
-#endif
-
-#ifndef error_t
-  #define error_t int
-#endif
-
-#ifndef WEXITSTATUS
-  #define WEXITSTATUS(status) (((status) & 0xff00) >> 8)
-#endif
-
-#ifndef MSG_DONTWAIT
-  #define MSG_DONTWAIT 0
-#endif
-
-enum
-{
-  _SC_PAGESIZE = 30,
-  _SC_PAGE_SIZE = 30
-};
-
-#if ! defined(EACCESS)
-#  define EACCESS EACCES
-#endif
-
-/* Thanks to the Cygwin project */
-#if ! defined(ENOCSI)
-#  define ENOCSI 43 /* No CSI structure available */
-#endif
-#if ! defined(EL2HLT)
-#  define EL2HLT 44 /* Level 2 halted */
-#endif
-#if ! defined(EDEADLK)
-#  define EDEADLK 45  /* Deadlock condition */
-#endif
-#if ! defined(ENOLCK)
-#  define ENOLCK 46 /* No record locks available */
-#endif
-#if ! defined(EBADE)
-#  define EBADE 50  /* Invalid exchange */
-#endif
-#if ! defined(EBADR)
-#  define EBADR 51  /* Invalid request descriptor */
-#endif
-#if ! defined(EXFULL)
-#  define EXFULL 52 /* Exchange full */
-#endif
-#if ! defined(ENOANO)
-#  define ENOANO 53 /* No anode */
-#endif
-#if ! defined(EBADRQC)
-#  define EBADRQC 54  /* Invalid request code */
-#endif
-#if ! defined(EBADSLT)
-#  define EBADSLT 55  /* Invalid slot */
-#endif
-#if ! defined(EDEADLOCK)
-#  define EDEADLOCK EDEADLK /* File locking deadlock error */
-#endif
-#if ! defined(EBFONT)
-#  define EBFONT 57 /* Bad font file fmt */
-#endif
-#if ! defined(ENOSTR)
-#  define ENOSTR 60 /* Device not a stream */
-#endif
-#if ! defined(ENODATA)
-#  define ENODATA 61  /* No data (for no delay io) */
-#endif
-#if ! defined(ETIME)
-#  define ETIME 62  /* Timer expired */
-#endif
-#if ! defined(ENOSR)
-#  define ENOSR 63  /* Out of streams resources */
-#endif
-#if ! defined(ENONET)
-#  define ENONET 64 /* Machine is not on the network */
-#endif
-#if ! defined(ENOPKG)
-#  define ENOPKG 65 /* Package not installed */
-#endif
-#if ! defined(EREMOTE)
-#  define EREMOTE 66  /* The object is remote */
-#endif
-#if ! defined(ENOLINK)
-#  define ENOLINK 67  /* The link has been severed */
-#endif
-#if ! defined(EADV)
-#  define EADV 68   /* Advertise error */
-#endif
-#if ! defined(ESRMNT)
-#  define ESRMNT 69 /* Srmount error */
-#endif
-#if ! defined(ECOMM)
-#  define ECOMM 70  /* Communication error on send */
-#endif
-#if ! defined(EMULTIHOP)
-#  define EMULTIHOP 74  /* Multihop attempted */
-#endif
-#if ! defined(ELBIN)
-#  define ELBIN 75  /* Inode is remote (not really error) */
-#endif
-#if ! defined(EDOTDOT)
-#  define EDOTDOT 76  /* Cross mount point (not really error) */
-#endif
-#if ! defined(EBADMSG)
-#  define EBADMSG 77  /* Trying to read unreadable message */
-#endif
-#if ! defined(ENOTUNIQ)
-#  define ENOTUNIQ 80 /* Given log. name not unique */
-#endif
-#if ! defined(EBADFD)
-#  define EBADFD 81 /* f.d. invalid for this operation */
-#endif
-#if ! defined(EREMCHG)
-#  define EREMCHG 82  /* Remote address changed */
-#endif
-#if ! defined(ELIBACC)
-#  define ELIBACC 83  /* Can't access a needed shared lib */
-#endif
-#if ! defined(ELIBBAD)
-#  define ELIBBAD 84  /* Accessing a corrupted shared lib */
-#endif
-#if ! defined(ELIBSCN)
-#  define ELIBSCN 85  /* .lib section in a.out corrupted */
-#endif
-#if ! defined(ELIBMAX)
-#  define ELIBMAX 86  /* Attempting to link in too many libs */
-#endif
-#if ! defined(ELIBEXEC)
-#  define ELIBEXEC 87 /* Attempting to exec a shared library */
-#endif
-#if ! defined(ENOSYS)
-#  define ENOSYS 88 /* Function not implemented */
-#endif
-#if ! defined(ENMFILE)
-#  define ENMFILE 89      /* No more files */
-#endif
-#if ! defined(ENOTEMPTY)
-#  define ENOTEMPTY 90  /* Directory not empty */
-#endif
-#if ! defined(ENAMETOOLONG)
-#  define ENAMETOOLONG 91 /* File or path name too long */
-#endif
-#if ! defined(EPFNOSUPPORT)
-#  define EPFNOSUPPORT 96 /* Protocol family not supported */
-#endif
-#if ! defined(ENOSHARE)
-#  define ENOSHARE 97        /* No such host or network path */
-#endif
-#if ! defined(ENOMEDIUM)
-#  define ENOMEDIUM 98       /* No medium (in tape drive) */
-#endif
-#if ! defined(ESHUTDOWN)
-#  define ESHUTDOWN 99  /* Can't send after socket shutdown */
-#endif
-#if ! defined(EADDRINUSE)
-#  define EADDRINUSE 100    /* Address already in use */
-#endif
-#if ! defined(EADDRNOTAVAIL)
-#  define EADDRNOTAVAIL 101 /* Address not available */
-#endif
-#if ! defined(EAFNOSUPPORT)
-#  define EAFNOSUPPORT 102 /* Address family not supported by protocol family 
*/
-#endif
-#if ! defined(EALREADY)
-#  define EALREADY 103    /* Socket already connected */
-#endif
-#if ! defined(ECANCELED)
-#  define ECANCELED 105 /* Connection cancelled */
-#endif
-#if ! defined(ECONNABORTED)
-#  define ECONNABORTED 106  /* Connection aborted */
-#endif
-#if ! defined(ECONNREFUSED)
-#  define ECONNREFUSED 107  /* Connection refused */
-#endif
-#if ! defined(ECONNRESET)
-#  define ECONNRESET 108  /* Connection reset by peer */
-#endif
-#if ! defined(EDESTADDRREQ)
-#  define EDESTADDRREQ 109  /* Destination address required */
-#endif
-#if ! defined(EHOSTUNREACH)
-#  define EHOSTUNREACH 110  /* Host is unreachable */
-#endif
-#if ! defined(ECONNABORTED)
-#  define ECONNABORTED 111  /* Connection aborted */
-#endif
-#if ! defined(EINPROGRESS)
-#  define EINPROGRESS 112   /* Connection already in progress */
-#endif
-#if ! defined(EISCONN)
-#  define EISCONN 113       /* Socket is already connected */
-#endif
-#if ! defined(ELOOP)
-#  define ELOOP 114 /* Too many symbolic links */
-#endif
-#if ! defined(EMSGSIZE)
-#  define EMSGSIZE 115    /* Message too long */
-#endif
-#if ! defined(ENETDOWN)
-#  define ENETDOWN 116    /* Network interface is not configured */
-#endif
-#if ! defined(ENETRESET)
-#  define ENETRESET 117   /* Connection aborted by network */
-#endif
-#if ! defined(ENETUNREACH)
-#  define ENETUNREACH 118   /* Network is unreachable */
-#endif
-#if ! defined(ENOBUFS)
-#  define ENOBUFS 119 /* No buffer space available */
-#endif
-#if ! defined(EHOSTDOWN)
-#  define EHOSTDOWN 120   /* Host is down */
-#endif
-#if ! defined(EPROCLIM)
-#  define EPROCLIM 121    /* Too many processes */
-#endif
-#if ! defined(EDQUOT)
-#  define EDQUOT 122      /* Disk quota exceeded */
-#endif
-#if ! defined(ENOPROTOOPT)
-#  define ENOPROTOOPT 123 /* Protocol not available */
-#endif
-#if ! defined(ESOCKTNOSUPPORT)
-#  define ESOCKTNOSUPPORT 124 /* Socket type not supported */
-#endif
-#if ! defined(ESTALE)
-#  define ESTALE 125          /* Unknown error */
-#endif
-#if ! defined(ENOTCONN)
-#  define ENOTCONN 126    /* Socket is not connected */
-#endif
-#if ! defined(ETOOMANYREFS)
-#  define ETOOMANYREFS 127  /* Too many references: cannot splice */
-#endif
-#if ! defined(ENOTSOCK)
-#  define ENOTSOCK 128  /* Socket operation on non-socket */
-#endif
-#if ! defined(ENOTSUP)
-#  define ENOTSUP 129       /* Not supported */
-#endif
-#if ! defined(EOPNOTSUPP)
-#  define EOPNOTSUPP 130  /* Operation not supported on transport endpoint */
-#endif
-#if ! defined(EUSERS)
-#  define EUSERS 131      /* Too many users */
-#endif
-#if ! defined(EOVERFLOW)
-#  define EOVERFLOW 132 /* Value too large for defined data type */
-#endif
-#if ! defined(EOWNERDEAD)
-#  define EOWNERDEAD 133          /* Unknown error */
-#endif
-#if ! defined(EPROTO)
-#  define EPROTO 134  /* Protocol error */
-#endif
-#if ! defined(EPROTONOSUPPORT)
-#  define EPROTONOSUPPORT 135 /* Unknown protocol */
-#endif
-#if ! defined(EPROTOTYPE)
-#  define EPROTOTYPE 136  /* Protocol wrong type for socket */
-#endif
-#if ! defined(ECASECLASH)
-#  define ECASECLASH 137      /* Filename exists with different case */
-#endif
-#if ! defined(ETIMEDOUT)
-/* Make sure it's the same as WSATIMEDOUT */
-#  define ETIMEDOUT 138   /* Connection timed out */
-#endif
-#if ! defined(EWOULDBLOCK) || EWOULDBLOCK == 140
-#  undef EWOULDBLOCK /* MinGW-w64 defines it as 140, but we want it as EAGAIN 
*/
-#  define EWOULDBLOCK EAGAIN  /* Operation would block */
-#endif
-
-#undef HOST_NOT_FOUND
-#define HOST_NOT_FOUND 1
-#undef TRY_AGAIN
-#define TRY_AGAIN 2
-#undef NO_RECOVERY
-#define NO_RECOVERY 3
-#undef NO_ADDRESS
-#define NO_ADDRESS 4
-
-#define PROT_READ   0x1
-#define PROT_WRITE  0x2
-#define MAP_SHARED  0x1
-#define MAP_PRIVATE 0x2 /* unsupported */
-#define MAP_FIXED   0x10
-#define MAP_ANONYMOUS 0x20 /* unsupported */
-#define MAP_FAILED  ((void *) -1)
-
-#define MS_ASYNC        1       /* sync memory asynchronously */
-#define MS_INVALIDATE   2       /* invalidate the caches */
-#define MS_SYNC         4       /* synchronous memory sync */
-
-struct statfs
-{
-  long f_type;                  /* type of filesystem (see below) */
-  long f_bsize;                 /* optimal transfer block size */
-  long f_blocks;                /* total data blocks in file system */
-  long f_bfree;                 /* free blocks in fs */
-  long f_bavail;                /* free blocks avail to non-superuser */
-  long f_files;                 /* total file nodes in file system */
-  long f_ffree;                 /* free file nodes in fs */
-  long f_fsid;                  /* file system id */
-  long f_namelen;               /* maximum length of filenames */
-  long f_spare[6];              /* spare for later */
-};
-#define sleep(secs) (Sleep (secs * 1000))
-
-/*********************** statfs *****************************/
-/* fake block size */
-#define FAKED_BLOCK_SIZE 512
-
-/* linux-compatible values for fs type */
-#define MSDOS_SUPER_MAGIC     0x4d44
-#define NTFS_SUPER_MAGIC      0x5346544E
-
-/*********************** End of statfs ***********************/
-
-#define SHUT_RDWR SD_BOTH
-
-/* Operations for flock() */
-#define LOCK_SH  1       /* shared lock */
-#define LOCK_EX  2       /* exclusive lock */
-#define LOCK_NB  4       /* or'd with one of the above to prevent
-                            blocking */
-#define LOCK_UN  8       /* remove lock */
-
-/* Not supported under MinGW */
-#ifndef S_IRGRP
-#define S_IRGRP 0
-#endif
-#ifndef S_IWGRP
-#define S_IWGRP 0
-#endif
-#ifndef S_IROTH
-#define S_IROTH 0
-#endif
-#ifndef S_IXGRP
-#define S_IXGRP 0
-#endif
-#ifndef S_IWOTH
-#define S_IWOTH 0
-#endif
-#ifndef S_IXOTH
-#define S_IXOTH 0
-#endif
-#ifndef S_ISUID
-#define S_ISUID 0
-#endif
-#ifndef S_ISGID
-#define S_ISGID 0
-#endif
-#ifndef S_ISVTX
-#define S_ISVTX 0
-#endif
-#ifndef S_IRWXG
-#define S_IRWXG 0
-#endif
-#ifndef S_IRWXO
-#define S_IRWXO 0
-#endif
-
-#define SHUT_WR SD_SEND
-#define SHUT_RD SD_RECEIVE
-#define SHUT_RDWR SD_BOTH
-
-#define SIGKILL 9
-#define SIGTERM 15
-
-#define SetErrnoFromWinError(e) _SetErrnoFromWinError (e, __FILE__, __LINE__)
-
-BOOL _plibc_CreateShortcut (const char *pszSrc, const char *pszDest);
-
-BOOL _plibc_CreateShortcutW (const wchar_t *pwszSrc, const wchar_t *pwszDest);
-
-BOOL _plibc_DereferenceShortcut (char *pszShortcut);
-
-BOOL _plibc_DereferenceShortcutW (wchar_t *pwszShortcut);
-
-char *plibc_ChooseDir (char *pszTitle, unsigned long ulFlags);
-
-wchar_t *plibc_ChooseDirW (wchar_t *pwszTitle, unsigned long ulFlags);
-
-char *plibc_ChooseFile (char *pszTitle, unsigned long ulFlags);
-
-wchar_t *plibc_ChooseFileW (wchar_t *pwszTitle, unsigned long ulFlags);
-
-long QueryRegistry (HKEY hMainKey, const char *pszKey, const char *pszSubKey,
-                    char *pszBuffer, long *pdLength);
-
-long QueryRegistryW (HKEY hMainKey, const wchar_t *pszKey, const
-                     wchar_t *pszSubKey,
-                     wchar_t *pszBuffer, long *pdLength);
-
-BOOL __win_IsHandleMarkedAsBlocking (int hHandle);
-
-void __win_SetHandleBlockingMode (int s, BOOL bBlocking);
-
-void __win_DiscardHandleBlockingMode (int s);
-
-int _win_isSocketValid (int s);
-
-int plibc_conv_to_win_path (const char *pszUnix, char *pszWindows);
-
-int plibc_conv_to_win_pathw (const wchar_t *pszUnix, wchar_t *pwszWindows);
-
-int plibc_conv_to_win_pathwconv (const char *pszUnix, wchar_t *pwszWindows);
-
-int plibc_conv_to_win_pathwconv_ex (const char *pszUnix, wchar_t *pszWindows,
-                                    int derefLinks);
-
-unsigned plibc_get_handle_count ();
-
-typedef void (*TPanicProc) (int, char *);
-void plibc_set_panic_proc (TPanicProc proc);
-
-void plibc_set_stat_size_size (int iLength);
-
-void plibc_set_stat_time_size (int iLength);
-
-int flock (int fd, int operation);
-
-int fsync (int fildes);
-
-int inet_pton (int af, const char *src, void *dst);
-
-int inet_pton4 (const char *src, u_char *dst, int pton);
-
-#if USE_IPV6
-int inet_pton6 (const char *src, u_char *dst);
-
-#endif
-int statfs (const char *path, struct statfs *buf);
-
-const char *hstrerror (int err);
-
-int mkstemp (char *tmplate);
-
-char *strptime (const char *buf, const char *format, struct tm *tm);
-
-const char *inet_ntop (int af, const void *src, char *dst, size_t size);
-
-#ifndef gmtime_r
-struct tm *gmtime_r (const time_t *clock, struct tm *result);
-
-#endif
-
-int plibc_init (char *pszOrg, char *pszApp);
-
-int plibc_init_utf8 (char *pszOrg, char *pszApp, int utf8_mode);
-
-void plibc_shutdown ();
-
-int plibc_initialized ();
-
-void _SetErrnoFromWinError (long lWinError, char *pszCaller, int iLine);
-
-void SetErrnoFromWinsockError (long lWinError);
-
-void SetHErrnoFromWinError (long lWinError);
-
-void SetErrnoFromHRESULT (HRESULT hRes);
-
-int GetErrnoFromWinsockError (long lWinError);
-
-FILE *_win_fopen (const char *filename, const char *mode);
-
-int _win_fclose (FILE *);
-
-DIR *_win_opendir (const char *dirname);
-
-struct dirent *_win_readdir (DIR *dirp);
-
-int _win_closedir (DIR *dirp);
-
-int _win_open (const char *filename, int oflag, ...);
-
-#ifdef ENABLE_NLS
-char *_win_bindtextdomain (const char *domainname, const char *dirname);
-
-#endif
-int _win_chdir (const char *path);
-
-int _win_close (int fd);
-
-int _win_creat (const char *path, mode_t mode);
-
-char *_win_ctime (const time_t *clock);
-
-char *_win_ctime_r (const time_t *clock, char *buf);
-
-int _win_fstat (int handle, struct stat *buffer);
-
-int _win_ftruncate (int fildes, off_t length);
-
-int _win_truncate (const char *fname, int distance);
-
-int _win_kill (pid_t pid, int sig);
-
-int _win_pipe (int *phandles);
-
-int _win_mkfifo (const char *path, mode_t mode);
-
-int _win_rmdir (const char *path);
-
-int _win_access (const char *path, int mode);
-
-int _win_chmod (const char *filename, int pmode);
-
-char *realpath (const char *file_name, char *resolved_name);
-
-long _win_random (void);
-
-void _win_srandom (unsigned int seed);
-
-int _win_remove (const char *path);
-
-int _win_rename (const char *oldname, const char *newname);
-
-int _win_stat (const char *path, struct stat *buffer);
-
-int _win_stati64 (const char *path, struct _stati64 *buffer);
-
-long _win_sysconf (int name);
-
-int _win_unlink (const char *filename);
-
-int _win_write (int fildes, const void *buf, size_t nbyte);
-
-int _win_read (int fildes, void *buf, size_t nbyte);
-
-size_t _win_fwrite (const void *buffer, size_t size, size_t count,
-                    FILE *stream);
-
-size_t _win_fread (void *buffer, size_t size, size_t count, FILE *stream);
-
-int _win_symlink (const char *path1, const char *path2);
-
-void *_win_mmap (void *start, size_t len, int access, int flags, int fd,
-                 unsigned long long offset);
-
-int _win_msync (void *start, size_t length, int flags);
-
-int _win_munmap (void *start, size_t length);
-
-int _win_lstat (const char *path, struct stat *buf);
-
-int _win_lstati64 (const char *path, struct _stati64 *buf);
-
-int _win_readlink (const char *path, char *buf, size_t bufsize);
-
-int _win_accept (int s, struct sockaddr *addr, int *addrlen);
-
-pid_t _win_waitpid (pid_t pid, int *stat_loc, int options);
-
-int _win_bind (int s, const struct sockaddr *name, int namelen);
-
-int _win_connect (int s,const struct sockaddr *name, int namelen);
-
-int _win_getpeername (int s, struct sockaddr *name,
-                      int *namelen);
-
-int _win_getsockname (int s, struct sockaddr *name,
-                      int *namelen);
-
-int _win_getsockopt (int s, int level, int optname, char *optval,
-                     int *optlen);
-
-int _win_listen (int s, int backlog);
-
-int _win_recv (int s, char *buf, int len, int flags);
-
-int _win_recvfrom (int s, void *buf, int len, int flags,
-                   struct sockaddr *from, int *fromlen);
-
-int _win_select (int max_fd, fd_set *rfds, fd_set *wfds, fd_set *efds,
-                 const struct timeval *tv);
-
-int _win_send (int s, const char *buf, int len, int flags);
-
-int _win_sendto (int s, const char *buf, int len, int flags,
-                 const struct sockaddr *to, int tolen);
-
-int _win_setsockopt (int s, int level, int optname, const void *optval,
-                     int optlen);
-
-int _win_shutdown (int s, int how);
-
-int _win_socket (int af, int type, int protocol);
-
-int _win_socketpair (int af, int type, int protocol, int socket_vector[2]);
-
-struct hostent *_win_gethostbyaddr (const char *addr, int len, int type);
-
-struct hostent *_win_gethostbyname (const char *name);
-
-struct hostent *gethostbyname2 (const char *name, int af);
-
-char *_win_strerror (int errnum);
-
-int IsWinNT ();
-
-char *index (const char *s, int c);
-
-char *_win_strtok_r (char *ptr, const char *sep, char **end);
-
-#if ! HAVE_STRNDUP
-char *strndup (const char *s, size_t n);
-
-#endif
-#if ! HAVE_STRNLEN && (! defined(__MINGW64_VERSION_MAJOR) || \
-  ! defined(_INC_STRING))
-size_t strnlen (const char *str, size_t maxlen);
-
-#endif
-char *stpcpy (char *dest, const char *src);
-
-char *strcasestr (const char *haystack_start, const char *needle_start);
-
-#ifndef __MINGW64_VERSION_MAJOR
-#define strcasecmp(a, b) stricmp (a, b)
-#define strncasecmp(a, b, c) strnicmp (a, b, c)
-#endif
-#ifndef wcscasecmp
-#define wcscasecmp(a, b) wcsicmp (a, b)
-#endif
-#ifndef wcsncasecmp
-#define wcsncasecmp(a, b, c) wcsnicmp (a, b, c)
-#endif
-#ifndef strtok_r /* winpthreads defines it in pthread.h */
-#define strtok_r _win_strtok_r
-#endif
-#endif /* WINDOWS */
-
-#ifndef WINDOWS
- #define DIR_SEPARATOR '/'
- #define DIR_SEPARATOR_STR "/"
- #define PATH_SEPARATOR ':'
- #define PATH_SEPARATOR_STR ":"
- #define NEWLINE "\n"
-
-#ifdef ENABLE_NLS
- #define BINDTEXTDOMAIN(d, n) bindtextdomain (d, n)
-#endif
- #define CREAT(p, m) creat (p, m)
- #define PLIBC_CTIME(c) ctime (c)
- #define CTIME_R(c, b) ctime_r (c, b)
- #undef FOPEN
- #define FOPEN(f, m) fopen (f, m)
- #define FCLOSE(f) fclose (f)
- #define FTRUNCATE(f, l) ftruncate (f, l)
- #define TRUNCATE(f, l) truncate (f, l)
- #define OPENDIR(d) opendir (d)
- #define CLOSEDIR(d) closedir (d)
- #define READDIR(d) readdir (d)
- #define OPEN open
- #define CHDIR(d) chdir (d)
- #define CLOSE(f) close (f)
- #define LSEEK(f, o, w) lseek (f, o, w)
- #define RMDIR(f) rmdir (f)
- #define ACCESS(p, m) access (p, m)
- #define CHMOD(f, p) chmod (f, p)
- #define FSTAT(h, b) fstat (h, b)
- #define PLIBC_KILL(p, s) kill (p, s)
- #define PIPE(h) pipe (h)
- #define REMOVE(p) remove (p)
- #define RENAME(o, n) rename (o, n)
- #define STAT(p, b) stat (p, b)
- #define STAT64(p, b) stat64 (p, b)
- #define SYSCONF(n) sysconf (n)
- #define UNLINK(f) unlink (f)
- #define WRITE(f, b, n) write (f, b, n)
- #define READ(f, b, n) read (f, b, n)
- #define GN_FREAD(b, s, c, f) fread (b, s, c, f)
- #define GN_FWRITE(b, s, c, f) fwrite (b, s, c, f)
- #define SYMLINK(a, b) symlink (a, b)
- #define MMAP(s, l, p, f, d, o) mmap (s, l, p, f, d, o)
- #define MKFIFO(p, m) mkfifo (p, m)
- #define MSYNC(s, l, f) msync (s, l, f)
- #define MUNMAP(s, l) munmap (s, l)
- #define STRERROR(i) strerror (i)
- #define RANDOM() random ()
- #define SRANDOM(s) srandom (s)
- #define READLINK(p, b, s) readlink (p, b, s)
- #define LSTAT(p, b) lstat (p, b)
- #define LSTAT64(p, b) lstat64 (p, b)
- #define PRINTF printf
- #define FPRINTF fprintf
- #define VPRINTF(f, a) vprintf (f, a)
- #define VFPRINTF(s, f, a) vfprintf (s, f, a)
- #define VSPRINTF(d, f, a) vsprintf (d, f, a)
- #define VSNPRINTF(str, size, fmt, a) vsnprintf (str, size, fmt, a)
- #define _REAL_SNPRINTF snprintf
- #define SPRINTF sprintf
- #define VSSCANF(s, f, a) vsscanf (s, f, a)
- #define SSCANF sscanf
- #define VFSCANF(s, f, a) vfscanf (s, f, a)
- #define VSCANF(f, a) vscanf (f, a)
- #define SCANF scanf
- #define FSCANF fscanf
- #define WAITPID(p, s, o) waitpid (p, s, o)
- #define ACCEPT(s, a, l) accept (s, a, l)
- #define BIND(s, n, l) bind (s, n, l)
- #define CONNECT(s, n, l) connect (s, n, l)
- #define GETPEERNAME(s, n, l) getpeername (s, n, l)
- #define GETSOCKNAME(s, n, l) getsockname (s, n, l)
- #define GETSOCKOPT(s, l, o, v, p) getsockopt (s, l, o, v, p)
- #define LISTEN(s, b) listen (s, b)
- #define RECV(s, b, l, f) recv (s, b, l, f)
- #define RECVFROM(s, b, l, f, r, o) recvfrom (s, b, l, f, r, o)
- #define SELECT(n, r, w, e, t) select (n, r, w, e, t)
- #define SEND(s, b, l, f) send (s, b, l, f)
- #define SENDTO(s, b, l, f, o, n) sendto (s, b, l, f, o, n)
- #define SETSOCKOPT(s, l, o, v, n) setsockopt (s, l, o, v, n)
- #define SHUTDOWN(s, h) shutdown (s, h)
- #define SOCKET(a, t, p) socket (a, t, p)
- #define SOCKETPAIR(a, t, p, v) socketpair (a, t, p, v)
- #define GETHOSTBYADDR(a, l, t) gethostbyaddr (a, l, t)
- #define GETHOSTBYNAME(n) gethostbyname (n)
- #define GETTIMEOFDAY(t, n) gettimeofday (t, n)
- #define INSQUE(e, p) insque (e, p)
- #define REMQUE(e) remque (e)
- #define HSEARCH(i, a) hsearch (i, a)
- #define HCREATE(n) hcreate (n)
- #define HDESTROY() hdestroy ()
- #define HSEARCH_R(i, a, r, h) hsearch_r (i, a, r, h)
- #define HCREATE_R(n, h) hcreate_r (n, h)
- #define HDESTROY_R(h) hdestroy_r (h)
- #define TSEARCH(k, r, c) tsearch (k, r, c)
- #define TFIND(k, r, c) tfind (k, r, c)
- #define TDELETE(k, r, c) tdelete (k, r, c)
- #define TWALK(r, a) twalk (r, a)
- #define TDESTROY(r, f) tdestroy (r, f)
- #define LFIND(k, b, n, s, c) lfind (k, b, n, s, c)
- #define LSEARCH(k, b, n, s, c) lsearch (k, b, n, s, c)
- #define STRUCT_STAT64 struct stat64
-#else
- #define DIR_SEPARATOR '\\'
- #define DIR_SEPARATOR_STR "\\"
- #define PATH_SEPARATOR ';'
- #define PATH_SEPARATOR_STR ";"
- #define NEWLINE "\r\n"
-
-#ifdef ENABLE_NLS
- #define BINDTEXTDOMAIN(d, n) _win_bindtextdomain (d, n)
-#endif
- #define CREAT(p, m) _win_creat (p, m)
- #define PLIBC_CTIME(c) _win_ctime (c)
- #define CTIME_R(c, b) _win_ctime_r (c, b)
- #define FOPEN(f, m) _win_fopen (f, m)
- #define FCLOSE(f) _win_fclose (f)
- #define FTRUNCATE(f, l) _win_ftruncate (f, l)
- #define TRUNCATE(f, l) _win_truncate (f, l)
- #define OPENDIR(d) _win_opendir (d)
- #define CLOSEDIR(d) _win_closedir (d)
- #define READDIR(d) _win_readdir (d)
- #define OPEN _win_open
- #define CHDIR(d) _win_chdir (d)
- #define CLOSE(f) _win_close (f)
- #define PLIBC_KILL(p, s) _win_kill (p, s)
- #define LSEEK(f, o, w) lseek (f, o, w)
- #define FSTAT(h, b) _win_fstat (h, b)
- #define RMDIR(f) _win_rmdir (f)
- #define ACCESS(p, m) _win_access (p, m)
- #define CHMOD(f, p) _win_chmod (f, p)
- #define PIPE(h) _win_pipe (h)
- #define RANDOM() _win_random ()
- #define SRANDOM(s) _win_srandom (s)
- #define REMOVE(p) _win_remove (p)
- #define RENAME(o, n) _win_rename (o, n)
- #define STAT(p, b) _win_stat (p, b)
- #define STAT64(p, b) _win_stati64 (p, b)
- #define SYSCONF(n) _win_sysconf (n)
- #define UNLINK(f) _win_unlink (f)
- #define WRITE(f, b, n) _win_write (f, b, n)
- #define READ(f, b, n) _win_read (f, b, n)
- #define GN_FREAD(b, s, c, f) _win_fread (b, s, c, f)
- #define GN_FWRITE(b, s, c, f) _win_fwrite (b, s, c, f)
- #define SYMLINK(a, b) _win_symlink (a, b)
- #define MMAP(s, l, p, f, d, o) _win_mmap (s, l, p, f, d, o)
- #define MKFIFO(p, m) _win_mkfifo (p, m)
- #define MSYNC(s, l, f) _win_msync (s, l, f)
- #define MUNMAP(s, l) _win_munmap (s, l)
- #define STRERROR(i) _win_strerror (i)
- #define READLINK(p, b, s) _win_readlink (p, b, s)
- #define LSTAT(p, b) _win_lstat (p, b)
- #define LSTAT64(p, b) _win_lstati64 (p, b)
- #define PRINTF printf
- #define FPRINTF fprintf
- #define VPRINTF(f, a) vprintf (f, a)
- #define VFPRINTF(s, f, a) vfprintf (s, f, a)
- #define VSPRINTF(d, f, a) vsprintf (d, f, a)
- #define VSNPRINTF(str, size, fmt, a) vsnprintf (str, size, fmt, a)
- #define _REAL_SNPRINTF snprintf
- #define SPRINTF sprintf
- #define VSSCANF(s, f, a) vsscanf (s, f, a)
- #define SSCANF sscanf
- #define VFSCANF(s, f, a) vfscanf (s, f, a)
- #define VSCANF(f, a) vscanf (f, a)
- #define SCANF scanf
- #define FSCANF fscanf
- #define WAITPID(p, s, o) _win_waitpid (p, s, o)
- #define ACCEPT(s, a, l) _win_accept (s, a, l)
- #define BIND(s, n, l) _win_bind (s, n, l)
- #define CONNECT(s, n, l) _win_connect (s, n, l)
- #define GETPEERNAME(s, n, l) _win_getpeername (s, n, l)
- #define GETSOCKNAME(s, n, l) _win_getsockname (s, n, l)
- #define GETSOCKOPT(s, l, o, v, p) _win_getsockopt (s, l, o, v, p)
- #define LISTEN(s, b) _win_listen (s, b)
- #define RECV(s, b, l, f) _win_recv (s, b, l, f)
- #define RECVFROM(s, b, l, f, r, o) _win_recvfrom (s, b, l, f, r, o)
- #define SELECT(n, r, w, e, t) _win_select (n, r, w, e, t)
- #define SEND(s, b, l, f) _win_send (s, b, l, f)
- #define SENDTO(s, b, l, f, o, n) _win_sendto (s, b, l, f, o, n)
- #define SETSOCKOPT(s, l, o, v, n) _win_setsockopt (s, l, o, v, n)
- #define SHUTDOWN(s, h) _win_shutdown (s, h)
- #define SOCKET(a, t, p) _win_socket (a, t, p)
- #define SOCKETPAIR(a, t, p, v) _win_socketpair (a, t, p, v)
- #define GETHOSTBYADDR(a, l, t) _win_gethostbyaddr (a, l, t)
- #define GETHOSTBYNAME(n) _win_gethostbyname (n)
- #define GETTIMEOFDAY(t, n) gettimeofday (t, n)
- #define INSQUE(e, p) _win_insque (e, p)
- #define REMQUE(e) _win_remque (e)
- #define HSEARCH(i, a) _win_hsearch (i, a)
- #define HCREATE(n) _win_hcreate (n)
- #define HDESTROY() _win_hdestroy ()
- #define HSEARCH_R(i, a, r, h) _win_hsearch_r (i, a, r, h)
- #define HCREATE_R(n, h) _win_hcreate_r (n, h)
- #define HDESTROY_R(h) _win_hdestroy_r (h)
- #define TSEARCH(k, r, c) _win_tsearch (k, r, c)
- #define TFIND(k, r, c) _win_tfind (k, r, c)
- #define TDELETE(k, r, c) _win_tdelete (k, r, c)
- #define TWALK(r, a) _win_twalk (r, a)
- #define TDESTROY(r, f) _win_tdestroy (r, f)
- #define LFIND(k, b, n, s, c) _win_lfind (k, b, n, s, c)
- #define LSEARCH(k, b, n, s, c) _win_lsearch (k, b, n, s, c)
- #define STRUCT_STAT64 struct _stati64
-#endif
-
-/* search.h */
-
-/* Prototype structure for a linked-list data structure.
-   This is the type used by the `insque' and `remque' functions.  */
-
-struct PLIBC_SEARCH_QELEM
-{
-  struct qelem *q_forw;
-  struct qelem *q_back;
-  char q_data[1];
-};
-
-
-/* Insert ELEM into a doubly-linked list, after PREV.  */
-void _win_insque (void *__elem, void *__prev);
-
-/* Unlink ELEM from the doubly-linked list that it is in.  */
-void _win_remque (void *__elem);
-
-
-/* For use with hsearch(3).  */
-typedef int (*PLIBC_SEARCH__compar_fn_t) (__const void *, __const void *);
-
-typedef PLIBC_SEARCH__compar_fn_t _win_comparison_fn_t;
-
-/* Action which shall be performed in the call the hsearch.  */
-typedef enum
-{
-  PLIBC_SEARCH_FIND,
-  PLIBC_SEARCH_ENTER
-}
-PLIBC_SEARCH_ACTION;
-
-typedef struct PLIBC_SEARCH_entry
-{
-  char *key;
-  void *data;
-}
-PLIBC_SEARCH_ENTRY;
-
-/* The reentrant version has no static variables to maintain the state.
-   Instead the interface of all functions is extended to take an argument
-   which describes the current status.  */
-typedef struct _PLIBC_SEARCH_ENTRY
-{
-  unsigned int used;
-  PLIBC_SEARCH_ENTRY entry;
-}
-_PLIBC_SEARCH_ENTRY;
-
-
-/* Family of hash table handling functions.  The functions also
-   have reentrant counterparts ending with _r.  The non-reentrant
-   functions all work on a signle internal hashing table.  */
-
-/* Search for entry matching ITEM.key in internal hash table.  If
-   ACTION is `FIND' return found entry or signal error by returning
-   NULL.  If ACTION is `ENTER' replace existing data (if any) with
-   ITEM.data.  */
-PLIBC_SEARCH_ENTRY *_win_hsearch (PLIBC_SEARCH_ENTRY __item, 
PLIBC_SEARCH_ACTION
-                                  __action);
-
-/* Create a new hashing table which will at most contain NEL elements.  */
-int _win_hcreate (size_t __nel);
-
-/* Destroy current internal hashing table.  */
-void _win_hdestroy (void);
-
-/* Data type for reentrant functions.  */
-struct PLIBC_SEARCH_hsearch_data
-{
-  struct _PLIBC_SEARCH_ENTRY *table;
-  unsigned int size;
-  unsigned int filled;
-};
-
-/* Reentrant versions which can handle multiple hashing tables at the
-   same time.  */
-int _win_hsearch_r (PLIBC_SEARCH_ENTRY __item, PLIBC_SEARCH_ACTION __action,
-                    PLIBC_SEARCH_ENTRY **__retval,
-                    struct PLIBC_SEARCH_hsearch_data *__htab);
-
-int _win_hcreate_r (size_t __nel, struct PLIBC_SEARCH_hsearch_data *__htab);
-
-void _win_hdestroy_r (struct PLIBC_SEARCH_hsearch_data *__htab);
-
-
-/* The tsearch routines are very interesting. They make many
-   assumptions about the compiler.  It assumes that the first field
-   in node must be the "key" field, which points to the datum.
-   Everything depends on that.  */
-/* For tsearch */
-typedef enum
-{
-  PLIBC_SEARCH_preorder,
-  PLIBC_SEARCH_postorder,
-  PLIBC_SEARCH_endorder,
-  PLIBC_SEARCH_leaf
-}
-PLIBC_SEARCH_VISIT;
-
-/* Search for an entry matching the given KEY in the tree pointed to
-   by *ROOTP and insert a new element if not found.  */
-void *_win_tsearch (__const void *__key, void **__rootp,
-                    PLIBC_SEARCH__compar_fn_t __compar);
-
-/* Search for an entry matching the given KEY in the tree pointed to
-   by *ROOTP.  If no matching entry is available return NULL.  */
-void *_win_tfind (__const void *__key, void *__const *__rootp,
-                  PLIBC_SEARCH__compar_fn_t __compar);
-
-/* Remove the element matching KEY from the tree pointed to by *ROOTP.  */
-void *_win_tdelete (__const void *__restrict __key,
-                    void **__restrict __rootp,
-                    PLIBC_SEARCH__compar_fn_t __compar);
-
-typedef void (*PLIBC_SEARCH__action_fn_t) (__const void *__nodep,
-                                           PLIBC_SEARCH_VISIT __value,
-                                           int __level);
-
-/* Walk through the whole tree and call the ACTION callback for every node
-   or leaf.  */
-void _win_twalk (__const void *__root, PLIBC_SEARCH__action_fn_t __action);
-
-/* Callback type for function to free a tree node.  If the keys are atomic
-   data this function should do nothing.  */
-typedef void (*PLIBC_SEARCH__free_fn_t) (void *__nodep);
-
-/* Destroy the whole tree, call FREEFCT for each node or leaf.  */
-void _win_tdestroy (void *__root, PLIBC_SEARCH__free_fn_t __freefct);
-
-
-/* Perform linear search for KEY by comparing by COMPAR in an array
-   [BASE,BASE+NMEMB*SIZE).  */
-void *_win_lfind (__const void *__key, __const void *__base,
-                  size_t *__nmemb, size_t __size, PLIBC_SEARCH__compar_fn_t
-                  __compar);
-
-/* Perform linear search for KEY by comparing by COMPAR function in
-   array [BASE,BASE+NMEMB*SIZE) and insert entry if not found.  */
-void *_win_lsearch (__const void *__key, void *__base,
-                    size_t *__nmemb, size_t __size, PLIBC_SEARCH__compar_fn_t
-                    __compar);
-
-
-#ifdef __cplusplus
-}
-#endif
-
-
-#endif // _PLIBC_H_
-
-/* end of plibc.h */
diff --git a/src/plugins/test_lib.c b/src/plugins/test_lib.c
index 97d4dc5..8bd6d4e 100644
--- a/src/plugins/test_lib.c
+++ b/src/plugins/test_lib.c
@@ -26,6 +26,7 @@
 #include "test_lib.h"
 #include <sys/types.h>
 #include <regex.h>
+#include <signal.h>
 
 /**
  * Function that libextractor calls for each
@@ -174,6 +175,33 @@ run (const char *plugin_name,
 }
 
 
+#ifndef WINDOWS
+/**
+ * Install a signal handler to ignore SIGPIPE.
+ */
+static void
+ignore_sigpipe ()
+{
+  struct sigaction oldsig;
+  struct sigaction sig;
+
+  memset (&sig, 0, sizeof (struct sigaction));
+  sig.sa_handler = SIG_IGN;
+  sigemptyset (&sig.sa_mask);
+#ifdef SA_INTERRUPT
+  sig.sa_flags = SA_INTERRUPT;  /* SunOS */
+#else
+  sig.sa_flags = SA_RESTART;
+#endif
+  if (0 != sigaction (SIGPIPE, &sig, &oldsig))
+    fprintf (stderr,
+             "Failed to install SIGPIPE handler: %s\n", strerror (errno));
+}
+
+
+#endif
+
+
 /**
  * Main function to be called to test a plugin.
  *
@@ -191,7 +219,10 @@ ET_main (const char *plugin_name,
   /* change environment to find plugins which may not yet be
      not installed but should be in the current directory (or .libs)
      on 'make check' */
-  if (0 != putenv ("LIBEXTRACTOR_PREFIX=." PATH_SEPARATOR_STR ".libs/"))
+#ifndef WINDOWS
+  ignore_sigpipe ();
+#endif
+  if (0 != putenv ("LIBEXTRACTOR_PREFIX=./.libs/"))
     fprintf (stderr,
              "Failed to update my environment, plugin loading may fail: %s\n",
              strerror (errno));

-- 
To stop receiving notification emails like this one, please contact
gnunet@gnunet.org.



reply via email to

[Prev in Thread] Current Thread [Next in Thread]