O código abaixo funciona bem no meu breve teste em um c-mode
buffer:
- Após digitar
/*
, pressione M-j
a ligação padrão para indent-new-comment-line
(e a ligação padrão para c-indent-new-comment-line
in c-mode
). Se for a primeira linha de comentário, os caracteres de fechamento */
serão inseridos automaticamente.
- Bater
M-j
mais vezes com a inserção de mais linhas de comentário com o *
prefixo. Esse é o comportamento interno de c-indent-new-comment-line
/ indent-new-comment-line
funções. Confira a documentação de várias linhas de comentários .
- Uma pepita extra no código abaixo garante que haja pelo menos um espaço entre o
*
em cada linha de comentário e o comentário.
(defun my-prettify-c-block-comment (orig-fun &rest args)
(let* ((first-comment-line (looking-back "/\\*\\s-*.*"))
(star-col-num (when first-comment-line
(save-excursion
(re-search-backward "/\\*")
(1+ (current-column))))))
(apply orig-fun args)
(when first-comment-line
(save-excursion
(newline)
(dotimes (cnt star-col-num)
(insert " "))
(move-to-column star-col-num)
(insert "*/"))
(move-to-column star-col-num) ; comment this line if using bsd style
(insert "*") ; comment this line if using bsd style
))
;; Ensure one space between the asterisk and the comment
(when (not (looking-back " "))
(insert " ")))
(advice-add 'c-indent-new-comment-line :around #'my-prettify-c-block-comment)
;; (advice-remove 'c-indent-new-comment-line #'my-prettify-c-block-comment)
Por exemplo, depois de avaliar o código acima, eu recebo a seguir na digitação: /*
M-j
First comment line
M-j
Second comment line
. O ▮ indica a localização do cursor no final da digitação.
/*
* First comment line
* Second comment line▮
*/
Testando o bloco de comentários de deslocamento ..
Com o cursor após o ponto e vírgula, digitando: /*
M-j
Test offset comment
fornece o abaixo. O ▮ indica a localização do cursor no final da digitação.
#include<stdio.h>
main() {
printf("Hello World"); /*
* Test offset comment▮
*/
}