mirror of
https://github.com/libevent/libevent.git
synced 2025-01-20 05:02:55 +08:00
3f8c7cd035
Previously we used include-guards with names like _EVENT2_EVENT_H_. But C reserves macros beginning with an underscore for use by the system. This patch converts all include guards for files like include/event2/<fname.h> to be of form EVENT2_<FNAME_H>_INCLUDED_, and all Libevent 1.x headers in include/<fname.h> to be of the form EVENT1_<FNAME_H>_INCLUDED_, and all internal libevent headers with names like <fname.h> to the form <FNAME_H>_INCLUDED_. FNAME_H is here derived from fname.h by replacing every non-macro-usable character in fname.h with an underscore, and putting every remaining character in uppercase. This is an automatic conversion. The script that produced was made by running the following script over all header files: ===== #!/usr/bin/perl -w # Run this on every .h file except config.h, sys/queue.h, WIN32/event2/event-config.h use strict; my %macros = (); my %skipped = (); FILE: for my $fn (@ARGV) { my $f = $fn; if ($fn !~ /^\.\//) { $f = "./$fn"; } if ($f eq './config.h' or $f =~ m#/tree.h$# or $f =~ m#/queue.h# or $f =~ m#/event-config.h# or $f =~ m#/evconfig-private.h#) { $skipped{$fn} = 1; next FILE; } $skipped{$fn} = 0; open(F, $fn); while (<F>) { if (/^#ifndef ([A-Za-z0-9_]+)/) { $macros{$fn} = $1; next FILE; } } } print "#!/usr/bin/perl -w -i -p\n\n"; for my $fn (@ARGV) { if (! exists $macros{$fn}) { print "# No macro known for $fn!\n" if (!$skipped{$fn}); } else { if ($macros{$fn} !~ /_H_?$/) { print "# Weird macro for $fn...\n"; } my $goodmacro = uc $fn; $goodmacro =~ s#^\./##; $goodmacro =~ s#INCLUDE/EVENT2#EVENT2#; $goodmacro =~ s#INCLUDE/#EVENT1_#; $goodmacro =~ s#TEST/##; $goodmacro =~ s#[\/\-\.]#_#g; print "s/(?<![A-Za-z0-9_])$macros{$fn}(?![A-Za-z0-9_])/${goodmacro}_INCLUDED_/g;\n" } } === And then running the script below that it generated over all === the .h files again #!/usr/bin/perl -w -i -p s/(?<![A-Za-z0-9_])_BUFFEREVENT_INTERNAL_H_(?![A-Za-z0-9_])/BUFFEREVENT_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_CHANGELIST_H_(?![A-Za-z0-9_])/CHANGELIST_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_DEFER_INTERNAL_H_(?![A-Za-z0-9_])/DEFER_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVBUFFER_INTERNAL_H_(?![A-Za-z0-9_])/EVBUFFER_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT_INTERNAL_H_(?![A-Za-z0-9_])/EVENT_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVMAP_H_(?![A-Za-z0-9_])/EVMAP_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVRPC_INTERNAL_H_(?![A-Za-z0-9_])/EVRPC_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVSIGNAL_H_(?![A-Za-z0-9_])/EVSIGNAL_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVTHREAD_INTERNAL_H_(?![A-Za-z0-9_])/EVTHREAD_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT_HT_H(?![A-Za-z0-9_])/HT_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_HTTP_INTERNAL_H_(?![A-Za-z0-9_])/HTTP_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVDNS_H_(?![A-Za-z0-9_])/EVENT1_EVDNS_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT_H_(?![A-Za-z0-9_])/EVENT1_EVENT_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_BUFFER_H_(?![A-Za-z0-9_])/EVENT2_BUFFER_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_BUFFER_COMPAT_H_(?![A-Za-z0-9_])/EVENT2_BUFFER_COMPAT_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_BUFFEREVENT_H_(?![A-Za-z0-9_])/EVENT2_BUFFEREVENT_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_BUFFEREVENT_COMPAT_H_(?![A-Za-z0-9_])/EVENT2_BUFFEREVENT_COMPAT_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_BUFFEREVENT_SSL_H_(?![A-Za-z0-9_])/EVENT2_BUFFEREVENT_SSL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_BUFFEREVENT_STRUCT_H_(?![A-Za-z0-9_])/EVENT2_BUFFEREVENT_STRUCT_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_DNS_H_(?![A-Za-z0-9_])/EVENT2_DNS_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_DNS_COMPAT_H_(?![A-Za-z0-9_])/EVENT2_DNS_COMPAT_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_DNS_STRUCT_H_(?![A-Za-z0-9_])/EVENT2_DNS_STRUCT_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_EVENT_H_(?![A-Za-z0-9_])/EVENT2_EVENT_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_EVENT_COMPAT_H_(?![A-Za-z0-9_])/EVENT2_EVENT_COMPAT_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_EVENT_STRUCT_H_(?![A-Za-z0-9_])/EVENT2_EVENT_STRUCT_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_HTTP_H_(?![A-Za-z0-9_])/EVENT2_HTTP_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_HTTP_COMPAT_H_(?![A-Za-z0-9_])/EVENT2_HTTP_COMPAT_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_HTTP_STRUCT_H_(?![A-Za-z0-9_])/EVENT2_HTTP_STRUCT_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_EVENT_KEYVALQ_STRUCT_H_(?![A-Za-z0-9_])/EVENT2_KEYVALQ_STRUCT_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_LISTENER_H_(?![A-Za-z0-9_])/EVENT2_LISTENER_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_RPC_H_(?![A-Za-z0-9_])/EVENT2_RPC_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_RPC_COMPAT_H_(?![A-Za-z0-9_])/EVENT2_RPC_COMPAT_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_RPC_STRUCT_H_(?![A-Za-z0-9_])/EVENT2_RPC_STRUCT_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_TAG_H_(?![A-Za-z0-9_])/EVENT2_TAG_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_TAG_COMPAT_H_(?![A-Za-z0-9_])/EVENT2_TAG_COMPAT_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_THREAD_H_(?![A-Za-z0-9_])/EVENT2_THREAD_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT2_UTIL_H_(?![A-Za-z0-9_])/EVENT2_UTIL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVHTTP_H_(?![A-Za-z0-9_])/EVENT1_EVHTTP_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVRPC_H_(?![A-Za-z0-9_])/EVENT1_EVRPC_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVUTIL_H_(?![A-Za-z0-9_])/EVENT1_EVUTIL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT_IOCP_INTERNAL_H(?![A-Za-z0-9_])/IOCP_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT_IPV6_INTERNAL_H(?![A-Za-z0-9_])/IPV6_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_LOG_H_(?![A-Za-z0-9_])/LOG_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_MIN_HEAP_H_(?![A-Za-z0-9_])/MINHEAP_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT_MM_INTERNAL_H(?![A-Za-z0-9_])/MM_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_RATELIM_INTERNAL_H_(?![A-Za-z0-9_])/RATELIM_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_STRLCPY_INTERNAL_H_(?![A-Za-z0-9_])/STRLCPY_INTERNAL_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_REGRESS_H_(?![A-Za-z0-9_])/REGRESS_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_TESTUTILS_H(?![A-Za-z0-9_])/REGRESS_TESTUTILS_H_INCLUDED_/g; # Weird macro for test/tinytest.h... s/(?<![A-Za-z0-9_])TINYTEST_H_INCLUDED_(?![A-Za-z0-9_])/TINYTEST_H_INCLUDED_/g; # No macro known for test/tinytest_local.h! # Weird macro for test/tinytest_macros.h... s/(?<![A-Za-z0-9_])TINYTEST_MACROS_H_INCLUDED_(?![A-Za-z0-9_])/TINYTEST_MACROS_H_INCLUDED_/g; s/(?<![A-Za-z0-9_])_EVENT_UTIL_INTERNAL_H(?![A-Za-z0-9_])/UTIL_INTERNAL_H_INCLUDED_/g;
221 lines
7.2 KiB
C
221 lines
7.2 KiB
C
/*
|
|
* Copyright (c) 2000-2007 Niels Provos <provos@citi.umich.edu>
|
|
* Copyright (c) 2007-2012 Niels Provos and Nick Mathewson
|
|
*
|
|
* 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.
|
|
* 3. The name of the author may not be used to endorse or promote products
|
|
* derived from this software without specific prior written permission.
|
|
*
|
|
* 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 EVENT2_EVENT_COMPAT_H_INCLUDED_
|
|
#define EVENT2_EVENT_COMPAT_H_INCLUDED_
|
|
|
|
/** @file event2/event_compat.h
|
|
|
|
Potentially non-threadsafe versions of the functions in event.h: provided
|
|
only for backwards compatibility.
|
|
|
|
In the oldest versions of Libevent, event_base was not a first-class
|
|
structure. Instead, there was a single event base that every function
|
|
manipulated. Later, when separate event bases were added, the old functions
|
|
that didn't take an event_base argument needed to work by manipulating the
|
|
"current" event base. This could lead to thread-safety issues, and obscure,
|
|
hard-to-diagnose bugs.
|
|
|
|
@deprecated All functions in this file are by definition deprecated.
|
|
*/
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#include <event2/event-config.h>
|
|
#ifdef EVENT__HAVE_SYS_TYPES_H
|
|
#include <sys/types.h>
|
|
#endif
|
|
#ifdef EVENT__HAVE_SYS_TIME_H
|
|
#include <sys/time.h>
|
|
#endif
|
|
|
|
/* For int types. */
|
|
#include <event2/util.h>
|
|
|
|
/**
|
|
Initialize the event API.
|
|
|
|
The event API needs to be initialized with event_init() before it can be
|
|
used. Sets the global current base that gets used for events that have no
|
|
base associated with them.
|
|
|
|
@deprecated This function is deprecated because it replaces the "current"
|
|
event_base, and is totally unsafe for multithreaded use. The replacement
|
|
is event_base_new().
|
|
|
|
@see event_base_set(), event_base_new()
|
|
*/
|
|
struct event_base *event_init(void);
|
|
|
|
/**
|
|
Loop to process events.
|
|
|
|
Like event_base_dispatch(), but uses the "current" base.
|
|
|
|
@deprecated This function is deprecated because it is easily confused by
|
|
multiple calls to event_init(), and because it is not safe for
|
|
multithreaded use. The replacement is event_base_dispatch().
|
|
|
|
@see event_base_dispatch(), event_init()
|
|
*/
|
|
int event_dispatch(void);
|
|
|
|
/**
|
|
Handle events.
|
|
|
|
This function behaves like event_base_loop(), but uses the "current" base
|
|
|
|
@deprecated This function is deprecated because it uses the event base from
|
|
the last call to event_init, and is therefore not safe for multithreaded
|
|
use. The replacement is event_base_loop().
|
|
|
|
@see event_base_loop(), event_init()
|
|
*/
|
|
int event_loop(int);
|
|
|
|
|
|
/**
|
|
Exit the event loop after the specified time.
|
|
|
|
This function behaves like event_base_loopexit(), except that it uses the
|
|
"current" base.
|
|
|
|
@deprecated This function is deprecated because it uses the event base from
|
|
the last call to event_init, and is therefore not safe for multithreaded
|
|
use. The replacement is event_base_loopexit().
|
|
|
|
@see event_init, event_base_loopexit()
|
|
*/
|
|
int event_loopexit(const struct timeval *);
|
|
|
|
|
|
/**
|
|
Abort the active event_loop() immediately.
|
|
|
|
This function behaves like event_base_loopbreakt(), except that it uses the
|
|
"current" base.
|
|
|
|
@deprecated This function is deprecated because it uses the event base from
|
|
the last call to event_init, and is therefore not safe for multithreaded
|
|
use. The replacement is event_base_loopbreak().
|
|
|
|
@see event_base_loopbreak(), event_init()
|
|
*/
|
|
int event_loopbreak(void);
|
|
|
|
/**
|
|
Schedule a one-time event to occur.
|
|
|
|
@deprecated This function is obsolete, and has been replaced by
|
|
event_base_once(). Its use is deprecated because it relies on the
|
|
"current" base configured by event_init().
|
|
|
|
@see event_base_once()
|
|
*/
|
|
int event_once(evutil_socket_t , short,
|
|
void (*)(evutil_socket_t, short, void *), void *, const struct timeval *);
|
|
|
|
|
|
/**
|
|
Get the kernel event notification mechanism used by Libevent.
|
|
|
|
@deprecated This function is obsolete, and has been replaced by
|
|
event_base_get_method(). Its use is deprecated because it relies on the
|
|
"current" base configured by event_init().
|
|
|
|
@see event_base_get_method()
|
|
*/
|
|
const char *event_get_method(void);
|
|
|
|
|
|
/**
|
|
Set the number of different event priorities.
|
|
|
|
@deprecated This function is deprecated because it is easily confused by
|
|
multiple calls to event_init(), and because it is not safe for
|
|
multithreaded use. The replacement is event_base_priority_init().
|
|
|
|
@see event_base_priority_init()
|
|
*/
|
|
int event_priority_init(int);
|
|
|
|
/**
|
|
Prepare an event structure to be added.
|
|
|
|
@deprecated event_set() is not recommended for new code, because it requires
|
|
a subsequent call to event_base_set() to be safe under most circumstances.
|
|
Use event_assign() or event_new() instead.
|
|
*/
|
|
void event_set(struct event *, evutil_socket_t, short, void (*)(evutil_socket_t, short, void *), void *);
|
|
|
|
#define evtimer_set(ev, cb, arg) event_set((ev), -1, 0, (cb), (arg))
|
|
#define evsignal_set(ev, x, cb, arg) \
|
|
event_set((ev), (x), EV_SIGNAL|EV_PERSIST, (cb), (arg))
|
|
|
|
|
|
/**
|
|
@name timeout_* macros
|
|
|
|
@deprecated These macros are deprecated because their naming is inconsistent
|
|
with the rest of Libevent. Use the evtimer_* macros instead.
|
|
@{
|
|
*/
|
|
#define timeout_add(ev, tv) event_add((ev), (tv))
|
|
#define timeout_set(ev, cb, arg) event_set((ev), -1, 0, (cb), (arg))
|
|
#define timeout_del(ev) event_del(ev)
|
|
#define timeout_pending(ev, tv) event_pending((ev), EV_TIMEOUT, (tv))
|
|
#define timeout_initialized(ev) event_initialized(ev)
|
|
/**@}*/
|
|
|
|
/**
|
|
@name signal_* macros
|
|
|
|
@deprecated These macros are deprecated because their naming is inconsistent
|
|
with the rest of Libevent. Use the evsignal_* macros instead.
|
|
@{
|
|
*/
|
|
#define signal_add(ev, tv) event_add((ev), (tv))
|
|
#define signal_set(ev, x, cb, arg) \
|
|
event_set((ev), (x), EV_SIGNAL|EV_PERSIST, (cb), (arg))
|
|
#define signal_del(ev) event_del(ev)
|
|
#define signal_pending(ev, tv) event_pending((ev), EV_SIGNAL, (tv))
|
|
#define signal_initialized(ev) event_initialized(ev)
|
|
/**@}*/
|
|
|
|
#ifndef EVENT_FD
|
|
/* These macros are obsolete; use event_get_fd and event_get_signal instead. */
|
|
#define EVENT_FD(ev) ((int)event_get_fd(ev))
|
|
#define EVENT_SIGNAL(ev) event_get_signal(ev)
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* EVENT2_EVENT_COMPAT_H_INCLUDED_ */
|