summaryrefslogtreecommitdiffhomepage
path: root/NetEx/NetGram.cpp
diff options
context:
space:
mode:
authormilo24x7@gmail.com <milo24x7@gmail.com@076cb2c4-205e-83fd-5cf3-1be9aa105544>2013-07-07 21:40:05 +0000
committermilo24x7@gmail.com <milo24x7@gmail.com@076cb2c4-205e-83fd-5cf3-1be9aa105544>2013-07-07 21:40:05 +0000
commit7943704cfe4e7d6c853ddca82f2d0f3365fb2c88 (patch)
treed520b8e84e9ce5ad843c8bef47bd67fae7a2c01f /NetEx/NetGram.cpp
parent2c1c5595efec1db63c142accda59e83079af217e (diff)
downloadstarshatter-7943704cfe4e7d6c853ddca82f2d0f3365fb2c88.zip
starshatter-7943704cfe4e7d6c853ddca82f2d0f3365fb2c88.tar.gz
starshatter-7943704cfe4e7d6c853ddca82f2d0f3365fb2c88.tar.bz2
Updated open source license declaration and fixed some formatting issues.
Diffstat (limited to 'NetEx/NetGram.cpp')
-rw-r--r--NetEx/NetGram.cpp246
1 files changed, 135 insertions, 111 deletions
diff --git a/NetEx/NetGram.cpp b/NetEx/NetGram.cpp
index 94e1ca2..3bb8f2a 100644
--- a/NetEx/NetGram.cpp
+++ b/NetEx/NetGram.cpp
@@ -1,111 +1,135 @@
-/* Project nGenEx
- Destroyer Studios LLC
- Copyright © 1997-2004. All Rights Reserved.
-
- SUBSYSTEM: NetEx.lib
- FILE: NetGram.cpp
- AUTHOR: John DiCamillo
-
-
- OVERVIEW
- ========
- Generic Network Packet (Datagram) Implementation
-*/
-
-
-#include "MemDebug.h"
-#include "NetGram.h"
-#include "NetLayer.h"
-
-// +-------------------------------------------------------------------+
-
-static DWORD net_gram_sequence = 1;
-
-// +-------------------------------------------------------------------+
-
-/**
- * NetGram constructor for ACK packets
- */
-NetGram::NetGram()
- : retries(0), packet_id(0), send_time(0)
-{ }
-
-/**
- * NetGram constructor for receiving packets from remote hosts
- */
-NetGram::NetGram(const NetAddr& src, Text msg)
- : addr(src), retries(0), send_time(0)
-{
- body = msg;
-
- if (body.length() >= NET_GRAM_HEADER_SIZE) {
- BYTE* data = (BYTE*) body.data();
-
- packet_id = (((DWORD) data[0]) << 24) +
- (((DWORD) data[1]) << 16) +
- (((DWORD) data[2]) << 8) +
- ((DWORD) data[3]);
- }
-}
-
-/**
- * NetGram constructor for composing packets to send to remote hosts
- */
-NetGram::NetGram(const NetAddr& dst, Text user_data, int r)
- : addr(dst), retries(r)
-{
- send_time = NetLayer::GetTime();
- packet_id = net_gram_sequence++;
-
- if (retries)
- packet_id |= NET_GRAM_RELIABLE;
-
- static BYTE buf[NET_GRAM_MAX_SIZE];
- buf[0] = (BYTE) (packet_id >> 24) & 0xff;
- buf[1] = (BYTE) (packet_id >> 16) & 0xff;
- buf[2] = (BYTE) (packet_id >> 8) & 0xff;
- buf[3] = (BYTE) (packet_id) & 0xff;
-
- int len = user_data.length();
- if (len >= NET_GRAM_MAX_SIZE - NET_GRAM_HEADER_SIZE)
- len = NET_GRAM_MAX_SIZE - NET_GRAM_HEADER_SIZE - 1;
-
- CopyMemory(buf+NET_GRAM_HEADER_SIZE, user_data.data(), len);
-
- body = Text((char*) buf, len+NET_GRAM_HEADER_SIZE);
-}
-
-// +--------------------------------------------------------------------+
-
-void
-NetGram::Retry()
-{
- if (retries > 0) {
- retries--;
- send_time = NetLayer::GetTime();
- }
-}
-
-// +--------------------------------------------------------------------+
-
-NetGram
-NetGram::Ack()
-{
- NetGram ack;
-
- ack.packet_id = packet_id | NET_GRAM_ACK;
- ack.send_time = NetLayer::GetTime();
-
- static BYTE buf[NET_GRAM_HEADER_SIZE];
- buf[0] = (BYTE) (ack.packet_id >> 24) & 0xff;
- buf[1] = (BYTE) (ack.packet_id >> 16) & 0xff;
- buf[2] = (BYTE) (ack.packet_id >> 8) & 0xff;
- buf[3] = (BYTE) (ack.packet_id) & 0xff;
-
- ack.body = Text((char*) buf, NET_GRAM_HEADER_SIZE);
-
- return ack;
-}
-
-
-
+/* Starshatter OpenSource Distribution
+ Copyright (c) 1997-2004, Destroyer Studios LLC.
+ All Rights Reserved.
+
+ Redistribution and use in source and binary forms, with or without
+ modification, are permitted provided that the following conditions are met:
+
+ * Redistributions of source code must retain the above copyright notice,
+ this list of conditions and the following disclaimer.
+ * Redistributions in binary form must reproduce the above copyright notice,
+ this list of conditions and the following disclaimer in the documentation
+ and/or other materials provided with the distribution.
+ * Neither the name "Destroyer Studios" nor the names of its contributors
+ may be used to endorse or promote products derived from this software
+ without specific prior written permission.
+
+ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
+ LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ POSSIBILITY OF SUCH DAMAGE.
+
+ SUBSYSTEM: NetEx.lib
+ FILE: NetGram.cpp
+ AUTHOR: John DiCamillo
+
+
+ OVERVIEW
+ ========
+ Generic Network Packet (Datagram) Implementation
+*/
+
+
+#include "MemDebug.h"
+#include "NetGram.h"
+#include "NetLayer.h"
+
+// +-------------------------------------------------------------------+
+
+static DWORD net_gram_sequence = 1;
+
+// +-------------------------------------------------------------------+
+
+/**
+ * NetGram constructor for ACK packets
+ */
+NetGram::NetGram()
+ : retries(0), packet_id(0), send_time(0)
+{ }
+
+/**
+ * NetGram constructor for receiving packets from remote hosts
+ */
+NetGram::NetGram(const NetAddr& src, Text msg)
+ : addr(src), retries(0), send_time(0)
+{
+ body = msg;
+
+ if (body.length() >= NET_GRAM_HEADER_SIZE) {
+ BYTE* data = (BYTE*) body.data();
+
+ packet_id = (((DWORD) data[0]) << 24) +
+ (((DWORD) data[1]) << 16) +
+ (((DWORD) data[2]) << 8) +
+ ((DWORD) data[3]);
+ }
+}
+
+/**
+ * NetGram constructor for composing packets to send to remote hosts
+ */
+NetGram::NetGram(const NetAddr& dst, Text user_data, int r)
+ : addr(dst), retries(r)
+{
+ send_time = NetLayer::GetTime();
+ packet_id = net_gram_sequence++;
+
+ if (retries)
+ packet_id |= NET_GRAM_RELIABLE;
+
+ static BYTE buf[NET_GRAM_MAX_SIZE];
+ buf[0] = (BYTE) (packet_id >> 24) & 0xff;
+ buf[1] = (BYTE) (packet_id >> 16) & 0xff;
+ buf[2] = (BYTE) (packet_id >> 8) & 0xff;
+ buf[3] = (BYTE) (packet_id) & 0xff;
+
+ int len = user_data.length();
+ if (len >= NET_GRAM_MAX_SIZE - NET_GRAM_HEADER_SIZE)
+ len = NET_GRAM_MAX_SIZE - NET_GRAM_HEADER_SIZE - 1;
+
+ CopyMemory(buf+NET_GRAM_HEADER_SIZE, user_data.data(), len);
+
+ body = Text((char*) buf, len+NET_GRAM_HEADER_SIZE);
+}
+
+// +--------------------------------------------------------------------+
+
+void
+NetGram::Retry()
+{
+ if (retries > 0) {
+ retries--;
+ send_time = NetLayer::GetTime();
+ }
+}
+
+// +--------------------------------------------------------------------+
+
+NetGram
+NetGram::Ack()
+{
+ NetGram ack;
+
+ ack.packet_id = packet_id | NET_GRAM_ACK;
+ ack.send_time = NetLayer::GetTime();
+
+ static BYTE buf[NET_GRAM_HEADER_SIZE];
+ buf[0] = (BYTE) (ack.packet_id >> 24) & 0xff;
+ buf[1] = (BYTE) (ack.packet_id >> 16) & 0xff;
+ buf[2] = (BYTE) (ack.packet_id >> 8) & 0xff;
+ buf[3] = (BYTE) (ack.packet_id) & 0xff;
+
+ ack.body = Text((char*) buf, NET_GRAM_HEADER_SIZE);
+
+ return ack;
+}
+
+
+