The main user of the c_str() is printf calls. It's in the commit message :)<br><div class="gmail_quote"><div dir="ltr">On Sat, Nov 19, 2016 at 7:14 AM Pavel Labath <<a href="mailto:labath@google.com">labath@google.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">labath added a comment.<br class="gmail_msg">
<br class="gmail_msg">
> Assuming we do that, what interface do you think would be simpler? We still<br class="gmail_msg">
> need easy access to both a StringRef and a c_str(), since StringRef::data<br class="gmail_msg">
> is not guaranteed to be null terminated, so the entry thing is still nice.<br class="gmail_msg">
<br class="gmail_msg">
I was assuming (possibly incorrectly, I did not look at that code much) that the main user of the null-terminated string version was execve(2), which needs an entire list of strings, not just a single item, in which case we could have the iteration simply be over StringRefs. That said, it probably does not matter now, as judging by your comments, you're looking for incremental changes, not one grand final design (btw, I didn't mean to suggest that this should all be done in one patch). In that case, this looks fine as far as I am concerned. We can always revise this later, and it doesn't look like it will require any major rewrite, just a bit of syntax-twiddling. You can then read my comments as "the direction I would like to move us in".<br class="gmail_msg">
<br class="gmail_msg">
> One idea might be to have the entry contain 2 StringRefs. `str` and<br class="gmail_msg">
> `quoted_str`. This way you never get access to the underlying quote char,<br class="gmail_msg">
> just the full arg, either quoted or unquoted (although doing this would<br class="gmail_msg">
> still be better done orthogonally to this patch)<br class="gmail_msg">
<br class="gmail_msg">
I don't think this is a good idea, as I don't see a need to be able to access the original quoted string this way. Also, when you construct the args vector programmatically, you would have to invent a quoted representation without knowing if it will ever be used. I'd prefer to have a standalone quote function instead, as then it can be used in other contexts as well (separate algorithms from data).<br class="gmail_msg">
<br class="gmail_msg">
<br class="gmail_msg">
<a href="https://reviews.llvm.org/D26883" rel="noreferrer" class="gmail_msg" target="_blank">https://reviews.llvm.org/D26883</a><br class="gmail_msg">
<br class="gmail_msg">
<br class="gmail_msg">
<br class="gmail_msg">
</blockquote></div>