How to make Emacs sql-mode recognize MySQL #-style comments?

元气小坏坏 提交于 2020-01-04 04:35:07

问题


I'm reading a bunch of MySQL files that use # (to end-of-line) comments, but my sql-mode doesn't support them. I found the syntax-table part of sql.el that defines /**/ and -- comments, but according to this, Emacs syntax tables support only 2 comment styles.

Is there a way to add support for # comments in sql.el easily?


回答1:


Emacs-24 sql.el has this built-in! Simply run M-x sql-set-product MySQL RET and the syntax table is set up automatically, as are the font-lock-keywords for all the additional reserved words and types, interactive-mode, etc, etc. Brilliant!!

Of if you look under SQL in the menubar you can use the Product submenu to select MySQL.

You can also M-x customize-variable sql-product RET to set the default product away from ANSI.




回答2:


The answer by Rolf did not seem to work for me. AFAIK, the character class for starting comments, of the alternative comment style should be "< b", not " b". This what I use:

    (add-hook 'sql-mode-hook 'my-sql-mode-hook) 
    (defun my-sql-mode-hook ()   
      ;; Make # start a new line comment in SQL. This is MySQL-specific
      ;; syntax.
      (modify-syntax-entry ?# "< b" sql-mode-syntax-table))



回答3:


You can define ?# to start comment-style b, which means there are two ways of starting the alternative comment style (either -- or #):

(setq sql-mode-syntax-table
  (let ((table (make-syntax-table)))
    ;; C-style comments /**/ (see elisp manual "Syntax Flags"))
    (modify-syntax-entry ?/ ". 14" table)
    (modify-syntax-entry ?* ". 23" table)
    ;; double-dash starts comments
    (modify-syntax-entry ?- ". 12b" table)
    (modify-syntax-entry ?# " b" table)
    (modify-syntax-entry ?\f "> b" table)
    ;; single quotes (') delimit strings
    (modify-syntax-entry ?' "\"" table)
    ;; double quotes (") don't delimit strings
    (modify-syntax-entry ?\" "." table)
    ;; backslash is no escape character
    (modify-syntax-entry ?\\ "." table)
    table))

(This was copied from sql.el and modified, which means that this is GPL)



来源:https://stackoverflow.com/questions/484826/how-to-make-emacs-sql-mode-recognize-mysql-style-comments

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!