I will look at this in more detail later, but hold off on committing until i have a chance to run it on Windows <br><div class="gmail_quote"><div dir="ltr">On Thu, May 12, 2016 at 8:05 AM Todd Fiala <<a href="mailto:todd.fiala@gmail.com">todd.fiala@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">tfiala added inline comments.<br>
<br>
================<br>
Comment at: packages/Python/lldbsuite/test_event/formatter/pickled.py:57<br>
@@ +56,3 @@<br>
+ # end.<br>
+ if self.use_send:<br>
+ # Send it as {serialized_length_of_serialized_bytes}{serialized_bytes}<br>
----------------<br>
tfiala wrote:<br>
> labath wrote:<br>
> > Why do we need the format to be different based on the kind of object we are writing to? The added magic (introspection) seems like a bad tradeoff, if all it does is avoid a couple of lines in `event_collector.py`<br>
> When we're using sockets, we have to be able to know the size of the full info when reconstructing on the receiving side. This is the normal mode in which this is used. However, that also complicates the parsing of the data for the simple test driver.<br>
><br>
> The code later on in the test_event unit tests:<br>
><br>
> ```<br>
> if os.path.exists(pickled_events_filename()):<br>
> with open(pickled_events_filename(), "rb") as events_file:<br>
> while True:<br>
> try:<br>
> # print("reading event")<br>
> event = cPickle.load(events_file)<br>
> # print("read event: {}".format(event))<br>
> if event:<br>
> events.append(event)<br>
> except EOFError:<br>
> # This is okay.<br>
> Break<br>
> ```<br>
><br>
> Would get considerably more complicated to deal with the same format that is only required for going over a network-style protocol. I prefer this tradeoff. In the unit tests, I just send the event output to a file, and then read it with the simple loop I included above.<br>
><br>
> However, to verify that I really prefer it, I will try writing it the other way.<br>
> However, to verify that I really prefer it, I will try writing it the other way.<br>
<br>
The flip side is I can try to factor out the listener side logic that reconstructs these. However, that is currently rather tightly coupled to the network listening transport. And most of the work it does has purely to do with needing to receive the whole message before it can try to un-pickle it. So I'm not really seeing that as a big win. (Except for testability. So maybe it's okay to break that out.) I'll see what that looks like since that is probably the better high-level way to handle this if we didn't want the change I made to the sender side.<br>
<br>
<br>
<a href="http://reviews.llvm.org/D20193" rel="noreferrer" target="_blank">http://reviews.llvm.org/D20193</a><br>
<br>
<br>
<br>
</blockquote></div>