Using your local language is a great idea because domain naming is easier. Not
TL;DR: Stick to English. Always.
Problems
Polymorphism
Cultural gaps
Mixed Code
Syntactic Errors
Solutions
Write in English
Rename Domain Concepts to English
Context
All programming languages are written in English.
Unless for a few failed experiments during the 90's all modern languages use English for their primitives and their frameworks.
if you wanted to read or write in medieval Europe, you had to acquire a new language at the same time. Writing meant Latin.
This is true for programming languages nowadays.
I am not a Native English speaker.
My code (tries to be) in English.
Sample Code
Wrong
const elements = new Set();
elements.add(1);
elements.add(1);
elements.size() = 1
//This is the standard set
var moreElements = new MultiConjunto();
//We defined a multiset in Spanish
//because we are extending the domain
moreElements.agregar('hello');
moreElements.agregar('hello');
//'agregar' is the Spanish word for 'add'
moreElements.size() = 2 //Since it is a multiset
//elements and moreElements are NOT polymorphic
//I cannot exchange their implementation
Right
const elements = new Set();
elements.add(1);
elements.add(1);
elements.size() = 1
//This is the standard set
var moreElements = new MultiSet();
//We defined a multiset in English
moreElements.add('hello');
moreElements.add('hello');
moreElements.size() = 2 //Since it is a multiset
//elements and moreElements are polymorphic
//I can exchange their implementation anytime
Detection
[X] Automatic
Most IDEs and linters have a thesaurus.
We can search for foreign words.
Tags
- Readability
Conclusion
Don't mix Non-English domain words with English primitives.
Even when Mapping your real-world entities, use plain English.
More Info
Credits
Photo by Anna Vander Stel on Unsplash
A programming language is a tool that has a profound influence on our thinking habits.
Edsger Dijkstra
Software Engineering Great Quotes
Maxi Contieri ・ Dec 28 '20
This article is part of the CodeSmell Series.
Top comments (3)
I didn't know you could assign to the return value of a function in JavaScript.
Hi. It is not an assignment
It is the actual outcome.
code is here for pedagogic purposes.
Languages are accidental.
But I will put it in a comment line for better explanation.
Thank you
MDN would write something like:
You can also write: