* [PATCH] feat: add markdown-ts-mode
@ 2024-04-20 3:23 Rahul Martim Juliato
2024-04-20 6:44 ` Eli Zaretskii
0 siblings, 1 reply; 16+ messages in thread
From: Rahul Martim Juliato @ 2024-04-20 3:23 UTC (permalink / raw)
To: emacs-devel
[-- Attachment #1: Type: text/plain, Size: 1018 bytes --]
Hello there!
I've been using Emacs without any extra packages as an educational
experiment after years of package hording.
One of the few things I've been missing is a way of displaying some sort
of syntax highlight for markdown documents.
It feels a bit frustrating opening a README.md file with a single face
color, since Emacs from the box can handle so much. I am sure others
might have shared this feeling before.
This patch is a modified version of a package I've recently published on
MELPA, screenshots are available here:
https://github.com/LionyxML/markdown-ts-mode
It is a very basic mode that provides syntax highlight and imenu support
using treesitter grammar from
https://github.com/tree-sitter-grammars/tree-sitter-markdown
The idea here is to provide minimal support to Emacs and continue
building up features in the future.
It is the first time I contribute to Emacs devel, so please let me know
if I did something wrong or anything is not at the expected standards.
-----
Rahul
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: 0001-feat-add-markdown-ts-mode.patch --]
[-- Type: text/x-diff, Size: 5071 bytes --]
From 364f61b03d601d2cb3aeb1687da2d1b2a232474c Mon Sep 17 00:00:00 2001
From: Rahul Martim Juliato <rahul.juliato@gmail.com>
Date: Fri, 19 Apr 2024 23:21:20 -0300
Subject: [PATCH] feat: add markdown-ts-mode
---
etc/NEWS | 5 ++
lisp/progmodes/markdown-ts-mode.el | 106 +++++++++++++++++++++++++++++
2 files changed, 111 insertions(+)
create mode 100644 lisp/progmodes/markdown-ts-mode.el
diff --git a/etc/NEWS b/etc/NEWS
index 8ad1e78ca60..ea0640337fb 100644
--- a/etc/NEWS
+++ b/etc/NEWS
@@ -1688,6 +1688,11 @@ A major mode based on the tree-sitter library for editing Elixir files.
*** New major mode 'lua-ts-mode'.
A major mode based on the tree-sitter library for editing Lua files.
+---
+*** New major mode 'markdown-ts-mode'.
+A major mode based on the tree-sitter library for editing Markdown files.
+
+
** Minibuffer and Completions
+++
diff --git a/lisp/progmodes/markdown-ts-mode.el b/lisp/progmodes/markdown-ts-mode.el
new file mode 100644
index 00000000000..a20d754f83e
--- /dev/null
+++ b/lisp/progmodes/markdown-ts-mode.el
@@ -0,0 +1,106 @@
+;;; markdown-ts-mode.el --- tree sitter support for Markdown -*- lexical-binding: t; -*-
+
+;; Copyright (C) 2024 Free Software Foundation, Inc.
+
+;; Author : Rahul Martim Juliato <rahul.juliato@gmail.com>
+;; Maintainer : Rahul Martim Juliato <rahul.juliato@gmail.com>
+;; Created : April 2024
+;; Keywords : markdown md languages tree-sitter
+
+;; This file is part of GNU Emacs.
+
+;; GNU Emacs is free software: you can redistribute it and/or modify
+;; it under the terms of the GNU General Public License as published by
+;; the Free Software Foundation, either version 3 of the License, or
+;; (at your option) any later version.
+
+;; GNU Emacs is distributed in the hope that it will be useful,
+;; but WITHOUT ANY WARRANTY; without even the implied warranty of
+;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+;; GNU General Public License for more details.
+
+;; You should have received a copy of the GNU General Public License
+;; along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
+
+;;; Commentary:
+;;
+
+;;; Code:
+
+(require 'treesit)
+(require 'subr-x)
+
+(declare-function treesit-node-parent "treesit.c")
+(declare-function treesit-node-type "treesit.c")
+(declare-function treesit-parser-create "treesit.c")
+
+(defvar markdown-ts--treesit-settings
+ (treesit-font-lock-rules
+ :language 'markdown
+ :override t
+ :feature 'delimiter
+ '([ "[" "]" "(" ")" ] @shadow)
+
+ :language 'markdown
+ :feature 'paragraph
+ '([((atx_heading) @font-lock-keyword-face)
+ ((block_quote_marker) @font-lock-string-face)
+ ((code_span) @font-lock-string-face)
+ ((emphasis) @underline)
+ ((image_description) @link)
+ ((indented_code_block) @font-lock-string-face)
+ ((link_destination) @font-lock-string-face)
+ ((setext_heading) @font-lock-keyword-face)
+ ((strong_emphasis) @bold)
+ ((thematic_break) @shadow)
+ (block_quote (block_quote_marker) @font-lock-string-face)
+ (block_quote (paragraph) @font-lock-string-face)
+ (fenced_code_block (code_fence_content) @font-lock-string-face)
+ (fenced_code_block (fenced_code_block_delimiter) @font-lock-doc-face)
+ (inline_link (link_destination) @font-lock-string-face)
+ (inline_link (link_text) @link)
+ (list_item (list_marker_dot) @font-lock-keyword-face)
+ (list_item (list_marker_minus) @font-lock-keyword-face)
+ (list_item (list_marker_plus) @font-lock-keyword-face)
+ (list_item (list_marker_star) @font-lock-keyword-face)
+ (shortcut_link (link_text) @link)
+ ])))
+
+(defun markdown-ts-imenu-node-p (node)
+ "Check if NODE is a valid entry to imenu."
+ (equal (treesit-node-type (treesit-node-parent node))
+ "atx_heading"))
+
+(defun markdown-ts-imenu-name-function (node)
+ "Return an imenu entry if NODE is a valid header."
+ (let ((name (treesit-node-text node)))
+ (if (markdown-ts-imenu-node-p node)
+ (thread-first (treesit-node-parent node)(treesit-node-text))
+ name)))
+
+(defun markdown-ts-setup ()
+ "Setup treesit for `markdown-ts-mode'."
+ (setq-local treesit-font-lock-settings markdown-ts--treesit-settings)
+ (treesit-major-mode-setup))
+
+;;;###autoload
+(define-derived-mode markdown-ts-mode fundamental-mode "markdown[ts]"
+ "Major mode for editing Markdown using tree-sitter grammar."
+ (setq-local font-lock-defaults nil
+ treesit-font-lock-feature-list '((delimiter)
+ (paragraph)))
+
+ (setq-local treesit-simple-imenu-settings
+ `(("Headings" markdown-ts-imenu-node-p nil markdown-ts-imenu-name-function)))
+
+ (when (treesit-ready-p 'markdown)
+ (treesit-parser-create 'markdown)
+ (markdown-ts-setup)))
+
+(derived-mode-add-parents 'markdown-ts-mode '(markdown-mode))
+
+(if (treesit-ready-p 'markdown)
+ (add-to-list 'auto-mode-alist '("\\.md\\'" . markdown-ts-mode)))
+
+(provide 'markdown-ts-mode)
+;;; markdown-ts-mode.el ends here
--
2.39.2
^ permalink raw reply related [flat|nested] 16+ messages in thread
* Re: [PATCH] feat: add markdown-ts-mode
2024-04-20 3:23 [PATCH] feat: add markdown-ts-mode Rahul Martim Juliato
@ 2024-04-20 6:44 ` Eli Zaretskii
2024-04-20 17:45 ` Jostein Kjønigsen
0 siblings, 1 reply; 16+ messages in thread
From: Eli Zaretskii @ 2024-04-20 6:44 UTC (permalink / raw)
To: Rahul Martim Juliato, Yuan Fu; +Cc: emacs-devel
> From: Rahul Martim Juliato <rahuljuliato@gmail.com>
> Date: Sat, 20 Apr 2024 00:23:45 -0300
>
> I've been using Emacs without any extra packages as an educational
> experiment after years of package hording.
>
>
> One of the few things I've been missing is a way of displaying some sort
> of syntax highlight for markdown documents.
>
>
> It feels a bit frustrating opening a README.md file with a single face
> color, since Emacs from the box can handle so much. I am sure others
> might have shared this feeling before.
>
>
> This patch is a modified version of a package I've recently published on
> MELPA, screenshots are available here:
> https://github.com/LionyxML/markdown-ts-mode
>
>
> It is a very basic mode that provides syntax highlight and imenu support
> using treesitter grammar from
> https://github.com/tree-sitter-grammars/tree-sitter-markdown
>
>
> The idea here is to provide minimal support to Emacs and continue
> building up features in the future.
>
>
> It is the first time I contribute to Emacs devel, so please let me know
> if I did something wrong or anything is not at the expected standards.
Thanks, please see a couple of comments below. I've CC'ed Yuan as
well, in case he has comments.
> >From 364f61b03d601d2cb3aeb1687da2d1b2a232474c Mon Sep 17 00:00:00 2001
> From: Rahul Martim Juliato <rahul.juliato@gmail.com>
> Date: Fri, 19 Apr 2024 23:21:20 -0300
>
> ---
> etc/NEWS | 5 ++
> lisp/progmodes/markdown-ts-mode.el | 106 +++++++++++++++++++++++++++++
> 2 files changed, 111 insertions(+)
> create mode 100644 lisp/progmodes/markdown-ts-mode.el
Please accompany the patches with a ChangeLog-style commit log
message; see CONTRIBUTE for the details. In this case, you'd need a
very minimal one, something like:
* lisp/progmodes/markdown-ts-mode.el: New file.
* etc/NEWS: Announce the new mode.
> +---
> +*** New major mode 'markdown-ts-mode'.
> +A major mode based on the tree-sitter library for editing Markdown files.
How about mentioning this in the user manual as well? It doesn't have
to be anything more than just the name of the mode.
> diff --git a/lisp/progmodes/markdown-ts-mode.el b/lisp/progmodes/markdown-ts-mode.el
Should this mode live in lisp/textmodes/ instead? Markdown is AFAIU a
mode for text with markup, it isn't a programming language.
> +(defun markdown-ts-setup ()
> + "Setup treesit for `markdown-ts-mode'."
> + (setq-local treesit-font-lock-settings markdown-ts--treesit-settings)
> + (treesit-major-mode-setup))
> +
> +;;;###autoload
> +(define-derived-mode markdown-ts-mode fundamental-mode "markdown[ts]"
> + "Major mode for editing Markdown using tree-sitter grammar."
> + (setq-local font-lock-defaults nil
> + treesit-font-lock-feature-list '((delimiter)
> + (paragraph)))
I wonder whether this mode should inherit from Text mode instead, and
consequently have some text-related commands, perhaps aided by the
tree-sitter grammar? WDYT? We could, of course, add commands later,
but the decision to have Text mode as the parent of this one should be
made now.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH] feat: add markdown-ts-mode
2024-04-20 6:44 ` Eli Zaretskii
@ 2024-04-20 17:45 ` Jostein Kjønigsen
2024-04-21 5:50 ` Rahul Martim Juliato
0 siblings, 1 reply; 16+ messages in thread
From: Jostein Kjønigsen @ 2024-04-20 17:45 UTC (permalink / raw)
To: Rahul Martim Juliato
Cc: Yuan Fu, Ergus via Emacs development discussions., Eli Zaretskii
[-- Attachment #1: Type: text/plain, Size: 5185 bytes --]
Some comments so far about *how* the mode should correctly be added to repo, so I won't delve into that.
Instead, I like the idea behind having built in modes for stuff like this. So I went ahead and tested the real-world functionality of the major-mode on the files I have :)
First I tried to install the grammar using the default for treesit-install-grammar, and that failed. I then tweaked some settings, and I think I did the right thing?
Repo: https://github.com/tree-sitter-grammars/tree-sitter-markdown
Subfolder for compilation: tree-sitter-markdown/src
After installing this grammar using , I can compile/evaluate the provided major-mode (but not before!). I think most other TS-based major-modes in Emacs have a way to handle this more gracefully, and that should probably be addressed here too?
Now after compiling it and activating it... Im getting some confusing behaviour on existing files:
1. No syntax-highlighting at all. Not on new, nor existing buffers. What I am doing wrong here? :)
2. Newline chars in modeline to tell me my current section (# Deployment^J). Is this major-mode somehow linebreak-type sensitive? IMO that's not a great thing.
3. No imenu? Imenu really would make this nicer to use, but not really worth looking into until other issues are resolved.
The contrast to the version you say you've already published on MELPA is quite significant, where from what I can tell...
In that mode, literally everything works. Are there any reason you can't submit that version instead of this modified version?
Also: Please don't consider these comments in a dissuading manner. These are meant as constructive criticism, because I want Emacs to have these things, but then they need to be good enough :)
—
Kind Regards
Jostein Kjønigsen
> On 20 Apr 2024, at 08:44, Eli Zaretskii <eliz@gnu.org> wrote:
>
>> From: Rahul Martim Juliato <rahuljuliato@gmail.com>
>> Date: Sat, 20 Apr 2024 00:23:45 -0300
>>
>> I've been using Emacs without any extra packages as an educational
>> experiment after years of package hording.
>>
>>
>> One of the few things I've been missing is a way of displaying some sort
>> of syntax highlight for markdown documents.
>>
>>
>> It feels a bit frustrating opening a README.md file with a single face
>> color, since Emacs from the box can handle so much. I am sure others
>> might have shared this feeling before.
>>
>>
>> This patch is a modified version of a package I've recently published on
>> MELPA, screenshots are available here:
>> https://github.com/LionyxML/markdown-ts-mode
>>
>>
>> It is a very basic mode that provides syntax highlight and imenu support
>> using treesitter grammar from
>> https://github.com/tree-sitter-grammars/tree-sitter-markdown
>>
>>
>> The idea here is to provide minimal support to Emacs and continue
>> building up features in the future.
>>
>>
>> It is the first time I contribute to Emacs devel, so please let me know
>> iif I did something wrong or anything is not at the expected standards.
>
> Thanks, please see a couple of comments below. I've CC'ed Yuan as
> well, in case he has comments.
>
>>> From 364f61b03d601d2cb3aeb1687da2d1b2a232474c Mon Sep 17 00:00:00 2001
>> From: Rahul Martim Juliato <rahul.juliato@gmail.com>
>> Date: Fri, 19 Apr 2024 23:21:20 -0300
>>
>> ---
>> etc/NEWS | 5 ++
>> lisp/progmodes/markdown-ts-mode.el | 106 +++++++++++++++++++++++++++++
>> 2 files changed, 111 insertions(+)
>> create mode 100644 lisp/progmodes/markdown-ts-mode.el
>
> Please accompany the patches with a ChangeLog-style commit log
> message; see CONTRIBUTE for the details. In this case, you'd need a
> very minimal one, something like:
>
> * lisp/progmodes/markdown-ts-mode.el: New file.
> * etc/NEWS: Announce the new mode.
>
>> +---
>> +*** New major mode 'markdown-ts-mode'.
>> +A major mode based on the tree-sitter library for editing Markdown files.
>
> How about mentioning this in the user manual as well? It doesn't have
> to be anything more than just the name of the mode.
>
>> diff --git a/lisp/progmodes/markdown-ts-mode.el b/lisp/progmodes/markdown-ts-mode.el
>
> Should this mode live in lisp/textmodes/ instead? Markdown is AFAIU a
> mode for text with markup, it isn't a programming language.
>
>> +(defun markdown-ts-setup ()
>> + "Setup treesit for `markdown-ts-mode'."
>> + (setq-local treesit-font-lock-settings markdown-ts--treesit-settings)
>> + (treesit-major-mode-setup))
>> +
>> +;;;###autoload
>> +(define-derived-mode markdown-ts-mode fundamental-mode "markdown[ts]"
>> + "Major mode for editing Markdown using tree-sitter grammar."
>> + (setq-local font-lock-defaults nil
>> + treesit-font-lock-feature-list '((delimiter)
>> + (paragraph)))
>
> I wonder whether this mode should inherit from Text mode instead, and
> consequently have some text-related commands, perhaps aided by the
> tree-sitter grammar? WDYT? We could, of course, add commands later,
> but the decision to have Text mode as the parent of this one should be
> made now.
>
[-- Attachment #2: Type: text/html, Size: 7629 bytes --]
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH] feat: add markdown-ts-mode
2024-04-20 17:45 ` Jostein Kjønigsen
@ 2024-04-21 5:50 ` Rahul Martim Juliato
2024-04-22 7:02 ` Philip Kaludercic
0 siblings, 1 reply; 16+ messages in thread
From: Rahul Martim Juliato @ 2024-04-21 5:50 UTC (permalink / raw)
To: Jostein Kjønigsen
Cc: Rahul Martim Juliato, Yuan Fu,
Ergus via Emacs development discussions., Eli Zaretskii
[-- Attachment #1: Type: text/plain, Size: 3959 bytes --]
Thanks Eli and Jostein!
No problem criticising :)
Please find a new patch attached. Things I've made:
- changed the file to the textmodes folder
- made it inherit from `text-mode'
- changed the news with +++
- changed `emacs.texi' (is it here?) to add Markdown
- scratched my head until 2:30AM thinking why it would not work for
Jostein test.
Well Jostein, I've been played by the tree-sitter github repository
maintainer, lol.
First, a little note. There's actually no major changes to the version
on github. I only changed documenting strings and made some small name
changes to more "alike" already existing modes.
It happens that on tree-sitter repository, unlike any other of their
repositories (that I've seen), "main" branch is NOT the current branch,
but the "we moved from here bye" one.
The current default branch is "split_parser" where
tree-sitter-markdown/src/ resides, hence the confusion.
So, I wrote the mode with the "main" one in mind.
I already checked the "new" (split_parser) one, and it seems it is
possible to convert the current work to use this one instead. I'll try
to do this in the middle of the week or sooner :)
In the mean time, I realized more people would like to test this patch
and tree-sitter setup is really trick, so I made this little "guide" on
how to apply it until the end result (this might work now, pointing to
the "main" branch with the current patch).
If you could please try the path (B) on the guide and tell me if this
works for you, It would be nice, Jostein.
Thanks!
Rahul
--- beggining of guide on how to apply this patch and test it
Git apply this patch.
Run the autogen script:
./autogen.sh
Make sure configure uses tree-sitter:
./configure --with-tree-sitter
Compile:
make bootstrap
Check the build:
./src/emacs -Q --version
Open emacs
./src/emacs -Q --init-dir=~/tmp_emacs_dir/
A) The Hard Way
Visit a .md file
C-x f TEST.md
Note the mode will not automatically load.
This behavior is the same as typescript-ts-mode or other
treesitter modes I've been using.
M-x markdown-ts-mode
It will fail since you have no tree sitter grammar installed.
and will suggest installing it with `treesit-install-language-grammar'.
This behaviour is also standard for the tree-sitter modes I
currently use (typescript, tsx, rust).
Issuing "M-x treesit-install-language-grammar RET".
It asks for language, complete with "markdown RET".
It says there's no recipie for it, if you want to build it
interactivelly. Anwser "yes".
It asks for the URL where the grammar is hosted, enter:
"https://github.com/tree-sitter-grammars/tree-sitter-markdown RET"
It asks for the tag or branch, setting the default, enter "main RET".
It asks for the subfolder, leave the default (src), enter "RET".
It asks for the C compiler to use (default: auto-detect), just "RET".
It asks for the C++ compiler to use (default: auto-detect), just "RET".
Install to (default "~/tmp_emacs_dir/treesitter"), just "RET".
It will clone the repository, compile the library and tell in the
minibuffer the library is installed to your folder.
B) The Easier Way.
Copy-paste and eval this use-package definition.
(use-package markdown-ts-mode
:mode ("\\.md\\'" . markdown-ts-mode)
:defer 't
:config
(add-to-list 'treesit-language-source-alist '(markdown "https://github.com/tree-sitter-grammars/tree-sitter-markdown" "main" "src")))
Visit your markdown test file.
It will probably fail due to the missing grammar.
Issue "M-x treesit-install-language-grammar RET".
Now with TAB it should complete "markdown", if not, type it.
As we already have the source now defined, just hit "RET" to install
to the default treemacs folder.
It will clone the repository and say it installed on your folder.
Just reload the mode with "M-x markdown-ts-mode".
From now on (with the use-package definition on `init.el') you should
just open .md and have the highlight and stuff.
--- end of the guide
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: 0001-feat-add-markdown-ts-mode.patch --]
[-- Type: text/x-diff, Size: 5707 bytes --]
From 45796df36129ec77c532b3fa21cdd0b8033c9777 Mon Sep 17 00:00:00 2001
From: Rahul Martim Juliato <rahul.juliato@gmail.com>
Date: Fri, 19 Apr 2024 23:21:20 -0300
Subject: [PATCH] feat: add markdown-ts-mode
* lisp/textmodes/markdown-ts-mode.el: New file.
* doc/emacs/emacs.texi: Add Markdown to the manual
* etc/NEWS: Announce markdown-ts-mode
---
doc/emacs/emacs.texi | 1 +
etc/NEWS | 5 ++
lisp/textmodes/markdown-ts-mode.el | 106 +++++++++++++++++++++++++++++
3 files changed, 112 insertions(+)
create mode 100644 lisp/textmodes/markdown-ts-mode.el
diff --git a/doc/emacs/emacs.texi b/doc/emacs/emacs.texi
index 7d77f13ab21..244c822ee04 100644
--- a/doc/emacs/emacs.texi
+++ b/doc/emacs/emacs.texi
@@ -618,6 +618,7 @@ Top
* Enriched Text:: Editing text enriched with fonts, colors, etc.
* Text Based Tables:: Commands for editing text-based tables.
* Two-Column:: Splitting text columns into separate windows.
+* Markdown:: Major mode for editing Markdown files.
Filling Text
diff --git a/etc/NEWS b/etc/NEWS
index 8ad1e78ca60..06fbaa03b55 100644
--- a/etc/NEWS
+++ b/etc/NEWS
@@ -1688,6 +1688,11 @@ A major mode based on the tree-sitter library for editing Elixir files.
*** New major mode 'lua-ts-mode'.
A major mode based on the tree-sitter library for editing Lua files.
++++
+*** New major mode 'markdown-ts-mode'.
+A major mode based on the tree-sitter library for editing Markdown files.
+
+
** Minibuffer and Completions
+++
diff --git a/lisp/textmodes/markdown-ts-mode.el b/lisp/textmodes/markdown-ts-mode.el
new file mode 100644
index 00000000000..063780a772f
--- /dev/null
+++ b/lisp/textmodes/markdown-ts-mode.el
@@ -0,0 +1,106 @@
+;;; markdown-ts-mode.el --- tree sitter support for Markdown -*- lexical-binding: t; -*-
+
+;; Copyright (C) 2024 Free Software Foundation, Inc.
+
+;; Author : Rahul Martim Juliato <rahul.juliato@gmail.com>
+;; Maintainer : Rahul Martim Juliato <rahul.juliato@gmail.com>
+;; Created : April 2024
+;; Keywords : markdown md languages tree-sitter
+
+;; This file is part of GNU Emacs.
+
+;; GNU Emacs is free software: you can redistribute it and/or modify
+;; it under the terms of the GNU General Public License as published by
+;; the Free Software Foundation, either version 3 of the License, or
+;; (at your option) any later version.
+
+;; GNU Emacs is distributed in the hope that it will be useful,
+;; but WITHOUT ANY WARRANTY; without even the implied warranty of
+;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+;; GNU General Public License for more details.
+
+;; You should have received a copy of the GNU General Public License
+;; along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
+
+;;; Commentary:
+;;
+
+;;; Code:
+
+(require 'treesit)
+(require 'subr-x)
+
+(declare-function treesit-node-parent "treesit.c")
+(declare-function treesit-node-type "treesit.c")
+(declare-function treesit-parser-create "treesit.c")
+
+(defvar markdown-ts--treesit-settings
+ (treesit-font-lock-rules
+ :language 'markdown
+ :override t
+ :feature 'delimiter
+ '([ "[" "]" "(" ")" ] @shadow)
+
+ :language 'markdown
+ :feature 'paragraph
+ '([((atx_heading) @font-lock-keyword-face)
+ ((block_quote_marker) @font-lock-string-face)
+ ((code_span) @font-lock-string-face)
+ ((emphasis) @underline)
+ ((image_description) @link)
+ ((indented_code_block) @font-lock-string-face)
+ ((link_destination) @font-lock-string-face)
+ ((setext_heading) @font-lock-keyword-face)
+ ((strong_emphasis) @bold)
+ ((thematic_break) @shadow)
+ (block_quote (block_quote_marker) @font-lock-string-face)
+ (block_quote (paragraph) @font-lock-string-face)
+ (fenced_code_block (code_fence_content) @font-lock-string-face)
+ (fenced_code_block (fenced_code_block_delimiter) @font-lock-doc-face)
+ (inline_link (link_destination) @font-lock-string-face)
+ (inline_link (link_text) @link)
+ (list_item (list_marker_dot) @font-lock-keyword-face)
+ (list_item (list_marker_minus) @font-lock-keyword-face)
+ (list_item (list_marker_plus) @font-lock-keyword-face)
+ (list_item (list_marker_star) @font-lock-keyword-face)
+ (shortcut_link (link_text) @link)
+ ])))
+
+(defun markdown-ts-imenu-node-p (node)
+ "Check if NODE is a valid entry to imenu."
+ (equal (treesit-node-type (treesit-node-parent node))
+ "atx_heading"))
+
+(defun markdown-ts-imenu-name-function (node)
+ "Return an imenu entry if NODE is a valid header."
+ (let ((name (treesit-node-text node)))
+ (if (markdown-ts-imenu-node-p node)
+ (thread-first (treesit-node-parent node)(treesit-node-text))
+ name)))
+
+(defun markdown-ts-setup ()
+ "Setup treesit for `markdown-ts-mode'."
+ (setq-local treesit-font-lock-settings markdown-ts--treesit-settings)
+ (treesit-major-mode-setup))
+
+;;;###autoload
+(define-derived-mode markdown-ts-mode text-mode "Markdown"
+ "Major mode for editing Markdown using tree-sitter grammar."
+ (setq-local font-lock-defaults nil
+ treesit-font-lock-feature-list '((delimiter)
+ (paragraph)))
+
+ (setq-local treesit-simple-imenu-settings
+ `(("Headings" markdown-ts-imenu-node-p nil markdown-ts-imenu-name-function)))
+
+ (when (treesit-ready-p 'markdown)
+ (treesit-parser-create 'markdown)
+ (markdown-ts-setup)))
+
+(derived-mode-add-parents 'markdown-ts-mode '(markdown-mode))
+
+(if (treesit-ready-p 'markdown)
+ (add-to-list 'auto-mode-alist '("\\.md\\'" . markdown-ts-mode)))
+
+(provide 'markdown-ts-mode)
+;;; markdown-ts-mode.el ends here
--
2.39.2
[-- Attachment #3: Type: text/plain, Size: 5282 bytes --]
Jostein Kjønigsen <jostein@secure.kjonigsen.net> writes:
> Some comments so far about *how* the mode should correctly be added to repo, so I won't delve into
> that.
>
> Instead, I like the idea behind having built in modes for stuff like this. So I went ahead and tested the
> real-world functionality of the major-mode on the files I have :)
>
> First I tried to install the grammar using the default for treesit-install-grammar, and that failed. I then
> tweaked some settings, and I think I did the right thing?
>
> Repo: https://github.com/tree-sitter-grammars/tree-sitter-markdown
> Subfolder for compilation:
>
> tree-sitter-markdown/src
>
> After installing this grammar using , I can compile/evaluate the provided major-mode (but not
> before!). I think most other TS-based major-modes in Emacs have a way to handle this more gracefully,
> and that should probably be addressed here too?
>
> Now after compiling it and activating it... Im getting some confusing behaviour on existing files:
>
> 1. No syntax-highlighting at all. Not on new, nor existing buffers. What I am doing wrong here? :)
> 2. Newline chars in modeline to tell me my current section (# Deployment^J). Is this major-mode
> somehow linebreak-type sensitive? IMO that's not a great thing.
> 3. No imenu? Imenu really would make this nicer to use, but not really worth looking into until other
> issues are resolved.
>
> The contrast to the version you say you've already published on MELPA is quite significant, where from
> what I can tell...
>
> In that mode, literally everything works. Are there any reason you can't submit that version instead of
> this modified version?
>
> Also: Please don't consider these comments in a dissuading manner. These are meant as constructive
> criticism, because I want Emacs to have these things, but then they need to be good enough :)
>
> —
> Kind Regards
> Jostein Kjønigsen
>
> On 20 Apr 2024, at 08:44, Eli Zaretskii <eliz@gnu.org> wrote:
>
> From: Rahul Martim Juliato <rahuljuliato@gmail.com>
> Date: Sat, 20 Apr 2024 00:23:45 -0300
>
> I've been using Emacs without any extra packages as an educational
> experiment after years of package hording.
>
> One of the few things I've been missing is a way of displaying some sort
> of syntax highlight for markdown documents.
>
> It feels a bit frustrating opening a README.md file with a single face
> color, since Emacs from the box can handle so much. I am sure others
> might have shared this feeling before.
>
> This patch is a modified version of a package I've recently published on
> MELPA, screenshots are available here:
> https://github.com/LionyxML/markdown-ts-mode
>
> It is a very basic mode that provides syntax highlight and imenu support
> using treesitter grammar from
> https://github.com/tree-sitter-grammars/tree-sitter-markdown
>
> The idea here is to provide minimal support to Emacs and continue
> building up features in the future.
>
> It is the first time I contribute to Emacs devel, so please let me know
> iif I did something wrong or anything is not at the expected standards.
>
> Thanks, please see a couple of comments below. I've CC'ed Yuan as
> well, in case he has comments.
>
> From 364f61b03d601d2cb3aeb1687da2d1b2a232474c Mon Sep 17 00:00:00 2001
>
> From: Rahul Martim Juliato <rahul.juliato@gmail.com>
> Date: Fri, 19 Apr 2024 23:21:20 -0300
>
> ---
> etc/NEWS | 5 ++
> lisp/progmodes/markdown-ts-mode.el | 106 +++++++++++++++++++++++++++++
> 2 files changed, 111 insertions(+)
> create mode 100644 lisp/progmodes/markdown-ts-mode.el
>
> Please accompany the patches with a ChangeLog-style commit log
> message; see CONTRIBUTE for the details. In this case, you'd need a
> very minimal one, something like:
>
> * lisp/progmodes/markdown-ts-mode.el: New file.
> * etc/NEWS: Announce the new mode.
>
> +---
> +*** New major mode 'markdown-ts-mode'.
> +A major mode based on the tree-sitter library for editing Markdown files.
>
> How about mentioning this in the user manual as well? It doesn't have
> to be anything more than just the name of the mode.
>
> diff --git a/lisp/progmodes/markdown-ts-mode.el b/lisp/progmodes/markdown-ts-mode.el
>
> Should this mode live in lisp/textmodes/ instead? Markdown is AFAIU a
> mode for text with markup, it isn't a programming language.
>
> +(defun markdown-ts-setup ()
> + "Setup treesit for `markdown-ts-mode'."
> + (setq-local treesit-font-lock-settings markdown-ts--treesit-settings)
> + (treesit-major-mode-setup))
> +
> +;;;###autoload
> +(define-derived-mode markdown-ts-mode fundamental-mode "markdown[ts]"
> + "Major mode for editing Markdown using tree-sitter grammar."
> + (setq-local font-lock-defaults nil
> + treesit-font-lock-feature-list '((delimiter)
> + (paragraph)))
>
> I wonder whether this mode should inherit from Text mode instead, and
> consequently have some text-related commands, perhaps aided by the
> tree-sitter grammar? WDYT? We could, of course, add commands later,
> but the decision to have Text mode as the parent of this one should be
> made now.
^ permalink raw reply related [flat|nested] 16+ messages in thread
* Re: [PATCH] feat: add markdown-ts-mode
2024-04-21 5:50 ` Rahul Martim Juliato
@ 2024-04-22 7:02 ` Philip Kaludercic
2024-04-23 1:20 ` Rahul Martim Juliato
0 siblings, 1 reply; 16+ messages in thread
From: Philip Kaludercic @ 2024-04-22 7:02 UTC (permalink / raw)
To: Rahul Martim Juliato
Cc: Jostein Kjønigsen, Yuan Fu,
Ergus via Emacs development discussions., Eli Zaretskii
Rahul Martim Juliato <rahuljuliato@gmail.com> writes:
> Thanks Eli and Jostein!
>
> No problem criticising :)
>
>
> Please find a new patch attached. Things I've made:
>
> - changed the file to the textmodes folder
>
> - made it inherit from `text-mode'
>
> - changed the news with +++
>
> - changed `emacs.texi' (is it here?) to add Markdown
>
> - scratched my head until 2:30AM thinking why it would not work for
> Jostein test.
>
>
> Well Jostein, I've been played by the tree-sitter github repository
> maintainer, lol.
>
> First, a little note. There's actually no major changes to the version
> on github. I only changed documenting strings and made some small name
> changes to more "alike" already existing modes.
>
> It happens that on tree-sitter repository, unlike any other of their
> repositories (that I've seen), "main" branch is NOT the current branch,
> but the "we moved from here bye" one.
>
> The current default branch is "split_parser" where
> tree-sitter-markdown/src/ resides, hence the confusion.
>
> So, I wrote the mode with the "main" one in mind.
>
> I already checked the "new" (split_parser) one, and it seems it is
> possible to convert the current work to use this one instead. I'll try
> to do this in the middle of the week or sooner :)
>
> In the mean time, I realized more people would like to test this patch
> and tree-sitter setup is really trick, so I made this little "guide" on
> how to apply it until the end result (this might work now, pointing to
> the "main" branch with the current patch).
>
> If you could please try the path (B) on the guide and tell me if this
> works for you, It would be nice, Jostein.
>
>
> Thanks!
>
> Rahul
>
>
>
> --- beggining of guide on how to apply this patch and test it
>
> Git apply this patch.
>
> Run the autogen script:
>
> ./autogen.sh
>
> Make sure configure uses tree-sitter:
>
> ./configure --with-tree-sitter
>
> Compile:
>
> make bootstrap
>
> Check the build:
>
> ./src/emacs -Q --version
>
> Open emacs
>
> ./src/emacs -Q --init-dir=~/tmp_emacs_dir/
>
>
> A) The Hard Way
>
> Visit a .md file
>
> C-x f TEST.md
>
> Note the mode will not automatically load.
>
> This behavior is the same as typescript-ts-mode or other
> treesitter modes I've been using.
>
> M-x markdown-ts-mode
>
> It will fail since you have no tree sitter grammar installed.
> and will suggest installing it with `treesit-install-language-grammar'.
>
> This behaviour is also standard for the tree-sitter modes I
> currently use (typescript, tsx, rust).
>
> Issuing "M-x treesit-install-language-grammar RET".
>
> It asks for language, complete with "markdown RET".
>
> It says there's no recipie for it, if you want to build it
> interactivelly. Anwser "yes".
>
> It asks for the URL where the grammar is hosted, enter:
> "https://github.com/tree-sitter-grammars/tree-sitter-markdown RET"
>
> It asks for the tag or branch, setting the default, enter "main RET".
>
> It asks for the subfolder, leave the default (src), enter "RET".
>
> It asks for the C compiler to use (default: auto-detect), just "RET".
>
> It asks for the C++ compiler to use (default: auto-detect), just "RET".
>
> Install to (default "~/tmp_emacs_dir/treesitter"), just "RET".
>
> It will clone the repository, compile the library and tell in the
> minibuffer the library is installed to your folder.
>
>
> B) The Easier Way.
>
> Copy-paste and eval this use-package definition.
>
> (use-package markdown-ts-mode
> :mode ("\\.md\\'" . markdown-ts-mode)
> :defer 't
> :config
> (add-to-list 'treesit-language-source-alist '(markdown "https://github.com/tree-sitter-grammars/tree-sitter-markdown" "main" "src")))
>
>
> Visit your markdown test file.
>
> It will probably fail due to the missing grammar.
>
> Issue "M-x treesit-install-language-grammar RET".
>
> Now with TAB it should complete "markdown", if not, type it.
>
> As we already have the source now defined, just hit "RET" to install
> to the default treemacs folder.
>
> It will clone the repository and say it installed on your folder.
>
> Just reload the mode with "M-x markdown-ts-mode".
>
> From now on (with the use-package definition on `init.el') you should
> just open .md and have the highlight and stuff.
>
> --- end of the guide
>
> From 45796df36129ec77c532b3fa21cdd0b8033c9777 Mon Sep 17 00:00:00 2001
> From: Rahul Martim Juliato <rahul.juliato@gmail.com>
> Date: Fri, 19 Apr 2024 23:21:20 -0300
> Subject: [PATCH] feat: add markdown-ts-mode
>
> * lisp/textmodes/markdown-ts-mode.el: New file.
> * doc/emacs/emacs.texi: Add Markdown to the manual
> * etc/NEWS: Announce markdown-ts-mode
> ---
> doc/emacs/emacs.texi | 1 +
> etc/NEWS | 5 ++
> lisp/textmodes/markdown-ts-mode.el | 106 +++++++++++++++++++++++++++++
> 3 files changed, 112 insertions(+)
> create mode 100644 lisp/textmodes/markdown-ts-mode.el
>
> diff --git a/doc/emacs/emacs.texi b/doc/emacs/emacs.texi
> index 7d77f13ab21..244c822ee04 100644
> --- a/doc/emacs/emacs.texi
> +++ b/doc/emacs/emacs.texi
> @@ -618,6 +618,7 @@ Top
> * Enriched Text:: Editing text enriched with fonts, colors, etc.
> * Text Based Tables:: Commands for editing text-based tables.
> * Two-Column:: Splitting text columns into separate windows.
> +* Markdown:: Major mode for editing Markdown files.
>
> Filling Text
>
> diff --git a/etc/NEWS b/etc/NEWS
> index 8ad1e78ca60..06fbaa03b55 100644
> --- a/etc/NEWS
> +++ b/etc/NEWS
> @@ -1688,6 +1688,11 @@ A major mode based on the tree-sitter library for editing Elixir files.
> *** New major mode 'lua-ts-mode'.
> A major mode based on the tree-sitter library for editing Lua files.
>
> ++++
> +*** New major mode 'markdown-ts-mode'.
> +A major mode based on the tree-sitter library for editing Markdown files.
> +
> +
> ** Minibuffer and Completions
>
> +++
> diff --git a/lisp/textmodes/markdown-ts-mode.el b/lisp/textmodes/markdown-ts-mode.el
> new file mode 100644
> index 00000000000..063780a772f
> --- /dev/null
> +++ b/lisp/textmodes/markdown-ts-mode.el
> @@ -0,0 +1,106 @@
> +;;; markdown-ts-mode.el --- tree sitter support for Markdown -*- lexical-binding: t; -*-
> +
> +;; Copyright (C) 2024 Free Software Foundation, Inc.
> +
> +;; Author : Rahul Martim Juliato <rahul.juliato@gmail.com>
> +;; Maintainer : Rahul Martim Juliato <rahul.juliato@gmail.com>
> +;; Created : April 2024
> +;; Keywords : markdown md languages tree-sitter
> +
> +;; This file is part of GNU Emacs.
> +
> +;; GNU Emacs is free software: you can redistribute it and/or modify
> +;; it under the terms of the GNU General Public License as published by
> +;; the Free Software Foundation, either version 3 of the License, or
> +;; (at your option) any later version.
> +
> +;; GNU Emacs is distributed in the hope that it will be useful,
> +;; but WITHOUT ANY WARRANTY; without even the implied warranty of
> +;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
> +;; GNU General Public License for more details.
> +
> +;; You should have received a copy of the GNU General Public License
> +;; along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
> +
> +;;; Commentary:
> +;;
You should probably briefly explain the package here.
> +;;; Code:
> +
> +(require 'treesit)
> +(require 'subr-x)
> +
> +(declare-function treesit-node-parent "treesit.c")
> +(declare-function treesit-node-type "treesit.c")
> +(declare-function treesit-parser-create "treesit.c")
> +
> +(defvar markdown-ts--treesit-settings
> + (treesit-font-lock-rules
> + :language 'markdown
> + :override t
> + :feature 'delimiter
> + '([ "[" "]" "(" ")" ] @shadow)
> +
> + :language 'markdown
> + :feature 'paragraph
> + '([((atx_heading) @font-lock-keyword-face)
> + ((block_quote_marker) @font-lock-string-face)
> + ((code_span) @font-lock-string-face)
> + ((emphasis) @underline)
> + ((image_description) @link)
> + ((indented_code_block) @font-lock-string-face)
> + ((link_destination) @font-lock-string-face)
> + ((setext_heading) @font-lock-keyword-face)
> + ((strong_emphasis) @bold)
> + ((thematic_break) @shadow)
> + (block_quote (block_quote_marker) @font-lock-string-face)
> + (block_quote (paragraph) @font-lock-string-face)
> + (fenced_code_block (code_fence_content) @font-lock-string-face)
> + (fenced_code_block (fenced_code_block_delimiter) @font-lock-doc-face)
> + (inline_link (link_destination) @font-lock-string-face)
> + (inline_link (link_text) @link)
> + (list_item (list_marker_dot) @font-lock-keyword-face)
> + (list_item (list_marker_minus) @font-lock-keyword-face)
> + (list_item (list_marker_plus) @font-lock-keyword-face)
> + (list_item (list_marker_star) @font-lock-keyword-face)
> + (shortcut_link (link_text) @link)
> + ])))
> +
> +(defun markdown-ts-imenu-node-p (node)
> + "Check if NODE is a valid entry to imenu."
> + (equal (treesit-node-type (treesit-node-parent node))
> + "atx_heading"))
> +
> +(defun markdown-ts-imenu-name-function (node)
> + "Return an imenu entry if NODE is a valid header."
> + (let ((name (treesit-node-text node)))
> + (if (markdown-ts-imenu-node-p node)
> + (thread-first (treesit-node-parent node)(treesit-node-text))
> + name)))
> +
> +(defun markdown-ts-setup ()
> + "Setup treesit for `markdown-ts-mode'."
> + (setq-local treesit-font-lock-settings markdown-ts--treesit-settings)
> + (treesit-major-mode-setup))
> +
> +;;;###autoload
> +(define-derived-mode markdown-ts-mode text-mode "Markdown"
> + "Major mode for editing Markdown using tree-sitter grammar."
> + (setq-local font-lock-defaults nil
> + treesit-font-lock-feature-list '((delimiter)
> + (paragraph)))
> +
> + (setq-local treesit-simple-imenu-settings
> + `(("Headings" markdown-ts-imenu-node-p nil markdown-ts-imenu-name-function)))
> +
> + (when (treesit-ready-p 'markdown)
> + (treesit-parser-create 'markdown)
> + (markdown-ts-setup)))
> +
> +(derived-mode-add-parents 'markdown-ts-mode '(markdown-mode))
> +
> +(if (treesit-ready-p 'markdown)
> + (add-to-list 'auto-mode-alist '("\\.md\\'" . markdown-ts-mode)))
> +
> +(provide 'markdown-ts-mode)
> +;;; markdown-ts-mode.el ends here
So if I understand correctly, there is no keymap or any convenience
features that markdown-mode provides, because this is just the
beginning, right? A large part of major modes for me is not just the
syntax highlighting and integration into Emacs systems, but also
bindings that in the case of Markdown would insert links or add/remove
emphasis. I think it would be nice, if we could add these features in
the future, and re-use bindings from a package like AucTeX to build on
existing intuition (org-mode would be an alternative, but I am not a fan
or their choice of bindings). Some commands to "compile" and preview a
document would also be nice.
--
Philip Kaludercic on peregrine
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH] feat: add markdown-ts-mode
2024-04-22 7:02 ` Philip Kaludercic
@ 2024-04-23 1:20 ` Rahul Martim Juliato
2024-04-27 10:18 ` Philip Kaludercic
0 siblings, 1 reply; 16+ messages in thread
From: Rahul Martim Juliato @ 2024-04-23 1:20 UTC (permalink / raw)
To: Philip Kaludercic, Eli Zaretskii, Jostein Kjønigsen
Cc: Rahul Martim Juliato, Yuan Fu,
Ergus via Emacs development discussions.
[-- Attachment #1: Type: text/plain, Size: 13187 bytes --]
Philip Kaludercic <philipk@posteo.net> writes:
> Rahul Martim Juliato <rahuljuliato@gmail.com> writes:
>
>> Thanks Eli and Jostein!
>>
>> No problem criticising :)
>>
>>
>> Please find a new patch attached. Things I've made:
>>
>> - changed the file to the textmodes folder
>>
>> - made it inherit from `text-mode'
>>
>> - changed the news with +++
>>
>> - changed `emacs.texi' (is it here?) to add Markdown
>>
>> - scratched my head until 2:30AM thinking why it would not work for
>> Jostein test.
>>
>>
>> Well Jostein, I've been played by the tree-sitter github repository
>> maintainer, lol.
>>
>> First, a little note. There's actually no major changes to the version
>> on github. I only changed documenting strings and made some small name
>> changes to more "alike" already existing modes.
>>
>> It happens that on tree-sitter repository, unlike any other of their
>> repositories (that I've seen), "main" branch is NOT the current branch,
>> but the "we moved from here bye" one.
>>
>> The current default branch is "split_parser" where
>> tree-sitter-markdown/src/ resides, hence the confusion.
>>
>> So, I wrote the mode with the "main" one in mind.
>>
>> I already checked the "new" (split_parser) one, and it seems it is
>> possible to convert the current work to use this one instead. I'll try
>> to do this in the middle of the week or sooner :)
>>
>> In the mean time, I realized more people would like to test this patch
>> and tree-sitter setup is really trick, so I made this little "guide" on
>> how to apply it until the end result (this might work now, pointing to
>> the "main" branch with the current patch).
>>
>> If you could please try the path (B) on the guide and tell me if this
>> works for you, It would be nice, Jostein.
>>
>>
>> Thanks!
>>
>> Rahul
>>
>>
>>
>> --- beggining of guide on how to apply this patch and test it
>>
>> Git apply this patch.
>>
>> Run the autogen script:
>>
>> ./autogen.sh
>>
>> Make sure configure uses tree-sitter:
>>
>> ./configure --with-tree-sitter
>>
>> Compile:
>>
>> make bootstrap
>>
>> Check the build:
>>
>> ./src/emacs -Q --version
>>
>> Open emacs
>>
>> ./src/emacs -Q --init-dir=~/tmp_emacs_dir/
>>
>>
>> A) The Hard Way
>>
>> Visit a .md file
>>
>> C-x f TEST.md
>>
>> Note the mode will not automatically load.
>>
>> This behavior is the same as typescript-ts-mode or other
>> treesitter modes I've been using.
>>
>> M-x markdown-ts-mode
>>
>> It will fail since you have no tree sitter grammar installed.
>> and will suggest installing it with `treesit-install-language-grammar'.
>>
>> This behaviour is also standard for the tree-sitter modes I
>> currently use (typescript, tsx, rust).
>>
>> Issuing "M-x treesit-install-language-grammar RET".
>>
>> It asks for language, complete with "markdown RET".
>>
>> It says there's no recipie for it, if you want to build it
>> interactivelly. Anwser "yes".
>>
>> It asks for the URL where the grammar is hosted, enter:
>> "https://github.com/tree-sitter-grammars/tree-sitter-markdown RET"
>>
>> It asks for the tag or branch, setting the default, enter "main RET".
>>
>> It asks for the subfolder, leave the default (src), enter "RET".
>>
>> It asks for the C compiler to use (default: auto-detect), just "RET".
>>
>> It asks for the C++ compiler to use (default: auto-detect), just "RET".
>>
>> Install to (default "~/tmp_emacs_dir/treesitter"), just "RET".
>>
>> It will clone the repository, compile the library and tell in the
>> minibuffer the library is installed to your folder.
>>
>>
>> B) The Easier Way.
>>
>> Copy-paste and eval this use-package definition.
>>
>> (use-package markdown-ts-mode
>> :mode ("\\.md\\'" . markdown-ts-mode)
>> :defer 't
>> :config
>> (add-to-list 'treesit-language-source-alist '(markdown "https://github.com/tree-sitter-grammars/tree-sitter-markdown" "main" "src")))
>>
>>
>> Visit your markdown test file.
>>
>> It will probably fail due to the missing grammar.
>>
>> Issue "M-x treesit-install-language-grammar RET".
>>
>> Now with TAB it should complete "markdown", if not, type it.
>>
>> As we already have the source now defined, just hit "RET" to install
>> to the default treemacs folder.
>>
>> It will clone the repository and say it installed on your folder.
>>
>> Just reload the mode with "M-x markdown-ts-mode".
>>
>> From now on (with the use-package definition on `init.el') you should
>> just open .md and have the highlight and stuff.
>>
>> --- end of the guide
>>
>> From 45796df36129ec77c532b3fa21cdd0b8033c9777 Mon Sep 17 00:00:00 2001
>> From: Rahul Martim Juliato <rahul.juliato@gmail.com>
>> Date: Fri, 19 Apr 2024 23:21:20 -0300
>> Subject: [PATCH] feat: add markdown-ts-mode
>>
>> * lisp/textmodes/markdown-ts-mode.el: New file.
>> * doc/emacs/emacs.texi: Add Markdown to the manual
>> * etc/NEWS: Announce markdown-ts-mode
>> ---
>> doc/emacs/emacs.texi | 1 +
>> etc/NEWS | 5 ++
>> lisp/textmodes/markdown-ts-mode.el | 106 +++++++++++++++++++++++++++++
>> 3 files changed, 112 insertions(+)
>> create mode 100644 lisp/textmodes/markdown-ts-mode.el
>>
>> diff --git a/doc/emacs/emacs.texi b/doc/emacs/emacs.texi
>> index 7d77f13ab21..244c822ee04 100644
>> --- a/doc/emacs/emacs.texi
>> +++ b/doc/emacs/emacs.texi
>> @@ -618,6 +618,7 @@ Top
>> * Enriched Text:: Editing text enriched with fonts, colors, etc.
>> * Text Based Tables:: Commands for editing text-based tables.
>> * Two-Column:: Splitting text columns into separate windows.
>> +* Markdown:: Major mode for editing Markdown files.
>>
>> Filling Text
>>
>> diff --git a/etc/NEWS b/etc/NEWS
>> index 8ad1e78ca60..06fbaa03b55 100644
>> --- a/etc/NEWS
>> +++ b/etc/NEWS
>> @@ -1688,6 +1688,11 @@ A major mode based on the tree-sitter library for editing Elixir files.
>> *** New major mode 'lua-ts-mode'.
>> A major mode based on the tree-sitter library for editing Lua files.
>>
>> ++++
>> +*** New major mode 'markdown-ts-mode'.
>> +A major mode based on the tree-sitter library for editing Markdown files.
>> +
>> +
>> ** Minibuffer and Completions
>>
>> +++
>> diff --git a/lisp/textmodes/markdown-ts-mode.el b/lisp/textmodes/markdown-ts-mode.el
>> new file mode 100644
>> index 00000000000..063780a772f
>> --- /dev/null
>> +++ b/lisp/textmodes/markdown-ts-mode.el
>> @@ -0,0 +1,106 @@
>> +;;; markdown-ts-mode.el --- tree sitter support for Markdown -*- lexical-binding: t; -*-
>> +
>> +;; Copyright (C) 2024 Free Software Foundation, Inc.
>> +
>> +;; Author : Rahul Martim Juliato <rahul.juliato@gmail.com>
>> +;; Maintainer : Rahul Martim Juliato <rahul.juliato@gmail.com>
>> +;; Created : April 2024
>> +;; Keywords : markdown md languages tree-sitter
>> +
>> +;; This file is part of GNU Emacs.
>> +
>> +;; GNU Emacs is free software: you can redistribute it and/or modify
>> +;; it under the terms of the GNU General Public License as published by
>> +;; the Free Software Foundation, either version 3 of the License, or
>> +;; (at your option) any later version.
>> +
>> +;; GNU Emacs is distributed in the hope that it will be useful,
>> +;; but WITHOUT ANY WARRANTY; without even the implied warranty of
>> +;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
>> +;; GNU General Public License for more details.
>> +
>> +;; You should have received a copy of the GNU General Public License
>> +;; along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
>> +
>> +;;; Commentary:
>> +;;
>
> You should probably briefly explain the package here.
>
>> +;;; Code:
>> +
>> +(require 'treesit)
>> +(require 'subr-x)
>> +
>> +(declare-function treesit-node-parent "treesit.c")
>> +(declare-function treesit-node-type "treesit.c")
>> +(declare-function treesit-parser-create "treesit.c")
>> +
>> +(defvar markdown-ts--treesit-settings
>> + (treesit-font-lock-rules
>> + :language 'markdown
>> + :override t
>> + :feature 'delimiter
>> + '([ "[" "]" "(" ")" ] @shadow)
>> +
>> + :language 'markdown
>> + :feature 'paragraph
>> + '([((atx_heading) @font-lock-keyword-face)
>> + ((block_quote_marker) @font-lock-string-face)
>> + ((code_span) @font-lock-string-face)
>> + ((emphasis) @underline)
>> + ((image_description) @link)
>> + ((indented_code_block) @font-lock-string-face)
>> + ((link_destination) @font-lock-string-face)
>> + ((setext_heading) @font-lock-keyword-face)
>> + ((strong_emphasis) @bold)
>> + ((thematic_break) @shadow)
>> + (block_quote (block_quote_marker) @font-lock-string-face)
>> + (block_quote (paragraph) @font-lock-string-face)
>> + (fenced_code_block (code_fence_content) @font-lock-string-face)
>> + (fenced_code_block (fenced_code_block_delimiter) @font-lock-doc-face)
>> + (inline_link (link_destination) @font-lock-string-face)
>> + (inline_link (link_text) @link)
>> + (list_item (list_marker_dot) @font-lock-keyword-face)
>> + (list_item (list_marker_minus) @font-lock-keyword-face)
>> + (list_item (list_marker_plus) @font-lock-keyword-face)
>> + (list_item (list_marker_star) @font-lock-keyword-face)
>> + (shortcut_link (link_text) @link)
>> + ])))
>> +
>> +(defun markdown-ts-imenu-node-p (node)
>> + "Check if NODE is a valid entry to imenu."
>> + (equal (treesit-node-type (treesit-node-parent node))
>> + "atx_heading"))
>> +
>> +(defun markdown-ts-imenu-name-function (node)
>> + "Return an imenu entry if NODE is a valid header."
>> + (let ((name (treesit-node-text node)))
>> + (if (markdown-ts-imenu-node-p node)
>> + (thread-first (treesit-node-parent node)(treesit-node-text))
>> + name)))
>> +
>> +(defun markdown-ts-setup ()
>> + "Setup treesit for `markdown-ts-mode'."
>> + (setq-local treesit-font-lock-settings markdown-ts--treesit-settings)
>> + (treesit-major-mode-setup))
>> +
>> +;;;###autoload
>> +(define-derived-mode markdown-ts-mode text-mode "Markdown"
>> + "Major mode for editing Markdown using tree-sitter grammar."
>> + (setq-local font-lock-defaults nil
>> + treesit-font-lock-feature-list '((delimiter)
>> + (paragraph)))
>> +
>> + (setq-local treesit-simple-imenu-settings
>> + `(("Headings" markdown-ts-imenu-node-p nil markdown-ts-imenu-name-function)))
>> +
>> + (when (treesit-ready-p 'markdown)
>> + (treesit-parser-create 'markdown)
>> + (markdown-ts-setup)))
>> +
>> +(derived-mode-add-parents 'markdown-ts-mode '(markdown-mode))
>> +
>> +(if (treesit-ready-p 'markdown)
>> + (add-to-list 'auto-mode-alist '("\\.md\\'" . markdown-ts-mode)))
>> +
>> +(provide 'markdown-ts-mode)
>> +;;; markdown-ts-mode.el ends here
>
> So if I understand correctly, there is no keymap or any convenience
> features that markdown-mode provides, because this is just the
> beginning, right? A large part of major modes for me is not just the
> syntax highlighting and integration into Emacs systems, but also
> bindings that in the case of Markdown would insert links or add/remove
> emphasis. I think it would be nice, if we could add these features in
> the future, and re-use bindings from a package like AucTeX to build on
> existing intuition (org-mode would be an alternative, but I am not a fan
> or their choice of bindings). Some commands to "compile" and preview a
> document would also be nice.
Hello there again!
Please find attached the current version of this patch.
It now works with the "official" tree-sitter grammar for markdown:
https://github.com/tree-sitter-grammars/tree-sitter-markdown
Please note (as explained above) the `main branch' is not the default
anymore, but `split_parser' is.
They splitted the parser into two, one for the body of the document and
another to inline.
So, in order to test this patch, configure it with:
(use-package markdown-ts-mode
:ensure nil
:defer t
:mode ("\\.md\\'" . markdown-ts-mode)
:config
(add-to-list 'treesit-language-source-alist '(markdown "https://github.com/tree-sitter-grammars/tree-sitter-markdown" "split_parser" "tree-sitter-markdown/src"))
(add-to-list 'treesit-language-source-alist '(markdown-inline "https://github.com/tree-sitter-grammars/tree-sitter-markdown" "split_parser" "tree-sitter-markdown-inline/src")))
If you visit a markdown file treesit issues an error, as always, asking
for the grammars.
Then, install BOTH grammars:
M-x treesit-install-language-grammar RET markdown RET
M-x treesit-install-language-grammar RET markdown-inline RET
Reload the `markdown-ts-mode'.
And everything should be working fine :)
@Philip, thanks for bringing that up! I completely agree with you;
aiming for a fully-featured mode is our long-term objective.
The idea here is to establish a foundation for supporting markdown files
within Emacs, without relying on external packages.
From there, we can delve into discussions about editing and exporting
features. For instance, we could consider mimicking bindings and prompts
from org-mode, as well as exploring integrations if users opt to also
utilize third-party markdown-mode.
However, simply having the mode built-in reduces friction significantly
for new ideas and collaborations :)
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: 0001-feat-add-markdown-ts-mode.patch --]
[-- Type: text/x-diff, Size: 5872 bytes --]
From a1d071285b3ea989f8722b0b2915cf881b59b84c Mon Sep 17 00:00:00 2001
From: Rahul Martim Juliato <rahul.juliato@gmail.com>
Date: Fri, 19 Apr 2024 23:21:20 -0300
Subject: [PATCH] feat: add markdown-ts-mode
* lisp/textmodes/markdown-ts-mode.el: New file
* doc/emacs/emacs.texi: Add Markdown to the manual
* etc/NEWS: Announce markdown-ts-mode
---
doc/emacs/emacs.texi | 1 +
etc/NEWS | 5 ++
lisp/textmodes/markdown-ts-mode.el | 113 +++++++++++++++++++++++++++++
3 files changed, 119 insertions(+)
create mode 100644 lisp/textmodes/markdown-ts-mode.el
diff --git a/doc/emacs/emacs.texi b/doc/emacs/emacs.texi
index 7d77f13ab21..244c822ee04 100644
--- a/doc/emacs/emacs.texi
+++ b/doc/emacs/emacs.texi
@@ -618,6 +618,7 @@ Top
* Enriched Text:: Editing text enriched with fonts, colors, etc.
* Text Based Tables:: Commands for editing text-based tables.
* Two-Column:: Splitting text columns into separate windows.
+* Markdown:: Major mode for editing Markdown files.
Filling Text
diff --git a/etc/NEWS b/etc/NEWS
index 8ad1e78ca60..06fbaa03b55 100644
--- a/etc/NEWS
+++ b/etc/NEWS
@@ -1688,6 +1688,11 @@ A major mode based on the tree-sitter library for editing Elixir files.
*** New major mode 'lua-ts-mode'.
A major mode based on the tree-sitter library for editing Lua files.
++++
+*** New major mode 'markdown-ts-mode'.
+A major mode based on the tree-sitter library for editing Markdown files.
+
+
** Minibuffer and Completions
+++
diff --git a/lisp/textmodes/markdown-ts-mode.el b/lisp/textmodes/markdown-ts-mode.el
new file mode 100644
index 00000000000..49fe1baf011
--- /dev/null
+++ b/lisp/textmodes/markdown-ts-mode.el
@@ -0,0 +1,113 @@
+;;; markdown-ts-mode.el --- tree sitter support for Markdown -*- lexical-binding: t; -*-
+
+;; Copyright (C) 2024 Free Software Foundation, Inc.
+
+;; Author : Rahul Martim Juliato <rahul.juliato@gmail.com>
+;; Maintainer : Rahul Martim Juliato <rahul.juliato@gmail.com>
+;; Created : April 2024
+;; Keywords : markdown md languages tree-sitter
+
+;; This file is part of GNU Emacs.
+
+;; GNU Emacs is free software: you can redistribute it and/or modify
+;; it under the terms of the GNU General Public License as published by
+;; the Free Software Foundation, either version 3 of the License, or
+;; (at your option) any later version.
+
+;; GNU Emacs is distributed in the hope that it will be useful,
+;; but WITHOUT ANY WARRANTY; without even the implied warranty of
+;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+;; GNU General Public License for more details.
+
+;; You should have received a copy of the GNU General Public License
+;; along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
+
+;;; Commentary:
+;;
+
+;;; Code:
+
+(require 'treesit)
+(require 'subr-x)
+
+(declare-function treesit-node-parent "treesit.c")
+(declare-function treesit-node-type "treesit.c")
+(declare-function treesit-parser-create "treesit.c")
+
+(defvar markdown-ts--treesit-settings
+ (treesit-font-lock-rules
+ :language 'markdown
+ :override t
+ :feature 'delimiter
+ '([ "[" "]" "(" ")" ] @shadow)
+
+
+ :language 'markdown
+ :feature 'paragraph
+ '([((setext_heading) @font-lock-keyword-face)
+ ((atx_heading) @font-lock-keyword-face)
+ ((thematic_break) @shadow)
+ ((indented_code_block) @font-lock-string-face)
+ (list_item (list_marker_star) @font-lock-keyword-face)
+ (list_item (list_marker_plus) @font-lock-keyword-face)
+ (list_item (list_marker_minus) @font-lock-keyword-face)
+ (list_item (list_marker_dot) @font-lock-keyword-face)
+ (fenced_code_block (fenced_code_block_delimiter) @font-lock-doc-face)
+ (fenced_code_block (code_fence_content) @font-lock-string-face)
+ ((block_quote_marker) @font-lock-string-face)
+ (block_quote (paragraph) @font-lock-string-face)
+ (block_quote (block_quote_marker) @font-lock-string-face)
+ ])
+
+ :language 'markdown-inline
+ :feature 'paragraph-inline
+ '([
+ ((image_description) @link)
+ ((link_destination) @font-lock-string-face)
+ ((code_span) @font-lock-string-face)
+ ((emphasis) @underline)
+ ((strong_emphasis) @bold)
+ (inline_link (link_text) @link)
+ (inline_link (link_destination) @font-lock-string-face)
+ (shortcut_link (link_text) @link)])))
+
+(defun markdown-ts-imenu-node-p (node)
+ "Check if NODE is a valid entry to imenu."
+ (equal (treesit-node-type (treesit-node-parent node))
+ "atx_heading"))
+
+(defun markdown-ts-imenu-name-function (node)
+ "Return an imenu entry if NODE is a valid header."
+ (let ((name (treesit-node-text node)))
+ (if (markdown-ts-imenu-node-p node)
+ (thread-first (treesit-node-parent node)(treesit-node-text))
+ name)))
+
+(defun markdown-ts-setup ()
+ "Setup treesit for `markdown-ts-mode'."
+ (setq-local treesit-font-lock-settings markdown-ts--treesit-settings)
+ (treesit-major-mode-setup))
+
+;;;###autoload
+(define-derived-mode markdown-ts-mode text-mode "Markdown"
+ "Major mode for editing Markdown using tree-sitter grammar."
+ (setq-local font-lock-defaults nil
+ treesit-font-lock-feature-list '((delimiter)
+ (paragraph)
+ (paragraph-inline)))
+
+ (setq-local treesit-simple-imenu-settings
+ `(("Headings" markdown-ts-imenu-node-p nil markdown-ts-imenu-name-function)))
+
+ (when (treesit-ready-p 'markdown)
+ (treesit-parser-create 'markdown-inline)
+ (treesit-parser-create 'markdown)
+ (markdown-ts-setup)))
+
+(derived-mode-add-parents 'markdown-ts-mode '(markdown-mode))
+
+(if (treesit-ready-p 'markdown)
+ (add-to-list 'auto-mode-alist '("\\.md\\'" . markdown-ts-mode)))
+
+(provide 'markdown-ts-mode)
+;;; markdown-ts-mode.el ends here
--
2.39.2
^ permalink raw reply related [flat|nested] 16+ messages in thread
* Re: [PATCH] feat: add markdown-ts-mode
2024-04-23 1:20 ` Rahul Martim Juliato
@ 2024-04-27 10:18 ` Philip Kaludercic
2024-06-29 2:09 ` Rahul Martim Juliato
0 siblings, 1 reply; 16+ messages in thread
From: Philip Kaludercic @ 2024-04-27 10:18 UTC (permalink / raw)
To: Rahul Martim Juliato
Cc: Eli Zaretskii, Jostein Kjønigsen, Yuan Fu,
Ergus via Emacs development discussions.
Rahul Martim Juliato <rahuljuliato@gmail.com> writes:
>> So if I understand correctly, there is no keymap or any convenience
>> features that markdown-mode provides, because this is just the
>> beginning, right? A large part of major modes for me is not just the
>> syntax highlighting and integration into Emacs systems, but also
>> bindings that in the case of Markdown would insert links or add/remove
>> emphasis. I think it would be nice, if we could add these features in
>> the future, and re-use bindings from a package like AucTeX to build on
>> existing intuition (org-mode would be an alternative, but I am not a fan
>> or their choice of bindings). Some commands to "compile" and preview a
>> document would also be nice.
>
>
> Hello there again!
>
> Please find attached the current version of this patch.
>
> It now works with the "official" tree-sitter grammar for markdown:
> https://github.com/tree-sitter-grammars/tree-sitter-markdown
>
> Please note (as explained above) the `main branch' is not the default
> anymore, but `split_parser' is.
>
> They splitted the parser into two, one for the body of the document and
> another to inline.
>
> So, in order to test this patch, configure it with:
>
> (use-package markdown-ts-mode
> :ensure nil
> :defer t
> :mode ("\\.md\\'" . markdown-ts-mode)
> :config
> (add-to-list 'treesit-language-source-alist '(markdown
> "https://github.com/tree-sitter-grammars/tree-sitter-markdown"
> "split_parser" "tree-sitter-markdown/src"))
> (add-to-list 'treesit-language-source-alist '(markdown-inline
> "https://github.com/tree-sitter-grammars/tree-sitter-markdown"
> "split_parser" "tree-sitter-markdown-inline/src")))
I have said this before, and will say it again,
`treesit-language-source-alist' shouldn't clone moving git repositories
but download tarballs (which basically every git host provides as a
feature, since git archive is built-in) and use those to build the
library. These tarballs should be pinned in the -ts-mode.el files
themselves to make using these major modes more reliable.
> If you visit a markdown file treesit issues an error, as always, asking
> for the grammars.
>
> Then, install BOTH grammars:
>
> M-x treesit-install-language-grammar RET markdown RET
> M-x treesit-install-language-grammar RET markdown-inline RET
>
> Reload the `markdown-ts-mode'.
>
> And everything should be working fine :)
>
>
> @Philip, thanks for bringing that up! I completely agree with you;
> aiming for a fully-featured mode is our long-term objective.
>
> The idea here is to establish a foundation for supporting markdown files
> within Emacs, without relying on external packages.
That sounds good.
> From there, we can delve into discussions about editing and exporting
> features. For instance, we could consider mimicking bindings and prompts
> from org-mode, as well as exploring integrations if users opt to also
> utilize third-party markdown-mode.
I would be interested in helping out or at the very least to comment on
the development going on, since I had started writing the same mode
myself a while back, but never got around to it since because I don't
understand how `treesit-font-lock-rules' works.
> However, simply having the mode built-in reduces friction significantly
> for new ideas and collaborations :)
And makes it easier for external packages to rely on the code. Usually
I'd also say that it makes Emacs more usable in offline environments,
but the fact that the tree-sitter grammars have to for now be downloaded
stands in the way of that :/
--
Philip Kaludercic on peregrine
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH] feat: add markdown-ts-mode
2024-04-27 10:18 ` Philip Kaludercic
@ 2024-06-29 2:09 ` Rahul Martim Juliato
2024-07-03 19:13 ` Rahul Martim Juliato
0 siblings, 1 reply; 16+ messages in thread
From: Rahul Martim Juliato @ 2024-06-29 2:09 UTC (permalink / raw)
To: Philip Kaludercic
Cc: Rahul Martim Juliato, Eli Zaretskii, Jostein Kjønigsen,
Yuan Fu, Ergus via Emacs development discussions.
[-- Attachment #1: Type: text/plain, Size: 4414 bytes --]
Philip Kaludercic <philipk@posteo.net> writes:
> Rahul Martim Juliato <rahuljuliato@gmail.com> writes:
>
>>> So if I understand correctly, there is no keymap or any convenience
>>> features that markdown-mode provides, because this is just the
>>> beginning, right? A large part of major modes for me is not just the
>>> syntax highlighting and integration into Emacs systems, but also
>>> bindings that in the case of Markdown would insert links or add/remove
>>> emphasis. I think it would be nice, if we could add these features in
>>> the future, and re-use bindings from a package like AucTeX to build on
>>> existing intuition (org-mode would be an alternative, but I am not a fan
>>> or their choice of bindings). Some commands to "compile" and preview a
>>> document would also be nice.
>>
>>
>> Hello there again!
>>
>> Please find attached the current version of this patch.
>>
>> It now works with the "official" tree-sitter grammar for markdown:
>> https://github.com/tree-sitter-grammars/tree-sitter-markdown
>>
>> Please note (as explained above) the `main branch' is not the default
>> anymore, but `split_parser' is.
>>
>> They splitted the parser into two, one for the body of the document and
>> another to inline.
>>
>> So, in order to test this patch, configure it with:
>>
>> (use-package markdown-ts-mode
>> :ensure nil
>> :defer t
>> :mode ("\\.md\\'" . markdown-ts-mode)
>> :config
>> (add-to-list 'treesit-language-source-alist '(markdown
>> "https://github.com/tree-sitter-grammars/tree-sitter-markdown"
>> "split_parser" "tree-sitter-markdown/src"))
>> (add-to-list 'treesit-language-source-alist '(markdown-inline
>> "https://github.com/tree-sitter-grammars/tree-sitter-markdown"
>> "split_parser" "tree-sitter-markdown-inline/src")))
>
> I have said this before, and will say it again,
> `treesit-language-source-alist' shouldn't clone moving git repositories
> but download tarballs (which basically every git host provides as a
> feature, since git archive is built-in) and use those to build the
> library. These tarballs should be pinned in the -ts-mode.el files
> themselves to make using these major modes more reliable.
>
This is a problem with all TS modes, isnt it? Or did I do something
wrong on my patch?
>> If you visit a markdown file treesit issues an error, as always, asking
>> for the grammars.
>>
>> Then, install BOTH grammars:
>>
>> M-x treesit-install-language-grammar RET markdown RET
>> M-x treesit-install-language-grammar RET markdown-inline RET
>>
>> Reload the `markdown-ts-mode'.
>>
>> And everything should be working fine :)
>>
>>
>> @Philip, thanks for bringing that up! I completely agree with you;
>> aiming for a fully-featured mode is our long-term objective.
>>
>> The idea here is to establish a foundation for supporting markdown files
>> within Emacs, without relying on external packages.
>
> That sounds good.
>
>> From there, we can delve into discussions about editing and exporting
>> features. For instance, we could consider mimicking bindings and prompts
>> from org-mode, as well as exploring integrations if users opt to also
>> utilize third-party markdown-mode.
>
> I would be interested in helping out or at the very least to comment on
> the development going on, since I had started writing the same mode
> myself a while back, but never got around to it since because I don't
> understand how `treesit-font-lock-rules' works.
>
>> However, simply having the mode built-in reduces friction significantly
>> for new ideas and collaborations :)
>
> And makes it easier for external packages to rely on the code. Usually
> I'd also say that it makes Emacs more usable in offline environments,
> but the fact that the tree-sitter grammars have to for now be downloaded
> stands in the way of that :/
I agree with you Philip it is more usable in offline environments, but
as all tree-sitter modes, they depend on those external libraries. But I
have to say, I've been looking some distros including those libraries on
their package repositories, so it should reduce (hopefully) some
friction with it.
---
Sorry for the long hiatus on this thread. I was actually waiting for
more discussions but many cooler topics (and also life) got in the way :)
I haven't made any changes on my last patch, but I am attaching it here
to sync with this message.
So is there anything else I could do about it?
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: markdown-ts-mode --]
[-- Type: text/x-diff, Size: 5872 bytes --]
From a1d071285b3ea989f8722b0b2915cf881b59b84c Mon Sep 17 00:00:00 2001
From: Rahul Martim Juliato <rahul.juliato@gmail.com>
Date: Fri, 19 Apr 2024 23:21:20 -0300
Subject: [PATCH] feat: add markdown-ts-mode
* lisp/textmodes/markdown-ts-mode.el: New file
* doc/emacs/emacs.texi: Add Markdown to the manual
* etc/NEWS: Announce markdown-ts-mode
---
doc/emacs/emacs.texi | 1 +
etc/NEWS | 5 ++
lisp/textmodes/markdown-ts-mode.el | 113 +++++++++++++++++++++++++++++
3 files changed, 119 insertions(+)
create mode 100644 lisp/textmodes/markdown-ts-mode.el
diff --git a/doc/emacs/emacs.texi b/doc/emacs/emacs.texi
index 7d77f13ab21..244c822ee04 100644
--- a/doc/emacs/emacs.texi
+++ b/doc/emacs/emacs.texi
@@ -618,6 +618,7 @@ Top
* Enriched Text:: Editing text enriched with fonts, colors, etc.
* Text Based Tables:: Commands for editing text-based tables.
* Two-Column:: Splitting text columns into separate windows.
+* Markdown:: Major mode for editing Markdown files.
Filling Text
diff --git a/etc/NEWS b/etc/NEWS
index 8ad1e78ca60..06fbaa03b55 100644
--- a/etc/NEWS
+++ b/etc/NEWS
@@ -1688,6 +1688,11 @@ A major mode based on the tree-sitter library for editing Elixir files.
*** New major mode 'lua-ts-mode'.
A major mode based on the tree-sitter library for editing Lua files.
++++
+*** New major mode 'markdown-ts-mode'.
+A major mode based on the tree-sitter library for editing Markdown files.
+
+
** Minibuffer and Completions
+++
diff --git a/lisp/textmodes/markdown-ts-mode.el b/lisp/textmodes/markdown-ts-mode.el
new file mode 100644
index 00000000000..49fe1baf011
--- /dev/null
+++ b/lisp/textmodes/markdown-ts-mode.el
@@ -0,0 +1,113 @@
+;;; markdown-ts-mode.el --- tree sitter support for Markdown -*- lexical-binding: t; -*-
+
+;; Copyright (C) 2024 Free Software Foundation, Inc.
+
+;; Author : Rahul Martim Juliato <rahul.juliato@gmail.com>
+;; Maintainer : Rahul Martim Juliato <rahul.juliato@gmail.com>
+;; Created : April 2024
+;; Keywords : markdown md languages tree-sitter
+
+;; This file is part of GNU Emacs.
+
+;; GNU Emacs is free software: you can redistribute it and/or modify
+;; it under the terms of the GNU General Public License as published by
+;; the Free Software Foundation, either version 3 of the License, or
+;; (at your option) any later version.
+
+;; GNU Emacs is distributed in the hope that it will be useful,
+;; but WITHOUT ANY WARRANTY; without even the implied warranty of
+;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+;; GNU General Public License for more details.
+
+;; You should have received a copy of the GNU General Public License
+;; along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
+
+;;; Commentary:
+;;
+
+;;; Code:
+
+(require 'treesit)
+(require 'subr-x)
+
+(declare-function treesit-node-parent "treesit.c")
+(declare-function treesit-node-type "treesit.c")
+(declare-function treesit-parser-create "treesit.c")
+
+(defvar markdown-ts--treesit-settings
+ (treesit-font-lock-rules
+ :language 'markdown
+ :override t
+ :feature 'delimiter
+ '([ "[" "]" "(" ")" ] @shadow)
+
+
+ :language 'markdown
+ :feature 'paragraph
+ '([((setext_heading) @font-lock-keyword-face)
+ ((atx_heading) @font-lock-keyword-face)
+ ((thematic_break) @shadow)
+ ((indented_code_block) @font-lock-string-face)
+ (list_item (list_marker_star) @font-lock-keyword-face)
+ (list_item (list_marker_plus) @font-lock-keyword-face)
+ (list_item (list_marker_minus) @font-lock-keyword-face)
+ (list_item (list_marker_dot) @font-lock-keyword-face)
+ (fenced_code_block (fenced_code_block_delimiter) @font-lock-doc-face)
+ (fenced_code_block (code_fence_content) @font-lock-string-face)
+ ((block_quote_marker) @font-lock-string-face)
+ (block_quote (paragraph) @font-lock-string-face)
+ (block_quote (block_quote_marker) @font-lock-string-face)
+ ])
+
+ :language 'markdown-inline
+ :feature 'paragraph-inline
+ '([
+ ((image_description) @link)
+ ((link_destination) @font-lock-string-face)
+ ((code_span) @font-lock-string-face)
+ ((emphasis) @underline)
+ ((strong_emphasis) @bold)
+ (inline_link (link_text) @link)
+ (inline_link (link_destination) @font-lock-string-face)
+ (shortcut_link (link_text) @link)])))
+
+(defun markdown-ts-imenu-node-p (node)
+ "Check if NODE is a valid entry to imenu."
+ (equal (treesit-node-type (treesit-node-parent node))
+ "atx_heading"))
+
+(defun markdown-ts-imenu-name-function (node)
+ "Return an imenu entry if NODE is a valid header."
+ (let ((name (treesit-node-text node)))
+ (if (markdown-ts-imenu-node-p node)
+ (thread-first (treesit-node-parent node)(treesit-node-text))
+ name)))
+
+(defun markdown-ts-setup ()
+ "Setup treesit for `markdown-ts-mode'."
+ (setq-local treesit-font-lock-settings markdown-ts--treesit-settings)
+ (treesit-major-mode-setup))
+
+;;;###autoload
+(define-derived-mode markdown-ts-mode text-mode "Markdown"
+ "Major mode for editing Markdown using tree-sitter grammar."
+ (setq-local font-lock-defaults nil
+ treesit-font-lock-feature-list '((delimiter)
+ (paragraph)
+ (paragraph-inline)))
+
+ (setq-local treesit-simple-imenu-settings
+ `(("Headings" markdown-ts-imenu-node-p nil markdown-ts-imenu-name-function)))
+
+ (when (treesit-ready-p 'markdown)
+ (treesit-parser-create 'markdown-inline)
+ (treesit-parser-create 'markdown)
+ (markdown-ts-setup)))
+
+(derived-mode-add-parents 'markdown-ts-mode '(markdown-mode))
+
+(if (treesit-ready-p 'markdown)
+ (add-to-list 'auto-mode-alist '("\\.md\\'" . markdown-ts-mode)))
+
+(provide 'markdown-ts-mode)
+;;; markdown-ts-mode.el ends here
--
2.39.2
^ permalink raw reply related [flat|nested] 16+ messages in thread
* Re: [PATCH] feat: add markdown-ts-mode
2024-06-29 2:09 ` Rahul Martim Juliato
@ 2024-07-03 19:13 ` Rahul Martim Juliato
2024-07-03 20:13 ` Stefan Kangas
2024-07-04 5:08 ` Eli Zaretskii
0 siblings, 2 replies; 16+ messages in thread
From: Rahul Martim Juliato @ 2024-07-03 19:13 UTC (permalink / raw)
To: Rahul Martim Juliato; +Cc: emacs-devel
[-- Attachment #1: Type: text/plain, Size: 527 bytes --]
Hello there!
Following up on the April thread:
https://lists.gnu.org/archive/html/emacs-devel/2024-04/msg00746.html
And the June thread:
https://lists.gnu.org/archive/html/emacs-devel/2024-06/msg01061.html
I noticed the move to the Emacs 30 branch is already underway. However,
I have not received any feedback on my patch, which has left me in the
dark about its status.
Could you please provide your insights or suggestions on the patch? Your
feedback is crucial for moving this forward.
Best regards,
Rahul M. Juliato
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: 0001-feat-add-markdown-ts-mode.patch --]
[-- Type: text/x-diff, Size: 5873 bytes --]
>From a1d071285b3ea989f8722b0b2915cf881b59b84c Mon Sep 17 00:00:00 2001
From: Rahul Martim Juliato <rahul.juliato@gmail.com>
Date: Fri, 19 Apr 2024 23:21:20 -0300
Subject: [PATCH] feat: add markdown-ts-mode
* lisp/textmodes/markdown-ts-mode.el: New file
* doc/emacs/emacs.texi: Add Markdown to the manual
* etc/NEWS: Announce markdown-ts-mode
---
doc/emacs/emacs.texi | 1 +
etc/NEWS | 5 ++
lisp/textmodes/markdown-ts-mode.el | 113 +++++++++++++++++++++++++++++
3 files changed, 119 insertions(+)
create mode 100644 lisp/textmodes/markdown-ts-mode.el
diff --git a/doc/emacs/emacs.texi b/doc/emacs/emacs.texi
index 7d77f13ab21..244c822ee04 100644
--- a/doc/emacs/emacs.texi
+++ b/doc/emacs/emacs.texi
@@ -618,6 +618,7 @@ Top
* Enriched Text:: Editing text enriched with fonts, colors, etc.
* Text Based Tables:: Commands for editing text-based tables.
* Two-Column:: Splitting text columns into separate windows.
+* Markdown:: Major mode for editing Markdown files.
Filling Text
diff --git a/etc/NEWS b/etc/NEWS
index 8ad1e78ca60..06fbaa03b55 100644
--- a/etc/NEWS
+++ b/etc/NEWS
@@ -1688,6 +1688,11 @@ A major mode based on the tree-sitter library for editing Elixir files.
*** New major mode 'lua-ts-mode'.
A major mode based on the tree-sitter library for editing Lua files.
++++
+*** New major mode 'markdown-ts-mode'.
+A major mode based on the tree-sitter library for editing Markdown files.
+
+
** Minibuffer and Completions
+++
diff --git a/lisp/textmodes/markdown-ts-mode.el b/lisp/textmodes/markdown-ts-mode.el
new file mode 100644
index 00000000000..49fe1baf011
--- /dev/null
+++ b/lisp/textmodes/markdown-ts-mode.el
@@ -0,0 +1,113 @@
+;;; markdown-ts-mode.el --- tree sitter support for Markdown -*- lexical-binding: t; -*-
+
+;; Copyright (C) 2024 Free Software Foundation, Inc.
+
+;; Author : Rahul Martim Juliato <rahul.juliato@gmail.com>
+;; Maintainer : Rahul Martim Juliato <rahul.juliato@gmail.com>
+;; Created : April 2024
+;; Keywords : markdown md languages tree-sitter
+
+;; This file is part of GNU Emacs.
+
+;; GNU Emacs is free software: you can redistribute it and/or modify
+;; it under the terms of the GNU General Public License as published by
+;; the Free Software Foundation, either version 3 of the License, or
+;; (at your option) any later version.
+
+;; GNU Emacs is distributed in the hope that it will be useful,
+;; but WITHOUT ANY WARRANTY; without even the implied warranty of
+;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+;; GNU General Public License for more details.
+
+;; You should have received a copy of the GNU General Public License
+;; along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>.
+
+;;; Commentary:
+;;
+
+;;; Code:
+
+(require 'treesit)
+(require 'subr-x)
+
+(declare-function treesit-node-parent "treesit.c")
+(declare-function treesit-node-type "treesit.c")
+(declare-function treesit-parser-create "treesit.c")
+
+(defvar markdown-ts--treesit-settings
+ (treesit-font-lock-rules
+ :language 'markdown
+ :override t
+ :feature 'delimiter
+ '([ "[" "]" "(" ")" ] @shadow)
+
+
+ :language 'markdown
+ :feature 'paragraph
+ '([((setext_heading) @font-lock-keyword-face)
+ ((atx_heading) @font-lock-keyword-face)
+ ((thematic_break) @shadow)
+ ((indented_code_block) @font-lock-string-face)
+ (list_item (list_marker_star) @font-lock-keyword-face)
+ (list_item (list_marker_plus) @font-lock-keyword-face)
+ (list_item (list_marker_minus) @font-lock-keyword-face)
+ (list_item (list_marker_dot) @font-lock-keyword-face)
+ (fenced_code_block (fenced_code_block_delimiter) @font-lock-doc-face)
+ (fenced_code_block (code_fence_content) @font-lock-string-face)
+ ((block_quote_marker) @font-lock-string-face)
+ (block_quote (paragraph) @font-lock-string-face)
+ (block_quote (block_quote_marker) @font-lock-string-face)
+ ])
+
+ :language 'markdown-inline
+ :feature 'paragraph-inline
+ '([
+ ((image_description) @link)
+ ((link_destination) @font-lock-string-face)
+ ((code_span) @font-lock-string-face)
+ ((emphasis) @underline)
+ ((strong_emphasis) @bold)
+ (inline_link (link_text) @link)
+ (inline_link (link_destination) @font-lock-string-face)
+ (shortcut_link (link_text) @link)])))
+
+(defun markdown-ts-imenu-node-p (node)
+ "Check if NODE is a valid entry to imenu."
+ (equal (treesit-node-type (treesit-node-parent node))
+ "atx_heading"))
+
+(defun markdown-ts-imenu-name-function (node)
+ "Return an imenu entry if NODE is a valid header."
+ (let ((name (treesit-node-text node)))
+ (if (markdown-ts-imenu-node-p node)
+ (thread-first (treesit-node-parent node)(treesit-node-text))
+ name)))
+
+(defun markdown-ts-setup ()
+ "Setup treesit for `markdown-ts-mode'."
+ (setq-local treesit-font-lock-settings markdown-ts--treesit-settings)
+ (treesit-major-mode-setup))
+
+;;;###autoload
+(define-derived-mode markdown-ts-mode text-mode "Markdown"
+ "Major mode for editing Markdown using tree-sitter grammar."
+ (setq-local font-lock-defaults nil
+ treesit-font-lock-feature-list '((delimiter)
+ (paragraph)
+ (paragraph-inline)))
+
+ (setq-local treesit-simple-imenu-settings
+ `(("Headings" markdown-ts-imenu-node-p nil markdown-ts-imenu-name-function)))
+
+ (when (treesit-ready-p 'markdown)
+ (treesit-parser-create 'markdown-inline)
+ (treesit-parser-create 'markdown)
+ (markdown-ts-setup)))
+
+(derived-mode-add-parents 'markdown-ts-mode '(markdown-mode))
+
+(if (treesit-ready-p 'markdown)
+ (add-to-list 'auto-mode-alist '("\\.md\\'" . markdown-ts-mode)))
+
+(provide 'markdown-ts-mode)
+;;; markdown-ts-mode.el ends here
--
2.39.2
[-- Attachment #3: Type: text/plain, Size: 4537 bytes --]
> Philip Kaludercic <philipk@posteo.net> writes:
>> Rahul Martim Juliato <rahuljuliato@gmail.com> writes:
>>
>>>> So if I understand correctly, there is no keymap or any convenience
>>>> features that markdown-mode provides, because this is just the
>>>> beginning, right? A large part of major modes for me is not just the
>>>> syntax highlighting and integration into Emacs systems, but also
>>>> bindings that in the case of Markdown would insert links or add/remove
>>>> emphasis. I think it would be nice, if we could add these features in
>>>> the future, and re-use bindings from a package like AucTeX to build on
>>>> existing intuition (org-mode would be an alternative, but I am not a fan
>>>> or their choice of bindings). Some commands to "compile" and preview a
>>>> document would also be nice.
>>>
>>>
>>> Hello there again!
>>>
>>> Please find attached the current version of this patch.
>>>
>>> It now works with the "official" tree-sitter grammar for markdown:
>>> https://github.com/tree-sitter-grammars/tree-sitter-markdown
>>>
>>> Please note (as explained above) the `main branch' is not the default
>>> anymore, but `split_parser' is.
>>>
>>> They splitted the parser into two, one for the body of the document and
>>> another to inline.
>>>
>>> So, in order to test this patch, configure it with:
>>>
>>> (use-package markdown-ts-mode
>>> :ensure nil
>>> :defer t
>>> :mode ("\\.md\\'" . markdown-ts-mode)
>>> :config
>>> (add-to-list 'treesit-language-source-alist '(markdown
>>> "https://github.com/tree-sitter-grammars/tree-sitter-markdown"
>>> "split_parser" "tree-sitter-markdown/src"))
>>> (add-to-list 'treesit-language-source-alist '(markdown-inline
>>> "https://github.com/tree-sitter-grammars/tree-sitter-markdown"
>>> "split_parser" "tree-sitter-markdown-inline/src")))
>>
>> I have said this before, and will say it again,
>> `treesit-language-source-alist' shouldn't clone moving git repositories
>> but download tarballs (which basically every git host provides as a
>> feature, since git archive is built-in) and use those to build the
>> library. These tarballs should be pinned in the -ts-mode.el files
>> themselves to make using these major modes more reliable.
>>
>
> This is a problem with all TS modes, isnt it? Or did I do something
> wrong on my patch?
>
>>> If you visit a markdown file treesit issues an error, as always, asking
>>> for the grammars.
>>>
>>> Then, install BOTH grammars:
>>>
>>> M-x treesit-install-language-grammar RET markdown RET
>>> M-x treesit-install-language-grammar RET markdown-inline RET
>>>
>>> Reload the `markdown-ts-mode'.
>>>
>>> And everything should be working fine :)
>>>
>>>
>>> @Philip, thanks for bringing that up! I completely agree with you;
>>> aiming for a fully-featured mode is our long-term objective.
>>>
>>> The idea here is to establish a foundation for supporting markdown files
>>> within Emacs, without relying on external packages.
>>
>> That sounds good.
>>
>>> From there, we can delve into discussions about editing and exporting
>>> features. For instance, we could consider mimicking bindings and prompts
>>> from org-mode, as well as exploring integrations if users opt to also
>>> utilize third-party markdown-mode.
>>
>> I would be interested in helping out or at the very least to comment on
>> the development going on, since I had started writing the same mode
>> myself a while back, but never got around to it since because I don't
>> understand how `treesit-font-lock-rules' works.
>>
>>> However, simply having the mode built-in reduces friction significantly
>>> for new ideas and collaborations :)
>>
>> And makes it easier for external packages to rely on the code. Usually
>> I'd also say that it makes Emacs more usable in offline environments,
>> but the fact that the tree-sitter grammars have to for now be downloaded
>> stands in the way of that :/
>
> I agree with you Philip it is more usable in offline environments, but
> as all tree-sitter modes, they depend on those external libraries. But I
> have to say, I've been looking some distros including those libraries on
> their package repositories, so it should reduce (hopefully) some
> friction with it.
>
> ---
>
> Sorry for the long hiatus on this thread. I was actually waiting for
> more discussions but many cooler topics (and also life) got in the way :)
>
>
> I haven't made any changes on my last patch, but I am attaching it here
> to sync with this message.
>
>
> So is there anything else I could do about it?
^ permalink raw reply related [flat|nested] 16+ messages in thread
* Re: [PATCH] feat: add markdown-ts-mode
2024-07-03 19:13 ` Rahul Martim Juliato
@ 2024-07-03 20:13 ` Stefan Kangas
2024-07-04 5:17 ` Eli Zaretskii
2024-07-04 5:08 ` Eli Zaretskii
1 sibling, 1 reply; 16+ messages in thread
From: Stefan Kangas @ 2024-07-03 20:13 UTC (permalink / raw)
To: Rahul Martim Juliato; +Cc: emacs-devel, Eli Zaretskii, Andrea Corallo, Yuan Fu
Rahul Martim Juliato <rahuljuliato@gmail.com> writes:
> Following up on the April thread:
> https://lists.gnu.org/archive/html/emacs-devel/2024-04/msg00746.html
>
> And the June thread:
> https://lists.gnu.org/archive/html/emacs-devel/2024-06/msg01061.html
>
> I noticed the move to the Emacs 30 branch is already underway. However,
> I have not received any feedback on my patch, which has left me in the
> dark about its status.
>
> Could you please provide your insights or suggestions on the patch? Your
> feedback is crucial for moving this forward.
Thanks, I think this should be installed. It's important for us to have
Markdown support available out-of-the-box.
Should this go to master or emacs-30? I'd tend to think the latter,
since it's been in review enough time.
Eli, Andrea?
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH] feat: add markdown-ts-mode
2024-07-03 19:13 ` Rahul Martim Juliato
2024-07-03 20:13 ` Stefan Kangas
@ 2024-07-04 5:08 ` Eli Zaretskii
1 sibling, 0 replies; 16+ messages in thread
From: Eli Zaretskii @ 2024-07-04 5:08 UTC (permalink / raw)
To: Rahul Martim Juliato; +Cc: emacs-devel
> From: Rahul Martim Juliato <rahuljuliato@gmail.com>
> Cc: emacs-devel@gnu.org
> Date: Wed, 03 Jul 2024 16:13:52 -0300
>
> Could you please provide your insights or suggestions on the patch? Your
> feedback is crucial for moving this forward.
Thanks, please find some comments below.
> * lisp/textmodes/markdown-ts-mode.el: New file
> * doc/emacs/emacs.texi: Add Markdown to the manual
> * etc/NEWS: Announce markdown-ts-mode
Each entry should end with a period.
> index 7d77f13ab21..244c822ee04 100644
> --- a/doc/emacs/emacs.texi
> +++ b/doc/emacs/emacs.texi
> @@ -618,6 +618,7 @@ Top
> * Enriched Text:: Editing text enriched with fonts, colors, etc.
> * Text Based Tables:: Commands for editing text-based tables.
> * Two-Column:: Splitting text columns into separate windows.
> +* Markdown:: Major mode for editing Markdown files.
Where's the actual text of this new section? Looks like some part(s)
of the patch were left out?
> +(if (treesit-ready-p 'markdown)
> + (add-to-list 'auto-mode-alist '("\\.md\\'" . markdown-ts-mode)))
Should this also test that the markdown-inline grammar is present?
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH] feat: add markdown-ts-mode
2024-07-03 20:13 ` Stefan Kangas
@ 2024-07-04 5:17 ` Eli Zaretskii
2024-07-04 6:23 ` Eli Zaretskii
0 siblings, 1 reply; 16+ messages in thread
From: Eli Zaretskii @ 2024-07-04 5:17 UTC (permalink / raw)
To: Stefan Kangas; +Cc: rahuljuliato, emacs-devel, acorallo, casouri
> From: Stefan Kangas <stefankangas@gmail.com>
> Date: Wed, 3 Jul 2024 20:13:09 +0000
> Cc: emacs-devel@gnu.org, Eli Zaretskii <eliz@gnu.org>, Andrea Corallo <acorallo@gnu.org>,
> Yuan Fu <casouri@gmail.com>
>
> Thanks, I think this should be installed. It's important for us to have
> Markdown support available out-of-the-box.
>
> Should this go to master or emacs-30? I'd tend to think the latter,
> since it's been in review enough time.
>
> Eli, Andrea?
I'm not sure this is important enough to make exception of the rule
that no new features are installed on the release branch.
Moreover, given the proliferation of Markdown style in contexts other
than just *.md files, I think we should have Markdown support in other
places, such as email modes and in what looks like plain text files.
We need some reliable auto-detection of Markdown markup that turns on
this mode, or maybe a markdown-minor-mode. It is also possible that
Text mode should support some of the more popular Markdown styles
(like quoting `like this`) OOTB.
IOW, I think we should do more work here than just add a mode for
editing *.md files, and that will take some time and discussions to
figure out and integrate.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH] feat: add markdown-ts-mode
2024-07-04 5:17 ` Eli Zaretskii
@ 2024-07-04 6:23 ` Eli Zaretskii
2024-07-04 13:19 ` Andrea Corallo
0 siblings, 1 reply; 16+ messages in thread
From: Eli Zaretskii @ 2024-07-04 6:23 UTC (permalink / raw)
To: stefankangas, rahuljuliato; +Cc: emacs-devel, acorallo, casouri
> Date: Thu, 04 Jul 2024 08:17:56 +0300
> From: Eli Zaretskii <eliz@gnu.org>
> Cc: rahuljuliato@gmail.com, emacs-devel@gnu.org, acorallo@gnu.org,
> casouri@gmail.com
>
> I'm not sure this is important enough to make exception of the rule
> that no new features are installed on the release branch.
>
> Moreover, given the proliferation of Markdown style in contexts other
> than just *.md files, I think we should have Markdown support in other
> places, such as email modes and in what looks like plain text files.
> We need some reliable auto-detection of Markdown markup that turns on
> this mode, or maybe a markdown-minor-mode. It is also possible that
> Text mode should support some of the more popular Markdown styles
> (like quoting `like this`) OOTB.
>
> IOW, I think we should do more work here than just add a mode for
> editing *.md files, and that will take some time and discussions to
> figure out and integrate.
To clarify: the above doesn't mean we need to wait with installing the
mode as it was submitted (with the few minor nits that need to be
fixed). It just means that good integration with Emacs will take
time and more work, and therefore installing this on the emacs-30
release branch is not necessarily urgent.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH] feat: add markdown-ts-mode
2024-07-04 6:23 ` Eli Zaretskii
@ 2024-07-04 13:19 ` Andrea Corallo
2024-07-26 3:59 ` Rahul Martim Juliato
0 siblings, 1 reply; 16+ messages in thread
From: Andrea Corallo @ 2024-07-04 13:19 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: stefankangas, rahuljuliato, emacs-devel, casouri
Eli Zaretskii <eliz@gnu.org> writes:
>> Date: Thu, 04 Jul 2024 08:17:56 +0300
>> From: Eli Zaretskii <eliz@gnu.org>
>> Cc: rahuljuliato@gmail.com, emacs-devel@gnu.org, acorallo@gnu.org,
>> casouri@gmail.com
>>
>> I'm not sure this is important enough to make exception of the rule
>> that no new features are installed on the release branch.
>>
>> Moreover, given the proliferation of Markdown style in contexts other
>> than just *.md files, I think we should have Markdown support in other
>> places, such as email modes and in what looks like plain text files.
>> We need some reliable auto-detection of Markdown markup that turns on
>> this mode, or maybe a markdown-minor-mode. It is also possible that
>> Text mode should support some of the more popular Markdown styles
>> (like quoting `like this`) OOTB.
>>
>> IOW, I think we should do more work here than just add a mode for
>> editing *.md files, and that will take some time and discussions to
>> figure out and integrate.
>
> To clarify: the above doesn't mean we need to wait with installing the
> mode as it was submitted (with the few minor nits that need to be
> fixed). It just means that good integration with Emacs will take
> time and more work, and therefore installing this on the emacs-30
> release branch is not necessarily urgent.
Agree
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH] feat: add markdown-ts-mode
2024-07-04 13:19 ` Andrea Corallo
@ 2024-07-26 3:59 ` Rahul Martim Juliato
2024-07-26 22:51 ` Stefan Kangas
0 siblings, 1 reply; 16+ messages in thread
From: Rahul Martim Juliato @ 2024-07-26 3:59 UTC (permalink / raw)
To: Andrea Corallo
Cc: Eli Zaretskii, stefankangas, rahuljuliato, emacs-devel, casouri
[-- Attachment #1: Type: text/plain, Size: 2188 bytes --]
On Thu, Jul 04, 2024 at 09:19:26AM -0400, Andrea Corallo wrote:
> Eli Zaretskii <eliz@gnu.org> writes:
>
> >> Date: Thu, 04 Jul 2024 08:17:56 +0300
> >> From: Eli Zaretskii <eliz@gnu.org>
> >> Cc: rahuljuliato@gmail.com, emacs-devel@gnu.org, acorallo@gnu.org,
> >> casouri@gmail.com
> >>
> >> I'm not sure this is important enough to make exception of the rule
> >> that no new features are installed on the release branch.
> >>
> >> Moreover, given the proliferation of Markdown style in contexts other
> >> than just *.md files, I think we should have Markdown support in other
> >> places, such as email modes and in what looks like plain text files.
> >> We need some reliable auto-detection of Markdown markup that turns on
> >> this mode, or maybe a markdown-minor-mode. It is also possible that
> >> Text mode should support some of the more popular Markdown styles
> >> (like quoting `like this`) OOTB.
> >>
> >> IOW, I think we should do more work here than just add a mode for
> >> editing *.md files, and that will take some time and discussions to
> >> figure out and integrate.
> >
> > To clarify: the above doesn't mean we need to wait with installing the
> > mode as it was submitted (with the few minor nits that need to be
> > fixed). It just means that good integration with Emacs will take
> > time and more work, and therefore installing this on the emacs-30
> > release branch is not necessarily urgent.
>
> Agree
Hi Eli and everybody!
Thank you for the clarification. I understand that integrating the
Markdown mode fully into Emacs will take time and more discussion.
Given the current focus on Emacs 30, I'll delay a bit my work on new
patches or updates until after its release. I’m looking forward to
revisiting this once things settle down.
Meanwhile I'll step forward with the MELPA version of the package
including some features and attending to some suggestions I've got.
Thanks for your understanding!
--
Rahul Martim Juliato
https://www.rahuljuliato.com
PGP Fingerprint: 6B68 4353 84E2 2C7E 5A26 B79A C666 FC94 BD7E A483
PGP Public Key : https://www.rahuljuliato.com/rahul_pub_key.asc
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 833 bytes --]
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH] feat: add markdown-ts-mode
2024-07-26 3:59 ` Rahul Martim Juliato
@ 2024-07-26 22:51 ` Stefan Kangas
0 siblings, 0 replies; 16+ messages in thread
From: Stefan Kangas @ 2024-07-26 22:51 UTC (permalink / raw)
To: Rahul Martim Juliato, Andrea Corallo; +Cc: Eli Zaretskii, emacs-devel, casouri
Rahul Martim Juliato <rahuljuliato@gmail.com> writes:
> Hi Eli and everybody!
>
> Thank you for the clarification. I understand that integrating the
> Markdown mode fully into Emacs will take time and more discussion.
>
> Given the current focus on Emacs 30, I'll delay a bit my work on new
> patches or updates until after its release. I’m looking forward to
> revisiting this once things settle down.
>
> Meanwhile I'll step forward with the MELPA version of the package
> including some features and attending to some suggestions I've got.
We can install this on the master branch, meanwhile. There is no need
to delay or pause the work, as we usually have enough bandwidth here to
review new packages while also getting a new release out the door. So
my recommendation is to charge ahead, Emacs 30 notwithstanding.
If you want to get this out to users, for an FSF-copyright assigned
package, GNU ELPA will probably be a better fit than MELPA. For
example, it is always available for installation in the default
installation and AFAIK there are no drawbacks.
^ permalink raw reply [flat|nested] 16+ messages in thread
end of thread, other threads:[~2024-07-26 22:51 UTC | newest]
Thread overview: 16+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-04-20 3:23 [PATCH] feat: add markdown-ts-mode Rahul Martim Juliato
2024-04-20 6:44 ` Eli Zaretskii
2024-04-20 17:45 ` Jostein Kjønigsen
2024-04-21 5:50 ` Rahul Martim Juliato
2024-04-22 7:02 ` Philip Kaludercic
2024-04-23 1:20 ` Rahul Martim Juliato
2024-04-27 10:18 ` Philip Kaludercic
2024-06-29 2:09 ` Rahul Martim Juliato
2024-07-03 19:13 ` Rahul Martim Juliato
2024-07-03 20:13 ` Stefan Kangas
2024-07-04 5:17 ` Eli Zaretskii
2024-07-04 6:23 ` Eli Zaretskii
2024-07-04 13:19 ` Andrea Corallo
2024-07-26 3:59 ` Rahul Martim Juliato
2024-07-26 22:51 ` Stefan Kangas
2024-07-04 5:08 ` Eli Zaretskii
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/emacs.git
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.