DEV Community

Cover image for Desenvolva um código melhor com Object Calisthenics
Marcelo Augusto for Pixelwolfhq

Posted on

Desenvolva um código melhor com Object Calisthenics

O famoso código Hadouken

Baixo, frente + soco = Hadouken

18 horas em plena sexta-feira, você doido para jogar um game e se depara com um código desse.
A vontade é de sair gritando, mas você como uma ótimo profissional, vai refatorar o código e deixar ele brilhando o/ o/

Eis que eu te apresento o Object Calisthenics

O que é Object Calisthenics?

É um conjunto de boas práticas e regras criado pelos desenvolvedores Java, mas que servem para as demais linguagens.
Ao todo são 9 regras, vou explicar as mais simples e eficientes.

Essas regras vão ajudar na manutenção do código, nos testes e até mesmo na compreensão.

Regras

OBS: A linguagem utilizada é JavaScript, mas nada impede que você aplique os conceitos em outras linguagens.

Um nível de identação por método

function displayPyramid(numberOfLine) { for (let index = 0; index < numberOfLine; index++) { let output = ""; const limit = numberOfLine - index; for (let secondIndex = 1; secondIndex < limit; secondIndex++) { output += " "; } for (let thirdIndex = 1; thirdIndex <= 2 * index + 1; thirdIndex++) { output += "*"; } console.log(output); } } 
Enter fullscreen mode Exit fullscreen mode

Podemos extrair os dois laços for por duas funções separadas.

function getBlankSpace(numberOfLine, currentLineIndex) { let output = ""; const limit = numberOfLine - currentLineIndex; for (let index = 1; index < limit; index++) { output += " "; } return output; } function getFilledPyramid(currentLineIndex) { let output = ""; for (let index = 1; index <= 2 * currentLineIndex + 1; index++) { output += "*"; } return output; } function displayPyramid(numberOfLine) { for (let index = 0; index < numberOfLine; index++) { let output = ""; output += getBlankSpace(numberOfLine, index); output += getFilledPyramid(index); console.log(output); } } 
Enter fullscreen mode Exit fullscreen mode

Não use ELSE

function printSeat(ticketCode) { if (ticketCode.startsWith("A") || ticketCode.startsWith("B")) { printVipSeat(); } else { printBasicSeat(); } } 
Enter fullscreen mode Exit fullscreen mode

Faça um retorno antecipado

function printSeat(ticketCode) { if (ticketCode.startsWith("A") || ticketCode.startsWith("B")) { return printVipSeat(); } return printBasicSeat(); } 
Enter fullscreen mode Exit fullscreen mode

Benefícios:

  • Reduz a complexidade e aumenta a legibilidade do fluxo lógico
  • Reduz a duplicação de validações mais complexas, te forçando a criar métodos para determinada validação
  • Te força a pensar em um código mais limpo

Não use abreviações

let temp = 1; const n = 5; for (let i = 1; i <= n; i++) { temp *= i; console.log(`${i}! = ${temp}`); } 
Enter fullscreen mode Exit fullscreen mode

Deixe seu código mais claro, uma mudança simples dessa evita que o seu colega perca horas tentando adivinhar o que cada variável faz

let temporary = 1; const count = 5; for (let index = 1; index <= count; index++) { temporary *= index; console.log(`${index}! = ${temporary}`); } 
Enter fullscreen mode Exit fullscreen mode

Benefícios:

  • Revelar a intenção da variável

Referências

Clean Code — Object Calisthenics in Javascript

Desenvolva um código melhor com Object Calisthenics

Writing cleaner code with Object Calisthenics

Object Calisthenics

Conclusão

Quando falamos de um código limpo o que não falta é material disponível sobre o assunto. O que passei aqui foi só a ponta do ‘iceberg’, para vermos que pequenas mudanças no processo de escrita do código já podemos obter melhorias significativas na qualidade do que é produzido. Se ainda têm interesse sobre o assunto, pesquise mais sobre Object Calisthenics.

Top comments (0)