src/proto2/NetworkPacket.cc
author terom
Thu, 20 Nov 2008 20:27:12 +0000
branchno-netsession
changeset 37 ed2957490bbf
parent 36 785d220fc6b7
child 40 4b2867fb5c12
permissions -rw-r--r--
compile step complete
31
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
     1
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
     2
#include "NetworkPacket.hh"
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
     3
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
     4
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
     5
NetworkPacket::NetworkPacket (void) :
33
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
     6
    buf_size(NETWORK_PACKET_SIZE), data_size(0), offset(0) {
31
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
     7
    
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
     8
    // nothing
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
     9
}
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    10
33
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
    11
void NetworkPacket::check_write_size (size_t item_size) {
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
    12
     if (offset + item_size > buf_size)
36
terom
parents: 33
diff changeset
    13
        throw NetworkPacketError("not enough space to write");
33
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
    14
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
    15
}
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
    16
        
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
    17
void NetworkPacket::check_read_size (size_t item_size) {
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
    18
    if (offset + item_size > data_size)
36
terom
parents: 33
diff changeset
    19
        throw NetworkPacketError("not enough data to read");
33
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
    20
}
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
    21
31
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    22
template <typename T> T NetworkPacket::read_val (void) {
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    23
    T val;
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    24
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    25
    // check size
33
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
    26
    check_read_size(sizeof(T));
31
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    27
    
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    28
    // set value
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    29
    val = *((T*) (buf + offset));
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    30
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    31
    // update offset
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    32
    offset += sizeof(T);
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    33
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    34
    // return
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    35
    return val;
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    36
}
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    37
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    38
template <typename T> void NetworkPacket::write_val (const T &val) {
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    39
    // check max size
33
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
    40
    check_write_size(sizeof(T));
31
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    41
    
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    42
    // set value
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    43
    *((T*) (buf + offset)) = val;
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    44
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    45
    // update offset and size
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    46
    offset += sizeof(T);
33
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
    47
    data_size += sizeof(T);
31
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    48
}
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    49
36
terom
parents: 33
diff changeset
    50
uint32_t NetworkPacket::read_uint32 (void) {
31
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    51
    return ntohl(read_val<uint32_t>());
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    52
}
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    53
36
terom
parents: 33
diff changeset
    54
uint16_t NetworkPacket::read_uint16 (void) {
31
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    55
    return ntohs(read_val<uint16_t>());
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    56
}
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    57
36
terom
parents: 33
diff changeset
    58
uint8_t NetworkPacket::read_uint8 (void) {
31
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    59
    return read_val<uint8_t>();
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    60
}
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    61
36
terom
parents: 33
diff changeset
    62
int32_t NetworkPacket::read_int32 (void) {
31
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    63
    return ntohl(read_val<int32_t>());
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    64
}
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    65
36
terom
parents: 33
diff changeset
    66
int16_t NetworkPacket::read_int16 (void) {
31
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    67
    return ntohs(read_val<int16_t>());
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    68
}
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    69
36
terom
parents: 33
diff changeset
    70
int8_t NetworkPacket::read_int8 (void) {
31
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    71
    return read_val<int8_t>();
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    72
}
36
terom
parents: 33
diff changeset
    73
        
terom
parents: 33
diff changeset
    74
float NetworkPacket::read_float32 (void) {
37
ed2957490bbf compile step complete
terom
parents: 36
diff changeset
    75
    return (float) read_uint32();
36
terom
parents: 33
diff changeset
    76
}
terom
parents: 33
diff changeset
    77
terom
parents: 33
diff changeset
    78
Vector NetworkPacket::read_vector (void) {
terom
parents: 33
diff changeset
    79
    float fx = read_float32();
terom
parents: 33
diff changeset
    80
    float fy = read_float32();
terom
parents: 33
diff changeset
    81
terom
parents: 33
diff changeset
    82
    return Vector(fx, fy);
terom
parents: 33
diff changeset
    83
}
31
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    84
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    85
void NetworkPacket::write_uint32 (uint32_t val) {
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    86
    write_val<uint32_t>(htonl(val));
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    87
}
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    88
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    89
void NetworkPacket::write_uint16 (uint16_t val) {
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    90
    write_val<uint16_t>(htons(val));
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    91
}
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    92
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    93
void NetworkPacket::write_uint8 (uint8_t val) {
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    94
    write_val<uint8_t>(val);
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    95
}
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    96
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    97
void NetworkPacket::write_int32 (int32_t val) {
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    98
    write_val<int32_t>(htonl(val));
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
    99
}
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
   100
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
   101
void NetworkPacket::write_int16 (int16_t val) {
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
   102
    write_val<int16_t>(htons(val));
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
   103
}
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
   104
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
   105
void NetworkPacket::write_int8 (int8_t val) {
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
   106
    write_val<int8_t>(val);
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
   107
}
36
terom
parents: 33
diff changeset
   108
        
37
ed2957490bbf compile step complete
terom
parents: 36
diff changeset
   109
void NetworkPacket::write_float32 (float val) {
ed2957490bbf compile step complete
terom
parents: 36
diff changeset
   110
    write_uint32((uint32_t) val);
36
terom
parents: 33
diff changeset
   111
}
31
d0d7489d4e8b add initial code written so far
terom
parents:
diff changeset
   112
36
terom
parents: 33
diff changeset
   113
void NetworkPacket::write_vector (const Vector &vec) {
terom
parents: 33
diff changeset
   114
    write_float32(vec.x);
terom
parents: 33
diff changeset
   115
    write_float32(vec.y);
terom
parents: 33
diff changeset
   116
}
terom
parents: 33
diff changeset
   117
terom
parents: 33
diff changeset
   118
void NetworkPacket::write_packet (const NetworkPacket &pkt) {
33
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
   119
    // check buffer size
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
   120
    check_write_size(pkt.get_data_size());
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
   121
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
   122
    // copy
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
   123
    memcpy(buf + offset, pkt.get_buf(), pkt.get_data_size());
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
   124
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
   125
    // update offset/data_size
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
   126
    offset += pkt.get_data_size();
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
   127
    data_size += pkt.get_data_size();
e53f09b378f4 more untested, uncompiled code
terom
parents: 32
diff changeset
   128
}
36
terom
parents: 33
diff changeset
   129