Added all of enet lib, changed Cmake files accordingly
This commit is contained in:
parent
a629555e6b
commit
619a3a5171
|
@ -534,8 +534,13 @@ include_directories(Source/Core)
|
||||||
#
|
#
|
||||||
add_subdirectory(Externals/Bochs_disasm)
|
add_subdirectory(Externals/Bochs_disasm)
|
||||||
include_directories(Externals/Bochs_disasm)
|
include_directories(Externals/Bochs_disasm)
|
||||||
include_directories(Externals)
|
|
||||||
add_subdirectory(Externals/enet)
|
if(NOT ENET_FOUND)
|
||||||
|
message("Using static enet from Externals")
|
||||||
|
include_directories(Externals)
|
||||||
|
add_subdirectory(Externals/enet)
|
||||||
|
endif()
|
||||||
|
LIST(APPEND LIBS enet)
|
||||||
|
|
||||||
if(NOT XXHASH_FOUND)
|
if(NOT XXHASH_FOUND)
|
||||||
message("Using static xxhash from Externals")
|
message("Using static xxhash from Externals")
|
||||||
|
|
|
@ -1,15 +1,57 @@
|
||||||
set(SRCS
|
cmake_minimum_required(VERSION 2.6)
|
||||||
callbacks.c
|
|
||||||
compress.c
|
project(enet)
|
||||||
host.c
|
|
||||||
list.c
|
# The "configure" step.
|
||||||
packet.c
|
include(CheckFunctionExists)
|
||||||
peer.c
|
include(CheckStructHasMember)
|
||||||
protocol.c)
|
include(CheckTypeSize)
|
||||||
if(${CMAKE_SYSTEM_NAME} MATCHES "Windows")
|
check_function_exists("fcntl" HAS_FCNTL)
|
||||||
set(SRCS ${SRCS} win32.c)
|
check_function_exists("poll" HAS_POLL)
|
||||||
else()
|
check_function_exists("gethostbyname_r" HAS_GETHOSTBYNAME_R)
|
||||||
set(SRCS ${SRCS} unix.c)
|
check_function_exists("gethostbyaddr_r" HAS_GETHOSTBYADDR_R)
|
||||||
|
check_function_exists("inet_pton" HAS_INET_PTON)
|
||||||
|
check_function_exists("inet_ntop" HAS_INET_NTOP)
|
||||||
|
check_struct_has_member("struct msghdr" "msg_flags" "sys/types.h;sys/socket.h" HAS_MSGHDR_FLAGS)
|
||||||
|
set(CMAKE_EXTRA_INCLUDE_FILES "sys/types.h" "sys/socket.h")
|
||||||
|
check_type_size("socklen_t" HAS_SOCKLEN_T BUILTIN_TYPES_ONLY)
|
||||||
|
unset(CMAKE_EXTRA_INCLUDE_FILES)
|
||||||
|
|
||||||
|
if(HAS_FCNTL)
|
||||||
|
add_definitions(-DHAS_FCNTL=1)
|
||||||
endif()
|
endif()
|
||||||
add_definitions(-Wno-parentheses-equality -DHAS_SOCKLEN_T)
|
if(HAS_POLL)
|
||||||
add_library(enet STATIC ${SRCS})
|
add_definitions(-DHAS_POLL=1)
|
||||||
|
endif()
|
||||||
|
if(HAS_GETHOSTBYNAME_R)
|
||||||
|
add_definitions(-DHAS_GETHOSTBYNAME_R=1)
|
||||||
|
endif()
|
||||||
|
if(HAS_GETHOSTBYADDR_R)
|
||||||
|
add_definitions(-DHAS_GETHOSTBYADDR_R=1)
|
||||||
|
endif()
|
||||||
|
if(HAS_INET_PTON)
|
||||||
|
add_definitions(-DHAS_INET_PTON=1)
|
||||||
|
endif()
|
||||||
|
if(HAS_INET_NTOP)
|
||||||
|
add_definitions(-DHAS_INET_NTOP=1)
|
||||||
|
endif()
|
||||||
|
if(HAS_MSGHDR_FLAGS)
|
||||||
|
add_definitions(-DHAS_MSGHDR_FLAGS=1)
|
||||||
|
endif()
|
||||||
|
if(HAS_SOCKLEN_T)
|
||||||
|
add_definitions(-DHAS_SOCKLEN_T=1)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
include_directories(${PROJECT_SOURCE_DIR}/include)
|
||||||
|
|
||||||
|
add_library(enet STATIC
|
||||||
|
callbacks.c
|
||||||
|
compress.c
|
||||||
|
host.c
|
||||||
|
list.c
|
||||||
|
packet.c
|
||||||
|
peer.c
|
||||||
|
protocol.c
|
||||||
|
unix.c
|
||||||
|
win32.c
|
||||||
|
)
|
||||||
|
|
|
@ -0,0 +1,171 @@
|
||||||
|
ENet 1.3.12 (April 24, 2014):
|
||||||
|
|
||||||
|
* added maximumPacketSize and maximumWaitingData fields to ENetHost to limit the amount of
|
||||||
|
data waiting to be delivered on a peer (beware that the default maximumPacketSize is
|
||||||
|
32MB and should be set higher if desired as should maximumWaitingData)
|
||||||
|
|
||||||
|
ENet 1.3.11 (December 26, 2013):
|
||||||
|
|
||||||
|
* allow an ENetHost to connect to itself
|
||||||
|
* fixed possible bug with disconnect notifications during connect attempts
|
||||||
|
* fixed some preprocessor definition bugs
|
||||||
|
|
||||||
|
ENet 1.3.10 (October 23, 2013);
|
||||||
|
|
||||||
|
* doubled maximum reliable window size
|
||||||
|
* fixed RCVTIMEO/SNDTIMEO socket options and also added NODELAY
|
||||||
|
|
||||||
|
ENet 1.3.9 (August 19, 2013):
|
||||||
|
|
||||||
|
* added duplicatePeers option to ENetHost which can limit the number of peers from duplicate IPs
|
||||||
|
* added enet_socket_get_option() and ENET_SOCKOPT_ERROR
|
||||||
|
* added enet_host_random_seed() platform stub
|
||||||
|
|
||||||
|
ENet 1.3.8 (June 2, 2013):
|
||||||
|
|
||||||
|
* added enet_linked_version() for checking the linked version
|
||||||
|
* added enet_socket_get_address() for querying the local address of a socket
|
||||||
|
* silenced some debugging prints unless ENET_DEBUG is defined during compilation
|
||||||
|
* handle EINTR in enet_socket_wait() so that enet_host_service() doesn't propagate errors from signals
|
||||||
|
* optimized enet_host_bandwidth_throttle() to be less expensive for large numbers of peers
|
||||||
|
|
||||||
|
ENet 1.3.7 (March 6, 2013):
|
||||||
|
|
||||||
|
* added ENET_PACKET_FLAG_SENT to indicate that a packet is being freed because it has been sent
|
||||||
|
* added userData field to ENetPacket
|
||||||
|
* changed how random seed is generated on Windows to avoid import warnings
|
||||||
|
* fixed case where disconnects could be generated with no preceding connect event
|
||||||
|
|
||||||
|
ENet 1.3.6 (December 11, 2012):
|
||||||
|
|
||||||
|
* added support for intercept callback in ENetHost that can be used to process raw packets before ENet
|
||||||
|
* added enet_socket_shutdown() for issuing shutdown on a socket
|
||||||
|
* fixed enet_socket_connect() to not error on non-blocking connects
|
||||||
|
* fixed bug in MTU negotiation during connections
|
||||||
|
|
||||||
|
ENet 1.3.5 (July 31, 2012):
|
||||||
|
|
||||||
|
* fixed bug in unreliable packet fragment queuing
|
||||||
|
|
||||||
|
ENet 1.3.4 (May 29, 2012):
|
||||||
|
|
||||||
|
* added enet_peer_ping_interval() for configuring per-peer ping intervals
|
||||||
|
* added enet_peer_timeout() for configuring per-peer timeouts
|
||||||
|
* added protocol packet size limits
|
||||||
|
|
||||||
|
ENet 1.3.3 (June 28, 2011):
|
||||||
|
|
||||||
|
* fixed bug with simultaneous disconnects not dispatching events
|
||||||
|
|
||||||
|
ENet 1.3.2 (May 31, 2011):
|
||||||
|
|
||||||
|
* added support for unreliable packet fragmenting via the packet flag
|
||||||
|
ENET_PACKET_FLAG_UNRELIABLE_FRAGMENT
|
||||||
|
* fixed regression in unreliable packet queuing
|
||||||
|
* added check against received port to limit some forms of IP-spoofing
|
||||||
|
|
||||||
|
ENet 1.3.1 (February 10, 2011):
|
||||||
|
|
||||||
|
* fixed bug in tracking of reliable data in transit
|
||||||
|
* reliable data window size now scales with the throttle
|
||||||
|
* fixed bug in fragment length calculation when checksums are used
|
||||||
|
|
||||||
|
ENet 1.3.0 (June 5, 2010):
|
||||||
|
|
||||||
|
* enet_host_create() now requires the channel limit to be specified as
|
||||||
|
a parameter
|
||||||
|
* enet_host_connect() now accepts a data parameter which is supplied
|
||||||
|
to the receiving receiving host in the event data field for a connect event
|
||||||
|
* added an adaptive order-2 PPM range coder as a built-in compressor option
|
||||||
|
which can be set with enet_host_compress_with_range_coder()
|
||||||
|
* added support for packet compression configurable with a callback
|
||||||
|
* improved session number handling to not rely on the packet checksum
|
||||||
|
field, saving 4 bytes per packet unless the checksum option is used
|
||||||
|
* removed the dependence on the rand callback for session number handling
|
||||||
|
|
||||||
|
Caveats: This version is not protocol compatible with the 1.2 series or
|
||||||
|
earlier. The enet_host_connect and enet_host_create API functions require
|
||||||
|
supplying additional parameters.
|
||||||
|
|
||||||
|
ENet 1.2.5 (June 28, 2011):
|
||||||
|
|
||||||
|
* fixed bug with simultaneous disconnects not dispatching events
|
||||||
|
|
||||||
|
ENet 1.2.4 (May 31, 2011):
|
||||||
|
|
||||||
|
* fixed regression in unreliable packet queuing
|
||||||
|
* added check against received port to limit some forms of IP-spoofing
|
||||||
|
|
||||||
|
ENet 1.2.3 (February 10, 2011):
|
||||||
|
|
||||||
|
* fixed bug in tracking reliable data in transit
|
||||||
|
|
||||||
|
ENet 1.2.2 (June 5, 2010):
|
||||||
|
|
||||||
|
* checksum functionality is now enabled by setting a checksum callback
|
||||||
|
inside ENetHost instead of being a configure script option
|
||||||
|
* added totalSentData, totalSentPackets, totalReceivedData, and
|
||||||
|
totalReceivedPackets counters inside ENetHost for getting usage
|
||||||
|
statistics
|
||||||
|
* added enet_host_channel_limit() for limiting the maximum number of
|
||||||
|
channels allowed by connected peers
|
||||||
|
* now uses dispatch queues for event dispatch rather than potentially
|
||||||
|
unscalable array walking
|
||||||
|
* added no_memory callback that is called when a malloc attempt fails,
|
||||||
|
such that if no_memory returns rather than aborts (the default behavior),
|
||||||
|
then the error is propagated to the return value of the API calls
|
||||||
|
* now uses packed attribute for protocol structures on platforms with
|
||||||
|
strange alignment rules
|
||||||
|
* improved autoconf build system contributed by Nathan Brink allowing
|
||||||
|
for easier building as a shared library
|
||||||
|
|
||||||
|
Caveats: If you were using the compile-time option that enabled checksums,
|
||||||
|
make sure to set the checksum callback inside ENetHost to enet_crc32 to
|
||||||
|
regain the old behavior. The ENetCallbacks structure has added new fields,
|
||||||
|
so make sure to clear the structure to zero before use if
|
||||||
|
using enet_initialize_with_callbacks().
|
||||||
|
|
||||||
|
ENet 1.2.1 (November 12, 2009):
|
||||||
|
|
||||||
|
* fixed bug that could cause disconnect events to be dropped
|
||||||
|
* added thin wrapper around select() for portable usage
|
||||||
|
* added ENET_SOCKOPT_REUSEADDR socket option
|
||||||
|
* factored enet_socket_bind()/enet_socket_listen() out of enet_socket_create()
|
||||||
|
* added contributed Code::Blocks build file
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,191 @@
|
||||||
|
<doxygenlayout version="1.0">
|
||||||
|
<!-- Generated by doxygen 1.8.6 -->
|
||||||
|
<!-- Navigation index tabs for HTML output -->
|
||||||
|
<navindex>
|
||||||
|
<tab type="mainpage" visible="yes" title="Home"/>
|
||||||
|
<tab type="user" visible="yes" title="Features" url="@ref Features" />
|
||||||
|
<tab type="user" visible="yes" title="Downloads" url="@ref Downloads" />
|
||||||
|
<tab type="user" visible="yes" title="Installation" url="@ref Installation" />
|
||||||
|
<tab type="user" visible="yes" title="Tutorial" url="@ref Tutorial" />
|
||||||
|
<tab type="user" visible="yes" title="Mailing List" url="@ref MailingList" />
|
||||||
|
<tab type="user" visible="yes" title="IRC Channel" url="@ref IRCChannel" />
|
||||||
|
<tab type="user" visible="yes" title="FAQ" url="@ref FAQ" />
|
||||||
|
<tab type="user" visible="yes" title="License" url="@ref License" />
|
||||||
|
<tab type="usergroup" visible="yes" title="Documentation" briefdescription="Documentation">
|
||||||
|
<tab type="modules" visible="yes" title="Functions" intro=""/>
|
||||||
|
<tab type="classlist" visible="yes" title="Data Structures" intro=""/>
|
||||||
|
<tab type="filelist" visible="yes" title="Files" intro=""/>
|
||||||
|
<tab type="globals" visible="yes" title="" intro=""/>
|
||||||
|
</tab>
|
||||||
|
</navindex>
|
||||||
|
|
||||||
|
<!-- Layout definition for a class page -->
|
||||||
|
<class>
|
||||||
|
<briefdescription visible="yes"/>
|
||||||
|
<includes visible="$SHOW_INCLUDE_FILES"/>
|
||||||
|
<inheritancegraph visible="$CLASS_GRAPH"/>
|
||||||
|
<collaborationgraph visible="$COLLABORATION_GRAPH"/>
|
||||||
|
<memberdecl>
|
||||||
|
<nestedclasses visible="yes" title=""/>
|
||||||
|
<publictypes title=""/>
|
||||||
|
<services title=""/>
|
||||||
|
<interfaces title=""/>
|
||||||
|
<publicslots title=""/>
|
||||||
|
<signals title=""/>
|
||||||
|
<publicmethods title=""/>
|
||||||
|
<publicstaticmethods title=""/>
|
||||||
|
<publicattributes title=""/>
|
||||||
|
<publicstaticattributes title=""/>
|
||||||
|
<protectedtypes title=""/>
|
||||||
|
<protectedslots title=""/>
|
||||||
|
<protectedmethods title=""/>
|
||||||
|
<protectedstaticmethods title=""/>
|
||||||
|
<protectedattributes title=""/>
|
||||||
|
<protectedstaticattributes title=""/>
|
||||||
|
<packagetypes title=""/>
|
||||||
|
<packagemethods title=""/>
|
||||||
|
<packagestaticmethods title=""/>
|
||||||
|
<packageattributes title=""/>
|
||||||
|
<packagestaticattributes title=""/>
|
||||||
|
<properties title=""/>
|
||||||
|
<events title=""/>
|
||||||
|
<privatetypes title=""/>
|
||||||
|
<privateslots title=""/>
|
||||||
|
<privatemethods title=""/>
|
||||||
|
<privatestaticmethods title=""/>
|
||||||
|
<privateattributes title=""/>
|
||||||
|
<privatestaticattributes title=""/>
|
||||||
|
<friends title=""/>
|
||||||
|
<related title="" subtitle=""/>
|
||||||
|
<membergroups visible="yes"/>
|
||||||
|
</memberdecl>
|
||||||
|
<detaileddescription title=""/>
|
||||||
|
<memberdef>
|
||||||
|
<inlineclasses title=""/>
|
||||||
|
<typedefs title=""/>
|
||||||
|
<enums title=""/>
|
||||||
|
<services title=""/>
|
||||||
|
<interfaces title=""/>
|
||||||
|
<constructors title=""/>
|
||||||
|
<functions title=""/>
|
||||||
|
<related title=""/>
|
||||||
|
<variables title=""/>
|
||||||
|
<properties title=""/>
|
||||||
|
<events title=""/>
|
||||||
|
</memberdef>
|
||||||
|
<allmemberslink visible="yes"/>
|
||||||
|
<usedfiles visible="$SHOW_USED_FILES"/>
|
||||||
|
<authorsection visible="yes"/>
|
||||||
|
</class>
|
||||||
|
|
||||||
|
<!-- Layout definition for a namespace page -->
|
||||||
|
<namespace>
|
||||||
|
<briefdescription visible="yes"/>
|
||||||
|
<memberdecl>
|
||||||
|
<nestednamespaces visible="yes" title=""/>
|
||||||
|
<constantgroups visible="yes" title=""/>
|
||||||
|
<classes visible="yes" title=""/>
|
||||||
|
<typedefs title=""/>
|
||||||
|
<enums title=""/>
|
||||||
|
<functions title=""/>
|
||||||
|
<variables title=""/>
|
||||||
|
<membergroups visible="yes"/>
|
||||||
|
</memberdecl>
|
||||||
|
<detaileddescription title=""/>
|
||||||
|
<memberdef>
|
||||||
|
<inlineclasses title=""/>
|
||||||
|
<typedefs title=""/>
|
||||||
|
<enums title=""/>
|
||||||
|
<functions title=""/>
|
||||||
|
<variables title=""/>
|
||||||
|
</memberdef>
|
||||||
|
<authorsection visible="yes"/>
|
||||||
|
</namespace>
|
||||||
|
|
||||||
|
<!-- Layout definition for a file page -->
|
||||||
|
<file>
|
||||||
|
<briefdescription visible="yes"/>
|
||||||
|
<includes visible="$SHOW_INCLUDE_FILES"/>
|
||||||
|
<includegraph visible="$INCLUDE_GRAPH"/>
|
||||||
|
<includedbygraph visible="$INCLUDED_BY_GRAPH"/>
|
||||||
|
<sourcelink visible="yes"/>
|
||||||
|
<memberdecl>
|
||||||
|
<classes visible="yes" title=""/>
|
||||||
|
<namespaces visible="yes" title=""/>
|
||||||
|
<constantgroups visible="yes" title=""/>
|
||||||
|
<defines title=""/>
|
||||||
|
<typedefs title=""/>
|
||||||
|
<enums title=""/>
|
||||||
|
<functions title=""/>
|
||||||
|
<variables title=""/>
|
||||||
|
<membergroups visible="yes"/>
|
||||||
|
</memberdecl>
|
||||||
|
<detaileddescription title=""/>
|
||||||
|
<memberdef>
|
||||||
|
<inlineclasses title=""/>
|
||||||
|
<defines title=""/>
|
||||||
|
<typedefs title=""/>
|
||||||
|
<enums title=""/>
|
||||||
|
<functions title=""/>
|
||||||
|
<variables title=""/>
|
||||||
|
</memberdef>
|
||||||
|
<authorsection/>
|
||||||
|
</file>
|
||||||
|
|
||||||
|
<!-- Layout definition for a group page -->
|
||||||
|
<group>
|
||||||
|
<briefdescription visible="yes"/>
|
||||||
|
<groupgraph visible="$GROUP_GRAPHS"/>
|
||||||
|
<memberdecl>
|
||||||
|
<nestedgroups visible="yes" title=""/>
|
||||||
|
<dirs visible="yes" title=""/>
|
||||||
|
<files visible="yes" title=""/>
|
||||||
|
<namespaces visible="yes" title=""/>
|
||||||
|
<classes visible="yes" title=""/>
|
||||||
|
<defines title=""/>
|
||||||
|
<typedefs title=""/>
|
||||||
|
<enums title=""/>
|
||||||
|
<enumvalues title=""/>
|
||||||
|
<functions title=""/>
|
||||||
|
<variables title=""/>
|
||||||
|
<signals title=""/>
|
||||||
|
<publicslots title=""/>
|
||||||
|
<protectedslots title=""/>
|
||||||
|
<privateslots title=""/>
|
||||||
|
<events title=""/>
|
||||||
|
<properties title=""/>
|
||||||
|
<friends title=""/>
|
||||||
|
<membergroups visible="yes"/>
|
||||||
|
</memberdecl>
|
||||||
|
<detaileddescription title=""/>
|
||||||
|
<memberdef>
|
||||||
|
<pagedocs/>
|
||||||
|
<inlineclasses title=""/>
|
||||||
|
<defines title=""/>
|
||||||
|
<typedefs title=""/>
|
||||||
|
<enums title=""/>
|
||||||
|
<enumvalues title=""/>
|
||||||
|
<functions title=""/>
|
||||||
|
<variables title=""/>
|
||||||
|
<signals title=""/>
|
||||||
|
<publicslots title=""/>
|
||||||
|
<protectedslots title=""/>
|
||||||
|
<privateslots title=""/>
|
||||||
|
<events title=""/>
|
||||||
|
<properties title=""/>
|
||||||
|
<friends title=""/>
|
||||||
|
</memberdef>
|
||||||
|
<authorsection visible="yes"/>
|
||||||
|
</group>
|
||||||
|
|
||||||
|
<!-- Layout definition for a directory page -->
|
||||||
|
<directory>
|
||||||
|
<briefdescription visible="yes"/>
|
||||||
|
<directorygraph visible="yes"/>
|
||||||
|
<memberdecl>
|
||||||
|
<dirs visible="yes"/>
|
||||||
|
<files visible="yes"/>
|
||||||
|
</memberdecl>
|
||||||
|
<detaileddescription title=""/>
|
||||||
|
</directory>
|
||||||
|
</doxygenlayout>
|
|
@ -1,4 +1,4 @@
|
||||||
Copyright (c) 2002-2014 Lee Salzman
|
Copyright (c) 2002-2015 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:
|
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:
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,22 @@
|
||||||
|
pkgconfigdir = $(libdir)/pkgconfig
|
||||||
|
nodist_pkgconfig_DATA = libenet.pc
|
||||||
|
|
||||||
|
enetincludedir=$(includedir)/enet
|
||||||
|
enetinclude_HEADERS = \
|
||||||
|
include/enet/callbacks.h \
|
||||||
|
include/enet/enet.h \
|
||||||
|
include/enet/list.h \
|
||||||
|
include/enet/protocol.h \
|
||||||
|
include/enet/time.h \
|
||||||
|
include/enet/types.h \
|
||||||
|
include/enet/unix.h \
|
||||||
|
include/enet/utility.h \
|
||||||
|
include/enet/win32.h
|
||||||
|
|
||||||
|
lib_LTLIBRARIES = libenet.la
|
||||||
|
libenet_la_SOURCES = callbacks.c compress.c host.c list.c packet.c peer.c protocol.c unix.c win32.c
|
||||||
|
# see info '(libtool) Updating version info' before making a release
|
||||||
|
libenet_la_LDFLAGS = $(AM_LDFLAGS) -version-info 7:0:0
|
||||||
|
AM_CPPFLAGS = -I$(top_srcdir)/include
|
||||||
|
|
||||||
|
ACLOCAL_AMFLAGS = -Im4
|
|
@ -0,0 +1,26 @@
|
||||||
|
AC_INIT([libenet], [1.3.12])
|
||||||
|
AC_CONFIG_SRCDIR([include/enet/enet.h])
|
||||||
|
AM_INIT_AUTOMAKE([foreign])
|
||||||
|
|
||||||
|
AC_CONFIG_MACRO_DIR([m4])
|
||||||
|
|
||||||
|
AC_PROG_CC
|
||||||
|
AC_PROG_LIBTOOL
|
||||||
|
|
||||||
|
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_CONFIG_FILES([Makefile
|
||||||
|
libenet.pc])
|
||||||
|
AC_OUTPUT
|
|
@ -0,0 +1,24 @@
|
||||||
|
/**
|
||||||
|
@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 multi-threaded 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.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,126 @@
|
||||||
|
/**
|
||||||
|
@page Features Features and Architecture
|
||||||
|
|
||||||
|
ENet evolved specifically as a UDP networking layer for the
|
||||||
|
multiplayer first person shooter Cube. Cube necessitated low latency
|
||||||
|
communication 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
|
||||||
|
guarantees 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).
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
|
@ -0,0 +1,63 @@
|
||||||
|
/**
|
||||||
|
@page Installation Installation
|
||||||
|
|
||||||
|
ENet should be trivially simple to integrate with most applications.
|
||||||
|
First, make sure you download the latest source distribution at @ref Downloads.
|
||||||
|
|
||||||
|
@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 github, 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:
|
||||||
|
|
||||||
|
autoreconf -vfi
|
||||||
|
|
||||||
|
|
||||||
|
@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
|
||||||
|
|
||||||
|
You may simply use the included "enet.lib" or "enet64.lib" static libraries.
|
||||||
|
However, if you wish to build the library yourself, then the following
|
||||||
|
instructions apply:
|
||||||
|
|
||||||
|
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 and winmm.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" and
|
||||||
|
"winmm.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.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
|
@ -0,0 +1,26 @@
|
||||||
|
/**
|
||||||
|
@page License License
|
||||||
|
|
||||||
|
Copyright (c) 2002-2015 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.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
|
@ -0,0 +1,59 @@
|
||||||
|
/** @mainpage ENet
|
||||||
|
|
||||||
|
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 omits certain higher level networking features such as authentication,
|
||||||
|
lobbying, server discovery, encryption, or other similar tasks that are
|
||||||
|
particularly application specific so that the library remains flexible,
|
||||||
|
portable, and easily embeddable.
|
||||||
|
|
||||||
|
@ref Features
|
||||||
|
|
||||||
|
@ref Downloads
|
||||||
|
|
||||||
|
@ref Installation
|
||||||
|
|
||||||
|
@ref Tutorial
|
||||||
|
|
||||||
|
@ref MailingList
|
||||||
|
|
||||||
|
@ref IRCChannel
|
||||||
|
|
||||||
|
@ref FAQ
|
||||||
|
|
||||||
|
@ref License
|
||||||
|
|
||||||
|
<a class="el" href="usergroup0.html">Documentation</a>
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
@page Downloads Downloads
|
||||||
|
|
||||||
|
You can retrieve the source to ENet by downloading it in either .tar.gz form
|
||||||
|
or accessing the github distribution directly.
|
||||||
|
|
||||||
|
The most recent stable release (1.3.12) can be downloaded <a class="el" href="download/enet-1.3.12.tar.gz">here</a>.
|
||||||
|
The last release that is protocol compatible with the 1.2 series or earlier (1.2.5) can be downloaded <a class="el" href="download/enet-1.2.5.tar.gz">here</a>.
|
||||||
|
|
||||||
|
You can find the most recent ENet source at <a class="el" href="https://github.com/lsalzman/enet">the github repository</a>.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
@page MailingList Mailing List
|
||||||
|
|
||||||
|
The <a class="el" href="http://lists.cubik.org/mailman/listinfo/enet-discuss">enet-discuss</a> list is for discussion of ENet, including bug reports or feature requests.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
@page IRCChannel IRC Channel
|
||||||
|
|
||||||
|
Join the \#enet channel on the <a class="el" href="http://freenode.net">freenode IRC network (irc.freenode.net)</a> for real-time discussion about the ENet library.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
|
@ -0,0 +1,366 @@
|
||||||
|
/**
|
||||||
|
@page Tutorial Tutorial
|
||||||
|
|
||||||
|
@ref Initialization
|
||||||
|
|
||||||
|
@ref CreateServer
|
||||||
|
|
||||||
|
@ref CreateClient
|
||||||
|
|
||||||
|
@ref ManageHost
|
||||||
|
|
||||||
|
@ref SendingPacket
|
||||||
|
|
||||||
|
@ref Disconnecting
|
||||||
|
|
||||||
|
@ref Connecting
|
||||||
|
|
||||||
|
@section Initialization Initialization
|
||||||
|
|
||||||
|
You should include the file <enet/enet.h> when using ENet. Do not
|
||||||
|
include <enet.h> without the directory prefix, as this may cause
|
||||||
|
file name conflicts on some systems.
|
||||||
|
|
||||||
|
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
|
||||||
|
#include <enet/enet.h>
|
||||||
|
|
||||||
|
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 */,
|
||||||
|
2 /* allow up to 2 channels to be used, 0 and 1 */,
|
||||||
|
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 */,
|
||||||
|
2 /* allow up 2 channels to be used, 0 and 1 */,
|
||||||
|
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.
|
||||||
|
|
||||||
|
Beware that most processing of the network with the ENet stack is done
|
||||||
|
inside enet_host_service(). Both hosts that make up the sides of a connection
|
||||||
|
must regularly call this function to ensure packets are actually sent and
|
||||||
|
received. A common symptom of not actively calling enet_host_service()
|
||||||
|
on both ends is that one side receives events while the other does not.
|
||||||
|
The best way to schedule this activity to ensure adequate service is, for
|
||||||
|
example, to call enet_host_service() with a 0 timeout (meaning non-blocking)
|
||||||
|
at the beginning of every frame in a game loop.
|
||||||
|
|
||||||
|
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 disconnected.\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 guaranteed 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, 0);
|
||||||
|
|
||||||
|
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
|
||||||
|
*/
|
|
@ -0,0 +1,168 @@
|
||||||
|
# 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=.\compress.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
|
|
@ -18,6 +18,35 @@
|
||||||
<Platform>x64</Platform>
|
<Platform>x64</Platform>
|
||||||
</ProjectConfiguration>
|
</ProjectConfiguration>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<ClInclude Include="include\enet\callbacks.h" />
|
||||||
|
<ClInclude Include="include\enet\enet.h" />
|
||||||
|
<ClInclude Include="include\enet\list.h" />
|
||||||
|
<ClInclude Include="include\enet\protocol.h" />
|
||||||
|
<ClInclude Include="include\enet\time.h" />
|
||||||
|
<ClInclude Include="include\enet\types.h" />
|
||||||
|
<ClInclude Include="include\enet\unix.h" />
|
||||||
|
<ClInclude Include="include\enet\utility.h" />
|
||||||
|
<ClInclude Include="include\enet\win32.h" />
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<ClCompile Include="callbacks.c" />
|
||||||
|
<ClCompile Include="compress.c" />
|
||||||
|
<ClCompile Include="host.c" />
|
||||||
|
<ClCompile Include="list.c" />
|
||||||
|
<ClCompile Include="packet.c" />
|
||||||
|
<ClCompile Include="peer.c" />
|
||||||
|
<ClCompile Include="protocol.c" />
|
||||||
|
<ClCompile Include="unix.c" />
|
||||||
|
<ClCompile Include="win32.c" />
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<Text Include="CMakeLists.txt" />
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<None Include="LICENSE" />
|
||||||
|
<None Include="README" />
|
||||||
|
</ItemGroup>
|
||||||
<PropertyGroup Label="Globals">
|
<PropertyGroup Label="Globals">
|
||||||
<ProjectGuid>{CBC76802-C128-4B17-BF6C-23B08C313E5E}</ProjectGuid>
|
<ProjectGuid>{CBC76802-C128-4B17-BF6C-23B08C313E5E}</ProjectGuid>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
|
@ -42,36 +71,11 @@
|
||||||
</ImportGroup>
|
</ImportGroup>
|
||||||
<PropertyGroup Label="UserMacros" />
|
<PropertyGroup Label="UserMacros" />
|
||||||
<PropertyGroup />
|
<PropertyGroup />
|
||||||
<ItemDefinitionGroup>
|
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
|
||||||
|
<ClCompile>
|
||||||
|
<AdditionalIncludeDirectories>$(ExternalsDir)enet\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
|
||||||
|
</ClCompile>
|
||||||
</ItemDefinitionGroup>
|
</ItemDefinitionGroup>
|
||||||
<ItemGroup>
|
|
||||||
<Text Include="CMakeLists.txt" />
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<ClCompile Include="callbacks.c" />
|
|
||||||
<ClCompile Include="compress.c" />
|
|
||||||
<ClCompile Include="host.c" />
|
|
||||||
<ClCompile Include="list.c" />
|
|
||||||
<ClCompile Include="packet.c" />
|
|
||||||
<ClCompile Include="peer.c" />
|
|
||||||
<ClCompile Include="protocol.c" />
|
|
||||||
<ClCompile Include="unix.c" />
|
|
||||||
<ClCompile Include="win32.c" />
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<ClInclude Include="callbacks.h" />
|
|
||||||
<ClInclude Include="enet.h" />
|
|
||||||
<ClInclude Include="list.h" />
|
|
||||||
<ClInclude Include="protocol.h" />
|
|
||||||
<ClInclude Include="time.h" />
|
|
||||||
<ClInclude Include="types.h" />
|
|
||||||
<ClInclude Include="unix.h" />
|
|
||||||
<ClInclude Include="utility.h" />
|
|
||||||
<ClInclude Include="win32.h" />
|
|
||||||
</ItemGroup>
|
|
||||||
<ItemGroup>
|
|
||||||
<None Include="LICENSE" />
|
|
||||||
</ItemGroup>
|
|
||||||
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
||||||
<ImportGroup Label="ExtensionTargets">
|
<ImportGroup Label="ExtensionTargets">
|
||||||
</ImportGroup>
|
</ImportGroup>
|
||||||
|
|
|
@ -0,0 +1,55 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||||
|
<ItemGroup>
|
||||||
|
<Filter Include="include">
|
||||||
|
<UniqueIdentifier>{a5756b80-36f2-45f6-b1f1-b67082477376}</UniqueIdentifier>
|
||||||
|
</Filter>
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<ClInclude Include="include\enet\callbacks.h">
|
||||||
|
<Filter>include</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="include\enet\enet.h">
|
||||||
|
<Filter>include</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="include\enet\list.h">
|
||||||
|
<Filter>include</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="include\enet\protocol.h">
|
||||||
|
<Filter>include</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="include\enet\time.h">
|
||||||
|
<Filter>include</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="include\enet\types.h">
|
||||||
|
<Filter>include</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="include\enet\unix.h">
|
||||||
|
<Filter>include</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="include\enet\utility.h">
|
||||||
|
<Filter>include</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="include\enet\win32.h">
|
||||||
|
<Filter>include</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<ClCompile Include="callbacks.c" />
|
||||||
|
<ClCompile Include="compress.c" />
|
||||||
|
<ClCompile Include="host.c" />
|
||||||
|
<ClCompile Include="list.c" />
|
||||||
|
<ClCompile Include="packet.c" />
|
||||||
|
<ClCompile Include="peer.c" />
|
||||||
|
<ClCompile Include="protocol.c" />
|
||||||
|
<ClCompile Include="unix.c" />
|
||||||
|
<ClCompile Include="win32.c" />
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<Text Include="CMakeLists.txt" />
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<None Include="LICENSE" />
|
||||||
|
<None Include="README" />
|
||||||
|
</ItemGroup>
|
||||||
|
</Project>
|
|
@ -0,0 +1,86 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>
|
||||||
|
<CodeBlocks_project_file>
|
||||||
|
<FileVersion major="1" minor="6" />
|
||||||
|
<Project>
|
||||||
|
<Option title="enet_dll" />
|
||||||
|
<Option pch_mode="2" />
|
||||||
|
<Option compiler="gcc" />
|
||||||
|
<Build>
|
||||||
|
<Target title="Debug">
|
||||||
|
<Option output="bin\Debug\libenet" prefix_auto="1" extension_auto="1" />
|
||||||
|
<Option object_output="obj\Debug\" />
|
||||||
|
<Option type="3" />
|
||||||
|
<Option compiler="gcc" />
|
||||||
|
<Option createDefFile="1" />
|
||||||
|
<Option createStaticLib="1" />
|
||||||
|
<Compiler>
|
||||||
|
<Add option="-g" />
|
||||||
|
</Compiler>
|
||||||
|
</Target>
|
||||||
|
<Target title="Release">
|
||||||
|
<Option output="bin\Release\libenet" prefix_auto="1" extension_auto="1" />
|
||||||
|
<Option object_output="obj\Release\" />
|
||||||
|
<Option type="3" />
|
||||||
|
<Option compiler="gcc" />
|
||||||
|
<Option createDefFile="1" />
|
||||||
|
<Option createStaticLib="1" />
|
||||||
|
<Compiler>
|
||||||
|
<Add option="-O2" />
|
||||||
|
</Compiler>
|
||||||
|
<Linker>
|
||||||
|
<Add option="-s" />
|
||||||
|
</Linker>
|
||||||
|
</Target>
|
||||||
|
</Build>
|
||||||
|
<Compiler>
|
||||||
|
<Add option="-Wall" />
|
||||||
|
<Add option="-DENET_DLL" />
|
||||||
|
<Add directory="include" />
|
||||||
|
</Compiler>
|
||||||
|
<Linker>
|
||||||
|
<Add library="ws2_32" />
|
||||||
|
<Add library="Winmm" />
|
||||||
|
</Linker>
|
||||||
|
<Unit filename="callbacks.c">
|
||||||
|
<Option compilerVar="CC" />
|
||||||
|
</Unit>
|
||||||
|
<Unit filename="compress.c">
|
||||||
|
<Option compilerVar="CC" />
|
||||||
|
</Unit>
|
||||||
|
<Unit filename="host.c">
|
||||||
|
<Option compilerVar="CC" />
|
||||||
|
</Unit>
|
||||||
|
<Unit filename="include\enet\callbacks.h" />
|
||||||
|
<Unit filename="include\enet\enet.h" />
|
||||||
|
<Unit filename="include\enet\list.h" />
|
||||||
|
<Unit filename="include\enet\protocol.h" />
|
||||||
|
<Unit filename="include\enet\time.h" />
|
||||||
|
<Unit filename="include\enet\types.h" />
|
||||||
|
<Unit filename="include\enet\unix.h" />
|
||||||
|
<Unit filename="include\enet\utility.h" />
|
||||||
|
<Unit filename="include\enet\win32.h" />
|
||||||
|
<Unit filename="list.c">
|
||||||
|
<Option compilerVar="CC" />
|
||||||
|
</Unit>
|
||||||
|
<Unit filename="packet.c">
|
||||||
|
<Option compilerVar="CC" />
|
||||||
|
</Unit>
|
||||||
|
<Unit filename="peer.c">
|
||||||
|
<Option compilerVar="CC" />
|
||||||
|
</Unit>
|
||||||
|
<Unit filename="protocol.c">
|
||||||
|
<Option compilerVar="CC" />
|
||||||
|
</Unit>
|
||||||
|
<Unit filename="unix.c">
|
||||||
|
<Option compilerVar="CC" />
|
||||||
|
</Unit>
|
||||||
|
<Unit filename="win32.c">
|
||||||
|
<Option compilerVar="CC" />
|
||||||
|
</Unit>
|
||||||
|
<Extensions>
|
||||||
|
<code_completion />
|
||||||
|
<envvars />
|
||||||
|
<debugger />
|
||||||
|
</Extensions>
|
||||||
|
</Project>
|
||||||
|
</CodeBlocks_project_file>
|
|
@ -1 +0,0 @@
|
||||||
48571bb05fcdb420da2b0b38cdaf2488bd031d20
|
|
|
@ -13,15 +13,15 @@ extern "C"
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
#include "enet/win32.h"
|
#include "win32.h"
|
||||||
#else
|
#else
|
||||||
#include "enet/unix.h"
|
#include "unix.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "enet/types.h"
|
#include "types.h"
|
||||||
#include "enet/protocol.h"
|
#include "protocol.h"
|
||||||
#include "enet/list.h"
|
#include "list.h"
|
||||||
#include "enet/callbacks.h"
|
#include "callbacks.h"
|
||||||
|
|
||||||
#define ENET_VERSION_MAJOR 1
|
#define ENET_VERSION_MAJOR 1
|
||||||
#define ENET_VERSION_MINOR 3
|
#define ENET_VERSION_MINOR 3
|
|
@ -5,7 +5,7 @@
|
||||||
#ifndef __ENET_PROTOCOL_H__
|
#ifndef __ENET_PROTOCOL_H__
|
||||||
#define __ENET_PROTOCOL_H__
|
#define __ENET_PROTOCOL_H__
|
||||||
|
|
||||||
#include "enet/types.h"
|
#include "types.h"
|
||||||
|
|
||||||
enum
|
enum
|
||||||
{
|
{
|
|
@ -0,0 +1,10 @@
|
||||||
|
prefix=@prefix@
|
||||||
|
exec_prefix=@exec_prefix@
|
||||||
|
libdir=@libdir@
|
||||||
|
includedir=@includedir@
|
||||||
|
|
||||||
|
Name: @PACKAGE_NAME@
|
||||||
|
Description: Low-latency UDP networking library supporting optional reliability
|
||||||
|
Version: @PACKAGE_VERSION@
|
||||||
|
Cflags: -I${includedir}
|
||||||
|
Libs: -L${libdir} -lenet
|
|
@ -0,0 +1,59 @@
|
||||||
|
solution "enet"
|
||||||
|
configurations { "Debug", "Release" }
|
||||||
|
platforms { "x32", "x64" }
|
||||||
|
|
||||||
|
project "enet_static"
|
||||||
|
kind "StaticLib"
|
||||||
|
language "C"
|
||||||
|
|
||||||
|
files { "*.c" }
|
||||||
|
|
||||||
|
includedirs { "include/" }
|
||||||
|
|
||||||
|
configuration "Debug"
|
||||||
|
targetsuffix "d"
|
||||||
|
|
||||||
|
defines({ "DEBUG" })
|
||||||
|
|
||||||
|
flags { "Symbols" }
|
||||||
|
|
||||||
|
configuration "Release"
|
||||||
|
defines({ "NDEBUG" })
|
||||||
|
|
||||||
|
flags { "Optimize" }
|
||||||
|
|
||||||
|
configuration { "Debug", "x64" }
|
||||||
|
targetsuffix "64d"
|
||||||
|
|
||||||
|
configuration { "Release", "x64" }
|
||||||
|
targetsuffix "64"
|
||||||
|
|
||||||
|
project "enet"
|
||||||
|
kind "SharedLib"
|
||||||
|
language "C"
|
||||||
|
|
||||||
|
files { "*.c" }
|
||||||
|
|
||||||
|
includedirs { "include/" }
|
||||||
|
|
||||||
|
defines({"ENET_DLL=1" })
|
||||||
|
|
||||||
|
configuration "Debug"
|
||||||
|
targetsuffix "d"
|
||||||
|
|
||||||
|
defines({ "DEBUG" })
|
||||||
|
|
||||||
|
flags { "Symbols" }
|
||||||
|
|
||||||
|
configuration "Release"
|
||||||
|
defines({ "NDEBUG" })
|
||||||
|
|
||||||
|
flags { "Optimize" }
|
||||||
|
|
||||||
|
configuration { "Debug", "x64" }
|
||||||
|
targetsuffix "64d"
|
||||||
|
|
||||||
|
configuration { "Release", "x64" }
|
||||||
|
targetsuffix "64"
|
||||||
|
|
||||||
|
|
|
@ -1191,7 +1191,9 @@ commandError:
|
||||||
static int
|
static int
|
||||||
enet_protocol_receive_incoming_commands (ENetHost * host, ENetEvent * event)
|
enet_protocol_receive_incoming_commands (ENetHost * host, ENetEvent * event)
|
||||||
{
|
{
|
||||||
for (;;)
|
int packets;
|
||||||
|
|
||||||
|
for (packets = 0; packets < 256; ++ packets)
|
||||||
{
|
{
|
||||||
int receivedLength;
|
int receivedLength;
|
||||||
ENetBuffer buffer;
|
ENetBuffer buffer;
|
||||||
|
|
|
@ -104,7 +104,7 @@ enet_address_set_host (ENetAddress * address, const char * name)
|
||||||
char buffer [2048];
|
char buffer [2048];
|
||||||
int errnum;
|
int errnum;
|
||||||
|
|
||||||
#if defined(linux) || defined(__linux) || defined(__linux__) || defined(__FreeBSD__) || defined(__FreeBSD_kernel__)
|
#if defined(linux) || defined(__linux) || defined(__linux__) || defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__DragonFly__)
|
||||||
gethostbyname_r (name, & hostData, buffer, sizeof (buffer), & hostEntry, & errnum);
|
gethostbyname_r (name, & hostData, buffer, sizeof (buffer), & hostEntry, & errnum);
|
||||||
#else
|
#else
|
||||||
hostEntry = gethostbyname_r (name, & hostData, buffer, sizeof (buffer), & errnum);
|
hostEntry = gethostbyname_r (name, & hostData, buffer, sizeof (buffer), & errnum);
|
||||||
|
@ -162,7 +162,7 @@ enet_address_get_host (const ENetAddress * address, char * name, size_t nameLeng
|
||||||
|
|
||||||
in.s_addr = address -> host;
|
in.s_addr = address -> host;
|
||||||
|
|
||||||
#if defined(linux) || defined(__linux) || defined(__linux__) || defined(__FreeBSD__) || defined(__FreeBSD_kernel__)
|
#if defined(linux) || defined(__linux) || defined(__linux__) || defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__DragonFly__)
|
||||||
gethostbyaddr_r ((char *) & in, sizeof (struct in_addr), AF_INET, & hostData, buffer, sizeof (buffer), & hostEntry, & errnum);
|
gethostbyaddr_r ((char *) & in, sizeof (struct in_addr), AF_INET, & hostData, buffer, sizeof (buffer), & hostEntry, & errnum);
|
||||||
#else
|
#else
|
||||||
hostEntry = gethostbyaddr_r ((char *) & in, sizeof (struct in_addr), AF_INET, & hostData, buffer, sizeof (buffer), & errnum);
|
hostEntry = gethostbyaddr_r ((char *) & in, sizeof (struct in_addr), AF_INET, & hostData, buffer, sizeof (buffer), & errnum);
|
||||||
|
@ -246,7 +246,7 @@ enet_socket_set_option (ENetSocket socket, ENetSocketOption option, int value)
|
||||||
{
|
{
|
||||||
case ENET_SOCKOPT_NONBLOCK:
|
case ENET_SOCKOPT_NONBLOCK:
|
||||||
#ifdef HAS_FCNTL
|
#ifdef HAS_FCNTL
|
||||||
result = fcntl (socket, F_SETFL, O_NONBLOCK | fcntl (socket, F_GETFL));
|
result = fcntl (socket, F_SETFL, (value ? O_NONBLOCK : 0) | (fcntl (socket, F_GETFL) & ~O_NONBLOCK));
|
||||||
#else
|
#else
|
||||||
result = ioctl (socket, FIONBIO, & value);
|
result = ioctl (socket, FIONBIO, & value);
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1,20 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
set -xe
|
|
||||||
rm -rf _enet
|
|
||||||
git clone https://github.com/lsalzman/enet.git _enet
|
|
||||||
if [ -a git-revision ]; then
|
|
||||||
cd _enet
|
|
||||||
git checkout $(cat ../git-revision)
|
|
||||||
cp ../*.h include/
|
|
||||||
cp ../*.c .
|
|
||||||
git stash
|
|
||||||
git checkout MASTER
|
|
||||||
git stash pop
|
|
||||||
cd ..
|
|
||||||
fi
|
|
||||||
cd _enet; git rev-parse HEAD > ../git-revision; cd ..
|
|
||||||
git rm -rf --ignore-unmatch *.[ch]
|
|
||||||
mv _enet/*.c _enet/include/enet/*.h _enet/LICENSE .
|
|
||||||
git add *.[ch] LICENSE git-revision
|
|
||||||
rm -rf _enet
|
|
||||||
echo 'Make sure to update CMakeLists.txt.'
|
|
|
@ -4,10 +4,11 @@
|
||||||
*/
|
*/
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
|
|
||||||
#include <time.h>
|
|
||||||
#define ENET_BUILDING_LIB 1
|
#define ENET_BUILDING_LIB 1
|
||||||
#include "enet/enet.h"
|
#include "enet/enet.h"
|
||||||
|
#include <windows.h>
|
||||||
#include <mmsystem.h>
|
#include <mmsystem.h>
|
||||||
|
|
||||||
static enet_uint32 timeBase = 0;
|
static enet_uint32 timeBase = 0;
|
||||||
|
|
||||||
int
|
int
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
#include "Common/Common.h"
|
#include "Common/Common.h"
|
||||||
#include "Common/Thread.h"
|
#include "Common/Thread.h"
|
||||||
#include "Common/TraversalProto.h"
|
#include "Common/TraversalProto.h"
|
||||||
#include "enet/enet.h"
|
#include "enet/include/enet/enet.h"
|
||||||
|
|
||||||
class TraversalClientClient
|
class TraversalClientClient
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue