Eclipse – Formatter e Save Action

Depois de ter falado sobre Code Templates para comentários no código, vou neste post falar sobre a formatação e como otimizar isso para lhe ajudar e não atrapalhar.

Muitos desenvolvedores tem problemas com o famoso Ctrl+Shift+F, que promete formatar seu código e muitas vezes acaba é deixando ele mais confuso.

Bem, o nosso padrão de código(se é que posso chamar assim) é muito diferente(ou um pouco depende) dos códigos dos gringos, ou seja, o Eclipse formata no padrão deles pode dizer assim ;).

Para resolver esse “problema” o desenvolvedor tem que fazer uma configuração simples, mas um pouco chata(considerada por alguns) mas no pior caso será feita apenas uma única vez ;).
Vá em Windows –> Preferences –> Java –> Code Style –> Formatter.

Vamos agora criar um novo profiler, clique em New e digite um nome para o seu novo profile.



Pronto, agora vamos personalizar, clique em editar.



Vou tentar falar um pouco sobre cada aba de opção.

Indentation
Nesta aba você vai selecionar a indentação em si e o tamanho dela, normalmente o tamanho da tab é 4.

Braces
Nesta aba você vai personalizar a posição das chaves(“{” , “}”).

White Space
Está é interessante, pois você poderá personalizar até os espaços em branco entre cada variável, método e assinaturas de todo tipo de objeto, desde strings até arrays e várias outras.

Blank Lines
Nesta aba você irá definir as quebras de linhas(linhas em branco) entres métodos, variáveis, pacotes e etc. Aqui você irá definir por exemplo que o espaço de linha entre a declaração de um package para um import seja de 2 linhas por exemplo.

New Lines
Nesta aba você define como um método vazio deverá ficar, se você deseja inserir uma nova linha neste método, definir também como um array declarado deverá ser exibido e identado, assim como uma annotation.

Control Statements
Esse é bem interessante mesmo, pois aqui você irá definir como seus else, IF, catch, while etc devem ser identados.

Line Wrapping
Neste você define o tamanho Maximo da coluna que uma linha pode comportar, como deve ser a identação de uma assinatura de um método, métodos declarados, enum, variáveis declaradas e etc.

Comments
Isso é referente a identação do Java Doc, blocos de comentários normais(//, /**/), qual o formato das tags HTML, espaço entre os textos do comentário e se desejar remover qualquer linha em branco que esteja no comentário.

Todas essa opções podem já serem visualizadas no código de exemplo ao lado de cada uma, facilitando assim a personalização.
Então supondo que você já criou e personalizou seu profile vamos agora tentar otimizar isso.

Para se utilizar do profile basta você executar o atalho dentro do código, que é o Ctrl + Shitf + F, pronto ele aplica a sua configuração personalizada.
Mas supondo que você criou um profile e quer sempre executar ele, fica meio chato você ficar sempre digitando o Ctrl+Shit+F correto ? Que tal otimizar isso ?

Save Actions
Vá em Windows –> Preferences –> Java –> Editor –> Save Actions.


Para ativar(caso não esteja) basta selecionar a opção “Perform the selected actions on save”.

Agora podemos adicionar uma formatação automática, selecione o Format source code e clique em Formatter.



Verifique se o seu profile está selecionado como profile ativo(Active Profile), clique em Ok e pronto, na próxima vez que você salvar(Ctrl + S) qualquer arquivo .java(classe) ele irá aplicar a(s) sua(s) configuração(ões) automaticamente.

Para definir como padrão para todos os integrantes da equipe, basta seguir os passos abaixo.

Vá em Windows –> Preferences –> Java –> Code Style –> Formatter –> Edit –> Export –> Salve seu profile.

Agora cada desenvolvedor irá poder importar toda a configuração de formatação de código, ou você mesmo poderá levar para onde quiser a sua formatação.

Simples não ?

Ações adicionais do Save Action

Se você quiser personalizar ainda mais a sua formatação é possível ainda inserir algumas formatações adicionais. Na tela de Save Actions temos o Configure onde você poderá definir mais configurações que serão executadas ao salvar qualquer classe Java.


Vou tentar explicar um pouco cada uma delas:

Code Style
Responsável em adicionar ou criar blocos fechados({, }) no bloco de IF/while/for/do.Definir se você quer parênteses em condições por exemplo:
(((i > 0) && (i < 10)) || (i == 50)) ou sem (i > 0 && i < 10 || i == 50).
Se quer adicionar o modificador final em todas os parâmetros onde seja necessário, e quais tipos de parâmetros(private, parameter, local variables).

Member Accesses
Usar o “this” em todos as variáveis e métodos locais ou somente onde for necessário. Como devem ser declarados os métodos e variáveis etc.

Unnecessary Code
Como o nome mesmo já diz, remove trechos de códigos desnecessários, como imports de classes que não existem dentre outras configurações.

Missing Code
Adiciona automaticamente as tags “@Override” e “@Deprecated” nos métodos.

Code Organizing
Organiza a ordem do métodos.

Bem essa são as formas simples de como otimizar o código, seja pela formatação dele ou até por simples comentários, mas essa é a intenção, não perder tempo com coisas simples e repetitivas ;).

