mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-12 03:00:38 +00:00
git-svn-id: https://svn.eduke32.com/eduke32@1128 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
5469140ff7
commit
3456c1e909
69 changed files with 583 additions and 16763 deletions
|
@ -28,7 +28,7 @@ USE_OPENGL = 1
|
||||||
NOASM = 0
|
NOASM = 0
|
||||||
LINKED_GTK = 0
|
LINKED_GTK = 0
|
||||||
BUILD32_ON_64 = 0
|
BUILD32_ON_64 = 0
|
||||||
ENET_NETWORKING = 1
|
RANCID_NETWORKING = 1
|
||||||
|
|
||||||
# Debugging/Build options
|
# Debugging/Build options
|
||||||
RELEASE?=1
|
RELEASE?=1
|
||||||
|
@ -44,7 +44,7 @@ ESRC=$(EROOT)/src
|
||||||
EINC=$(EROOT)/include
|
EINC=$(EROOT)/include
|
||||||
INC=$(SRC)
|
INC=$(SRC)
|
||||||
o=o
|
o=o
|
||||||
ENETROOT=$(ESRC)/enet
|
# ENETROOT=$(ESRC)/enet
|
||||||
|
|
||||||
ifneq (0,$(RELEASE))
|
ifneq (0,$(RELEASE))
|
||||||
# Debugging disabled
|
# Debugging disabled
|
||||||
|
@ -192,9 +192,9 @@ ifeq ($(PLATFORM),DARWIN)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifeq ($(PLATFORM),WINDOWS)
|
ifeq ($(PLATFORM),WINDOWS)
|
||||||
OURCFLAGS += -fno-pic -DUNDERSCORES -I$(DXROOT)/include -I$(ALROOT)/include -I$(ENETROOT)/include
|
OURCFLAGS += -fno-pic -DUNDERSCORES -I$(DXROOT)/include -I$(ALROOT)/include # -I$(ENETROOT)/include
|
||||||
NASMFLAGS+= -DUNDERSCORES -f win32
|
NASMFLAGS+= -DUNDERSCORES -f win32
|
||||||
LIBS += -L$(ALROOT)/lib -lvorbisfile -lvorbis -logg -L$(ENETROOT) -lwsock32 -lws2_32 -lwinmm
|
LIBS += -L$(ALROOT)/lib -lvorbisfile -lvorbis -logg -lwsock32 -lws2_32 -lwinmm #-L$(ENETROOT)
|
||||||
GAMEOBJS+= $(OBJ)/gameres.$o $(OBJ)/winbits.$o $(OBJ)/startwin.game.$o
|
GAMEOBJS+= $(OBJ)/gameres.$o $(OBJ)/winbits.$o $(OBJ)/startwin.game.$o
|
||||||
EDITOROBJS+= $(OBJ)/buildres.$o
|
EDITOROBJS+= $(OBJ)/buildres.$o
|
||||||
endif
|
endif
|
||||||
|
@ -285,8 +285,8 @@ endif
|
||||||
|
|
||||||
include Makefile.deps
|
include Makefile.deps
|
||||||
|
|
||||||
ifneq (0,$(ENET_NETWORKING))
|
ifneq (0,$(RANCID_NETWORKING))
|
||||||
duke3d_h+=$(EINC)/enet_mmulti.h
|
duke3d_h+=$(EINC)/mmulti_unstable.h
|
||||||
else
|
else
|
||||||
duke3d_h+=$(EINC)/mmulti.h
|
duke3d_h+=$(EINC)/mmulti.h
|
||||||
endif
|
endif
|
||||||
|
@ -300,7 +300,7 @@ endif
|
||||||
$(MAKE) -C $(EROOT)/ "OBJ=../$(EOBJ)" \
|
$(MAKE) -C $(EROOT)/ "OBJ=../$(EOBJ)" \
|
||||||
SUPERBUILD=$(SUPERBUILD) POLYMOST=$(POLYMOST) \
|
SUPERBUILD=$(SUPERBUILD) POLYMOST=$(POLYMOST) \
|
||||||
USE_OPENGL=$(USE_OPENGL) BUILD32_ON_64=$(BUILD32_ON_64) \
|
USE_OPENGL=$(USE_OPENGL) BUILD32_ON_64=$(BUILD32_ON_64) \
|
||||||
NOASM=$(NOASM) RELEASE=$(RELEASE) OPTLEVEL=$(OPTLEVEL) ENET_NETWORKING=$(ENET_NETWORKING) $@
|
NOASM=$(NOASM) RELEASE=$(RELEASE) OPTLEVEL=$(OPTLEVEL) RANCID_NETWORKING=$(RANCID_NETWORKING) $@
|
||||||
ifeq ($(PRETTY_OUTPUT),1)
|
ifeq ($(PRETTY_OUTPUT),1)
|
||||||
printf "\033[K\033[0;35mChanging dir to \033[1;35m$(CURDIR)\033[0;35m.\033[0m\n"
|
printf "\033[K\033[0;35mChanging dir to \033[1;35m$(CURDIR)\033[0;35m.\033[0m\n"
|
||||||
endif
|
endif
|
||||||
|
|
|
@ -27,7 +27,7 @@ DXROOT=c:\sdks\dx6
|
||||||
MSSDKROOT="C:\Program Files\Microsoft Visual Studio 8\VC
|
MSSDKROOT="C:\Program Files\Microsoft Visual Studio 8\VC
|
||||||
PLATFORMSDK="C:\Program Files\Microsoft Visual Studio 8\VC\PlatformSDK
|
PLATFORMSDK="C:\Program Files\Microsoft Visual Studio 8\VC\PlatformSDK
|
||||||
|
|
||||||
ENGINEOPTS=/DSUPERBUILD /DPOLYMOST /DUSE_OPENGL /DUSE_OPENAL /DPOLYMER
|
ENGINEOPTS=/DSUPERBUILD /DPOLYMOST /DUSE_OPENGL /DUSE_OPENAL /DPOLYMER /DRANCID_NETWORKING
|
||||||
|
|
||||||
CC=cl
|
CC=cl
|
||||||
AS=ml
|
AS=ml
|
||||||
|
|
|
@ -17,7 +17,7 @@ PRETTY_OUTPUT = 1
|
||||||
# USE_OPENGL - enables OpenGL support in Polymost
|
# USE_OPENGL - enables OpenGL support in Polymost
|
||||||
# NOASM - disables the use of inline assembly pragmas
|
# NOASM - disables the use of inline assembly pragmas
|
||||||
# LINKED_GTK - enables compile-time linkage to GTK
|
# LINKED_GTK - enables compile-time linkage to GTK
|
||||||
# ENET_NETWORKING - enable enet-based network backend from rancidmeat/xDuke ports
|
# RANCID_NETWORKING - enable network backend from rancidmeat port
|
||||||
#
|
#
|
||||||
|
|
||||||
SUPERBUILD ?= 1
|
SUPERBUILD ?= 1
|
||||||
|
@ -27,7 +27,7 @@ USE_OPENGL ?= 1
|
||||||
NOASM ?= 0
|
NOASM ?= 0
|
||||||
LINKED_GTK ?= 0
|
LINKED_GTK ?= 0
|
||||||
BUILD32_ON_64 ?= 0
|
BUILD32_ON_64 ?= 0
|
||||||
ENET_NETWORKING ?= 0
|
RANCID_NETWORKING ?= 0
|
||||||
|
|
||||||
# Debugging/Build options
|
# Debugging/Build options
|
||||||
# RELEASE - 1 = no debugging
|
# RELEASE - 1 = no debugging
|
||||||
|
@ -50,7 +50,7 @@ SRC=src
|
||||||
RSRC=rsrc
|
RSRC=rsrc
|
||||||
INC=include
|
INC=include
|
||||||
|
|
||||||
ENETROOT=$(SRC)/enet
|
# ENETROOT=$(SRC)/enet
|
||||||
|
|
||||||
# Filename extensions - these won't need to change
|
# Filename extensions - these won't need to change
|
||||||
#
|
#
|
||||||
|
@ -126,7 +126,7 @@ ifeq (1,$(POLYMER))
|
||||||
ENGINEOBJS+= $(OBJ)/polymer.$o
|
ENGINEOBJS+= $(OBJ)/polymer.$o
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifneq (0,$(ENET_NETWORKING))
|
ifneq (0,$(RANCID_NETWORKING))
|
||||||
ENGINEOBJS+= $(OBJ)/mmulti_unstable.$o
|
ENGINEOBJS+= $(OBJ)/mmulti_unstable.$o
|
||||||
else
|
else
|
||||||
ENGINEOBJS+= $(OBJ)/mmulti.$o
|
ENGINEOBJS+= $(OBJ)/mmulti.$o
|
||||||
|
@ -154,8 +154,8 @@ ifeq ($(PLATFORM),BSD)
|
||||||
LIBS+= -lm
|
LIBS+= -lm
|
||||||
endif
|
endif
|
||||||
ifeq ($(PLATFORM),WINDOWS)
|
ifeq ($(PLATFORM),WINDOWS)
|
||||||
OURCFLAGS+= -DUNDERSCORES -I$(DXROOT)/include -I$(FMODROOTWIN)/inc -I$(ENETROOT)/include
|
OURCFLAGS+= -DUNDERSCORES -I$(DXROOT)/include -I$(FMODROOTWIN)/inc # -I$(ENETROOT)/include
|
||||||
LIBS+= -lm -L$(ENETROOT) -lwsock32 -lws2_32 -lwinmm
|
LIBS+= -lm -lwsock32 -lws2_32 -lwinmm #-L$(ENETROOT)
|
||||||
ASFLAGS+= -DUNDERSCORES -f win32
|
ASFLAGS+= -DUNDERSCORES -f win32
|
||||||
endif
|
endif
|
||||||
ifeq ($(PLATFORM),BEOS)
|
ifeq ($(PLATFORM),BEOS)
|
||||||
|
|
|
@ -18,7 +18,7 @@ $(OBJ)/lzwnew.$o: $(SRC)/lzwnew.c
|
||||||
$(OBJ)/md4.$o: $(SRC)/md4.c $(INC)/md4.h $(INC)/compat.h
|
$(OBJ)/md4.$o: $(SRC)/md4.c $(INC)/md4.h $(INC)/compat.h
|
||||||
$(OBJ)/mmulti_null.$o: $(SRC)/mmulti_null.c $(INC)/mmulti.h
|
$(OBJ)/mmulti_null.$o: $(SRC)/mmulti_null.c $(INC)/mmulti.h
|
||||||
$(OBJ)/mmulti.$o: $(SRC)/mmulti.c $(INC)/mmulti.h
|
$(OBJ)/mmulti.$o: $(SRC)/mmulti.c $(INC)/mmulti.h
|
||||||
$(OBJ)/enet_mmulti.$o: $(SRC)/enet_mmulti.cpp $(INC)/enet_mmulti.h
|
# $(OBJ)/enet_mmulti.$o: $(SRC)/enet_mmulti.cpp $(INC)/enet_mmulti.h
|
||||||
$(OBJ)/mmulti_unstable.$o: $(SRC)/mmulti_unstable.c $(INC)/mmulti_unstable.h
|
$(OBJ)/mmulti_unstable.$o: $(SRC)/mmulti_unstable.c $(INC)/mmulti_unstable.h
|
||||||
$(OBJ)/osd.$o: $(SRC)/osd.c $(INC)/build.h $(INC)/osd.h $(INC)/compat.h $(INC)/baselayer.h
|
$(OBJ)/osd.$o: $(SRC)/osd.c $(INC)/build.h $(INC)/osd.h $(INC)/compat.h $(INC)/baselayer.h
|
||||||
$(OBJ)/pragmas.$o: $(SRC)/pragmas.c $(INC)/compat.h
|
$(OBJ)/pragmas.$o: $(SRC)/pragmas.c $(INC)/compat.h
|
||||||
|
|
|
@ -22,7 +22,7 @@ EDITORLIB=build.lib
|
||||||
DXROOT=c:\sdks\dx6
|
DXROOT=c:\sdks\dx6
|
||||||
MSSDKROOT="C:\Program Files\Microsoft Visual Studio 8\VC
|
MSSDKROOT="C:\Program Files\Microsoft Visual Studio 8\VC
|
||||||
PLATFORMSDK="C:\Program Files\Microsoft Visual Studio 8\VC\PlatformSDK
|
PLATFORMSDK="C:\Program Files\Microsoft Visual Studio 8\VC\PlatformSDK
|
||||||
ENETROOT=$(SRC)\enet
|
# ENETROOT=$(SRC)\enet
|
||||||
|
|
||||||
# /D these to enable certain features of the port's compile process
|
# /D these to enable certain features of the port's compile process
|
||||||
# NOASM When defined, uses C instead of assembly code
|
# NOASM When defined, uses C instead of assembly code
|
||||||
|
@ -45,7 +45,7 @@ CC=cl
|
||||||
AS=ml
|
AS=ml
|
||||||
RC=rc
|
RC=rc
|
||||||
LINK=link /opt:nowin98 /opt:ref /nologo
|
LINK=link /opt:nowin98 /opt:ref /nologo
|
||||||
CFLAGS=$(CFLAGS) /nologo /MD /J $(flags_cl) $(TARGETOPTS) /I$(INC) /I$(DXROOT)\include /I$(MSSDKROOT)\include" /I$(PLATFORMSDK)\include /I$(ENETROOT)\include"
|
CFLAGS=$(CFLAGS) /nologo /MD /J $(flags_cl) $(TARGETOPTS) /I$(INC) /I$(DXROOT)\include /I$(MSSDKROOT)\include" /I$(PLATFORMSDK)\include" # /I$(ENETROOT)\include"
|
||||||
ASFLAGS=/nologo /coff /c
|
ASFLAGS=/nologo /coff /c
|
||||||
EXESUFFIX=.exe
|
EXESUFFIX=.exe
|
||||||
|
|
||||||
|
|
|
@ -162,9 +162,9 @@ endif
|
||||||
|
|
||||||
BUILDCFLAGS+= -DRENDERTYPE$(RENDERTYPE)=1
|
BUILDCFLAGS+= -DRENDERTYPE$(RENDERTYPE)=1
|
||||||
|
|
||||||
ifneq (0,$(ENET_NETWORKING))
|
ifneq (0,$(RANCID_NETWORKING))
|
||||||
LIBS+= -lenet
|
# LIBS+= -lenet
|
||||||
BUILDCFLAGS+= -DENET_NETWORKING
|
BUILDCFLAGS+= -DRANCID_NETWORKING
|
||||||
endif
|
endif
|
||||||
ifneq (0,$(SUPERBUILD))
|
ifneq (0,$(SUPERBUILD))
|
||||||
BUILDCFLAGS+= -DSUPERBUILD
|
BUILDCFLAGS+= -DSUPERBUILD
|
||||||
|
|
|
@ -1,23 +0,0 @@
|
||||||
#ifndef _MMULTI_STABLE_H_
|
|
||||||
#define _MMULTI_STABLE_H_
|
|
||||||
|
|
||||||
#define MAXMULTIPLAYERS 16
|
|
||||||
|
|
||||||
void callcommit(void);
|
|
||||||
void initcrc(void);
|
|
||||||
long getcrc(char *buffer, int bufleng);
|
|
||||||
void initmultiplayers(int argc, char **argv);
|
|
||||||
void sendpacket(long other, char *bufptr, long messleng);
|
|
||||||
void setpackettimeout(long datimeoutcount, long daresendagaincount);
|
|
||||||
void uninitmultiplayers(void);
|
|
||||||
void sendlogon(void);
|
|
||||||
void sendlogoff(void);
|
|
||||||
int getoutputcirclesize(void);
|
|
||||||
void setsocket(int newsocket);
|
|
||||||
int getpacket(int *other, char *bufptr);
|
|
||||||
void flushpackets(void);
|
|
||||||
void genericmultifunction(long other, char *bufptr, long messleng, long command);
|
|
||||||
|
|
||||||
extern int natfree;
|
|
||||||
|
|
||||||
#endif
|
|
|
@ -1,20 +0,0 @@
|
||||||
/ChangeLog/1.4/Wed Feb 13 01:31:07 2008//
|
|
||||||
/Doxyfile/1.1.1.1/Wed Oct 20 17:17:52 2004//
|
|
||||||
/LICENSE/1.2/Thu May 31 09:13:08 2007//
|
|
||||||
/Makefile.am/1.1.1.1/Wed Oct 20 17:17:51 2004//
|
|
||||||
/README/1.6/Wed Feb 13 01:31:07 2008//
|
|
||||||
/callbacks.c/1.1.1.1/Wed Oct 20 17:17:51 2004//
|
|
||||||
/configure.in/1.13/Wed Jan 9 14:14:09 2008//
|
|
||||||
/design.txt/1.1.1.1/Wed Oct 20 17:17:51 2004//
|
|
||||||
/enet.dsp/1.3/Tue Oct 9 23:08:10 2007/-kb/
|
|
||||||
/host.c/1.6/Fri Oct 12 05:21:57 2007//
|
|
||||||
/list.c/1.1.1.1/Wed Oct 20 17:17:51 2004//
|
|
||||||
/packet.c/1.5/Tue Mar 27 06:39:40 2007//
|
|
||||||
/peer.c/1.19/Sun Oct 21 19:14:54 2007//
|
|
||||||
/protocol.c/1.25/Wed Jan 9 14:03:32 2008//
|
|
||||||
/tutorial.txt/1.2/Thu Jul 6 21:30:34 2006//
|
|
||||||
/unix.c/1.8/Wed Oct 3 04:10:09 2007//
|
|
||||||
/win32.c/1.8/Wed Oct 3 04:10:09 2007//
|
|
||||||
D/docs////
|
|
||||||
D/include////
|
|
||||||
D/pyenet////
|
|
|
@ -1 +0,0 @@
|
||||||
R D/pyenet////
|
|
|
@ -1 +0,0 @@
|
||||||
enet
|
|
|
@ -1 +0,0 @@
|
||||||
:pserver:anonymous@bespin.org:/var/lib/cvs/enet
|
|
|
@ -1,36 +0,0 @@
|
||||||
ENet 1.2 (February 12, 2008):
|
|
||||||
|
|
||||||
* fixed bug in VERIFY_CONNECT acknowledgement that could cause connect
|
|
||||||
attempts to occasionally timeout
|
|
||||||
* fixed acknowledgements to check both the outgoing and sent queues
|
|
||||||
when removing acknowledged packets
|
|
||||||
* fixed accidental bit rot in the MSVC project file
|
|
||||||
* revised sequence number overflow handling to address some possible
|
|
||||||
disconnect bugs
|
|
||||||
* added enet_host_check_events() for getting only local queued events
|
|
||||||
* factored out socket option setting into enet_socket_set_option() so
|
|
||||||
that socket options are now set separately from enet_socket_create()
|
|
||||||
|
|
||||||
Caveats: While this release is superficially protocol compatible with 1.1,
|
|
||||||
differences in the sequence number overflow handling can potentially cause
|
|
||||||
random disconnects.
|
|
||||||
|
|
||||||
ENet 1.1 (June 6, 2007):
|
|
||||||
|
|
||||||
* optional CRC32 just in case someone needs a stronger checksum than UDP
|
|
||||||
provides (--enable-crc32 configure option)
|
|
||||||
* the size of packet headers are half the size they used to be (so less
|
|
||||||
overhead when sending small packets)
|
|
||||||
* enet_peer_disconnect_later() that waits till all queued outgoing
|
|
||||||
packets get sent before issuing an actual disconnect
|
|
||||||
* freeCallback field in individual packets for notification of when a
|
|
||||||
packet is about to be freed
|
|
||||||
* ENET_PACKET_FLAG_NO_ALLOCATE for supplying pre-allocated data to a
|
|
||||||
packet (can be used in concert with freeCallback to support some custom
|
|
||||||
allocation schemes that the normal memory allocation callbacks would
|
|
||||||
normally not allow)
|
|
||||||
* enet_address_get_host_ip() for printing address numbers
|
|
||||||
* promoted the enet_socket_*() functions to be part of the API now
|
|
||||||
* a few stability/crash fixes
|
|
||||||
|
|
||||||
|
|
|
@ -1,993 +0,0 @@
|
||||||
# Doxyfile 1.2.18
|
|
||||||
|
|
||||||
# This file describes the settings to be used by the documentation system
|
|
||||||
# doxygen (www.doxygen.org) for a project
|
|
||||||
#
|
|
||||||
# All text after a hash (#) is considered a comment and will be ignored
|
|
||||||
# The format is:
|
|
||||||
# TAG = value [value, ...]
|
|
||||||
# For lists items can also be appended using:
|
|
||||||
# TAG += value [value, ...]
|
|
||||||
# Values that contain spaces should be placed between quotes (" ")
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# General configuration options
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
# The PROJECT_NAME tag is a single word (or a sequence of words surrounded
|
|
||||||
# by quotes) that should identify the project.
|
|
||||||
|
|
||||||
PROJECT_NAME = enet
|
|
||||||
|
|
||||||
# The PROJECT_NUMBER tag can be used to enter a project or revision number.
|
|
||||||
# This could be handy for archiving the generated documentation or
|
|
||||||
# if some version control system is used.
|
|
||||||
|
|
||||||
PROJECT_NUMBER =
|
|
||||||
|
|
||||||
# The OUTPUT_DIRECTORY tag is used to specify the (relative or absolute)
|
|
||||||
# base path where the generated documentation will be put.
|
|
||||||
# If a relative path is entered, it will be relative to the location
|
|
||||||
# where doxygen was started. If left blank the current directory will be used.
|
|
||||||
|
|
||||||
OUTPUT_DIRECTORY = docs
|
|
||||||
|
|
||||||
# The OUTPUT_LANGUAGE tag is used to specify the language in which all
|
|
||||||
# documentation generated by doxygen is written. Doxygen will use this
|
|
||||||
# information to generate all constant output in the proper language.
|
|
||||||
# The default language is English, other supported languages are:
|
|
||||||
# Brazilian, Catalan, Chinese, Chinese-Traditional, Croatian, Czech, Danish, Dutch,
|
|
||||||
# Finnish, French, German, Greek, Hungarian, Italian, Japanese, Japanese-en
|
|
||||||
# (Japanese with english messages), Korean, Norwegian, Polish, Portuguese,
|
|
||||||
# Romanian, Russian, Serbian, Slovak, Slovene, Spanish, Swedish and Ukrainian.
|
|
||||||
|
|
||||||
OUTPUT_LANGUAGE = English
|
|
||||||
|
|
||||||
# If the EXTRACT_ALL tag is set to YES doxygen will assume all entities in
|
|
||||||
# documentation are documented, even if no documentation was available.
|
|
||||||
# Private class members and static file members will be hidden unless
|
|
||||||
# the EXTRACT_PRIVATE and EXTRACT_STATIC tags are set to YES
|
|
||||||
|
|
||||||
EXTRACT_ALL = NO
|
|
||||||
|
|
||||||
# If the EXTRACT_PRIVATE tag is set to YES all private members of a class
|
|
||||||
# will be included in the documentation.
|
|
||||||
|
|
||||||
EXTRACT_PRIVATE = NO
|
|
||||||
|
|
||||||
# If the EXTRACT_STATIC tag is set to YES all static members of a file
|
|
||||||
# will be included in the documentation.
|
|
||||||
|
|
||||||
EXTRACT_STATIC = NO
|
|
||||||
|
|
||||||
# If the EXTRACT_LOCAL_CLASSES tag is set to YES classes (and structs)
|
|
||||||
# defined locally in source files will be included in the documentation.
|
|
||||||
# If set to NO only classes defined in header files are included.
|
|
||||||
|
|
||||||
EXTRACT_LOCAL_CLASSES = NO
|
|
||||||
|
|
||||||
# If the HIDE_UNDOC_MEMBERS tag is set to YES, Doxygen will hide all
|
|
||||||
# undocumented members of documented classes, files or namespaces.
|
|
||||||
# If set to NO (the default) these members will be included in the
|
|
||||||
# various overviews, but no documentation section is generated.
|
|
||||||
# This option has no effect if EXTRACT_ALL is enabled.
|
|
||||||
|
|
||||||
HIDE_UNDOC_MEMBERS = NO
|
|
||||||
|
|
||||||
# If the HIDE_UNDOC_CLASSES tag is set to YES, Doxygen will hide all
|
|
||||||
# undocumented classes that are normally visible in the class hierarchy.
|
|
||||||
# If set to NO (the default) these class will be included in the various
|
|
||||||
# overviews. This option has no effect if EXTRACT_ALL is enabled.
|
|
||||||
|
|
||||||
HIDE_UNDOC_CLASSES = NO
|
|
||||||
|
|
||||||
# If the HIDE_FRIEND_COMPOUNDS tag is set to YES, Doxygen will hide all
|
|
||||||
# friend (class|struct|union) declarations.
|
|
||||||
# If set to NO (the default) these declarations will be included in the
|
|
||||||
# documentation.
|
|
||||||
|
|
||||||
HIDE_FRIEND_COMPOUNDS = NO
|
|
||||||
|
|
||||||
# If the BRIEF_MEMBER_DESC tag is set to YES (the default) Doxygen will
|
|
||||||
# include brief member descriptions after the members that are listed in
|
|
||||||
# the file and class documentation (similar to JavaDoc).
|
|
||||||
# Set to NO to disable this.
|
|
||||||
|
|
||||||
BRIEF_MEMBER_DESC = YES
|
|
||||||
|
|
||||||
# If the REPEAT_BRIEF tag is set to YES (the default) Doxygen will prepend
|
|
||||||
# the brief description of a member or function before the detailed description.
|
|
||||||
# Note: if both HIDE_UNDOC_MEMBERS and BRIEF_MEMBER_DESC are set to NO, the
|
|
||||||
# brief descriptions will be completely suppressed.
|
|
||||||
|
|
||||||
REPEAT_BRIEF = NO
|
|
||||||
|
|
||||||
# If the ALWAYS_DETAILED_SEC and REPEAT_BRIEF tags are both set to YES then
|
|
||||||
# Doxygen will generate a detailed section even if there is only a brief
|
|
||||||
# description.
|
|
||||||
|
|
||||||
ALWAYS_DETAILED_SEC = NO
|
|
||||||
|
|
||||||
# If the INLINE_INHERITED_MEMB tag is set to YES, doxygen will show all inherited
|
|
||||||
# members of a class in the documentation of that class as if those members were
|
|
||||||
# ordinary class members. Constructors, destructors and assignment operators of
|
|
||||||
# the base classes will not be shown.
|
|
||||||
|
|
||||||
INLINE_INHERITED_MEMB = NO
|
|
||||||
|
|
||||||
# If the FULL_PATH_NAMES tag is set to YES then Doxygen will prepend the full
|
|
||||||
# path before files name in the file list and in the header files. If set
|
|
||||||
# to NO the shortest path that makes the file name unique will be used.
|
|
||||||
|
|
||||||
FULL_PATH_NAMES = NO
|
|
||||||
|
|
||||||
# If the FULL_PATH_NAMES tag is set to YES then the STRIP_FROM_PATH tag
|
|
||||||
# can be used to strip a user defined part of the path. Stripping is
|
|
||||||
# only done if one of the specified strings matches the left-hand part of
|
|
||||||
# the path. It is allowed to use relative paths in the argument list.
|
|
||||||
|
|
||||||
STRIP_FROM_PATH =
|
|
||||||
|
|
||||||
# The INTERNAL_DOCS tag determines if documentation
|
|
||||||
# that is typed after a \internal command is included. If the tag is set
|
|
||||||
# to NO (the default) then the documentation will be excluded.
|
|
||||||
# Set it to YES to include the internal documentation.
|
|
||||||
|
|
||||||
INTERNAL_DOCS = NO
|
|
||||||
|
|
||||||
# Setting the STRIP_CODE_COMMENTS tag to YES (the default) will instruct
|
|
||||||
# doxygen to hide any special comment blocks from generated source code
|
|
||||||
# fragments. Normal C and C++ comments will always remain visible.
|
|
||||||
|
|
||||||
STRIP_CODE_COMMENTS = YES
|
|
||||||
|
|
||||||
# If the CASE_SENSE_NAMES tag is set to NO then Doxygen will only generate
|
|
||||||
# file names in lower case letters. If set to YES upper case letters are also
|
|
||||||
# allowed. This is useful if you have classes or files whose names only differ
|
|
||||||
# in case and if your file system supports case sensitive file names. Windows
|
|
||||||
# users are adviced to set this option to NO.
|
|
||||||
|
|
||||||
CASE_SENSE_NAMES = YES
|
|
||||||
|
|
||||||
# If the SHORT_NAMES tag is set to YES, doxygen will generate much shorter
|
|
||||||
# (but less readable) file names. This can be useful is your file systems
|
|
||||||
# doesn't support long names like on DOS, Mac, or CD-ROM.
|
|
||||||
|
|
||||||
SHORT_NAMES = NO
|
|
||||||
|
|
||||||
# If the HIDE_SCOPE_NAMES tag is set to NO (the default) then Doxygen
|
|
||||||
# will show members with their full class and namespace scopes in the
|
|
||||||
# documentation. If set to YES the scope will be hidden.
|
|
||||||
|
|
||||||
HIDE_SCOPE_NAMES = NO
|
|
||||||
|
|
||||||
# If the VERBATIM_HEADERS tag is set to YES (the default) then Doxygen
|
|
||||||
# will generate a verbatim copy of the header file for each class for
|
|
||||||
# which an include is specified. Set to NO to disable this.
|
|
||||||
|
|
||||||
VERBATIM_HEADERS = YES
|
|
||||||
|
|
||||||
# If the SHOW_INCLUDE_FILES tag is set to YES (the default) then Doxygen
|
|
||||||
# will put list of the files that are included by a file in the documentation
|
|
||||||
# of that file.
|
|
||||||
|
|
||||||
SHOW_INCLUDE_FILES = YES
|
|
||||||
|
|
||||||
# If the JAVADOC_AUTOBRIEF tag is set to YES then Doxygen
|
|
||||||
# will interpret the first line (until the first dot) of a JavaDoc-style
|
|
||||||
# comment as the brief description. If set to NO, the JavaDoc
|
|
||||||
# comments will behave just like the Qt-style comments (thus requiring an
|
|
||||||
# explict @brief command for a brief description.
|
|
||||||
|
|
||||||
JAVADOC_AUTOBRIEF = YES
|
|
||||||
|
|
||||||
# The MULTILINE_CPP_IS_BRIEF tag can be set to YES to make Doxygen
|
|
||||||
# treat a multi-line C++ special comment block (i.e. a block of //! or ///
|
|
||||||
# comments) as a brief description. This used to be the default behaviour.
|
|
||||||
# The new default is to treat a multi-line C++ comment block as a detailed
|
|
||||||
# description. Set this tag to YES if you prefer the old behaviour instead.
|
|
||||||
|
|
||||||
MULTILINE_CPP_IS_BRIEF = NO
|
|
||||||
|
|
||||||
# If the DETAILS_AT_TOP tag is set to YES then Doxygen
|
|
||||||
# will output the detailed description near the top, like JavaDoc.
|
|
||||||
# If set to NO, the detailed description appears after the member
|
|
||||||
# documentation.
|
|
||||||
|
|
||||||
DETAILS_AT_TOP = YES
|
|
||||||
|
|
||||||
# If the INHERIT_DOCS tag is set to YES (the default) then an undocumented
|
|
||||||
# member inherits the documentation from any documented member that it
|
|
||||||
# reimplements.
|
|
||||||
|
|
||||||
INHERIT_DOCS = YES
|
|
||||||
|
|
||||||
# If the INLINE_INFO tag is set to YES (the default) then a tag [inline]
|
|
||||||
# is inserted in the documentation for inline members.
|
|
||||||
|
|
||||||
INLINE_INFO = YES
|
|
||||||
|
|
||||||
# If the SORT_MEMBER_DOCS tag is set to YES (the default) then doxygen
|
|
||||||
# will sort the (detailed) documentation of file and class members
|
|
||||||
# alphabetically by member name. If set to NO the members will appear in
|
|
||||||
# declaration order.
|
|
||||||
|
|
||||||
SORT_MEMBER_DOCS = YES
|
|
||||||
|
|
||||||
# If member grouping is used in the documentation and the DISTRIBUTE_GROUP_DOC
|
|
||||||
# tag is set to YES, then doxygen will reuse the documentation of the first
|
|
||||||
# member in the group (if any) for the other members of the group. By default
|
|
||||||
# all members of a group must be documented explicitly.
|
|
||||||
|
|
||||||
DISTRIBUTE_GROUP_DOC = NO
|
|
||||||
|
|
||||||
# The TAB_SIZE tag can be used to set the number of spaces in a tab.
|
|
||||||
# Doxygen uses this value to replace tabs by spaces in code fragments.
|
|
||||||
|
|
||||||
TAB_SIZE = 8
|
|
||||||
|
|
||||||
# The GENERATE_TODOLIST tag can be used to enable (YES) or
|
|
||||||
# disable (NO) the todo list. This list is created by putting \todo
|
|
||||||
# commands in the documentation.
|
|
||||||
|
|
||||||
GENERATE_TODOLIST = YES
|
|
||||||
|
|
||||||
# The GENERATE_TESTLIST tag can be used to enable (YES) or
|
|
||||||
# disable (NO) the test list. This list is created by putting \test
|
|
||||||
# commands in the documentation.
|
|
||||||
|
|
||||||
GENERATE_TESTLIST = YES
|
|
||||||
|
|
||||||
# The GENERATE_BUGLIST tag can be used to enable (YES) or
|
|
||||||
# disable (NO) the bug list. This list is created by putting \bug
|
|
||||||
# commands in the documentation.
|
|
||||||
|
|
||||||
GENERATE_BUGLIST = YES
|
|
||||||
|
|
||||||
# The GENERATE_DEPRECATEDLIST tag can be used to enable (YES) or
|
|
||||||
# disable (NO) the deprecated list. This list is created by putting \deprecated commands in the documentation.
|
|
||||||
|
|
||||||
GENERATE_DEPRECATEDLIST= YES
|
|
||||||
|
|
||||||
# This tag can be used to specify a number of aliases that acts
|
|
||||||
# as commands in the documentation. An alias has the form "name=value".
|
|
||||||
# For example adding "sideeffect=\par Side Effects:\n" will allow you to
|
|
||||||
# put the command \sideeffect (or @sideeffect) in the documentation, which
|
|
||||||
# will result in a user defined paragraph with heading "Side Effects:".
|
|
||||||
# You can put \n's in the value part of an alias to insert newlines.
|
|
||||||
|
|
||||||
ALIASES =
|
|
||||||
|
|
||||||
# The ENABLED_SECTIONS tag can be used to enable conditional
|
|
||||||
# documentation sections, marked by \if sectionname ... \endif.
|
|
||||||
|
|
||||||
ENABLED_SECTIONS =
|
|
||||||
|
|
||||||
# The MAX_INITIALIZER_LINES tag determines the maximum number of lines
|
|
||||||
# the initial value of a variable or define consist of for it to appear in
|
|
||||||
# the documentation. If the initializer consists of more lines than specified
|
|
||||||
# here it will be hidden. Use a value of 0 to hide initializers completely.
|
|
||||||
# The appearance of the initializer of individual variables and defines in the
|
|
||||||
# documentation can be controlled using \showinitializer or \hideinitializer
|
|
||||||
# command in the documentation regardless of this setting.
|
|
||||||
|
|
||||||
MAX_INITIALIZER_LINES = 30
|
|
||||||
|
|
||||||
# Set the OPTIMIZE_OUTPUT_FOR_C tag to YES if your project consists of C sources
|
|
||||||
# only. Doxygen will then generate output that is more tailored for C.
|
|
||||||
# For instance some of the names that are used will be different. The list
|
|
||||||
# of all members will be omitted, etc.
|
|
||||||
|
|
||||||
OPTIMIZE_OUTPUT_FOR_C = YES
|
|
||||||
|
|
||||||
# Set the OPTIMIZE_OUTPUT_JAVA tag to YES if your project consists of Java sources
|
|
||||||
# only. Doxygen will then generate output that is more tailored for Java.
|
|
||||||
# For instance namespaces will be presented as packages, qualified scopes
|
|
||||||
# will look different, etc.
|
|
||||||
|
|
||||||
OPTIMIZE_OUTPUT_JAVA = NO
|
|
||||||
|
|
||||||
# Set the SHOW_USED_FILES tag to NO to disable the list of files generated
|
|
||||||
# at the bottom of the documentation of classes and structs. If set to YES the
|
|
||||||
# list will mention the files that were used to generate the documentation.
|
|
||||||
|
|
||||||
SHOW_USED_FILES = YES
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to warning and progress messages
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
# The QUIET tag can be used to turn on/off the messages that are generated
|
|
||||||
# by doxygen. Possible values are YES and NO. If left blank NO is used.
|
|
||||||
|
|
||||||
QUIET = NO
|
|
||||||
|
|
||||||
# The WARNINGS tag can be used to turn on/off the warning messages that are
|
|
||||||
# generated by doxygen. Possible values are YES and NO. If left blank
|
|
||||||
# NO is used.
|
|
||||||
|
|
||||||
WARNINGS = YES
|
|
||||||
|
|
||||||
# If WARN_IF_UNDOCUMENTED is set to YES, then doxygen will generate warnings
|
|
||||||
# for undocumented members. If EXTRACT_ALL is set to YES then this flag will
|
|
||||||
# automatically be disabled.
|
|
||||||
|
|
||||||
WARN_IF_UNDOCUMENTED = YES
|
|
||||||
|
|
||||||
# The WARN_FORMAT tag determines the format of the warning messages that
|
|
||||||
# doxygen can produce. The string should contain the $file, $line, and $text
|
|
||||||
# tags, which will be replaced by the file and line number from which the
|
|
||||||
# warning originated and the warning text.
|
|
||||||
|
|
||||||
WARN_FORMAT = "$file:$line: $text"
|
|
||||||
|
|
||||||
# The WARN_LOGFILE tag can be used to specify a file to which warning
|
|
||||||
# and error messages should be written. If left blank the output is written
|
|
||||||
# to stderr.
|
|
||||||
|
|
||||||
WARN_LOGFILE =
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the input files
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
# The INPUT tag can be used to specify the files and/or directories that contain
|
|
||||||
# documented source files. You may enter file names like "myfile.cpp" or
|
|
||||||
# directories like "/usr/src/myproject". Separate the files or directories
|
|
||||||
# with spaces.
|
|
||||||
|
|
||||||
INPUT = . include/enet docs
|
|
||||||
|
|
||||||
# If the value of the INPUT tag contains directories, you can use the
|
|
||||||
# FILE_PATTERNS tag to specify one or more wildcard pattern (like *.cpp
|
|
||||||
# and *.h) to filter out the source-files in the directories. If left
|
|
||||||
# blank the following patterns are tested:
|
|
||||||
# *.c *.cc *.cxx *.cpp *.c++ *.java *.ii *.ixx *.ipp *.i++ *.inl *.h *.hh *.hxx *.hpp
|
|
||||||
# *.h++ *.idl *.odl
|
|
||||||
|
|
||||||
FILE_PATTERNS = *.c *.h *.dox
|
|
||||||
|
|
||||||
# The RECURSIVE tag can be used to turn specify whether or not subdirectories
|
|
||||||
# should be searched for input files as well. Possible values are YES and NO.
|
|
||||||
# If left blank NO is used.
|
|
||||||
|
|
||||||
RECURSIVE = YES
|
|
||||||
|
|
||||||
# The EXCLUDE tag can be used to specify files and/or directories that should
|
|
||||||
# excluded from the INPUT source files. This way you can easily exclude a
|
|
||||||
# subdirectory from a directory tree whose root is specified with the INPUT tag.
|
|
||||||
|
|
||||||
EXCLUDE = Tests
|
|
||||||
|
|
||||||
# The EXCLUDE_SYMLINKS tag can be used select whether or not files or directories
|
|
||||||
# that are symbolic links (a Unix filesystem feature) are excluded from the input.
|
|
||||||
|
|
||||||
EXCLUDE_SYMLINKS = NO
|
|
||||||
|
|
||||||
# If the value of the INPUT tag contains directories, you can use the
|
|
||||||
# EXCLUDE_PATTERNS tag to specify one or more wildcard patterns to exclude
|
|
||||||
# certain files from those directories.
|
|
||||||
|
|
||||||
EXCLUDE_PATTERNS =
|
|
||||||
|
|
||||||
# The EXAMPLE_PATH tag can be used to specify one or more files or
|
|
||||||
# directories that contain example code fragments that are included (see
|
|
||||||
# the \include command).
|
|
||||||
|
|
||||||
EXAMPLE_PATH =
|
|
||||||
|
|
||||||
# If the value of the EXAMPLE_PATH tag contains directories, you can use the
|
|
||||||
# EXAMPLE_PATTERNS tag to specify one or more wildcard pattern (like *.cpp
|
|
||||||
# and *.h) to filter out the source-files in the directories. If left
|
|
||||||
# blank all files are included.
|
|
||||||
|
|
||||||
EXAMPLE_PATTERNS =
|
|
||||||
|
|
||||||
# If the EXAMPLE_RECURSIVE tag is set to YES then subdirectories will be
|
|
||||||
# searched for input files to be used with the \include or \dontinclude
|
|
||||||
# commands irrespective of the value of the RECURSIVE tag.
|
|
||||||
# Possible values are YES and NO. If left blank NO is used.
|
|
||||||
|
|
||||||
EXAMPLE_RECURSIVE = NO
|
|
||||||
|
|
||||||
# The IMAGE_PATH tag can be used to specify one or more files or
|
|
||||||
# directories that contain image that are included in the documentation (see
|
|
||||||
# the \image command).
|
|
||||||
|
|
||||||
IMAGE_PATH =
|
|
||||||
|
|
||||||
# The INPUT_FILTER tag can be used to specify a program that doxygen should
|
|
||||||
# invoke to filter for each input file. Doxygen will invoke the filter program
|
|
||||||
# by executing (via popen()) the command <filter> <input-file>, where <filter>
|
|
||||||
# is the value of the INPUT_FILTER tag, and <input-file> is the name of an
|
|
||||||
# input file. Doxygen will then use the output that the filter program writes
|
|
||||||
# to standard output.
|
|
||||||
|
|
||||||
INPUT_FILTER =
|
|
||||||
|
|
||||||
# If the FILTER_SOURCE_FILES tag is set to YES, the input filter (if set using
|
|
||||||
# INPUT_FILTER) will be used to filter the input files when producing source
|
|
||||||
# files to browse (i.e. when SOURCE_BROWSER is set to YES).
|
|
||||||
|
|
||||||
FILTER_SOURCE_FILES = NO
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to source browsing
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
# If the SOURCE_BROWSER tag is set to YES then a list of source files will
|
|
||||||
# be generated. Documented entities will be cross-referenced with these sources.
|
|
||||||
|
|
||||||
SOURCE_BROWSER = NO
|
|
||||||
|
|
||||||
# Setting the INLINE_SOURCES tag to YES will include the body
|
|
||||||
# of functions and classes directly in the documentation.
|
|
||||||
|
|
||||||
INLINE_SOURCES = NO
|
|
||||||
|
|
||||||
# If the REFERENCED_BY_RELATION tag is set to YES (the default)
|
|
||||||
# then for each documented function all documented
|
|
||||||
# functions referencing it will be listed.
|
|
||||||
|
|
||||||
REFERENCED_BY_RELATION = YES
|
|
||||||
|
|
||||||
# If the REFERENCES_RELATION tag is set to YES (the default)
|
|
||||||
# then for each documented function all documented entities
|
|
||||||
# called/used by that function will be listed.
|
|
||||||
|
|
||||||
REFERENCES_RELATION = YES
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the alphabetical class index
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
# If the ALPHABETICAL_INDEX tag is set to YES, an alphabetical index
|
|
||||||
# of all compounds will be generated. Enable this if the project
|
|
||||||
# contains a lot of classes, structs, unions or interfaces.
|
|
||||||
|
|
||||||
ALPHABETICAL_INDEX = YES
|
|
||||||
|
|
||||||
# If the alphabetical index is enabled (see ALPHABETICAL_INDEX) then
|
|
||||||
# the COLS_IN_ALPHA_INDEX tag can be used to specify the number of columns
|
|
||||||
# in which this list will be split (can be a number in the range [1..20])
|
|
||||||
|
|
||||||
COLS_IN_ALPHA_INDEX = 5
|
|
||||||
|
|
||||||
# In case all classes in a project start with a common prefix, all
|
|
||||||
# classes will be put under the same header in the alphabetical index.
|
|
||||||
# The IGNORE_PREFIX tag can be used to specify one or more prefixes that
|
|
||||||
# should be ignored while generating the index headers.
|
|
||||||
|
|
||||||
IGNORE_PREFIX =
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the HTML output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
# If the GENERATE_HTML tag is set to YES (the default) Doxygen will
|
|
||||||
# generate HTML output.
|
|
||||||
|
|
||||||
GENERATE_HTML = YES
|
|
||||||
|
|
||||||
# The HTML_OUTPUT tag is used to specify where the HTML docs will be put.
|
|
||||||
# If a relative path is entered the value of OUTPUT_DIRECTORY will be
|
|
||||||
# put in front of it. If left blank `html' will be used as the default path.
|
|
||||||
|
|
||||||
HTML_OUTPUT = html
|
|
||||||
|
|
||||||
# The HTML_FILE_EXTENSION tag can be used to specify the file extension for
|
|
||||||
# each generated HTML page (for example: .htm,.php,.asp). If it is left blank
|
|
||||||
# doxygen will generate files with .html extension.
|
|
||||||
|
|
||||||
HTML_FILE_EXTENSION = .html
|
|
||||||
|
|
||||||
# The HTML_HEADER tag can be used to specify a personal HTML header for
|
|
||||||
# each generated HTML page. If it is left blank doxygen will generate a
|
|
||||||
# standard header.
|
|
||||||
|
|
||||||
HTML_HEADER =
|
|
||||||
|
|
||||||
# The HTML_FOOTER tag can be used to specify a personal HTML footer for
|
|
||||||
# each generated HTML page. If it is left blank doxygen will generate a
|
|
||||||
# standard footer.
|
|
||||||
|
|
||||||
HTML_FOOTER =
|
|
||||||
|
|
||||||
# The HTML_STYLESHEET tag can be used to specify a user defined cascading
|
|
||||||
# style sheet that is used by each HTML page. It can be used to
|
|
||||||
# fine-tune the look of the HTML output. If the tag is left blank doxygen
|
|
||||||
# will generate a default style sheet
|
|
||||||
|
|
||||||
HTML_STYLESHEET =
|
|
||||||
|
|
||||||
# If the HTML_ALIGN_MEMBERS tag is set to YES, the members of classes,
|
|
||||||
# files or namespaces will be aligned in HTML using tables. If set to
|
|
||||||
# NO a bullet list will be used.
|
|
||||||
|
|
||||||
HTML_ALIGN_MEMBERS = YES
|
|
||||||
|
|
||||||
# If the GENERATE_HTMLHELP tag is set to YES, additional index files
|
|
||||||
# will be generated that can be used as input for tools like the
|
|
||||||
# Microsoft HTML help workshop to generate a compressed HTML help file (.chm)
|
|
||||||
# of the generated HTML documentation.
|
|
||||||
|
|
||||||
GENERATE_HTMLHELP = NO
|
|
||||||
|
|
||||||
# If the GENERATE_HTMLHELP tag is set to YES, the CHM_FILE tag can
|
|
||||||
# be used to specify the file name of the resulting .chm file. You
|
|
||||||
# can add a path in front of the file if the result should not be
|
|
||||||
# written to the html output dir.
|
|
||||||
|
|
||||||
CHM_FILE =
|
|
||||||
|
|
||||||
# If the GENERATE_HTMLHELP tag is set to YES, the HHC_LOCATION tag can
|
|
||||||
# be used to specify the location (absolute path including file name) of
|
|
||||||
# the HTML help compiler (hhc.exe). If non empty doxygen will try to run
|
|
||||||
# the html help compiler on the generated index.hhp.
|
|
||||||
|
|
||||||
HHC_LOCATION =
|
|
||||||
|
|
||||||
# If the GENERATE_HTMLHELP tag is set to YES, the GENERATE_CHI flag
|
|
||||||
# controls if a separate .chi index file is generated (YES) or that
|
|
||||||
# it should be included in the master .chm file (NO).
|
|
||||||
|
|
||||||
GENERATE_CHI = NO
|
|
||||||
|
|
||||||
# If the GENERATE_HTMLHELP tag is set to YES, the BINARY_TOC flag
|
|
||||||
# controls whether a binary table of contents is generated (YES) or a
|
|
||||||
# normal table of contents (NO) in the .chm file.
|
|
||||||
|
|
||||||
BINARY_TOC = NO
|
|
||||||
|
|
||||||
# The TOC_EXPAND flag can be set to YES to add extra items for group members
|
|
||||||
# to the contents of the Html help documentation and to the tree view.
|
|
||||||
|
|
||||||
TOC_EXPAND = NO
|
|
||||||
|
|
||||||
# The DISABLE_INDEX tag can be used to turn on/off the condensed index at
|
|
||||||
# top of each HTML page. The value NO (the default) enables the index and
|
|
||||||
# the value YES disables it.
|
|
||||||
|
|
||||||
DISABLE_INDEX = NO
|
|
||||||
|
|
||||||
# This tag can be used to set the number of enum values (range [1..20])
|
|
||||||
# that doxygen will group on one line in the generated HTML documentation.
|
|
||||||
|
|
||||||
ENUM_VALUES_PER_LINE = 4
|
|
||||||
|
|
||||||
# If the GENERATE_TREEVIEW tag is set to YES, a side panel will be
|
|
||||||
# generated containing a tree-like index structure (just like the one that
|
|
||||||
# is generated for HTML Help). For this to work a browser that supports
|
|
||||||
# JavaScript and frames is required (for instance Mozilla, Netscape 4.0+,
|
|
||||||
# or Internet explorer 4.0+). Note that for large projects the tree generation
|
|
||||||
# can take a very long time. In such cases it is better to disable this feature.
|
|
||||||
# Windows users are probably better off using the HTML help feature.
|
|
||||||
|
|
||||||
GENERATE_TREEVIEW = NO
|
|
||||||
|
|
||||||
# If the treeview is enabled (see GENERATE_TREEVIEW) then this tag can be
|
|
||||||
# used to set the initial width (in pixels) of the frame in which the tree
|
|
||||||
# is shown.
|
|
||||||
|
|
||||||
TREEVIEW_WIDTH = 250
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the LaTeX output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
# If the GENERATE_LATEX tag is set to YES (the default) Doxygen will
|
|
||||||
# generate Latex output.
|
|
||||||
|
|
||||||
GENERATE_LATEX = NO
|
|
||||||
|
|
||||||
# The LATEX_OUTPUT tag is used to specify where the LaTeX docs will be put.
|
|
||||||
# If a relative path is entered the value of OUTPUT_DIRECTORY will be
|
|
||||||
# put in front of it. If left blank `latex' will be used as the default path.
|
|
||||||
|
|
||||||
LATEX_OUTPUT = latex
|
|
||||||
|
|
||||||
# The LATEX_CMD_NAME tag can be used to specify the LaTeX command name to be invoked. If left blank `latex' will be used as the default command name.
|
|
||||||
|
|
||||||
LATEX_CMD_NAME = latex
|
|
||||||
|
|
||||||
# The MAKEINDEX_CMD_NAME tag can be used to specify the command name to
|
|
||||||
# generate index for LaTeX. If left blank `makeindex' will be used as the
|
|
||||||
# default command name.
|
|
||||||
|
|
||||||
MAKEINDEX_CMD_NAME = makeindex
|
|
||||||
|
|
||||||
# If the COMPACT_LATEX tag is set to YES Doxygen generates more compact
|
|
||||||
# LaTeX documents. This may be useful for small projects and may help to
|
|
||||||
# save some trees in general.
|
|
||||||
|
|
||||||
COMPACT_LATEX = NO
|
|
||||||
|
|
||||||
# The PAPER_TYPE tag can be used to set the paper type that is used
|
|
||||||
# by the printer. Possible values are: a4, a4wide, letter, legal and
|
|
||||||
# executive. If left blank a4wide will be used.
|
|
||||||
|
|
||||||
PAPER_TYPE = a4wide
|
|
||||||
|
|
||||||
# The EXTRA_PACKAGES tag can be to specify one or more names of LaTeX
|
|
||||||
# packages that should be included in the LaTeX output.
|
|
||||||
|
|
||||||
EXTRA_PACKAGES =
|
|
||||||
|
|
||||||
# The LATEX_HEADER tag can be used to specify a personal LaTeX header for
|
|
||||||
# the generated latex document. The header should contain everything until
|
|
||||||
# the first chapter. If it is left blank doxygen will generate a
|
|
||||||
# standard header. Notice: only use this tag if you know what you are doing!
|
|
||||||
|
|
||||||
LATEX_HEADER =
|
|
||||||
|
|
||||||
# If the PDF_HYPERLINKS tag is set to YES, the LaTeX that is generated
|
|
||||||
# is prepared for conversion to pdf (using ps2pdf). The pdf file will
|
|
||||||
# contain links (just like the HTML output) instead of page references
|
|
||||||
# This makes the output suitable for online browsing using a pdf viewer.
|
|
||||||
|
|
||||||
PDF_HYPERLINKS = NO
|
|
||||||
|
|
||||||
# If the USE_PDFLATEX tag is set to YES, pdflatex will be used instead of
|
|
||||||
# plain latex in the generated Makefile. Set this option to YES to get a
|
|
||||||
# higher quality PDF documentation.
|
|
||||||
|
|
||||||
USE_PDFLATEX = NO
|
|
||||||
|
|
||||||
# If the LATEX_BATCHMODE tag is set to YES, doxygen will add the \\batchmode.
|
|
||||||
# command to the generated LaTeX files. This will instruct LaTeX to keep
|
|
||||||
# running if errors occur, instead of asking the user for help.
|
|
||||||
# This option is also used when generating formulas in HTML.
|
|
||||||
|
|
||||||
LATEX_BATCHMODE = NO
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the RTF output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
# If the GENERATE_RTF tag is set to YES Doxygen will generate RTF output
|
|
||||||
# The RTF output is optimised for Word 97 and may not look very pretty with
|
|
||||||
# other RTF readers or editors.
|
|
||||||
|
|
||||||
GENERATE_RTF = NO
|
|
||||||
|
|
||||||
# The RTF_OUTPUT tag is used to specify where the RTF docs will be put.
|
|
||||||
# If a relative path is entered the value of OUTPUT_DIRECTORY will be
|
|
||||||
# put in front of it. If left blank `rtf' will be used as the default path.
|
|
||||||
|
|
||||||
RTF_OUTPUT = rtf
|
|
||||||
|
|
||||||
# If the COMPACT_RTF tag is set to YES Doxygen generates more compact
|
|
||||||
# RTF documents. This may be useful for small projects and may help to
|
|
||||||
# save some trees in general.
|
|
||||||
|
|
||||||
COMPACT_RTF = NO
|
|
||||||
|
|
||||||
# If the RTF_HYPERLINKS tag is set to YES, the RTF that is generated
|
|
||||||
# will contain hyperlink fields. The RTF file will
|
|
||||||
# contain links (just like the HTML output) instead of page references.
|
|
||||||
# This makes the output suitable for online browsing using WORD or other
|
|
||||||
# programs which support those fields.
|
|
||||||
# Note: wordpad (write) and others do not support links.
|
|
||||||
|
|
||||||
RTF_HYPERLINKS = NO
|
|
||||||
|
|
||||||
# Load stylesheet definitions from file. Syntax is similar to doxygen's
|
|
||||||
# config file, i.e. a series of assigments. You only have to provide
|
|
||||||
# replacements, missing definitions are set to their default value.
|
|
||||||
|
|
||||||
RTF_STYLESHEET_FILE =
|
|
||||||
|
|
||||||
# Set optional variables used in the generation of an rtf document.
|
|
||||||
# Syntax is similar to doxygen's config file.
|
|
||||||
|
|
||||||
RTF_EXTENSIONS_FILE =
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the man page output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
# If the GENERATE_MAN tag is set to YES (the default) Doxygen will
|
|
||||||
# generate man pages
|
|
||||||
|
|
||||||
GENERATE_MAN = NO
|
|
||||||
|
|
||||||
# The MAN_OUTPUT tag is used to specify where the man pages will be put.
|
|
||||||
# If a relative path is entered the value of OUTPUT_DIRECTORY will be
|
|
||||||
# put in front of it. If left blank `man' will be used as the default path.
|
|
||||||
|
|
||||||
MAN_OUTPUT = man
|
|
||||||
|
|
||||||
# The MAN_EXTENSION tag determines the extension that is added to
|
|
||||||
# the generated man pages (default is the subroutine's section .3)
|
|
||||||
|
|
||||||
MAN_EXTENSION = .3
|
|
||||||
|
|
||||||
# If the MAN_LINKS tag is set to YES and Doxygen generates man output,
|
|
||||||
# then it will generate one additional man file for each entity
|
|
||||||
# documented in the real man page(s). These additional files
|
|
||||||
# only source the real man page, but without them the man command
|
|
||||||
# would be unable to find the correct page. The default is NO.
|
|
||||||
|
|
||||||
MAN_LINKS = NO
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options related to the XML output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
# If the GENERATE_XML tag is set to YES Doxygen will
|
|
||||||
# generate an XML file that captures the structure of
|
|
||||||
# the code including all documentation. Note that this
|
|
||||||
# feature is still experimental and incomplete at the
|
|
||||||
# moment.
|
|
||||||
|
|
||||||
GENERATE_XML = NO
|
|
||||||
|
|
||||||
# The XML_SCHEMA tag can be used to specify an XML schema,
|
|
||||||
# which can be used by a validating XML parser to check the
|
|
||||||
# syntax of the XML files.
|
|
||||||
|
|
||||||
XML_SCHEMA =
|
|
||||||
|
|
||||||
# The XML_DTD tag can be used to specify an XML DTD,
|
|
||||||
# which can be used by a validating XML parser to check the
|
|
||||||
# syntax of the XML files.
|
|
||||||
|
|
||||||
XML_DTD =
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# configuration options for the AutoGen Definitions output
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
# If the GENERATE_AUTOGEN_DEF tag is set to YES Doxygen will
|
|
||||||
# generate an AutoGen Definitions (see autogen.sf.net) file
|
|
||||||
# that captures the structure of the code including all
|
|
||||||
# documentation. Note that this feature is still experimental
|
|
||||||
# and incomplete at the moment.
|
|
||||||
|
|
||||||
GENERATE_AUTOGEN_DEF = NO
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# Configuration options related to the preprocessor
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
# If the ENABLE_PREPROCESSING tag is set to YES (the default) Doxygen will
|
|
||||||
# evaluate all C-preprocessor directives found in the sources and include
|
|
||||||
# files.
|
|
||||||
|
|
||||||
ENABLE_PREPROCESSING = YES
|
|
||||||
|
|
||||||
# If the MACRO_EXPANSION tag is set to YES Doxygen will expand all macro
|
|
||||||
# names in the source code. If set to NO (the default) only conditional
|
|
||||||
# compilation will be performed. Macro expansion can be done in a controlled
|
|
||||||
# way by setting EXPAND_ONLY_PREDEF to YES.
|
|
||||||
|
|
||||||
MACRO_EXPANSION = NO
|
|
||||||
|
|
||||||
# If the EXPAND_ONLY_PREDEF and MACRO_EXPANSION tags are both set to YES
|
|
||||||
# then the macro expansion is limited to the macros specified with the
|
|
||||||
# PREDEFINED and EXPAND_AS_PREDEFINED tags.
|
|
||||||
|
|
||||||
EXPAND_ONLY_PREDEF = NO
|
|
||||||
|
|
||||||
# If the SEARCH_INCLUDES tag is set to YES (the default) the includes files
|
|
||||||
# in the INCLUDE_PATH (see below) will be search if a #include is found.
|
|
||||||
|
|
||||||
SEARCH_INCLUDES = YES
|
|
||||||
|
|
||||||
# The INCLUDE_PATH tag can be used to specify one or more directories that
|
|
||||||
# contain include files that are not input files but should be processed by
|
|
||||||
# the preprocessor.
|
|
||||||
|
|
||||||
INCLUDE_PATH =
|
|
||||||
|
|
||||||
# You can use the INCLUDE_FILE_PATTERNS tag to specify one or more wildcard
|
|
||||||
# patterns (like *.h and *.hpp) to filter out the header-files in the
|
|
||||||
# directories. If left blank, the patterns specified with FILE_PATTERNS will
|
|
||||||
# be used.
|
|
||||||
|
|
||||||
INCLUDE_FILE_PATTERNS =
|
|
||||||
|
|
||||||
# The PREDEFINED tag can be used to specify one or more macro names that
|
|
||||||
# are defined before the preprocessor is started (similar to the -D option of
|
|
||||||
# gcc). The argument of the tag is a list of macros of the form: name
|
|
||||||
# or name=definition (no spaces). If the definition and the = are
|
|
||||||
# omitted =1 is assumed.
|
|
||||||
|
|
||||||
PREDEFINED = FORCE_DOXYGEN
|
|
||||||
|
|
||||||
# If the MACRO_EXPANSION and EXPAND_PREDEF_ONLY tags are set to YES then
|
|
||||||
# this tag can be used to specify a list of macro names that should be expanded.
|
|
||||||
# The macro definition that is found in the sources will be used.
|
|
||||||
# Use the PREDEFINED tag if you want to use a different macro definition.
|
|
||||||
|
|
||||||
EXPAND_AS_DEFINED =
|
|
||||||
|
|
||||||
# If the SKIP_FUNCTION_MACROS tag is set to YES (the default) then
|
|
||||||
# doxygen's preprocessor will remove all function-like macros that are alone
|
|
||||||
# on a line, have an all uppercase name, and do not end with a semicolon. Such
|
|
||||||
# function macros are typically used for boiler-plate code, and will confuse the
|
|
||||||
# parser if not removed.
|
|
||||||
|
|
||||||
SKIP_FUNCTION_MACROS = YES
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# Configuration::addtions related to external references
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
# The TAGFILES tag can be used to specify one or more tagfiles.
|
|
||||||
|
|
||||||
TAGFILES =
|
|
||||||
|
|
||||||
# When a file name is specified after GENERATE_TAGFILE, doxygen will create
|
|
||||||
# a tag file that is based on the input files it reads.
|
|
||||||
|
|
||||||
GENERATE_TAGFILE =
|
|
||||||
|
|
||||||
# If the ALLEXTERNALS tag is set to YES all external classes will be listed
|
|
||||||
# in the class index. If set to NO only the inherited external classes
|
|
||||||
# will be listed.
|
|
||||||
|
|
||||||
ALLEXTERNALS = NO
|
|
||||||
|
|
||||||
# If the EXTERNAL_GROUPS tag is set to YES all external groups will be listed
|
|
||||||
# in the modules index. If set to NO, only the current project's groups will
|
|
||||||
# be listed.
|
|
||||||
|
|
||||||
EXTERNAL_GROUPS = YES
|
|
||||||
|
|
||||||
# The PERL_PATH should be the absolute path and name of the perl script
|
|
||||||
# interpreter (i.e. the result of `which perl').
|
|
||||||
|
|
||||||
PERL_PATH = /usr/bin/perl
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# Configuration options related to the dot tool
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
# If the CLASS_DIAGRAMS tag is set to YES (the default) Doxygen will
|
|
||||||
# generate a inheritance diagram (in Html, RTF and LaTeX) for classes with base or
|
|
||||||
# super classes. Setting the tag to NO turns the diagrams off. Note that this
|
|
||||||
# option is superceded by the HAVE_DOT option below. This is only a fallback. It is
|
|
||||||
# recommended to install and use dot, since it yield more powerful graphs.
|
|
||||||
|
|
||||||
CLASS_DIAGRAMS = YES
|
|
||||||
|
|
||||||
# If set to YES, the inheritance and collaboration graphs will hide
|
|
||||||
# inheritance and usage relations if the target is undocumented
|
|
||||||
# or is not a class.
|
|
||||||
|
|
||||||
HIDE_UNDOC_RELATIONS = YES
|
|
||||||
|
|
||||||
# If you set the HAVE_DOT tag to YES then doxygen will assume the dot tool is
|
|
||||||
# available from the path. This tool is part of Graphviz, a graph visualization
|
|
||||||
# toolkit from AT&T and Lucent Bell Labs. The other options in this section
|
|
||||||
# have no effect if this option is set to NO (the default)
|
|
||||||
|
|
||||||
HAVE_DOT = NO
|
|
||||||
|
|
||||||
# If the CLASS_GRAPH and HAVE_DOT tags are set to YES then doxygen
|
|
||||||
# will generate a graph for each documented class showing the direct and
|
|
||||||
# indirect inheritance relations. Setting this tag to YES will force the
|
|
||||||
# the CLASS_DIAGRAMS tag to NO.
|
|
||||||
|
|
||||||
CLASS_GRAPH = YES
|
|
||||||
|
|
||||||
# If the COLLABORATION_GRAPH and HAVE_DOT tags are set to YES then doxygen
|
|
||||||
# will generate a graph for each documented class showing the direct and
|
|
||||||
# indirect implementation dependencies (inheritance, containment, and
|
|
||||||
# class references variables) of the class with other documented classes.
|
|
||||||
|
|
||||||
COLLABORATION_GRAPH = YES
|
|
||||||
|
|
||||||
# If set to YES, the inheritance and collaboration graphs will show the
|
|
||||||
# relations between templates and their instances.
|
|
||||||
|
|
||||||
TEMPLATE_RELATIONS = YES
|
|
||||||
|
|
||||||
# If the ENABLE_PREPROCESSING, SEARCH_INCLUDES, INCLUDE_GRAPH, and HAVE_DOT
|
|
||||||
# tags are set to YES then doxygen will generate a graph for each documented
|
|
||||||
# file showing the direct and indirect include dependencies of the file with
|
|
||||||
# other documented files.
|
|
||||||
|
|
||||||
INCLUDE_GRAPH = YES
|
|
||||||
|
|
||||||
# If the ENABLE_PREPROCESSING, SEARCH_INCLUDES, INCLUDED_BY_GRAPH, and
|
|
||||||
# HAVE_DOT tags are set to YES then doxygen will generate a graph for each
|
|
||||||
# documented header file showing the documented files that directly or
|
|
||||||
# indirectly include this file.
|
|
||||||
|
|
||||||
INCLUDED_BY_GRAPH = YES
|
|
||||||
|
|
||||||
# If the GRAPHICAL_HIERARCHY and HAVE_DOT tags are set to YES then doxygen
|
|
||||||
# will graphical hierarchy of all classes instead of a textual one.
|
|
||||||
|
|
||||||
GRAPHICAL_HIERARCHY = YES
|
|
||||||
|
|
||||||
# The DOT_IMAGE_FORMAT tag can be used to set the image format of the images
|
|
||||||
# generated by dot. Possible values are png, jpg, or gif
|
|
||||||
# If left blank png will be used.
|
|
||||||
|
|
||||||
DOT_IMAGE_FORMAT = png
|
|
||||||
|
|
||||||
# The tag DOT_PATH can be used to specify the path where the dot tool can be
|
|
||||||
# found. If left blank, it is assumed the dot tool can be found on the path.
|
|
||||||
|
|
||||||
DOT_PATH =
|
|
||||||
|
|
||||||
# The DOTFILE_DIRS tag can be used to specify one or more directories that
|
|
||||||
# contain dot files that are included in the documentation (see the
|
|
||||||
# \dotfile command).
|
|
||||||
|
|
||||||
DOTFILE_DIRS =
|
|
||||||
|
|
||||||
# The MAX_DOT_GRAPH_WIDTH tag can be used to set the maximum allowed width
|
|
||||||
# (in pixels) of the graphs generated by dot. If a graph becomes larger than
|
|
||||||
# this value, doxygen will try to truncate the graph, so that it fits within
|
|
||||||
# the specified constraint. Beware that most browsers cannot cope with very
|
|
||||||
# large images.
|
|
||||||
|
|
||||||
MAX_DOT_GRAPH_WIDTH = 1024
|
|
||||||
|
|
||||||
# The MAX_DOT_GRAPH_HEIGHT tag can be used to set the maximum allows height
|
|
||||||
# (in pixels) of the graphs generated by dot. If a graph becomes larger than
|
|
||||||
# this value, doxygen will try to truncate the graph, so that it fits within
|
|
||||||
# the specified constraint. Beware that most browsers cannot cope with very
|
|
||||||
# large images.
|
|
||||||
|
|
||||||
MAX_DOT_GRAPH_HEIGHT = 1024
|
|
||||||
|
|
||||||
# If the GENERATE_LEGEND tag is set to YES (the default) Doxygen will
|
|
||||||
# generate a legend page explaining the meaning of the various boxes and
|
|
||||||
# arrows in the dot generated graphs.
|
|
||||||
|
|
||||||
GENERATE_LEGEND = YES
|
|
||||||
|
|
||||||
# If the DOT_CLEANUP tag is set to YES (the default) Doxygen will
|
|
||||||
# remove the intermedate dot files that are used to generate
|
|
||||||
# the various graphs.
|
|
||||||
|
|
||||||
DOT_CLEANUP = YES
|
|
||||||
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
# Configuration::addtions related to the search engine
|
|
||||||
#---------------------------------------------------------------------------
|
|
||||||
|
|
||||||
# The SEARCHENGINE tag specifies whether or not a search engine should be
|
|
||||||
# used. If set to NO the values of all tags below this one will be ignored.
|
|
||||||
|
|
||||||
SEARCHENGINE = NO
|
|
||||||
|
|
||||||
# The CGI_NAME tag should be the name of the CGI script that
|
|
||||||
# starts the search engine (doxysearch) with the correct parameters.
|
|
||||||
# A script with this name will be generated by doxygen.
|
|
||||||
|
|
||||||
CGI_NAME = search.cgi
|
|
||||||
|
|
||||||
# The CGI_URL tag should be the absolute URL to the directory where the
|
|
||||||
# cgi binaries are located. See the documentation of your http daemon for
|
|
||||||
# details.
|
|
||||||
|
|
||||||
CGI_URL =
|
|
||||||
|
|
||||||
# The DOC_URL tag should be the absolute URL to the directory where the
|
|
||||||
# documentation is located. If left blank the absolute path to the
|
|
||||||
# documentation, with file:// prepended to it, will be used.
|
|
||||||
|
|
||||||
DOC_URL =
|
|
||||||
|
|
||||||
# The DOC_ABSPATH tag should be the absolute path to the directory where the
|
|
||||||
# documentation is located. If left blank the directory on the local machine
|
|
||||||
# will be used.
|
|
||||||
|
|
||||||
DOC_ABSPATH =
|
|
||||||
|
|
||||||
# The BIN_ABSPATH tag must point to the directory where the doxysearch binary
|
|
||||||
# is installed.
|
|
||||||
|
|
||||||
BIN_ABSPATH = /usr/local/bin/
|
|
||||||
|
|
||||||
# The EXT_DOC_PATHS tag can be used to specify one or more paths to
|
|
||||||
# documentation generated for other projects. This allows doxysearch to search
|
|
||||||
# the documentation for these projects as well.
|
|
||||||
|
|
||||||
EXT_DOC_PATHS =
|
|
|
@ -1,7 +0,0 @@
|
||||||
Copyright (c) 2002-2007 Lee Salzman
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
@ -1,5 +0,0 @@
|
||||||
lib_LIBRARIES = libenet.a
|
|
||||||
libenet_a_SOURCES = host.c list.c callbacks.c packet.c peer.c protocol.c unix.c win32.c
|
|
||||||
INCLUDES = -Iinclude/
|
|
||||||
|
|
||||||
SUBDIRS = include
|
|
|
@ -1,656 +0,0 @@
|
||||||
# Makefile.in generated by automake 1.9.6 from Makefile.am.
|
|
||||||
# @configure_input@
|
|
||||||
|
|
||||||
# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
|
|
||||||
# 2003, 2004, 2005 Free Software Foundation, Inc.
|
|
||||||
# This Makefile.in is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
|
|
||||||
# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
|
||||||
# PARTICULAR PURPOSE.
|
|
||||||
|
|
||||||
@SET_MAKE@
|
|
||||||
|
|
||||||
srcdir = @srcdir@
|
|
||||||
top_srcdir = @top_srcdir@
|
|
||||||
VPATH = @srcdir@
|
|
||||||
pkgdatadir = $(datadir)/@PACKAGE@
|
|
||||||
pkglibdir = $(libdir)/@PACKAGE@
|
|
||||||
pkgincludedir = $(includedir)/@PACKAGE@
|
|
||||||
top_builddir = .
|
|
||||||
am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
|
|
||||||
INSTALL = @INSTALL@
|
|
||||||
install_sh_DATA = $(install_sh) -c -m 644
|
|
||||||
install_sh_PROGRAM = $(install_sh) -c
|
|
||||||
install_sh_SCRIPT = $(install_sh) -c
|
|
||||||
INSTALL_HEADER = $(INSTALL_DATA)
|
|
||||||
transform = $(program_transform_name)
|
|
||||||
NORMAL_INSTALL = :
|
|
||||||
PRE_INSTALL = :
|
|
||||||
POST_INSTALL = :
|
|
||||||
NORMAL_UNINSTALL = :
|
|
||||||
PRE_UNINSTALL = :
|
|
||||||
POST_UNINSTALL = :
|
|
||||||
subdir = .
|
|
||||||
DIST_COMMON = README $(am__configure_deps) $(srcdir)/Makefile.am \
|
|
||||||
$(srcdir)/Makefile.in $(top_srcdir)/configure ChangeLog \
|
|
||||||
depcomp install-sh missing
|
|
||||||
ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
|
|
||||||
am__aclocal_m4_deps = $(top_srcdir)/configure.in
|
|
||||||
am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
|
|
||||||
$(ACLOCAL_M4)
|
|
||||||
am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \
|
|
||||||
configure.lineno configure.status.lineno
|
|
||||||
mkinstalldirs = $(install_sh) -d
|
|
||||||
CONFIG_CLEAN_FILES =
|
|
||||||
am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`;
|
|
||||||
am__vpath_adj = case $$p in \
|
|
||||||
$(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \
|
|
||||||
*) f=$$p;; \
|
|
||||||
esac;
|
|
||||||
am__strip_dir = `echo $$p | sed -e 's|^.*/||'`;
|
|
||||||
am__installdirs = "$(DESTDIR)$(libdir)"
|
|
||||||
libLIBRARIES_INSTALL = $(INSTALL_DATA)
|
|
||||||
LIBRARIES = $(lib_LIBRARIES)
|
|
||||||
AR = ar
|
|
||||||
ARFLAGS = cru
|
|
||||||
libenet_a_AR = $(AR) $(ARFLAGS)
|
|
||||||
libenet_a_LIBADD =
|
|
||||||
am_libenet_a_OBJECTS = host.$(OBJEXT) list.$(OBJEXT) \
|
|
||||||
callbacks.$(OBJEXT) packet.$(OBJEXT) peer.$(OBJEXT) \
|
|
||||||
protocol.$(OBJEXT) unix.$(OBJEXT) win32.$(OBJEXT)
|
|
||||||
libenet_a_OBJECTS = $(am_libenet_a_OBJECTS)
|
|
||||||
DEFAULT_INCLUDES = -I. -I$(srcdir)
|
|
||||||
depcomp = $(SHELL) $(top_srcdir)/depcomp
|
|
||||||
am__depfiles_maybe = depfiles
|
|
||||||
COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
|
|
||||||
$(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
|
|
||||||
CCLD = $(CC)
|
|
||||||
LINK = $(CCLD) $(AM_CFLAGS) $(CFLAGS) $(AM_LDFLAGS) $(LDFLAGS) -o $@
|
|
||||||
SOURCES = $(libenet_a_SOURCES)
|
|
||||||
DIST_SOURCES = $(libenet_a_SOURCES)
|
|
||||||
RECURSIVE_TARGETS = all-recursive check-recursive dvi-recursive \
|
|
||||||
html-recursive info-recursive install-data-recursive \
|
|
||||||
install-exec-recursive install-info-recursive \
|
|
||||||
install-recursive installcheck-recursive installdirs-recursive \
|
|
||||||
pdf-recursive ps-recursive uninstall-info-recursive \
|
|
||||||
uninstall-recursive
|
|
||||||
ETAGS = etags
|
|
||||||
CTAGS = ctags
|
|
||||||
DIST_SUBDIRS = $(SUBDIRS)
|
|
||||||
DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
|
|
||||||
distdir = $(PACKAGE)-$(VERSION)
|
|
||||||
top_distdir = $(distdir)
|
|
||||||
am__remove_distdir = \
|
|
||||||
{ test ! -d $(distdir) \
|
|
||||||
|| { find $(distdir) -type d ! -perm -200 -exec chmod u+w {} ';' \
|
|
||||||
&& rm -fr $(distdir); }; }
|
|
||||||
DIST_ARCHIVES = $(distdir).tar.gz
|
|
||||||
GZIP_ENV = --best
|
|
||||||
distuninstallcheck_listfiles = find . -type f -print
|
|
||||||
distcleancheck_listfiles = find . -type f -print
|
|
||||||
ACLOCAL = @ACLOCAL@
|
|
||||||
AMDEP_FALSE = @AMDEP_FALSE@
|
|
||||||
AMDEP_TRUE = @AMDEP_TRUE@
|
|
||||||
AMTAR = @AMTAR@
|
|
||||||
AUTOCONF = @AUTOCONF@
|
|
||||||
AUTOHEADER = @AUTOHEADER@
|
|
||||||
AUTOMAKE = @AUTOMAKE@
|
|
||||||
AWK = @AWK@
|
|
||||||
CC = @CC@
|
|
||||||
CCDEPMODE = @CCDEPMODE@
|
|
||||||
CFLAGS = @CFLAGS@
|
|
||||||
CPP = @CPP@
|
|
||||||
CPPFLAGS = @CPPFLAGS@
|
|
||||||
CYGPATH_W = @CYGPATH_W@
|
|
||||||
DEFS = @DEFS@
|
|
||||||
DEPDIR = @DEPDIR@
|
|
||||||
ECHO_C = @ECHO_C@
|
|
||||||
ECHO_N = @ECHO_N@
|
|
||||||
ECHO_T = @ECHO_T@
|
|
||||||
EGREP = @EGREP@
|
|
||||||
EXEEXT = @EXEEXT@
|
|
||||||
GREP = @GREP@
|
|
||||||
INSTALL_DATA = @INSTALL_DATA@
|
|
||||||
INSTALL_PROGRAM = @INSTALL_PROGRAM@
|
|
||||||
INSTALL_SCRIPT = @INSTALL_SCRIPT@
|
|
||||||
INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
|
|
||||||
LDFLAGS = @LDFLAGS@
|
|
||||||
LIBOBJS = @LIBOBJS@
|
|
||||||
LIBS = @LIBS@
|
|
||||||
LTLIBOBJS = @LTLIBOBJS@
|
|
||||||
MAKEINFO = @MAKEINFO@
|
|
||||||
OBJEXT = @OBJEXT@
|
|
||||||
PACKAGE = @PACKAGE@
|
|
||||||
PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
|
|
||||||
PACKAGE_NAME = @PACKAGE_NAME@
|
|
||||||
PACKAGE_STRING = @PACKAGE_STRING@
|
|
||||||
PACKAGE_TARNAME = @PACKAGE_TARNAME@
|
|
||||||
PACKAGE_VERSION = @PACKAGE_VERSION@
|
|
||||||
PATH_SEPARATOR = @PATH_SEPARATOR@
|
|
||||||
RANLIB = @RANLIB@
|
|
||||||
SET_MAKE = @SET_MAKE@
|
|
||||||
SHELL = @SHELL@
|
|
||||||
STRIP = @STRIP@
|
|
||||||
VERSION = @VERSION@
|
|
||||||
ac_ct_CC = @ac_ct_CC@
|
|
||||||
am__fastdepCC_FALSE = @am__fastdepCC_FALSE@
|
|
||||||
am__fastdepCC_TRUE = @am__fastdepCC_TRUE@
|
|
||||||
am__include = @am__include@
|
|
||||||
am__leading_dot = @am__leading_dot@
|
|
||||||
am__quote = @am__quote@
|
|
||||||
am__tar = @am__tar@
|
|
||||||
am__untar = @am__untar@
|
|
||||||
bindir = @bindir@
|
|
||||||
build_alias = @build_alias@
|
|
||||||
datadir = @datadir@
|
|
||||||
datarootdir = @datarootdir@
|
|
||||||
docdir = @docdir@
|
|
||||||
dvidir = @dvidir@
|
|
||||||
exec_prefix = @exec_prefix@
|
|
||||||
host_alias = @host_alias@
|
|
||||||
htmldir = @htmldir@
|
|
||||||
includedir = @includedir@
|
|
||||||
infodir = @infodir@
|
|
||||||
install_sh = @install_sh@
|
|
||||||
libdir = @libdir@
|
|
||||||
libexecdir = @libexecdir@
|
|
||||||
localedir = @localedir@
|
|
||||||
localstatedir = @localstatedir@
|
|
||||||
mandir = @mandir@
|
|
||||||
mkdir_p = @mkdir_p@
|
|
||||||
oldincludedir = @oldincludedir@
|
|
||||||
pdfdir = @pdfdir@
|
|
||||||
prefix = @prefix@
|
|
||||||
program_transform_name = @program_transform_name@
|
|
||||||
psdir = @psdir@
|
|
||||||
sbindir = @sbindir@
|
|
||||||
sharedstatedir = @sharedstatedir@
|
|
||||||
sysconfdir = @sysconfdir@
|
|
||||||
target_alias = @target_alias@
|
|
||||||
lib_LIBRARIES = libenet.a
|
|
||||||
libenet_a_SOURCES = host.c list.c callbacks.c packet.c peer.c protocol.c unix.c win32.c
|
|
||||||
INCLUDES = -Iinclude/
|
|
||||||
SUBDIRS = include
|
|
||||||
all: all-recursive
|
|
||||||
|
|
||||||
.SUFFIXES:
|
|
||||||
.SUFFIXES: .c .o .obj
|
|
||||||
am--refresh:
|
|
||||||
@:
|
|
||||||
$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps)
|
|
||||||
@for dep in $?; do \
|
|
||||||
case '$(am__configure_deps)' in \
|
|
||||||
*$$dep*) \
|
|
||||||
echo ' cd $(srcdir) && $(AUTOMAKE) --foreign '; \
|
|
||||||
cd $(srcdir) && $(AUTOMAKE) --foreign \
|
|
||||||
&& exit 0; \
|
|
||||||
exit 1;; \
|
|
||||||
esac; \
|
|
||||||
done; \
|
|
||||||
echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign Makefile'; \
|
|
||||||
cd $(top_srcdir) && \
|
|
||||||
$(AUTOMAKE) --foreign Makefile
|
|
||||||
.PRECIOUS: Makefile
|
|
||||||
Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
|
||||||
@case '$?' in \
|
|
||||||
*config.status*) \
|
|
||||||
echo ' $(SHELL) ./config.status'; \
|
|
||||||
$(SHELL) ./config.status;; \
|
|
||||||
*) \
|
|
||||||
echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \
|
|
||||||
cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \
|
|
||||||
esac;
|
|
||||||
|
|
||||||
$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
|
|
||||||
$(SHELL) ./config.status --recheck
|
|
||||||
|
|
||||||
$(top_srcdir)/configure: $(am__configure_deps)
|
|
||||||
cd $(srcdir) && $(AUTOCONF)
|
|
||||||
$(ACLOCAL_M4): $(am__aclocal_m4_deps)
|
|
||||||
cd $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS)
|
|
||||||
install-libLIBRARIES: $(lib_LIBRARIES)
|
|
||||||
@$(NORMAL_INSTALL)
|
|
||||||
test -z "$(libdir)" || $(mkdir_p) "$(DESTDIR)$(libdir)"
|
|
||||||
@list='$(lib_LIBRARIES)'; for p in $$list; do \
|
|
||||||
if test -f $$p; then \
|
|
||||||
f=$(am__strip_dir) \
|
|
||||||
echo " $(libLIBRARIES_INSTALL) '$$p' '$(DESTDIR)$(libdir)/$$f'"; \
|
|
||||||
$(libLIBRARIES_INSTALL) "$$p" "$(DESTDIR)$(libdir)/$$f"; \
|
|
||||||
else :; fi; \
|
|
||||||
done
|
|
||||||
@$(POST_INSTALL)
|
|
||||||
@list='$(lib_LIBRARIES)'; for p in $$list; do \
|
|
||||||
if test -f $$p; then \
|
|
||||||
p=$(am__strip_dir) \
|
|
||||||
echo " $(RANLIB) '$(DESTDIR)$(libdir)/$$p'"; \
|
|
||||||
$(RANLIB) "$(DESTDIR)$(libdir)/$$p"; \
|
|
||||||
else :; fi; \
|
|
||||||
done
|
|
||||||
|
|
||||||
uninstall-libLIBRARIES:
|
|
||||||
@$(NORMAL_UNINSTALL)
|
|
||||||
@list='$(lib_LIBRARIES)'; for p in $$list; do \
|
|
||||||
p=$(am__strip_dir) \
|
|
||||||
echo " rm -f '$(DESTDIR)$(libdir)/$$p'"; \
|
|
||||||
rm -f "$(DESTDIR)$(libdir)/$$p"; \
|
|
||||||
done
|
|
||||||
|
|
||||||
clean-libLIBRARIES:
|
|
||||||
-test -z "$(lib_LIBRARIES)" || rm -f $(lib_LIBRARIES)
|
|
||||||
libenet.a: $(libenet_a_OBJECTS) $(libenet_a_DEPENDENCIES)
|
|
||||||
-rm -f libenet.a
|
|
||||||
$(libenet_a_AR) libenet.a $(libenet_a_OBJECTS) $(libenet_a_LIBADD)
|
|
||||||
$(RANLIB) libenet.a
|
|
||||||
|
|
||||||
mostlyclean-compile:
|
|
||||||
-rm -f *.$(OBJEXT)
|
|
||||||
|
|
||||||
distclean-compile:
|
|
||||||
-rm -f *.tab.c
|
|
||||||
|
|
||||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/callbacks.Po@am__quote@
|
|
||||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/host.Po@am__quote@
|
|
||||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/list.Po@am__quote@
|
|
||||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/packet.Po@am__quote@
|
|
||||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/peer.Po@am__quote@
|
|
||||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/protocol.Po@am__quote@
|
|
||||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/unix.Po@am__quote@
|
|
||||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/win32.Po@am__quote@
|
|
||||||
|
|
||||||
.c.o:
|
|
||||||
@am__fastdepCC_TRUE@ if $(COMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \
|
|
||||||
@am__fastdepCC_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi
|
|
||||||
@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
|
|
||||||
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
|
|
||||||
@am__fastdepCC_FALSE@ $(COMPILE) -c $<
|
|
||||||
|
|
||||||
.c.obj:
|
|
||||||
@am__fastdepCC_TRUE@ if $(COMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ `$(CYGPATH_W) '$<'`; \
|
|
||||||
@am__fastdepCC_TRUE@ then mv -f "$(DEPDIR)/$*.Tpo" "$(DEPDIR)/$*.Po"; else rm -f "$(DEPDIR)/$*.Tpo"; exit 1; fi
|
|
||||||
@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
|
|
||||||
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
|
|
||||||
@am__fastdepCC_FALSE@ $(COMPILE) -c `$(CYGPATH_W) '$<'`
|
|
||||||
uninstall-info-am:
|
|
||||||
|
|
||||||
# This directory's subdirectories are mostly independent; you can cd
|
|
||||||
# into them and run `make' without going through this Makefile.
|
|
||||||
# To change the values of `make' variables: instead of editing Makefiles,
|
|
||||||
# (1) if the variable is set in `config.status', edit `config.status'
|
|
||||||
# (which will cause the Makefiles to be regenerated when you run `make');
|
|
||||||
# (2) otherwise, pass the desired values on the `make' command line.
|
|
||||||
$(RECURSIVE_TARGETS):
|
|
||||||
@failcom='exit 1'; \
|
|
||||||
for f in x $$MAKEFLAGS; do \
|
|
||||||
case $$f in \
|
|
||||||
*=* | --[!k]*);; \
|
|
||||||
*k*) failcom='fail=yes';; \
|
|
||||||
esac; \
|
|
||||||
done; \
|
|
||||||
dot_seen=no; \
|
|
||||||
target=`echo $@ | sed s/-recursive//`; \
|
|
||||||
list='$(SUBDIRS)'; for subdir in $$list; do \
|
|
||||||
echo "Making $$target in $$subdir"; \
|
|
||||||
if test "$$subdir" = "."; then \
|
|
||||||
dot_seen=yes; \
|
|
||||||
local_target="$$target-am"; \
|
|
||||||
else \
|
|
||||||
local_target="$$target"; \
|
|
||||||
fi; \
|
|
||||||
(cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
|
|
||||||
|| eval $$failcom; \
|
|
||||||
done; \
|
|
||||||
if test "$$dot_seen" = "no"; then \
|
|
||||||
$(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \
|
|
||||||
fi; test -z "$$fail"
|
|
||||||
|
|
||||||
mostlyclean-recursive clean-recursive distclean-recursive \
|
|
||||||
maintainer-clean-recursive:
|
|
||||||
@failcom='exit 1'; \
|
|
||||||
for f in x $$MAKEFLAGS; do \
|
|
||||||
case $$f in \
|
|
||||||
*=* | --[!k]*);; \
|
|
||||||
*k*) failcom='fail=yes';; \
|
|
||||||
esac; \
|
|
||||||
done; \
|
|
||||||
dot_seen=no; \
|
|
||||||
case "$@" in \
|
|
||||||
distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \
|
|
||||||
*) list='$(SUBDIRS)' ;; \
|
|
||||||
esac; \
|
|
||||||
rev=''; for subdir in $$list; do \
|
|
||||||
if test "$$subdir" = "."; then :; else \
|
|
||||||
rev="$$subdir $$rev"; \
|
|
||||||
fi; \
|
|
||||||
done; \
|
|
||||||
rev="$$rev ."; \
|
|
||||||
target=`echo $@ | sed s/-recursive//`; \
|
|
||||||
for subdir in $$rev; do \
|
|
||||||
echo "Making $$target in $$subdir"; \
|
|
||||||
if test "$$subdir" = "."; then \
|
|
||||||
local_target="$$target-am"; \
|
|
||||||
else \
|
|
||||||
local_target="$$target"; \
|
|
||||||
fi; \
|
|
||||||
(cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
|
|
||||||
|| eval $$failcom; \
|
|
||||||
done && test -z "$$fail"
|
|
||||||
tags-recursive:
|
|
||||||
list='$(SUBDIRS)'; for subdir in $$list; do \
|
|
||||||
test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \
|
|
||||||
done
|
|
||||||
ctags-recursive:
|
|
||||||
list='$(SUBDIRS)'; for subdir in $$list; do \
|
|
||||||
test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) ctags); \
|
|
||||||
done
|
|
||||||
|
|
||||||
ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
|
|
||||||
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
|
||||||
unique=`for i in $$list; do \
|
|
||||||
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
|
||||||
done | \
|
|
||||||
$(AWK) ' { files[$$0] = 1; } \
|
|
||||||
END { for (i in files) print i; }'`; \
|
|
||||||
mkid -fID $$unique
|
|
||||||
tags: TAGS
|
|
||||||
|
|
||||||
TAGS: tags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
|
|
||||||
$(TAGS_FILES) $(LISP)
|
|
||||||
tags=; \
|
|
||||||
here=`pwd`; \
|
|
||||||
if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \
|
|
||||||
include_option=--etags-include; \
|
|
||||||
empty_fix=.; \
|
|
||||||
else \
|
|
||||||
include_option=--include; \
|
|
||||||
empty_fix=; \
|
|
||||||
fi; \
|
|
||||||
list='$(SUBDIRS)'; for subdir in $$list; do \
|
|
||||||
if test "$$subdir" = .; then :; else \
|
|
||||||
test ! -f $$subdir/TAGS || \
|
|
||||||
tags="$$tags $$include_option=$$here/$$subdir/TAGS"; \
|
|
||||||
fi; \
|
|
||||||
done; \
|
|
||||||
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
|
||||||
unique=`for i in $$list; do \
|
|
||||||
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
|
||||||
done | \
|
|
||||||
$(AWK) ' { files[$$0] = 1; } \
|
|
||||||
END { for (i in files) print i; }'`; \
|
|
||||||
if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \
|
|
||||||
test -n "$$unique" || unique=$$empty_fix; \
|
|
||||||
$(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
|
|
||||||
$$tags $$unique; \
|
|
||||||
fi
|
|
||||||
ctags: CTAGS
|
|
||||||
CTAGS: ctags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
|
|
||||||
$(TAGS_FILES) $(LISP)
|
|
||||||
tags=; \
|
|
||||||
here=`pwd`; \
|
|
||||||
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
|
||||||
unique=`for i in $$list; do \
|
|
||||||
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
|
||||||
done | \
|
|
||||||
$(AWK) ' { files[$$0] = 1; } \
|
|
||||||
END { for (i in files) print i; }'`; \
|
|
||||||
test -z "$(CTAGS_ARGS)$$tags$$unique" \
|
|
||||||
|| $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
|
|
||||||
$$tags $$unique
|
|
||||||
|
|
||||||
GTAGS:
|
|
||||||
here=`$(am__cd) $(top_builddir) && pwd` \
|
|
||||||
&& cd $(top_srcdir) \
|
|
||||||
&& gtags -i $(GTAGS_ARGS) $$here
|
|
||||||
|
|
||||||
distclean-tags:
|
|
||||||
-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
|
|
||||||
|
|
||||||
distdir: $(DISTFILES)
|
|
||||||
$(am__remove_distdir)
|
|
||||||
mkdir $(distdir)
|
|
||||||
@srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \
|
|
||||||
topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \
|
|
||||||
list='$(DISTFILES)'; for file in $$list; do \
|
|
||||||
case $$file in \
|
|
||||||
$(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \
|
|
||||||
$(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \
|
|
||||||
esac; \
|
|
||||||
if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
|
|
||||||
dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \
|
|
||||||
if test "$$dir" != "$$file" && test "$$dir" != "."; then \
|
|
||||||
dir="/$$dir"; \
|
|
||||||
$(mkdir_p) "$(distdir)$$dir"; \
|
|
||||||
else \
|
|
||||||
dir=''; \
|
|
||||||
fi; \
|
|
||||||
if test -d $$d/$$file; then \
|
|
||||||
if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
|
|
||||||
cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \
|
|
||||||
fi; \
|
|
||||||
cp -pR $$d/$$file $(distdir)$$dir || exit 1; \
|
|
||||||
else \
|
|
||||||
test -f $(distdir)/$$file \
|
|
||||||
|| cp -p $$d/$$file $(distdir)/$$file \
|
|
||||||
|| exit 1; \
|
|
||||||
fi; \
|
|
||||||
done
|
|
||||||
list='$(DIST_SUBDIRS)'; for subdir in $$list; do \
|
|
||||||
if test "$$subdir" = .; then :; else \
|
|
||||||
test -d "$(distdir)/$$subdir" \
|
|
||||||
|| $(mkdir_p) "$(distdir)/$$subdir" \
|
|
||||||
|| exit 1; \
|
|
||||||
distdir=`$(am__cd) $(distdir) && pwd`; \
|
|
||||||
top_distdir=`$(am__cd) $(top_distdir) && pwd`; \
|
|
||||||
(cd $$subdir && \
|
|
||||||
$(MAKE) $(AM_MAKEFLAGS) \
|
|
||||||
top_distdir="$$top_distdir" \
|
|
||||||
distdir="$$distdir/$$subdir" \
|
|
||||||
distdir) \
|
|
||||||
|| exit 1; \
|
|
||||||
fi; \
|
|
||||||
done
|
|
||||||
-find $(distdir) -type d ! -perm -777 -exec chmod a+rwx {} \; -o \
|
|
||||||
! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \
|
|
||||||
! -type d ! -perm -400 -exec chmod a+r {} \; -o \
|
|
||||||
! -type d ! -perm -444 -exec $(SHELL) $(install_sh) -c -m a+r {} {} \; \
|
|
||||||
|| chmod -R a+r $(distdir)
|
|
||||||
dist-gzip: distdir
|
|
||||||
tardir=$(distdir) && $(am__tar) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz
|
|
||||||
$(am__remove_distdir)
|
|
||||||
|
|
||||||
dist-bzip2: distdir
|
|
||||||
tardir=$(distdir) && $(am__tar) | bzip2 -9 -c >$(distdir).tar.bz2
|
|
||||||
$(am__remove_distdir)
|
|
||||||
|
|
||||||
dist-tarZ: distdir
|
|
||||||
tardir=$(distdir) && $(am__tar) | compress -c >$(distdir).tar.Z
|
|
||||||
$(am__remove_distdir)
|
|
||||||
|
|
||||||
dist-shar: distdir
|
|
||||||
shar $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).shar.gz
|
|
||||||
$(am__remove_distdir)
|
|
||||||
|
|
||||||
dist-zip: distdir
|
|
||||||
-rm -f $(distdir).zip
|
|
||||||
zip -rq $(distdir).zip $(distdir)
|
|
||||||
$(am__remove_distdir)
|
|
||||||
|
|
||||||
dist dist-all: distdir
|
|
||||||
tardir=$(distdir) && $(am__tar) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz
|
|
||||||
$(am__remove_distdir)
|
|
||||||
|
|
||||||
# This target untars the dist file and tries a VPATH configuration. Then
|
|
||||||
# it guarantees that the distribution is self-contained by making another
|
|
||||||
# tarfile.
|
|
||||||
distcheck: dist
|
|
||||||
case '$(DIST_ARCHIVES)' in \
|
|
||||||
*.tar.gz*) \
|
|
||||||
GZIP=$(GZIP_ENV) gunzip -c $(distdir).tar.gz | $(am__untar) ;;\
|
|
||||||
*.tar.bz2*) \
|
|
||||||
bunzip2 -c $(distdir).tar.bz2 | $(am__untar) ;;\
|
|
||||||
*.tar.Z*) \
|
|
||||||
uncompress -c $(distdir).tar.Z | $(am__untar) ;;\
|
|
||||||
*.shar.gz*) \
|
|
||||||
GZIP=$(GZIP_ENV) gunzip -c $(distdir).shar.gz | unshar ;;\
|
|
||||||
*.zip*) \
|
|
||||||
unzip $(distdir).zip ;;\
|
|
||||||
esac
|
|
||||||
chmod -R a-w $(distdir); chmod a+w $(distdir)
|
|
||||||
mkdir $(distdir)/_build
|
|
||||||
mkdir $(distdir)/_inst
|
|
||||||
chmod a-w $(distdir)
|
|
||||||
dc_install_base=`$(am__cd) $(distdir)/_inst && pwd | sed -e 's,^[^:\\/]:[\\/],/,'` \
|
|
||||||
&& dc_destdir="$${TMPDIR-/tmp}/am-dc-$$$$/" \
|
|
||||||
&& cd $(distdir)/_build \
|
|
||||||
&& ../configure --srcdir=.. --prefix="$$dc_install_base" \
|
|
||||||
$(DISTCHECK_CONFIGURE_FLAGS) \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) dvi \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) check \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) install \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) installcheck \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) uninstall \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) distuninstallcheck_dir="$$dc_install_base" \
|
|
||||||
distuninstallcheck \
|
|
||||||
&& chmod -R a-w "$$dc_install_base" \
|
|
||||||
&& ({ \
|
|
||||||
(cd ../.. && umask 077 && mkdir "$$dc_destdir") \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" install \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" uninstall \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" \
|
|
||||||
distuninstallcheck_dir="$$dc_destdir" distuninstallcheck; \
|
|
||||||
} || { rm -rf "$$dc_destdir"; exit 1; }) \
|
|
||||||
&& rm -rf "$$dc_destdir" \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) dist \
|
|
||||||
&& rm -rf $(DIST_ARCHIVES) \
|
|
||||||
&& $(MAKE) $(AM_MAKEFLAGS) distcleancheck
|
|
||||||
$(am__remove_distdir)
|
|
||||||
@(echo "$(distdir) archives ready for distribution: "; \
|
|
||||||
list='$(DIST_ARCHIVES)'; for i in $$list; do echo $$i; done) | \
|
|
||||||
sed -e '1{h;s/./=/g;p;x;}' -e '$${p;x;}'
|
|
||||||
distuninstallcheck:
|
|
||||||
@cd $(distuninstallcheck_dir) \
|
|
||||||
&& test `$(distuninstallcheck_listfiles) | wc -l` -le 1 \
|
|
||||||
|| { echo "ERROR: files left after uninstall:" ; \
|
|
||||||
if test -n "$(DESTDIR)"; then \
|
|
||||||
echo " (check DESTDIR support)"; \
|
|
||||||
fi ; \
|
|
||||||
$(distuninstallcheck_listfiles) ; \
|
|
||||||
exit 1; } >&2
|
|
||||||
distcleancheck: distclean
|
|
||||||
@if test '$(srcdir)' = . ; then \
|
|
||||||
echo "ERROR: distcleancheck can only run from a VPATH build" ; \
|
|
||||||
exit 1 ; \
|
|
||||||
fi
|
|
||||||
@test `$(distcleancheck_listfiles) | wc -l` -eq 0 \
|
|
||||||
|| { echo "ERROR: files left in build directory after distclean:" ; \
|
|
||||||
$(distcleancheck_listfiles) ; \
|
|
||||||
exit 1; } >&2
|
|
||||||
check-am: all-am
|
|
||||||
check: check-recursive
|
|
||||||
all-am: Makefile $(LIBRARIES)
|
|
||||||
installdirs: installdirs-recursive
|
|
||||||
installdirs-am:
|
|
||||||
for dir in "$(DESTDIR)$(libdir)"; do \
|
|
||||||
test -z "$$dir" || $(mkdir_p) "$$dir"; \
|
|
||||||
done
|
|
||||||
install: install-recursive
|
|
||||||
install-exec: install-exec-recursive
|
|
||||||
install-data: install-data-recursive
|
|
||||||
uninstall: uninstall-recursive
|
|
||||||
|
|
||||||
install-am: all-am
|
|
||||||
@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
|
|
||||||
|
|
||||||
installcheck: installcheck-recursive
|
|
||||||
install-strip:
|
|
||||||
$(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
|
|
||||||
install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
|
|
||||||
`test -z '$(STRIP)' || \
|
|
||||||
echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
|
|
||||||
mostlyclean-generic:
|
|
||||||
|
|
||||||
clean-generic:
|
|
||||||
|
|
||||||
distclean-generic:
|
|
||||||
-test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
|
|
||||||
|
|
||||||
maintainer-clean-generic:
|
|
||||||
@echo "This command is intended for maintainers to use"
|
|
||||||
@echo "it deletes files that may require special tools to rebuild."
|
|
||||||
clean: clean-recursive
|
|
||||||
|
|
||||||
clean-am: clean-generic clean-libLIBRARIES mostlyclean-am
|
|
||||||
|
|
||||||
distclean: distclean-recursive
|
|
||||||
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
|
|
||||||
-rm -rf ./$(DEPDIR)
|
|
||||||
-rm -f Makefile
|
|
||||||
distclean-am: clean-am distclean-compile distclean-generic \
|
|
||||||
distclean-tags
|
|
||||||
|
|
||||||
dvi: dvi-recursive
|
|
||||||
|
|
||||||
dvi-am:
|
|
||||||
|
|
||||||
html: html-recursive
|
|
||||||
|
|
||||||
info: info-recursive
|
|
||||||
|
|
||||||
info-am:
|
|
||||||
|
|
||||||
install-data-am:
|
|
||||||
|
|
||||||
install-exec-am: install-libLIBRARIES
|
|
||||||
|
|
||||||
install-info: install-info-recursive
|
|
||||||
|
|
||||||
install-man:
|
|
||||||
|
|
||||||
installcheck-am:
|
|
||||||
|
|
||||||
maintainer-clean: maintainer-clean-recursive
|
|
||||||
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
|
|
||||||
-rm -rf $(top_srcdir)/autom4te.cache
|
|
||||||
-rm -rf ./$(DEPDIR)
|
|
||||||
-rm -f Makefile
|
|
||||||
maintainer-clean-am: distclean-am maintainer-clean-generic
|
|
||||||
|
|
||||||
mostlyclean: mostlyclean-recursive
|
|
||||||
|
|
||||||
mostlyclean-am: mostlyclean-compile mostlyclean-generic
|
|
||||||
|
|
||||||
pdf: pdf-recursive
|
|
||||||
|
|
||||||
pdf-am:
|
|
||||||
|
|
||||||
ps: ps-recursive
|
|
||||||
|
|
||||||
ps-am:
|
|
||||||
|
|
||||||
uninstall-am: uninstall-info-am uninstall-libLIBRARIES
|
|
||||||
|
|
||||||
uninstall-info: uninstall-info-recursive
|
|
||||||
|
|
||||||
.PHONY: $(RECURSIVE_TARGETS) CTAGS GTAGS all all-am am--refresh check \
|
|
||||||
check-am clean clean-generic clean-libLIBRARIES \
|
|
||||||
clean-recursive ctags ctags-recursive dist dist-all dist-bzip2 \
|
|
||||||
dist-gzip dist-shar dist-tarZ dist-zip distcheck distclean \
|
|
||||||
distclean-compile distclean-generic distclean-recursive \
|
|
||||||
distclean-tags distcleancheck distdir distuninstallcheck dvi \
|
|
||||||
dvi-am html html-am info info-am install install-am \
|
|
||||||
install-data install-data-am install-exec install-exec-am \
|
|
||||||
install-info install-info-am install-libLIBRARIES install-man \
|
|
||||||
install-strip installcheck installcheck-am installdirs \
|
|
||||||
installdirs-am maintainer-clean maintainer-clean-generic \
|
|
||||||
maintainer-clean-recursive mostlyclean mostlyclean-compile \
|
|
||||||
mostlyclean-generic mostlyclean-recursive pdf pdf-am ps ps-am \
|
|
||||||
tags tags-recursive uninstall uninstall-am uninstall-info-am \
|
|
||||||
uninstall-libLIBRARIES
|
|
||||||
|
|
||||||
# Tell versions [3.59,3.63) of GNU make to not export all variables.
|
|
||||||
# Otherwise a system limit (for SysV at least) may be exceeded.
|
|
||||||
.NOEXPORT:
|
|
|
@ -1,15 +0,0 @@
|
||||||
Please visit the ENet homepage at http://enet.bespin.org for installation
|
|
||||||
and usage instructions.
|
|
||||||
|
|
||||||
If you obtained this package from CVS, the quick description on how to build
|
|
||||||
is:
|
|
||||||
|
|
||||||
# Generate the build system.
|
|
||||||
|
|
||||||
aclocal && automake -a -c --foreign && autoconf
|
|
||||||
|
|
||||||
# Compile and install the library.
|
|
||||||
|
|
||||||
./configure && make && make install
|
|
||||||
|
|
||||||
|
|
850
polymer/eduke32/build/src/enet/aclocal.m4
vendored
850
polymer/eduke32/build/src/enet/aclocal.m4
vendored
|
@ -1,850 +0,0 @@
|
||||||
# generated automatically by aclocal 1.9.6 -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004,
|
|
||||||
# 2005 Free Software Foundation, Inc.
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
|
|
||||||
# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
|
||||||
# PARTICULAR PURPOSE.
|
|
||||||
|
|
||||||
# Copyright (C) 2002, 2003, 2005 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# AM_AUTOMAKE_VERSION(VERSION)
|
|
||||||
# ----------------------------
|
|
||||||
# Automake X.Y traces this macro to ensure aclocal.m4 has been
|
|
||||||
# generated from the m4 files accompanying Automake X.Y.
|
|
||||||
AC_DEFUN([AM_AUTOMAKE_VERSION], [am__api_version="1.9"])
|
|
||||||
|
|
||||||
# AM_SET_CURRENT_AUTOMAKE_VERSION
|
|
||||||
# -------------------------------
|
|
||||||
# Call AM_AUTOMAKE_VERSION so it can be traced.
|
|
||||||
# This function is AC_REQUIREd by AC_INIT_AUTOMAKE.
|
|
||||||
AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION],
|
|
||||||
[AM_AUTOMAKE_VERSION([1.9.6])])
|
|
||||||
|
|
||||||
# AM_AUX_DIR_EXPAND -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets
|
|
||||||
# $ac_aux_dir to `$srcdir/foo'. In other projects, it is set to
|
|
||||||
# `$srcdir', `$srcdir/..', or `$srcdir/../..'.
|
|
||||||
#
|
|
||||||
# Of course, Automake must honor this variable whenever it calls a
|
|
||||||
# tool from the auxiliary directory. The problem is that $srcdir (and
|
|
||||||
# therefore $ac_aux_dir as well) can be either absolute or relative,
|
|
||||||
# depending on how configure is run. This is pretty annoying, since
|
|
||||||
# it makes $ac_aux_dir quite unusable in subdirectories: in the top
|
|
||||||
# source directory, any form will work fine, but in subdirectories a
|
|
||||||
# relative path needs to be adjusted first.
|
|
||||||
#
|
|
||||||
# $ac_aux_dir/missing
|
|
||||||
# fails when called from a subdirectory if $ac_aux_dir is relative
|
|
||||||
# $top_srcdir/$ac_aux_dir/missing
|
|
||||||
# fails if $ac_aux_dir is absolute,
|
|
||||||
# fails when called from a subdirectory in a VPATH build with
|
|
||||||
# a relative $ac_aux_dir
|
|
||||||
#
|
|
||||||
# The reason of the latter failure is that $top_srcdir and $ac_aux_dir
|
|
||||||
# are both prefixed by $srcdir. In an in-source build this is usually
|
|
||||||
# harmless because $srcdir is `.', but things will broke when you
|
|
||||||
# start a VPATH build or use an absolute $srcdir.
|
|
||||||
#
|
|
||||||
# So we could use something similar to $top_srcdir/$ac_aux_dir/missing,
|
|
||||||
# iff we strip the leading $srcdir from $ac_aux_dir. That would be:
|
|
||||||
# am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"`
|
|
||||||
# and then we would define $MISSING as
|
|
||||||
# MISSING="\${SHELL} $am_aux_dir/missing"
|
|
||||||
# This will work as long as MISSING is not called from configure, because
|
|
||||||
# unfortunately $(top_srcdir) has no meaning in configure.
|
|
||||||
# However there are other variables, like CC, which are often used in
|
|
||||||
# configure, and could therefore not use this "fixed" $ac_aux_dir.
|
|
||||||
#
|
|
||||||
# Another solution, used here, is to always expand $ac_aux_dir to an
|
|
||||||
# absolute PATH. The drawback is that using absolute paths prevent a
|
|
||||||
# configured tree to be moved without reconfiguration.
|
|
||||||
|
|
||||||
AC_DEFUN([AM_AUX_DIR_EXPAND],
|
|
||||||
[dnl Rely on autoconf to set up CDPATH properly.
|
|
||||||
AC_PREREQ([2.50])dnl
|
|
||||||
# expand $ac_aux_dir to an absolute path
|
|
||||||
am_aux_dir=`cd $ac_aux_dir && pwd`
|
|
||||||
])
|
|
||||||
|
|
||||||
# AM_CONDITIONAL -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 1997, 2000, 2001, 2003, 2004, 2005
|
|
||||||
# Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 7
|
|
||||||
|
|
||||||
# AM_CONDITIONAL(NAME, SHELL-CONDITION)
|
|
||||||
# -------------------------------------
|
|
||||||
# Define a conditional.
|
|
||||||
AC_DEFUN([AM_CONDITIONAL],
|
|
||||||
[AC_PREREQ(2.52)dnl
|
|
||||||
ifelse([$1], [TRUE], [AC_FATAL([$0: invalid condition: $1])],
|
|
||||||
[$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl
|
|
||||||
AC_SUBST([$1_TRUE])
|
|
||||||
AC_SUBST([$1_FALSE])
|
|
||||||
if $2; then
|
|
||||||
$1_TRUE=
|
|
||||||
$1_FALSE='#'
|
|
||||||
else
|
|
||||||
$1_TRUE='#'
|
|
||||||
$1_FALSE=
|
|
||||||
fi
|
|
||||||
AC_CONFIG_COMMANDS_PRE(
|
|
||||||
[if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then
|
|
||||||
AC_MSG_ERROR([[conditional "$1" was never defined.
|
|
||||||
Usually this means the macro was only invoked conditionally.]])
|
|
||||||
fi])])
|
|
||||||
|
|
||||||
|
|
||||||
# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005
|
|
||||||
# Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 8
|
|
||||||
|
|
||||||
# There are a few dirty hacks below to avoid letting `AC_PROG_CC' be
|
|
||||||
# written in clear, in which case automake, when reading aclocal.m4,
|
|
||||||
# will think it sees a *use*, and therefore will trigger all it's
|
|
||||||
# C support machinery. Also note that it means that autoscan, seeing
|
|
||||||
# CC etc. in the Makefile, will ask for an AC_PROG_CC use...
|
|
||||||
|
|
||||||
|
|
||||||
# _AM_DEPENDENCIES(NAME)
|
|
||||||
# ----------------------
|
|
||||||
# See how the compiler implements dependency checking.
|
|
||||||
# NAME is "CC", "CXX", "GCJ", or "OBJC".
|
|
||||||
# We try a few techniques and use that to set a single cache variable.
|
|
||||||
#
|
|
||||||
# We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was
|
|
||||||
# modified to invoke _AM_DEPENDENCIES(CC); we would have a circular
|
|
||||||
# dependency, and given that the user is not expected to run this macro,
|
|
||||||
# just rely on AC_PROG_CC.
|
|
||||||
AC_DEFUN([_AM_DEPENDENCIES],
|
|
||||||
[AC_REQUIRE([AM_SET_DEPDIR])dnl
|
|
||||||
AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl
|
|
||||||
AC_REQUIRE([AM_MAKE_INCLUDE])dnl
|
|
||||||
AC_REQUIRE([AM_DEP_TRACK])dnl
|
|
||||||
|
|
||||||
ifelse([$1], CC, [depcc="$CC" am_compiler_list=],
|
|
||||||
[$1], CXX, [depcc="$CXX" am_compiler_list=],
|
|
||||||
[$1], OBJC, [depcc="$OBJC" am_compiler_list='gcc3 gcc'],
|
|
||||||
[$1], GCJ, [depcc="$GCJ" am_compiler_list='gcc3 gcc'],
|
|
||||||
[depcc="$$1" am_compiler_list=])
|
|
||||||
|
|
||||||
AC_CACHE_CHECK([dependency style of $depcc],
|
|
||||||
[am_cv_$1_dependencies_compiler_type],
|
|
||||||
[if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then
|
|
||||||
# We make a subdir and do the tests there. Otherwise we can end up
|
|
||||||
# making bogus files that we don't know about and never remove. For
|
|
||||||
# instance it was reported that on HP-UX the gcc test will end up
|
|
||||||
# making a dummy file named `D' -- because `-MD' means `put the output
|
|
||||||
# in D'.
|
|
||||||
mkdir conftest.dir
|
|
||||||
# Copy depcomp to subdir because otherwise we won't find it if we're
|
|
||||||
# using a relative directory.
|
|
||||||
cp "$am_depcomp" conftest.dir
|
|
||||||
cd conftest.dir
|
|
||||||
# We will build objects and dependencies in a subdirectory because
|
|
||||||
# it helps to detect inapplicable dependency modes. For instance
|
|
||||||
# both Tru64's cc and ICC support -MD to output dependencies as a
|
|
||||||
# side effect of compilation, but ICC will put the dependencies in
|
|
||||||
# the current directory while Tru64 will put them in the object
|
|
||||||
# directory.
|
|
||||||
mkdir sub
|
|
||||||
|
|
||||||
am_cv_$1_dependencies_compiler_type=none
|
|
||||||
if test "$am_compiler_list" = ""; then
|
|
||||||
am_compiler_list=`sed -n ['s/^#*\([a-zA-Z0-9]*\))$/\1/p'] < ./depcomp`
|
|
||||||
fi
|
|
||||||
for depmode in $am_compiler_list; do
|
|
||||||
# Setup a source with many dependencies, because some compilers
|
|
||||||
# like to wrap large dependency lists on column 80 (with \), and
|
|
||||||
# we should not choose a depcomp mode which is confused by this.
|
|
||||||
#
|
|
||||||
# We need to recreate these files for each test, as the compiler may
|
|
||||||
# overwrite some of them when testing with obscure command lines.
|
|
||||||
# This happens at least with the AIX C compiler.
|
|
||||||
: > sub/conftest.c
|
|
||||||
for i in 1 2 3 4 5 6; do
|
|
||||||
echo '#include "conftst'$i'.h"' >> sub/conftest.c
|
|
||||||
# Using `: > sub/conftst$i.h' creates only sub/conftst1.h with
|
|
||||||
# Solaris 8's {/usr,}/bin/sh.
|
|
||||||
touch sub/conftst$i.h
|
|
||||||
done
|
|
||||||
echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf
|
|
||||||
|
|
||||||
case $depmode in
|
|
||||||
nosideeffect)
|
|
||||||
# after this tag, mechanisms are not by side-effect, so they'll
|
|
||||||
# only be used when explicitly requested
|
|
||||||
if test "x$enable_dependency_tracking" = xyes; then
|
|
||||||
continue
|
|
||||||
else
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
none) break ;;
|
|
||||||
esac
|
|
||||||
# We check with `-c' and `-o' for the sake of the "dashmstdout"
|
|
||||||
# mode. It turns out that the SunPro C++ compiler does not properly
|
|
||||||
# handle `-M -o', and we need to detect this.
|
|
||||||
if depmode=$depmode \
|
|
||||||
source=sub/conftest.c object=sub/conftest.${OBJEXT-o} \
|
|
||||||
depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \
|
|
||||||
$SHELL ./depcomp $depcc -c -o sub/conftest.${OBJEXT-o} sub/conftest.c \
|
|
||||||
>/dev/null 2>conftest.err &&
|
|
||||||
grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 &&
|
|
||||||
grep sub/conftest.${OBJEXT-o} sub/conftest.Po > /dev/null 2>&1 &&
|
|
||||||
${MAKE-make} -s -f confmf > /dev/null 2>&1; then
|
|
||||||
# icc doesn't choke on unknown options, it will just issue warnings
|
|
||||||
# or remarks (even with -Werror). So we grep stderr for any message
|
|
||||||
# that says an option was ignored or not supported.
|
|
||||||
# When given -MP, icc 7.0 and 7.1 complain thusly:
|
|
||||||
# icc: Command line warning: ignoring option '-M'; no argument required
|
|
||||||
# The diagnosis changed in icc 8.0:
|
|
||||||
# icc: Command line remark: option '-MP' not supported
|
|
||||||
if (grep 'ignoring option' conftest.err ||
|
|
||||||
grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else
|
|
||||||
am_cv_$1_dependencies_compiler_type=$depmode
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
cd ..
|
|
||||||
rm -rf conftest.dir
|
|
||||||
else
|
|
||||||
am_cv_$1_dependencies_compiler_type=none
|
|
||||||
fi
|
|
||||||
])
|
|
||||||
AC_SUBST([$1DEPMODE], [depmode=$am_cv_$1_dependencies_compiler_type])
|
|
||||||
AM_CONDITIONAL([am__fastdep$1], [
|
|
||||||
test "x$enable_dependency_tracking" != xno \
|
|
||||||
&& test "$am_cv_$1_dependencies_compiler_type" = gcc3])
|
|
||||||
])
|
|
||||||
|
|
||||||
|
|
||||||
# AM_SET_DEPDIR
|
|
||||||
# -------------
|
|
||||||
# Choose a directory name for dependency files.
|
|
||||||
# This macro is AC_REQUIREd in _AM_DEPENDENCIES
|
|
||||||
AC_DEFUN([AM_SET_DEPDIR],
|
|
||||||
[AC_REQUIRE([AM_SET_LEADING_DOT])dnl
|
|
||||||
AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl
|
|
||||||
])
|
|
||||||
|
|
||||||
|
|
||||||
# AM_DEP_TRACK
|
|
||||||
# ------------
|
|
||||||
AC_DEFUN([AM_DEP_TRACK],
|
|
||||||
[AC_ARG_ENABLE(dependency-tracking,
|
|
||||||
[ --disable-dependency-tracking speeds up one-time build
|
|
||||||
--enable-dependency-tracking do not reject slow dependency extractors])
|
|
||||||
if test "x$enable_dependency_tracking" != xno; then
|
|
||||||
am_depcomp="$ac_aux_dir/depcomp"
|
|
||||||
AMDEPBACKSLASH='\'
|
|
||||||
fi
|
|
||||||
AM_CONDITIONAL([AMDEP], [test "x$enable_dependency_tracking" != xno])
|
|
||||||
AC_SUBST([AMDEPBACKSLASH])
|
|
||||||
])
|
|
||||||
|
|
||||||
# Generate code to set up dependency tracking. -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005
|
|
||||||
# Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
#serial 3
|
|
||||||
|
|
||||||
# _AM_OUTPUT_DEPENDENCY_COMMANDS
|
|
||||||
# ------------------------------
|
|
||||||
AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
|
|
||||||
[for mf in $CONFIG_FILES; do
|
|
||||||
# Strip MF so we end up with the name of the file.
|
|
||||||
mf=`echo "$mf" | sed -e 's/:.*$//'`
|
|
||||||
# Check whether this is an Automake generated Makefile or not.
|
|
||||||
# We used to match only the files named `Makefile.in', but
|
|
||||||
# some people rename them; so instead we look at the file content.
|
|
||||||
# Grep'ing the first line is not enough: some people post-process
|
|
||||||
# each Makefile.in and add a new line on top of each file to say so.
|
|
||||||
# So let's grep whole file.
|
|
||||||
if grep '^#.*generated by automake' $mf > /dev/null 2>&1; then
|
|
||||||
dirpart=`AS_DIRNAME("$mf")`
|
|
||||||
else
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
# Extract the definition of DEPDIR, am__include, and am__quote
|
|
||||||
# from the Makefile without running `make'.
|
|
||||||
DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
|
|
||||||
test -z "$DEPDIR" && continue
|
|
||||||
am__include=`sed -n 's/^am__include = //p' < "$mf"`
|
|
||||||
test -z "am__include" && continue
|
|
||||||
am__quote=`sed -n 's/^am__quote = //p' < "$mf"`
|
|
||||||
# When using ansi2knr, U may be empty or an underscore; expand it
|
|
||||||
U=`sed -n 's/^U = //p' < "$mf"`
|
|
||||||
# Find all dependency output files, they are included files with
|
|
||||||
# $(DEPDIR) in their names. We invoke sed twice because it is the
|
|
||||||
# simplest approach to changing $(DEPDIR) to its actual value in the
|
|
||||||
# expansion.
|
|
||||||
for file in `sed -n "
|
|
||||||
s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \
|
|
||||||
sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g' -e 's/\$U/'"$U"'/g'`; do
|
|
||||||
# Make sure the directory exists.
|
|
||||||
test -f "$dirpart/$file" && continue
|
|
||||||
fdir=`AS_DIRNAME(["$file"])`
|
|
||||||
AS_MKDIR_P([$dirpart/$fdir])
|
|
||||||
# echo "creating $dirpart/$file"
|
|
||||||
echo '# dummy' > "$dirpart/$file"
|
|
||||||
done
|
|
||||||
done
|
|
||||||
])# _AM_OUTPUT_DEPENDENCY_COMMANDS
|
|
||||||
|
|
||||||
|
|
||||||
# AM_OUTPUT_DEPENDENCY_COMMANDS
|
|
||||||
# -----------------------------
|
|
||||||
# This macro should only be invoked once -- use via AC_REQUIRE.
|
|
||||||
#
|
|
||||||
# This code is only required when automatic dependency tracking
|
|
||||||
# is enabled. FIXME. This creates each `.P' file that we will
|
|
||||||
# need in order to bootstrap the dependency handling code.
|
|
||||||
AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS],
|
|
||||||
[AC_CONFIG_COMMANDS([depfiles],
|
|
||||||
[test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS],
|
|
||||||
[AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"])
|
|
||||||
])
|
|
||||||
|
|
||||||
# Do all the work for Automake. -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005
|
|
||||||
# Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 12
|
|
||||||
|
|
||||||
# This macro actually does too much. Some checks are only needed if
|
|
||||||
# your package does certain things. But this isn't really a big deal.
|
|
||||||
|
|
||||||
# AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE])
|
|
||||||
# AM_INIT_AUTOMAKE([OPTIONS])
|
|
||||||
# -----------------------------------------------
|
|
||||||
# The call with PACKAGE and VERSION arguments is the old style
|
|
||||||
# call (pre autoconf-2.50), which is being phased out. PACKAGE
|
|
||||||
# and VERSION should now be passed to AC_INIT and removed from
|
|
||||||
# the call to AM_INIT_AUTOMAKE.
|
|
||||||
# We support both call styles for the transition. After
|
|
||||||
# the next Automake release, Autoconf can make the AC_INIT
|
|
||||||
# arguments mandatory, and then we can depend on a new Autoconf
|
|
||||||
# release and drop the old call support.
|
|
||||||
AC_DEFUN([AM_INIT_AUTOMAKE],
|
|
||||||
[AC_PREREQ([2.58])dnl
|
|
||||||
dnl Autoconf wants to disallow AM_ names. We explicitly allow
|
|
||||||
dnl the ones we care about.
|
|
||||||
m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl
|
|
||||||
AC_REQUIRE([AM_SET_CURRENT_AUTOMAKE_VERSION])dnl
|
|
||||||
AC_REQUIRE([AC_PROG_INSTALL])dnl
|
|
||||||
# test to see if srcdir already configured
|
|
||||||
if test "`cd $srcdir && pwd`" != "`pwd`" &&
|
|
||||||
test -f $srcdir/config.status; then
|
|
||||||
AC_MSG_ERROR([source directory already configured; run "make distclean" there first])
|
|
||||||
fi
|
|
||||||
|
|
||||||
# test whether we have cygpath
|
|
||||||
if test -z "$CYGPATH_W"; then
|
|
||||||
if (cygpath --version) >/dev/null 2>/dev/null; then
|
|
||||||
CYGPATH_W='cygpath -w'
|
|
||||||
else
|
|
||||||
CYGPATH_W=echo
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
AC_SUBST([CYGPATH_W])
|
|
||||||
|
|
||||||
# Define the identity of the package.
|
|
||||||
dnl Distinguish between old-style and new-style calls.
|
|
||||||
m4_ifval([$2],
|
|
||||||
[m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl
|
|
||||||
AC_SUBST([PACKAGE], [$1])dnl
|
|
||||||
AC_SUBST([VERSION], [$2])],
|
|
||||||
[_AM_SET_OPTIONS([$1])dnl
|
|
||||||
AC_SUBST([PACKAGE], ['AC_PACKAGE_TARNAME'])dnl
|
|
||||||
AC_SUBST([VERSION], ['AC_PACKAGE_VERSION'])])dnl
|
|
||||||
|
|
||||||
_AM_IF_OPTION([no-define],,
|
|
||||||
[AC_DEFINE_UNQUOTED(PACKAGE, "$PACKAGE", [Name of package])
|
|
||||||
AC_DEFINE_UNQUOTED(VERSION, "$VERSION", [Version number of package])])dnl
|
|
||||||
|
|
||||||
# Some tools Automake needs.
|
|
||||||
AC_REQUIRE([AM_SANITY_CHECK])dnl
|
|
||||||
AC_REQUIRE([AC_ARG_PROGRAM])dnl
|
|
||||||
AM_MISSING_PROG(ACLOCAL, aclocal-${am__api_version})
|
|
||||||
AM_MISSING_PROG(AUTOCONF, autoconf)
|
|
||||||
AM_MISSING_PROG(AUTOMAKE, automake-${am__api_version})
|
|
||||||
AM_MISSING_PROG(AUTOHEADER, autoheader)
|
|
||||||
AM_MISSING_PROG(MAKEINFO, makeinfo)
|
|
||||||
AM_PROG_INSTALL_SH
|
|
||||||
AM_PROG_INSTALL_STRIP
|
|
||||||
AC_REQUIRE([AM_PROG_MKDIR_P])dnl
|
|
||||||
# We need awk for the "check" target. The system "awk" is bad on
|
|
||||||
# some platforms.
|
|
||||||
AC_REQUIRE([AC_PROG_AWK])dnl
|
|
||||||
AC_REQUIRE([AC_PROG_MAKE_SET])dnl
|
|
||||||
AC_REQUIRE([AM_SET_LEADING_DOT])dnl
|
|
||||||
_AM_IF_OPTION([tar-ustar], [_AM_PROG_TAR([ustar])],
|
|
||||||
[_AM_IF_OPTION([tar-pax], [_AM_PROG_TAR([pax])],
|
|
||||||
[_AM_PROG_TAR([v7])])])
|
|
||||||
_AM_IF_OPTION([no-dependencies],,
|
|
||||||
[AC_PROVIDE_IFELSE([AC_PROG_CC],
|
|
||||||
[_AM_DEPENDENCIES(CC)],
|
|
||||||
[define([AC_PROG_CC],
|
|
||||||
defn([AC_PROG_CC])[_AM_DEPENDENCIES(CC)])])dnl
|
|
||||||
AC_PROVIDE_IFELSE([AC_PROG_CXX],
|
|
||||||
[_AM_DEPENDENCIES(CXX)],
|
|
||||||
[define([AC_PROG_CXX],
|
|
||||||
defn([AC_PROG_CXX])[_AM_DEPENDENCIES(CXX)])])dnl
|
|
||||||
])
|
|
||||||
])
|
|
||||||
|
|
||||||
|
|
||||||
# When config.status generates a header, we must update the stamp-h file.
|
|
||||||
# This file resides in the same directory as the config header
|
|
||||||
# that is generated. The stamp files are numbered to have different names.
|
|
||||||
|
|
||||||
# Autoconf calls _AC_AM_CONFIG_HEADER_HOOK (when defined) in the
|
|
||||||
# loop where config.status creates the headers, so we can generate
|
|
||||||
# our stamp files there.
|
|
||||||
AC_DEFUN([_AC_AM_CONFIG_HEADER_HOOK],
|
|
||||||
[# Compute $1's index in $config_headers.
|
|
||||||
_am_stamp_count=1
|
|
||||||
for _am_header in $config_headers :; do
|
|
||||||
case $_am_header in
|
|
||||||
$1 | $1:* )
|
|
||||||
break ;;
|
|
||||||
* )
|
|
||||||
_am_stamp_count=`expr $_am_stamp_count + 1` ;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
echo "timestamp for $1" >`AS_DIRNAME([$1])`/stamp-h[]$_am_stamp_count])
|
|
||||||
|
|
||||||
# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# AM_PROG_INSTALL_SH
|
|
||||||
# ------------------
|
|
||||||
# Define $install_sh.
|
|
||||||
AC_DEFUN([AM_PROG_INSTALL_SH],
|
|
||||||
[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl
|
|
||||||
install_sh=${install_sh-"$am_aux_dir/install-sh"}
|
|
||||||
AC_SUBST(install_sh)])
|
|
||||||
|
|
||||||
# Copyright (C) 2003, 2005 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 2
|
|
||||||
|
|
||||||
# Check whether the underlying file-system supports filenames
|
|
||||||
# with a leading dot. For instance MS-DOS doesn't.
|
|
||||||
AC_DEFUN([AM_SET_LEADING_DOT],
|
|
||||||
[rm -rf .tst 2>/dev/null
|
|
||||||
mkdir .tst 2>/dev/null
|
|
||||||
if test -d .tst; then
|
|
||||||
am__leading_dot=.
|
|
||||||
else
|
|
||||||
am__leading_dot=_
|
|
||||||
fi
|
|
||||||
rmdir .tst 2>/dev/null
|
|
||||||
AC_SUBST([am__leading_dot])])
|
|
||||||
|
|
||||||
# Check to see how 'make' treats includes. -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 2001, 2002, 2003, 2005 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 3
|
|
||||||
|
|
||||||
# AM_MAKE_INCLUDE()
|
|
||||||
# -----------------
|
|
||||||
# Check to see how make treats includes.
|
|
||||||
AC_DEFUN([AM_MAKE_INCLUDE],
|
|
||||||
[am_make=${MAKE-make}
|
|
||||||
cat > confinc << 'END'
|
|
||||||
am__doit:
|
|
||||||
@echo done
|
|
||||||
.PHONY: am__doit
|
|
||||||
END
|
|
||||||
# If we don't find an include directive, just comment out the code.
|
|
||||||
AC_MSG_CHECKING([for style of include used by $am_make])
|
|
||||||
am__include="#"
|
|
||||||
am__quote=
|
|
||||||
_am_result=none
|
|
||||||
# First try GNU make style include.
|
|
||||||
echo "include confinc" > confmf
|
|
||||||
# We grep out `Entering directory' and `Leaving directory'
|
|
||||||
# messages which can occur if `w' ends up in MAKEFLAGS.
|
|
||||||
# In particular we don't look at `^make:' because GNU make might
|
|
||||||
# be invoked under some other name (usually "gmake"), in which
|
|
||||||
# case it prints its new name instead of `make'.
|
|
||||||
if test "`$am_make -s -f confmf 2> /dev/null | grep -v 'ing directory'`" = "done"; then
|
|
||||||
am__include=include
|
|
||||||
am__quote=
|
|
||||||
_am_result=GNU
|
|
||||||
fi
|
|
||||||
# Now try BSD make style include.
|
|
||||||
if test "$am__include" = "#"; then
|
|
||||||
echo '.include "confinc"' > confmf
|
|
||||||
if test "`$am_make -s -f confmf 2> /dev/null`" = "done"; then
|
|
||||||
am__include=.include
|
|
||||||
am__quote="\""
|
|
||||||
_am_result=BSD
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
AC_SUBST([am__include])
|
|
||||||
AC_SUBST([am__quote])
|
|
||||||
AC_MSG_RESULT([$_am_result])
|
|
||||||
rm -f confinc confmf
|
|
||||||
])
|
|
||||||
|
|
||||||
# Fake the existence of programs that GNU maintainers use. -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 1997, 1999, 2000, 2001, 2003, 2005
|
|
||||||
# Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 4
|
|
||||||
|
|
||||||
# AM_MISSING_PROG(NAME, PROGRAM)
|
|
||||||
# ------------------------------
|
|
||||||
AC_DEFUN([AM_MISSING_PROG],
|
|
||||||
[AC_REQUIRE([AM_MISSING_HAS_RUN])
|
|
||||||
$1=${$1-"${am_missing_run}$2"}
|
|
||||||
AC_SUBST($1)])
|
|
||||||
|
|
||||||
|
|
||||||
# AM_MISSING_HAS_RUN
|
|
||||||
# ------------------
|
|
||||||
# Define MISSING if not defined so far and test if it supports --run.
|
|
||||||
# If it does, set am_missing_run to use it, otherwise, to nothing.
|
|
||||||
AC_DEFUN([AM_MISSING_HAS_RUN],
|
|
||||||
[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl
|
|
||||||
test x"${MISSING+set}" = xset || MISSING="\${SHELL} $am_aux_dir/missing"
|
|
||||||
# Use eval to expand $SHELL
|
|
||||||
if eval "$MISSING --run true"; then
|
|
||||||
am_missing_run="$MISSING --run "
|
|
||||||
else
|
|
||||||
am_missing_run=
|
|
||||||
AC_MSG_WARN([`missing' script is too old or missing])
|
|
||||||
fi
|
|
||||||
])
|
|
||||||
|
|
||||||
# Copyright (C) 2003, 2004, 2005 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# AM_PROG_MKDIR_P
|
|
||||||
# ---------------
|
|
||||||
# Check whether `mkdir -p' is supported, fallback to mkinstalldirs otherwise.
|
|
||||||
#
|
|
||||||
# Automake 1.8 used `mkdir -m 0755 -p --' to ensure that directories
|
|
||||||
# created by `make install' are always world readable, even if the
|
|
||||||
# installer happens to have an overly restrictive umask (e.g. 077).
|
|
||||||
# This was a mistake. There are at least two reasons why we must not
|
|
||||||
# use `-m 0755':
|
|
||||||
# - it causes special bits like SGID to be ignored,
|
|
||||||
# - it may be too restrictive (some setups expect 775 directories).
|
|
||||||
#
|
|
||||||
# Do not use -m 0755 and let people choose whatever they expect by
|
|
||||||
# setting umask.
|
|
||||||
#
|
|
||||||
# We cannot accept any implementation of `mkdir' that recognizes `-p'.
|
|
||||||
# Some implementations (such as Solaris 8's) are not thread-safe: if a
|
|
||||||
# parallel make tries to run `mkdir -p a/b' and `mkdir -p a/c'
|
|
||||||
# concurrently, both version can detect that a/ is missing, but only
|
|
||||||
# one can create it and the other will error out. Consequently we
|
|
||||||
# restrict ourselves to GNU make (using the --version option ensures
|
|
||||||
# this.)
|
|
||||||
AC_DEFUN([AM_PROG_MKDIR_P],
|
|
||||||
[if mkdir -p --version . >/dev/null 2>&1 && test ! -d ./--version; then
|
|
||||||
# We used to keeping the `.' as first argument, in order to
|
|
||||||
# allow $(mkdir_p) to be used without argument. As in
|
|
||||||
# $(mkdir_p) $(somedir)
|
|
||||||
# where $(somedir) is conditionally defined. However this is wrong
|
|
||||||
# for two reasons:
|
|
||||||
# 1. if the package is installed by a user who cannot write `.'
|
|
||||||
# make install will fail,
|
|
||||||
# 2. the above comment should most certainly read
|
|
||||||
# $(mkdir_p) $(DESTDIR)$(somedir)
|
|
||||||
# so it does not work when $(somedir) is undefined and
|
|
||||||
# $(DESTDIR) is not.
|
|
||||||
# To support the latter case, we have to write
|
|
||||||
# test -z "$(somedir)" || $(mkdir_p) $(DESTDIR)$(somedir),
|
|
||||||
# so the `.' trick is pointless.
|
|
||||||
mkdir_p='mkdir -p --'
|
|
||||||
else
|
|
||||||
# On NextStep and OpenStep, the `mkdir' command does not
|
|
||||||
# recognize any option. It will interpret all options as
|
|
||||||
# directories to create, and then abort because `.' already
|
|
||||||
# exists.
|
|
||||||
for d in ./-p ./--version;
|
|
||||||
do
|
|
||||||
test -d $d && rmdir $d
|
|
||||||
done
|
|
||||||
# $(mkinstalldirs) is defined by Automake if mkinstalldirs exists.
|
|
||||||
if test -f "$ac_aux_dir/mkinstalldirs"; then
|
|
||||||
mkdir_p='$(mkinstalldirs)'
|
|
||||||
else
|
|
||||||
mkdir_p='$(install_sh) -d'
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
AC_SUBST([mkdir_p])])
|
|
||||||
|
|
||||||
# Helper functions for option handling. -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 2001, 2002, 2003, 2005 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 3
|
|
||||||
|
|
||||||
# _AM_MANGLE_OPTION(NAME)
|
|
||||||
# -----------------------
|
|
||||||
AC_DEFUN([_AM_MANGLE_OPTION],
|
|
||||||
[[_AM_OPTION_]m4_bpatsubst($1, [[^a-zA-Z0-9_]], [_])])
|
|
||||||
|
|
||||||
# _AM_SET_OPTION(NAME)
|
|
||||||
# ------------------------------
|
|
||||||
# Set option NAME. Presently that only means defining a flag for this option.
|
|
||||||
AC_DEFUN([_AM_SET_OPTION],
|
|
||||||
[m4_define(_AM_MANGLE_OPTION([$1]), 1)])
|
|
||||||
|
|
||||||
# _AM_SET_OPTIONS(OPTIONS)
|
|
||||||
# ----------------------------------
|
|
||||||
# OPTIONS is a space-separated list of Automake options.
|
|
||||||
AC_DEFUN([_AM_SET_OPTIONS],
|
|
||||||
[AC_FOREACH([_AM_Option], [$1], [_AM_SET_OPTION(_AM_Option)])])
|
|
||||||
|
|
||||||
# _AM_IF_OPTION(OPTION, IF-SET, [IF-NOT-SET])
|
|
||||||
# -------------------------------------------
|
|
||||||
# Execute IF-SET if OPTION is set, IF-NOT-SET otherwise.
|
|
||||||
AC_DEFUN([_AM_IF_OPTION],
|
|
||||||
[m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])])
|
|
||||||
|
|
||||||
# Check to make sure that the build environment is sane. -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 1996, 1997, 2000, 2001, 2003, 2005
|
|
||||||
# Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 4
|
|
||||||
|
|
||||||
# AM_SANITY_CHECK
|
|
||||||
# ---------------
|
|
||||||
AC_DEFUN([AM_SANITY_CHECK],
|
|
||||||
[AC_MSG_CHECKING([whether build environment is sane])
|
|
||||||
# Just in case
|
|
||||||
sleep 1
|
|
||||||
echo timestamp > conftest.file
|
|
||||||
# Do `set' in a subshell so we don't clobber the current shell's
|
|
||||||
# arguments. Must try -L first in case configure is actually a
|
|
||||||
# symlink; some systems play weird games with the mod time of symlinks
|
|
||||||
# (eg FreeBSD returns the mod time of the symlink's containing
|
|
||||||
# directory).
|
|
||||||
if (
|
|
||||||
set X `ls -Lt $srcdir/configure conftest.file 2> /dev/null`
|
|
||||||
if test "$[*]" = "X"; then
|
|
||||||
# -L didn't work.
|
|
||||||
set X `ls -t $srcdir/configure conftest.file`
|
|
||||||
fi
|
|
||||||
rm -f conftest.file
|
|
||||||
if test "$[*]" != "X $srcdir/configure conftest.file" \
|
|
||||||
&& test "$[*]" != "X conftest.file $srcdir/configure"; then
|
|
||||||
|
|
||||||
# If neither matched, then we have a broken ls. This can happen
|
|
||||||
# if, for instance, CONFIG_SHELL is bash and it inherits a
|
|
||||||
# broken ls alias from the environment. This has actually
|
|
||||||
# happened. Such a system could not be considered "sane".
|
|
||||||
AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken
|
|
||||||
alias in your environment])
|
|
||||||
fi
|
|
||||||
|
|
||||||
test "$[2]" = conftest.file
|
|
||||||
)
|
|
||||||
then
|
|
||||||
# Ok.
|
|
||||||
:
|
|
||||||
else
|
|
||||||
AC_MSG_ERROR([newly created file is older than distributed files!
|
|
||||||
Check your system clock])
|
|
||||||
fi
|
|
||||||
AC_MSG_RESULT(yes)])
|
|
||||||
|
|
||||||
# Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# AM_PROG_INSTALL_STRIP
|
|
||||||
# ---------------------
|
|
||||||
# One issue with vendor `install' (even GNU) is that you can't
|
|
||||||
# specify the program used to strip binaries. This is especially
|
|
||||||
# annoying in cross-compiling environments, where the build's strip
|
|
||||||
# is unlikely to handle the host's binaries.
|
|
||||||
# Fortunately install-sh will honor a STRIPPROG variable, so we
|
|
||||||
# always use install-sh in `make install-strip', and initialize
|
|
||||||
# STRIPPROG with the value of the STRIP variable (set by the user).
|
|
||||||
AC_DEFUN([AM_PROG_INSTALL_STRIP],
|
|
||||||
[AC_REQUIRE([AM_PROG_INSTALL_SH])dnl
|
|
||||||
# Installed binaries are usually stripped using `strip' when the user
|
|
||||||
# run `make install-strip'. However `strip' might not be the right
|
|
||||||
# tool to use in cross-compilation environments, therefore Automake
|
|
||||||
# will honor the `STRIP' environment variable to overrule this program.
|
|
||||||
dnl Don't test for $cross_compiling = yes, because it might be `maybe'.
|
|
||||||
if test "$cross_compiling" != no; then
|
|
||||||
AC_CHECK_TOOL([STRIP], [strip], :)
|
|
||||||
fi
|
|
||||||
INSTALL_STRIP_PROGRAM="\${SHELL} \$(install_sh) -c -s"
|
|
||||||
AC_SUBST([INSTALL_STRIP_PROGRAM])])
|
|
||||||
|
|
||||||
# Check how to create a tarball. -*- Autoconf -*-
|
|
||||||
|
|
||||||
# Copyright (C) 2004, 2005 Free Software Foundation, Inc.
|
|
||||||
#
|
|
||||||
# This file is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# serial 2
|
|
||||||
|
|
||||||
# _AM_PROG_TAR(FORMAT)
|
|
||||||
# --------------------
|
|
||||||
# Check how to create a tarball in format FORMAT.
|
|
||||||
# FORMAT should be one of `v7', `ustar', or `pax'.
|
|
||||||
#
|
|
||||||
# Substitute a variable $(am__tar) that is a command
|
|
||||||
# writing to stdout a FORMAT-tarball containing the directory
|
|
||||||
# $tardir.
|
|
||||||
# tardir=directory && $(am__tar) > result.tar
|
|
||||||
#
|
|
||||||
# Substitute a variable $(am__untar) that extract such
|
|
||||||
# a tarball read from stdin.
|
|
||||||
# $(am__untar) < result.tar
|
|
||||||
AC_DEFUN([_AM_PROG_TAR],
|
|
||||||
[# Always define AMTAR for backward compatibility.
|
|
||||||
AM_MISSING_PROG([AMTAR], [tar])
|
|
||||||
m4_if([$1], [v7],
|
|
||||||
[am__tar='${AMTAR} chof - "$$tardir"'; am__untar='${AMTAR} xf -'],
|
|
||||||
[m4_case([$1], [ustar],, [pax],,
|
|
||||||
[m4_fatal([Unknown tar format])])
|
|
||||||
AC_MSG_CHECKING([how to create a $1 tar archive])
|
|
||||||
# Loop over all known methods to create a tar archive until one works.
|
|
||||||
_am_tools='gnutar m4_if([$1], [ustar], [plaintar]) pax cpio none'
|
|
||||||
_am_tools=${am_cv_prog_tar_$1-$_am_tools}
|
|
||||||
# Do not fold the above two line into one, because Tru64 sh and
|
|
||||||
# Solaris sh will not grok spaces in the rhs of `-'.
|
|
||||||
for _am_tool in $_am_tools
|
|
||||||
do
|
|
||||||
case $_am_tool in
|
|
||||||
gnutar)
|
|
||||||
for _am_tar in tar gnutar gtar;
|
|
||||||
do
|
|
||||||
AM_RUN_LOG([$_am_tar --version]) && break
|
|
||||||
done
|
|
||||||
am__tar="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$$tardir"'
|
|
||||||
am__tar_="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$tardir"'
|
|
||||||
am__untar="$_am_tar -xf -"
|
|
||||||
;;
|
|
||||||
plaintar)
|
|
||||||
# Must skip GNU tar: if it does not support --format= it doesn't create
|
|
||||||
# ustar tarball either.
|
|
||||||
(tar --version) >/dev/null 2>&1 && continue
|
|
||||||
am__tar='tar chf - "$$tardir"'
|
|
||||||
am__tar_='tar chf - "$tardir"'
|
|
||||||
am__untar='tar xf -'
|
|
||||||
;;
|
|
||||||
pax)
|
|
||||||
am__tar='pax -L -x $1 -w "$$tardir"'
|
|
||||||
am__tar_='pax -L -x $1 -w "$tardir"'
|
|
||||||
am__untar='pax -r'
|
|
||||||
;;
|
|
||||||
cpio)
|
|
||||||
am__tar='find "$$tardir" -print | cpio -o -H $1 -L'
|
|
||||||
am__tar_='find "$tardir" -print | cpio -o -H $1 -L'
|
|
||||||
am__untar='cpio -i -H $1 -d'
|
|
||||||
;;
|
|
||||||
none)
|
|
||||||
am__tar=false
|
|
||||||
am__tar_=false
|
|
||||||
am__untar=false
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# If the value was cached, stop now. We just wanted to have am__tar
|
|
||||||
# and am__untar set.
|
|
||||||
test -n "${am_cv_prog_tar_$1}" && break
|
|
||||||
|
|
||||||
# tar/untar a dummy directory, and stop if the command works
|
|
||||||
rm -rf conftest.dir
|
|
||||||
mkdir conftest.dir
|
|
||||||
echo GrepMe > conftest.dir/file
|
|
||||||
AM_RUN_LOG([tardir=conftest.dir && eval $am__tar_ >conftest.tar])
|
|
||||||
rm -rf conftest.dir
|
|
||||||
if test -s conftest.tar; then
|
|
||||||
AM_RUN_LOG([$am__untar <conftest.tar])
|
|
||||||
grep GrepMe conftest.dir/file >/dev/null 2>&1 && break
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
rm -rf conftest.dir
|
|
||||||
|
|
||||||
AC_CACHE_VAL([am_cv_prog_tar_$1], [am_cv_prog_tar_$1=$_am_tool])
|
|
||||||
AC_MSG_RESULT([$am_cv_prog_tar_$1])])
|
|
||||||
AC_SUBST([am__tar])
|
|
||||||
AC_SUBST([am__untar])
|
|
||||||
]) # _AM_PROG_TAR
|
|
||||||
|
|
|
@ -1,53 +0,0 @@
|
||||||
/**
|
|
||||||
@file callbacks.c
|
|
||||||
@brief ENet callback functions
|
|
||||||
*/
|
|
||||||
#define ENET_BUILDING_LIB 1
|
|
||||||
#include "enet/enet.h"
|
|
||||||
|
|
||||||
static ENetCallbacks callbacks = { malloc, free, rand };
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_initialize_with_callbacks (ENetVersion version, const ENetCallbacks * inits)
|
|
||||||
{
|
|
||||||
if (version != ENET_VERSION)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
if (inits -> malloc != NULL || inits -> free != NULL)
|
|
||||||
{
|
|
||||||
if (inits -> malloc == NULL || inits -> free == NULL)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
callbacks.malloc = inits -> malloc;
|
|
||||||
callbacks.free = inits -> free;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (inits -> rand != NULL)
|
|
||||||
callbacks.rand = inits -> rand;
|
|
||||||
|
|
||||||
return enet_initialize ();
|
|
||||||
}
|
|
||||||
|
|
||||||
void *
|
|
||||||
enet_malloc (size_t size)
|
|
||||||
{
|
|
||||||
void * memory = callbacks.malloc (size);
|
|
||||||
|
|
||||||
if (memory == NULL)
|
|
||||||
abort ();
|
|
||||||
|
|
||||||
return memory;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
enet_free (void * memory)
|
|
||||||
{
|
|
||||||
callbacks.free (memory);
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_rand (void)
|
|
||||||
{
|
|
||||||
return callbacks.rand ();
|
|
||||||
}
|
|
||||||
|
|
5691
polymer/eduke32/build/src/enet/configure
vendored
5691
polymer/eduke32/build/src/enet/configure
vendored
File diff suppressed because it is too large
Load diff
|
@ -1,36 +0,0 @@
|
||||||
AC_INIT(libenet, 1-8-2008)
|
|
||||||
AM_INIT_AUTOMAKE(libenet.a, 1-8-2008)
|
|
||||||
|
|
||||||
AC_PROG_CC
|
|
||||||
AC_PROG_RANLIB
|
|
||||||
|
|
||||||
AC_CHECK_FUNC(gethostbyaddr_r, [AC_DEFINE(HAS_GETHOSTBYADDR_R)])
|
|
||||||
AC_CHECK_FUNC(gethostbyname_r, [AC_DEFINE(HAS_GETHOSTBYNAME_R)])
|
|
||||||
AC_CHECK_FUNC(poll, [AC_DEFINE(HAS_POLL)])
|
|
||||||
AC_CHECK_FUNC(fcntl, [AC_DEFINE(HAS_FCNTL)])
|
|
||||||
AC_CHECK_FUNC(inet_pton, [AC_DEFINE(HAS_INET_PTON)])
|
|
||||||
AC_CHECK_FUNC(inet_ntop, [AC_DEFINE(HAS_INET_NTOP)])
|
|
||||||
|
|
||||||
AC_CHECK_MEMBER(struct msghdr.msg_flags, [AC_DEFINE(HAS_MSGHDR_FLAGS)], , [#include <sys/socket.h>])
|
|
||||||
|
|
||||||
AC_CHECK_TYPE(socklen_t, [AC_DEFINE(HAS_SOCKLEN_T)], ,
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <sys/socket.h>
|
|
||||||
)
|
|
||||||
|
|
||||||
AC_EGREP_HEADER(MSG_MAXIOVLEN, /usr/include/sys/socket.h, AC_DEFINE(ENET_BUFFER_MAXIMUM, [MSG_MAXIOVLEN]))
|
|
||||||
AC_EGREP_HEADER(MSG_MAXIOVLEN, socket.h, AC_DEFINE(ENET_BUFFER_MAXIMUM, [MSG_MAXIOVLEN]))
|
|
||||||
|
|
||||||
AC_MSG_CHECKING(whether to use CRC32)
|
|
||||||
AC_ARG_ENABLE(crc32,
|
|
||||||
[ --enable-crc32 enable CRC32 packet verification ],
|
|
||||||
[if test "$enableval" = yes; then
|
|
||||||
AC_MSG_RESULT(yes)
|
|
||||||
AC_DEFINE(USE_CRC32)
|
|
||||||
else
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
fi],
|
|
||||||
[AC_MSG_RESULT(no)])
|
|
||||||
|
|
||||||
AC_OUTPUT([Makefile include/Makefile include/enet/Makefile])
|
|
||||||
|
|
|
@ -1,530 +0,0 @@
|
||||||
#! /bin/sh
|
|
||||||
# depcomp - compile a program generating dependencies as side-effects
|
|
||||||
|
|
||||||
scriptversion=2005-07-09.11
|
|
||||||
|
|
||||||
# Copyright (C) 1999, 2000, 2003, 2004, 2005 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
# any later version.
|
|
||||||
|
|
||||||
# This program 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 General Public License for more details.
|
|
||||||
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program; if not, write to the Free Software
|
|
||||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
||||||
# 02110-1301, USA.
|
|
||||||
|
|
||||||
# As a special exception to the GNU General Public License, if you
|
|
||||||
# distribute this file as part of a program that contains a
|
|
||||||
# configuration script generated by Autoconf, you may include it under
|
|
||||||
# the same distribution terms that you use for the rest of that program.
|
|
||||||
|
|
||||||
# Originally written by Alexandre Oliva <oliva@dcc.unicamp.br>.
|
|
||||||
|
|
||||||
case $1 in
|
|
||||||
'')
|
|
||||||
echo "$0: No command. Try \`$0 --help' for more information." 1>&2
|
|
||||||
exit 1;
|
|
||||||
;;
|
|
||||||
-h | --h*)
|
|
||||||
cat <<\EOF
|
|
||||||
Usage: depcomp [--help] [--version] PROGRAM [ARGS]
|
|
||||||
|
|
||||||
Run PROGRAMS ARGS to compile a file, generating dependencies
|
|
||||||
as side-effects.
|
|
||||||
|
|
||||||
Environment variables:
|
|
||||||
depmode Dependency tracking mode.
|
|
||||||
source Source file read by `PROGRAMS ARGS'.
|
|
||||||
object Object file output by `PROGRAMS ARGS'.
|
|
||||||
DEPDIR directory where to store dependencies.
|
|
||||||
depfile Dependency file to output.
|
|
||||||
tmpdepfile Temporary file to use when outputing dependencies.
|
|
||||||
libtool Whether libtool is used (yes/no).
|
|
||||||
|
|
||||||
Report bugs to <bug-automake@gnu.org>.
|
|
||||||
EOF
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
-v | --v*)
|
|
||||||
echo "depcomp $scriptversion"
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if test -z "$depmode" || test -z "$source" || test -z "$object"; then
|
|
||||||
echo "depcomp: Variables source, object and depmode must be set" 1>&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po.
|
|
||||||
depfile=${depfile-`echo "$object" |
|
|
||||||
sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`}
|
|
||||||
tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`}
|
|
||||||
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
|
|
||||||
# Some modes work just like other modes, but use different flags. We
|
|
||||||
# parameterize here, but still list the modes in the big case below,
|
|
||||||
# to make depend.m4 easier to write. Note that we *cannot* use a case
|
|
||||||
# here, because this file can only contain one case statement.
|
|
||||||
if test "$depmode" = hp; then
|
|
||||||
# HP compiler uses -M and no extra arg.
|
|
||||||
gccflag=-M
|
|
||||||
depmode=gcc
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$depmode" = dashXmstdout; then
|
|
||||||
# This is just like dashmstdout with a different argument.
|
|
||||||
dashmflag=-xM
|
|
||||||
depmode=dashmstdout
|
|
||||||
fi
|
|
||||||
|
|
||||||
case "$depmode" in
|
|
||||||
gcc3)
|
|
||||||
## gcc 3 implements dependency tracking that does exactly what
|
|
||||||
## we want. Yay! Note: for some reason libtool 1.4 doesn't like
|
|
||||||
## it if -MD -MP comes after the -MF stuff. Hmm.
|
|
||||||
"$@" -MT "$object" -MD -MP -MF "$tmpdepfile"
|
|
||||||
stat=$?
|
|
||||||
if test $stat -eq 0; then :
|
|
||||||
else
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
mv "$tmpdepfile" "$depfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
gcc)
|
|
||||||
## There are various ways to get dependency output from gcc. Here's
|
|
||||||
## why we pick this rather obscure method:
|
|
||||||
## - Don't want to use -MD because we'd like the dependencies to end
|
|
||||||
## up in a subdir. Having to rename by hand is ugly.
|
|
||||||
## (We might end up doing this anyway to support other compilers.)
|
|
||||||
## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like
|
|
||||||
## -MM, not -M (despite what the docs say).
|
|
||||||
## - Using -M directly means running the compiler twice (even worse
|
|
||||||
## than renaming).
|
|
||||||
if test -z "$gccflag"; then
|
|
||||||
gccflag=-MD,
|
|
||||||
fi
|
|
||||||
"$@" -Wp,"$gccflag$tmpdepfile"
|
|
||||||
stat=$?
|
|
||||||
if test $stat -eq 0; then :
|
|
||||||
else
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
alpha=ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz
|
|
||||||
## The second -e expression handles DOS-style file names with drive letters.
|
|
||||||
sed -e 's/^[^:]*: / /' \
|
|
||||||
-e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile"
|
|
||||||
## This next piece of magic avoids the `deleted header file' problem.
|
|
||||||
## The problem is that when a header file which appears in a .P file
|
|
||||||
## is deleted, the dependency causes make to die (because there is
|
|
||||||
## typically no way to rebuild the header). We avoid this by adding
|
|
||||||
## dummy dependencies for each header file. Too bad gcc doesn't do
|
|
||||||
## this for us directly.
|
|
||||||
tr ' ' '
|
|
||||||
' < "$tmpdepfile" |
|
|
||||||
## Some versions of gcc put a space before the `:'. On the theory
|
|
||||||
## that the space means something, we add a space to the output as
|
|
||||||
## well.
|
|
||||||
## Some versions of the HPUX 10.20 sed can't process this invocation
|
|
||||||
## correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
hp)
|
|
||||||
# This case exists only to let depend.m4 do its work. It works by
|
|
||||||
# looking at the text of this script. This case will never be run,
|
|
||||||
# since it is checked for above.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
sgi)
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
"$@" "-Wp,-MDupdate,$tmpdepfile"
|
|
||||||
else
|
|
||||||
"$@" -MDupdate "$tmpdepfile"
|
|
||||||
fi
|
|
||||||
stat=$?
|
|
||||||
if test $stat -eq 0; then :
|
|
||||||
else
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
|
|
||||||
if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
|
|
||||||
# Clip off the initial element (the dependent). Don't try to be
|
|
||||||
# clever and replace this with sed code, as IRIX sed won't handle
|
|
||||||
# lines with more than a fixed number of characters (4096 in
|
|
||||||
# IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines;
|
|
||||||
# the IRIX cc adds comments like `#:fec' to the end of the
|
|
||||||
# dependency line.
|
|
||||||
tr ' ' '
|
|
||||||
' < "$tmpdepfile" \
|
|
||||||
| sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' | \
|
|
||||||
tr '
|
|
||||||
' ' ' >> $depfile
|
|
||||||
echo >> $depfile
|
|
||||||
|
|
||||||
# The second pass generates a dummy entry for each header file.
|
|
||||||
tr ' ' '
|
|
||||||
' < "$tmpdepfile" \
|
|
||||||
| sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \
|
|
||||||
>> $depfile
|
|
||||||
else
|
|
||||||
# The sourcefile does not contain any dependencies, so just
|
|
||||||
# store a dummy comment line, to avoid errors with the Makefile
|
|
||||||
# "include basename.Plo" scheme.
|
|
||||||
echo "#dummy" > "$depfile"
|
|
||||||
fi
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
aix)
|
|
||||||
# The C for AIX Compiler uses -M and outputs the dependencies
|
|
||||||
# in a .u file. In older versions, this file always lives in the
|
|
||||||
# current directory. Also, the AIX compiler puts `$object:' at the
|
|
||||||
# start of each line; $object doesn't have directory information.
|
|
||||||
# Version 6 uses the directory in both cases.
|
|
||||||
stripped=`echo "$object" | sed 's/\(.*\)\..*$/\1/'`
|
|
||||||
tmpdepfile="$stripped.u"
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
"$@" -Wc,-M
|
|
||||||
else
|
|
||||||
"$@" -M
|
|
||||||
fi
|
|
||||||
stat=$?
|
|
||||||
|
|
||||||
if test -f "$tmpdepfile"; then :
|
|
||||||
else
|
|
||||||
stripped=`echo "$stripped" | sed 's,^.*/,,'`
|
|
||||||
tmpdepfile="$stripped.u"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test $stat -eq 0; then :
|
|
||||||
else
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test -f "$tmpdepfile"; then
|
|
||||||
outname="$stripped.o"
|
|
||||||
# Each line is of the form `foo.o: dependent.h'.
|
|
||||||
# Do two passes, one to just change these to
|
|
||||||
# `$object: dependent.h' and one to simply `dependent.h:'.
|
|
||||||
sed -e "s,^$outname:,$object :," < "$tmpdepfile" > "$depfile"
|
|
||||||
sed -e "s,^$outname: \(.*\)$,\1:," < "$tmpdepfile" >> "$depfile"
|
|
||||||
else
|
|
||||||
# The sourcefile does not contain any dependencies, so just
|
|
||||||
# store a dummy comment line, to avoid errors with the Makefile
|
|
||||||
# "include basename.Plo" scheme.
|
|
||||||
echo "#dummy" > "$depfile"
|
|
||||||
fi
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
icc)
|
|
||||||
# Intel's C compiler understands `-MD -MF file'. However on
|
|
||||||
# icc -MD -MF foo.d -c -o sub/foo.o sub/foo.c
|
|
||||||
# ICC 7.0 will fill foo.d with something like
|
|
||||||
# foo.o: sub/foo.c
|
|
||||||
# foo.o: sub/foo.h
|
|
||||||
# which is wrong. We want:
|
|
||||||
# sub/foo.o: sub/foo.c
|
|
||||||
# sub/foo.o: sub/foo.h
|
|
||||||
# sub/foo.c:
|
|
||||||
# sub/foo.h:
|
|
||||||
# ICC 7.1 will output
|
|
||||||
# foo.o: sub/foo.c sub/foo.h
|
|
||||||
# and will wrap long lines using \ :
|
|
||||||
# foo.o: sub/foo.c ... \
|
|
||||||
# sub/foo.h ... \
|
|
||||||
# ...
|
|
||||||
|
|
||||||
"$@" -MD -MF "$tmpdepfile"
|
|
||||||
stat=$?
|
|
||||||
if test $stat -eq 0; then :
|
|
||||||
else
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
rm -f "$depfile"
|
|
||||||
# Each line is of the form `foo.o: dependent.h',
|
|
||||||
# or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'.
|
|
||||||
# Do two passes, one to just change these to
|
|
||||||
# `$object: dependent.h' and one to simply `dependent.h:'.
|
|
||||||
sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile"
|
|
||||||
# Some versions of the HPUX 10.20 sed can't process this invocation
|
|
||||||
# correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" |
|
|
||||||
sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
tru64)
|
|
||||||
# The Tru64 compiler uses -MD to generate dependencies as a side
|
|
||||||
# effect. `cc -MD -o foo.o ...' puts the dependencies into `foo.o.d'.
|
|
||||||
# At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put
|
|
||||||
# dependencies in `foo.d' instead, so we check for that too.
|
|
||||||
# Subdirectories are respected.
|
|
||||||
dir=`echo "$object" | sed -e 's|/[^/]*$|/|'`
|
|
||||||
test "x$dir" = "x$object" && dir=
|
|
||||||
base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'`
|
|
||||||
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
# With Tru64 cc, shared objects can also be used to make a
|
|
||||||
# static library. This mecanism is used in libtool 1.4 series to
|
|
||||||
# handle both shared and static libraries in a single compilation.
|
|
||||||
# With libtool 1.4, dependencies were output in $dir.libs/$base.lo.d.
|
|
||||||
#
|
|
||||||
# With libtool 1.5 this exception was removed, and libtool now
|
|
||||||
# generates 2 separate objects for the 2 libraries. These two
|
|
||||||
# compilations output dependencies in in $dir.libs/$base.o.d and
|
|
||||||
# in $dir$base.o.d. We have to check for both files, because
|
|
||||||
# one of the two compilations can be disabled. We should prefer
|
|
||||||
# $dir$base.o.d over $dir.libs/$base.o.d because the latter is
|
|
||||||
# automatically cleaned when .libs/ is deleted, while ignoring
|
|
||||||
# the former would cause a distcleancheck panic.
|
|
||||||
tmpdepfile1=$dir.libs/$base.lo.d # libtool 1.4
|
|
||||||
tmpdepfile2=$dir$base.o.d # libtool 1.5
|
|
||||||
tmpdepfile3=$dir.libs/$base.o.d # libtool 1.5
|
|
||||||
tmpdepfile4=$dir.libs/$base.d # Compaq CCC V6.2-504
|
|
||||||
"$@" -Wc,-MD
|
|
||||||
else
|
|
||||||
tmpdepfile1=$dir$base.o.d
|
|
||||||
tmpdepfile2=$dir$base.d
|
|
||||||
tmpdepfile3=$dir$base.d
|
|
||||||
tmpdepfile4=$dir$base.d
|
|
||||||
"$@" -MD
|
|
||||||
fi
|
|
||||||
|
|
||||||
stat=$?
|
|
||||||
if test $stat -eq 0; then :
|
|
||||||
else
|
|
||||||
rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" "$tmpdepfile4"
|
|
||||||
exit $stat
|
|
||||||
fi
|
|
||||||
|
|
||||||
for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" "$tmpdepfile4"
|
|
||||||
do
|
|
||||||
test -f "$tmpdepfile" && break
|
|
||||||
done
|
|
||||||
if test -f "$tmpdepfile"; then
|
|
||||||
sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile"
|
|
||||||
# That's a tab and a space in the [].
|
|
||||||
sed -e 's,^.*\.[a-z]*:[ ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile"
|
|
||||||
else
|
|
||||||
echo "#dummy" > "$depfile"
|
|
||||||
fi
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
#nosideeffect)
|
|
||||||
# This comment above is used by automake to tell side-effect
|
|
||||||
# dependency tracking mechanisms from slower ones.
|
|
||||||
|
|
||||||
dashmstdout)
|
|
||||||
# Important note: in order to support this mode, a compiler *must*
|
|
||||||
# always write the preprocessed file to stdout, regardless of -o.
|
|
||||||
"$@" || exit $?
|
|
||||||
|
|
||||||
# Remove the call to Libtool.
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test $1 != '--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Remove `-o $object'.
|
|
||||||
IFS=" "
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case $arg in
|
|
||||||
-o)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
$object)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"
|
|
||||||
shift # fnord
|
|
||||||
shift # $arg
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
test -z "$dashmflag" && dashmflag=-M
|
|
||||||
# Require at least two characters before searching for `:'
|
|
||||||
# in the target name. This is to cope with DOS-style filenames:
|
|
||||||
# a dependency such as `c:/foo/bar' could be seen as target `c' otherwise.
|
|
||||||
"$@" $dashmflag |
|
|
||||||
sed 's:^[ ]*[^: ][^:][^:]*\:[ ]*:'"$object"'\: :' > "$tmpdepfile"
|
|
||||||
rm -f "$depfile"
|
|
||||||
cat < "$tmpdepfile" > "$depfile"
|
|
||||||
tr ' ' '
|
|
||||||
' < "$tmpdepfile" | \
|
|
||||||
## Some versions of the HPUX 10.20 sed can't process this invocation
|
|
||||||
## correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
dashXmstdout)
|
|
||||||
# This case only exists to satisfy depend.m4. It is never actually
|
|
||||||
# run, as this mode is specially recognized in the preamble.
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
makedepend)
|
|
||||||
"$@" || exit $?
|
|
||||||
# Remove any Libtool call
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test $1 != '--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
# X makedepend
|
|
||||||
shift
|
|
||||||
cleared=no
|
|
||||||
for arg in "$@"; do
|
|
||||||
case $cleared in
|
|
||||||
no)
|
|
||||||
set ""; shift
|
|
||||||
cleared=yes ;;
|
|
||||||
esac
|
|
||||||
case "$arg" in
|
|
||||||
-D*|-I*)
|
|
||||||
set fnord "$@" "$arg"; shift ;;
|
|
||||||
# Strip any option that makedepend may not understand. Remove
|
|
||||||
# the object too, otherwise makedepend will parse it as a source file.
|
|
||||||
-*|$object)
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"; shift ;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
obj_suffix="`echo $object | sed 's/^.*\././'`"
|
|
||||||
touch "$tmpdepfile"
|
|
||||||
${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@"
|
|
||||||
rm -f "$depfile"
|
|
||||||
cat < "$tmpdepfile" > "$depfile"
|
|
||||||
sed '1,2d' "$tmpdepfile" | tr ' ' '
|
|
||||||
' | \
|
|
||||||
## Some versions of the HPUX 10.20 sed can't process this invocation
|
|
||||||
## correctly. Breaking it into two sed invocations is a workaround.
|
|
||||||
sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile" "$tmpdepfile".bak
|
|
||||||
;;
|
|
||||||
|
|
||||||
cpp)
|
|
||||||
# Important note: in order to support this mode, a compiler *must*
|
|
||||||
# always write the preprocessed file to stdout.
|
|
||||||
"$@" || exit $?
|
|
||||||
|
|
||||||
# Remove the call to Libtool.
|
|
||||||
if test "$libtool" = yes; then
|
|
||||||
while test $1 != '--mode=compile'; do
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
shift
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Remove `-o $object'.
|
|
||||||
IFS=" "
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case $arg in
|
|
||||||
-o)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
$object)
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"
|
|
||||||
shift # fnord
|
|
||||||
shift # $arg
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
"$@" -E |
|
|
||||||
sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \
|
|
||||||
-e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' |
|
|
||||||
sed '$ s: \\$::' > "$tmpdepfile"
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
cat < "$tmpdepfile" >> "$depfile"
|
|
||||||
sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
msvisualcpp)
|
|
||||||
# Important note: in order to support this mode, a compiler *must*
|
|
||||||
# always write the preprocessed file to stdout, regardless of -o,
|
|
||||||
# because we must use -o when running libtool.
|
|
||||||
"$@" || exit $?
|
|
||||||
IFS=" "
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
case "$arg" in
|
|
||||||
"-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI")
|
|
||||||
set fnord "$@"
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
set fnord "$@" "$arg"
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
"$@" -E |
|
|
||||||
sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::echo "`cygpath -u \\"\1\\"`":p' | sort | uniq > "$tmpdepfile"
|
|
||||||
rm -f "$depfile"
|
|
||||||
echo "$object : \\" > "$depfile"
|
|
||||||
. "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s:: \1 \\:p' >> "$depfile"
|
|
||||||
echo " " >> "$depfile"
|
|
||||||
. "$tmpdepfile" | sed 's% %\\ %g' | sed -n '/^\(.*\)$/ s::\1\::p' >> "$depfile"
|
|
||||||
rm -f "$tmpdepfile"
|
|
||||||
;;
|
|
||||||
|
|
||||||
none)
|
|
||||||
exec "$@"
|
|
||||||
;;
|
|
||||||
|
|
||||||
*)
|
|
||||||
echo "Unknown depmode $depmode" 1>&2
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
exit 0
|
|
||||||
|
|
||||||
# Local Variables:
|
|
||||||
# mode: shell-script
|
|
||||||
# sh-indentation: 2
|
|
||||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
|
||||||
# time-stamp-start: "scriptversion="
|
|
||||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
|
||||||
# time-stamp-end: "$"
|
|
||||||
# End:
|
|
|
@ -1,117 +0,0 @@
|
||||||
* Why ENet?
|
|
||||||
|
|
||||||
ENet evolved specifically as a UDP networking layer for the multiplayer
|
|
||||||
first person shooter Cube. Cube necessitated low latency communcation with
|
|
||||||
data sent out very frequently, so TCP was an unsuitable choice due to its
|
|
||||||
high latency and stream orientation. UDP, however, lacks many sometimes
|
|
||||||
necessary features from TCP such as reliability, sequencing, unrestricted
|
|
||||||
packet sizes, and connection management. So UDP by itself was not suitable
|
|
||||||
as a network protocol either. No suitable freely available networking
|
|
||||||
libraries existed at the time of ENet's creation to fill this niche.
|
|
||||||
|
|
||||||
UDP and TCP could have been used together in Cube to benefit somewhat
|
|
||||||
from both of their features, however, the resulting combinations of protocols
|
|
||||||
still leaves much to be desired. TCP lacks multiple streams of communication
|
|
||||||
without resorting to opening many sockets and complicates delineation of
|
|
||||||
packets due to its buffering behavior. UDP lacks sequencing, connection
|
|
||||||
management, management of bandwidth resources, and imposes limitations on
|
|
||||||
the size of packets. A significant investment is required to integrate these
|
|
||||||
two protocols, and the end result is worse off in features and performance
|
|
||||||
than the uniform protocol presented by ENet.
|
|
||||||
|
|
||||||
ENet thus attempts to address these issues and provide a single, uniform
|
|
||||||
protocol layered over UDP to the developer with the best features of UDP and
|
|
||||||
TCP as well as some useful features neither provide, with a much cleaner
|
|
||||||
integration than any resulting from a mixture of UDP and TCP.
|
|
||||||
|
|
||||||
* Connection management
|
|
||||||
|
|
||||||
ENet provides a simple connection interface over which to communicate
|
|
||||||
with a foreign host. The liveness of the connection is actively monitored
|
|
||||||
by pinging the foreign host at frequent intervals, and also monitors the
|
|
||||||
network conditions from the local host to the foreign host such as the
|
|
||||||
mean round trip time and packet loss in this fashion.
|
|
||||||
|
|
||||||
* Sequencing
|
|
||||||
|
|
||||||
Rather than a single byte stream that complicates the delineation
|
|
||||||
of packets, ENet presents connections as multiple, properly sequenced packet
|
|
||||||
streams that simplify the transfer of various types of data.
|
|
||||||
|
|
||||||
ENet provides sequencing for all packets by assigning to each sent
|
|
||||||
packet a sequence number that is incremented as packets are sent. ENet
|
|
||||||
guarentees that no packet with a higher sequence number will be delivered
|
|
||||||
before a packet with a lower sequence number, thus ensuring packets are
|
|
||||||
delivered exactly in the order they are sent.
|
|
||||||
|
|
||||||
For unreliable packets, ENet will simply discard the lower sequence
|
|
||||||
number packet if a packet with a higher sequence number has already been
|
|
||||||
delivered. This allows the packets to be dispatched immediately as they
|
|
||||||
arrive, and reduce latency of unreliable packets to an absolute minimum.
|
|
||||||
For reliable packets, if a higher sequence number packet arrives, but the
|
|
||||||
preceding packets in the sequence have not yet arrived, ENet will stall
|
|
||||||
delivery of the higher sequence number packets until its predecessors
|
|
||||||
have arrived.
|
|
||||||
|
|
||||||
* Channels
|
|
||||||
|
|
||||||
Since ENet will stall delivery of reliable packets to ensure proper
|
|
||||||
sequencing, and consequently any packets of higher sequence number whether
|
|
||||||
reliable or unreliable, in the event the reliable packet's predecessors
|
|
||||||
have not yet arrived, this can introduce latency into the delivery of other
|
|
||||||
packets which may not need to be as strictly ordered with respect to the
|
|
||||||
packet that stalled their delivery.
|
|
||||||
|
|
||||||
To combat this latency and reduce the ordering restrictions on packets,
|
|
||||||
ENet provides multiple channels of communication over a given connection.
|
|
||||||
Each channel is independently sequenced, and so the delivery status of
|
|
||||||
a packet in one channel will not stall the delivery of other packets
|
|
||||||
in another channel.
|
|
||||||
|
|
||||||
* Reliability
|
|
||||||
|
|
||||||
ENet provides optional reliability of packet delivery by ensuring the
|
|
||||||
foreign host acknowledges receipt of all reliable packets. ENet will attempt
|
|
||||||
to resend the packet up to a reasonable amount of times, if no acknowledgement
|
|
||||||
of the packet's receipt happens within a specified timeout. Retry timeouts
|
|
||||||
are progressive and become more lenient with every failed attempt to allow
|
|
||||||
for temporary turbulence in network conditions.
|
|
||||||
|
|
||||||
* Fragmentation and reassembly
|
|
||||||
|
|
||||||
ENet will send and deliver packets regardless of size. Large packets are
|
|
||||||
fragmented into many smaller packets of suitable size, and reassembled on
|
|
||||||
the foreign host to recover the original packet for delivery. The process
|
|
||||||
is entirely transparent to the developer.
|
|
||||||
|
|
||||||
* Aggregation
|
|
||||||
|
|
||||||
ENet aggregates all protocol commands, including acknowledgements and
|
|
||||||
packet transfer, into larger protocol packets to ensure the proper utilization
|
|
||||||
of the connection and to limit the opportunities for packet loss that might
|
|
||||||
otherwise result in further delivery latency.
|
|
||||||
|
|
||||||
* Adaptability
|
|
||||||
|
|
||||||
ENet provides an in-flight data window for reliable packets to ensure
|
|
||||||
connections are not overwhelmed by volumes of packets. It also provides a
|
|
||||||
static bandwidth allocation mechanism to ensure the total volume of packets
|
|
||||||
sent and received to a host don't exceed the host's capabilities. Further,
|
|
||||||
ENet also provides a dynamic throttle that responds to deviations from normal
|
|
||||||
network connections to rectify various types of network congestion by further
|
|
||||||
limiting the volume of packets sent.
|
|
||||||
|
|
||||||
* Portability
|
|
||||||
|
|
||||||
ENet works on Windows and any other Unix or Unix-like platform providing
|
|
||||||
a BSD sockets interface. The library has a small and stable code base that
|
|
||||||
can easily be extended to support other platforms and integrates easily.
|
|
||||||
|
|
||||||
* Freedom
|
|
||||||
|
|
||||||
ENet demands no royalties and doesn't carry a viral license that would
|
|
||||||
restrict you in how you might use it in your programs. ENet is licensed under
|
|
||||||
a short-and-sweet MIT-style license, which gives you the freedom to do anything
|
|
||||||
you want with it (well, almost anything).
|
|
||||||
|
|
||||||
|
|
|
@ -1,7 +0,0 @@
|
||||||
/FAQ.dox/1.1.1.1/Wed Oct 20 17:17:52 2004//
|
|
||||||
/design.dox/1.1.1.1/Wed Oct 20 17:17:52 2004//
|
|
||||||
/install.dox/1.2/Tue Oct 9 23:22:45 2007//
|
|
||||||
/license.dox/1.1.1.1/Wed Oct 20 17:17:52 2004//
|
|
||||||
/mainpage.dox/1.13/Wed Feb 13 01:31:07 2008//
|
|
||||||
/tutorial.dox/1.3/Tue Mar 14 23:21:51 2006//
|
|
||||||
D
|
|
|
@ -1 +0,0 @@
|
||||||
enet/docs
|
|
|
@ -1 +0,0 @@
|
||||||
:pserver:anonymous@bespin.org:/var/lib/cvs/enet
|
|
|
@ -1,24 +0,0 @@
|
||||||
/**
|
|
||||||
@page FAQ Frequently Answered Questions
|
|
||||||
|
|
||||||
@section Q1 Is ENet thread safe?
|
|
||||||
|
|
||||||
ENet does not use any significant global variables, the vast majority
|
|
||||||
of state is encapsulated in the ENetHost structure. As such, as long
|
|
||||||
as the application guards access to this structure, then ENet should
|
|
||||||
operate fine in a multithreaded environment.
|
|
||||||
|
|
||||||
@section Q2 Isn't ENet just re-inventing TCP?! What's the point?
|
|
||||||
|
|
||||||
In a perfect world, that would be true. But as many have found, using
|
|
||||||
TCP either in lieu of or in conjunction with UDP can lead to all kinds
|
|
||||||
of nightmares. TCP is a good, solid protocol, however it simply isn't
|
|
||||||
up to the task of real-time games. Too much of TCP's implementation
|
|
||||||
dictates a policy that isn't practical for games. If you want to use
|
|
||||||
TCP, then do so -- this library is for people that either don't want
|
|
||||||
to use TCP or have tried and ended up being discouraged with the
|
|
||||||
performance.
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
|
@ -1,126 +0,0 @@
|
||||||
/**
|
|
||||||
@page Features Features and Architecture
|
|
||||||
|
|
||||||
ENet evolved specifically as a UDP networking layer for the
|
|
||||||
multiplayer first person shooter Cube. Cube necessitated low latency
|
|
||||||
communcation with data sent out very frequently, so TCP was an
|
|
||||||
unsuitable choice due to its high latency and stream orientation. UDP,
|
|
||||||
however, lacks many sometimes necessary features from TCP such as
|
|
||||||
reliability, sequencing, unrestricted packet sizes, and connection
|
|
||||||
management. So UDP by itself was not suitable as a network protocol
|
|
||||||
either. No suitable freely available networking libraries existed at
|
|
||||||
the time of ENet's creation to fill this niche.
|
|
||||||
|
|
||||||
UDP and TCP could have been used together in Cube to benefit somewhat
|
|
||||||
from both of their features, however, the resulting combinations of
|
|
||||||
protocols still leaves much to be desired. TCP lacks multiple streams
|
|
||||||
of communication without resorting to opening many sockets and
|
|
||||||
complicates delineation of packets due to its buffering behavior. UDP
|
|
||||||
lacks sequencing, connection management, management of bandwidth
|
|
||||||
resources, and imposes limitations on the size of packets. A
|
|
||||||
significant investment is required to integrate these two protocols,
|
|
||||||
and the end result is worse off in features and performance than the
|
|
||||||
uniform protocol presented by ENet.
|
|
||||||
|
|
||||||
ENet thus attempts to address these issues and provide a single,
|
|
||||||
uniform protocol layered over UDP to the developer with the best
|
|
||||||
features of UDP and TCP as well as some useful features neither
|
|
||||||
provide, with a much cleaner integration than any resulting from a
|
|
||||||
mixture of UDP and TCP.
|
|
||||||
|
|
||||||
@section CM Connection Management
|
|
||||||
|
|
||||||
ENet provides a simple connection interface over which to communicate
|
|
||||||
with a foreign host. The liveness of the connection is actively
|
|
||||||
monitored by pinging the foreign host at frequent intervals, and also
|
|
||||||
monitors the network conditions from the local host to the foreign
|
|
||||||
host such as the mean round trip time and packet loss in this fashion.
|
|
||||||
|
|
||||||
@section Sequencing Sequencing
|
|
||||||
|
|
||||||
Rather than a single byte stream that complicates the delineation of
|
|
||||||
packets, ENet presents connections as multiple, properly sequenced
|
|
||||||
packet streams that simplify the transfer of various types of data.
|
|
||||||
|
|
||||||
ENet provides sequencing for all packets by assigning to each sent
|
|
||||||
packet a sequence number that is incremented as packets are sent. ENet
|
|
||||||
guarentees that no packet with a higher sequence number will be
|
|
||||||
delivered before a packet with a lower sequence number, thus ensuring
|
|
||||||
packets are delivered exactly in the order they are sent.
|
|
||||||
|
|
||||||
For unreliable packets, ENet will simply discard the lower sequence
|
|
||||||
number packet if a packet with a higher sequence number has already
|
|
||||||
been delivered. This allows the packets to be dispatched immediately
|
|
||||||
as they arrive, and reduce latency of unreliable packets to an
|
|
||||||
absolute minimum. For reliable packets, if a higher sequence number
|
|
||||||
packet arrives, but the preceding packets in the sequence have not yet
|
|
||||||
arrived, ENet will stall delivery of the higher sequence number
|
|
||||||
packets until its predecessors have arrived.
|
|
||||||
|
|
||||||
@section Channels Channels
|
|
||||||
|
|
||||||
Since ENet will stall delivery of reliable packets to ensure proper
|
|
||||||
sequencing, and consequently any packets of higher sequence number
|
|
||||||
whether reliable or unreliable, in the event the reliable packet's
|
|
||||||
predecessors have not yet arrived, this can introduce latency into the
|
|
||||||
delivery of other packets which may not need to be as strictly ordered
|
|
||||||
with respect to the packet that stalled their delivery.
|
|
||||||
|
|
||||||
To combat this latency and reduce the ordering restrictions on
|
|
||||||
packets, ENet provides multiple channels of communication over a given
|
|
||||||
connection. Each channel is independently sequenced, and so the
|
|
||||||
delivery status of a packet in one channel will not stall the delivery
|
|
||||||
of other packets in another channel.
|
|
||||||
|
|
||||||
@section Reliability Reliability
|
|
||||||
|
|
||||||
ENet provides optional reliability of packet delivery by ensuring the
|
|
||||||
foreign host acknowledges receipt of all reliable packets. ENet will
|
|
||||||
attempt to resend the packet up to a reasonable amount of times, if no
|
|
||||||
acknowledgement of the packet's receipt happens within a specified
|
|
||||||
timeout. Retry timeouts are progressive and become more lenient with
|
|
||||||
every failed attempt to allow for temporary turbulence in network
|
|
||||||
conditions.
|
|
||||||
|
|
||||||
@section FaR Fragmentation and Reassembly
|
|
||||||
|
|
||||||
ENet will send and deliver packets regardless of size. Large packets
|
|
||||||
are fragmented into many smaller packets of suitable size, and
|
|
||||||
reassembled on the foreign host to recover the original packet for
|
|
||||||
delivery. The process is entirely transparent to the developer.
|
|
||||||
|
|
||||||
@section Aggregation Aggregation
|
|
||||||
|
|
||||||
ENet aggregates all protocol commands, including acknowledgements and
|
|
||||||
packet transfer, into larger protocol packets to ensure the proper
|
|
||||||
utilization of the connection and to limit the opportunities for
|
|
||||||
packet loss that might otherwise result in further delivery latency.
|
|
||||||
|
|
||||||
@section Adaptability Adaptability
|
|
||||||
|
|
||||||
ENet provides an in-flight data window for reliable packets to ensure
|
|
||||||
connections are not overwhelmed by volumes of packets. It also
|
|
||||||
provides a static bandwidth allocation mechanism to ensure the total
|
|
||||||
volume of packets sent and received to a host don't exceed the host's
|
|
||||||
capabilities. Further, ENet also provides a dynamic throttle that
|
|
||||||
responds to deviations from normal network connections to rectify
|
|
||||||
various types of network congestion by further limiting the volume of
|
|
||||||
packets sent.
|
|
||||||
|
|
||||||
@section Portability Portability
|
|
||||||
|
|
||||||
ENet works on Windows and any other Unix or Unix-like platform
|
|
||||||
providing a BSD sockets interface. The library has a small and stable
|
|
||||||
code base that can easily be extended to support other platforms and
|
|
||||||
integrates easily. ENet makes no assumptions about the underlying
|
|
||||||
platform's endianess or word size.
|
|
||||||
|
|
||||||
@section Freedom Freedom
|
|
||||||
|
|
||||||
ENet demands no royalties and doesn't carry a viral license that would
|
|
||||||
restrict you in how you might use it in your programs. ENet is
|
|
||||||
licensed under a short-and-sweet MIT-style license, which gives you
|
|
||||||
the freedom to do anything you want with it (well, almost anything).
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
|
@ -1,60 +0,0 @@
|
||||||
/**
|
|
||||||
@page Installation Installation
|
|
||||||
|
|
||||||
ENet should be trivially simple to integrate with most applications.
|
|
||||||
First, make sure you download the latest source distribution here @ref
|
|
||||||
SourceDistro.
|
|
||||||
|
|
||||||
@section Unix Unix-like Operating Systems
|
|
||||||
|
|
||||||
If you are using an ENet release, then you should simply be able to build it
|
|
||||||
by doing the following:
|
|
||||||
|
|
||||||
./configure && make && make install
|
|
||||||
|
|
||||||
If you obtained the package from CVS, you must have automake and autoconf
|
|
||||||
available to generate the build system first by doing the following command
|
|
||||||
before using the above mentioned build procedure:
|
|
||||||
|
|
||||||
aclocal && automake -a -c --foreign && autoconf
|
|
||||||
|
|
||||||
|
|
||||||
@subsection SolarisBSD Solaris and BSD
|
|
||||||
|
|
||||||
When building ENet under Solaris, you must specify the -lsocket and
|
|
||||||
-lnsl parameters to your compiler to ensure that the sockets library
|
|
||||||
is linked in.
|
|
||||||
|
|
||||||
@section Windows Microsoft Windows
|
|
||||||
|
|
||||||
There is an included MSVC 6 project (enet.dsp) which you may use to
|
|
||||||
build a suitable library file. Alternatively, you may simply drag all
|
|
||||||
the ENet source files into your main project.
|
|
||||||
|
|
||||||
You will have to link to the Winsock2 libraries, so make sure to add
|
|
||||||
ws2_32.lib to your library list (Project Settings | Link |
|
|
||||||
Object/library modules).
|
|
||||||
|
|
||||||
@subsection enet.dsp Building with the included enet.dsp
|
|
||||||
|
|
||||||
Load the included enet.dsp. MSVC may ask you to convert it if you
|
|
||||||
are on a newer version of MSVC - just allow the conversion and save
|
|
||||||
the resulting project as "enet" or similar. After you build this
|
|
||||||
project, it will output an "enet.lib" file to either the "Debug/"
|
|
||||||
or "Release/" directory, depending on which configuration you have
|
|
||||||
selected to build. By default, it should produce "Debug/enet.lib".
|
|
||||||
|
|
||||||
You may then copy the resulting "enet.lib" file and the header files
|
|
||||||
found in the "include/" directory to your other projects and add it to
|
|
||||||
their library lists. Make sure to also link against "ws2_32.lib" as
|
|
||||||
described above.
|
|
||||||
|
|
||||||
@subsection DLL DLL
|
|
||||||
|
|
||||||
If you wish to build ENet as a DLL you must first define ENET_DLL
|
|
||||||
within the project (Project Settings | C/C++ | Preprocessor |
|
|
||||||
Preprocessor definitions) or, more invasively, simply define ENET_DLL
|
|
||||||
at the top of enet.h.
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
|
@ -1,26 +0,0 @@
|
||||||
/**
|
|
||||||
@page License License
|
|
||||||
|
|
||||||
Copyright (c) 2002 Lee Salzman
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining
|
|
||||||
a copy of this software and associated documentation files (the
|
|
||||||
"Software"), to deal in the Software without restriction, including
|
|
||||||
without limitation the rights to use, copy, modify, merge, publish,
|
|
||||||
distribute, sublicense, and/or sell copies of the Software, and to
|
|
||||||
permit persons to whom the Software is furnished to do so, subject to
|
|
||||||
the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be
|
|
||||||
included in all copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
||||||
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
||||||
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
||||||
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
|
||||||
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|
||||||
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
||||||
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
|
@ -1,64 +0,0 @@
|
||||||
/** @mainpage enet
|
|
||||||
<center>http://enet.bespin.org</center>
|
|
||||||
<hr>
|
|
||||||
|
|
||||||
ENet's purpose is to provide a relatively thin, simple and robust
|
|
||||||
network communication layer on top of UDP (User Datagram Protocol).
|
|
||||||
The primary feature it provides is optional reliable, in-order
|
|
||||||
delivery of packets.
|
|
||||||
|
|
||||||
ENet is NOT intended to be a general purpose high level networking
|
|
||||||
library that handles authentication, lobbying, server discovery,
|
|
||||||
compression, encryption and other high level, often application level
|
|
||||||
or dependent tasks.
|
|
||||||
|
|
||||||
@ref Features
|
|
||||||
|
|
||||||
@ref SourceDistro
|
|
||||||
|
|
||||||
@ref Installation
|
|
||||||
|
|
||||||
@ref Tutorial
|
|
||||||
|
|
||||||
@ref MailingList
|
|
||||||
|
|
||||||
@ref FAQ
|
|
||||||
|
|
||||||
@ref License
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
@page SourceDistro Source Distribution
|
|
||||||
|
|
||||||
You can retrieve the source to ENet by downloading it in either .tar.gz form
|
|
||||||
or accessing the cvs distribution directly.
|
|
||||||
|
|
||||||
The most recent stable release (1.2) can be downloaded <a href="http://enet.bespin.org/download/enet-1.2.tar.gz">here</a>.
|
|
||||||
|
|
||||||
To access ENet via anonymous CVS, you must use the CVSROOT
|
|
||||||
:pserver:anonymous\@bespin.org:/var/lib/cvs/enet with an empty
|
|
||||||
password.
|
|
||||||
|
|
||||||
@code
|
|
||||||
$ cvs -z3 -d :pserver:anonymous@bespin.org:/var/lib/cvs/enet login
|
|
||||||
@endcode
|
|
||||||
Hit the return key when prompted for a password.
|
|
||||||
@code
|
|
||||||
$ cvs -z3 -d :pserver:anonymous@bespin.org:/var/lib/cvs/enet co -l .
|
|
||||||
$ cvs -z3 co enet
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
This will create a CVS directory in the current directory, and with
|
|
||||||
the second command will proceed to check the enet module out of CVS.
|
|
||||||
Any problems with CVS access or request for write access should be
|
|
||||||
sent via email to @ref MailingList.
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
@page MailingList ENet Mailing List
|
|
||||||
|
|
||||||
The <a href="http://lists.cubik.org/mailman/listinfo/enet-discuss">enet-discuss</a> list is for discussion of ENet, including bug reports or feature requests.
|
|
||||||
|
|
||||||
*/
|
|
|
@ -1,349 +0,0 @@
|
||||||
/**
|
|
||||||
@page Tutorial Tutorial
|
|
||||||
|
|
||||||
@ref Initialization
|
|
||||||
|
|
||||||
@ref CreateServer
|
|
||||||
|
|
||||||
@ref CreateClient
|
|
||||||
|
|
||||||
@ref ManageHost
|
|
||||||
|
|
||||||
@ref SendingPacket
|
|
||||||
|
|
||||||
@ref Disconnecting
|
|
||||||
|
|
||||||
@ref Connecting
|
|
||||||
|
|
||||||
@section Initialization Initialization
|
|
||||||
|
|
||||||
Before using ENet, you must call enet_initialize() to initialize the
|
|
||||||
library. Upon program exit, you should call enet_deinitialize() so
|
|
||||||
that the library may clean up any used resources.
|
|
||||||
|
|
||||||
@code
|
|
||||||
int
|
|
||||||
main (int argc, char ** argv)
|
|
||||||
{
|
|
||||||
if (enet_initialize () != 0)
|
|
||||||
{
|
|
||||||
fprintf (stderr, "An error occurred while initializing ENet.\n");
|
|
||||||
return EXIT_FAILURE;
|
|
||||||
}
|
|
||||||
atexit (enet_deinitialize);
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
}
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
@section CreateServer Creating an ENet server
|
|
||||||
|
|
||||||
Servers in ENet are constructed with enet_host_create(). You must
|
|
||||||
specify an address on which to receive data and new connections, as
|
|
||||||
well as the maximum allowable numbers of connected peers. You may
|
|
||||||
optionally specify the incoming and outgoing bandwidth of the server
|
|
||||||
in bytes per second so that ENet may try to statically manage
|
|
||||||
bandwidth resources among connected peers in addition to its dynamic
|
|
||||||
throttling algorithm; specifying 0 for these two options will cause
|
|
||||||
ENet to rely entirely upon its dynamic throttling algorithm to manage
|
|
||||||
bandwidth.
|
|
||||||
|
|
||||||
When done with a host, the host may be destroyed with
|
|
||||||
enet_host_destroy(). All connected peers to the host will be reset,
|
|
||||||
and the resources used by the host will be freed.
|
|
||||||
|
|
||||||
@code
|
|
||||||
ENetAddress address;
|
|
||||||
ENetHost * server;
|
|
||||||
|
|
||||||
/* Bind the server to the default localhost. */
|
|
||||||
/* A specific host address can be specified by */
|
|
||||||
/* enet_address_set_host (& address, "x.x.x.x"); */
|
|
||||||
|
|
||||||
address.host = ENET_HOST_ANY;
|
|
||||||
/* Bind the server to port 1234. */
|
|
||||||
address.port = 1234;
|
|
||||||
|
|
||||||
server = enet_host_create (& address /* the address to bind the server host to */,
|
|
||||||
32 /* allow up to 32 clients and/or outgoing connections */,
|
|
||||||
0 /* assume any amount of incoming bandwidth */,
|
|
||||||
0 /* assume any amount of outgoing bandwidth */);
|
|
||||||
if (server == NULL)
|
|
||||||
{
|
|
||||||
fprintf (stderr,
|
|
||||||
"An error occurred while trying to create an ENet server host.\n");
|
|
||||||
exit (EXIT_FAILURE);
|
|
||||||
}
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
enet_host_destroy(server);
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
@section CreateClient Creating an ENet client
|
|
||||||
|
|
||||||
Clients in ENet are similarly constructed with enet_host_create() when
|
|
||||||
no address is specified to bind the host to. Bandwidth may be
|
|
||||||
specified for the client host as in the above example. The peer count
|
|
||||||
controls the maximum number of connections to other server hosts that
|
|
||||||
may be simultaneously open.
|
|
||||||
|
|
||||||
@code
|
|
||||||
ENetHost * client;
|
|
||||||
|
|
||||||
client = enet_host_create (NULL /* create a client host */,
|
|
||||||
1 /* only allow 1 outgoing connection */,
|
|
||||||
57600 / 8 /* 56K modem with 56 Kbps downstream bandwidth */,
|
|
||||||
14400 / 8 /* 56K modem with 14 Kbps upstream bandwidth */);
|
|
||||||
|
|
||||||
if (client == NULL)
|
|
||||||
{
|
|
||||||
fprintf (stderr,
|
|
||||||
"An error occurred while trying to create an ENet client host.\n");
|
|
||||||
exit (EXIT_FAILURE);
|
|
||||||
}
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
enet_host_destroy(client);
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
@section ManageHost Managing an ENet host
|
|
||||||
|
|
||||||
ENet uses a polled event model to notify the programmer of significant
|
|
||||||
events. ENet hosts are polled for events with enet_host_service(),
|
|
||||||
where an optional timeout value in milliseconds may be specified to
|
|
||||||
control how long ENet will poll; if a timeout of 0 is specified,
|
|
||||||
enet_host_service() will return immediately if there are no events to
|
|
||||||
dispatch. enet_host_service() will return 1 if an event was dispatched
|
|
||||||
within the specified timeout.
|
|
||||||
|
|
||||||
Currently there are only four types of significant events in ENet:
|
|
||||||
|
|
||||||
An event of type ENET_EVENT_TYPE_NONE is returned if no event occurred
|
|
||||||
within the specified time limit. enet_host_service() will return 0
|
|
||||||
with this event.
|
|
||||||
|
|
||||||
An event of type ENET_EVENT_TYPE_CONNECT is returned when either a new client
|
|
||||||
host has connected to the server host or when an attempt to establish a
|
|
||||||
connection with a foreign host has succeeded. Only the "peer" field of the
|
|
||||||
event structure is valid for this event and contains the newly connected peer.
|
|
||||||
|
|
||||||
An event of type ENET_EVENT_TYPE_RECEIVE is returned when a packet is received
|
|
||||||
from a connected peer. The "peer" field contains the peer the packet was
|
|
||||||
received from, "channelID" is the channel on which the packet was sent, and
|
|
||||||
"packet" is the packet that was sent. The packet contained in the "packet"
|
|
||||||
field must be destroyed with enet_packet_destroy() when you are done
|
|
||||||
inspecting its contents.
|
|
||||||
|
|
||||||
An event of type ENET_EVENT_TYPE_DISCONNECT is returned when a connected peer
|
|
||||||
has either explicitly disconnected or timed out. Only the "peer" field of the
|
|
||||||
event structure is valid for this event and contains the peer that
|
|
||||||
disconnected. Only the "data" field of the peer is still valid on a
|
|
||||||
disconnect event and must be explicitly reset.
|
|
||||||
|
|
||||||
@code
|
|
||||||
ENetEvent event;
|
|
||||||
|
|
||||||
/* Wait up to 1000 milliseconds for an event. */
|
|
||||||
while (enet_host_service (client, & event, 1000) > 0)
|
|
||||||
{
|
|
||||||
switch (event.type)
|
|
||||||
{
|
|
||||||
case ENET_EVENT_TYPE_CONNECT:
|
|
||||||
printf ("A new client connected from %x:%u.\n",
|
|
||||||
event.peer -> address.host,
|
|
||||||
event.peer -> address.port);
|
|
||||||
|
|
||||||
/* Store any relevant client information here. */
|
|
||||||
event.peer -> data = "Client information";
|
|
||||||
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ENET_EVENT_TYPE_RECEIVE:
|
|
||||||
printf ("A packet of length %u containing %s was received from %s on channel %u.\n",
|
|
||||||
event.packet -> dataLength,
|
|
||||||
event.packet -> data,
|
|
||||||
event.peer -> data,
|
|
||||||
event.channelID);
|
|
||||||
|
|
||||||
/* Clean up the packet now that we're done using it. */
|
|
||||||
enet_packet_destroy (event.packet);
|
|
||||||
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ENET_EVENT_TYPE_DISCONNECT:
|
|
||||||
printf ("%s disconected.\n", event.peer -> data);
|
|
||||||
|
|
||||||
/* Reset the peer's client information. */
|
|
||||||
|
|
||||||
event.peer -> data = NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
@section SendingPacket Sending a packet to an ENet peer
|
|
||||||
|
|
||||||
Packets in ENet are created with enet_packet_create(), where the size
|
|
||||||
of the packet must be specified. Optionally, initial data may be
|
|
||||||
specified to copy into the packet.
|
|
||||||
|
|
||||||
Certain flags may also be supplied to enet_packet_create() to control
|
|
||||||
various packet features:
|
|
||||||
|
|
||||||
ENET_PACKET_FLAG_RELIABLE specifies that the packet must use reliable
|
|
||||||
delivery. A reliable packet is guarenteed to be delivered, and a
|
|
||||||
number of retry attempts will be made until an acknowledgement is
|
|
||||||
received from the foreign host the packet is sent to. If a certain
|
|
||||||
number of retry attempts is reached without any acknowledgement, ENet
|
|
||||||
will assume the peer has disconnected and forcefully reset the
|
|
||||||
connection. If this flag is not specified, the packet is assumed an
|
|
||||||
unreliable packet, and no retry attempts will be made nor
|
|
||||||
acknowledgements generated.
|
|
||||||
|
|
||||||
A packet may be resized (extended or truncated) with
|
|
||||||
enet_packet_resize().
|
|
||||||
|
|
||||||
A packet is sent to a foreign host with
|
|
||||||
enet_peer_send(). enet_peer_send() accepts a channel id over which to
|
|
||||||
send the packet to a given peer. Once the packet is handed over to
|
|
||||||
ENet with enet_peer_send(), ENet will handle its deallocation and
|
|
||||||
enet_packet_destroy() should not be used upon it.
|
|
||||||
|
|
||||||
One may also use enet_host_broadcast() to send a packet to all
|
|
||||||
connected peers on a given host over a specified channel id, as with
|
|
||||||
enet_peer_send().
|
|
||||||
|
|
||||||
Queued packets will be sent on a call to enet_host_service().
|
|
||||||
Alternatively, enet_host_flush() will send out queued packets without
|
|
||||||
dispatching any events.
|
|
||||||
|
|
||||||
@code
|
|
||||||
/* Create a reliable packet of size 7 containing "packet\0" */
|
|
||||||
ENetPacket * packet = enet_packet_create ("packet",
|
|
||||||
strlen ("packet") + 1,
|
|
||||||
ENET_PACKET_FLAG_RELIABLE);
|
|
||||||
|
|
||||||
/* Extend the packet so and append the string "foo", so it now */
|
|
||||||
/* contains "packetfoo\0" */
|
|
||||||
enet_packet_resize (packet, strlen ("packetfoo") + 1);
|
|
||||||
strcpy (& packet -> data [strlen ("packet")], "foo");
|
|
||||||
|
|
||||||
/* Send the packet to the peer over channel id 0. */
|
|
||||||
/* One could also broadcast the packet by */
|
|
||||||
/* enet_host_broadcast (host, 0, packet); */
|
|
||||||
enet_peer_send (peer, 0, packet);
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
/* One could just use enet_host_service() instead. */
|
|
||||||
enet_host_flush (host);
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
@section Disconnecting Disconnecting an ENet peer
|
|
||||||
|
|
||||||
Peers may be gently disconnected with enet_peer_disconnect(). A
|
|
||||||
disconnect request will be sent to the foreign host, and ENet will
|
|
||||||
wait for an acknowledgement from the foreign host before finally
|
|
||||||
disconnecting. An event of type ENET_EVENT_TYPE_DISCONNECT will be
|
|
||||||
generated once the disconnection succeeds. Normally timeouts apply to
|
|
||||||
the disconnect acknowledgement, and so if no acknowledgement is
|
|
||||||
received after a length of time the peer will be forcefully
|
|
||||||
disconnected.
|
|
||||||
|
|
||||||
enet_peer_reset() will forcefully disconnect a peer. The foreign host
|
|
||||||
will get no notification of a disconnect and will time out on the
|
|
||||||
foreign host. No event is generated.
|
|
||||||
|
|
||||||
@code
|
|
||||||
ENetEvent event;
|
|
||||||
|
|
||||||
enet_peer_disconnect (peer, 0);
|
|
||||||
|
|
||||||
/* Allow up to 3 seconds for the disconnect to succeed
|
|
||||||
* and drop any packets received packets.
|
|
||||||
*/
|
|
||||||
while (enet_host_service (client, & event, 3000) > 0)
|
|
||||||
{
|
|
||||||
switch (event.type)
|
|
||||||
{
|
|
||||||
case ENET_EVENT_TYPE_RECEIVE:
|
|
||||||
enet_packet_destroy (event.packet);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ENET_EVENT_TYPE_DISCONNECT:
|
|
||||||
puts ("Disconnection succeeded.");
|
|
||||||
return;
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* We've arrived here, so the disconnect attempt didn't */
|
|
||||||
/* succeed yet. Force the connection down. */
|
|
||||||
enet_peer_reset (peer);
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
@endcode
|
|
||||||
|
|
||||||
@section Connecting Connecting to an ENet host
|
|
||||||
|
|
||||||
A connection to a foreign host is initiated with enet_host_connect().
|
|
||||||
It accepts the address of a foreign host to connect to, and the number
|
|
||||||
of channels that should be allocated for communication. If N channels
|
|
||||||
are allocated for use, their channel ids will be numbered 0 through
|
|
||||||
N-1. A peer representing the connection attempt is returned, or NULL
|
|
||||||
if there were no available peers over which to initiate the
|
|
||||||
connection. When the connection attempt succeeds, an event of type
|
|
||||||
ENET_EVENT_TYPE_CONNECT will be generated. If the connection attempt
|
|
||||||
times out or otherwise fails, an event of type
|
|
||||||
ENET_EVENT_TYPE_DISCONNECT will be generated.
|
|
||||||
|
|
||||||
@code
|
|
||||||
ENetAddress address;
|
|
||||||
ENetEvent event;
|
|
||||||
ENetPeer *peer;
|
|
||||||
|
|
||||||
/* Connect to some.server.net:1234. */
|
|
||||||
enet_address_set_host (& address, "some.server.net");
|
|
||||||
address.port = 1234;
|
|
||||||
|
|
||||||
/* Initiate the connection, allocating the two channels 0 and 1. */
|
|
||||||
peer = enet_host_connect (client, & address, 2);
|
|
||||||
|
|
||||||
if (peer == NULL)
|
|
||||||
{
|
|
||||||
fprintf (stderr,
|
|
||||||
"No available peers for initiating an ENet connection.\n");
|
|
||||||
exit (EXIT_FAILURE);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Wait up to 5 seconds for the connection attempt to succeed. */
|
|
||||||
if (enet_host_service (client, & event, 5000) > 0 &&
|
|
||||||
event.type == ENET_EVENT_TYPE_CONNECT)
|
|
||||||
{
|
|
||||||
puts ("Connection to some.server.net:1234 succeeded.");
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Either the 5 seconds are up or a disconnect event was */
|
|
||||||
/* received. Reset the peer in the event the 5 seconds */
|
|
||||||
/* had run out without any significant event. */
|
|
||||||
enet_peer_reset (peer);
|
|
||||||
|
|
||||||
puts ("Connection to some.server.net:1234 failed.");
|
|
||||||
}
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
@endcode
|
|
||||||
*/
|
|
|
@ -1,164 +0,0 @@
|
||||||
# Microsoft Developer Studio Project File - Name="enet" - Package Owner=<4>
|
|
||||||
# Microsoft Developer Studio Generated Build File, Format Version 6.00
|
|
||||||
# ** DO NOT EDIT **
|
|
||||||
|
|
||||||
# TARGTYPE "Win32 (x86) Static Library" 0x0104
|
|
||||||
|
|
||||||
CFG=enet - Win32 Debug
|
|
||||||
!MESSAGE This is not a valid makefile. To build this project using NMAKE,
|
|
||||||
!MESSAGE use the Export Makefile command and run
|
|
||||||
!MESSAGE
|
|
||||||
!MESSAGE NMAKE /f "enet.mak".
|
|
||||||
!MESSAGE
|
|
||||||
!MESSAGE You can specify a configuration when running NMAKE
|
|
||||||
!MESSAGE by defining the macro CFG on the command line. For example:
|
|
||||||
!MESSAGE
|
|
||||||
!MESSAGE NMAKE /f "enet.mak" CFG="enet - Win32 Debug"
|
|
||||||
!MESSAGE
|
|
||||||
!MESSAGE Possible choices for configuration are:
|
|
||||||
!MESSAGE
|
|
||||||
!MESSAGE "enet - Win32 Release" (based on "Win32 (x86) Static Library")
|
|
||||||
!MESSAGE "enet - Win32 Debug" (based on "Win32 (x86) Static Library")
|
|
||||||
!MESSAGE
|
|
||||||
|
|
||||||
# Begin Project
|
|
||||||
# PROP AllowPerConfigDependencies 0
|
|
||||||
# PROP Scc_ProjName ""
|
|
||||||
# PROP Scc_LocalPath ""
|
|
||||||
CPP=cl.exe
|
|
||||||
RSC=rc.exe
|
|
||||||
|
|
||||||
!IF "$(CFG)" == "enet - Win32 Release"
|
|
||||||
|
|
||||||
# PROP BASE Use_MFC 0
|
|
||||||
# PROP BASE Use_Debug_Libraries 0
|
|
||||||
# PROP BASE Output_Dir "Release"
|
|
||||||
# PROP BASE Intermediate_Dir "Release"
|
|
||||||
# PROP BASE Target_Dir ""
|
|
||||||
# PROP Use_MFC 0
|
|
||||||
# PROP Use_Debug_Libraries 0
|
|
||||||
# PROP Output_Dir "Release"
|
|
||||||
# PROP Intermediate_Dir "Release"
|
|
||||||
# PROP Target_Dir ""
|
|
||||||
MTL=midl.exe
|
|
||||||
# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /YX /FD /c
|
|
||||||
# ADD CPP /nologo /W3 /O2 /I "include" /D "WIN32" /D "NDEBUG" /D "_MBCS" /D "_LIB" /FD /c
|
|
||||||
# SUBTRACT CPP /YX
|
|
||||||
# ADD BASE RSC /l 0x409 /d "NDEBUG"
|
|
||||||
# ADD RSC /l 0x409 /d "NDEBUG"
|
|
||||||
BSC32=bscmake.exe
|
|
||||||
# ADD BASE BSC32 /nologo
|
|
||||||
# ADD BSC32 /nologo
|
|
||||||
LIB32=link.exe -lib
|
|
||||||
# ADD BASE LIB32 /nologo
|
|
||||||
# ADD LIB32 /nologo
|
|
||||||
|
|
||||||
!ELSEIF "$(CFG)" == "enet - Win32 Debug"
|
|
||||||
|
|
||||||
# PROP BASE Use_MFC 0
|
|
||||||
# PROP BASE Use_Debug_Libraries 1
|
|
||||||
# PROP BASE Output_Dir "Debug"
|
|
||||||
# PROP BASE Intermediate_Dir "Debug"
|
|
||||||
# PROP BASE Target_Dir ""
|
|
||||||
# PROP Use_MFC 0
|
|
||||||
# PROP Use_Debug_Libraries 1
|
|
||||||
# PROP Output_Dir "Debug"
|
|
||||||
# PROP Intermediate_Dir "Debug"
|
|
||||||
# PROP Target_Dir ""
|
|
||||||
MTL=midl.exe
|
|
||||||
# ADD BASE CPP /nologo /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /YX /FD /GZ /c
|
|
||||||
# ADD CPP /nologo /G6 /MTd /W3 /ZI /Od /I "include" /D "WIN32" /D "_DEBUG" /D "_MBCS" /D "_LIB" /FR /FD /GZ /c
|
|
||||||
# SUBTRACT CPP /YX
|
|
||||||
# ADD BASE RSC /l 0x409 /d "_DEBUG"
|
|
||||||
# ADD RSC /l 0x409 /d "_DEBUG"
|
|
||||||
BSC32=bscmake.exe
|
|
||||||
# ADD BASE BSC32 /nologo
|
|
||||||
# ADD BSC32 /nologo
|
|
||||||
LIB32=link.exe -lib
|
|
||||||
# ADD BASE LIB32 /nologo
|
|
||||||
# ADD LIB32 /nologo
|
|
||||||
|
|
||||||
!ENDIF
|
|
||||||
|
|
||||||
# Begin Target
|
|
||||||
|
|
||||||
# Name "enet - Win32 Release"
|
|
||||||
# Name "enet - Win32 Debug"
|
|
||||||
# Begin Group "Source Files"
|
|
||||||
|
|
||||||
# PROP Default_Filter "cpp;c;cxx;rc;def;r;odl;idl;hpj;bat"
|
|
||||||
# Begin Source File
|
|
||||||
|
|
||||||
SOURCE=.\host.c
|
|
||||||
# End Source File
|
|
||||||
# Begin Source File
|
|
||||||
|
|
||||||
SOURCE=.\list.c
|
|
||||||
# End Source File
|
|
||||||
# Begin Source File
|
|
||||||
|
|
||||||
SOURCE=.\callbacks.c
|
|
||||||
# End Source File
|
|
||||||
# Begin Source File
|
|
||||||
|
|
||||||
SOURCE=.\packet.c
|
|
||||||
# End Source File
|
|
||||||
# Begin Source File
|
|
||||||
|
|
||||||
SOURCE=.\peer.c
|
|
||||||
# End Source File
|
|
||||||
# Begin Source File
|
|
||||||
|
|
||||||
SOURCE=.\protocol.c
|
|
||||||
# End Source File
|
|
||||||
# Begin Source File
|
|
||||||
|
|
||||||
SOURCE=.\unix.c
|
|
||||||
# End Source File
|
|
||||||
# Begin Source File
|
|
||||||
|
|
||||||
SOURCE=.\win32.c
|
|
||||||
# End Source File
|
|
||||||
# End Group
|
|
||||||
# Begin Group "Header Files"
|
|
||||||
|
|
||||||
# PROP Default_Filter "h;hpp;hxx;hm;inl"
|
|
||||||
# Begin Source File
|
|
||||||
|
|
||||||
SOURCE=.\include\enet\enet.h
|
|
||||||
# End Source File
|
|
||||||
# Begin Source File
|
|
||||||
|
|
||||||
SOURCE=.\include\enet\list.h
|
|
||||||
# End Source File
|
|
||||||
# Begin Source File
|
|
||||||
|
|
||||||
SOURCE=.\include\enet\callbacks.h
|
|
||||||
# End Source File
|
|
||||||
# Begin Source File
|
|
||||||
|
|
||||||
SOURCE=.\include\enet\protocol.h
|
|
||||||
# End Source File
|
|
||||||
# Begin Source File
|
|
||||||
|
|
||||||
SOURCE=.\include\enet\time.h
|
|
||||||
# End Source File
|
|
||||||
# Begin Source File
|
|
||||||
|
|
||||||
SOURCE=.\include\enet\types.h
|
|
||||||
# End Source File
|
|
||||||
# Begin Source File
|
|
||||||
|
|
||||||
SOURCE=.\include\enet\unix.h
|
|
||||||
# End Source File
|
|
||||||
# Begin Source File
|
|
||||||
|
|
||||||
SOURCE=.\include\enet\utility.h
|
|
||||||
# End Source File
|
|
||||||
# Begin Source File
|
|
||||||
|
|
||||||
SOURCE=.\include\enet\win32.h
|
|
||||||
# End Source File
|
|
||||||
# End Group
|
|
||||||
# End Target
|
|
||||||
# End Project
|
|
|
@ -1,398 +0,0 @@
|
||||||
/**
|
|
||||||
@file host.c
|
|
||||||
@brief ENet host management functions
|
|
||||||
*/
|
|
||||||
#define ENET_BUILDING_LIB 1
|
|
||||||
#include <string.h>
|
|
||||||
#include "enet/enet.h"
|
|
||||||
|
|
||||||
/** @defgroup host ENet host functions
|
|
||||||
@{
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** Creates a host for communicating to peers.
|
|
||||||
|
|
||||||
@param address the address at which other peers may connect to this host. If NULL, then no peers may connect to the host.
|
|
||||||
@param peerCount the maximum number of peers that should be allocated for the host.
|
|
||||||
@param incomingBandwidth downstream bandwidth of the host in bytes/second; if 0, ENet will assume unlimited bandwidth.
|
|
||||||
@param outgoingBandwidth upstream bandwidth of the host in bytes/second; if 0, ENet will assume unlimited bandwidth.
|
|
||||||
|
|
||||||
@returns the host on success and NULL on failure
|
|
||||||
|
|
||||||
@remarks ENet will strategically drop packets on specific sides of a connection between hosts
|
|
||||||
to ensure the host's bandwidth is not overwhelmed. The bandwidth parameters also determine
|
|
||||||
the window size of a connection which limits the amount of reliable packets that may be in transit
|
|
||||||
at any given time.
|
|
||||||
*/
|
|
||||||
ENetHost *
|
|
||||||
enet_host_create (const ENetAddress * address, size_t peerCount, enet_uint32 incomingBandwidth, enet_uint32 outgoingBandwidth)
|
|
||||||
{
|
|
||||||
ENetHost * host = (ENetHost *) enet_malloc (sizeof (ENetHost));
|
|
||||||
ENetPeer * currentPeer;
|
|
||||||
|
|
||||||
if (peerCount > ENET_PROTOCOL_MAXIMUM_PEER_ID)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
host -> peers = (ENetPeer *) enet_malloc (peerCount * sizeof (ENetPeer));
|
|
||||||
memset (host -> peers, 0, peerCount * sizeof (ENetPeer));
|
|
||||||
|
|
||||||
host -> socket = enet_socket_create (ENET_SOCKET_TYPE_DATAGRAM, address);
|
|
||||||
if (host -> socket == ENET_SOCKET_NULL)
|
|
||||||
{
|
|
||||||
enet_free (host -> peers);
|
|
||||||
enet_free (host);
|
|
||||||
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
enet_socket_set_option (host -> socket, ENET_SOCKOPT_NONBLOCK, 1);
|
|
||||||
enet_socket_set_option (host -> socket, ENET_SOCKOPT_BROADCAST, 1);
|
|
||||||
enet_socket_set_option (host -> socket, ENET_SOCKOPT_RCVBUF, ENET_HOST_RECEIVE_BUFFER_SIZE);
|
|
||||||
enet_socket_set_option (host -> socket, ENET_SOCKOPT_SNDBUF, ENET_HOST_SEND_BUFFER_SIZE);
|
|
||||||
|
|
||||||
if (address != NULL)
|
|
||||||
host -> address = * address;
|
|
||||||
|
|
||||||
host -> incomingBandwidth = incomingBandwidth;
|
|
||||||
host -> outgoingBandwidth = outgoingBandwidth;
|
|
||||||
host -> bandwidthThrottleEpoch = 0;
|
|
||||||
host -> recalculateBandwidthLimits = 0;
|
|
||||||
host -> mtu = ENET_HOST_DEFAULT_MTU;
|
|
||||||
host -> peerCount = peerCount;
|
|
||||||
host -> lastServicedPeer = host -> peers;
|
|
||||||
host -> commandCount = 0;
|
|
||||||
host -> bufferCount = 0;
|
|
||||||
host -> receivedAddress.host = ENET_HOST_ANY;
|
|
||||||
host -> receivedAddress.port = 0;
|
|
||||||
host -> receivedDataLength = 0;
|
|
||||||
|
|
||||||
for (currentPeer = host -> peers;
|
|
||||||
currentPeer < & host -> peers [host -> peerCount];
|
|
||||||
++ currentPeer)
|
|
||||||
{
|
|
||||||
currentPeer -> host = host;
|
|
||||||
currentPeer -> incomingPeerID = currentPeer - host -> peers;
|
|
||||||
currentPeer -> data = NULL;
|
|
||||||
|
|
||||||
enet_list_clear (& currentPeer -> acknowledgements);
|
|
||||||
enet_list_clear (& currentPeer -> sentReliableCommands);
|
|
||||||
enet_list_clear (& currentPeer -> sentUnreliableCommands);
|
|
||||||
enet_list_clear (& currentPeer -> outgoingReliableCommands);
|
|
||||||
enet_list_clear (& currentPeer -> outgoingUnreliableCommands);
|
|
||||||
|
|
||||||
enet_peer_reset (currentPeer);
|
|
||||||
}
|
|
||||||
|
|
||||||
return host;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Destroys the host and all resources associated with it.
|
|
||||||
@param host pointer to the host to destroy
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
enet_host_destroy (ENetHost * host)
|
|
||||||
{
|
|
||||||
ENetPeer * currentPeer;
|
|
||||||
|
|
||||||
enet_socket_destroy (host -> socket);
|
|
||||||
|
|
||||||
for (currentPeer = host -> peers;
|
|
||||||
currentPeer < & host -> peers [host -> peerCount];
|
|
||||||
++ currentPeer)
|
|
||||||
{
|
|
||||||
enet_peer_reset (currentPeer);
|
|
||||||
}
|
|
||||||
|
|
||||||
enet_free (host -> peers);
|
|
||||||
enet_free (host);
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Initiates a connection to a foreign host.
|
|
||||||
@param host host seeking the connection
|
|
||||||
@param address destination for the connection
|
|
||||||
@param channelCount number of channels to allocate
|
|
||||||
@returns a peer representing the foreign host on success, NULL on failure
|
|
||||||
@remarks The peer returned will have not completed the connection until enet_host_service()
|
|
||||||
notifies of an ENET_EVENT_TYPE_CONNECT event for the peer.
|
|
||||||
*/
|
|
||||||
ENetPeer *
|
|
||||||
enet_host_connect (ENetHost * host, const ENetAddress * address, size_t channelCount)
|
|
||||||
{
|
|
||||||
ENetPeer * currentPeer;
|
|
||||||
ENetChannel * channel;
|
|
||||||
ENetProtocol command;
|
|
||||||
|
|
||||||
if (channelCount < ENET_PROTOCOL_MINIMUM_CHANNEL_COUNT)
|
|
||||||
channelCount = ENET_PROTOCOL_MINIMUM_CHANNEL_COUNT;
|
|
||||||
else
|
|
||||||
if (channelCount > ENET_PROTOCOL_MAXIMUM_CHANNEL_COUNT)
|
|
||||||
channelCount = ENET_PROTOCOL_MAXIMUM_CHANNEL_COUNT;
|
|
||||||
|
|
||||||
for (currentPeer = host -> peers;
|
|
||||||
currentPeer < & host -> peers [host -> peerCount];
|
|
||||||
++ currentPeer)
|
|
||||||
{
|
|
||||||
if (currentPeer -> state == ENET_PEER_STATE_DISCONNECTED)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (currentPeer >= & host -> peers [host -> peerCount])
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
currentPeer -> state = ENET_PEER_STATE_CONNECTING;
|
|
||||||
currentPeer -> address = * address;
|
|
||||||
currentPeer -> channels = (ENetChannel *) enet_malloc (channelCount * sizeof (ENetChannel));
|
|
||||||
currentPeer -> channelCount = channelCount;
|
|
||||||
currentPeer -> sessionID = (enet_uint32) enet_rand ();
|
|
||||||
|
|
||||||
if (host -> outgoingBandwidth == 0)
|
|
||||||
currentPeer -> windowSize = ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE;
|
|
||||||
else
|
|
||||||
currentPeer -> windowSize = (host -> outgoingBandwidth /
|
|
||||||
ENET_PEER_WINDOW_SIZE_SCALE) *
|
|
||||||
ENET_PROTOCOL_MINIMUM_WINDOW_SIZE;
|
|
||||||
|
|
||||||
if (currentPeer -> windowSize < ENET_PROTOCOL_MINIMUM_WINDOW_SIZE)
|
|
||||||
currentPeer -> windowSize = ENET_PROTOCOL_MINIMUM_WINDOW_SIZE;
|
|
||||||
else
|
|
||||||
if (currentPeer -> windowSize > ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE)
|
|
||||||
currentPeer -> windowSize = ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE;
|
|
||||||
|
|
||||||
for (channel = currentPeer -> channels;
|
|
||||||
channel < & currentPeer -> channels [channelCount];
|
|
||||||
++ channel)
|
|
||||||
{
|
|
||||||
channel -> outgoingReliableSequenceNumber = 0;
|
|
||||||
channel -> outgoingUnreliableSequenceNumber = 0;
|
|
||||||
channel -> incomingReliableSequenceNumber = 0;
|
|
||||||
|
|
||||||
enet_list_clear (& channel -> incomingReliableCommands);
|
|
||||||
enet_list_clear (& channel -> incomingUnreliableCommands);
|
|
||||||
|
|
||||||
channel -> usedReliableWindows = 0;
|
|
||||||
memset (channel -> reliableWindows, 0, sizeof (channel -> reliableWindows));
|
|
||||||
}
|
|
||||||
|
|
||||||
command.header.command = ENET_PROTOCOL_COMMAND_CONNECT | ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE;
|
|
||||||
command.header.channelID = 0xFF;
|
|
||||||
command.connect.outgoingPeerID = ENET_HOST_TO_NET_16 (currentPeer -> incomingPeerID);
|
|
||||||
command.connect.mtu = ENET_HOST_TO_NET_16 (currentPeer -> mtu);
|
|
||||||
command.connect.windowSize = ENET_HOST_TO_NET_32 (currentPeer -> windowSize);
|
|
||||||
command.connect.channelCount = ENET_HOST_TO_NET_32 (channelCount);
|
|
||||||
command.connect.incomingBandwidth = ENET_HOST_TO_NET_32 (host -> incomingBandwidth);
|
|
||||||
command.connect.outgoingBandwidth = ENET_HOST_TO_NET_32 (host -> outgoingBandwidth);
|
|
||||||
command.connect.packetThrottleInterval = ENET_HOST_TO_NET_32 (currentPeer -> packetThrottleInterval);
|
|
||||||
command.connect.packetThrottleAcceleration = ENET_HOST_TO_NET_32 (currentPeer -> packetThrottleAcceleration);
|
|
||||||
command.connect.packetThrottleDeceleration = ENET_HOST_TO_NET_32 (currentPeer -> packetThrottleDeceleration);
|
|
||||||
command.connect.sessionID = currentPeer -> sessionID;
|
|
||||||
|
|
||||||
enet_peer_queue_outgoing_command (currentPeer, & command, NULL, 0, 0);
|
|
||||||
|
|
||||||
return currentPeer;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Queues a packet to be sent to all peers associated with the host.
|
|
||||||
@param host host on which to broadcast the packet
|
|
||||||
@param channelID channel on which to broadcast
|
|
||||||
@param packet packet to broadcast
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
enet_host_broadcast (ENetHost * host, enet_uint8 channelID, ENetPacket * packet)
|
|
||||||
{
|
|
||||||
ENetPeer * currentPeer;
|
|
||||||
|
|
||||||
for (currentPeer = host -> peers;
|
|
||||||
currentPeer < & host -> peers [host -> peerCount];
|
|
||||||
++ currentPeer)
|
|
||||||
{
|
|
||||||
if (currentPeer -> state != ENET_PEER_STATE_CONNECTED)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
enet_peer_send (currentPeer, channelID, packet);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (packet -> referenceCount == 0)
|
|
||||||
enet_packet_destroy (packet);
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Adjusts the bandwidth limits of a host.
|
|
||||||
@param host host to adjust
|
|
||||||
@param incomingBandwidth new incoming bandwidth
|
|
||||||
@param outgoingBandwidth new outgoing bandwidth
|
|
||||||
@remarks the incoming and outgoing bandwidth parameters are identical in function to those
|
|
||||||
specified in enet_host_create().
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
enet_host_bandwidth_limit (ENetHost * host, enet_uint32 incomingBandwidth, enet_uint32 outgoingBandwidth)
|
|
||||||
{
|
|
||||||
host -> incomingBandwidth = incomingBandwidth;
|
|
||||||
host -> outgoingBandwidth = outgoingBandwidth;
|
|
||||||
host -> recalculateBandwidthLimits = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
enet_host_bandwidth_throttle (ENetHost * host)
|
|
||||||
{
|
|
||||||
enet_uint32 timeCurrent = enet_time_get (),
|
|
||||||
elapsedTime = timeCurrent - host -> bandwidthThrottleEpoch,
|
|
||||||
peersTotal = 0,
|
|
||||||
dataTotal = 0,
|
|
||||||
peersRemaining,
|
|
||||||
bandwidth,
|
|
||||||
throttle = 0,
|
|
||||||
bandwidthLimit = 0;
|
|
||||||
int needsAdjustment;
|
|
||||||
ENetPeer * peer;
|
|
||||||
ENetProtocol command;
|
|
||||||
|
|
||||||
if (elapsedTime < ENET_HOST_BANDWIDTH_THROTTLE_INTERVAL)
|
|
||||||
return;
|
|
||||||
|
|
||||||
for (peer = host -> peers;
|
|
||||||
peer < & host -> peers [host -> peerCount];
|
|
||||||
++ peer)
|
|
||||||
{
|
|
||||||
if (peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
++ peersTotal;
|
|
||||||
dataTotal += peer -> outgoingDataTotal;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (peersTotal == 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
peersRemaining = peersTotal;
|
|
||||||
needsAdjustment = 1;
|
|
||||||
|
|
||||||
if (host -> outgoingBandwidth == 0)
|
|
||||||
bandwidth = ~0;
|
|
||||||
else
|
|
||||||
bandwidth = (host -> outgoingBandwidth * elapsedTime) / 1000;
|
|
||||||
|
|
||||||
while (peersRemaining > 0 && needsAdjustment != 0)
|
|
||||||
{
|
|
||||||
needsAdjustment = 0;
|
|
||||||
|
|
||||||
if (dataTotal < bandwidth)
|
|
||||||
throttle = ENET_PEER_PACKET_THROTTLE_SCALE;
|
|
||||||
else
|
|
||||||
throttle = (bandwidth * ENET_PEER_PACKET_THROTTLE_SCALE) / dataTotal;
|
|
||||||
|
|
||||||
for (peer = host -> peers;
|
|
||||||
peer < & host -> peers [host -> peerCount];
|
|
||||||
++ peer)
|
|
||||||
{
|
|
||||||
enet_uint32 peerBandwidth;
|
|
||||||
|
|
||||||
if ((peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER) ||
|
|
||||||
peer -> incomingBandwidth == 0 ||
|
|
||||||
peer -> outgoingBandwidthThrottleEpoch == timeCurrent)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
peerBandwidth = (peer -> incomingBandwidth * elapsedTime) / 1000;
|
|
||||||
if ((throttle * peer -> outgoingDataTotal) / ENET_PEER_PACKET_THROTTLE_SCALE <= peerBandwidth)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
peer -> packetThrottleLimit = (peerBandwidth *
|
|
||||||
ENET_PEER_PACKET_THROTTLE_SCALE) / peer -> outgoingDataTotal;
|
|
||||||
|
|
||||||
if (peer -> packetThrottleLimit == 0)
|
|
||||||
peer -> packetThrottleLimit = 1;
|
|
||||||
|
|
||||||
if (peer -> packetThrottle > peer -> packetThrottleLimit)
|
|
||||||
peer -> packetThrottle = peer -> packetThrottleLimit;
|
|
||||||
|
|
||||||
peer -> outgoingBandwidthThrottleEpoch = timeCurrent;
|
|
||||||
|
|
||||||
|
|
||||||
needsAdjustment = 1;
|
|
||||||
-- peersRemaining;
|
|
||||||
bandwidth -= peerBandwidth;
|
|
||||||
dataTotal -= peerBandwidth;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (peersRemaining > 0)
|
|
||||||
for (peer = host -> peers;
|
|
||||||
peer < & host -> peers [host -> peerCount];
|
|
||||||
++ peer)
|
|
||||||
{
|
|
||||||
if ((peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER) ||
|
|
||||||
peer -> outgoingBandwidthThrottleEpoch == timeCurrent)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
peer -> packetThrottleLimit = throttle;
|
|
||||||
|
|
||||||
if (peer -> packetThrottle > peer -> packetThrottleLimit)
|
|
||||||
peer -> packetThrottle = peer -> packetThrottleLimit;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (host -> recalculateBandwidthLimits)
|
|
||||||
{
|
|
||||||
host -> recalculateBandwidthLimits = 0;
|
|
||||||
|
|
||||||
peersRemaining = peersTotal;
|
|
||||||
bandwidth = host -> incomingBandwidth;
|
|
||||||
needsAdjustment = 1;
|
|
||||||
|
|
||||||
if (bandwidth == 0)
|
|
||||||
bandwidthLimit = 0;
|
|
||||||
else
|
|
||||||
while (peersRemaining > 0 && needsAdjustment != 0)
|
|
||||||
{
|
|
||||||
needsAdjustment = 0;
|
|
||||||
bandwidthLimit = bandwidth / peersRemaining;
|
|
||||||
|
|
||||||
for (peer = host -> peers;
|
|
||||||
peer < & host -> peers [host -> peerCount];
|
|
||||||
++ peer)
|
|
||||||
{
|
|
||||||
if ((peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER) ||
|
|
||||||
peer -> incomingBandwidthThrottleEpoch == timeCurrent)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (peer -> outgoingBandwidth > 0 &&
|
|
||||||
peer -> outgoingBandwidth >= bandwidthLimit)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
peer -> incomingBandwidthThrottleEpoch = timeCurrent;
|
|
||||||
|
|
||||||
needsAdjustment = 1;
|
|
||||||
-- peersRemaining;
|
|
||||||
bandwidth -= peer -> outgoingBandwidth;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for (peer = host -> peers;
|
|
||||||
peer < & host -> peers [host -> peerCount];
|
|
||||||
++ peer)
|
|
||||||
{
|
|
||||||
if (peer -> state != ENET_PEER_STATE_CONNECTED && peer -> state != ENET_PEER_STATE_DISCONNECT_LATER)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
command.header.command = ENET_PROTOCOL_COMMAND_BANDWIDTH_LIMIT | ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE;
|
|
||||||
command.header.channelID = 0xFF;
|
|
||||||
command.bandwidthLimit.outgoingBandwidth = ENET_HOST_TO_NET_32 (host -> outgoingBandwidth);
|
|
||||||
|
|
||||||
if (peer -> incomingBandwidthThrottleEpoch == timeCurrent)
|
|
||||||
command.bandwidthLimit.incomingBandwidth = ENET_HOST_TO_NET_32 (peer -> outgoingBandwidth);
|
|
||||||
else
|
|
||||||
command.bandwidthLimit.incomingBandwidth = ENET_HOST_TO_NET_32 (bandwidthLimit);
|
|
||||||
|
|
||||||
enet_peer_queue_outgoing_command (peer, & command, NULL, 0, 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
host -> bandwidthThrottleEpoch = timeCurrent;
|
|
||||||
|
|
||||||
for (peer = host -> peers;
|
|
||||||
peer < & host -> peers [host -> peerCount];
|
|
||||||
++ peer)
|
|
||||||
{
|
|
||||||
peer -> incomingDataTotal = 0;
|
|
||||||
peer -> outgoingDataTotal = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/** @} */
|
|
|
@ -1,2 +0,0 @@
|
||||||
/Makefile.am/1.1.1.1/Wed Oct 20 17:17:52 2004//
|
|
||||||
D/enet////
|
|
|
@ -1 +0,0 @@
|
||||||
enet/include
|
|
|
@ -1 +0,0 @@
|
||||||
:pserver:anonymous@bespin.org:/var/lib/cvs/enet
|
|
|
@ -1 +0,0 @@
|
||||||
SUBDIRS = enet
|
|
|
@ -1,435 +0,0 @@
|
||||||
# Makefile.in generated by automake 1.9.6 from Makefile.am.
|
|
||||||
# @configure_input@
|
|
||||||
|
|
||||||
# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
|
|
||||||
# 2003, 2004, 2005 Free Software Foundation, Inc.
|
|
||||||
# This Makefile.in is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
|
|
||||||
# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
|
||||||
# PARTICULAR PURPOSE.
|
|
||||||
|
|
||||||
@SET_MAKE@
|
|
||||||
srcdir = @srcdir@
|
|
||||||
top_srcdir = @top_srcdir@
|
|
||||||
VPATH = @srcdir@
|
|
||||||
pkgdatadir = $(datadir)/@PACKAGE@
|
|
||||||
pkglibdir = $(libdir)/@PACKAGE@
|
|
||||||
pkgincludedir = $(includedir)/@PACKAGE@
|
|
||||||
top_builddir = ..
|
|
||||||
am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
|
|
||||||
INSTALL = @INSTALL@
|
|
||||||
install_sh_DATA = $(install_sh) -c -m 644
|
|
||||||
install_sh_PROGRAM = $(install_sh) -c
|
|
||||||
install_sh_SCRIPT = $(install_sh) -c
|
|
||||||
INSTALL_HEADER = $(INSTALL_DATA)
|
|
||||||
transform = $(program_transform_name)
|
|
||||||
NORMAL_INSTALL = :
|
|
||||||
PRE_INSTALL = :
|
|
||||||
POST_INSTALL = :
|
|
||||||
NORMAL_UNINSTALL = :
|
|
||||||
PRE_UNINSTALL = :
|
|
||||||
POST_UNINSTALL = :
|
|
||||||
subdir = include
|
|
||||||
DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in
|
|
||||||
ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
|
|
||||||
am__aclocal_m4_deps = $(top_srcdir)/configure.in
|
|
||||||
am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
|
|
||||||
$(ACLOCAL_M4)
|
|
||||||
mkinstalldirs = $(install_sh) -d
|
|
||||||
CONFIG_CLEAN_FILES =
|
|
||||||
SOURCES =
|
|
||||||
DIST_SOURCES =
|
|
||||||
RECURSIVE_TARGETS = all-recursive check-recursive dvi-recursive \
|
|
||||||
html-recursive info-recursive install-data-recursive \
|
|
||||||
install-exec-recursive install-info-recursive \
|
|
||||||
install-recursive installcheck-recursive installdirs-recursive \
|
|
||||||
pdf-recursive ps-recursive uninstall-info-recursive \
|
|
||||||
uninstall-recursive
|
|
||||||
ETAGS = etags
|
|
||||||
CTAGS = ctags
|
|
||||||
DIST_SUBDIRS = $(SUBDIRS)
|
|
||||||
DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
|
|
||||||
ACLOCAL = @ACLOCAL@
|
|
||||||
AMDEP_FALSE = @AMDEP_FALSE@
|
|
||||||
AMDEP_TRUE = @AMDEP_TRUE@
|
|
||||||
AMTAR = @AMTAR@
|
|
||||||
AUTOCONF = @AUTOCONF@
|
|
||||||
AUTOHEADER = @AUTOHEADER@
|
|
||||||
AUTOMAKE = @AUTOMAKE@
|
|
||||||
AWK = @AWK@
|
|
||||||
CC = @CC@
|
|
||||||
CCDEPMODE = @CCDEPMODE@
|
|
||||||
CFLAGS = @CFLAGS@
|
|
||||||
CPP = @CPP@
|
|
||||||
CPPFLAGS = @CPPFLAGS@
|
|
||||||
CYGPATH_W = @CYGPATH_W@
|
|
||||||
DEFS = @DEFS@
|
|
||||||
DEPDIR = @DEPDIR@
|
|
||||||
ECHO_C = @ECHO_C@
|
|
||||||
ECHO_N = @ECHO_N@
|
|
||||||
ECHO_T = @ECHO_T@
|
|
||||||
EGREP = @EGREP@
|
|
||||||
EXEEXT = @EXEEXT@
|
|
||||||
GREP = @GREP@
|
|
||||||
INSTALL_DATA = @INSTALL_DATA@
|
|
||||||
INSTALL_PROGRAM = @INSTALL_PROGRAM@
|
|
||||||
INSTALL_SCRIPT = @INSTALL_SCRIPT@
|
|
||||||
INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
|
|
||||||
LDFLAGS = @LDFLAGS@
|
|
||||||
LIBOBJS = @LIBOBJS@
|
|
||||||
LIBS = @LIBS@
|
|
||||||
LTLIBOBJS = @LTLIBOBJS@
|
|
||||||
MAKEINFO = @MAKEINFO@
|
|
||||||
OBJEXT = @OBJEXT@
|
|
||||||
PACKAGE = @PACKAGE@
|
|
||||||
PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
|
|
||||||
PACKAGE_NAME = @PACKAGE_NAME@
|
|
||||||
PACKAGE_STRING = @PACKAGE_STRING@
|
|
||||||
PACKAGE_TARNAME = @PACKAGE_TARNAME@
|
|
||||||
PACKAGE_VERSION = @PACKAGE_VERSION@
|
|
||||||
PATH_SEPARATOR = @PATH_SEPARATOR@
|
|
||||||
RANLIB = @RANLIB@
|
|
||||||
SET_MAKE = @SET_MAKE@
|
|
||||||
SHELL = @SHELL@
|
|
||||||
STRIP = @STRIP@
|
|
||||||
VERSION = @VERSION@
|
|
||||||
ac_ct_CC = @ac_ct_CC@
|
|
||||||
am__fastdepCC_FALSE = @am__fastdepCC_FALSE@
|
|
||||||
am__fastdepCC_TRUE = @am__fastdepCC_TRUE@
|
|
||||||
am__include = @am__include@
|
|
||||||
am__leading_dot = @am__leading_dot@
|
|
||||||
am__quote = @am__quote@
|
|
||||||
am__tar = @am__tar@
|
|
||||||
am__untar = @am__untar@
|
|
||||||
bindir = @bindir@
|
|
||||||
build_alias = @build_alias@
|
|
||||||
datadir = @datadir@
|
|
||||||
datarootdir = @datarootdir@
|
|
||||||
docdir = @docdir@
|
|
||||||
dvidir = @dvidir@
|
|
||||||
exec_prefix = @exec_prefix@
|
|
||||||
host_alias = @host_alias@
|
|
||||||
htmldir = @htmldir@
|
|
||||||
includedir = @includedir@
|
|
||||||
infodir = @infodir@
|
|
||||||
install_sh = @install_sh@
|
|
||||||
libdir = @libdir@
|
|
||||||
libexecdir = @libexecdir@
|
|
||||||
localedir = @localedir@
|
|
||||||
localstatedir = @localstatedir@
|
|
||||||
mandir = @mandir@
|
|
||||||
mkdir_p = @mkdir_p@
|
|
||||||
oldincludedir = @oldincludedir@
|
|
||||||
pdfdir = @pdfdir@
|
|
||||||
prefix = @prefix@
|
|
||||||
program_transform_name = @program_transform_name@
|
|
||||||
psdir = @psdir@
|
|
||||||
sbindir = @sbindir@
|
|
||||||
sharedstatedir = @sharedstatedir@
|
|
||||||
sysconfdir = @sysconfdir@
|
|
||||||
target_alias = @target_alias@
|
|
||||||
SUBDIRS = enet
|
|
||||||
all: all-recursive
|
|
||||||
|
|
||||||
.SUFFIXES:
|
|
||||||
$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps)
|
|
||||||
@for dep in $?; do \
|
|
||||||
case '$(am__configure_deps)' in \
|
|
||||||
*$$dep*) \
|
|
||||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \
|
|
||||||
&& exit 0; \
|
|
||||||
exit 1;; \
|
|
||||||
esac; \
|
|
||||||
done; \
|
|
||||||
echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign include/Makefile'; \
|
|
||||||
cd $(top_srcdir) && \
|
|
||||||
$(AUTOMAKE) --foreign include/Makefile
|
|
||||||
.PRECIOUS: Makefile
|
|
||||||
Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
|
||||||
@case '$?' in \
|
|
||||||
*config.status*) \
|
|
||||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
|
|
||||||
*) \
|
|
||||||
echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
|
|
||||||
cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
|
|
||||||
esac;
|
|
||||||
|
|
||||||
$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
|
|
||||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
|
||||||
|
|
||||||
$(top_srcdir)/configure: $(am__configure_deps)
|
|
||||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
|
||||||
$(ACLOCAL_M4): $(am__aclocal_m4_deps)
|
|
||||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
|
||||||
uninstall-info-am:
|
|
||||||
|
|
||||||
# This directory's subdirectories are mostly independent; you can cd
|
|
||||||
# into them and run `make' without going through this Makefile.
|
|
||||||
# To change the values of `make' variables: instead of editing Makefiles,
|
|
||||||
# (1) if the variable is set in `config.status', edit `config.status'
|
|
||||||
# (which will cause the Makefiles to be regenerated when you run `make');
|
|
||||||
# (2) otherwise, pass the desired values on the `make' command line.
|
|
||||||
$(RECURSIVE_TARGETS):
|
|
||||||
@failcom='exit 1'; \
|
|
||||||
for f in x $$MAKEFLAGS; do \
|
|
||||||
case $$f in \
|
|
||||||
*=* | --[!k]*);; \
|
|
||||||
*k*) failcom='fail=yes';; \
|
|
||||||
esac; \
|
|
||||||
done; \
|
|
||||||
dot_seen=no; \
|
|
||||||
target=`echo $@ | sed s/-recursive//`; \
|
|
||||||
list='$(SUBDIRS)'; for subdir in $$list; do \
|
|
||||||
echo "Making $$target in $$subdir"; \
|
|
||||||
if test "$$subdir" = "."; then \
|
|
||||||
dot_seen=yes; \
|
|
||||||
local_target="$$target-am"; \
|
|
||||||
else \
|
|
||||||
local_target="$$target"; \
|
|
||||||
fi; \
|
|
||||||
(cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
|
|
||||||
|| eval $$failcom; \
|
|
||||||
done; \
|
|
||||||
if test "$$dot_seen" = "no"; then \
|
|
||||||
$(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \
|
|
||||||
fi; test -z "$$fail"
|
|
||||||
|
|
||||||
mostlyclean-recursive clean-recursive distclean-recursive \
|
|
||||||
maintainer-clean-recursive:
|
|
||||||
@failcom='exit 1'; \
|
|
||||||
for f in x $$MAKEFLAGS; do \
|
|
||||||
case $$f in \
|
|
||||||
*=* | --[!k]*);; \
|
|
||||||
*k*) failcom='fail=yes';; \
|
|
||||||
esac; \
|
|
||||||
done; \
|
|
||||||
dot_seen=no; \
|
|
||||||
case "$@" in \
|
|
||||||
distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \
|
|
||||||
*) list='$(SUBDIRS)' ;; \
|
|
||||||
esac; \
|
|
||||||
rev=''; for subdir in $$list; do \
|
|
||||||
if test "$$subdir" = "."; then :; else \
|
|
||||||
rev="$$subdir $$rev"; \
|
|
||||||
fi; \
|
|
||||||
done; \
|
|
||||||
rev="$$rev ."; \
|
|
||||||
target=`echo $@ | sed s/-recursive//`; \
|
|
||||||
for subdir in $$rev; do \
|
|
||||||
echo "Making $$target in $$subdir"; \
|
|
||||||
if test "$$subdir" = "."; then \
|
|
||||||
local_target="$$target-am"; \
|
|
||||||
else \
|
|
||||||
local_target="$$target"; \
|
|
||||||
fi; \
|
|
||||||
(cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
|
|
||||||
|| eval $$failcom; \
|
|
||||||
done && test -z "$$fail"
|
|
||||||
tags-recursive:
|
|
||||||
list='$(SUBDIRS)'; for subdir in $$list; do \
|
|
||||||
test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \
|
|
||||||
done
|
|
||||||
ctags-recursive:
|
|
||||||
list='$(SUBDIRS)'; for subdir in $$list; do \
|
|
||||||
test "$$subdir" = . || (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) ctags); \
|
|
||||||
done
|
|
||||||
|
|
||||||
ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
|
|
||||||
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
|
||||||
unique=`for i in $$list; do \
|
|
||||||
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
|
||||||
done | \
|
|
||||||
$(AWK) ' { files[$$0] = 1; } \
|
|
||||||
END { for (i in files) print i; }'`; \
|
|
||||||
mkid -fID $$unique
|
|
||||||
tags: TAGS
|
|
||||||
|
|
||||||
TAGS: tags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
|
|
||||||
$(TAGS_FILES) $(LISP)
|
|
||||||
tags=; \
|
|
||||||
here=`pwd`; \
|
|
||||||
if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \
|
|
||||||
include_option=--etags-include; \
|
|
||||||
empty_fix=.; \
|
|
||||||
else \
|
|
||||||
include_option=--include; \
|
|
||||||
empty_fix=; \
|
|
||||||
fi; \
|
|
||||||
list='$(SUBDIRS)'; for subdir in $$list; do \
|
|
||||||
if test "$$subdir" = .; then :; else \
|
|
||||||
test ! -f $$subdir/TAGS || \
|
|
||||||
tags="$$tags $$include_option=$$here/$$subdir/TAGS"; \
|
|
||||||
fi; \
|
|
||||||
done; \
|
|
||||||
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
|
||||||
unique=`for i in $$list; do \
|
|
||||||
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
|
||||||
done | \
|
|
||||||
$(AWK) ' { files[$$0] = 1; } \
|
|
||||||
END { for (i in files) print i; }'`; \
|
|
||||||
if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \
|
|
||||||
test -n "$$unique" || unique=$$empty_fix; \
|
|
||||||
$(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
|
|
||||||
$$tags $$unique; \
|
|
||||||
fi
|
|
||||||
ctags: CTAGS
|
|
||||||
CTAGS: ctags-recursive $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
|
|
||||||
$(TAGS_FILES) $(LISP)
|
|
||||||
tags=; \
|
|
||||||
here=`pwd`; \
|
|
||||||
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
|
||||||
unique=`for i in $$list; do \
|
|
||||||
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
|
||||||
done | \
|
|
||||||
$(AWK) ' { files[$$0] = 1; } \
|
|
||||||
END { for (i in files) print i; }'`; \
|
|
||||||
test -z "$(CTAGS_ARGS)$$tags$$unique" \
|
|
||||||
|| $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
|
|
||||||
$$tags $$unique
|
|
||||||
|
|
||||||
GTAGS:
|
|
||||||
here=`$(am__cd) $(top_builddir) && pwd` \
|
|
||||||
&& cd $(top_srcdir) \
|
|
||||||
&& gtags -i $(GTAGS_ARGS) $$here
|
|
||||||
|
|
||||||
distclean-tags:
|
|
||||||
-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
|
|
||||||
|
|
||||||
distdir: $(DISTFILES)
|
|
||||||
@srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \
|
|
||||||
topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \
|
|
||||||
list='$(DISTFILES)'; for file in $$list; do \
|
|
||||||
case $$file in \
|
|
||||||
$(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \
|
|
||||||
$(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \
|
|
||||||
esac; \
|
|
||||||
if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
|
|
||||||
dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \
|
|
||||||
if test "$$dir" != "$$file" && test "$$dir" != "."; then \
|
|
||||||
dir="/$$dir"; \
|
|
||||||
$(mkdir_p) "$(distdir)$$dir"; \
|
|
||||||
else \
|
|
||||||
dir=''; \
|
|
||||||
fi; \
|
|
||||||
if test -d $$d/$$file; then \
|
|
||||||
if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
|
|
||||||
cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \
|
|
||||||
fi; \
|
|
||||||
cp -pR $$d/$$file $(distdir)$$dir || exit 1; \
|
|
||||||
else \
|
|
||||||
test -f $(distdir)/$$file \
|
|
||||||
|| cp -p $$d/$$file $(distdir)/$$file \
|
|
||||||
|| exit 1; \
|
|
||||||
fi; \
|
|
||||||
done
|
|
||||||
list='$(DIST_SUBDIRS)'; for subdir in $$list; do \
|
|
||||||
if test "$$subdir" = .; then :; else \
|
|
||||||
test -d "$(distdir)/$$subdir" \
|
|
||||||
|| $(mkdir_p) "$(distdir)/$$subdir" \
|
|
||||||
|| exit 1; \
|
|
||||||
distdir=`$(am__cd) $(distdir) && pwd`; \
|
|
||||||
top_distdir=`$(am__cd) $(top_distdir) && pwd`; \
|
|
||||||
(cd $$subdir && \
|
|
||||||
$(MAKE) $(AM_MAKEFLAGS) \
|
|
||||||
top_distdir="$$top_distdir" \
|
|
||||||
distdir="$$distdir/$$subdir" \
|
|
||||||
distdir) \
|
|
||||||
|| exit 1; \
|
|
||||||
fi; \
|
|
||||||
done
|
|
||||||
check-am: all-am
|
|
||||||
check: check-recursive
|
|
||||||
all-am: Makefile
|
|
||||||
installdirs: installdirs-recursive
|
|
||||||
installdirs-am:
|
|
||||||
install: install-recursive
|
|
||||||
install-exec: install-exec-recursive
|
|
||||||
install-data: install-data-recursive
|
|
||||||
uninstall: uninstall-recursive
|
|
||||||
|
|
||||||
install-am: all-am
|
|
||||||
@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
|
|
||||||
|
|
||||||
installcheck: installcheck-recursive
|
|
||||||
install-strip:
|
|
||||||
$(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
|
|
||||||
install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
|
|
||||||
`test -z '$(STRIP)' || \
|
|
||||||
echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
|
|
||||||
mostlyclean-generic:
|
|
||||||
|
|
||||||
clean-generic:
|
|
||||||
|
|
||||||
distclean-generic:
|
|
||||||
-test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
|
|
||||||
|
|
||||||
maintainer-clean-generic:
|
|
||||||
@echo "This command is intended for maintainers to use"
|
|
||||||
@echo "it deletes files that may require special tools to rebuild."
|
|
||||||
clean: clean-recursive
|
|
||||||
|
|
||||||
clean-am: clean-generic mostlyclean-am
|
|
||||||
|
|
||||||
distclean: distclean-recursive
|
|
||||||
-rm -f Makefile
|
|
||||||
distclean-am: clean-am distclean-generic distclean-tags
|
|
||||||
|
|
||||||
dvi: dvi-recursive
|
|
||||||
|
|
||||||
dvi-am:
|
|
||||||
|
|
||||||
html: html-recursive
|
|
||||||
|
|
||||||
info: info-recursive
|
|
||||||
|
|
||||||
info-am:
|
|
||||||
|
|
||||||
install-data-am:
|
|
||||||
|
|
||||||
install-exec-am:
|
|
||||||
|
|
||||||
install-info: install-info-recursive
|
|
||||||
|
|
||||||
install-man:
|
|
||||||
|
|
||||||
installcheck-am:
|
|
||||||
|
|
||||||
maintainer-clean: maintainer-clean-recursive
|
|
||||||
-rm -f Makefile
|
|
||||||
maintainer-clean-am: distclean-am maintainer-clean-generic
|
|
||||||
|
|
||||||
mostlyclean: mostlyclean-recursive
|
|
||||||
|
|
||||||
mostlyclean-am: mostlyclean-generic
|
|
||||||
|
|
||||||
pdf: pdf-recursive
|
|
||||||
|
|
||||||
pdf-am:
|
|
||||||
|
|
||||||
ps: ps-recursive
|
|
||||||
|
|
||||||
ps-am:
|
|
||||||
|
|
||||||
uninstall-am: uninstall-info-am
|
|
||||||
|
|
||||||
uninstall-info: uninstall-info-recursive
|
|
||||||
|
|
||||||
.PHONY: $(RECURSIVE_TARGETS) CTAGS GTAGS all all-am check check-am \
|
|
||||||
clean clean-generic clean-recursive ctags ctags-recursive \
|
|
||||||
distclean distclean-generic distclean-recursive distclean-tags \
|
|
||||||
distdir dvi dvi-am html html-am info info-am install \
|
|
||||||
install-am install-data install-data-am install-exec \
|
|
||||||
install-exec-am install-info install-info-am install-man \
|
|
||||||
install-strip installcheck installcheck-am installdirs \
|
|
||||||
installdirs-am maintainer-clean maintainer-clean-generic \
|
|
||||||
maintainer-clean-recursive mostlyclean mostlyclean-generic \
|
|
||||||
mostlyclean-recursive pdf pdf-am ps ps-am tags tags-recursive \
|
|
||||||
uninstall uninstall-am uninstall-info-am
|
|
||||||
|
|
||||||
# Tell versions [3.59,3.63) of GNU make to not export all variables.
|
|
||||||
# Otherwise a system limit (for SysV at least) may be exceeded.
|
|
||||||
.NOEXPORT:
|
|
|
@ -1,11 +0,0 @@
|
||||||
/Makefile.am/1.1.1.1/Wed Oct 20 17:17:52 2004//
|
|
||||||
/callbacks.h/1.1.1.1/Wed Oct 20 17:17:52 2004//
|
|
||||||
/enet.h/1.22/Fri Oct 12 23:15:29 2007//
|
|
||||||
/list.h/1.1.1.1/Wed Oct 20 17:17:52 2004//
|
|
||||||
/protocol.h/1.4/Wed Dec 13 04:36:07 2006//
|
|
||||||
/time.h/1.1.1.1/Wed Oct 20 17:17:52 2004//
|
|
||||||
/types.h/1.1.1.1/Wed Oct 20 17:17:52 2004//
|
|
||||||
/unix.h/1.1.1.1/Wed Oct 20 17:17:52 2004//
|
|
||||||
/utility.h/1.1.1.1/Wed Oct 20 17:17:52 2004//
|
|
||||||
/win32.h/1.3/Tue Mar 14 23:21:51 2006//
|
|
||||||
D
|
|
|
@ -1 +0,0 @@
|
||||||
enet/include/enet
|
|
|
@ -1 +0,0 @@
|
||||||
:pserver:anonymous@bespin.org:/var/lib/cvs/enet
|
|
|
@ -1,12 +0,0 @@
|
||||||
libenetincludedir = $(includedir)/enet
|
|
||||||
libenetinclude_HEADERS = \
|
|
||||||
types.h \
|
|
||||||
list.h \
|
|
||||||
utility.h \
|
|
||||||
time.h \
|
|
||||||
callbacks.h \
|
|
||||||
unix.h \
|
|
||||||
win32.h \
|
|
||||||
protocol.h \
|
|
||||||
enet.h
|
|
||||||
|
|
|
@ -1,367 +0,0 @@
|
||||||
# Makefile.in generated by automake 1.9.6 from Makefile.am.
|
|
||||||
# @configure_input@
|
|
||||||
|
|
||||||
# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
|
|
||||||
# 2003, 2004, 2005 Free Software Foundation, Inc.
|
|
||||||
# This Makefile.in is free software; the Free Software Foundation
|
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
|
||||||
# with or without modifications, as long as this notice is preserved.
|
|
||||||
|
|
||||||
# This program is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
|
|
||||||
# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
|
||||||
# PARTICULAR PURPOSE.
|
|
||||||
|
|
||||||
@SET_MAKE@
|
|
||||||
|
|
||||||
srcdir = @srcdir@
|
|
||||||
top_srcdir = @top_srcdir@
|
|
||||||
VPATH = @srcdir@
|
|
||||||
pkgdatadir = $(datadir)/@PACKAGE@
|
|
||||||
pkglibdir = $(libdir)/@PACKAGE@
|
|
||||||
pkgincludedir = $(includedir)/@PACKAGE@
|
|
||||||
top_builddir = ../..
|
|
||||||
am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
|
|
||||||
INSTALL = @INSTALL@
|
|
||||||
install_sh_DATA = $(install_sh) -c -m 644
|
|
||||||
install_sh_PROGRAM = $(install_sh) -c
|
|
||||||
install_sh_SCRIPT = $(install_sh) -c
|
|
||||||
INSTALL_HEADER = $(INSTALL_DATA)
|
|
||||||
transform = $(program_transform_name)
|
|
||||||
NORMAL_INSTALL = :
|
|
||||||
PRE_INSTALL = :
|
|
||||||
POST_INSTALL = :
|
|
||||||
NORMAL_UNINSTALL = :
|
|
||||||
PRE_UNINSTALL = :
|
|
||||||
POST_UNINSTALL = :
|
|
||||||
subdir = include/enet
|
|
||||||
DIST_COMMON = $(libenetinclude_HEADERS) $(srcdir)/Makefile.am \
|
|
||||||
$(srcdir)/Makefile.in
|
|
||||||
ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
|
|
||||||
am__aclocal_m4_deps = $(top_srcdir)/configure.in
|
|
||||||
am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
|
|
||||||
$(ACLOCAL_M4)
|
|
||||||
mkinstalldirs = $(install_sh) -d
|
|
||||||
CONFIG_CLEAN_FILES =
|
|
||||||
SOURCES =
|
|
||||||
DIST_SOURCES =
|
|
||||||
am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`;
|
|
||||||
am__vpath_adj = case $$p in \
|
|
||||||
$(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \
|
|
||||||
*) f=$$p;; \
|
|
||||||
esac;
|
|
||||||
am__strip_dir = `echo $$p | sed -e 's|^.*/||'`;
|
|
||||||
am__installdirs = "$(DESTDIR)$(libenetincludedir)"
|
|
||||||
libenetincludeHEADERS_INSTALL = $(INSTALL_HEADER)
|
|
||||||
HEADERS = $(libenetinclude_HEADERS)
|
|
||||||
ETAGS = etags
|
|
||||||
CTAGS = ctags
|
|
||||||
DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
|
|
||||||
ACLOCAL = @ACLOCAL@
|
|
||||||
AMDEP_FALSE = @AMDEP_FALSE@
|
|
||||||
AMDEP_TRUE = @AMDEP_TRUE@
|
|
||||||
AMTAR = @AMTAR@
|
|
||||||
AUTOCONF = @AUTOCONF@
|
|
||||||
AUTOHEADER = @AUTOHEADER@
|
|
||||||
AUTOMAKE = @AUTOMAKE@
|
|
||||||
AWK = @AWK@
|
|
||||||
CC = @CC@
|
|
||||||
CCDEPMODE = @CCDEPMODE@
|
|
||||||
CFLAGS = @CFLAGS@
|
|
||||||
CPP = @CPP@
|
|
||||||
CPPFLAGS = @CPPFLAGS@
|
|
||||||
CYGPATH_W = @CYGPATH_W@
|
|
||||||
DEFS = @DEFS@
|
|
||||||
DEPDIR = @DEPDIR@
|
|
||||||
ECHO_C = @ECHO_C@
|
|
||||||
ECHO_N = @ECHO_N@
|
|
||||||
ECHO_T = @ECHO_T@
|
|
||||||
EGREP = @EGREP@
|
|
||||||
EXEEXT = @EXEEXT@
|
|
||||||
GREP = @GREP@
|
|
||||||
INSTALL_DATA = @INSTALL_DATA@
|
|
||||||
INSTALL_PROGRAM = @INSTALL_PROGRAM@
|
|
||||||
INSTALL_SCRIPT = @INSTALL_SCRIPT@
|
|
||||||
INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
|
|
||||||
LDFLAGS = @LDFLAGS@
|
|
||||||
LIBOBJS = @LIBOBJS@
|
|
||||||
LIBS = @LIBS@
|
|
||||||
LTLIBOBJS = @LTLIBOBJS@
|
|
||||||
MAKEINFO = @MAKEINFO@
|
|
||||||
OBJEXT = @OBJEXT@
|
|
||||||
PACKAGE = @PACKAGE@
|
|
||||||
PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
|
|
||||||
PACKAGE_NAME = @PACKAGE_NAME@
|
|
||||||
PACKAGE_STRING = @PACKAGE_STRING@
|
|
||||||
PACKAGE_TARNAME = @PACKAGE_TARNAME@
|
|
||||||
PACKAGE_VERSION = @PACKAGE_VERSION@
|
|
||||||
PATH_SEPARATOR = @PATH_SEPARATOR@
|
|
||||||
RANLIB = @RANLIB@
|
|
||||||
SET_MAKE = @SET_MAKE@
|
|
||||||
SHELL = @SHELL@
|
|
||||||
STRIP = @STRIP@
|
|
||||||
VERSION = @VERSION@
|
|
||||||
ac_ct_CC = @ac_ct_CC@
|
|
||||||
am__fastdepCC_FALSE = @am__fastdepCC_FALSE@
|
|
||||||
am__fastdepCC_TRUE = @am__fastdepCC_TRUE@
|
|
||||||
am__include = @am__include@
|
|
||||||
am__leading_dot = @am__leading_dot@
|
|
||||||
am__quote = @am__quote@
|
|
||||||
am__tar = @am__tar@
|
|
||||||
am__untar = @am__untar@
|
|
||||||
bindir = @bindir@
|
|
||||||
build_alias = @build_alias@
|
|
||||||
datadir = @datadir@
|
|
||||||
datarootdir = @datarootdir@
|
|
||||||
docdir = @docdir@
|
|
||||||
dvidir = @dvidir@
|
|
||||||
exec_prefix = @exec_prefix@
|
|
||||||
host_alias = @host_alias@
|
|
||||||
htmldir = @htmldir@
|
|
||||||
includedir = @includedir@
|
|
||||||
infodir = @infodir@
|
|
||||||
install_sh = @install_sh@
|
|
||||||
libdir = @libdir@
|
|
||||||
libexecdir = @libexecdir@
|
|
||||||
localedir = @localedir@
|
|
||||||
localstatedir = @localstatedir@
|
|
||||||
mandir = @mandir@
|
|
||||||
mkdir_p = @mkdir_p@
|
|
||||||
oldincludedir = @oldincludedir@
|
|
||||||
pdfdir = @pdfdir@
|
|
||||||
prefix = @prefix@
|
|
||||||
program_transform_name = @program_transform_name@
|
|
||||||
psdir = @psdir@
|
|
||||||
sbindir = @sbindir@
|
|
||||||
sharedstatedir = @sharedstatedir@
|
|
||||||
sysconfdir = @sysconfdir@
|
|
||||||
target_alias = @target_alias@
|
|
||||||
libenetincludedir = $(includedir)/enet
|
|
||||||
libenetinclude_HEADERS = \
|
|
||||||
types.h \
|
|
||||||
list.h \
|
|
||||||
utility.h \
|
|
||||||
time.h \
|
|
||||||
callbacks.h \
|
|
||||||
unix.h \
|
|
||||||
win32.h \
|
|
||||||
protocol.h \
|
|
||||||
enet.h
|
|
||||||
|
|
||||||
all: all-am
|
|
||||||
|
|
||||||
.SUFFIXES:
|
|
||||||
$(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps)
|
|
||||||
@for dep in $?; do \
|
|
||||||
case '$(am__configure_deps)' in \
|
|
||||||
*$$dep*) \
|
|
||||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh \
|
|
||||||
&& exit 0; \
|
|
||||||
exit 1;; \
|
|
||||||
esac; \
|
|
||||||
done; \
|
|
||||||
echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign include/enet/Makefile'; \
|
|
||||||
cd $(top_srcdir) && \
|
|
||||||
$(AUTOMAKE) --foreign include/enet/Makefile
|
|
||||||
.PRECIOUS: Makefile
|
|
||||||
Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
|
||||||
@case '$?' in \
|
|
||||||
*config.status*) \
|
|
||||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
|
|
||||||
*) \
|
|
||||||
echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
|
|
||||||
cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
|
|
||||||
esac;
|
|
||||||
|
|
||||||
$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
|
|
||||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
|
||||||
|
|
||||||
$(top_srcdir)/configure: $(am__configure_deps)
|
|
||||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
|
||||||
$(ACLOCAL_M4): $(am__aclocal_m4_deps)
|
|
||||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
|
||||||
uninstall-info-am:
|
|
||||||
install-libenetincludeHEADERS: $(libenetinclude_HEADERS)
|
|
||||||
@$(NORMAL_INSTALL)
|
|
||||||
test -z "$(libenetincludedir)" || $(mkdir_p) "$(DESTDIR)$(libenetincludedir)"
|
|
||||||
@list='$(libenetinclude_HEADERS)'; for p in $$list; do \
|
|
||||||
if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \
|
|
||||||
f=$(am__strip_dir) \
|
|
||||||
echo " $(libenetincludeHEADERS_INSTALL) '$$d$$p' '$(DESTDIR)$(libenetincludedir)/$$f'"; \
|
|
||||||
$(libenetincludeHEADERS_INSTALL) "$$d$$p" "$(DESTDIR)$(libenetincludedir)/$$f"; \
|
|
||||||
done
|
|
||||||
|
|
||||||
uninstall-libenetincludeHEADERS:
|
|
||||||
@$(NORMAL_UNINSTALL)
|
|
||||||
@list='$(libenetinclude_HEADERS)'; for p in $$list; do \
|
|
||||||
f=$(am__strip_dir) \
|
|
||||||
echo " rm -f '$(DESTDIR)$(libenetincludedir)/$$f'"; \
|
|
||||||
rm -f "$(DESTDIR)$(libenetincludedir)/$$f"; \
|
|
||||||
done
|
|
||||||
|
|
||||||
ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES)
|
|
||||||
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
|
||||||
unique=`for i in $$list; do \
|
|
||||||
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
|
||||||
done | \
|
|
||||||
$(AWK) ' { files[$$0] = 1; } \
|
|
||||||
END { for (i in files) print i; }'`; \
|
|
||||||
mkid -fID $$unique
|
|
||||||
tags: TAGS
|
|
||||||
|
|
||||||
TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
|
|
||||||
$(TAGS_FILES) $(LISP)
|
|
||||||
tags=; \
|
|
||||||
here=`pwd`; \
|
|
||||||
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
|
||||||
unique=`for i in $$list; do \
|
|
||||||
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
|
||||||
done | \
|
|
||||||
$(AWK) ' { files[$$0] = 1; } \
|
|
||||||
END { for (i in files) print i; }'`; \
|
|
||||||
if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \
|
|
||||||
test -n "$$unique" || unique=$$empty_fix; \
|
|
||||||
$(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
|
|
||||||
$$tags $$unique; \
|
|
||||||
fi
|
|
||||||
ctags: CTAGS
|
|
||||||
CTAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) \
|
|
||||||
$(TAGS_FILES) $(LISP)
|
|
||||||
tags=; \
|
|
||||||
here=`pwd`; \
|
|
||||||
list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \
|
|
||||||
unique=`for i in $$list; do \
|
|
||||||
if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
|
|
||||||
done | \
|
|
||||||
$(AWK) ' { files[$$0] = 1; } \
|
|
||||||
END { for (i in files) print i; }'`; \
|
|
||||||
test -z "$(CTAGS_ARGS)$$tags$$unique" \
|
|
||||||
|| $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
|
|
||||||
$$tags $$unique
|
|
||||||
|
|
||||||
GTAGS:
|
|
||||||
here=`$(am__cd) $(top_builddir) && pwd` \
|
|
||||||
&& cd $(top_srcdir) \
|
|
||||||
&& gtags -i $(GTAGS_ARGS) $$here
|
|
||||||
|
|
||||||
distclean-tags:
|
|
||||||
-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
|
|
||||||
|
|
||||||
distdir: $(DISTFILES)
|
|
||||||
@srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; \
|
|
||||||
topsrcdirstrip=`echo "$(top_srcdir)" | sed 's|.|.|g'`; \
|
|
||||||
list='$(DISTFILES)'; for file in $$list; do \
|
|
||||||
case $$file in \
|
|
||||||
$(srcdir)/*) file=`echo "$$file" | sed "s|^$$srcdirstrip/||"`;; \
|
|
||||||
$(top_srcdir)/*) file=`echo "$$file" | sed "s|^$$topsrcdirstrip/|$(top_builddir)/|"`;; \
|
|
||||||
esac; \
|
|
||||||
if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
|
|
||||||
dir=`echo "$$file" | sed -e 's,/[^/]*$$,,'`; \
|
|
||||||
if test "$$dir" != "$$file" && test "$$dir" != "."; then \
|
|
||||||
dir="/$$dir"; \
|
|
||||||
$(mkdir_p) "$(distdir)$$dir"; \
|
|
||||||
else \
|
|
||||||
dir=''; \
|
|
||||||
fi; \
|
|
||||||
if test -d $$d/$$file; then \
|
|
||||||
if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
|
|
||||||
cp -pR $(srcdir)/$$file $(distdir)$$dir || exit 1; \
|
|
||||||
fi; \
|
|
||||||
cp -pR $$d/$$file $(distdir)$$dir || exit 1; \
|
|
||||||
else \
|
|
||||||
test -f $(distdir)/$$file \
|
|
||||||
|| cp -p $$d/$$file $(distdir)/$$file \
|
|
||||||
|| exit 1; \
|
|
||||||
fi; \
|
|
||||||
done
|
|
||||||
check-am: all-am
|
|
||||||
check: check-am
|
|
||||||
all-am: Makefile $(HEADERS)
|
|
||||||
installdirs:
|
|
||||||
for dir in "$(DESTDIR)$(libenetincludedir)"; do \
|
|
||||||
test -z "$$dir" || $(mkdir_p) "$$dir"; \
|
|
||||||
done
|
|
||||||
install: install-am
|
|
||||||
install-exec: install-exec-am
|
|
||||||
install-data: install-data-am
|
|
||||||
uninstall: uninstall-am
|
|
||||||
|
|
||||||
install-am: all-am
|
|
||||||
@$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
|
|
||||||
|
|
||||||
installcheck: installcheck-am
|
|
||||||
install-strip:
|
|
||||||
$(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
|
|
||||||
install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
|
|
||||||
`test -z '$(STRIP)' || \
|
|
||||||
echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
|
|
||||||
mostlyclean-generic:
|
|
||||||
|
|
||||||
clean-generic:
|
|
||||||
|
|
||||||
distclean-generic:
|
|
||||||
-test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
|
|
||||||
|
|
||||||
maintainer-clean-generic:
|
|
||||||
@echo "This command is intended for maintainers to use"
|
|
||||||
@echo "it deletes files that may require special tools to rebuild."
|
|
||||||
clean: clean-am
|
|
||||||
|
|
||||||
clean-am: clean-generic mostlyclean-am
|
|
||||||
|
|
||||||
distclean: distclean-am
|
|
||||||
-rm -f Makefile
|
|
||||||
distclean-am: clean-am distclean-generic distclean-tags
|
|
||||||
|
|
||||||
dvi: dvi-am
|
|
||||||
|
|
||||||
dvi-am:
|
|
||||||
|
|
||||||
html: html-am
|
|
||||||
|
|
||||||
info: info-am
|
|
||||||
|
|
||||||
info-am:
|
|
||||||
|
|
||||||
install-data-am: install-libenetincludeHEADERS
|
|
||||||
|
|
||||||
install-exec-am:
|
|
||||||
|
|
||||||
install-info: install-info-am
|
|
||||||
|
|
||||||
install-man:
|
|
||||||
|
|
||||||
installcheck-am:
|
|
||||||
|
|
||||||
maintainer-clean: maintainer-clean-am
|
|
||||||
-rm -f Makefile
|
|
||||||
maintainer-clean-am: distclean-am maintainer-clean-generic
|
|
||||||
|
|
||||||
mostlyclean: mostlyclean-am
|
|
||||||
|
|
||||||
mostlyclean-am: mostlyclean-generic
|
|
||||||
|
|
||||||
pdf: pdf-am
|
|
||||||
|
|
||||||
pdf-am:
|
|
||||||
|
|
||||||
ps: ps-am
|
|
||||||
|
|
||||||
ps-am:
|
|
||||||
|
|
||||||
uninstall-am: uninstall-info-am uninstall-libenetincludeHEADERS
|
|
||||||
|
|
||||||
.PHONY: CTAGS GTAGS all all-am check check-am clean clean-generic \
|
|
||||||
ctags distclean distclean-generic distclean-tags distdir dvi \
|
|
||||||
dvi-am html html-am info info-am install install-am \
|
|
||||||
install-data install-data-am install-exec install-exec-am \
|
|
||||||
install-info install-info-am install-libenetincludeHEADERS \
|
|
||||||
install-man install-strip installcheck installcheck-am \
|
|
||||||
installdirs maintainer-clean maintainer-clean-generic \
|
|
||||||
mostlyclean mostlyclean-generic pdf pdf-am ps ps-am tags \
|
|
||||||
uninstall uninstall-am uninstall-info-am \
|
|
||||||
uninstall-libenetincludeHEADERS
|
|
||||||
|
|
||||||
# Tell versions [3.59,3.63) of GNU make to not export all variables.
|
|
||||||
# Otherwise a system limit (for SysV at least) may be exceeded.
|
|
||||||
.NOEXPORT:
|
|
|
@ -1,28 +0,0 @@
|
||||||
/**
|
|
||||||
@file callbacks.h
|
|
||||||
@brief ENet callbacks
|
|
||||||
*/
|
|
||||||
#ifndef __ENET_CALLBACKS_H__
|
|
||||||
#define __ENET_CALLBACKS_H__
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
void * (ENET_CALLBACK * malloc) (size_t size);
|
|
||||||
void (ENET_CALLBACK * free) (void * memory);
|
|
||||||
int (ENET_CALLBACK * rand) (void);
|
|
||||||
} ENetCallbacks;
|
|
||||||
|
|
||||||
/** @defgroup callbacks ENet internal callbacks
|
|
||||||
@{
|
|
||||||
@ingroup private
|
|
||||||
*/
|
|
||||||
extern void * enet_malloc (size_t);
|
|
||||||
extern void enet_free (void *);
|
|
||||||
extern int enet_rand (void);
|
|
||||||
|
|
||||||
/** @} */
|
|
||||||
|
|
||||||
#endif /* __ENET_CALLBACKS_H__ */
|
|
||||||
|
|
|
@ -1,488 +0,0 @@
|
||||||
/**
|
|
||||||
@file enet.h
|
|
||||||
@brief ENet public header file
|
|
||||||
*/
|
|
||||||
#ifndef __ENET_ENET_H__
|
|
||||||
#define __ENET_ENET_H__
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
|
|
||||||
#ifdef WIN32
|
|
||||||
#include "enet/win32.h"
|
|
||||||
#else
|
|
||||||
#include "enet/unix.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "enet/types.h"
|
|
||||||
#include "enet/protocol.h"
|
|
||||||
#include "enet/list.h"
|
|
||||||
#include "enet/callbacks.h"
|
|
||||||
|
|
||||||
typedef enum
|
|
||||||
{
|
|
||||||
ENET_VERSION = 1
|
|
||||||
} ENetVersion;
|
|
||||||
|
|
||||||
typedef enum
|
|
||||||
{
|
|
||||||
ENET_SOCKET_TYPE_STREAM = 1,
|
|
||||||
ENET_SOCKET_TYPE_DATAGRAM = 2
|
|
||||||
} ENetSocketType;
|
|
||||||
|
|
||||||
typedef enum
|
|
||||||
{
|
|
||||||
ENET_SOCKET_WAIT_NONE = 0,
|
|
||||||
ENET_SOCKET_WAIT_SEND = (1 << 0),
|
|
||||||
ENET_SOCKET_WAIT_RECEIVE = (1 << 1)
|
|
||||||
} ENetSocketWait;
|
|
||||||
|
|
||||||
typedef enum
|
|
||||||
{
|
|
||||||
ENET_SOCKOPT_NONBLOCK = 1,
|
|
||||||
ENET_SOCKOPT_BROADCAST = 2,
|
|
||||||
ENET_SOCKOPT_RCVBUF = 3,
|
|
||||||
ENET_SOCKOPT_SNDBUF = 4
|
|
||||||
} ENetSocketOption;
|
|
||||||
|
|
||||||
enum
|
|
||||||
{
|
|
||||||
ENET_HOST_ANY = 0, /**< specifies the default server host */
|
|
||||||
ENET_HOST_BROADCAST = 0xFFFFFFFF, /**< specifies a subnet-wide broadcast */
|
|
||||||
|
|
||||||
ENET_PORT_ANY = 0 /**< specifies that a port should be automatically chosen */
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Portable internet address structure.
|
|
||||||
*
|
|
||||||
* The host must be specified in network byte-order, and the port must be in host
|
|
||||||
* byte-order. The constant ENET_HOST_ANY may be used to specify the default
|
|
||||||
* server host. The constant ENET_HOST_BROADCAST may be used to specify the
|
|
||||||
* broadcast address (255.255.255.255). This makes sense for enet_host_connect,
|
|
||||||
* but not for enet_host_create. Once a server responds to a broadcast, the
|
|
||||||
* address is updated from ENET_HOST_BROADCAST to the server's actual IP address.
|
|
||||||
*/
|
|
||||||
typedef struct _ENetAddress
|
|
||||||
{
|
|
||||||
enet_uint32 host;
|
|
||||||
enet_uint16 port;
|
|
||||||
} ENetAddress;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Packet flag bit constants.
|
|
||||||
*
|
|
||||||
* The host must be specified in network byte-order, and the port must be in
|
|
||||||
* host byte-order. The constant ENET_HOST_ANY may be used to specify the
|
|
||||||
* default server host.
|
|
||||||
|
|
||||||
@sa ENetPacket
|
|
||||||
*/
|
|
||||||
typedef enum
|
|
||||||
{
|
|
||||||
/** packet must be received by the target peer and resend attempts should be
|
|
||||||
* made until the packet is delivered */
|
|
||||||
ENET_PACKET_FLAG_RELIABLE = (1 << 0),
|
|
||||||
/** packet will not be sequenced with other packets
|
|
||||||
* not supported for reliable packets
|
|
||||||
*/
|
|
||||||
ENET_PACKET_FLAG_UNSEQUENCED = (1 << 1),
|
|
||||||
/** packet will not allocate data, and user must supply it instead */
|
|
||||||
ENET_PACKET_FLAG_NO_ALLOCATE = (1 << 2)
|
|
||||||
} ENetPacketFlag;
|
|
||||||
|
|
||||||
struct _ENetPacket;
|
|
||||||
typedef void (ENET_CALLBACK * ENetPacketFreeCallback) (struct _ENetPacket *);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ENet packet structure.
|
|
||||||
*
|
|
||||||
* An ENet data packet that may be sent to or received from a peer. The shown
|
|
||||||
* fields should only be read and never modified. The data field contains the
|
|
||||||
* allocated data for the packet. The dataLength fields specifies the length
|
|
||||||
* of the allocated data. The flags field is either 0 (specifying no flags),
|
|
||||||
* or a bitwise-or of any combination of the following flags:
|
|
||||||
*
|
|
||||||
* ENET_PACKET_FLAG_RELIABLE - packet must be received by the target peer
|
|
||||||
* and resend attempts should be made until the packet is delivered
|
|
||||||
*
|
|
||||||
* ENET_PACKET_FLAG_UNSEQUENCED - packet will not be sequenced with other packets
|
|
||||||
* (not supported for reliable packets)
|
|
||||||
*
|
|
||||||
* ENET_PACKET_FLAG_NO_ALLOCATE - packet will not allocate data, and user must supply it instead
|
|
||||||
|
|
||||||
@sa ENetPacketFlag
|
|
||||||
*/
|
|
||||||
typedef struct _ENetPacket
|
|
||||||
{
|
|
||||||
size_t referenceCount; /**< internal use only */
|
|
||||||
enet_uint32 flags; /**< bitwise-or of ENetPacketFlag constants */
|
|
||||||
enet_uint8 * data; /**< allocated data for packet */
|
|
||||||
size_t dataLength; /**< length of data */
|
|
||||||
ENetPacketFreeCallback freeCallback; /**< function to be called when the packet is no longer in use */
|
|
||||||
} ENetPacket;
|
|
||||||
|
|
||||||
typedef struct _ENetAcknowledgement
|
|
||||||
{
|
|
||||||
ENetListNode acknowledgementList;
|
|
||||||
enet_uint32 sentTime;
|
|
||||||
ENetProtocol command;
|
|
||||||
} ENetAcknowledgement;
|
|
||||||
|
|
||||||
typedef struct _ENetOutgoingCommand
|
|
||||||
{
|
|
||||||
ENetListNode outgoingCommandList;
|
|
||||||
enet_uint16 reliableSequenceNumber;
|
|
||||||
enet_uint16 unreliableSequenceNumber;
|
|
||||||
enet_uint32 sentTime;
|
|
||||||
enet_uint32 roundTripTimeout;
|
|
||||||
enet_uint32 roundTripTimeoutLimit;
|
|
||||||
enet_uint32 fragmentOffset;
|
|
||||||
enet_uint16 fragmentLength;
|
|
||||||
enet_uint16 sendAttempts;
|
|
||||||
ENetProtocol command;
|
|
||||||
ENetPacket * packet;
|
|
||||||
} ENetOutgoingCommand;
|
|
||||||
|
|
||||||
typedef struct _ENetIncomingCommand
|
|
||||||
{
|
|
||||||
ENetListNode incomingCommandList;
|
|
||||||
enet_uint16 reliableSequenceNumber;
|
|
||||||
enet_uint16 unreliableSequenceNumber;
|
|
||||||
ENetProtocol command;
|
|
||||||
enet_uint32 fragmentCount;
|
|
||||||
enet_uint32 fragmentsRemaining;
|
|
||||||
enet_uint32 * fragments;
|
|
||||||
ENetPacket * packet;
|
|
||||||
} ENetIncomingCommand;
|
|
||||||
|
|
||||||
typedef enum
|
|
||||||
{
|
|
||||||
ENET_PEER_STATE_DISCONNECTED = 0,
|
|
||||||
ENET_PEER_STATE_CONNECTING = 1,
|
|
||||||
ENET_PEER_STATE_ACKNOWLEDGING_CONNECT = 2,
|
|
||||||
ENET_PEER_STATE_CONNECTION_PENDING = 3,
|
|
||||||
ENET_PEER_STATE_CONNECTION_SUCCEEDED = 4,
|
|
||||||
ENET_PEER_STATE_CONNECTED = 5,
|
|
||||||
ENET_PEER_STATE_DISCONNECT_LATER = 6,
|
|
||||||
ENET_PEER_STATE_DISCONNECTING = 7,
|
|
||||||
ENET_PEER_STATE_ACKNOWLEDGING_DISCONNECT = 8,
|
|
||||||
ENET_PEER_STATE_ZOMBIE = 9
|
|
||||||
} ENetPeerState;
|
|
||||||
|
|
||||||
#ifndef ENET_BUFFER_MAXIMUM
|
|
||||||
#define ENET_BUFFER_MAXIMUM (1 + 2 * ENET_PROTOCOL_MAXIMUM_PACKET_COMMANDS)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
enum
|
|
||||||
{
|
|
||||||
ENET_HOST_RECEIVE_BUFFER_SIZE = 256 * 1024,
|
|
||||||
ENET_HOST_SEND_BUFFER_SIZE = 256 * 1024,
|
|
||||||
ENET_HOST_BANDWIDTH_THROTTLE_INTERVAL = 1000,
|
|
||||||
ENET_HOST_DEFAULT_MTU = 1400,
|
|
||||||
|
|
||||||
ENET_PEER_DEFAULT_ROUND_TRIP_TIME = 500,
|
|
||||||
ENET_PEER_DEFAULT_PACKET_THROTTLE = 32,
|
|
||||||
ENET_PEER_PACKET_THROTTLE_SCALE = 32,
|
|
||||||
ENET_PEER_PACKET_THROTTLE_COUNTER = 7,
|
|
||||||
ENET_PEER_PACKET_THROTTLE_ACCELERATION = 2,
|
|
||||||
ENET_PEER_PACKET_THROTTLE_DECELERATION = 2,
|
|
||||||
ENET_PEER_PACKET_THROTTLE_INTERVAL = 5000,
|
|
||||||
ENET_PEER_PACKET_LOSS_SCALE = (1 << 16),
|
|
||||||
ENET_PEER_PACKET_LOSS_INTERVAL = 10000,
|
|
||||||
ENET_PEER_WINDOW_SIZE_SCALE = 64 * 1024,
|
|
||||||
ENET_PEER_TIMEOUT_LIMIT = 32,
|
|
||||||
ENET_PEER_TIMEOUT_MINIMUM = 5000,
|
|
||||||
ENET_PEER_TIMEOUT_MAXIMUM = 30000,
|
|
||||||
ENET_PEER_PING_INTERVAL = 500,
|
|
||||||
ENET_PEER_UNSEQUENCED_WINDOWS = 64,
|
|
||||||
ENET_PEER_UNSEQUENCED_WINDOW_SIZE = 1024,
|
|
||||||
ENET_PEER_FREE_UNSEQUENCED_WINDOWS = 32,
|
|
||||||
ENET_PEER_RELIABLE_WINDOWS = 16,
|
|
||||||
ENET_PEER_RELIABLE_WINDOW_SIZE = 0x1000,
|
|
||||||
ENET_PEER_FREE_RELIABLE_WINDOWS = 8
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef struct _ENetChannel
|
|
||||||
{
|
|
||||||
enet_uint16 outgoingReliableSequenceNumber;
|
|
||||||
enet_uint16 outgoingUnreliableSequenceNumber;
|
|
||||||
enet_uint16 usedReliableWindows;
|
|
||||||
enet_uint16 reliableWindows [ENET_PEER_RELIABLE_WINDOWS];
|
|
||||||
enet_uint16 incomingReliableSequenceNumber;
|
|
||||||
ENetList incomingReliableCommands;
|
|
||||||
ENetList incomingUnreliableCommands;
|
|
||||||
} ENetChannel;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* An ENet peer which data packets may be sent or received from.
|
|
||||||
*
|
|
||||||
* No fields should be modified unless otherwise specified.
|
|
||||||
*/
|
|
||||||
typedef struct _ENetPeer
|
|
||||||
{
|
|
||||||
struct _ENetHost * host;
|
|
||||||
enet_uint16 outgoingPeerID;
|
|
||||||
enet_uint16 incomingPeerID;
|
|
||||||
enet_uint32 sessionID;
|
|
||||||
ENetAddress address; /**< Internet address of the peer */
|
|
||||||
void * data; /**< Application private data, may be freely modified */
|
|
||||||
ENetPeerState state;
|
|
||||||
ENetChannel * channels;
|
|
||||||
size_t channelCount; /**< Number of channels allocated for communication with peer */
|
|
||||||
enet_uint32 incomingBandwidth; /**< Downstream bandwidth of the client in bytes/second */
|
|
||||||
enet_uint32 outgoingBandwidth; /**< Upstream bandwidth of the client in bytes/second */
|
|
||||||
enet_uint32 incomingBandwidthThrottleEpoch;
|
|
||||||
enet_uint32 outgoingBandwidthThrottleEpoch;
|
|
||||||
enet_uint32 incomingDataTotal;
|
|
||||||
enet_uint32 outgoingDataTotal;
|
|
||||||
enet_uint32 lastSendTime;
|
|
||||||
enet_uint32 lastReceiveTime;
|
|
||||||
enet_uint32 nextTimeout;
|
|
||||||
enet_uint32 earliestTimeout;
|
|
||||||
enet_uint32 packetLossEpoch;
|
|
||||||
enet_uint32 packetsSent;
|
|
||||||
enet_uint32 packetsLost;
|
|
||||||
enet_uint32 packetLoss; /**< mean packet loss of reliable packets as a ratio with respect to the constant ENET_PEER_PACKET_LOSS_SCALE */
|
|
||||||
enet_uint32 packetLossVariance;
|
|
||||||
enet_uint32 packetThrottle;
|
|
||||||
enet_uint32 packetThrottleLimit;
|
|
||||||
enet_uint32 packetThrottleCounter;
|
|
||||||
enet_uint32 packetThrottleEpoch;
|
|
||||||
enet_uint32 packetThrottleAcceleration;
|
|
||||||
enet_uint32 packetThrottleDeceleration;
|
|
||||||
enet_uint32 packetThrottleInterval;
|
|
||||||
enet_uint32 lastRoundTripTime;
|
|
||||||
enet_uint32 lowestRoundTripTime;
|
|
||||||
enet_uint32 lastRoundTripTimeVariance;
|
|
||||||
enet_uint32 highestRoundTripTimeVariance;
|
|
||||||
enet_uint32 roundTripTime; /**< mean round trip time (RTT), in milliseconds, between sending a reliable packet and receiving its acknowledgement */
|
|
||||||
enet_uint32 roundTripTimeVariance;
|
|
||||||
enet_uint16 mtu;
|
|
||||||
enet_uint32 windowSize;
|
|
||||||
enet_uint32 reliableDataInTransit;
|
|
||||||
enet_uint16 outgoingReliableSequenceNumber;
|
|
||||||
ENetList acknowledgements;
|
|
||||||
ENetList sentReliableCommands;
|
|
||||||
ENetList sentUnreliableCommands;
|
|
||||||
ENetList outgoingReliableCommands;
|
|
||||||
ENetList outgoingUnreliableCommands;
|
|
||||||
enet_uint16 incomingUnsequencedGroup;
|
|
||||||
enet_uint16 outgoingUnsequencedGroup;
|
|
||||||
enet_uint32 unsequencedWindow [ENET_PEER_UNSEQUENCED_WINDOW_SIZE / 32];
|
|
||||||
enet_uint32 disconnectData;
|
|
||||||
} ENetPeer;
|
|
||||||
|
|
||||||
/** An ENet host for communicating with peers.
|
|
||||||
*
|
|
||||||
* No fields should be modified.
|
|
||||||
|
|
||||||
@sa enet_host_create()
|
|
||||||
@sa enet_host_destroy()
|
|
||||||
@sa enet_host_connect()
|
|
||||||
@sa enet_host_service()
|
|
||||||
@sa enet_host_flush()
|
|
||||||
@sa enet_host_broadcast()
|
|
||||||
@sa enet_host_bandwidth_limit()
|
|
||||||
@sa enet_host_bandwidth_throttle()
|
|
||||||
*/
|
|
||||||
typedef struct _ENetHost
|
|
||||||
{
|
|
||||||
ENetSocket socket;
|
|
||||||
ENetAddress address; /**< Internet address of the host */
|
|
||||||
enet_uint32 incomingBandwidth; /**< downstream bandwidth of the host */
|
|
||||||
enet_uint32 outgoingBandwidth; /**< upstream bandwidth of the host */
|
|
||||||
enet_uint32 bandwidthThrottleEpoch;
|
|
||||||
enet_uint32 mtu;
|
|
||||||
int recalculateBandwidthLimits;
|
|
||||||
ENetPeer * peers; /**< array of peers allocated for this host */
|
|
||||||
size_t peerCount; /**< number of peers allocated for this host */
|
|
||||||
enet_uint32 serviceTime;
|
|
||||||
ENetPeer * lastServicedPeer;
|
|
||||||
int continueSending;
|
|
||||||
size_t packetSize;
|
|
||||||
enet_uint16 headerFlags;
|
|
||||||
ENetProtocol commands [ENET_PROTOCOL_MAXIMUM_PACKET_COMMANDS];
|
|
||||||
size_t commandCount;
|
|
||||||
ENetBuffer buffers [ENET_BUFFER_MAXIMUM];
|
|
||||||
size_t bufferCount;
|
|
||||||
ENetAddress receivedAddress;
|
|
||||||
enet_uint8 receivedData [ENET_PROTOCOL_MAXIMUM_MTU];
|
|
||||||
size_t receivedDataLength;
|
|
||||||
} ENetHost;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* An ENet event type, as specified in @ref ENetEvent.
|
|
||||||
*/
|
|
||||||
typedef enum
|
|
||||||
{
|
|
||||||
/** no event occurred within the specified time limit */
|
|
||||||
ENET_EVENT_TYPE_NONE = 0,
|
|
||||||
|
|
||||||
/** a connection request initiated by enet_host_connect has completed.
|
|
||||||
* The peer field contains the peer which successfully connected.
|
|
||||||
*/
|
|
||||||
ENET_EVENT_TYPE_CONNECT = 1,
|
|
||||||
|
|
||||||
/** a peer has disconnected. This event is generated on a successful
|
|
||||||
* completion of a disconnect initiated by enet_pper_disconnect, if
|
|
||||||
* a peer has timed out, or if a connection request intialized by
|
|
||||||
* enet_host_connect has timed out. The peer field contains the peer
|
|
||||||
* which disconnected. The data field contains user supplied data
|
|
||||||
* describing the disconnection, or 0, if none is available.
|
|
||||||
*/
|
|
||||||
ENET_EVENT_TYPE_DISCONNECT = 2,
|
|
||||||
|
|
||||||
/** a packet has been received from a peer. The peer field specifies the
|
|
||||||
* peer which sent the packet. The channelID field specifies the channel
|
|
||||||
* number upon which the packet was received. The packet field contains
|
|
||||||
* the packet that was received; this packet must be destroyed with
|
|
||||||
* enet_packet_destroy after use.
|
|
||||||
*/
|
|
||||||
ENET_EVENT_TYPE_RECEIVE = 3
|
|
||||||
} ENetEventType;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* An ENet event as returned by enet_host_service().
|
|
||||||
|
|
||||||
@sa enet_host_service
|
|
||||||
*/
|
|
||||||
typedef struct _ENetEvent
|
|
||||||
{
|
|
||||||
ENetEventType type; /**< type of the event */
|
|
||||||
ENetPeer * peer; /**< peer that generated a connect, disconnect or receive event */
|
|
||||||
enet_uint8 channelID; /**< channel on the peer that generated the event, if appropriate */
|
|
||||||
enet_uint32 data; /**< data associated with the event, if appropriate */
|
|
||||||
ENetPacket * packet; /**< packet associated with the event, if appropriate */
|
|
||||||
} ENetEvent;
|
|
||||||
|
|
||||||
/** @defgroup global ENet global functions
|
|
||||||
@{
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
Initializes ENet globally. Must be called prior to using any functions in
|
|
||||||
ENet.
|
|
||||||
@returns 0 on success, < 0 on failure
|
|
||||||
*/
|
|
||||||
ENET_API int enet_initialize (void);
|
|
||||||
|
|
||||||
/**
|
|
||||||
Initializes ENet globally and supplies user-overridden callbacks. Must be called prior to using any functions in ENet. Do not use enet_initialize() if you use this variant.
|
|
||||||
|
|
||||||
@param version the constant ENET_VERSION should be supplied so ENet knows which version of ENetCallbacks struct to use
|
|
||||||
@param inits user-overriden callbacks where any NULL callbacks will use ENet's defaults
|
|
||||||
@returns 0 on success, < 0 on failure
|
|
||||||
*/
|
|
||||||
ENET_API int enet_initialize_with_callbacks (ENetVersion version, const ENetCallbacks * inits);
|
|
||||||
|
|
||||||
/**
|
|
||||||
Shuts down ENet globally. Should be called when a program that has
|
|
||||||
initialized ENet exits.
|
|
||||||
*/
|
|
||||||
ENET_API void enet_deinitialize (void);
|
|
||||||
|
|
||||||
/** @} */
|
|
||||||
|
|
||||||
/** @defgroup private ENet private implementation functions */
|
|
||||||
|
|
||||||
/**
|
|
||||||
Returns the wall-time in milliseconds. Its initial value is unspecified
|
|
||||||
unless otherwise set.
|
|
||||||
*/
|
|
||||||
ENET_API enet_uint32 enet_time_get (void);
|
|
||||||
/**
|
|
||||||
Sets the current wall-time in milliseconds.
|
|
||||||
*/
|
|
||||||
ENET_API void enet_time_set (enet_uint32);
|
|
||||||
|
|
||||||
/** @defgroup socket ENet socket functions
|
|
||||||
@{
|
|
||||||
*/
|
|
||||||
ENET_API ENetSocket enet_socket_create (ENetSocketType, const ENetAddress *);
|
|
||||||
ENET_API ENetSocket enet_socket_accept (ENetSocket, ENetAddress *);
|
|
||||||
ENET_API int enet_socket_connect (ENetSocket, const ENetAddress *);
|
|
||||||
ENET_API int enet_socket_send (ENetSocket, const ENetAddress *, const ENetBuffer *, size_t);
|
|
||||||
ENET_API int enet_socket_receive (ENetSocket, ENetAddress *, ENetBuffer *, size_t);
|
|
||||||
ENET_API int enet_socket_wait (ENetSocket, enet_uint32 *, enet_uint32);
|
|
||||||
ENET_API int enet_socket_set_option (ENetSocket, ENetSocketOption, int);
|
|
||||||
ENET_API void enet_socket_destroy (ENetSocket);
|
|
||||||
|
|
||||||
/** @} */
|
|
||||||
|
|
||||||
/** @defgroup Address ENet address functions
|
|
||||||
@{
|
|
||||||
*/
|
|
||||||
/** Attempts to resolve the host named by the parameter hostName and sets
|
|
||||||
the host field in the address parameter if successful.
|
|
||||||
@param address destination to store resolved address
|
|
||||||
@param hostName host name to lookup
|
|
||||||
@retval 0 on success
|
|
||||||
@retval < 0 on failure
|
|
||||||
@returns the address of the given hostName in address on success
|
|
||||||
*/
|
|
||||||
ENET_API int enet_address_set_host (ENetAddress * address, const char * hostName);
|
|
||||||
|
|
||||||
/** Gives the printable form of the ip address specified in the address parameter.
|
|
||||||
@param address address printed
|
|
||||||
@param hostName destination for name, must not be NULL
|
|
||||||
@param nameLength maximum length of hostName.
|
|
||||||
@returns the null-terminated name of the host in hostName on success
|
|
||||||
@retval 0 on success
|
|
||||||
@retval < 0 on failure
|
|
||||||
*/
|
|
||||||
ENET_API int enet_address_get_host_ip (const ENetAddress * address, char * hostName, size_t nameLength);
|
|
||||||
|
|
||||||
/** Attempts to do a reverse lookup of the host field in the address parameter.
|
|
||||||
@param address address used for reverse lookup
|
|
||||||
@param hostName destination for name, must not be NULL
|
|
||||||
@param nameLength maximum length of hostName.
|
|
||||||
@returns the null-terminated name of the host in hostName on success
|
|
||||||
@retval 0 on success
|
|
||||||
@retval < 0 on failure
|
|
||||||
*/
|
|
||||||
ENET_API int enet_address_get_host (const ENetAddress * address, char * hostName, size_t nameLength);
|
|
||||||
|
|
||||||
/** @} */
|
|
||||||
|
|
||||||
ENET_API ENetPacket * enet_packet_create (const void *, size_t, enet_uint32);
|
|
||||||
ENET_API void enet_packet_destroy (ENetPacket *);
|
|
||||||
ENET_API int enet_packet_resize (ENetPacket *, size_t);
|
|
||||||
extern enet_uint32 enet_crc32 (const ENetBuffer *, size_t);
|
|
||||||
|
|
||||||
ENET_API ENetHost * enet_host_create (const ENetAddress *, size_t, enet_uint32, enet_uint32);
|
|
||||||
ENET_API void enet_host_destroy (ENetHost *);
|
|
||||||
ENET_API ENetPeer * enet_host_connect (ENetHost *, const ENetAddress *, size_t);
|
|
||||||
ENET_API int enet_host_check_events (ENetHost *, ENetEvent *);
|
|
||||||
ENET_API int enet_host_service (ENetHost *, ENetEvent *, enet_uint32);
|
|
||||||
ENET_API void enet_host_flush (ENetHost *);
|
|
||||||
ENET_API void enet_host_broadcast (ENetHost *, enet_uint8, ENetPacket *);
|
|
||||||
ENET_API void enet_host_bandwidth_limit (ENetHost *, enet_uint32, enet_uint32);
|
|
||||||
extern void enet_host_bandwidth_throttle (ENetHost *);
|
|
||||||
|
|
||||||
ENET_API int enet_peer_send (ENetPeer *, enet_uint8, ENetPacket *);
|
|
||||||
ENET_API ENetPacket * enet_peer_receive (ENetPeer *, enet_uint8);
|
|
||||||
ENET_API void enet_peer_ping (ENetPeer *);
|
|
||||||
ENET_API void enet_peer_reset (ENetPeer *);
|
|
||||||
ENET_API void enet_peer_disconnect (ENetPeer *, enet_uint32);
|
|
||||||
ENET_API void enet_peer_disconnect_now (ENetPeer *, enet_uint32);
|
|
||||||
ENET_API void enet_peer_disconnect_later (ENetPeer *, enet_uint32);
|
|
||||||
ENET_API void enet_peer_throttle_configure (ENetPeer *, enet_uint32, enet_uint32, enet_uint32);
|
|
||||||
extern int enet_peer_throttle (ENetPeer *, enet_uint32);
|
|
||||||
extern void enet_peer_reset_queues (ENetPeer *);
|
|
||||||
extern ENetOutgoingCommand * enet_peer_queue_outgoing_command (ENetPeer *, const ENetProtocol *, ENetPacket *, enet_uint32, enet_uint16);
|
|
||||||
extern ENetIncomingCommand * enet_peer_queue_incoming_command (ENetPeer *, const ENetProtocol *, ENetPacket *, enet_uint32);
|
|
||||||
extern ENetAcknowledgement * enet_peer_queue_acknowledgement (ENetPeer *, const ENetProtocol *, enet_uint16);
|
|
||||||
|
|
||||||
extern size_t enet_protocol_command_size (enet_uint8);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* __ENET_ENET_H__ */
|
|
||||||
|
|
|
@ -1,42 +0,0 @@
|
||||||
/**
|
|
||||||
@file list.h
|
|
||||||
@brief ENet list management
|
|
||||||
*/
|
|
||||||
#ifndef __ENET_LIST_H__
|
|
||||||
#define __ENET_LIST_H__
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
|
|
||||||
typedef struct _ENetListNode
|
|
||||||
{
|
|
||||||
struct _ENetListNode * next;
|
|
||||||
struct _ENetListNode * previous;
|
|
||||||
} ENetListNode;
|
|
||||||
|
|
||||||
typedef ENetListNode * ENetListIterator;
|
|
||||||
|
|
||||||
typedef struct _ENetList
|
|
||||||
{
|
|
||||||
ENetListNode sentinel;
|
|
||||||
} ENetList;
|
|
||||||
|
|
||||||
extern void enet_list_clear (ENetList *);
|
|
||||||
|
|
||||||
extern ENetListIterator enet_list_insert (ENetListIterator, void *);
|
|
||||||
extern void * enet_list_remove (ENetListIterator);
|
|
||||||
|
|
||||||
extern size_t enet_list_size (ENetList *);
|
|
||||||
|
|
||||||
#define enet_list_begin(list) ((list) -> sentinel.next)
|
|
||||||
#define enet_list_end(list) (& (list) -> sentinel)
|
|
||||||
|
|
||||||
#define enet_list_empty(list) (enet_list_begin (list) == enet_list_end (list))
|
|
||||||
|
|
||||||
#define enet_list_next(iterator) ((iterator) -> next)
|
|
||||||
#define enet_list_previous(iterator) ((iterator) -> previous)
|
|
||||||
|
|
||||||
#define enet_list_front(list) ((void *) (list) -> sentinel.next)
|
|
||||||
#define enet_list_back(list) ((void *) (list) -> sentinel.previous)
|
|
||||||
|
|
||||||
#endif /* __ENET_LIST_H__ */
|
|
||||||
|
|
|
@ -1,174 +0,0 @@
|
||||||
/**
|
|
||||||
@file protocol.h
|
|
||||||
@brief ENet protocol
|
|
||||||
*/
|
|
||||||
#ifndef __ENET_PROTOCOL_H__
|
|
||||||
#define __ENET_PROTOCOL_H__
|
|
||||||
|
|
||||||
#include "enet/types.h"
|
|
||||||
|
|
||||||
enum
|
|
||||||
{
|
|
||||||
ENET_PROTOCOL_MINIMUM_MTU = 576,
|
|
||||||
ENET_PROTOCOL_MAXIMUM_MTU = 4096,
|
|
||||||
ENET_PROTOCOL_MAXIMUM_PACKET_COMMANDS = 32,
|
|
||||||
ENET_PROTOCOL_MINIMUM_WINDOW_SIZE = 4096,
|
|
||||||
ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE = 32768,
|
|
||||||
ENET_PROTOCOL_MINIMUM_CHANNEL_COUNT = 1,
|
|
||||||
ENET_PROTOCOL_MAXIMUM_CHANNEL_COUNT = 255,
|
|
||||||
ENET_PROTOCOL_MAXIMUM_PEER_ID = 0x7FFF
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef enum
|
|
||||||
{
|
|
||||||
ENET_PROTOCOL_COMMAND_NONE = 0,
|
|
||||||
ENET_PROTOCOL_COMMAND_ACKNOWLEDGE = 1,
|
|
||||||
ENET_PROTOCOL_COMMAND_CONNECT = 2,
|
|
||||||
ENET_PROTOCOL_COMMAND_VERIFY_CONNECT = 3,
|
|
||||||
ENET_PROTOCOL_COMMAND_DISCONNECT = 4,
|
|
||||||
ENET_PROTOCOL_COMMAND_PING = 5,
|
|
||||||
ENET_PROTOCOL_COMMAND_SEND_RELIABLE = 6,
|
|
||||||
ENET_PROTOCOL_COMMAND_SEND_UNRELIABLE = 7,
|
|
||||||
ENET_PROTOCOL_COMMAND_SEND_FRAGMENT = 8,
|
|
||||||
ENET_PROTOCOL_COMMAND_SEND_UNSEQUENCED = 9,
|
|
||||||
ENET_PROTOCOL_COMMAND_BANDWIDTH_LIMIT = 10,
|
|
||||||
ENET_PROTOCOL_COMMAND_THROTTLE_CONFIGURE = 11,
|
|
||||||
ENET_PROTOCOL_COMMAND_COUNT = 12,
|
|
||||||
|
|
||||||
ENET_PROTOCOL_COMMAND_MASK = 0x0F
|
|
||||||
} ENetProtocolCommand;
|
|
||||||
|
|
||||||
typedef enum
|
|
||||||
{
|
|
||||||
ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE = (1 << 7),
|
|
||||||
ENET_PROTOCOL_COMMAND_FLAG_UNSEQUENCED = (1 << 6),
|
|
||||||
|
|
||||||
ENET_PROTOCOL_HEADER_FLAG_SENT_TIME = (1 << 15),
|
|
||||||
ENET_PROTOCOL_HEADER_FLAG_MASK = 0x8000
|
|
||||||
} ENetProtocolFlag;
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
enet_uint32 checksum;
|
|
||||||
enet_uint16 peerID;
|
|
||||||
enet_uint16 sentTime;
|
|
||||||
} ENetProtocolHeader;
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
enet_uint8 command;
|
|
||||||
enet_uint8 channelID;
|
|
||||||
enet_uint16 reliableSequenceNumber;
|
|
||||||
} ENetProtocolCommandHeader;
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
ENetProtocolCommandHeader header;
|
|
||||||
enet_uint16 receivedReliableSequenceNumber;
|
|
||||||
enet_uint16 receivedSentTime;
|
|
||||||
} ENetProtocolAcknowledge;
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
ENetProtocolCommandHeader header;
|
|
||||||
enet_uint16 outgoingPeerID;
|
|
||||||
enet_uint16 mtu;
|
|
||||||
enet_uint32 windowSize;
|
|
||||||
enet_uint32 channelCount;
|
|
||||||
enet_uint32 incomingBandwidth;
|
|
||||||
enet_uint32 outgoingBandwidth;
|
|
||||||
enet_uint32 packetThrottleInterval;
|
|
||||||
enet_uint32 packetThrottleAcceleration;
|
|
||||||
enet_uint32 packetThrottleDeceleration;
|
|
||||||
enet_uint32 sessionID;
|
|
||||||
} ENetProtocolConnect;
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
ENetProtocolCommandHeader header;
|
|
||||||
enet_uint16 outgoingPeerID;
|
|
||||||
enet_uint16 mtu;
|
|
||||||
enet_uint32 windowSize;
|
|
||||||
enet_uint32 channelCount;
|
|
||||||
enet_uint32 incomingBandwidth;
|
|
||||||
enet_uint32 outgoingBandwidth;
|
|
||||||
enet_uint32 packetThrottleInterval;
|
|
||||||
enet_uint32 packetThrottleAcceleration;
|
|
||||||
enet_uint32 packetThrottleDeceleration;
|
|
||||||
} ENetProtocolVerifyConnect;
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
ENetProtocolCommandHeader header;
|
|
||||||
enet_uint32 incomingBandwidth;
|
|
||||||
enet_uint32 outgoingBandwidth;
|
|
||||||
} ENetProtocolBandwidthLimit;
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
ENetProtocolCommandHeader header;
|
|
||||||
enet_uint32 packetThrottleInterval;
|
|
||||||
enet_uint32 packetThrottleAcceleration;
|
|
||||||
enet_uint32 packetThrottleDeceleration;
|
|
||||||
} ENetProtocolThrottleConfigure;
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
ENetProtocolCommandHeader header;
|
|
||||||
enet_uint32 data;
|
|
||||||
} ENetProtocolDisconnect;
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
ENetProtocolCommandHeader header;
|
|
||||||
} ENetProtocolPing;
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
ENetProtocolCommandHeader header;
|
|
||||||
enet_uint16 dataLength;
|
|
||||||
} ENetProtocolSendReliable;
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
ENetProtocolCommandHeader header;
|
|
||||||
enet_uint16 unreliableSequenceNumber;
|
|
||||||
enet_uint16 dataLength;
|
|
||||||
} ENetProtocolSendUnreliable;
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
ENetProtocolCommandHeader header;
|
|
||||||
enet_uint16 unsequencedGroup;
|
|
||||||
enet_uint16 dataLength;
|
|
||||||
} ENetProtocolSendUnsequenced;
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
ENetProtocolCommandHeader header;
|
|
||||||
enet_uint16 startSequenceNumber;
|
|
||||||
enet_uint16 dataLength;
|
|
||||||
enet_uint32 fragmentCount;
|
|
||||||
enet_uint32 fragmentNumber;
|
|
||||||
enet_uint32 totalLength;
|
|
||||||
enet_uint32 fragmentOffset;
|
|
||||||
} ENetProtocolSendFragment;
|
|
||||||
|
|
||||||
typedef union
|
|
||||||
{
|
|
||||||
ENetProtocolCommandHeader header;
|
|
||||||
ENetProtocolAcknowledge acknowledge;
|
|
||||||
ENetProtocolConnect connect;
|
|
||||||
ENetProtocolVerifyConnect verifyConnect;
|
|
||||||
ENetProtocolDisconnect disconnect;
|
|
||||||
ENetProtocolPing ping;
|
|
||||||
ENetProtocolSendReliable sendReliable;
|
|
||||||
ENetProtocolSendUnreliable sendUnreliable;
|
|
||||||
ENetProtocolSendUnsequenced sendUnsequenced;
|
|
||||||
ENetProtocolSendFragment sendFragment;
|
|
||||||
ENetProtocolBandwidthLimit bandwidthLimit;
|
|
||||||
ENetProtocolThrottleConfigure throttleConfigure;
|
|
||||||
} ENetProtocol;
|
|
||||||
|
|
||||||
#endif /* __ENET_PROTOCOL_H__ */
|
|
||||||
|
|
|
@ -1,18 +0,0 @@
|
||||||
/**
|
|
||||||
@file time.h
|
|
||||||
@brief ENet time constants and macros
|
|
||||||
*/
|
|
||||||
#ifndef __ENET_TIME_H__
|
|
||||||
#define __ENET_TIME_H__
|
|
||||||
|
|
||||||
#define ENET_TIME_OVERFLOW 86400000
|
|
||||||
|
|
||||||
#define ENET_TIME_LESS(a, b) ((a) - (b) >= ENET_TIME_OVERFLOW)
|
|
||||||
#define ENET_TIME_GREATER(a, b) ((b) - (a) >= ENET_TIME_OVERFLOW)
|
|
||||||
#define ENET_TIME_LESS_EQUAL(a, b) (! ENET_TIME_GREATER (a, b))
|
|
||||||
#define ENET_TIME_GREATER_EQUAL(a, b) (! ENET_TIME_LESS (a, b))
|
|
||||||
|
|
||||||
#define ENET_TIME_DIFFERENCE(a, b) ((a) - (b) >= ENET_TIME_OVERFLOW ? (b) - (a) : (a) - (b))
|
|
||||||
|
|
||||||
#endif /* __ENET_TIME_H__ */
|
|
||||||
|
|
|
@ -1,13 +0,0 @@
|
||||||
/**
|
|
||||||
@file types.h
|
|
||||||
@brief type definitions for ENet
|
|
||||||
*/
|
|
||||||
#ifndef __ENET_TYPES_H__
|
|
||||||
#define __ENET_TYPES_H__
|
|
||||||
|
|
||||||
typedef unsigned char enet_uint8; /**< unsigned 8-bit type */
|
|
||||||
typedef unsigned short enet_uint16; /**< unsigned 16-bit type */
|
|
||||||
typedef unsigned int enet_uint32; /**< unsigned 32-bit type */
|
|
||||||
|
|
||||||
#endif /* __ENET_TYPES_H__ */
|
|
||||||
|
|
|
@ -1,36 +0,0 @@
|
||||||
/**
|
|
||||||
@file unix.h
|
|
||||||
@brief ENet Unix header
|
|
||||||
*/
|
|
||||||
#ifndef __ENET_UNIX_H__
|
|
||||||
#define __ENET_UNIX_H__
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <netinet/in.h>
|
|
||||||
|
|
||||||
typedef int ENetSocket;
|
|
||||||
|
|
||||||
enum
|
|
||||||
{
|
|
||||||
ENET_SOCKET_NULL = -1
|
|
||||||
};
|
|
||||||
|
|
||||||
#define ENET_HOST_TO_NET_16(value) (htons (value)) /**< macro that converts host to net byte-order of a 16-bit value */
|
|
||||||
#define ENET_HOST_TO_NET_32(value) (htonl (value)) /**< macro that converts host to net byte-order of a 32-bit value */
|
|
||||||
|
|
||||||
#define ENET_NET_TO_HOST_16(value) (ntohs (value)) /**< macro that converts net to host byte-order of a 16-bit value */
|
|
||||||
#define ENET_NET_TO_HOST_32(value) (ntohl (value)) /**< macro that converts net to host byte-order of a 32-bit value */
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
void * data;
|
|
||||||
size_t dataLength;
|
|
||||||
} ENetBuffer;
|
|
||||||
|
|
||||||
#define ENET_CALLBACK
|
|
||||||
|
|
||||||
#define ENET_API extern
|
|
||||||
|
|
||||||
#endif /* __ENET_UNIX_H__ */
|
|
||||||
|
|
|
@ -1,12 +0,0 @@
|
||||||
/**
|
|
||||||
@file utility.h
|
|
||||||
@brief ENet utility header
|
|
||||||
*/
|
|
||||||
#ifndef __ENET_UTILITY_H__
|
|
||||||
#define __ENET_UTILITY_H__
|
|
||||||
|
|
||||||
#define ENET_MAX(x, y) ((x) > (y) ? (x) : (y))
|
|
||||||
#define ENET_MIN(x, y) ((x) < (y) ? (x) : (y))
|
|
||||||
|
|
||||||
#endif /* __ENET_UTILITY_H__ */
|
|
||||||
|
|
|
@ -1,51 +0,0 @@
|
||||||
/**
|
|
||||||
@file win32.h
|
|
||||||
@brief ENet Win32 header
|
|
||||||
*/
|
|
||||||
#ifndef __ENET_WIN32_H__
|
|
||||||
#define __ENET_WIN32_H__
|
|
||||||
|
|
||||||
#ifdef ENET_BUILDING_LIB
|
|
||||||
#pragma warning (disable: 4996) // 'strncpy' was declared deprecated
|
|
||||||
#pragma warning (disable: 4267) // size_t to int conversion
|
|
||||||
#pragma warning (disable: 4244) // 64bit to 32bit int
|
|
||||||
#pragma warning (disable: 4018) // signed/unsigned mismatch
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <winsock2.h>
|
|
||||||
|
|
||||||
typedef SOCKET ENetSocket;
|
|
||||||
|
|
||||||
enum
|
|
||||||
{
|
|
||||||
ENET_SOCKET_NULL = INVALID_SOCKET
|
|
||||||
};
|
|
||||||
|
|
||||||
#define ENET_HOST_TO_NET_16(value) (htons (value))
|
|
||||||
#define ENET_HOST_TO_NET_32(value) (htonl (value))
|
|
||||||
|
|
||||||
#define ENET_NET_TO_HOST_16(value) (ntohs (value))
|
|
||||||
#define ENET_NET_TO_HOST_32(value) (ntohl (value))
|
|
||||||
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
size_t dataLength;
|
|
||||||
void * data;
|
|
||||||
} ENetBuffer;
|
|
||||||
|
|
||||||
#define ENET_CALLBACK __cdecl
|
|
||||||
|
|
||||||
#if defined ENET_DLL
|
|
||||||
#if defined ENET_BUILDING_LIB
|
|
||||||
#define ENET_API __declspec( dllexport )
|
|
||||||
#else
|
|
||||||
#define ENET_API __declspec( dllimport )
|
|
||||||
#endif /* ENET_BUILDING_LIB */
|
|
||||||
#else /* !ENET_DLL */
|
|
||||||
#define ENET_API extern
|
|
||||||
#endif /* ENET_DLL */
|
|
||||||
|
|
||||||
#endif /* __ENET_WIN32_H__ */
|
|
||||||
|
|
||||||
|
|
|
@ -1,323 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
# install - install a program, script, or datafile
|
|
||||||
|
|
||||||
scriptversion=2005-05-14.22
|
|
||||||
|
|
||||||
# This originates from X11R5 (mit/util/scripts/install.sh), which was
|
|
||||||
# later released in X11R6 (xc/config/util/install.sh) with the
|
|
||||||
# following copyright and license.
|
|
||||||
#
|
|
||||||
# Copyright (C) 1994 X Consortium
|
|
||||||
#
|
|
||||||
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
# of this software and associated documentation files (the "Software"), to
|
|
||||||
# deal in the Software without restriction, including without limitation the
|
|
||||||
# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
|
||||||
# sell copies of the Software, and to permit persons to whom the Software is
|
|
||||||
# furnished to do so, subject to the following conditions:
|
|
||||||
#
|
|
||||||
# The above copyright notice and this permission notice shall be included in
|
|
||||||
# all copies or substantial portions of the Software.
|
|
||||||
#
|
|
||||||
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
# X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
|
|
||||||
# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC-
|
|
||||||
# TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
#
|
|
||||||
# Except as contained in this notice, the name of the X Consortium shall not
|
|
||||||
# be used in advertising or otherwise to promote the sale, use or other deal-
|
|
||||||
# ings in this Software without prior written authorization from the X Consor-
|
|
||||||
# tium.
|
|
||||||
#
|
|
||||||
#
|
|
||||||
# FSF changes to this file are in the public domain.
|
|
||||||
#
|
|
||||||
# Calling this script install-sh is preferred over install.sh, to prevent
|
|
||||||
# `make' implicit rules from creating a file called install from it
|
|
||||||
# when there is no Makefile.
|
|
||||||
#
|
|
||||||
# This script is compatible with the BSD install script, but was written
|
|
||||||
# from scratch. It can only install one file at a time, a restriction
|
|
||||||
# shared with many OS's install programs.
|
|
||||||
|
|
||||||
# set DOITPROG to echo to test this script
|
|
||||||
|
|
||||||
# Don't use :- since 4.3BSD and earlier shells don't like it.
|
|
||||||
doit="${DOITPROG-}"
|
|
||||||
|
|
||||||
# put in absolute paths if you don't have them in your path; or use env. vars.
|
|
||||||
|
|
||||||
mvprog="${MVPROG-mv}"
|
|
||||||
cpprog="${CPPROG-cp}"
|
|
||||||
chmodprog="${CHMODPROG-chmod}"
|
|
||||||
chownprog="${CHOWNPROG-chown}"
|
|
||||||
chgrpprog="${CHGRPPROG-chgrp}"
|
|
||||||
stripprog="${STRIPPROG-strip}"
|
|
||||||
rmprog="${RMPROG-rm}"
|
|
||||||
mkdirprog="${MKDIRPROG-mkdir}"
|
|
||||||
|
|
||||||
chmodcmd="$chmodprog 0755"
|
|
||||||
chowncmd=
|
|
||||||
chgrpcmd=
|
|
||||||
stripcmd=
|
|
||||||
rmcmd="$rmprog -f"
|
|
||||||
mvcmd="$mvprog"
|
|
||||||
src=
|
|
||||||
dst=
|
|
||||||
dir_arg=
|
|
||||||
dstarg=
|
|
||||||
no_target_directory=
|
|
||||||
|
|
||||||
usage="Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE
|
|
||||||
or: $0 [OPTION]... SRCFILES... DIRECTORY
|
|
||||||
or: $0 [OPTION]... -t DIRECTORY SRCFILES...
|
|
||||||
or: $0 [OPTION]... -d DIRECTORIES...
|
|
||||||
|
|
||||||
In the 1st form, copy SRCFILE to DSTFILE.
|
|
||||||
In the 2nd and 3rd, copy all SRCFILES to DIRECTORY.
|
|
||||||
In the 4th, create DIRECTORIES.
|
|
||||||
|
|
||||||
Options:
|
|
||||||
-c (ignored)
|
|
||||||
-d create directories instead of installing files.
|
|
||||||
-g GROUP $chgrpprog installed files to GROUP.
|
|
||||||
-m MODE $chmodprog installed files to MODE.
|
|
||||||
-o USER $chownprog installed files to USER.
|
|
||||||
-s $stripprog installed files.
|
|
||||||
-t DIRECTORY install into DIRECTORY.
|
|
||||||
-T report an error if DSTFILE is a directory.
|
|
||||||
--help display this help and exit.
|
|
||||||
--version display version info and exit.
|
|
||||||
|
|
||||||
Environment variables override the default commands:
|
|
||||||
CHGRPPROG CHMODPROG CHOWNPROG CPPROG MKDIRPROG MVPROG RMPROG STRIPPROG
|
|
||||||
"
|
|
||||||
|
|
||||||
while test -n "$1"; do
|
|
||||||
case $1 in
|
|
||||||
-c) shift
|
|
||||||
continue;;
|
|
||||||
|
|
||||||
-d) dir_arg=true
|
|
||||||
shift
|
|
||||||
continue;;
|
|
||||||
|
|
||||||
-g) chgrpcmd="$chgrpprog $2"
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
continue;;
|
|
||||||
|
|
||||||
--help) echo "$usage"; exit $?;;
|
|
||||||
|
|
||||||
-m) chmodcmd="$chmodprog $2"
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
continue;;
|
|
||||||
|
|
||||||
-o) chowncmd="$chownprog $2"
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
continue;;
|
|
||||||
|
|
||||||
-s) stripcmd=$stripprog
|
|
||||||
shift
|
|
||||||
continue;;
|
|
||||||
|
|
||||||
-t) dstarg=$2
|
|
||||||
shift
|
|
||||||
shift
|
|
||||||
continue;;
|
|
||||||
|
|
||||||
-T) no_target_directory=true
|
|
||||||
shift
|
|
||||||
continue;;
|
|
||||||
|
|
||||||
--version) echo "$0 $scriptversion"; exit $?;;
|
|
||||||
|
|
||||||
*) # When -d is used, all remaining arguments are directories to create.
|
|
||||||
# When -t is used, the destination is already specified.
|
|
||||||
test -n "$dir_arg$dstarg" && break
|
|
||||||
# Otherwise, the last argument is the destination. Remove it from $@.
|
|
||||||
for arg
|
|
||||||
do
|
|
||||||
if test -n "$dstarg"; then
|
|
||||||
# $@ is not empty: it contains at least $arg.
|
|
||||||
set fnord "$@" "$dstarg"
|
|
||||||
shift # fnord
|
|
||||||
fi
|
|
||||||
shift # arg
|
|
||||||
dstarg=$arg
|
|
||||||
done
|
|
||||||
break;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
|
|
||||||
if test -z "$1"; then
|
|
||||||
if test -z "$dir_arg"; then
|
|
||||||
echo "$0: no input file specified." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
# It's OK to call `install-sh -d' without argument.
|
|
||||||
# This can happen when creating conditional directories.
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
for src
|
|
||||||
do
|
|
||||||
# Protect names starting with `-'.
|
|
||||||
case $src in
|
|
||||||
-*) src=./$src ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if test -n "$dir_arg"; then
|
|
||||||
dst=$src
|
|
||||||
src=
|
|
||||||
|
|
||||||
if test -d "$dst"; then
|
|
||||||
mkdircmd=:
|
|
||||||
chmodcmd=
|
|
||||||
else
|
|
||||||
mkdircmd=$mkdirprog
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
# Waiting for this to be detected by the "$cpprog $src $dsttmp" command
|
|
||||||
# might cause directories to be created, which would be especially bad
|
|
||||||
# if $src (and thus $dsttmp) contains '*'.
|
|
||||||
if test ! -f "$src" && test ! -d "$src"; then
|
|
||||||
echo "$0: $src does not exist." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test -z "$dstarg"; then
|
|
||||||
echo "$0: no destination specified." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
dst=$dstarg
|
|
||||||
# Protect names starting with `-'.
|
|
||||||
case $dst in
|
|
||||||
-*) dst=./$dst ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# If destination is a directory, append the input filename; won't work
|
|
||||||
# if double slashes aren't ignored.
|
|
||||||
if test -d "$dst"; then
|
|
||||||
if test -n "$no_target_directory"; then
|
|
||||||
echo "$0: $dstarg: Is a directory" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
dst=$dst/`basename "$src"`
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
# This sed command emulates the dirname command.
|
|
||||||
dstdir=`echo "$dst" | sed -e 's,/*$,,;s,[^/]*$,,;s,/*$,,;s,^$,.,'`
|
|
||||||
|
|
||||||
# Make sure that the destination directory exists.
|
|
||||||
|
|
||||||
# Skip lots of stat calls in the usual case.
|
|
||||||
if test ! -d "$dstdir"; then
|
|
||||||
defaultIFS='
|
|
||||||
'
|
|
||||||
IFS="${IFS-$defaultIFS}"
|
|
||||||
|
|
||||||
oIFS=$IFS
|
|
||||||
# Some sh's can't handle IFS=/ for some reason.
|
|
||||||
IFS='%'
|
|
||||||
set x `echo "$dstdir" | sed -e 's@/@%@g' -e 's@^%@/@'`
|
|
||||||
shift
|
|
||||||
IFS=$oIFS
|
|
||||||
|
|
||||||
pathcomp=
|
|
||||||
|
|
||||||
while test $# -ne 0 ; do
|
|
||||||
pathcomp=$pathcomp$1
|
|
||||||
shift
|
|
||||||
if test ! -d "$pathcomp"; then
|
|
||||||
$mkdirprog "$pathcomp"
|
|
||||||
# mkdir can fail with a `File exist' error in case several
|
|
||||||
# install-sh are creating the directory concurrently. This
|
|
||||||
# is OK.
|
|
||||||
test -d "$pathcomp" || exit
|
|
||||||
fi
|
|
||||||
pathcomp=$pathcomp/
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test -n "$dir_arg"; then
|
|
||||||
$doit $mkdircmd "$dst" \
|
|
||||||
&& { test -z "$chowncmd" || $doit $chowncmd "$dst"; } \
|
|
||||||
&& { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } \
|
|
||||||
&& { test -z "$stripcmd" || $doit $stripcmd "$dst"; } \
|
|
||||||
&& { test -z "$chmodcmd" || $doit $chmodcmd "$dst"; }
|
|
||||||
|
|
||||||
else
|
|
||||||
dstfile=`basename "$dst"`
|
|
||||||
|
|
||||||
# Make a couple of temp file names in the proper directory.
|
|
||||||
dsttmp=$dstdir/_inst.$$_
|
|
||||||
rmtmp=$dstdir/_rm.$$_
|
|
||||||
|
|
||||||
# Trap to clean up those temp files at exit.
|
|
||||||
trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0
|
|
||||||
trap '(exit $?); exit' 1 2 13 15
|
|
||||||
|
|
||||||
# Copy the file name to the temp name.
|
|
||||||
$doit $cpprog "$src" "$dsttmp" &&
|
|
||||||
|
|
||||||
# and set any options; do chmod last to preserve setuid bits.
|
|
||||||
#
|
|
||||||
# If any of these fail, we abort the whole thing. If we want to
|
|
||||||
# ignore errors from any of these, just make sure not to ignore
|
|
||||||
# errors from the above "$doit $cpprog $src $dsttmp" command.
|
|
||||||
#
|
|
||||||
{ test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } \
|
|
||||||
&& { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } \
|
|
||||||
&& { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } \
|
|
||||||
&& { test -z "$chmodcmd" || $doit $chmodcmd "$dsttmp"; } &&
|
|
||||||
|
|
||||||
# Now rename the file to the real destination.
|
|
||||||
{ $doit $mvcmd -f "$dsttmp" "$dstdir/$dstfile" 2>/dev/null \
|
|
||||||
|| {
|
|
||||||
# The rename failed, perhaps because mv can't rename something else
|
|
||||||
# to itself, or perhaps because mv is so ancient that it does not
|
|
||||||
# support -f.
|
|
||||||
|
|
||||||
# Now remove or move aside any old file at destination location.
|
|
||||||
# We try this two ways since rm can't unlink itself on some
|
|
||||||
# systems and the destination file might be busy for other
|
|
||||||
# reasons. In this case, the final cleanup might fail but the new
|
|
||||||
# file should still install successfully.
|
|
||||||
{
|
|
||||||
if test -f "$dstdir/$dstfile"; then
|
|
||||||
$doit $rmcmd -f "$dstdir/$dstfile" 2>/dev/null \
|
|
||||||
|| $doit $mvcmd -f "$dstdir/$dstfile" "$rmtmp" 2>/dev/null \
|
|
||||||
|| {
|
|
||||||
echo "$0: cannot unlink or rename $dstdir/$dstfile" >&2
|
|
||||||
(exit 1); exit 1
|
|
||||||
}
|
|
||||||
else
|
|
||||||
:
|
|
||||||
fi
|
|
||||||
} &&
|
|
||||||
|
|
||||||
# Now rename the file to the real destination.
|
|
||||||
$doit $mvcmd "$dsttmp" "$dstdir/$dstfile"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
fi || { (exit 1); exit 1; }
|
|
||||||
done
|
|
||||||
|
|
||||||
# The final little trick to "correctly" pass the exit status to the exit trap.
|
|
||||||
{
|
|
||||||
(exit 0); exit 0
|
|
||||||
}
|
|
||||||
|
|
||||||
# Local variables:
|
|
||||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
|
||||||
# time-stamp-start: "scriptversion="
|
|
||||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
|
||||||
# time-stamp-end: "$"
|
|
||||||
# End:
|
|
|
@ -1,57 +0,0 @@
|
||||||
/**
|
|
||||||
@file list.c
|
|
||||||
@brief ENet linked list functions
|
|
||||||
*/
|
|
||||||
#define ENET_BUILDING_LIB 1
|
|
||||||
#include "enet/list.h"
|
|
||||||
|
|
||||||
/**
|
|
||||||
@defgroup list ENet linked list utility functions
|
|
||||||
@ingroup private
|
|
||||||
@{
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
enet_list_clear (ENetList * list)
|
|
||||||
{
|
|
||||||
list -> sentinel.next = & list -> sentinel;
|
|
||||||
list -> sentinel.previous = & list -> sentinel;
|
|
||||||
}
|
|
||||||
|
|
||||||
ENetListIterator
|
|
||||||
enet_list_insert (ENetListIterator position, void * data)
|
|
||||||
{
|
|
||||||
ENetListIterator result = (ENetListIterator) data;
|
|
||||||
|
|
||||||
result -> previous = position -> previous;
|
|
||||||
result -> next = position;
|
|
||||||
|
|
||||||
result -> previous -> next = result;
|
|
||||||
position -> previous = result;
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
void *
|
|
||||||
enet_list_remove (ENetListIterator position)
|
|
||||||
{
|
|
||||||
position -> previous -> next = position -> next;
|
|
||||||
position -> next -> previous = position -> previous;
|
|
||||||
|
|
||||||
return position;
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t
|
|
||||||
enet_list_size (ENetList * list)
|
|
||||||
{
|
|
||||||
size_t size = 0;
|
|
||||||
ENetListIterator position;
|
|
||||||
|
|
||||||
for (position = enet_list_begin (list);
|
|
||||||
position != enet_list_end (list);
|
|
||||||
position = enet_list_next (position))
|
|
||||||
++ size;
|
|
||||||
|
|
||||||
return size;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** @} */
|
|
|
@ -1,360 +0,0 @@
|
||||||
#! /bin/sh
|
|
||||||
# Common stub for a few missing GNU programs while installing.
|
|
||||||
|
|
||||||
scriptversion=2005-06-08.21
|
|
||||||
|
|
||||||
# Copyright (C) 1996, 1997, 1999, 2000, 2002, 2003, 2004, 2005
|
|
||||||
# Free Software Foundation, Inc.
|
|
||||||
# Originally by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996.
|
|
||||||
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation; either version 2, or (at your option)
|
|
||||||
# any later version.
|
|
||||||
|
|
||||||
# This program 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 General Public License for more details.
|
|
||||||
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with this program; if not, write to the Free Software
|
|
||||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
||||||
# 02110-1301, USA.
|
|
||||||
|
|
||||||
# As a special exception to the GNU General Public License, if you
|
|
||||||
# distribute this file as part of a program that contains a
|
|
||||||
# configuration script generated by Autoconf, you may include it under
|
|
||||||
# the same distribution terms that you use for the rest of that program.
|
|
||||||
|
|
||||||
if test $# -eq 0; then
|
|
||||||
echo 1>&2 "Try \`$0 --help' for more information"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
run=:
|
|
||||||
|
|
||||||
# In the cases where this matters, `missing' is being run in the
|
|
||||||
# srcdir already.
|
|
||||||
if test -f configure.ac; then
|
|
||||||
configure_ac=configure.ac
|
|
||||||
else
|
|
||||||
configure_ac=configure.in
|
|
||||||
fi
|
|
||||||
|
|
||||||
msg="missing on your system"
|
|
||||||
|
|
||||||
case "$1" in
|
|
||||||
--run)
|
|
||||||
# Try to run requested program, and just exit if it succeeds.
|
|
||||||
run=
|
|
||||||
shift
|
|
||||||
"$@" && exit 0
|
|
||||||
# Exit code 63 means version mismatch. This often happens
|
|
||||||
# when the user try to use an ancient version of a tool on
|
|
||||||
# a file that requires a minimum version. In this case we
|
|
||||||
# we should proceed has if the program had been absent, or
|
|
||||||
# if --run hadn't been passed.
|
|
||||||
if test $? = 63; then
|
|
||||||
run=:
|
|
||||||
msg="probably too old"
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
-h|--h|--he|--hel|--help)
|
|
||||||
echo "\
|
|
||||||
$0 [OPTION]... PROGRAM [ARGUMENT]...
|
|
||||||
|
|
||||||
Handle \`PROGRAM [ARGUMENT]...' for when PROGRAM is missing, or return an
|
|
||||||
error status if there is no known handling for PROGRAM.
|
|
||||||
|
|
||||||
Options:
|
|
||||||
-h, --help display this help and exit
|
|
||||||
-v, --version output version information and exit
|
|
||||||
--run try to run the given command, and emulate it if it fails
|
|
||||||
|
|
||||||
Supported PROGRAM values:
|
|
||||||
aclocal touch file \`aclocal.m4'
|
|
||||||
autoconf touch file \`configure'
|
|
||||||
autoheader touch file \`config.h.in'
|
|
||||||
automake touch all \`Makefile.in' files
|
|
||||||
bison create \`y.tab.[ch]', if possible, from existing .[ch]
|
|
||||||
flex create \`lex.yy.c', if possible, from existing .c
|
|
||||||
help2man touch the output file
|
|
||||||
lex create \`lex.yy.c', if possible, from existing .c
|
|
||||||
makeinfo touch the output file
|
|
||||||
tar try tar, gnutar, gtar, then tar without non-portable flags
|
|
||||||
yacc create \`y.tab.[ch]', if possible, from existing .[ch]
|
|
||||||
|
|
||||||
Send bug reports to <bug-automake@gnu.org>."
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
|
|
||||||
-v|--v|--ve|--ver|--vers|--versi|--versio|--version)
|
|
||||||
echo "missing $scriptversion (GNU Automake)"
|
|
||||||
exit $?
|
|
||||||
;;
|
|
||||||
|
|
||||||
-*)
|
|
||||||
echo 1>&2 "$0: Unknown \`$1' option"
|
|
||||||
echo 1>&2 "Try \`$0 --help' for more information"
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
esac
|
|
||||||
|
|
||||||
# Now exit if we have it, but it failed. Also exit now if we
|
|
||||||
# don't have it and --version was passed (most likely to detect
|
|
||||||
# the program).
|
|
||||||
case "$1" in
|
|
||||||
lex|yacc)
|
|
||||||
# Not GNU programs, they don't have --version.
|
|
||||||
;;
|
|
||||||
|
|
||||||
tar)
|
|
||||||
if test -n "$run"; then
|
|
||||||
echo 1>&2 "ERROR: \`tar' requires --run"
|
|
||||||
exit 1
|
|
||||||
elif test "x$2" = "x--version" || test "x$2" = "x--help"; then
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
*)
|
|
||||||
if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
|
|
||||||
# We have it, but it failed.
|
|
||||||
exit 1
|
|
||||||
elif test "x$2" = "x--version" || test "x$2" = "x--help"; then
|
|
||||||
# Could not run --version or --help. This is probably someone
|
|
||||||
# running `$TOOL --version' or `$TOOL --help' to check whether
|
|
||||||
# $TOOL exists and not knowing $TOOL uses missing.
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# If it does not exist, or fails to run (possibly an outdated version),
|
|
||||||
# try to emulate it.
|
|
||||||
case "$1" in
|
|
||||||
aclocal*)
|
|
||||||
echo 1>&2 "\
|
|
||||||
WARNING: \`$1' is $msg. You should only need it if
|
|
||||||
you modified \`acinclude.m4' or \`${configure_ac}'. You might want
|
|
||||||
to install the \`Automake' and \`Perl' packages. Grab them from
|
|
||||||
any GNU archive site."
|
|
||||||
touch aclocal.m4
|
|
||||||
;;
|
|
||||||
|
|
||||||
autoconf)
|
|
||||||
echo 1>&2 "\
|
|
||||||
WARNING: \`$1' is $msg. You should only need it if
|
|
||||||
you modified \`${configure_ac}'. You might want to install the
|
|
||||||
\`Autoconf' and \`GNU m4' packages. Grab them from any GNU
|
|
||||||
archive site."
|
|
||||||
touch configure
|
|
||||||
;;
|
|
||||||
|
|
||||||
autoheader)
|
|
||||||
echo 1>&2 "\
|
|
||||||
WARNING: \`$1' is $msg. You should only need it if
|
|
||||||
you modified \`acconfig.h' or \`${configure_ac}'. You might want
|
|
||||||
to install the \`Autoconf' and \`GNU m4' packages. Grab them
|
|
||||||
from any GNU archive site."
|
|
||||||
files=`sed -n 's/^[ ]*A[CM]_CONFIG_HEADER(\([^)]*\)).*/\1/p' ${configure_ac}`
|
|
||||||
test -z "$files" && files="config.h"
|
|
||||||
touch_files=
|
|
||||||
for f in $files; do
|
|
||||||
case "$f" in
|
|
||||||
*:*) touch_files="$touch_files "`echo "$f" |
|
|
||||||
sed -e 's/^[^:]*://' -e 's/:.*//'`;;
|
|
||||||
*) touch_files="$touch_files $f.in";;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
touch $touch_files
|
|
||||||
;;
|
|
||||||
|
|
||||||
automake*)
|
|
||||||
echo 1>&2 "\
|
|
||||||
WARNING: \`$1' is $msg. You should only need it if
|
|
||||||
you modified \`Makefile.am', \`acinclude.m4' or \`${configure_ac}'.
|
|
||||||
You might want to install the \`Automake' and \`Perl' packages.
|
|
||||||
Grab them from any GNU archive site."
|
|
||||||
find . -type f -name Makefile.am -print |
|
|
||||||
sed 's/\.am$/.in/' |
|
|
||||||
while read f; do touch "$f"; done
|
|
||||||
;;
|
|
||||||
|
|
||||||
autom4te)
|
|
||||||
echo 1>&2 "\
|
|
||||||
WARNING: \`$1' is needed, but is $msg.
|
|
||||||
You might have modified some files without having the
|
|
||||||
proper tools for further handling them.
|
|
||||||
You can get \`$1' as part of \`Autoconf' from any GNU
|
|
||||||
archive site."
|
|
||||||
|
|
||||||
file=`echo "$*" | sed -n 's/.*--output[ =]*\([^ ]*\).*/\1/p'`
|
|
||||||
test -z "$file" && file=`echo "$*" | sed -n 's/.*-o[ ]*\([^ ]*\).*/\1/p'`
|
|
||||||
if test -f "$file"; then
|
|
||||||
touch $file
|
|
||||||
else
|
|
||||||
test -z "$file" || exec >$file
|
|
||||||
echo "#! /bin/sh"
|
|
||||||
echo "# Created by GNU Automake missing as a replacement of"
|
|
||||||
echo "# $ $@"
|
|
||||||
echo "exit 0"
|
|
||||||
chmod +x $file
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
bison|yacc)
|
|
||||||
echo 1>&2 "\
|
|
||||||
WARNING: \`$1' $msg. You should only need it if
|
|
||||||
you modified a \`.y' file. You may need the \`Bison' package
|
|
||||||
in order for those modifications to take effect. You can get
|
|
||||||
\`Bison' from any GNU archive site."
|
|
||||||
rm -f y.tab.c y.tab.h
|
|
||||||
if [ $# -ne 1 ]; then
|
|
||||||
eval LASTARG="\${$#}"
|
|
||||||
case "$LASTARG" in
|
|
||||||
*.y)
|
|
||||||
SRCFILE=`echo "$LASTARG" | sed 's/y$/c/'`
|
|
||||||
if [ -f "$SRCFILE" ]; then
|
|
||||||
cp "$SRCFILE" y.tab.c
|
|
||||||
fi
|
|
||||||
SRCFILE=`echo "$LASTARG" | sed 's/y$/h/'`
|
|
||||||
if [ -f "$SRCFILE" ]; then
|
|
||||||
cp "$SRCFILE" y.tab.h
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
if [ ! -f y.tab.h ]; then
|
|
||||||
echo >y.tab.h
|
|
||||||
fi
|
|
||||||
if [ ! -f y.tab.c ]; then
|
|
||||||
echo 'main() { return 0; }' >y.tab.c
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
lex|flex)
|
|
||||||
echo 1>&2 "\
|
|
||||||
WARNING: \`$1' is $msg. You should only need it if
|
|
||||||
you modified a \`.l' file. You may need the \`Flex' package
|
|
||||||
in order for those modifications to take effect. You can get
|
|
||||||
\`Flex' from any GNU archive site."
|
|
||||||
rm -f lex.yy.c
|
|
||||||
if [ $# -ne 1 ]; then
|
|
||||||
eval LASTARG="\${$#}"
|
|
||||||
case "$LASTARG" in
|
|
||||||
*.l)
|
|
||||||
SRCFILE=`echo "$LASTARG" | sed 's/l$/c/'`
|
|
||||||
if [ -f "$SRCFILE" ]; then
|
|
||||||
cp "$SRCFILE" lex.yy.c
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
if [ ! -f lex.yy.c ]; then
|
|
||||||
echo 'main() { return 0; }' >lex.yy.c
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
help2man)
|
|
||||||
echo 1>&2 "\
|
|
||||||
WARNING: \`$1' is $msg. You should only need it if
|
|
||||||
you modified a dependency of a manual page. You may need the
|
|
||||||
\`Help2man' package in order for those modifications to take
|
|
||||||
effect. You can get \`Help2man' from any GNU archive site."
|
|
||||||
|
|
||||||
file=`echo "$*" | sed -n 's/.*-o \([^ ]*\).*/\1/p'`
|
|
||||||
if test -z "$file"; then
|
|
||||||
file=`echo "$*" | sed -n 's/.*--output=\([^ ]*\).*/\1/p'`
|
|
||||||
fi
|
|
||||||
if [ -f "$file" ]; then
|
|
||||||
touch $file
|
|
||||||
else
|
|
||||||
test -z "$file" || exec >$file
|
|
||||||
echo ".ab help2man is required to generate this page"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
makeinfo)
|
|
||||||
echo 1>&2 "\
|
|
||||||
WARNING: \`$1' is $msg. You should only need it if
|
|
||||||
you modified a \`.texi' or \`.texinfo' file, or any other file
|
|
||||||
indirectly affecting the aspect of the manual. The spurious
|
|
||||||
call might also be the consequence of using a buggy \`make' (AIX,
|
|
||||||
DU, IRIX). You might want to install the \`Texinfo' package or
|
|
||||||
the \`GNU make' package. Grab either from any GNU archive site."
|
|
||||||
# The file to touch is that specified with -o ...
|
|
||||||
file=`echo "$*" | sed -n 's/.*-o \([^ ]*\).*/\1/p'`
|
|
||||||
if test -z "$file"; then
|
|
||||||
# ... or it is the one specified with @setfilename ...
|
|
||||||
infile=`echo "$*" | sed 's/.* \([^ ]*\) *$/\1/'`
|
|
||||||
file=`sed -n '/^@setfilename/ { s/.* \([^ ]*\) *$/\1/; p; q; }' $infile`
|
|
||||||
# ... or it is derived from the source name (dir/f.texi becomes f.info)
|
|
||||||
test -z "$file" && file=`echo "$infile" | sed 's,.*/,,;s,.[^.]*$,,'`.info
|
|
||||||
fi
|
|
||||||
# If the file does not exist, the user really needs makeinfo;
|
|
||||||
# let's fail without touching anything.
|
|
||||||
test -f $file || exit 1
|
|
||||||
touch $file
|
|
||||||
;;
|
|
||||||
|
|
||||||
tar)
|
|
||||||
shift
|
|
||||||
|
|
||||||
# We have already tried tar in the generic part.
|
|
||||||
# Look for gnutar/gtar before invocation to avoid ugly error
|
|
||||||
# messages.
|
|
||||||
if (gnutar --version > /dev/null 2>&1); then
|
|
||||||
gnutar "$@" && exit 0
|
|
||||||
fi
|
|
||||||
if (gtar --version > /dev/null 2>&1); then
|
|
||||||
gtar "$@" && exit 0
|
|
||||||
fi
|
|
||||||
firstarg="$1"
|
|
||||||
if shift; then
|
|
||||||
case "$firstarg" in
|
|
||||||
*o*)
|
|
||||||
firstarg=`echo "$firstarg" | sed s/o//`
|
|
||||||
tar "$firstarg" "$@" && exit 0
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
case "$firstarg" in
|
|
||||||
*h*)
|
|
||||||
firstarg=`echo "$firstarg" | sed s/h//`
|
|
||||||
tar "$firstarg" "$@" && exit 0
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo 1>&2 "\
|
|
||||||
WARNING: I can't seem to be able to run \`tar' with the given arguments.
|
|
||||||
You may want to install GNU tar or Free paxutils, or check the
|
|
||||||
command line arguments."
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
*)
|
|
||||||
echo 1>&2 "\
|
|
||||||
WARNING: \`$1' is needed, and is $msg.
|
|
||||||
You might have modified some files without having the
|
|
||||||
proper tools for further handling them. Check the \`README' file,
|
|
||||||
it often tells you about the needed prerequisites for installing
|
|
||||||
this package. You may also peek at any GNU archive site, in case
|
|
||||||
some other package would contain this missing \`$1' program."
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
exit 0
|
|
||||||
|
|
||||||
# Local variables:
|
|
||||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
|
||||||
# time-stamp-start: "scriptversion="
|
|
||||||
# time-stamp-format: "%:y-%02m-%02d.%02H"
|
|
||||||
# time-stamp-end: "$"
|
|
||||||
# End:
|
|
|
@ -1,140 +0,0 @@
|
||||||
/**
|
|
||||||
@file packet.c
|
|
||||||
@brief ENet packet management functions
|
|
||||||
*/
|
|
||||||
#include <string.h>
|
|
||||||
#define ENET_BUILDING_LIB 1
|
|
||||||
#include "enet/enet.h"
|
|
||||||
|
|
||||||
/** @defgroup Packet ENet packet functions
|
|
||||||
@{
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** Creates a packet that may be sent to a peer.
|
|
||||||
@param dataContents initial contents of the packet's data; the packet's data will remain uninitialized if dataContents is NULL.
|
|
||||||
@param dataLength size of the data allocated for this packet
|
|
||||||
@param flags flags for this packet as described for the ENetPacket structure.
|
|
||||||
@returns the packet on success, NULL on failure
|
|
||||||
*/
|
|
||||||
ENetPacket *
|
|
||||||
enet_packet_create (const void * data, size_t dataLength, enet_uint32 flags)
|
|
||||||
{
|
|
||||||
ENetPacket * packet = (ENetPacket *) enet_malloc (sizeof (ENetPacket));
|
|
||||||
|
|
||||||
if (flags & ENET_PACKET_FLAG_NO_ALLOCATE)
|
|
||||||
packet -> data = (enet_uint8 *) data;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
packet -> data = (enet_uint8 *) enet_malloc (dataLength);
|
|
||||||
if (packet -> data == NULL)
|
|
||||||
{
|
|
||||||
enet_free (packet);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (data != NULL)
|
|
||||||
memcpy (packet -> data, data, dataLength);
|
|
||||||
}
|
|
||||||
|
|
||||||
packet -> referenceCount = 0;
|
|
||||||
packet -> flags = flags;
|
|
||||||
packet -> dataLength = dataLength;
|
|
||||||
packet -> freeCallback = NULL;
|
|
||||||
|
|
||||||
return packet;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Destroys the packet and deallocates its data.
|
|
||||||
@param packet packet to be destroyed
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
enet_packet_destroy (ENetPacket * packet)
|
|
||||||
{
|
|
||||||
if (packet -> freeCallback != NULL)
|
|
||||||
(* packet -> freeCallback) (packet);
|
|
||||||
if (! (packet -> flags & ENET_PACKET_FLAG_NO_ALLOCATE))
|
|
||||||
enet_free (packet -> data);
|
|
||||||
enet_free (packet);
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Attempts to resize the data in the packet to length specified in the
|
|
||||||
dataLength parameter
|
|
||||||
@param packet packet to resize
|
|
||||||
@param dataLength new size for the packet data
|
|
||||||
@returns 0 on success, < 0 on failure
|
|
||||||
*/
|
|
||||||
int
|
|
||||||
enet_packet_resize (ENetPacket * packet, size_t dataLength)
|
|
||||||
{
|
|
||||||
enet_uint8 * newData;
|
|
||||||
|
|
||||||
if (dataLength <= packet -> dataLength || (packet -> flags & ENET_PACKET_FLAG_NO_ALLOCATE))
|
|
||||||
{
|
|
||||||
packet -> dataLength = dataLength;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
newData = (enet_uint8 *) enet_malloc (dataLength);
|
|
||||||
if (newData == NULL)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
memcpy (newData, packet -> data, packet -> dataLength);
|
|
||||||
enet_free (packet -> data);
|
|
||||||
|
|
||||||
packet -> data = newData;
|
|
||||||
packet -> dataLength = dataLength;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int initializedCRC32 = 0;
|
|
||||||
static enet_uint32 crcTable [256];
|
|
||||||
|
|
||||||
static void initialize_crc32 ()
|
|
||||||
{
|
|
||||||
int byte;
|
|
||||||
|
|
||||||
for (byte = 0; byte < 256; ++ byte)
|
|
||||||
{
|
|
||||||
enet_uint32 crc = byte << 24;
|
|
||||||
int offset;
|
|
||||||
|
|
||||||
for(offset = 0; offset < 8; ++ offset)
|
|
||||||
{
|
|
||||||
if (crc & 0x80000000)
|
|
||||||
crc = (crc << 1) ^ 0x04c11db7;
|
|
||||||
else
|
|
||||||
crc <<= 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
crcTable [byte] = crc;
|
|
||||||
}
|
|
||||||
|
|
||||||
initializedCRC32 = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
enet_uint32
|
|
||||||
enet_crc32 (const ENetBuffer * buffers, size_t bufferCount)
|
|
||||||
{
|
|
||||||
enet_uint32 crc = 0xFFFFFFFF;
|
|
||||||
|
|
||||||
if (! initializedCRC32) initialize_crc32 ();
|
|
||||||
|
|
||||||
while (bufferCount -- > 0)
|
|
||||||
{
|
|
||||||
const enet_uint8 * data = (const enet_uint8 *) buffers -> data,
|
|
||||||
* dataEnd = & data [buffers -> dataLength];
|
|
||||||
|
|
||||||
while (data < dataEnd)
|
|
||||||
{
|
|
||||||
crc = ((crc << 8) | * data ++) ^ crcTable [crc >> 24];
|
|
||||||
}
|
|
||||||
|
|
||||||
++ buffers;
|
|
||||||
}
|
|
||||||
|
|
||||||
return ENET_HOST_TO_NET_32 (~ crc);
|
|
||||||
}
|
|
||||||
|
|
||||||
/** @} */
|
|
|
@ -1,699 +0,0 @@
|
||||||
/**
|
|
||||||
@file peer.c
|
|
||||||
@brief ENet peer management functions
|
|
||||||
*/
|
|
||||||
#include <string.h>
|
|
||||||
#define ENET_BUILDING_LIB 1
|
|
||||||
#include "enet/enet.h"
|
|
||||||
|
|
||||||
/** @defgroup peer ENet peer functions
|
|
||||||
@{
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** Configures throttle parameter for a peer.
|
|
||||||
|
|
||||||
Unreliable packets are dropped by ENet in response to the varying conditions
|
|
||||||
of the Internet connection to the peer. The throttle represents a probability
|
|
||||||
that an unreliable packet should not be dropped and thus sent by ENet to the peer.
|
|
||||||
The lowest mean round trip time from the sending of a reliable packet to the
|
|
||||||
receipt of its acknowledgement is measured over an amount of time specified by
|
|
||||||
the interval parameter in milliseconds. If a measured round trip time happens to
|
|
||||||
be significantly less than the mean round trip time measured over the interval,
|
|
||||||
then the throttle probability is increased to allow more traffic by an amount
|
|
||||||
specified in the acceleration parameter, which is a ratio to the ENET_PEER_PACKET_THROTTLE_SCALE
|
|
||||||
constant. If a measured round trip time happens to be significantly greater than
|
|
||||||
the mean round trip time measured over the interval, then the throttle probability
|
|
||||||
is decreased to limit traffic by an amount specified in the deceleration parameter, which
|
|
||||||
is a ratio to the ENET_PEER_PACKET_THROTTLE_SCALE constant. When the throttle has
|
|
||||||
a value of ENET_PEER_PACKET_THROTTLE_SCALE, on unreliable packets are dropped by
|
|
||||||
ENet, and so 100% of all unreliable packets will be sent. When the throttle has a
|
|
||||||
value of 0, all unreliable packets are dropped by ENet, and so 0% of all unreliable
|
|
||||||
packets will be sent. Intermediate values for the throttle represent intermediate
|
|
||||||
probabilities between 0% and 100% of unreliable packets being sent. The bandwidth
|
|
||||||
limits of the local and foreign hosts are taken into account to determine a
|
|
||||||
sensible limit for the throttle probability above which it should not raise even in
|
|
||||||
the best of conditions.
|
|
||||||
|
|
||||||
@param peer peer to configure
|
|
||||||
@param interval interval, in milliseconds, over which to measure lowest mean RTT; the default value is ENET_PEER_PACKET_THROTTLE_INTERVAL.
|
|
||||||
@param acceleration rate at which to increase the throttle probability as mean RTT declines
|
|
||||||
@param deceleration rate at which to decrease the throttle probability as mean RTT increases
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
enet_peer_throttle_configure (ENetPeer * peer, enet_uint32 interval, enet_uint32 acceleration, enet_uint32 deceleration)
|
|
||||||
{
|
|
||||||
ENetProtocol command;
|
|
||||||
|
|
||||||
peer -> packetThrottleInterval = interval;
|
|
||||||
peer -> packetThrottleAcceleration = acceleration;
|
|
||||||
peer -> packetThrottleDeceleration = deceleration;
|
|
||||||
|
|
||||||
command.header.command = ENET_PROTOCOL_COMMAND_THROTTLE_CONFIGURE | ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE;
|
|
||||||
command.header.channelID = 0xFF;
|
|
||||||
|
|
||||||
command.throttleConfigure.packetThrottleInterval = ENET_HOST_TO_NET_32 (interval);
|
|
||||||
command.throttleConfigure.packetThrottleAcceleration = ENET_HOST_TO_NET_32 (acceleration);
|
|
||||||
command.throttleConfigure.packetThrottleDeceleration = ENET_HOST_TO_NET_32 (deceleration);
|
|
||||||
|
|
||||||
enet_peer_queue_outgoing_command (peer, & command, NULL, 0, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_peer_throttle (ENetPeer * peer, enet_uint32 rtt)
|
|
||||||
{
|
|
||||||
if (peer -> lastRoundTripTime <= peer -> lastRoundTripTimeVariance)
|
|
||||||
{
|
|
||||||
peer -> packetThrottle = peer -> packetThrottleLimit;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
if (rtt < peer -> lastRoundTripTime)
|
|
||||||
{
|
|
||||||
peer -> packetThrottle += peer -> packetThrottleAcceleration;
|
|
||||||
|
|
||||||
if (peer -> packetThrottle > peer -> packetThrottleLimit)
|
|
||||||
peer -> packetThrottle = peer -> packetThrottleLimit;
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
if (rtt > peer -> lastRoundTripTime + 2 * peer -> lastRoundTripTimeVariance)
|
|
||||||
{
|
|
||||||
if (peer -> packetThrottle > peer -> packetThrottleDeceleration)
|
|
||||||
peer -> packetThrottle -= peer -> packetThrottleDeceleration;
|
|
||||||
else
|
|
||||||
peer -> packetThrottle = 0;
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Queues a packet to be sent.
|
|
||||||
@param peer destination for the packet
|
|
||||||
@param channelID channel on which to send
|
|
||||||
@param packet packet to send
|
|
||||||
@retval 0 on success
|
|
||||||
@retval < 0 on failure
|
|
||||||
*/
|
|
||||||
int
|
|
||||||
enet_peer_send (ENetPeer * peer, enet_uint8 channelID, ENetPacket * packet)
|
|
||||||
{
|
|
||||||
ENetChannel * channel = & peer -> channels [channelID];
|
|
||||||
ENetProtocol command;
|
|
||||||
size_t fragmentLength;
|
|
||||||
|
|
||||||
if (peer -> state != ENET_PEER_STATE_CONNECTED ||
|
|
||||||
channelID >= peer -> channelCount)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
fragmentLength = peer -> mtu - sizeof (ENetProtocolHeader) - sizeof (ENetProtocolSendFragment);
|
|
||||||
|
|
||||||
if (packet -> dataLength > fragmentLength)
|
|
||||||
{
|
|
||||||
enet_uint16 startSequenceNumber = ENET_HOST_TO_NET_16 (channel -> outgoingReliableSequenceNumber + 1);
|
|
||||||
enet_uint32 fragmentCount = ENET_HOST_TO_NET_32 ((packet -> dataLength + fragmentLength - 1) / fragmentLength),
|
|
||||||
fragmentNumber,
|
|
||||||
fragmentOffset;
|
|
||||||
|
|
||||||
packet -> flags |= ENET_PACKET_FLAG_RELIABLE;
|
|
||||||
packet -> flags &= ~ENET_PACKET_FLAG_UNSEQUENCED;
|
|
||||||
|
|
||||||
for (fragmentNumber = 0,
|
|
||||||
fragmentOffset = 0;
|
|
||||||
fragmentOffset < packet -> dataLength;
|
|
||||||
++ fragmentNumber,
|
|
||||||
fragmentOffset += fragmentLength)
|
|
||||||
{
|
|
||||||
if (packet -> dataLength - fragmentOffset < fragmentLength)
|
|
||||||
fragmentLength = packet -> dataLength - fragmentOffset;
|
|
||||||
|
|
||||||
command.header.command = ENET_PROTOCOL_COMMAND_SEND_FRAGMENT | ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE;
|
|
||||||
command.header.channelID = channelID;
|
|
||||||
command.sendFragment.startSequenceNumber = startSequenceNumber;
|
|
||||||
command.sendFragment.dataLength = ENET_HOST_TO_NET_16 (fragmentLength);
|
|
||||||
command.sendFragment.fragmentCount = fragmentCount;
|
|
||||||
command.sendFragment.fragmentNumber = ENET_HOST_TO_NET_32 (fragmentNumber);
|
|
||||||
command.sendFragment.totalLength = ENET_HOST_TO_NET_32 (packet -> dataLength);
|
|
||||||
command.sendFragment.fragmentOffset = ENET_NET_TO_HOST_32 (fragmentOffset);
|
|
||||||
|
|
||||||
enet_peer_queue_outgoing_command (peer, & command, packet, fragmentOffset, fragmentLength);
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
command.header.channelID = channelID;
|
|
||||||
|
|
||||||
if (! (packet -> flags & (ENET_PACKET_FLAG_RELIABLE | ENET_PACKET_FLAG_UNSEQUENCED)) && channel -> outgoingUnreliableSequenceNumber >= 0xFFFF)
|
|
||||||
packet -> flags |= ENET_PACKET_FLAG_RELIABLE;
|
|
||||||
|
|
||||||
if (packet -> flags & ENET_PACKET_FLAG_RELIABLE)
|
|
||||||
{
|
|
||||||
command.header.command = ENET_PROTOCOL_COMMAND_SEND_RELIABLE | ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE;
|
|
||||||
command.sendReliable.dataLength = ENET_HOST_TO_NET_16 (packet -> dataLength);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
if (packet -> flags & ENET_PACKET_FLAG_UNSEQUENCED)
|
|
||||||
{
|
|
||||||
command.header.command = ENET_PROTOCOL_COMMAND_SEND_UNSEQUENCED | ENET_PROTOCOL_COMMAND_FLAG_UNSEQUENCED;
|
|
||||||
command.sendUnsequenced.unsequencedGroup = ENET_HOST_TO_NET_16 (peer -> outgoingUnsequencedGroup + 1);
|
|
||||||
command.sendUnsequenced.dataLength = ENET_HOST_TO_NET_16 (packet -> dataLength);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
command.header.command = ENET_PROTOCOL_COMMAND_SEND_UNRELIABLE;
|
|
||||||
command.sendUnreliable.unreliableSequenceNumber = ENET_HOST_TO_NET_16 (channel -> outgoingUnreliableSequenceNumber + 1);
|
|
||||||
command.sendUnreliable.dataLength = ENET_HOST_TO_NET_16 (packet -> dataLength);
|
|
||||||
}
|
|
||||||
|
|
||||||
enet_peer_queue_outgoing_command (peer, & command, packet, 0, packet -> dataLength);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Attempts to dequeue any incoming queued packet.
|
|
||||||
@param peer peer to dequeue packets from
|
|
||||||
@param channelID channel on which to receive
|
|
||||||
@returns a pointer to the packet, or NULL if there are no available incoming queued packets
|
|
||||||
*/
|
|
||||||
ENetPacket *
|
|
||||||
enet_peer_receive (ENetPeer * peer, enet_uint8 channelID)
|
|
||||||
{
|
|
||||||
ENetChannel * channel = & peer -> channels [channelID];
|
|
||||||
ENetIncomingCommand * incomingCommand = NULL;
|
|
||||||
ENetPacket * packet;
|
|
||||||
|
|
||||||
if (! enet_list_empty (& channel -> incomingUnreliableCommands))
|
|
||||||
{
|
|
||||||
incomingCommand = (ENetIncomingCommand *) enet_list_front (& channel -> incomingUnreliableCommands);
|
|
||||||
|
|
||||||
if ((incomingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_MASK) == ENET_PROTOCOL_COMMAND_SEND_UNRELIABLE)
|
|
||||||
{
|
|
||||||
if (incomingCommand -> reliableSequenceNumber != channel -> incomingReliableSequenceNumber)
|
|
||||||
incomingCommand = NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (incomingCommand == NULL &&
|
|
||||||
! enet_list_empty (& channel -> incomingReliableCommands))
|
|
||||||
{
|
|
||||||
incomingCommand = (ENetIncomingCommand *) enet_list_front (& channel -> incomingReliableCommands);
|
|
||||||
|
|
||||||
if (incomingCommand -> fragmentsRemaining > 0 ||
|
|
||||||
incomingCommand -> reliableSequenceNumber != (enet_uint16) (channel -> incomingReliableSequenceNumber + 1))
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
channel -> incomingReliableSequenceNumber = incomingCommand -> reliableSequenceNumber;
|
|
||||||
|
|
||||||
if (incomingCommand -> fragmentCount > 0)
|
|
||||||
channel -> incomingReliableSequenceNumber += incomingCommand -> fragmentCount - 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (incomingCommand == NULL)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
enet_list_remove (& incomingCommand -> incomingCommandList);
|
|
||||||
|
|
||||||
packet = incomingCommand -> packet;
|
|
||||||
|
|
||||||
-- packet -> referenceCount;
|
|
||||||
|
|
||||||
if (incomingCommand -> fragments != NULL)
|
|
||||||
enet_free (incomingCommand -> fragments);
|
|
||||||
|
|
||||||
enet_free (incomingCommand);
|
|
||||||
|
|
||||||
return packet;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
enet_peer_reset_outgoing_commands (ENetList * queue)
|
|
||||||
{
|
|
||||||
ENetOutgoingCommand * outgoingCommand;
|
|
||||||
|
|
||||||
while (! enet_list_empty (queue))
|
|
||||||
{
|
|
||||||
outgoingCommand = (ENetOutgoingCommand *) enet_list_remove (enet_list_begin (queue));
|
|
||||||
|
|
||||||
if (outgoingCommand -> packet != NULL)
|
|
||||||
{
|
|
||||||
-- outgoingCommand -> packet -> referenceCount;
|
|
||||||
|
|
||||||
if (outgoingCommand -> packet -> referenceCount == 0)
|
|
||||||
enet_packet_destroy (outgoingCommand -> packet);
|
|
||||||
}
|
|
||||||
|
|
||||||
enet_free (outgoingCommand);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
enet_peer_reset_incoming_commands (ENetList * queue)
|
|
||||||
{
|
|
||||||
ENetIncomingCommand * incomingCommand;
|
|
||||||
|
|
||||||
while (! enet_list_empty (queue))
|
|
||||||
{
|
|
||||||
incomingCommand = (ENetIncomingCommand *) enet_list_remove (enet_list_begin (queue));
|
|
||||||
|
|
||||||
if (incomingCommand -> packet != NULL)
|
|
||||||
{
|
|
||||||
-- incomingCommand -> packet -> referenceCount;
|
|
||||||
|
|
||||||
if (incomingCommand -> packet -> referenceCount == 0)
|
|
||||||
enet_packet_destroy (incomingCommand -> packet);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (incomingCommand -> fragments != NULL)
|
|
||||||
enet_free (incomingCommand -> fragments);
|
|
||||||
|
|
||||||
enet_free (incomingCommand);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
enet_peer_reset_queues (ENetPeer * peer)
|
|
||||||
{
|
|
||||||
ENetChannel * channel;
|
|
||||||
|
|
||||||
while (! enet_list_empty (& peer -> acknowledgements))
|
|
||||||
enet_free (enet_list_remove (enet_list_begin (& peer -> acknowledgements)));
|
|
||||||
|
|
||||||
enet_peer_reset_outgoing_commands (& peer -> sentReliableCommands);
|
|
||||||
enet_peer_reset_outgoing_commands (& peer -> sentUnreliableCommands);
|
|
||||||
enet_peer_reset_outgoing_commands (& peer -> outgoingReliableCommands);
|
|
||||||
enet_peer_reset_outgoing_commands (& peer -> outgoingUnreliableCommands);
|
|
||||||
|
|
||||||
if (peer -> channels != NULL && peer -> channelCount > 0)
|
|
||||||
{
|
|
||||||
for (channel = peer -> channels;
|
|
||||||
channel < & peer -> channels [peer -> channelCount];
|
|
||||||
++ channel)
|
|
||||||
{
|
|
||||||
enet_peer_reset_incoming_commands (& channel -> incomingReliableCommands);
|
|
||||||
enet_peer_reset_incoming_commands (& channel -> incomingUnreliableCommands);
|
|
||||||
}
|
|
||||||
|
|
||||||
enet_free (peer -> channels);
|
|
||||||
}
|
|
||||||
|
|
||||||
peer -> channels = NULL;
|
|
||||||
peer -> channelCount = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Forcefully disconnects a peer.
|
|
||||||
@param peer peer to forcefully disconnect
|
|
||||||
@remarks The foreign host represented by the peer is not notified of the disconnection and will timeout
|
|
||||||
on its connection to the local host.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
enet_peer_reset (ENetPeer * peer)
|
|
||||||
{
|
|
||||||
peer -> outgoingPeerID = ENET_PROTOCOL_MAXIMUM_PEER_ID;
|
|
||||||
peer -> sessionID = 0;
|
|
||||||
|
|
||||||
peer -> state = ENET_PEER_STATE_DISCONNECTED;
|
|
||||||
|
|
||||||
peer -> incomingBandwidth = 0;
|
|
||||||
peer -> outgoingBandwidth = 0;
|
|
||||||
peer -> incomingBandwidthThrottleEpoch = 0;
|
|
||||||
peer -> outgoingBandwidthThrottleEpoch = 0;
|
|
||||||
peer -> incomingDataTotal = 0;
|
|
||||||
peer -> outgoingDataTotal = 0;
|
|
||||||
peer -> lastSendTime = 0;
|
|
||||||
peer -> lastReceiveTime = 0;
|
|
||||||
peer -> nextTimeout = 0;
|
|
||||||
peer -> earliestTimeout = 0;
|
|
||||||
peer -> packetLossEpoch = 0;
|
|
||||||
peer -> packetsSent = 0;
|
|
||||||
peer -> packetsLost = 0;
|
|
||||||
peer -> packetLoss = 0;
|
|
||||||
peer -> packetLossVariance = 0;
|
|
||||||
peer -> packetThrottle = ENET_PEER_DEFAULT_PACKET_THROTTLE;
|
|
||||||
peer -> packetThrottleLimit = ENET_PEER_PACKET_THROTTLE_SCALE;
|
|
||||||
peer -> packetThrottleCounter = 0;
|
|
||||||
peer -> packetThrottleEpoch = 0;
|
|
||||||
peer -> packetThrottleAcceleration = ENET_PEER_PACKET_THROTTLE_ACCELERATION;
|
|
||||||
peer -> packetThrottleDeceleration = ENET_PEER_PACKET_THROTTLE_DECELERATION;
|
|
||||||
peer -> packetThrottleInterval = ENET_PEER_PACKET_THROTTLE_INTERVAL;
|
|
||||||
peer -> lastRoundTripTime = ENET_PEER_DEFAULT_ROUND_TRIP_TIME;
|
|
||||||
peer -> lowestRoundTripTime = ENET_PEER_DEFAULT_ROUND_TRIP_TIME;
|
|
||||||
peer -> lastRoundTripTimeVariance = 0;
|
|
||||||
peer -> highestRoundTripTimeVariance = 0;
|
|
||||||
peer -> roundTripTime = ENET_PEER_DEFAULT_ROUND_TRIP_TIME;
|
|
||||||
peer -> roundTripTimeVariance = 0;
|
|
||||||
peer -> mtu = peer -> host -> mtu;
|
|
||||||
peer -> reliableDataInTransit = 0;
|
|
||||||
peer -> outgoingReliableSequenceNumber = 0;
|
|
||||||
peer -> windowSize = ENET_PROTOCOL_MAXIMUM_WINDOW_SIZE;
|
|
||||||
peer -> incomingUnsequencedGroup = 0;
|
|
||||||
peer -> outgoingUnsequencedGroup = 0;
|
|
||||||
peer -> disconnectData = 0;
|
|
||||||
|
|
||||||
memset (peer -> unsequencedWindow, 0, sizeof (peer -> unsequencedWindow));
|
|
||||||
|
|
||||||
enet_peer_reset_queues (peer);
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Sends a ping request to a peer.
|
|
||||||
@param peer destination for the ping request
|
|
||||||
@remarks ping requests factor into the mean round trip time as designated by the
|
|
||||||
roundTripTime field in the ENetPeer structure. Enet automatically pings all connected
|
|
||||||
peers at regular intervals, however, this function may be called to ensure more
|
|
||||||
frequent ping requests.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
enet_peer_ping (ENetPeer * peer)
|
|
||||||
{
|
|
||||||
ENetProtocol command;
|
|
||||||
|
|
||||||
if (peer -> state != ENET_PEER_STATE_CONNECTED)
|
|
||||||
return;
|
|
||||||
|
|
||||||
command.header.command = ENET_PROTOCOL_COMMAND_PING | ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE;
|
|
||||||
command.header.channelID = 0xFF;
|
|
||||||
|
|
||||||
enet_peer_queue_outgoing_command (peer, & command, NULL, 0, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Force an immediate disconnection from a peer.
|
|
||||||
@param peer peer to disconnect
|
|
||||||
@param data data describing the disconnection
|
|
||||||
@remarks No ENET_EVENT_DISCONNECT event will be generated. The foreign peer is not
|
|
||||||
guarenteed to receive the disconnect notification, and is reset immediately upon
|
|
||||||
return from this function.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
enet_peer_disconnect_now (ENetPeer * peer, enet_uint32 data)
|
|
||||||
{
|
|
||||||
ENetProtocol command;
|
|
||||||
|
|
||||||
if (peer -> state == ENET_PEER_STATE_DISCONNECTED)
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (peer -> state != ENET_PEER_STATE_ZOMBIE &&
|
|
||||||
peer -> state != ENET_PEER_STATE_DISCONNECTING)
|
|
||||||
{
|
|
||||||
enet_peer_reset_queues (peer);
|
|
||||||
|
|
||||||
command.header.command = ENET_PROTOCOL_COMMAND_DISCONNECT | ENET_PROTOCOL_COMMAND_FLAG_UNSEQUENCED;
|
|
||||||
command.header.channelID = 0xFF;
|
|
||||||
command.disconnect.data = ENET_HOST_TO_NET_32 (data);
|
|
||||||
|
|
||||||
enet_peer_queue_outgoing_command (peer, & command, NULL, 0, 0);
|
|
||||||
|
|
||||||
enet_host_flush (peer -> host);
|
|
||||||
}
|
|
||||||
|
|
||||||
enet_peer_reset (peer);
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Request a disconnection from a peer.
|
|
||||||
@param peer peer to request a disconnection
|
|
||||||
@param data data describing the disconnection
|
|
||||||
@remarks An ENET_EVENT_DISCONNECT event will be generated by enet_host_service()
|
|
||||||
once the disconnection is complete.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
enet_peer_disconnect (ENetPeer * peer, enet_uint32 data)
|
|
||||||
{
|
|
||||||
ENetProtocol command;
|
|
||||||
|
|
||||||
if (peer -> state == ENET_PEER_STATE_DISCONNECTING ||
|
|
||||||
peer -> state == ENET_PEER_STATE_DISCONNECTED ||
|
|
||||||
peer -> state == ENET_PEER_STATE_ZOMBIE)
|
|
||||||
return;
|
|
||||||
|
|
||||||
enet_peer_reset_queues (peer);
|
|
||||||
|
|
||||||
command.header.command = ENET_PROTOCOL_COMMAND_DISCONNECT;
|
|
||||||
command.header.channelID = 0xFF;
|
|
||||||
command.disconnect.data = ENET_HOST_TO_NET_32 (data);
|
|
||||||
|
|
||||||
if (peer -> state == ENET_PEER_STATE_CONNECTED || peer -> state == ENET_PEER_STATE_DISCONNECT_LATER)
|
|
||||||
command.header.command |= ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE;
|
|
||||||
else
|
|
||||||
command.header.command |= ENET_PROTOCOL_COMMAND_FLAG_UNSEQUENCED;
|
|
||||||
|
|
||||||
enet_peer_queue_outgoing_command (peer, & command, NULL, 0, 0);
|
|
||||||
|
|
||||||
if (peer -> state == ENET_PEER_STATE_CONNECTED || peer -> state == ENET_PEER_STATE_DISCONNECT_LATER)
|
|
||||||
peer -> state = ENET_PEER_STATE_DISCONNECTING;
|
|
||||||
else
|
|
||||||
{
|
|
||||||
enet_host_flush (peer -> host);
|
|
||||||
enet_peer_reset (peer);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Request a disconnection from a peer, but only after all queued outgoing packets are sent.
|
|
||||||
@param peer peer to request a disconnection
|
|
||||||
@param data data describing the disconnection
|
|
||||||
@remarks An ENET_EVENT_DISCONNECT event will be generated by enet_host_service()
|
|
||||||
once the disconnection is complete.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
enet_peer_disconnect_later (ENetPeer * peer, enet_uint32 data)
|
|
||||||
{
|
|
||||||
if ((peer -> state == ENET_PEER_STATE_CONNECTED || peer -> state == ENET_PEER_STATE_DISCONNECT_LATER) &&
|
|
||||||
! (enet_list_empty (& peer -> outgoingReliableCommands) &&
|
|
||||||
enet_list_empty (& peer -> outgoingUnreliableCommands) &&
|
|
||||||
enet_list_empty (& peer -> sentReliableCommands)))
|
|
||||||
{
|
|
||||||
peer -> state = ENET_PEER_STATE_DISCONNECT_LATER;
|
|
||||||
peer -> disconnectData = data;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
enet_peer_disconnect (peer, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
ENetAcknowledgement *
|
|
||||||
enet_peer_queue_acknowledgement (ENetPeer * peer, const ENetProtocol * command, enet_uint16 sentTime)
|
|
||||||
{
|
|
||||||
ENetAcknowledgement * acknowledgement;
|
|
||||||
|
|
||||||
if (command -> header.channelID < peer -> channelCount)
|
|
||||||
{
|
|
||||||
ENetChannel * channel = & peer -> channels [command -> header.channelID];
|
|
||||||
enet_uint16 reliableWindow = command -> header.reliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE,
|
|
||||||
currentWindow = channel -> incomingReliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE;
|
|
||||||
|
|
||||||
if (command -> header.reliableSequenceNumber < channel -> incomingReliableSequenceNumber)
|
|
||||||
reliableWindow += ENET_PEER_RELIABLE_WINDOWS;
|
|
||||||
|
|
||||||
if (reliableWindow >= currentWindow + ENET_PEER_FREE_RELIABLE_WINDOWS - 1 && reliableWindow <= currentWindow + ENET_PEER_FREE_RELIABLE_WINDOWS)
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
peer -> outgoingDataTotal += sizeof (ENetProtocolAcknowledge);
|
|
||||||
|
|
||||||
acknowledgement = (ENetAcknowledgement *) enet_malloc (sizeof (ENetAcknowledgement));
|
|
||||||
|
|
||||||
acknowledgement -> sentTime = sentTime;
|
|
||||||
acknowledgement -> command = * command;
|
|
||||||
|
|
||||||
enet_list_insert (enet_list_end (& peer -> acknowledgements), acknowledgement);
|
|
||||||
|
|
||||||
return acknowledgement;
|
|
||||||
}
|
|
||||||
|
|
||||||
ENetOutgoingCommand *
|
|
||||||
enet_peer_queue_outgoing_command (ENetPeer * peer, const ENetProtocol * command, ENetPacket * packet, enet_uint32 offset, enet_uint16 length)
|
|
||||||
{
|
|
||||||
ENetChannel * channel = & peer -> channels [command -> header.channelID];
|
|
||||||
ENetOutgoingCommand * outgoingCommand;
|
|
||||||
|
|
||||||
peer -> outgoingDataTotal += enet_protocol_command_size (command -> header.command) + length;
|
|
||||||
|
|
||||||
outgoingCommand = (ENetOutgoingCommand *) enet_malloc (sizeof (ENetOutgoingCommand));
|
|
||||||
|
|
||||||
if (command -> header.channelID == 0xFF)
|
|
||||||
{
|
|
||||||
++ peer -> outgoingReliableSequenceNumber;
|
|
||||||
|
|
||||||
outgoingCommand -> reliableSequenceNumber = peer -> outgoingReliableSequenceNumber;
|
|
||||||
outgoingCommand -> unreliableSequenceNumber = 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
if (command -> header.command & ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE)
|
|
||||||
{
|
|
||||||
++ channel -> outgoingReliableSequenceNumber;
|
|
||||||
channel -> outgoingUnreliableSequenceNumber = 0;
|
|
||||||
|
|
||||||
outgoingCommand -> reliableSequenceNumber = channel -> outgoingReliableSequenceNumber;
|
|
||||||
outgoingCommand -> unreliableSequenceNumber = 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
if (command -> header.command & ENET_PROTOCOL_COMMAND_FLAG_UNSEQUENCED)
|
|
||||||
{
|
|
||||||
++ peer -> outgoingUnsequencedGroup;
|
|
||||||
|
|
||||||
outgoingCommand -> reliableSequenceNumber = 0;
|
|
||||||
outgoingCommand -> unreliableSequenceNumber = 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
++ channel -> outgoingUnreliableSequenceNumber;
|
|
||||||
|
|
||||||
outgoingCommand -> reliableSequenceNumber = channel -> outgoingReliableSequenceNumber;
|
|
||||||
outgoingCommand -> unreliableSequenceNumber = channel -> outgoingUnreliableSequenceNumber;
|
|
||||||
}
|
|
||||||
|
|
||||||
outgoingCommand -> sendAttempts = 0;
|
|
||||||
outgoingCommand -> sentTime = 0;
|
|
||||||
outgoingCommand -> roundTripTimeout = 0;
|
|
||||||
outgoingCommand -> roundTripTimeoutLimit = 0;
|
|
||||||
outgoingCommand -> fragmentOffset = offset;
|
|
||||||
outgoingCommand -> fragmentLength = length;
|
|
||||||
outgoingCommand -> packet = packet;
|
|
||||||
outgoingCommand -> command = * command;
|
|
||||||
outgoingCommand -> command.header.reliableSequenceNumber = ENET_HOST_TO_NET_16 (outgoingCommand -> reliableSequenceNumber);
|
|
||||||
|
|
||||||
if (packet != NULL)
|
|
||||||
++ packet -> referenceCount;
|
|
||||||
|
|
||||||
if (command -> header.command & ENET_PROTOCOL_COMMAND_FLAG_ACKNOWLEDGE)
|
|
||||||
enet_list_insert (enet_list_end (& peer -> outgoingReliableCommands), outgoingCommand);
|
|
||||||
else
|
|
||||||
enet_list_insert (enet_list_end (& peer -> outgoingUnreliableCommands), outgoingCommand);
|
|
||||||
|
|
||||||
return outgoingCommand;
|
|
||||||
}
|
|
||||||
|
|
||||||
ENetIncomingCommand *
|
|
||||||
enet_peer_queue_incoming_command (ENetPeer * peer, const ENetProtocol * command, ENetPacket * packet, enet_uint32 fragmentCount)
|
|
||||||
{
|
|
||||||
ENetChannel * channel = & peer -> channels [command -> header.channelID];
|
|
||||||
enet_uint32 unreliableSequenceNumber = 0, reliableSequenceNumber;
|
|
||||||
enet_uint16 reliableWindow, currentWindow;
|
|
||||||
ENetIncomingCommand * incomingCommand;
|
|
||||||
ENetListIterator currentCommand;
|
|
||||||
|
|
||||||
if (peer -> state == ENET_PEER_STATE_DISCONNECT_LATER)
|
|
||||||
goto freePacket;
|
|
||||||
|
|
||||||
if ((command -> header.command & ENET_PROTOCOL_COMMAND_MASK) != ENET_PROTOCOL_COMMAND_SEND_UNSEQUENCED)
|
|
||||||
{
|
|
||||||
reliableSequenceNumber = command -> header.reliableSequenceNumber;
|
|
||||||
reliableWindow = reliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE;
|
|
||||||
currentWindow = channel -> incomingReliableSequenceNumber / ENET_PEER_RELIABLE_WINDOW_SIZE;
|
|
||||||
|
|
||||||
if (reliableSequenceNumber < channel -> incomingReliableSequenceNumber)
|
|
||||||
reliableWindow += ENET_PEER_RELIABLE_WINDOWS;
|
|
||||||
|
|
||||||
if (reliableWindow < currentWindow || reliableWindow >= currentWindow + ENET_PEER_FREE_RELIABLE_WINDOWS - 1)
|
|
||||||
goto freePacket;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (command -> header.command & ENET_PROTOCOL_COMMAND_MASK)
|
|
||||||
{
|
|
||||||
case ENET_PROTOCOL_COMMAND_SEND_FRAGMENT:
|
|
||||||
case ENET_PROTOCOL_COMMAND_SEND_RELIABLE:
|
|
||||||
if (reliableSequenceNumber == channel -> incomingReliableSequenceNumber)
|
|
||||||
goto freePacket;
|
|
||||||
|
|
||||||
for (currentCommand = enet_list_previous (enet_list_end (& channel -> incomingReliableCommands));
|
|
||||||
currentCommand != enet_list_end (& channel -> incomingReliableCommands);
|
|
||||||
currentCommand = enet_list_previous (currentCommand))
|
|
||||||
{
|
|
||||||
incomingCommand = (ENetIncomingCommand *) currentCommand;
|
|
||||||
|
|
||||||
if (reliableSequenceNumber >= channel -> incomingReliableSequenceNumber)
|
|
||||||
{
|
|
||||||
if (incomingCommand -> reliableSequenceNumber < channel -> incomingReliableSequenceNumber)
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
if (incomingCommand -> reliableSequenceNumber >= channel -> incomingReliableSequenceNumber)
|
|
||||||
break;
|
|
||||||
|
|
||||||
if (incomingCommand -> reliableSequenceNumber <= reliableSequenceNumber)
|
|
||||||
{
|
|
||||||
if (incomingCommand -> reliableSequenceNumber < reliableSequenceNumber)
|
|
||||||
break;
|
|
||||||
|
|
||||||
goto freePacket;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ENET_PROTOCOL_COMMAND_SEND_UNRELIABLE:
|
|
||||||
unreliableSequenceNumber = ENET_NET_TO_HOST_16 (command -> sendUnreliable.unreliableSequenceNumber);
|
|
||||||
|
|
||||||
for (currentCommand = enet_list_previous (enet_list_end (& channel -> incomingUnreliableCommands));
|
|
||||||
currentCommand != enet_list_end (& channel -> incomingUnreliableCommands);
|
|
||||||
currentCommand = enet_list_previous (currentCommand))
|
|
||||||
{
|
|
||||||
incomingCommand = (ENetIncomingCommand *) currentCommand;
|
|
||||||
|
|
||||||
if ((incomingCommand -> command.header.command & ENET_PROTOCOL_COMMAND_MASK) != ENET_PROTOCOL_COMMAND_SEND_UNRELIABLE)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (reliableSequenceNumber >= channel -> incomingReliableSequenceNumber)
|
|
||||||
{
|
|
||||||
if (incomingCommand -> reliableSequenceNumber < channel -> incomingReliableSequenceNumber)
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
if (incomingCommand -> reliableSequenceNumber >= channel -> incomingReliableSequenceNumber)
|
|
||||||
break;
|
|
||||||
|
|
||||||
if (incomingCommand -> reliableSequenceNumber < reliableSequenceNumber)
|
|
||||||
break;
|
|
||||||
|
|
||||||
if (incomingCommand -> reliableSequenceNumber > reliableSequenceNumber)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (incomingCommand -> unreliableSequenceNumber <= unreliableSequenceNumber)
|
|
||||||
{
|
|
||||||
if (incomingCommand -> unreliableSequenceNumber < unreliableSequenceNumber)
|
|
||||||
break;
|
|
||||||
|
|
||||||
goto freePacket;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ENET_PROTOCOL_COMMAND_SEND_UNSEQUENCED:
|
|
||||||
currentCommand = enet_list_end (& channel -> incomingUnreliableCommands);
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
goto freePacket;
|
|
||||||
}
|
|
||||||
|
|
||||||
incomingCommand = (ENetIncomingCommand *) enet_malloc (sizeof (ENetIncomingCommand));
|
|
||||||
|
|
||||||
incomingCommand -> reliableSequenceNumber = command -> header.reliableSequenceNumber;
|
|
||||||
incomingCommand -> unreliableSequenceNumber = unreliableSequenceNumber & 0xFFFF;
|
|
||||||
incomingCommand -> command = * command;
|
|
||||||
incomingCommand -> fragmentCount = fragmentCount;
|
|
||||||
incomingCommand -> fragmentsRemaining = fragmentCount;
|
|
||||||
incomingCommand -> packet = packet;
|
|
||||||
incomingCommand -> fragments = NULL;
|
|
||||||
|
|
||||||
if (fragmentCount > 0)
|
|
||||||
{
|
|
||||||
incomingCommand -> fragments = (enet_uint32 *) enet_malloc ((fragmentCount + 31) / 32 * sizeof (enet_uint32));
|
|
||||||
memset (incomingCommand -> fragments, 0, (fragmentCount + 31) / 32 * sizeof (enet_uint32));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (packet != NULL)
|
|
||||||
++ packet -> referenceCount;
|
|
||||||
|
|
||||||
enet_list_insert (enet_list_next (currentCommand), incomingCommand);
|
|
||||||
|
|
||||||
return incomingCommand;
|
|
||||||
|
|
||||||
freePacket:
|
|
||||||
if (packet != NULL)
|
|
||||||
{
|
|
||||||
if (packet -> referenceCount == 0)
|
|
||||||
enet_packet_destroy (packet);
|
|
||||||
}
|
|
||||||
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** @} */
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,325 +0,0 @@
|
||||||
* Using ENet
|
|
||||||
|
|
||||||
Before using ENet, you must call enet_initialize() to initialize the
|
|
||||||
library. Upon program exit, you should call enet_deinitialize() so that
|
|
||||||
the library may clean up any used resources.
|
|
||||||
|
|
||||||
i.e.
|
|
||||||
|
|
||||||
int
|
|
||||||
main (int argc, char ** argv)
|
|
||||||
{
|
|
||||||
if (enet_initialize () != 0)
|
|
||||||
{
|
|
||||||
fprintf (stderror, "An error occurred while initializing ENet.\n");
|
|
||||||
return EXIT_FAILURE;
|
|
||||||
}
|
|
||||||
atexit (enet_deinitialize);
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
}
|
|
||||||
|
|
||||||
* Creating an ENet server
|
|
||||||
|
|
||||||
Servers in ENet are constructed with enet_host_create(). You must specify
|
|
||||||
an address on which to receive data and new connections, as well as the maximum
|
|
||||||
allowable numbers of connected peers. You may optionally specify the incoming
|
|
||||||
and outgoing bandwidth of the server in bytes per second so that ENet may try
|
|
||||||
to statically manage bandwidth resources among connected peers in addition to
|
|
||||||
its dynamic throttling algorithm; specifying 0 for these two options will cause
|
|
||||||
ENet to rely entirely upon its dynamic throttling algorithm to manage
|
|
||||||
bandwidth.
|
|
||||||
|
|
||||||
When done with a host, the host may be destroyed with enet_host_destroy().
|
|
||||||
All connected peers to the host will be reset, and the resources used by
|
|
||||||
the host will be freed.
|
|
||||||
|
|
||||||
i.e.
|
|
||||||
|
|
||||||
ENetAddress address;
|
|
||||||
ENetHost * server;
|
|
||||||
|
|
||||||
/* Bind the server to the default localhost.
|
|
||||||
* A specific host address can be specified by
|
|
||||||
* enet_address_set_host (& address, "x.x.x.x");
|
|
||||||
*/
|
|
||||||
address.host = ENET_HOST_ANY;
|
|
||||||
/* Bind the server to port 1234. */
|
|
||||||
address.port = 1234;
|
|
||||||
|
|
||||||
server = enet_host_create (& address /* the address to bind the server host to */,
|
|
||||||
32 /* allow up to 32 clients and/or outgoing connections */,
|
|
||||||
0 /* assume any amount of incoming bandwidth */,
|
|
||||||
0 /* assume any amount of outgoing bandwidth */);
|
|
||||||
if (server == NULL)
|
|
||||||
{
|
|
||||||
fprintf (stderr,
|
|
||||||
"An error occurred while trying to create an ENet server host.\n");
|
|
||||||
exit (EXIT_FAILURE);
|
|
||||||
}
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
enet_host_destroy(server);
|
|
||||||
|
|
||||||
* Creating an ENet client
|
|
||||||
|
|
||||||
Clients in ENet are similarly constructed with enet_host_create() when no
|
|
||||||
address is specified to bind the host to. Bandwidth may be specified for the
|
|
||||||
client host as in the above example. The peer count controls the maximum number
|
|
||||||
of connections to other server hosts that may be simultaneously open.
|
|
||||||
|
|
||||||
i.e.
|
|
||||||
|
|
||||||
ENetHost * client;
|
|
||||||
|
|
||||||
clienet = enet_host_create (NULL /* create a client host */,
|
|
||||||
1 /* only allow 1 outgoing connection */,
|
|
||||||
57600 / 8 /* 56K modem with 56 Kbps downstream bandwidth */,
|
|
||||||
14400 / 8 /* 56K modem with 14 Kbps upstream bandwidth */);
|
|
||||||
|
|
||||||
if (client == NULL)
|
|
||||||
{
|
|
||||||
fprintf (stderr,
|
|
||||||
"An error occurred while trying to create an ENet client host.\n");
|
|
||||||
exit (EXIT_FAILURE);
|
|
||||||
}
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
enet_host_destroy(client);
|
|
||||||
|
|
||||||
* Managing an ENet host
|
|
||||||
|
|
||||||
ENet uses a polled event model to notify the programmer of significant
|
|
||||||
events. ENet hosts are polled for events with enet_host_service(), where an
|
|
||||||
optional timeout value in milliseconds may be specified to control how long
|
|
||||||
ENet will poll; if a timeout of 0 is specified, enet_host_service() will
|
|
||||||
return immediately if there are no events to dispatch. enet_host_service()
|
|
||||||
will return 1 if an event was dispatched within the specified timeout.
|
|
||||||
|
|
||||||
Currently there are only four types of significant events in ENet:
|
|
||||||
|
|
||||||
An event of type ENET_EVENT_TYPE_NONE is returned if no event occurred
|
|
||||||
within the specified time limit. enet_host_service() will return 0
|
|
||||||
with this event.
|
|
||||||
|
|
||||||
An event of type ENET_EVENT_TYPE_CONNECT is returned when either a new client
|
|
||||||
host has connected to the server host or when an attempt to establish a
|
|
||||||
connection with a foreign host has succeeded. Only the "peer" field of the
|
|
||||||
event structure is valid for this event and contains the newly connected peer.
|
|
||||||
|
|
||||||
An event of type ENET_EVENT_TYPE_RECEIVE is returned when a packet is received
|
|
||||||
from a connected peer. The "peer" field contains the peer the packet was
|
|
||||||
received from, "channelID" is the channel on which the packet was sent, and
|
|
||||||
"packet" is the packet that was sent. The packet contained in the "packet"
|
|
||||||
field must be destroyed with enet_packet_destroy() when you are done
|
|
||||||
inspecting its contents.
|
|
||||||
|
|
||||||
An event of type ENET_EVENT_TYPE_DISCONNECT is returned when a connected peer
|
|
||||||
has either explicitly disconnected or timed out. Only the "peer" field of the
|
|
||||||
event structure is valid for this event and contains the peer that
|
|
||||||
disconnected. Only the "data" field of the peer is still valid on a
|
|
||||||
disconnect event and must be explicitly reset.
|
|
||||||
|
|
||||||
i.e.
|
|
||||||
|
|
||||||
ENetEvent event;
|
|
||||||
|
|
||||||
/* Wait up to 1000 milliseconds for an event. */
|
|
||||||
while (enet_host_service (client, & event, 1000) > 0)
|
|
||||||
{
|
|
||||||
switch (event.type)
|
|
||||||
{
|
|
||||||
case ENET_EVENT_TYPE_CONNECT:
|
|
||||||
printf ("A new client connected from %x:%u.\n",
|
|
||||||
event.peer -> address.host,
|
|
||||||
event.peer -> address.port);
|
|
||||||
|
|
||||||
/* Store any relevant client information here. */
|
|
||||||
event.peer -> data = "Client information";
|
|
||||||
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ENET_EVENT_TYPE_RECEIVE:
|
|
||||||
printf ("A packet of length %u containing %s was received from %s on channel %u.\n",
|
|
||||||
event.packet -> dataLength,
|
|
||||||
event.packet -> data,
|
|
||||||
event.peer -> data,
|
|
||||||
event.channelID);
|
|
||||||
|
|
||||||
/* Clean up the packet now that we're done using it. */
|
|
||||||
enet_packet_destroy (event.packet);
|
|
||||||
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ENET_EVENT_TYPE_DISCONNECT:
|
|
||||||
printf ("%s disconected.\n", event.peer -> data);
|
|
||||||
|
|
||||||
/* Reset the peer's client information. */
|
|
||||||
|
|
||||||
event.peer -> data = NULL;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
|
|
||||||
* Sending a packet to an ENet peer
|
|
||||||
|
|
||||||
Packets in ENet are created with enet_packet_create(), where the size of
|
|
||||||
the packet must be specified. Optionally, initial data may be specified to
|
|
||||||
copy into the packet.
|
|
||||||
|
|
||||||
Certain flags may also be supplied to enet_packet_create() to control
|
|
||||||
various packet features:
|
|
||||||
|
|
||||||
ENET_PACKET_FLAG_RELIABLE specifies that the packet must use reliable delivery.
|
|
||||||
A reliable packet is guarenteed to be delivered, and a number of retry attempts
|
|
||||||
will be made until an acknowledgement is received from the foreign host the
|
|
||||||
packet is sent to. If a certain number of retry attempts is reached without
|
|
||||||
any acknowledgement, ENet will assume the peer has disconnected and forcefully
|
|
||||||
reset the connection. If this flag is not specified, the packet is assumed
|
|
||||||
an unreliable packet, and no retry attempts will be made nor acknowledgements
|
|
||||||
generated.
|
|
||||||
|
|
||||||
A packet may be resized (extended or truncated) with enet_packet_resize().
|
|
||||||
|
|
||||||
A packet is sent to a foreign host with enet_peer_send(). enet_peer_send()
|
|
||||||
accepts a channel id over which to send the packet to a given peer. Once the
|
|
||||||
packet is handed over to ENet with enet_peer_send(), ENet will handle its
|
|
||||||
deallocation and enet_packet_destroy() should not be used upon it.
|
|
||||||
|
|
||||||
One may also use enet_host_broadcast() to send a packet to all connected
|
|
||||||
peers on a given host over a specified channel id, as with enet_peer_send().
|
|
||||||
|
|
||||||
Queued packets will be sent on a call to enet_host_service().
|
|
||||||
Alternatively, enet_host_flush() will send out queued packets without
|
|
||||||
dispatching any events.
|
|
||||||
|
|
||||||
i.e.
|
|
||||||
|
|
||||||
/* Create a reliable packet of size 7 containing "packet\0" */
|
|
||||||
ENetPacket * packet = enet_packet_create ("packet",
|
|
||||||
strlen ("packet") + 1,
|
|
||||||
ENET_PACKET_FLAG_RELIABLE);
|
|
||||||
|
|
||||||
/* Extend the packet so and append the string "foo", so it now
|
|
||||||
* contains "packetfoo\0"
|
|
||||||
*
|
|
||||||
enet_packet_resize (packet, strlen ("packetfoo") + 1);
|
|
||||||
strcpy (& packet -> data [strlen ("packet")], "foo");
|
|
||||||
|
|
||||||
/* Send the packet to the peer over channel id 3.
|
|
||||||
* One could also broadcast the packet by
|
|
||||||
* enet_host_broadcast (host, 3, packet);
|
|
||||||
*/
|
|
||||||
enet_peer_send (peer, 3, packet);
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
/* One could just use enet_host_service() instead. */
|
|
||||||
enet_host_flush (host);
|
|
||||||
|
|
||||||
* Disconnecting an ENet peer
|
|
||||||
|
|
||||||
Peers may be gently disconnected with enet_peer_disconnect(). A disconnect
|
|
||||||
request will be sent to the foreign host, and ENet will wait for an
|
|
||||||
acknowledgement from the foreign host before finally disconnecting. An
|
|
||||||
event of type ENET_EVENT_TYPE_DISCONNECT will be generated once the
|
|
||||||
disconnection succeeds. Normally timeouts apply to the disconnect
|
|
||||||
acknowledgement, and so if no acknowledgement is received after a length
|
|
||||||
of time the peer will be forcefully disconnected.
|
|
||||||
|
|
||||||
enet_peer_reset() will forcefully disconnect a peer. The foreign host
|
|
||||||
will get no notification of a disconnect and will time out on the foreign
|
|
||||||
host. No event is generated.
|
|
||||||
|
|
||||||
i.e.
|
|
||||||
ENetEvent event;
|
|
||||||
|
|
||||||
enet_peer_disconnect (& client -> peers [0], 0);
|
|
||||||
|
|
||||||
/* Allow up to 3 seconds for the disconnect to succeed
|
|
||||||
* and drop any packets received packets.
|
|
||||||
*/
|
|
||||||
while (enet_host_service (client, & event, 3000) > 0)
|
|
||||||
{
|
|
||||||
switch (event.type)
|
|
||||||
{
|
|
||||||
case ENET_EVENT_TYPE_RECEIVE:
|
|
||||||
enet_packet_destroy (event.packet);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ENET_EVENT_TYPE_DISCONNECT:
|
|
||||||
puts ("Disconnection succeeded.");
|
|
||||||
return;
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* We've arrived here, so the disconnect attempt didn't succeed yet.
|
|
||||||
* Force the connection down.
|
|
||||||
*/
|
|
||||||
enet_peer_reset (& client -> peers [0]);
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
|
|
||||||
* Connecting to an ENet host
|
|
||||||
|
|
||||||
A connection to a foregin host is initiated with enet_host_connect().
|
|
||||||
It accepts the address of a foreign host to connect to, and the number of
|
|
||||||
channels that should be allocated for communication. If N channels are
|
|
||||||
allocated for use, their channel ids will be numbered 0 through N-1.
|
|
||||||
A peer representing the connection attempt is returned, or NULL if there
|
|
||||||
were no available peers over which to initiate the connection. When the
|
|
||||||
connection attempt succeeds, an event of type ENET_EVENT_TYPE_CONNECT will
|
|
||||||
be generated. If the connection attempt times out or otherwise fails, an
|
|
||||||
event of type ENET_EVENT_TYPE_DISCONNECT will be generated.
|
|
||||||
|
|
||||||
i.e.
|
|
||||||
ENetAddress address;
|
|
||||||
ENetEvent event;
|
|
||||||
ENetPeer *peer;
|
|
||||||
|
|
||||||
/* Connect to some.server.net:1234. */
|
|
||||||
enet_address_set_host (& address, "some.server.net");
|
|
||||||
address.port = 1234;
|
|
||||||
|
|
||||||
/* Initiate the connection, allocating the two channels 0 and 1. */
|
|
||||||
peer = enet_host_connect (client, & address, 2);
|
|
||||||
|
|
||||||
if (peer == NULL)
|
|
||||||
{
|
|
||||||
fprintf (stderr,
|
|
||||||
"No available peers for initiating an ENet connection.\n");
|
|
||||||
exit (EXIT_FAILURE);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Wait up to 5 seconds for the connection attempt to succeed.
|
|
||||||
if (enet_host_service (client, & event, 5000) > 0 &&
|
|
||||||
event.type == ENET_EVENT_TYPE_CONNECT)
|
|
||||||
{
|
|
||||||
puts ("Connection to some.server.net:1234 succeeded.");
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* Either the 5 seconds are up or a disconnect event was
|
|
||||||
* received. Reset the peer in the event the 5 seconds
|
|
||||||
* had run out without any significant event.
|
|
||||||
*/
|
|
||||||
enet_peer_reset (peer);
|
|
||||||
|
|
||||||
puts ("Connection to some.server.net:1234 failed.");
|
|
||||||
}
|
|
||||||
...
|
|
||||||
...
|
|
||||||
...
|
|
||||||
|
|
|
@ -1,417 +0,0 @@
|
||||||
/**
|
|
||||||
@file unix.c
|
|
||||||
@brief ENet Unix system specific functions
|
|
||||||
*/
|
|
||||||
#ifndef WIN32
|
|
||||||
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <sys/socket.h>
|
|
||||||
#include <sys/ioctl.h>
|
|
||||||
#include <sys/time.h>
|
|
||||||
#include <arpa/inet.h>
|
|
||||||
#include <netdb.h>
|
|
||||||
#include <unistd.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include <errno.h>
|
|
||||||
#include <time.h>
|
|
||||||
|
|
||||||
#define ENET_BUILDING_LIB 1
|
|
||||||
#include "enet/enet.h"
|
|
||||||
|
|
||||||
#ifdef HAS_FCNTL
|
|
||||||
#include <fcntl.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef __APPLE__
|
|
||||||
#undef HAS_POLL
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef HAS_POLL
|
|
||||||
#include <sys/poll.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef HAS_SOCKLEN_T
|
|
||||||
typedef int socklen_t;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef MSG_NOSIGNAL
|
|
||||||
#define MSG_NOSIGNAL 0
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static enet_uint32 timeBase = 0;
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_initialize (void)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
enet_deinitialize (void)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
enet_uint32
|
|
||||||
enet_time_get (void)
|
|
||||||
{
|
|
||||||
struct timeval timeVal;
|
|
||||||
|
|
||||||
gettimeofday (& timeVal, NULL);
|
|
||||||
|
|
||||||
return timeVal.tv_sec * 1000 + timeVal.tv_usec / 1000 - timeBase;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
enet_time_set (enet_uint32 newTimeBase)
|
|
||||||
{
|
|
||||||
struct timeval timeVal;
|
|
||||||
|
|
||||||
gettimeofday (& timeVal, NULL);
|
|
||||||
|
|
||||||
timeBase = timeVal.tv_sec * 1000 + timeVal.tv_usec / 1000 - newTimeBase;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_address_set_host (ENetAddress * address, const char * name)
|
|
||||||
{
|
|
||||||
struct hostent * hostEntry = NULL;
|
|
||||||
#ifdef HAS_GETHOSTBYNAME_R
|
|
||||||
struct hostent hostData;
|
|
||||||
char buffer [2048];
|
|
||||||
int errnum;
|
|
||||||
|
|
||||||
#if defined(linux) || defined(__FreeBSD__)
|
|
||||||
gethostbyname_r (name, & hostData, buffer, sizeof (buffer), & hostEntry, & errnum);
|
|
||||||
#else
|
|
||||||
hostEntry = gethostbyname_r (name, & hostData, buffer, sizeof (buffer), & errnum);
|
|
||||||
#endif
|
|
||||||
#else
|
|
||||||
hostEntry = gethostbyname (name);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (hostEntry == NULL ||
|
|
||||||
hostEntry -> h_addrtype != AF_INET)
|
|
||||||
{
|
|
||||||
#ifdef HAS_INET_PTON
|
|
||||||
if (! inet_pton (AF_INET, name, & address -> host))
|
|
||||||
#else
|
|
||||||
if (! inet_aton (name, (struct in_addr *) & address -> host))
|
|
||||||
#endif
|
|
||||||
return -1;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
address -> host = * (enet_uint32 *) hostEntry -> h_addr_list [0];
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_address_get_host_ip (const ENetAddress * address, char * name, size_t nameLength)
|
|
||||||
{
|
|
||||||
#ifdef HAS_INET_NTOP
|
|
||||||
if (inet_ntop (AF_INET, & address -> host, name, nameLength) == NULL)
|
|
||||||
#else
|
|
||||||
char * addr = inet_ntoa (* (struct in_addr *) & address -> host);
|
|
||||||
if (addr != NULL)
|
|
||||||
strncpy (name, addr, nameLength);
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
return -1;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_address_get_host (const ENetAddress * address, char * name, size_t nameLength)
|
|
||||||
{
|
|
||||||
struct in_addr in;
|
|
||||||
struct hostent * hostEntry = NULL;
|
|
||||||
#ifdef HAS_GETHOSTBYADDR_R
|
|
||||||
struct hostent hostData;
|
|
||||||
char buffer [2048];
|
|
||||||
int errnum;
|
|
||||||
|
|
||||||
in.s_addr = address -> host;
|
|
||||||
|
|
||||||
#if defined(linux) || defined(__FreeBSD__)
|
|
||||||
gethostbyaddr_r ((char *) & in, sizeof (struct in_addr), AF_INET, & hostData, buffer, sizeof (buffer), & hostEntry, & errnum);
|
|
||||||
#else
|
|
||||||
hostEntry = gethostbyaddr_r ((char *) & in, sizeof (struct in_addr), AF_INET, & hostData, buffer, sizeof (buffer), & errnum);
|
|
||||||
#endif
|
|
||||||
#else
|
|
||||||
in.s_addr = address -> host;
|
|
||||||
|
|
||||||
hostEntry = gethostbyaddr ((char *) & in, sizeof (struct in_addr), AF_INET);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (hostEntry == NULL)
|
|
||||||
return enet_address_get_host_ip (address, name, nameLength);
|
|
||||||
|
|
||||||
strncpy (name, hostEntry -> h_name, nameLength);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
ENetSocket
|
|
||||||
enet_socket_create (ENetSocketType type, const ENetAddress * address)
|
|
||||||
{
|
|
||||||
ENetSocket newSocket = socket (PF_INET, type == ENET_SOCKET_TYPE_DATAGRAM ? SOCK_DGRAM : SOCK_STREAM, 0);
|
|
||||||
struct sockaddr_in sin;
|
|
||||||
|
|
||||||
if (newSocket == ENET_SOCKET_NULL)
|
|
||||||
return ENET_SOCKET_NULL;
|
|
||||||
|
|
||||||
if (address == NULL)
|
|
||||||
return newSocket;
|
|
||||||
|
|
||||||
memset (& sin, 0, sizeof (struct sockaddr_in));
|
|
||||||
|
|
||||||
sin.sin_family = AF_INET;
|
|
||||||
sin.sin_port = ENET_HOST_TO_NET_16 (address -> port);
|
|
||||||
sin.sin_addr.s_addr = address -> host;
|
|
||||||
|
|
||||||
if (bind (newSocket,
|
|
||||||
(struct sockaddr *) & sin,
|
|
||||||
sizeof (struct sockaddr_in)) == -1 ||
|
|
||||||
(type == ENET_SOCKET_TYPE_STREAM &&
|
|
||||||
address -> port != ENET_PORT_ANY &&
|
|
||||||
listen (newSocket, SOMAXCONN) == -1))
|
|
||||||
{
|
|
||||||
close (newSocket);
|
|
||||||
|
|
||||||
return ENET_SOCKET_NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
return newSocket;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_socket_set_option (ENetSocket socket, ENetSocketOption option, int value)
|
|
||||||
{
|
|
||||||
int result = -1;
|
|
||||||
switch (option)
|
|
||||||
{
|
|
||||||
case ENET_SOCKOPT_NONBLOCK:
|
|
||||||
#ifdef HAS_FCNTL
|
|
||||||
result = fcntl (socket, F_SETFL, O_NONBLOCK | fcntl (socket, F_GETFL));
|
|
||||||
#else
|
|
||||||
result = ioctl (socket, FIONBIO, & value);
|
|
||||||
#endif
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ENET_SOCKOPT_BROADCAST:
|
|
||||||
result = setsockopt (socket, SOL_SOCKET, SO_BROADCAST, (char *) & value, sizeof (int));
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ENET_SOCKOPT_RCVBUF:
|
|
||||||
result = setsockopt (socket, SOL_SOCKET, SO_RCVBUF, (char *) & value, sizeof (int));
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ENET_SOCKOPT_SNDBUF:
|
|
||||||
result = setsockopt (socket, SOL_SOCKET, SO_SNDBUF, (char *) & value, sizeof (int));
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return result == -1 ? -1 : 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_socket_connect (ENetSocket socket, const ENetAddress * address)
|
|
||||||
{
|
|
||||||
struct sockaddr_in sin;
|
|
||||||
|
|
||||||
memset (& sin, 0, sizeof (struct sockaddr_in));
|
|
||||||
|
|
||||||
sin.sin_family = AF_INET;
|
|
||||||
sin.sin_port = ENET_HOST_TO_NET_16 (address -> port);
|
|
||||||
sin.sin_addr.s_addr = address -> host;
|
|
||||||
|
|
||||||
return connect (socket, (struct sockaddr *) & sin, sizeof (struct sockaddr_in));
|
|
||||||
}
|
|
||||||
|
|
||||||
ENetSocket
|
|
||||||
enet_socket_accept (ENetSocket socket, ENetAddress * address)
|
|
||||||
{
|
|
||||||
int result;
|
|
||||||
struct sockaddr_in sin;
|
|
||||||
socklen_t sinLength = sizeof (struct sockaddr_in);
|
|
||||||
|
|
||||||
result = accept (socket,
|
|
||||||
address != NULL ? (struct sockaddr *) & sin : NULL,
|
|
||||||
address != NULL ? & sinLength : NULL);
|
|
||||||
|
|
||||||
if (result == -1)
|
|
||||||
return ENET_SOCKET_NULL;
|
|
||||||
|
|
||||||
if (address != NULL)
|
|
||||||
{
|
|
||||||
address -> host = (enet_uint32) sin.sin_addr.s_addr;
|
|
||||||
address -> port = ENET_NET_TO_HOST_16 (sin.sin_port);
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
enet_socket_destroy (ENetSocket socket)
|
|
||||||
{
|
|
||||||
close (socket);
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_socket_send (ENetSocket socket,
|
|
||||||
const ENetAddress * address,
|
|
||||||
const ENetBuffer * buffers,
|
|
||||||
size_t bufferCount)
|
|
||||||
{
|
|
||||||
struct msghdr msgHdr;
|
|
||||||
struct sockaddr_in sin;
|
|
||||||
int sentLength;
|
|
||||||
|
|
||||||
memset (& msgHdr, 0, sizeof (struct msghdr));
|
|
||||||
|
|
||||||
if (address != NULL)
|
|
||||||
{
|
|
||||||
sin.sin_family = AF_INET;
|
|
||||||
sin.sin_port = ENET_HOST_TO_NET_16 (address -> port);
|
|
||||||
sin.sin_addr.s_addr = address -> host;
|
|
||||||
|
|
||||||
msgHdr.msg_name = & sin;
|
|
||||||
msgHdr.msg_namelen = sizeof (struct sockaddr_in);
|
|
||||||
}
|
|
||||||
|
|
||||||
msgHdr.msg_iov = (struct iovec *) buffers;
|
|
||||||
msgHdr.msg_iovlen = bufferCount;
|
|
||||||
|
|
||||||
sentLength = sendmsg (socket, & msgHdr, MSG_NOSIGNAL);
|
|
||||||
|
|
||||||
if (sentLength == -1)
|
|
||||||
{
|
|
||||||
if (errno == EWOULDBLOCK)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return sentLength;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_socket_receive (ENetSocket socket,
|
|
||||||
ENetAddress * address,
|
|
||||||
ENetBuffer * buffers,
|
|
||||||
size_t bufferCount)
|
|
||||||
{
|
|
||||||
struct msghdr msgHdr;
|
|
||||||
struct sockaddr_in sin;
|
|
||||||
int recvLength;
|
|
||||||
|
|
||||||
memset (& msgHdr, 0, sizeof (struct msghdr));
|
|
||||||
|
|
||||||
if (address != NULL)
|
|
||||||
{
|
|
||||||
msgHdr.msg_name = & sin;
|
|
||||||
msgHdr.msg_namelen = sizeof (struct sockaddr_in);
|
|
||||||
}
|
|
||||||
|
|
||||||
msgHdr.msg_iov = (struct iovec *) buffers;
|
|
||||||
msgHdr.msg_iovlen = bufferCount;
|
|
||||||
|
|
||||||
recvLength = recvmsg (socket, & msgHdr, MSG_NOSIGNAL);
|
|
||||||
|
|
||||||
if (recvLength == -1)
|
|
||||||
{
|
|
||||||
if (errno == EWOULDBLOCK)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef HAS_MSGHDR_FLAGS
|
|
||||||
if (msgHdr.msg_flags & MSG_TRUNC)
|
|
||||||
return -1;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (address != NULL)
|
|
||||||
{
|
|
||||||
address -> host = (enet_uint32) sin.sin_addr.s_addr;
|
|
||||||
address -> port = ENET_NET_TO_HOST_16 (sin.sin_port);
|
|
||||||
}
|
|
||||||
|
|
||||||
return recvLength;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_socket_wait (ENetSocket socket, enet_uint32 * condition, enet_uint32 timeout)
|
|
||||||
{
|
|
||||||
#ifdef HAS_POLL
|
|
||||||
struct pollfd pollSocket;
|
|
||||||
int pollCount;
|
|
||||||
|
|
||||||
pollSocket.fd = socket;
|
|
||||||
pollSocket.events = 0;
|
|
||||||
|
|
||||||
if (* condition & ENET_SOCKET_WAIT_SEND)
|
|
||||||
pollSocket.events |= POLLOUT;
|
|
||||||
|
|
||||||
if (* condition & ENET_SOCKET_WAIT_RECEIVE)
|
|
||||||
pollSocket.events |= POLLIN;
|
|
||||||
|
|
||||||
pollCount = poll (& pollSocket, 1, timeout);
|
|
||||||
|
|
||||||
if (pollCount < 0)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
* condition = ENET_SOCKET_WAIT_NONE;
|
|
||||||
|
|
||||||
if (pollCount == 0)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
if (pollSocket.revents & POLLOUT)
|
|
||||||
* condition |= ENET_SOCKET_WAIT_SEND;
|
|
||||||
|
|
||||||
if (pollSocket.revents & POLLIN)
|
|
||||||
* condition |= ENET_SOCKET_WAIT_RECEIVE;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
#else
|
|
||||||
fd_set readSet, writeSet;
|
|
||||||
struct timeval timeVal;
|
|
||||||
int selectCount;
|
|
||||||
|
|
||||||
timeVal.tv_sec = timeout / 1000;
|
|
||||||
timeVal.tv_usec = (timeout % 1000) * 1000;
|
|
||||||
|
|
||||||
FD_ZERO (& readSet);
|
|
||||||
FD_ZERO (& writeSet);
|
|
||||||
|
|
||||||
if (* condition & ENET_SOCKET_WAIT_SEND)
|
|
||||||
FD_SET (socket, & writeSet);
|
|
||||||
|
|
||||||
if (* condition & ENET_SOCKET_WAIT_RECEIVE)
|
|
||||||
FD_SET (socket, & readSet);
|
|
||||||
|
|
||||||
selectCount = select (socket + 1, & readSet, & writeSet, NULL, & timeVal);
|
|
||||||
|
|
||||||
if (selectCount < 0)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
* condition = ENET_SOCKET_WAIT_NONE;
|
|
||||||
|
|
||||||
if (selectCount == 0)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
if (FD_ISSET (socket, & writeSet))
|
|
||||||
* condition |= ENET_SOCKET_WAIT_SEND;
|
|
||||||
|
|
||||||
if (FD_ISSET (socket, & readSet))
|
|
||||||
* condition |= ENET_SOCKET_WAIT_RECEIVE;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
|
@ -1,334 +0,0 @@
|
||||||
/**
|
|
||||||
@file win32.c
|
|
||||||
@brief ENet Win32 system specific functions
|
|
||||||
*/
|
|
||||||
#ifdef WIN32
|
|
||||||
|
|
||||||
#include <time.h>
|
|
||||||
#define ENET_BUILDING_LIB 1
|
|
||||||
#include "enet/enet.h"
|
|
||||||
|
|
||||||
static enet_uint32 timeBase = 0;
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_initialize (void)
|
|
||||||
{
|
|
||||||
WORD versionRequested = MAKEWORD (1, 1);
|
|
||||||
WSADATA wsaData;
|
|
||||||
|
|
||||||
if (WSAStartup (versionRequested, & wsaData))
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
if (LOBYTE (wsaData.wVersion) != 1||
|
|
||||||
HIBYTE (wsaData.wVersion) != 1)
|
|
||||||
{
|
|
||||||
WSACleanup ();
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
timeBeginPeriod (1);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
enet_deinitialize (void)
|
|
||||||
{
|
|
||||||
timeEndPeriod (1);
|
|
||||||
|
|
||||||
WSACleanup ();
|
|
||||||
}
|
|
||||||
|
|
||||||
enet_uint32
|
|
||||||
enet_time_get (void)
|
|
||||||
{
|
|
||||||
return (enet_uint32) timeGetTime () - timeBase;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
enet_time_set (enet_uint32 newTimeBase)
|
|
||||||
{
|
|
||||||
timeBase = (enet_uint32) timeGetTime () - newTimeBase;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_address_set_host (ENetAddress * address, const char * name)
|
|
||||||
{
|
|
||||||
struct hostent * hostEntry;
|
|
||||||
|
|
||||||
hostEntry = gethostbyname (name);
|
|
||||||
if (hostEntry == NULL ||
|
|
||||||
hostEntry -> h_addrtype != AF_INET)
|
|
||||||
{
|
|
||||||
unsigned long host = inet_addr (name);
|
|
||||||
if (host == INADDR_NONE)
|
|
||||||
return -1;
|
|
||||||
address -> host = host;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
address -> host = * (enet_uint32 *) hostEntry -> h_addr_list [0];
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_address_get_host_ip (const ENetAddress * address, char * name, size_t nameLength)
|
|
||||||
{
|
|
||||||
char * addr = inet_ntoa (* (struct in_addr *) & address -> host);
|
|
||||||
if (addr == NULL)
|
|
||||||
return -1;
|
|
||||||
strncpy (name, addr, nameLength);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_address_get_host (const ENetAddress * address, char * name, size_t nameLength)
|
|
||||||
{
|
|
||||||
struct in_addr in;
|
|
||||||
struct hostent * hostEntry;
|
|
||||||
|
|
||||||
in.s_addr = address -> host;
|
|
||||||
|
|
||||||
hostEntry = gethostbyaddr ((char *) & in, sizeof (struct in_addr), AF_INET);
|
|
||||||
if (hostEntry == NULL)
|
|
||||||
return enet_address_get_host_ip (address, name, nameLength);
|
|
||||||
|
|
||||||
strncpy (name, hostEntry -> h_name, nameLength);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
ENetSocket
|
|
||||||
enet_socket_create (ENetSocketType type, const ENetAddress * address)
|
|
||||||
{
|
|
||||||
ENetSocket newSocket = socket (PF_INET, type == ENET_SOCKET_TYPE_DATAGRAM ? SOCK_DGRAM : SOCK_STREAM, 0);
|
|
||||||
struct sockaddr_in sin;
|
|
||||||
|
|
||||||
if (newSocket == ENET_SOCKET_NULL)
|
|
||||||
return ENET_SOCKET_NULL;
|
|
||||||
|
|
||||||
memset (& sin, 0, sizeof (struct sockaddr_in));
|
|
||||||
|
|
||||||
sin.sin_family = AF_INET;
|
|
||||||
|
|
||||||
if (address != NULL)
|
|
||||||
{
|
|
||||||
sin.sin_port = ENET_HOST_TO_NET_16 (address -> port);
|
|
||||||
sin.sin_addr.s_addr = address -> host;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
sin.sin_port = 0;
|
|
||||||
sin.sin_addr.s_addr = INADDR_ANY;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (bind (newSocket,
|
|
||||||
(struct sockaddr *) & sin,
|
|
||||||
sizeof (struct sockaddr_in)) == SOCKET_ERROR ||
|
|
||||||
(type == ENET_SOCKET_TYPE_STREAM &&
|
|
||||||
address != NULL &&
|
|
||||||
address -> port != ENET_PORT_ANY &&
|
|
||||||
listen (newSocket, SOMAXCONN) == SOCKET_ERROR))
|
|
||||||
{
|
|
||||||
closesocket (newSocket);
|
|
||||||
|
|
||||||
return ENET_SOCKET_NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
return newSocket;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_socket_set_option (ENetSocket socket, ENetSocketOption option, int value)
|
|
||||||
{
|
|
||||||
int result = SOCKET_ERROR;
|
|
||||||
switch (option)
|
|
||||||
{
|
|
||||||
case ENET_SOCKOPT_NONBLOCK:
|
|
||||||
{
|
|
||||||
u_long nonBlocking = (u_long) value;
|
|
||||||
result = ioctlsocket (socket, FIONBIO, & nonBlocking);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
case ENET_SOCKOPT_BROADCAST:
|
|
||||||
result = setsockopt (socket, SOL_SOCKET, SO_BROADCAST, (char *) & value, sizeof (int));
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ENET_SOCKOPT_RCVBUF:
|
|
||||||
result = setsockopt (socket, SOL_SOCKET, SO_RCVBUF, (char *) & value, sizeof (int));
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ENET_SOCKOPT_SNDBUF:
|
|
||||||
result = setsockopt (socket, SOL_SOCKET, SO_SNDBUF, (char *) & value, sizeof (int));
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return result == SOCKET_ERROR ? -1 : 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_socket_connect (ENetSocket socket, const ENetAddress * address)
|
|
||||||
{
|
|
||||||
struct sockaddr_in sin;
|
|
||||||
|
|
||||||
memset (& sin, 0, sizeof (struct sockaddr_in));
|
|
||||||
|
|
||||||
sin.sin_family = AF_INET;
|
|
||||||
sin.sin_port = ENET_HOST_TO_NET_16 (address -> port);
|
|
||||||
sin.sin_addr.s_addr = address -> host;
|
|
||||||
|
|
||||||
return connect (socket, (struct sockaddr *) & sin, sizeof (struct sockaddr_in));
|
|
||||||
}
|
|
||||||
|
|
||||||
ENetSocket
|
|
||||||
enet_socket_accept (ENetSocket socket, ENetAddress * address)
|
|
||||||
{
|
|
||||||
SOCKET result;
|
|
||||||
struct sockaddr_in sin;
|
|
||||||
int sinLength = sizeof (struct sockaddr_in);
|
|
||||||
|
|
||||||
result = accept (socket,
|
|
||||||
address != NULL ? (struct sockaddr *) & sin : NULL,
|
|
||||||
address != NULL ? & sinLength : NULL);
|
|
||||||
|
|
||||||
if (result == INVALID_SOCKET)
|
|
||||||
return ENET_SOCKET_NULL;
|
|
||||||
|
|
||||||
if (address != NULL)
|
|
||||||
{
|
|
||||||
address -> host = (enet_uint32) sin.sin_addr.s_addr;
|
|
||||||
address -> port = ENET_NET_TO_HOST_16 (sin.sin_port);
|
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
enet_socket_destroy (ENetSocket socket)
|
|
||||||
{
|
|
||||||
closesocket (socket);
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_socket_send (ENetSocket socket,
|
|
||||||
const ENetAddress * address,
|
|
||||||
const ENetBuffer * buffers,
|
|
||||||
size_t bufferCount)
|
|
||||||
{
|
|
||||||
struct sockaddr_in sin;
|
|
||||||
DWORD sentLength;
|
|
||||||
|
|
||||||
if (address != NULL)
|
|
||||||
{
|
|
||||||
sin.sin_family = AF_INET;
|
|
||||||
sin.sin_port = ENET_HOST_TO_NET_16 (address -> port);
|
|
||||||
sin.sin_addr.s_addr = address -> host;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (WSASendTo (socket,
|
|
||||||
(LPWSABUF) buffers,
|
|
||||||
(DWORD) bufferCount,
|
|
||||||
& sentLength,
|
|
||||||
0,
|
|
||||||
address != NULL ? (struct sockaddr *) & sin : 0,
|
|
||||||
address != NULL ? sizeof (struct sockaddr_in) : 0,
|
|
||||||
NULL,
|
|
||||||
NULL) == SOCKET_ERROR)
|
|
||||||
{
|
|
||||||
if (WSAGetLastError () == WSAEWOULDBLOCK)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return (int) sentLength;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_socket_receive (ENetSocket socket,
|
|
||||||
ENetAddress * address,
|
|
||||||
ENetBuffer * buffers,
|
|
||||||
size_t bufferCount)
|
|
||||||
{
|
|
||||||
INT sinLength = sizeof (struct sockaddr_in);
|
|
||||||
DWORD flags = 0,
|
|
||||||
recvLength;
|
|
||||||
struct sockaddr_in sin;
|
|
||||||
|
|
||||||
if (WSARecvFrom (socket,
|
|
||||||
(LPWSABUF) buffers,
|
|
||||||
(DWORD) bufferCount,
|
|
||||||
& recvLength,
|
|
||||||
& flags,
|
|
||||||
address != NULL ? (struct sockaddr *) & sin : NULL,
|
|
||||||
address != NULL ? & sinLength : NULL,
|
|
||||||
NULL,
|
|
||||||
NULL) == SOCKET_ERROR)
|
|
||||||
{
|
|
||||||
switch (WSAGetLastError ())
|
|
||||||
{
|
|
||||||
case WSAEWOULDBLOCK:
|
|
||||||
case WSAECONNRESET:
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (flags & MSG_PARTIAL)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
if (address != NULL)
|
|
||||||
{
|
|
||||||
address -> host = (enet_uint32) sin.sin_addr.s_addr;
|
|
||||||
address -> port = ENET_NET_TO_HOST_16 (sin.sin_port);
|
|
||||||
}
|
|
||||||
|
|
||||||
return (int) recvLength;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
enet_socket_wait (ENetSocket socket, enet_uint32 * condition, enet_uint32 timeout)
|
|
||||||
{
|
|
||||||
fd_set readSet, writeSet;
|
|
||||||
struct timeval timeVal;
|
|
||||||
int selectCount;
|
|
||||||
|
|
||||||
timeVal.tv_sec = timeout / 1000;
|
|
||||||
timeVal.tv_usec = (timeout % 1000) * 1000;
|
|
||||||
|
|
||||||
FD_ZERO (& readSet);
|
|
||||||
FD_ZERO (& writeSet);
|
|
||||||
|
|
||||||
if (* condition & ENET_SOCKET_WAIT_SEND)
|
|
||||||
FD_SET (socket, & writeSet);
|
|
||||||
|
|
||||||
if (* condition & ENET_SOCKET_WAIT_RECEIVE)
|
|
||||||
FD_SET (socket, & readSet);
|
|
||||||
|
|
||||||
selectCount = select (socket + 1, & readSet, & writeSet, NULL, & timeVal);
|
|
||||||
|
|
||||||
if (selectCount < 0)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
* condition = ENET_SOCKET_WAIT_NONE;
|
|
||||||
|
|
||||||
if (selectCount == 0)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
if (FD_ISSET (socket, & writeSet))
|
|
||||||
* condition |= ENET_SOCKET_WAIT_SEND;
|
|
||||||
|
|
||||||
if (FD_ISSET (socket, & readSet))
|
|
||||||
* condition |= ENET_SOCKET_WAIT_RECEIVE;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
|
|
||||||
#include "mmulti_unstable.h"
|
#include "mmulti_unstable.h"
|
||||||
#include <enet/enet.h>
|
// #include <enet/enet.h>
|
||||||
#include "compat.h"
|
#include "compat.h"
|
||||||
#include "baselayer.h"
|
#include "baselayer.h"
|
||||||
|
|
||||||
|
@ -533,7 +533,8 @@ void flushpackets()
|
||||||
{
|
{
|
||||||
gcom->command = COMMIT_CMD_GET;
|
gcom->command = COMMIT_CMD_GET;
|
||||||
callcommit();
|
callcommit();
|
||||||
} while (gcom->other >= 0);
|
}
|
||||||
|
while (gcom->other >= 0);
|
||||||
|
|
||||||
for (i=connecthead;i>=0;i=connectpoint2[i])
|
for (i=connecthead;i>=0;i=connectpoint2[i])
|
||||||
{
|
{
|
||||||
|
@ -594,7 +595,6 @@ void genericmultifunction(int other, char *bufptr, int messleng, int command)
|
||||||
|
|
||||||
#define SOCKET_SHUTDOWN_BOTH 2
|
#define SOCKET_SHUTDOWN_BOTH 2
|
||||||
|
|
||||||
#include <signal.h>
|
|
||||||
#include "cache1d.h" /* kopen4load for cfg file. */
|
#include "cache1d.h" /* kopen4load for cfg file. */
|
||||||
|
|
||||||
#define IPSEG1(ip) ((((unsigned int) ip) & 0xFF000000) >> 24)
|
#define IPSEG1(ip) ((((unsigned int) ip) & 0xFF000000) >> 24)
|
||||||
|
@ -603,24 +603,20 @@ void genericmultifunction(int other, char *bufptr, int messleng, int command)
|
||||||
#define IPSEG4(ip) ((((unsigned int) ip) & 0x000000FF) )
|
#define IPSEG4(ip) ((((unsigned int) ip) & 0x000000FF) )
|
||||||
|
|
||||||
#define MAX_PLAYERS 16
|
#define MAX_PLAYERS 16
|
||||||
#define BUILD_DEFAULT_UDP_PORT 1635 /* eh...why not? */
|
#define BUILD_DEFAULT_UDP_PORT 23513 /* eh...why not? */
|
||||||
#define CLIENT_POLL_DELAY 3000 /* ms between pings at peer-to-peer startup. */
|
#define CLIENT_POLL_DELAY 5000 /* ms between pings at peer-to-peer startup. */
|
||||||
#define HEADER_PEER_GREETING 245
|
#define HEADER_PEER_GREETING 245
|
||||||
|
|
||||||
static sockettype udpsocket = -1;
|
static sockettype udpsocket = -1;
|
||||||
static short udpport = BUILD_DEFAULT_UDP_PORT;
|
static short udpport = BUILD_DEFAULT_UDP_PORT;
|
||||||
|
|
||||||
static struct {
|
static struct
|
||||||
|
{
|
||||||
int host;
|
int host;
|
||||||
short port;
|
short port;
|
||||||
} allowed_addresses[MAX_PLAYERS]; /* only respond to these IPs. */
|
} allowed_addresses[MAX_PLAYERS]; /* only respond to these IPs. */
|
||||||
|
|
||||||
volatile int ctrlc_pressed = 0;
|
volatile int ctrlc_pressed = 0;
|
||||||
static void siginthandler(int sigint)
|
|
||||||
{
|
|
||||||
UNREFERENCED_PARAMETER(sigint);
|
|
||||||
ctrlc_pressed = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
#if PLATFORM_WIN32
|
#if PLATFORM_WIN32
|
||||||
/*
|
/*
|
||||||
|
@ -955,8 +951,12 @@ static int open_udp_socket(int ip, int port)
|
||||||
{
|
{
|
||||||
struct sockaddr_in addr;
|
struct sockaddr_in addr;
|
||||||
|
|
||||||
initprintf("Setting up UDP interface %s:%d...\n", static_ipstring(ip), port);
|
// initprintf("Setting up UDP interface %s:%d...\n", static_ipstring(ip), port);
|
||||||
initprintf("Stun is currently %s\n", (natfree) ? "Enabled":"Disabled");
|
if (natfree)
|
||||||
|
{
|
||||||
|
//initprintf("Stun is currently %s\n", (natfree) ? "Enabled":"Disabled");
|
||||||
|
initprintf("mmulti_unstable: Stun enabled\n");
|
||||||
|
}
|
||||||
|
|
||||||
udpsocket = socket(PF_INET, SOCK_DGRAM, IPPROTO_UDP);
|
udpsocket = socket(PF_INET, SOCK_DGRAM, IPPROTO_UDP);
|
||||||
if ((signed)udpsocket == -1)
|
if ((signed)udpsocket == -1)
|
||||||
|
@ -1044,13 +1044,11 @@ static int connect_to_everyone(gcomtype *gcom, int myip, int bcast)
|
||||||
int max;
|
int max;
|
||||||
int remaining;
|
int remaining;
|
||||||
|
|
||||||
initprintf("peer-to-peer init. CTRL-C to abort...\n");
|
|
||||||
|
|
||||||
if (bcast)
|
if (bcast)
|
||||||
{
|
{
|
||||||
if (gcom->numplayers > 1)
|
if (gcom->numplayers > 1)
|
||||||
{
|
{
|
||||||
initprintf("ERROR: Can't do both 'broadcast' and 'allow'.\n");
|
initprintf("mmulti_unstable: Error: can't do both 'broadcast' and 'allow'.\n");
|
||||||
return(0);
|
return(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1065,7 +1063,7 @@ static int connect_to_everyone(gcomtype *gcom, int myip, int bcast)
|
||||||
while (my_id == 0) /* player number is based on id, low to high. */
|
while (my_id == 0) /* player number is based on id, low to high. */
|
||||||
my_id = (unsigned short) rand();
|
my_id = (unsigned short) rand();
|
||||||
|
|
||||||
initprintf("(This client's ID for this round is 0x%X.)\n\n", my_id);
|
initprintf("mmulti_unstable: Using 0x%X as client ID\n", my_id);
|
||||||
|
|
||||||
resendat = getticks();
|
resendat = getticks();
|
||||||
remaining = max = gcom->numplayers - 1;
|
remaining = max = gcom->numplayers - 1;
|
||||||
|
@ -1073,7 +1071,7 @@ static int connect_to_everyone(gcomtype *gcom, int myip, int bcast)
|
||||||
initprintf("Waiting for %d player%s...\n", remaining, remaining==1 ? "":"s");
|
initprintf("Waiting for %d player%s...\n", remaining, remaining==1 ? "":"s");
|
||||||
if (remaining == 0)
|
if (remaining == 0)
|
||||||
{
|
{
|
||||||
initprintf("Hmmm...don't have time to play with myself.\n");
|
initprintf("Hmmm... don't have time to play with myself!\n");
|
||||||
return(0);
|
return(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1104,10 +1102,8 @@ static int connect_to_everyone(gcomtype *gcom, int myip, int bcast)
|
||||||
|
|
||||||
if (!heard_from[i])
|
if (!heard_from[i])
|
||||||
{
|
{
|
||||||
initprintf("%sending greeting to %s:%d...\n",
|
initprintf("%s %s:%d...\n",first_send?"Connecting to":"Retrying",
|
||||||
first_send ? "S" : "Res",
|
static_ipstring(allowed_addresses[i].host),allowed_addresses[i].port);
|
||||||
static_ipstring(allowed_addresses[i].host),
|
|
||||||
allowed_addresses[i].port);
|
|
||||||
|
|
||||||
send_peer_greeting(allowed_addresses[i].host,
|
send_peer_greeting(allowed_addresses[i].host,
|
||||||
allowed_addresses[i].port,
|
allowed_addresses[i].port,
|
||||||
|
@ -1167,9 +1163,10 @@ static int connect_to_everyone(gcomtype *gcom, int myip, int bcast)
|
||||||
{
|
{
|
||||||
if (allowed_addresses[i].port != port)
|
if (allowed_addresses[i].port != port)
|
||||||
{
|
{
|
||||||
initprintf("Different player Port Number detected. %s:%i\n",ipstr,
|
initprintf("mmulti_unstable: Port number for player %d changed from %d to %d.\n",i,allowed_addresses[i].port,port);
|
||||||
|
/* initprintf("Different player Port Number detected. %s:%i\n",ipstr,
|
||||||
allowed_addresses[i].port);
|
allowed_addresses[i].port);
|
||||||
initprintf("Changed to %s:%i, player may be behind a firewall.\n", ipstr, port); //addfaz NAT addition
|
initprintf("Changed to %s:%i, player may be behind a firewall.\n", ipstr, port); //addfaz NAT addition */
|
||||||
allowed_addresses[i].port = port;
|
allowed_addresses[i].port = port;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1189,13 +1186,13 @@ static int connect_to_everyone(gcomtype *gcom, int myip, int bcast)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (i == max)
|
if (i == max)
|
||||||
initprintf("%s:%d is not an allowed player.\n", ipstr, port);
|
initprintf("mmulti_unstable: Disallowed player %s:%d ?!\n", ipstr, port);
|
||||||
|
|
||||||
else if (rc != sizeof(packet))
|
else if (rc != sizeof(packet))
|
||||||
initprintf("Missized packet/packet fragment from %s:%i\n", ipstr, port);
|
initprintf("mmulti_unstable: Missized packet or fragment from %s:%i ?!\n", ipstr, port);
|
||||||
|
|
||||||
else if (packet.header != HEADER_PEER_GREETING)
|
else if (packet.header != HEADER_PEER_GREETING)
|
||||||
initprintf("Unexpected packet type from %s:%i\n", ipstr, port);
|
initprintf("mmulti_unstable: Unexpected packet type from %s:%i ?!\n", ipstr, port);
|
||||||
|
|
||||||
else if (heard_from[i] == 0)
|
else if (heard_from[i] == 0)
|
||||||
{
|
{
|
||||||
|
@ -1205,7 +1202,7 @@ static int connect_to_everyone(gcomtype *gcom, int myip, int bcast)
|
||||||
allowed_addresses[i].port = port;
|
allowed_addresses[i].port = port;
|
||||||
remaining--;
|
remaining--;
|
||||||
|
|
||||||
initprintf("Heard from %s:%i (id 0x%X). %d player%s to go.\n",
|
initprintf("Connected to %s:%i (id 0x%X). %d player%s to go.\n",
|
||||||
ipstr, port ,(int) packet.id,
|
ipstr, port ,(int) packet.id,
|
||||||
remaining, remaining == 1 ? "" : "s");
|
remaining, remaining == 1 ? "" : "s");
|
||||||
|
|
||||||
|
@ -1246,8 +1243,8 @@ static int connect_to_everyone(gcomtype *gcom, int myip, int bcast)
|
||||||
{
|
{
|
||||||
if (heard_from[i] == heard_from[i+1]) /* blah. */
|
if (heard_from[i] == heard_from[i+1]) /* blah. */
|
||||||
{
|
{
|
||||||
initprintf("ERROR: Two players have the same random ID!\n");
|
initprintf("mmulti_unstable: ERROR: Two players have the same random ID!\n");
|
||||||
initprintf("ERROR: Please restart the game to generate new IDs.\n");
|
initprintf("mmulti_unstable: ERROR: Please restart the game to generate new IDs.\n");
|
||||||
return(0);
|
return(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1271,7 +1268,8 @@ static int connect_to_everyone(gcomtype *gcom, int myip, int bcast)
|
||||||
remaining = 1; /* yay for bubble sorting! */
|
remaining = 1; /* yay for bubble sorting! */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} while (remaining);
|
}
|
||||||
|
while (remaining);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Now we're sorted. But, the local player is referred to by both his
|
* Now we're sorted. But, the local player is referred to by both his
|
||||||
|
@ -1295,11 +1293,11 @@ static int connect_to_everyone(gcomtype *gcom, int myip, int bcast)
|
||||||
gcom->myconnectindex = i;
|
gcom->myconnectindex = i;
|
||||||
}
|
}
|
||||||
|
|
||||||
initprintf("%s:%i is player #%i.\n", static_ipstring(ip),allowed_addresses[i].port,i);
|
initprintf("mmulti_unstable: player #%i at %s:%i\n", i,static_ipstring(ip),allowed_addresses[i].port);
|
||||||
}
|
}
|
||||||
// assert(gcom->myconnectindex);
|
// assert(gcom->myconnectindex);
|
||||||
|
|
||||||
initprintf("Everyone ready! We are player #%i\n", gcom->myconnectindex);
|
initprintf("mmulti_unstable: We are player #%i\n", gcom->myconnectindex);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Ok, we should have specific IPs and ports for all players, and
|
* Ok, we should have specific IPs and ports for all players, and
|
||||||
|
@ -1364,7 +1362,7 @@ static int initialize_sockets(void)
|
||||||
#if PLATFORM_WIN32
|
#if PLATFORM_WIN32
|
||||||
int rc;
|
int rc;
|
||||||
WSADATA data;
|
WSADATA data;
|
||||||
initprintf("initializing WinSock...\n");
|
// initprintf("initializing WinSock...\n");
|
||||||
rc = WSAStartup(0x0101, &data);
|
rc = WSAStartup(0x0101, &data);
|
||||||
if (rc != 0)
|
if (rc != 0)
|
||||||
{
|
{
|
||||||
|
@ -1373,14 +1371,14 @@ static int initialize_sockets(void)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
initprintf("WinSock initialized.\n");
|
/* initprintf("WinSock initialized.\n");
|
||||||
initprintf(" - Caller uses version %d.%d, highest supported is %d.%d.\n",
|
initprintf(" - Caller uses version %d.%d, highest supported is %d.%d.\n",
|
||||||
data.wVersion >> 8, data.wVersion & 0xFF,
|
data.wVersion >> 8, data.wVersion & 0xFF,
|
||||||
data.wHighVersion >> 8, data.wHighVersion & 0xFF);
|
data.wHighVersion >> 8, data.wHighVersion & 0xFF);
|
||||||
initprintf(" - Implementation description: [%s].\n", data.szDescription);
|
initprintf(" - Implementation description: [%s].\n", data.szDescription);
|
||||||
initprintf(" - System status: [%s].\n", data.szSystemStatus);
|
initprintf(" - System status: [%s].\n", data.szSystemStatus);
|
||||||
initprintf(" - Max sockets: %d.\n", data.iMaxSockets);
|
initprintf(" - Max sockets: %d.\n", data.iMaxSockets);
|
||||||
initprintf(" - Max UDP datagram size: %d.\n", data.iMaxUdpDg);
|
initprintf(" - Max UDP datagram size: %d.\n", data.iMaxUdpDg); */
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -1418,7 +1416,7 @@ static int parse_udp_config(const char *cfgfile, gcomtype *gcom)
|
||||||
{
|
{
|
||||||
bogus = 0;
|
bogus = 0;
|
||||||
}
|
}
|
||||||
initprintf("Interface %s:%d chosen.\n",
|
initprintf("mmulti_unstable: Using interface %s:%d\n",
|
||||||
static_ipstring(ip), (int) udpport);
|
static_ipstring(ip), (int) udpport);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1503,7 +1501,7 @@ gcomtype *init_network_transport(char **ARGV, int argpos)
|
||||||
{
|
{
|
||||||
gcomtype *retval;
|
gcomtype *retval;
|
||||||
|
|
||||||
initprintf("\n\nUDP NETWORK TRANSPORT INITIALIZING...\n");
|
// initprintf("\n\nUDP NETWORK TRANSPORT INITIALIZING...\n");
|
||||||
|
|
||||||
ctrlc_pressed = 0;
|
ctrlc_pressed = 0;
|
||||||
|
|
||||||
|
@ -1517,7 +1515,6 @@ gcomtype *init_network_transport(char **ARGV, int argpos)
|
||||||
{
|
{
|
||||||
int rc;
|
int rc;
|
||||||
char *cfgfile = ARGV[argpos];
|
char *cfgfile = ARGV[argpos];
|
||||||
void (*oldsigint)(int);
|
|
||||||
|
|
||||||
memset(retval, '\0', sizeof(gcomtype));
|
memset(retval, '\0', sizeof(gcomtype));
|
||||||
memset(allowed_addresses, '\0', sizeof(allowed_addresses));
|
memset(allowed_addresses, '\0', sizeof(allowed_addresses));
|
||||||
|
@ -1525,10 +1522,8 @@ gcomtype *init_network_transport(char **ARGV, int argpos)
|
||||||
udpport = BUILD_DEFAULT_UDP_PORT;
|
udpport = BUILD_DEFAULT_UDP_PORT;
|
||||||
udpmode = udpmode_peer;
|
udpmode = udpmode_peer;
|
||||||
|
|
||||||
oldsigint = signal(SIGINT, siginthandler);
|
initprintf("mmulti_unstable: Using '%s' as configuration file\n", cfgfile);
|
||||||
initprintf("Parsing udp config %s\n", cfgfile);
|
|
||||||
rc = parse_udp_config(cfgfile, retval);
|
rc = parse_udp_config(cfgfile, retval);
|
||||||
signal(SIGINT, oldsigint);
|
|
||||||
|
|
||||||
if (!rc)
|
if (!rc)
|
||||||
{
|
{
|
||||||
|
@ -1545,7 +1540,7 @@ gcomtype *init_network_transport(char **ARGV, int argpos)
|
||||||
|
|
||||||
void deinit_network_transport(gcomtype *gcom)
|
void deinit_network_transport(gcomtype *gcom)
|
||||||
{
|
{
|
||||||
initprintf("\n\nUDP NETWORK TRANSPORT DEINITIALIZING...\n");
|
// initprintf("\n\nUDP NETWORK TRANSPORT DEINITIALIZING...\n");
|
||||||
|
|
||||||
if (gcom != NULL)
|
if (gcom != NULL)
|
||||||
{
|
{
|
||||||
|
|
|
@ -3326,6 +3326,9 @@ static int SetupOpenGL(int width, int height, int bitspp)
|
||||||
int err = 0;
|
int err = 0;
|
||||||
|
|
||||||
glinfo.vendor = (char *)bglGetString(GL_VENDOR);
|
glinfo.vendor = (char *)bglGetString(GL_VENDOR);
|
||||||
|
glinfo.renderer = (char *)bglGetString(GL_RENDERER);
|
||||||
|
glinfo.version = (char *)bglGetString(GL_VERSION);
|
||||||
|
glinfo.extensions = (char *)bglGetString(GL_EXTENSIONS);
|
||||||
|
|
||||||
// GL driver blacklist
|
// GL driver blacklist
|
||||||
if (!forcegl)
|
if (!forcegl)
|
||||||
|
@ -3333,7 +3336,11 @@ static int SetupOpenGL(int width, int height, int bitspp)
|
||||||
if (!Bstrcmp(glinfo.vendor,"Microsoft Corporation")) err = 1;
|
if (!Bstrcmp(glinfo.vendor,"Microsoft Corporation")) err = 1;
|
||||||
else if (!Bstrcmp(glinfo.vendor,"SiS")) err = 1;
|
else if (!Bstrcmp(glinfo.vendor,"SiS")) err = 1;
|
||||||
else if (!Bstrcmp(glinfo.vendor,"3Dfx Interactive Inc.")) err = 1;
|
else if (!Bstrcmp(glinfo.vendor,"3Dfx Interactive Inc.")) err = 1;
|
||||||
else if (!Bstrcmp(glinfo.vendor,"Intel")) err = 1;
|
else if (!Bstrcmp(glinfo.vendor,"Intel"))
|
||||||
|
{
|
||||||
|
if (Bstrcmp(glinfo.vendor,"Intel 865G"))
|
||||||
|
err = 1;
|
||||||
|
}
|
||||||
|
|
||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
|
@ -3347,10 +3354,6 @@ static int SetupOpenGL(int width, int height, int bitspp)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
glinfo.renderer = (char *)bglGetString(GL_RENDERER);
|
|
||||||
glinfo.version = (char *)bglGetString(GL_VERSION);
|
|
||||||
glinfo.extensions = (char *)bglGetString(GL_EXTENSIONS);
|
|
||||||
|
|
||||||
glinfo.maxanisotropy = 1.0;
|
glinfo.maxanisotropy = 1.0;
|
||||||
glinfo.bgra = 0;
|
glinfo.bgra = 0;
|
||||||
glinfo.texcompr = 0;
|
glinfo.texcompr = 0;
|
||||||
|
|
|
@ -642,7 +642,7 @@ int32 CONFIG_ReadSetup(void)
|
||||||
|
|
||||||
SCRIPT_GetString(ud.config.scripthandle, "Comm Setup","RTSName",&ud.rtsname[0]);
|
SCRIPT_GetString(ud.config.scripthandle, "Comm Setup","RTSName",&ud.rtsname[0]);
|
||||||
|
|
||||||
#ifndef ENET_NETWORKING
|
#ifndef RANCID_NETWORKING
|
||||||
// The packetrate mechanism is specific to the eduke32 networking code
|
// The packetrate mechanism is specific to the eduke32 networking code
|
||||||
SCRIPT_GetNumber(ud.config.scripthandle, "Comm Setup", "Rate",(int32 *)&packetrate);
|
SCRIPT_GetNumber(ud.config.scripthandle, "Comm Setup", "Rate",(int32 *)&packetrate);
|
||||||
packetrate = min(max(packetrate,50),1000);
|
packetrate = min(max(packetrate,50),1000);
|
||||||
|
@ -1140,7 +1140,7 @@ void CONFIG_WriteSetup(void)
|
||||||
SCRIPT_PutString(ud.config.scripthandle, "Comm Setup","PlayerName",&myname[0]);
|
SCRIPT_PutString(ud.config.scripthandle, "Comm Setup","PlayerName",&myname[0]);
|
||||||
SCRIPT_PutString(ud.config.scripthandle, "Comm Setup","RTSName",&ud.rtsname[0]);
|
SCRIPT_PutString(ud.config.scripthandle, "Comm Setup","RTSName",&ud.rtsname[0]);
|
||||||
|
|
||||||
#ifndef ENET_NETWORKING
|
#ifndef RANCID_NETWORKING
|
||||||
// The packetrate mechanism is specific to the eduke32 networking code
|
// The packetrate mechanism is specific to the eduke32 networking code
|
||||||
SCRIPT_PutNumber(ud.config.scripthandle, "Comm Setup", "Rate", packetrate, false, false);
|
SCRIPT_PutNumber(ud.config.scripthandle, "Comm Setup", "Rate", packetrate, false, false);
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -45,8 +45,8 @@ extern "C" {
|
||||||
#include "cache1d.h"
|
#include "cache1d.h"
|
||||||
#include "pragmas.h"
|
#include "pragmas.h"
|
||||||
|
|
||||||
#ifdef ENET_NETWORKING
|
#ifdef RANCID_NETWORKING
|
||||||
#include "enet_mmulti.h"
|
#include "mmulti_unstable.h"
|
||||||
#else
|
#else
|
||||||
#include "mmulti.h"
|
#include "mmulti.h"
|
||||||
#endif
|
#endif
|
||||||
|
@ -647,7 +647,7 @@ extern char num_volumes;
|
||||||
|
|
||||||
extern int lastsavedpos;
|
extern int lastsavedpos;
|
||||||
extern int restorepalette;
|
extern int restorepalette;
|
||||||
#ifndef ENET_NETWORKING
|
#ifndef RANCID_NETWORKING
|
||||||
extern int packetrate;
|
extern int packetrate;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -74,7 +74,7 @@ static int g_NoSound = 0;
|
||||||
static int g_NoMusic = 0;
|
static int g_NoMusic = 0;
|
||||||
static char *CommandMap = NULL;
|
static char *CommandMap = NULL;
|
||||||
static char *CommandName = NULL;
|
static char *CommandName = NULL;
|
||||||
#ifndef ENET_NETWORKING
|
#ifndef RANCID_NETWORKING
|
||||||
static char *CommandNet = NULL;
|
static char *CommandNet = NULL;
|
||||||
#endif
|
#endif
|
||||||
static int g_KeepAddr = 0;
|
static int g_KeepAddr = 0;
|
||||||
|
@ -8921,7 +8921,7 @@ static void comlinehelp(void)
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef ENET_NETWORKING
|
#ifndef RANCID_NETWORKING
|
||||||
static signed int rancid_players = 0;
|
static signed int rancid_players = 0;
|
||||||
static char rancid_ip_strings[MAXPLAYERS][32], rancid_local_port_string[8];
|
static char rancid_ip_strings[MAXPLAYERS][32], rancid_local_port_string[8];
|
||||||
|
|
||||||
|
@ -9609,7 +9609,7 @@ static void checkcommandline(int argc, const char **argv)
|
||||||
i++;
|
i++;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
#ifndef ENET_NETWORKING
|
#ifndef RANCID_NETWORKING
|
||||||
if (!Bstrcasecmp(c+1,"rmnet"))
|
if (!Bstrcasecmp(c+1,"rmnet"))
|
||||||
{
|
{
|
||||||
if (argc > i+1)
|
if (argc > i+1)
|
||||||
|
@ -9624,7 +9624,7 @@ static void checkcommandline(int argc, const char **argv)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (!Bstrcasecmp(c+1,"net")
|
if (!Bstrcasecmp(c+1,"net")
|
||||||
#ifdef ENET_NETWORKING
|
#ifdef RANCID_NETWORKING
|
||||||
|| !Bstrcasecmp(c+1,"rmnet")
|
|| !Bstrcasecmp(c+1,"rmnet")
|
||||||
#endif
|
#endif
|
||||||
)
|
)
|
||||||
|
@ -10524,7 +10524,7 @@ static void Startup(void)
|
||||||
for (i=0;i<MAXPLAYERS;i++)
|
for (i=0;i<MAXPLAYERS;i++)
|
||||||
g_player[i].playerreadyflag = 0;
|
g_player[i].playerreadyflag = 0;
|
||||||
|
|
||||||
#ifndef ENET_NETWORKING
|
#ifndef RANCID_NETWORKING
|
||||||
// enet regression
|
// enet regression
|
||||||
if (CommandNet)
|
if (CommandNet)
|
||||||
{
|
{
|
||||||
|
@ -10538,7 +10538,7 @@ static void Startup(void)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef ENET_NETWORKING
|
#ifdef RANCID_NETWORKING
|
||||||
// TODO: split this up in the same fine-grained manner as eduke32 network backend, to
|
// TODO: split this up in the same fine-grained manner as eduke32 network backend, to
|
||||||
// allow for event handling
|
// allow for event handling
|
||||||
initmultiplayers(netparamcount,netparam);
|
initmultiplayers(netparamcount,netparam);
|
||||||
|
|
|
@ -856,7 +856,7 @@ void menus(void)
|
||||||
updateplayer();
|
updateplayer();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#ifndef ENET_NETWORKING
|
#ifndef RANCID_NETWORKING
|
||||||
case 7:
|
case 7:
|
||||||
if (x == io)
|
if (x == io)
|
||||||
packetrate = min(max(((packetrate/50)*50)+50,50),1000);
|
packetrate = min(max(((packetrate/50)*50)+50,50),1000);
|
||||||
|
@ -962,7 +962,7 @@ void menus(void)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 7:
|
case 7:
|
||||||
#ifdef ENET_NETWORKING
|
#ifdef RANCID_NETWORKING
|
||||||
// enet network backend doesn't have a packet rate mechanism
|
// enet network backend doesn't have a packet rate mechanism
|
||||||
mgametext(d+70,yy,"n/a", MENUHIGHLIGHT(io),2+8+16);
|
mgametext(d+70,yy,"n/a", MENUHIGHLIGHT(io),2+8+16);
|
||||||
#else
|
#else
|
||||||
|
|
|
@ -384,7 +384,7 @@ static int osdcmd_fileinfo(const osdfuncparm_t *parm)
|
||||||
|
|
||||||
static int osdcmd_rate(const osdfuncparm_t *parm)
|
static int osdcmd_rate(const osdfuncparm_t *parm)
|
||||||
{
|
{
|
||||||
#ifndef ENET_NETWORKING
|
#ifndef RANCID_NETWORKING
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (parm->numparms == 0)
|
if (parm->numparms == 0)
|
||||||
|
|
Loading…
Reference in a new issue