I prefer my approach. It's simple yet effective. Sure, you dont have a structure to hold you data nice and warm, but it's simple enough.<br><br>One note to you guys, just in case: Considering a game might have a <b>lot</b> of packets, split the packets by group, with a file per group, or more if needed.<br>
E.g., my game is very incomplete and i already have about 20 packets and my ProcessPacket function already has over 2k lines of code. What i will do soon is split the packet by groups (client validation, login, etc), with a file for each group, with a function to process each group. That way my ProcessPacket function will only have to do some basic if comparisons to the ID it gets and run the function appropriate for that ID.<br>
<br><div class="gmail_quote">On Sun, Jan 17, 2010 at 8:25 PM, Alex Milstead <span dir="ltr"><<a href="mailto:alex.milstead@gatech.edu">alex.milstead@gatech.edu</a>></span> wrote:<br><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
I'd kicked around the idea of using some sort of required "cmd" field as the first field in the struct being sent, my only concern is what happens to the rest of the "trash" data after first memcpy. E.g., StructA and StructB, StructB is bigger than StructA, both have the first field as a "char cmd", but the rest of the data causes the structs to not be the same size. If I send a StructB but memcpy the incoming binary data into a StructA to check the command type, is it safe to then re-memcpy this incoming data back into a StructB once I've figured out the command type? Or is there weird memory stuff that happens (I would assume not as the incoming data will always be the same, we can copy that to whomever we wish at will)?<br>
<br>
Also, a packet class wrapper sounds like a great idea! Thanks for the suggestions.<div><div></div><div class="h5"><br>
<br>
On 1/17/2010 3:06 PM, Ruud van Gaal wrote:<br>
<blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
I use a packet class where I can just add bytes& shorts& ints (and<br>
strings) to a packet. So you just:<br>
<br>
enum Cmd<br>
{<br>
CMD_CAR_UPDATE,<br>
CMD_CHAT,<br>
...<br>
};<br>
<br>
pkt=new Packet();<br>
pkt->AddChar(CMD_CAR_UPDATE);<br>
pkt->AddFloat(carX);<br>
...<br>
<br>
and later at the receiving end:<br>
<br>
cmd=pkt->GetChar();<br>
if(cmd==...){ ... }<br>
<br>
Although a struct where all things start with 'char cmd' can also do nicely.<br>
Learn more about pointers and dereferencing them in C/C++.<br>
<br>
Cheers,<br>
Ruud<br>
<br>
<br>
<br>
<blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
-----Oorspronkelijk bericht-----<br>
Van: <a href="mailto:enet-discuss-bounces@cubik.org" target="_blank">enet-discuss-bounces@cubik.org</a><br>
[mailto:<a href="mailto:enet-discuss-bounces@cubik.org" target="_blank">enet-discuss-bounces@cubik.org</a>] Namens Alex Milstead<br>
Verzonden: Sunday, January 17, 2010 20:54<br>
Aan: Discussion of the ENet library<br>
Onderwerp: Re: [ENet-discuss] A query about channels<br>
<br>
In that case, is there a solid way to extract that<br>
identifier? Or will I need to do some I'm aware of sprintf<br>
calls, is it common practice to simply "sprintf" the first<br>
integer of the received binary data into a buffer and<br>
(effectively) switch-case on that buffer, then memcpy the<br>
remaining data that follows? Or is there a better way of doing this?<br>
<br>
Cheers,<br>
Alex<br>
<br>
On Jan 17, 2010, at 2:39 PM, Thorbjørn Lindeijer<br>
<<a href="mailto:bjorn@lindeijer.nl" target="_blank">bjorn@lindeijer.nl</a>><br>
wrote:<br>
<br>
<br>
<blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
On Sun, Jan 17, 2010 at 19:50, Alex Milstead<br>
<<a href="mailto:alex.milstead@gatech.edu" target="_blank">alex.milstead@gatech.edu</a>> wrote:<br>
<br>
<blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
Also, Jay you mentioned earlier that it was easy to do<br>
<br>
</blockquote></blockquote>
simple data-<br>
<br>
<blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;"><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
type<br>
checking on the receiving end. I'm a bit of a fledgling network<br>
programmer<br>
-- I'm still definitely becoming more acquainted the vast amount of<br>
unfamiliar programming techniques in this particular<br>
<br>
</blockquote></blockquote>
arena. The only<br>
<br>
<blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;"><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
surefire type-checking system I know about in programming is in<br>
java (=/),<br>
with it's "instanceof" operator. As far as I know this type of<br>
mechanism, or<br>
anything similar, doesn't really exist in C/C++. So my next<br>
question is, if<br>
we're sending binary data along and receiving it as binary data,<br>
what's the<br>
most efficient way of type-checking the probable struct<br>
<br>
</blockquote></blockquote>
being piped<br>
<br>
<blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;"><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
through?<br>
<br>
</blockquote>
You give it a number which designates its type. You'd<br>
<br>
</blockquote>
usually prepend<br>
<br>
<blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
such a number to each of your messages, so that you know how to<br>
interpret them on the other end.<br>
<br>
Regards,<br>
Bjørn<br>
_______________________________________________<br>
ENet-discuss mailing list<br>
<a href="mailto:ENet-discuss@cubik.org" target="_blank">ENet-discuss@cubik.org</a><br>
<a href="http://lists.cubik.org/mailman/listinfo/enet-discuss" target="_blank">http://lists.cubik.org/mailman/listinfo/enet-discuss</a><br>
<br>
</blockquote>
_______________________________________________<br>
ENet-discuss mailing list<br>
<a href="mailto:ENet-discuss@cubik.org" target="_blank">ENet-discuss@cubik.org</a><br>
<a href="http://lists.cubik.org/mailman/listinfo/enet-discuss" target="_blank">http://lists.cubik.org/mailman/listinfo/enet-discuss</a><br>
<br>
<br>
</blockquote>
_______________________________________________<br>
ENet-discuss mailing list<br>
<a href="mailto:ENet-discuss@cubik.org" target="_blank">ENet-discuss@cubik.org</a><br>
<a href="http://lists.cubik.org/mailman/listinfo/enet-discuss" target="_blank">http://lists.cubik.org/mailman/listinfo/enet-discuss</a><br>
<br>
</blockquote>
<br>
_______________________________________________<br>
ENet-discuss mailing list<br>
<a href="mailto:ENet-discuss@cubik.org" target="_blank">ENet-discuss@cubik.org</a><br>
<a href="http://lists.cubik.org/mailman/listinfo/enet-discuss" target="_blank">http://lists.cubik.org/mailman/listinfo/enet-discuss</a><br>
</div></div></blockquote></div><br>