<html>
<head>
<!-- Template generated by Exclaimer Mail Disclaimers on 08:43:48 Tuesday, 10 June 2014 -->
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<style type="text/css">P.ae431132-9d17-4a38-b6b5-634369783623 {
MARGIN: 0cm 0cm 0pt
}
LI.ae431132-9d17-4a38-b6b5-634369783623 {
MARGIN: 0cm 0cm 0pt
}
DIV.ae431132-9d17-4a38-b6b5-634369783623 {
MARGIN: 0cm 0cm 0pt
}
TABLE.ae431132-9d17-4a38-b6b5-634369783623Table {
MARGIN: 0cm 0cm 0pt
}
DIV.Section1 {
page: Section1
}
</style>
</head>
<body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;">
<p class="ae431132-9d17-4a38-b6b5-634369783623"></p>
<div id="bloop_customfont">I met Matthias a few weeks ago at PHP day in Verona and he
<i>really</i> knows his stuff. I don’t think his work experience is relevance - just the clarity and applicability of his ideas. FWIW, he works closely with the folks at Inviqa, who are creating some of the best OSS in the PHP community. Like me, they value
his opinion because it’s well-founded and generally applicable to any kind of software. Same goes with all the attendees who listen to his talks.</div>
<div id="bloop_customfont"><br>
</div>
<div id="bloop_customfont">I don’t understand the “well nobody else is using it” argument. We should examine the merits of this proposal based on whether we deem it a good design choice, not by looking over our shoulders. </div>
<div id="bloop_customfont"><br>
</div>
<div id="bloop_customfont">We are not constricting users here. There are better ways to allow extendability that work much better than inheritance</div>
<div id="bloop_sign_1402385806066617856" class="bloop_sign"></div>
<div><br>
</div>
<div><br>
</div>
<br>
<p style="color:#000;">On June 10, 2014 at 9:34:38 AM, Choi, Sam (<a href="mailto:sam.choi@hp.com">sam.choi@hp.com</a>) wrote:</p>
<blockquote type="cite" class="clean_bq"><span>
<div>
<div></div>
<div>Regarding use of the final keyword and limiting extending in general, a few thoughts below:
<br>
<br>
- While I found the blog post about final classes to be informative, I'd take it with a grain of salt. The author bills himself as a consultant who works with enterprise web applications. Briefly looking at his background, practically all his gigs were short
consulting jobs. I don't see a track record for open source projects so it would appear that his views are likely more applicable for enterprise developers working within closed systems.
<br>
- The Java community has already beaten this subject to death over the past decade. During recent years, it seems that the debate has waned. I occasionally see enterprise Java devs use final to communicate their intent so that their system isn't butchered many
years down the road when it becomes poorly understood legacy code. <br>
- On the other hand, I hardly ever see final classes in open source code/APIs. <br>
- Regarding future-proofing, I agree that it's easier to switch from final to not using final than the other way around. However, I've actually had cases where I needed to extend a final class in an API and was simply annoyed by the author's desire to control
how I use the API. I also understood that if the author were to change certain things, my extension may have to be refactored. That's a risk I'm certainly willing to take to get the job done.
<br>
<br>
Thanks, <br>
-- <br>
Sam Choi <br>
Hewlett-Packard Co. <br>
HP Cloud Services <br>
+1 650 316 1652 / Office <br>
<br>
<br>
</div>
</div>
</span></blockquote>
<p></p>
<p class="ae431132-9d17-4a38-b6b5-634369783623"> </p>
<p class="ae431132-9d17-4a38-b6b5-634369783623">
<table border="0" cellpadding="0" width="504">
<tbody>
<tr>
<td style="WIDTH: 270px" class="LEFT_ALIGNED"><span style="font-family:Verdana; font-size:small; ">Jamie Hannaford</span><br>
<span style="font-family:Verdana; font-size:x-small; ">Software Developer III - CH</span></td>
<td style="WIDTH: 281px"><img alt="experience Fanatical Support" align="right" src="cid:image27b7b9.JPG@45433388.4e9bc6d1" width="159" height="17"></td>
</tr>
<tr class="LEFT_ALIGNED">
<td colspan="2"><img alt="LINE" src="cid:imagec7d6ad.JPG@0fb781a3.4d99b3da" width="504" height="4"></td>
</tr>
<tr>
<td class="CONTACTINFO"><span style="font-family:Calibri; ">
<table class="ae431132-9d17-4a38-b6b5-634369783623Table">
<tbody>
<tr>
<td><span style="font-family:Verdana; font-size:x-small; ">Tel: </span></td>
<td><span style="font-family:Verdana; font-size:x-small; ">+41434303908</span></td>
</tr>
<tr>
<td><span style="font-family:Verdana; font-size:x-small; ">Mob: </span></td>
<td><span style="font-family:Verdana; font-size:x-small; ">+41791009767</span></td>
</tr>
</tbody>
</table>
</span></td>
<td class="RIGHT_ALIGNED"><img alt="Rackspace" src="cid:image60dd16.JPG@56dec61d.44bf8c6c" width="280" height="60"></td>
</tr>
<tr class="LEFT_ALIGNED">
<td class="CONTACTINFO" colspan="2"><img src="cid:image76adab.JPG@fa081716.479e8a71" width="504" height="3"></td>
</tr>
</tbody>
</table>
</p>
<p class="ae431132-9d17-4a38-b6b5-634369783623"> </p>
<p class="ae431132-9d17-4a38-b6b5-634369783623"></p>
<blockquote type="cite" class="clean_bq"><span>
<div>
<div>-----Original Message----- <br>
From: Matthew Farina [mailto:matt@mattfarina.com] <br>
Sent: Monday, June 09, 2014 7:09 AM <br>
To: Jamie Hannaford <br>
Cc: Shaunak Kashyap; Glen Campbell; OpenStack Development Mailing List (not for usage questions); Choi, Sam; Farina, Matt
<br>
Subject: Re: [openstack-sdk-php] Use of final and private keywords to limit extending
<br>
<br>
If you don't mind I'd like to step back for a moment and talk about the end users of this codebase and the types code it will be used in.
<br>
<br>
We're looking to make application developers successful in PHP. The top 10% of PHP application developers aren't an issue. If they have an SDK or not they will build amazing things. It's the long tail of app devs. Many of these developers don't know things
we might take for granted, like dependency injection. A lot of them may writing spaghetti procedural code. I use these examples because I've run into them in the past couple months. We need to make these folks successful in a cost effective and low barrier
to entry manner. <br>
<br>
When I've gotten into the world of closed source PHP (or any other language for that matter) and work that's not in the popular space I've seen many things that aren't clean or pretty. But, they work.
<br>
<br>
That means this SDK needs to be useful in the modern frameworks (which vary widely on opinions) and in environments we may not like.
<br>
<br>
The other thing I'd like to talk about is the protected keyword. I use this a lot. Using protected means an outside caller can't access the method. Only other methods on the class or classes that extend it.
<br>
This is an easy way to have an API and internals. <br>
<br>
Private is different. Private means it's part of the class but not there for extended classes. It's not just about controlling the public API for callers but not letting classes that extend this one have access to the functionality.
<br>
<br>
Given the scope of who our users are... <br>
<br>
- Any place we use the `final` scoping we need to explain how to extend it properly. It's a teaching moment for someone who might not come to a direction on what to do very quickly. Think about the long tail of developers and projects, most of which are not
open source. <br>
<br>
Note, I said I'm not opposed to using final. It's an intentional decision. For the kinds of things we're doing I can't see all to many use cases for using final. We need to enable users to be successful without controlling how they write applications because
this is an add-on to help them not a driver for their architecture. <br>
<br>
- For scoping private and public APIs, `protected` is a better keyword unless we are intending on blocking extension. If we block extension we should explain how to handled overriding things that are likely to happen in real world applications that are not
ideally written or architected. <br>
<br>
At the end of the day, applications that successfully do what they need to do while using OpenStack on the backend is what will make OpenStack more successful. We need to help make it easy for the developers, no matter how they choose to code, to be successful.
I find it useful to focus on end users and their practical cases over the theory of how to design something.
<br>
<br>
Thoughts, <br>
Matt <br>
<br>
<br>
On Fri, Jun 6, 2014 at 10:01 AM, Jamie Hannaford <jamie.hannaford@rackspace.com> wrote:
<br>
> So this is an issue that’s been heavily discussed recently in the PHP <br>
> community. <br>
> <br>
> Based on personal opinion, I heavily favor and use private properties <br>
> in software I write. I haven’t, however, used the “final” keyword that much. <br>
> But the more I read about and see it being used, the more inclined I <br>
> am to use it in projects. Here’s a great overview of why it’s useful <br>
> for public <br>
> APIs: http://verraes.net/2014/05/final-classes-in-php/ <br>
> <br>
> Here’s a tl;dr executive summary: <br>
> <br>
> - Open/Closed principle. It’s important to understand that “Open for <br>
> extension”, does not mean “Open for inheritance”. Composition, <br>
> strategies, callbacks, plugins, event listeners, … are all valid ways <br>
> to extend without inheritance. And usually, they are much preferred to <br>
> inheritance – hence the conventional recommendation in OOP to “favour composition over inheritance”.
<br>
> Inheritance creates more coupling, that can be hard to get rid of, and <br>
> that can make understanding the code quite tough. <br>
> <br>
> - Providing an API is a responsibility: by allowing end-users to <br>
> access features of our SDK, we need to give certain guarantees of <br>
> stability or low change frequency. The behavior of classes should be <br>
> deterministic - i.e. we should be able to trust that a class does a <br>
> certain thing. There’s no trust whatsoever if that behavior can be edited and overridden from external code.
<br>
> <br>
> - Future-proofing: the fewer behaviours and extension points we <br>
> expose, the more freedom we have to change system internals. This is <br>
> the idea behind encapsulation. <br>
> <br>
> You said that we should only use private and final keywords if there’s <br>
> an overwhelming reason to do so. I completely disagree. I actually <br>
> want to flip the proposition here: I think we should only use public <br>
> keywords if we’re CERTAIN we want to encourage and allow the <br>
> inheritance of that class. By making a class inheritable, you are <br>
> saying to the outside world: this class is meant to be extended. And the majority of times this is not what we want.
<br>
> Sure there are times when inheritance may well be the best option - <br>
> but you can support extension points in different, often better, ways. <br>
> Declaring explicitly what the extension points are is part of the <br>
> contract your code has with the rest of the system. Final classes help <br>
> to enforce this contract. <br>
> <br>
> To summarize, we have nothing to lose by favoring private and final <br>
> keywords. We gain the above advantages, and if we later decide to open <br>
> up that class as an extension point we can remove the keywords without <br>
> any issues. Should a valid reason come up to open it up, it will be <br>
> easy to do so, because nothing depends on it being closed. On the <br>
> other hand, if you start by making everything open or inheritable, it <br>
> will be very hard to close it later. <br>
> <br>
> Jamie <br>
> <br>
> On June 5, 2014 at 6:24:52 PM, Matthew Farina (matt@mattfarina.com) wrote: <br>
> <br>
> Some recent reviews have started to include the use of the private <br>
> keyword for methods and talk of using final on classes. I don't think <br>
> we have consistent agreement on how we should do this. <br>
> <br>
> My take is that we should not use private or final unless we can <br>
> articulate the design decision to intentionally do so. <br>
> <br>
> To limit public the public API for a class we can use protected. <br>
> Moving from protected to private or the use of final should have a <br>
> good reason. <br>
> <br>
> In open source software code is extended in ways we often don't think <br>
> of up front. Using private and final limits how those things can <br>
> happen. When we use them we are intentionally limiting extending so we <br>
> should be able to articulate why we want to put that limitation in <br>
> place. <br>
> <br>
> Given the reviews that have been put forth I think there is a <br>
> different stance. If there is one please share it. <br>
> <br>
> - Matt <br>
> <br>
> <br>
> <br>
> Jamie Hannaford <br>
> Software Developer III - CH <br>
> Tel: +41434303908 <br>
> Mob: +41791009767 <br>
> <br>
> <br>
> <br>
> Rackspace International GmbH a company registered in the Canton of <br>
> Zurich, Switzerland (company identification number CH-020.4.047.077-1) <br>
> whose registered office is at Pfingstweidstrasse 60, 8005 Zurich, Switzerland. <br>
> Rackspace International GmbH privacy policy can be viewed at <br>
> www.rackspace.co.uk/legal/swiss-privacy-policy <br>
> - <br>
> Rackspace Hosting Australia PTY LTD a company registered in the state <br>
> of Victoria, Australia (company registered number ACN 153 275 524) <br>
> whose registered office is at Suite 3, Level 7, 210 George Street, <br>
> Sydney, NSW 2000, Australia. Rackspace Hosting Australia PTY LTD <br>
> privacy policy can be viewed at <br>
> www.rackspace.com.au/company/legal-privacy-statement.php <br>
> - <br>
> Rackspace US, Inc, 5000 Walzem Road, San Antonio, Texas 78218, United <br>
> States of America Rackspace US, Inc privacy policy can be viewed at <br>
> www.rackspace.com/information/legal/privacystatement <br>
> - <br>
> Rackspace Limited is a company registered in England & Wales (company <br>
> registered number 03897010) whose registered office is at 5 Millington <br>
> Road, Hyde Park Hayes, Middlesex UB3 4AZ. <br>
> Rackspace Limited privacy policy can be viewed at <br>
> www.rackspace.co.uk/legal/privacy-policy <br>
> - <br>
> Rackspace Benelux B.V. is a company registered in the Netherlands <br>
> (company KvK nummer 34276327) whose registered office is at <br>
> Teleportboulevard 110, <br>
> 1043 EJ Amsterdam. <br>
> Rackspace Benelux B.V privacy policy can be viewed at <br>
> www.rackspace.nl/juridisch/privacy-policy <br>
> - <br>
> Rackspace Asia Limited is a company registered in Hong Kong (Company no: <br>
> 1211294) whose registered office is at 9/F, Cambridge House, Taikoo <br>
> Place, <br>
> 979 King's Road, Quarry Bay, Hong Kong. <br>
> Rackspace Asia Limited privacy policy can be viewed at <br>
> www.rackspace.com.hk/company/legal-privacy-statement.php <br>
> - <br>
> This e-mail message (including any attachments or embedded documents) <br>
> is intended for the exclusive and confidential use of the individual <br>
> or entity to which this message is addressed, and unless otherwise <br>
> expressly indicated, is confidential and privileged information of <br>
> Rackspace. Any dissemination, distribution or copying of the enclosed <br>
> material is prohibited. If you receive this transmission in error, <br>
> please notify us immediately by e-mail at abuse@rackspace.com and <br>
> delete the original message. Your cooperation is appreciated. <br>
</div>
</div>
</span></blockquote>
<p></p>
<span style="font-size: 11px;">Rackspace International GmbH a company registered in the Canton of Zurich, Switzerland (company identification number CH-020.4.047.077-1) whose registered office is at Pfingstweidstrasse 60, 8005 Zurich, Switzerland. Rackspace International GmbH privacy policy can be viewed at www.rackspace.co.uk/legal/swiss-privacy-policy<br>-<br>Rackspace Hosting Australia PTY LTD a company registered in the state of Victoria, Australia (company registered number ACN 153 275 524) whose registered office is at Suite 3, Level 7, 210 George Street, Sydney, NSW 2000, Australia. Rackspace Hosting Australia PTY LTD privacy policy can be viewed at www.rackspace.com.au/company/legal-privacy-statement.php<br>-<span style="font-size: 11px;"></span><br>Rackspace US, Inc, 5000 Walzem Road, San Antonio, Texas 78218, United States of America</span><br><span style="font-size: 11px;">Rackspace US, Inc privacy policy can be viewed at www.rackspace.com/information/legal/privacystatement</span><br><span style="font-size: 11px;">-</span><br><span style="font-size: 11px;">Rackspace Limited is a company registered in England & Wales (company registered number 03897010) whose registered office is at 5 Millington Road, Hyde Park Hayes, Middlesex UB3 4AZ.</span><br><span style="font-size: 11px;">Rackspace Limited privacy policy can be viewed at www.rackspace.co.uk/legal/privacy-policy</span><br><span style="font-size: 11px;">-</span><br><span style="font-size: 11px;">Rackspace Benelux B.V. is a company registered in the Netherlands (company KvK nummer 34276327) whose registered office is at Teleportboulevard 110, 1043 EJ Amsterdam.</span><br><span style="font-size: 11px;">Rackspace Benelux B.V privacy policy can be viewed at www.rackspace.nl/juridisch/privacy-policy</span><br><span style="font-size: 11px;">-</span><br><span style="font-size: 11px;">Rackspace Asia Limited is a company registered in Hong Kong (Company no: 1211294) whose registered office is at 9/F, Cambridge House, Taikoo Place, 979 King's Road, Quarry Bay, Hong Kong.</span><br><span style="font-size: 11px;">Rackspace Asia Limited privacy policy can be viewed at www.rackspace.com.hk/company/legal-privacy-statement.php</span><br><span style="font-size: 11px;">-</span><br><span style="font-size: 11px;">This e-mail message (including any attachments or embedded documents) is intended for the exclusive and confidential use of the individual or entity to which this message is addressed, and unless otherwise expressly indicated, is confidential and privileged information of Rackspace. Any dissemination, distribution or copying of the enclosed material is prohibited. If you receive this transmission in error, please notify us immediately by e-mail at abuse@rackspace.com and delete the original message. Your cooperation is appreciated.</span></body>
</html>