<html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"></head><body dir="auto"><div><span></span></div><div><meta http-equiv="content-type" content="text/html; charset=utf-8"><div>On Mar 5, 2014, at 11:32 AM, Chris Lattner <<a href="mailto:sabre@nondot.org">sabre@nondot.org</a>> wrote:</div><div><br></div><div><span></span></div><blockquote type="cite"><div><meta http-equiv="Content-Type" content="text/html charset=us-ascii"><br><div><div>On Mar 4, 2014, at 6:14 PM, Chandler Carruth <<a href="mailto:chandlerc@google.com">chandlerc@google.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div dir="ltr"><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Mar 4, 2014 at 6:06 PM, Richard Smith <span dir="ltr"><<a href="mailto:richard@metafoo.co.uk" target="_blank">richard@metafoo.co.uk</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">This rule does not seem to be widely followed by Clang today. Looking at Parser and Sema, many getters (0 argument functions with names matching /^get[A-Z]/) return mutable references to long-lived objects. Looking through Decl.h, things are a little different: we rarely return references, but do frequently return pointers that provide mutable access to contained objects.</blockquote>
</div><br>Yea, but I *significantly* prefer the rules I describe. =]</div></div></blockquote><div><br></div><div>I don't think your rules are feasible.</div><br><blockquote type="cite"><div dir="ltr"><div class="gmail_extra">The latter case is the one that is hard to write rules around. Sometimes, you are notionally getting a reference or a pointer, and the mutability is irrelevant. Other times, the reference or pointer present should not be exposed through a getter.</div>
</div>
</blockquote></div><br><div>This is a nice blue sky ideal, and if efficiency didn't matter perhaps it would work.  However, efficiency does matter, and our apis have all sorts of "give me access to internal bits" APIs for a reason.  If you really want to provide value semantics, you actually have to do a deep copy of anything returned, at which point this whole thing becomes immediately unworkable.  For example, we can't have Instruction::getOperand() or Instruction::getParent() return something with true value semantics.</div></div></blockquote><div><br></div><div>FWIW, over in ObjC land we’re used to -get… returning an interior pointer, and -copy… returning a copy.</div><div><br></div><div>As someone who is trying to learn the codebase by writing code against it (and admittedly wielding the dual weapons of an AppKit bias and very little C++ experience), I'd be happy to see get() methods return an interior pointer, copy() methods return a deep copy, and unprefixed methods return an object with value semantics (including iterators and the like).</div><div><br></div><div>I’m sure there’s a much better term for this than I’m aware of, but I feel more comfortable using a prefix like ‘get’ to imply the caller retains “semantic ownership”. One might argue that methods which act like member access should resemble mirror direct member access, but I think prefixing with ‘get’ acts explicitly states intent on the part of the class author. </div><div><br></div><div>--Kyle Sluder</div></div></body></html>