Abraços e espero ter contribuído com este artigo para agilizar o processo de desenvolvimento.

32.424 Comments on “Eclipse – Formatter e Save Action

  1. I absolutely love your blog.. Great colors & theme. Did you develop this
    site yourself? Please reply back as I’m looking to create my very own website and would
    like to know where you got this from or just what the
    theme is called. Thank you!

  2. Excellent blog you have here but I was curious if
    you knew of any forums that cover the same topics talked about
    here? I’d really like to be a part of community where I can get
    feed-back from other knowledgeable individuals that
    share the same interest. If you have any suggestions, please let me know.

    Thank you!

  3. Hi superb blog! Does running a blog like this require
    a large amount of work? I have no understanding of computer
    programming however I was hoping to start my own blog in the
    near future. Anyway, if you have any suggestions or tips
    for new blog owners please share. I understand this is off topic nevertheless I just
    needed to ask. Appreciate it!

  4. ทางเราจำหน่าย relx Infinity , relx Buhble Mon , Infy Pod ต้องขอบอกได้เลยว่า
    relxchill.com เป็นตัวแทนหลักอย่างเป็นทางการในไทย
    ที่ใหญ่ที่สุด และเป็นเจ้าเดียวกับ RELX
    THAILAND สินค้าทุกแบรนด์ ทุกรุ่น เราได้ทำการคัดสรร บุหรี่ไฟฟ้า
    ที่เป็นหนึ่งในนวัตกรรม ช่วยเลิกบุหรี่ ที่มีประสิทธิดีเยี่ยม และช่วยได้จริง มาให้ลูกค้าได้เลือกใช้ โดยสินค้าทุกชิ้นของเรา สั่งตรงจากโรงงาน

  5. Hi theгe colleagues, how is the whole thing, and what you want to
    say concerning this ɑrticle, in my view its genuinely remarkable in sսpport of me.

    Аlso visit my blog biatch

  6. There are certainly a lot of details like that to take into consideration. That is a great point to bring up. I offer the thoughts above as general inspiration but clearly there are questions like the one you bring up where the most important thing will be working in honest good faith. I don?t know if best practices have emerged around things like that, but I am sure that your job is clearly identified as a fair game. Both boys and girls feel the impact of just a moment?s pleasure, for the rest of their lives.

  7. Simply desire to say your article is as astounding. The clearness in your post is simply spectacular and i can assume
    you are an expert on this subject. Fine with your permission let me
    to grab your RSS feed to keep up to date with forthcoming post.

    Thanks a million and please carry on the gratifying work.

  8. Magnificent items fгom you, man. I haᴠe be aware ypur stuff ρrevious to and yoս’re just tоо fantastic.
    I гeally like wһat you’ve got right hеrе,
    certainly likе what you are stating and the way in ѡhich durіng wһich yоu
    ssay it. Yoս’re making іt enjoyable ɑnd you still care
    for to stay іt wise. I cant wait to learn far morе from yߋu.
    That is actually a great webb site.

    my web site: gole spletne kamere

  9. We’re a group of volunteers and starting a new scheme in our community.
    Your web site provided us with valuable info to work on. You’ve done an impressive job and our
    whole community will be thankful to you.

  10. When someone writes an paragraph he/she keeps the plan of a user in his/her brain that how
    a user can understand it. Therefore that’s why this paragraph
    is outstdanding. Thanks!

  11. Всесторонние обзоры: Ищете новый автомобиль? На нашем портале doroll.ru представлены исчерпывающие обзоры последних моделей от всех ведущих производителей. Вы можете ознакомиться с подробным анализом функций, характеристик и цен каждого автомобиля, что поможет вам принять взвешенное решение.

  12. Hola! I’ve been reading your site for some time now and finally
    got the courage to go ahead and give you a shout out from Austin Tx!
    Just wanted to mention keep up the excellent job!

  13. With havin so much content and articles do you ever run into any
    problems of plagorism or copyright infringement?
    My blog has a lot of completely unique content I’ve either written myself or outsourced but it appears a lot
    of it is popping it up all over the web without my authorization. Do you know any solutions
    to help stop content from being stolen? I’d really appreciate
    it.

Deixe um comentário

O seu endereço de e-mail não será publicado. Campos obrigatórios são marcados com *

*

Esse site utiliza o Akismet para reduzir spam. Aprenda como seus dados de comentários são processados.