<html><head></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; ">Makes sense.<div><br></div><div>Applied:</div><div><br></div><div><a href="http://llvm.org/viewvc/llvm-project?view=rev&revision=113799">http://llvm.org/viewvc/llvm-project?view=rev&revision=113799</a></div><div><br><div><div>On Sep 13, 2010, at 2:38 PM, Marcin Świderski wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div class="gmail_quote">W dniu 13 września 2010 23:17 użytkownik Ted Kremenek <span dir="ltr"><<a href="mailto:kremenek@apple.com">kremenek@apple.com</a>></span> napisał:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
Hi Marcin,<br>
<br>
If you think you will need to be using insert(), I'm dubious that a vector is the right data structure.  Doing inserts repeatedly might wreck havoc on CFG construction time.  What do you think?<br>
<div><div></div><div class="h5"><br>
On Sep 13, 2010, at 12:51 PM, Marcin Świderski wrote:<br>
<br>
> Hi<br>
><br>
> This is an implementation of insert method for BumpVector that is needed in my work on CFG.<br>
><br>
> Cheers,<br>
> Marcin<br>
</div></div>> <bump-vector-insert.patch><br>
<br>
</blockquote></div>I use insert for adding CFGElements for implicit destructors. The procedure is as follows:<div> - count objects for destruction (time linear w.r.t. depth of local scopes),</div><div> - make room for those objects with batch insert of empty CFGElements,</div>
<div> - set proper values of destructors for inserted CFGElements.</div><div><br></div><div>This will cause data moving inside the vector only while back patching for goto statements. In other cases this will only append data at the end of vector, and can be optimized if will cause too much overhead. Currently I would prefere to leave it this way.</div>
</blockquote></div><br></div></body></html>