forked from hoaproject/Blog
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add a new article about naming convention.
This article explain what was discussed in the RFC : hoaproject/Central#54
- Loading branch information
Showing
1 changed file
with
111 additions
and
0 deletions.
There are no files selected for viewing
111 changes: 111 additions & 0 deletions
111
Source/Posts/2017/07-Introduce-data-conversion-naming.xyl
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,111 @@ | ||
<?xml version="1.0" encoding="utf-8"?> | ||
<?xyl-overlay href="hoa://Application/Overlays/Article.xyl"?> | ||
<?xyl-meta name="title" value="Introduce data conversion naming"?> | ||
<?xyl-meta name="date" value="2017-07-01T07:54:50+02:00"?> | ||
|
||
<overlay xmlns="http://hoa-project.net/xyl/xylophone"> | ||
<article id="main"> | ||
<p> | ||
For 2017, we <a href="http://discourse.hoa-project.net/t/roadmap-to-2017-a-draft/235">defined | ||
a roadmap</a> composed of Request For Comments (RFC) that are discussed | ||
and implemented. One of these RFC is about | ||
<a href="https://github.com/hoaproject/Central/issues/54">naming convention | ||
and simplification</a> inspired by the <a href="https://aturon.github.io/style/naming.html">Rust | ||
coding convention</a>. | ||
</p> | ||
<p> | ||
So far, we use this formalism: <code>getFoo</code> to name a method | ||
that returns the value <code>foo</code>. This can be a direct attribute, or a | ||
computation. To get this data within another form, i.e. to convert this | ||
data into another type, we don't have any formalism yet. For instance, | ||
if <code>foo</code> is an array, and we would like to get it as a string, | ||
we will probably name a method like <code>getFooAsString</code> but this | ||
is not deterministic. | ||
</p> | ||
<h2>Property access</h2> | ||
<p> | ||
Initially we decided to remove the <code>get</code> prefix from getter | ||
methods because it's not mandatory to understand the code. Also in many | ||
languages this prefix has been dropped/is not present so we can ask if it's | ||
still relevant. | ||
</p> | ||
<p> | ||
After receiving some <a href="https://github.com/hoaproject/Central/issues/54#issuecomment-281268963">community | ||
feedbacks</a> it seems that this prefix is too present in the PHP world. | ||
Removing it will make the code harder to understand for most PHP developers. | ||
</p> | ||
<p> | ||
We don't want to hurt Hoa projects adoption so we prefer | ||
staying with the <code>get</code> prefix at the moment. | ||
</p> | ||
<h2>Conversions</h2> | ||
<p> | ||
A conversion have a computing cost. Some of them can be expensive, so the | ||
method prefix must be clear enough to know operation cost directly by | ||
reading the code. | ||
</p> | ||
<p> | ||
We have decided to introduce 3 method prefixes: | ||
</p> | ||
<table> | ||
<thead> | ||
<tr> | ||
<th>Prefix</th> | ||
<th>Cost</th> | ||
<th>Consumes convertee</th> | ||
</tr> | ||
</thead> | ||
<tbody> | ||
<tr> | ||
<td><code>as</code></td> | ||
<td>Free</td> | ||
<td>No</td> | ||
</tr> | ||
<tr> | ||
<td><code>to</code></td> | ||
<td>Expensive</td> | ||
<td>No</td> | ||
</tr> | ||
<tr> | ||
<td><code>into</code></td> | ||
<td>Variable</td> | ||
<td>Probably</td> | ||
</tr> | ||
</tbody> | ||
</table> | ||
<p> | ||
Example: | ||
</p> | ||
<ul> | ||
<li> | ||
Let's <code>$x</code> be a float. <code>asInteger()</code> will be | ||
(almost) free. | ||
</li> | ||
<li> | ||
Let's <code>$x</code> be an array. <code>toString()</code> will be | ||
expensive because we have to iterate over the array, to allocate a | ||
string, and to convert every pairs in the array as a string (like a | ||
serializer). | ||
</li> | ||
<li> | ||
Let's <code>$x</code> be an object. <code>intoArray()</code> will not be | ||
that expensive, it might reference all attributes into an array, so | ||
that's just one allocation. | ||
</li> | ||
</ul> | ||
<p> | ||
Conversions prefixed <code>as</code> and <code>into</code> typically | ||
decrease abstraction, either exposing a view into the underlying | ||
representation (<code>as</code>) or deconstructing data into its | ||
underlying representation (<code>into</code>). Conversions prefixed | ||
<code>to</code>, on the other hand, typically stay at the same level of | ||
abstraction, but do some work to change one representation into another. | ||
</p> | ||
<p> | ||
This is not something we will use often, but it is important to have a | ||
strict naming here. Based on this naming, the user will be able to choose | ||
if the resulting data must be cached or not (for instance, all <code>to</code> | ||
conversions are likely to be cached because they might be expensive). | ||
</p> | ||
</article> | ||
</overlay> |