
* configure.ac: Check for C++, Qt and support --enable-w32-qt. * m4/pkg.m4: New file. gpgme/ 2007-09-07 Marcus Brinkmann <marcus@g10code.de> * kdpipeiodevice.h, kdpipeiodevice.cpp, moc_kdpipeiodevice.cpp, kdpipeiodevice.moc, w32-qt-io.c: New files. * Makefile.am (ltlib_gpgme_extra): Rename to ltlib_gpgme_glib. (ltlib_gpgme_qt): New variable. (lib_LTLIBRARIES): Add $(ltlib_gpgme_qt). (libgpgme_qt_la_SOURCES): New variable. (AM_CPPFLAGS): Add @QT4_CORE_INCLUDES@ (AM_CFLAGS): Add @QT4_CORE_CFLAGS@. (libgpgme_qt_la_LDFLAGS, libgpgme_qt_la_DEPENDENCIES) (libgpgme_qt_la_LIBADD): New variables. * sema.h (struct critsect_s): Rename "private" to "priv" to make C++ users happy. Change users. * posix-sema.c (_gpgme_sema_cs_enter, _gpgme_sema_cs_leave) (_gpgme_sema_cs_destroy): Likewise. * w32-sema.c (critsect_init, _gpgme_sema_cs_enter) (_gpgme_sema_cs_leave, _gpgme_sema_cs_destroy): Likewise. * w32-glib-io.c (gpgme_get_giochannel): Change return type to void*. (gpgme_get_fdptr): New function. * w32-io.c (gpgme_get_fdptr): New function * gpgme.def: Add gpgme_get_fdptr.
116 lines
2.8 KiB
C
116 lines
2.8 KiB
C
/* w32-sema.c
|
|
Copyright (C) 2001 Werner Koch (dd9jn)
|
|
Copyright (C) 2001, 2002, 2004, 2007 g10 Code GmbH
|
|
|
|
This file is part of GPGME.
|
|
|
|
GPGME 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.
|
|
|
|
GPGME 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 program; if not, write to the Free Software
|
|
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
02111-1307, USA. */
|
|
|
|
#ifdef HAVE_CONFIG_H
|
|
#include <config.h>
|
|
#endif
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <assert.h>
|
|
#include <errno.h>
|
|
#include <signal.h>
|
|
#include <fcntl.h>
|
|
#include <sys/time.h>
|
|
#include <sys/types.h>
|
|
#include <windows.h>
|
|
#include <io.h>
|
|
|
|
#include "util.h"
|
|
#include "sema.h"
|
|
#include "debug.h"
|
|
|
|
static void
|
|
sema_fatal (const char *text)
|
|
{
|
|
fprintf (stderr, "sema.c: %s\n", text);
|
|
abort ();
|
|
}
|
|
|
|
|
|
static void
|
|
critsect_init (struct critsect_s *s)
|
|
{
|
|
CRITICAL_SECTION *mp;
|
|
static CRITICAL_SECTION init_lock;
|
|
static int initialized;
|
|
|
|
if (!initialized) {
|
|
/* The very first time we call this function, we assume that
|
|
only one thread is running, so that we can bootstrap the
|
|
semaphore code. */
|
|
InitializeCriticalSection (&init_lock);
|
|
initialized = 1;
|
|
}
|
|
if (!s)
|
|
return; /* we just want to initialize ourself */
|
|
|
|
/* first test whether it is really not initialized */
|
|
EnterCriticalSection (&init_lock);
|
|
if ( s->priv ) {
|
|
LeaveCriticalSection (&init_lock);
|
|
return;
|
|
}
|
|
/* now init it */
|
|
mp = malloc ( sizeof *mp );
|
|
if (!mp) {
|
|
LeaveCriticalSection (&init_lock);
|
|
sema_fatal ("out of core while creating critical section lock");
|
|
}
|
|
InitializeCriticalSection (mp);
|
|
s->priv = mp;
|
|
LeaveCriticalSection (&init_lock);
|
|
}
|
|
|
|
void
|
|
_gpgme_sema_subsystem_init ()
|
|
{
|
|
/* fixme: we should check that there is only one thread running */
|
|
critsect_init (NULL);
|
|
}
|
|
|
|
|
|
void
|
|
_gpgme_sema_cs_enter ( struct critsect_s *s )
|
|
{
|
|
if (!s->priv)
|
|
critsect_init (s);
|
|
EnterCriticalSection ( (CRITICAL_SECTION*)s->priv );
|
|
}
|
|
|
|
void
|
|
_gpgme_sema_cs_leave (struct critsect_s *s)
|
|
{
|
|
if (!s->priv)
|
|
critsect_init (s);
|
|
LeaveCriticalSection ((CRITICAL_SECTION*)s->priv);
|
|
}
|
|
|
|
void
|
|
_gpgme_sema_cs_destroy ( struct critsect_s *s )
|
|
{
|
|
if (s && s->priv) {
|
|
DeleteCriticalSection ((CRITICAL_SECTION*)s->priv);
|
|
free (s->priv);
|
|
s->priv = NULL;
|
|
}
|
|
}
|