QML style guide

Aaron J. Seigo aseigo at kde.org
Mon Oct 29 20:42:18 UTC 2012


hi..

we have a style guide for our C++ code: the kdelibs style, which was mostly 
borrowed from Qt. unfortunately for us there was no QML guide we could 
similarly abscond with.

and it shows.

summary -> i've started putting together a QML style guide draft and would 
like your input and to bring it completion in a collaboration with all of you 
who are writing QML for Plasma. to that end, i've started a wiki page here:

	http://community.kde.org/Plasma/QMLStyle

nothing is set in stone. let's make it great.

tl;dr version ->

in the early Plasma QML days things were often just proofs of concepts or 
written under tight deadlines with few people working on them. that and we 
didn't have a style guide to, well,  guide us. the result is that there is 
only one consistency: inconsistency.

within the same QML component (e.g. plasmoids) things aren't consistent; even 
inside the *same files* things are inconsistent. we can do better than this, 
and we should want to for the same reason we have a C++ coding style.

it makes maintenance easier. it is easier to read code not written by you as 
you don't have to go through the step of becoming familiar with a random 
coding style but know exactly where to look for any given part of the code.

i get frustrated seeing "if (foo==bar)" on one line and then "if( foo == bar 
)" a few lines later. it says we are not paying attention to what we write, 
but are just throwing up code. it is a sign of a lack of care and attention to 
detail. ime, discipline filters upwards.

but frustration is just an annoyance. losing time because Component.onComplete 
if found in some utterly random spot in the QML or having to scan the whole 
QML item block because properties are defined/set throughout: between 
functions, after other items, at the top, near the bottom.. i've seen it all 
in our QML unfortunately.

i know we are capable of producing consistent code. we do it with our C++ 
output.

starting today, i will be rejecting patches and if necessary fixing style 
slopiness complete with appropriately critical commit log messages CC'd to 
this list so everyone notices.

but i'd rather we just cleaned up our QML act by paying attention to the 
details and creating beautiful, consistent code and cleaning up the messy bed 
we've made for ourselves as we go ... fair?

-- 
Aaron J. Seigo
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 198 bytes
Desc: This is a digitally signed message part.
URL: <http://mail.kde.org/pipermail/plasma-devel/attachments/20121029/1d643c65/attachment-0001.sig>


More information about the Plasma-devel mailing list