updated readme, added comments and sample config+screenshot

This commit is contained in:
2024-03-19 09:14:53 +01:00
parent 4876c2c619
commit 87a50ed3f6
3 changed files with 119 additions and 0 deletions

BIN
.github/assets/screenshot.png vendored Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 67 KiB

View File

@@ -1,2 +1,64 @@
# kage-mode
An emacs mode for the kage shader language
![Screenshot](https://github.com/TLINDEN/kage-mode/blob/main/.github/assets/screenshot.png)
The mode provides all the features of [go-mode](https://github.com/dominikh/go-mode.el).
Please note, that you can't use
[lsp-mode](https://github.com/emacs-lsp/lsp-mode) with kage-mode
though, because the go-backend doesn't support it.
# Install
Copy the file `kage-mode.el` into some directory in your `load-path`.
A Melpa package will be available in the future.
# Configuration
This is my configuration for kage-mode:
```lisp
(use-package kage-mode
:ensure nil ;; installed locally in site-lisp
:defer nil
:mode "\\.kg\\'" ;; you must use a different suffix for kage files!
:commands kage-gofmt-before-save
:init
(defun tvd-kage-install-hooks()
;; remove the lsp-mode stuff, since unsupported
(remove-hook 'before-save-hook #'lsp-format-buffer t)
(remove-hook 'before-save-hook #'lsp-organize-imports t)
;; use gofmt -s
(add-hook 'before-save-hook #'kage-gofmt-before-save t t))
:config
(add-hook 'kage-mode-hook #'tvd-kage-install-hooks)
;; ignore warnings about no kage lsp backend
(setq lsp-warn-no-matched-clients nil))
```
# Meta
Copyright (C) 2024, T.v.Dein tlinden AT cpan.org
This file is NOT part of Emacs.
This program 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.
This program 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 this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
USA

57
kage-mode.el Normal file
View File

@@ -0,0 +1,57 @@
;;; kage-mode.el --- mode for the kage shader language -*- lexical-binding: t; -*-
;; Copyright (C) 2024, T.v.Dein <tlinden@cpan.org>
;; This file is NOT part of Emacs.
;; This program 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.
;; This program 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 this program; if not, write to the Free Software
;; Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
;; USA
;; Version: 0.0.1
;; Package-Version: 20240319.100
;; Author: T.v.Dein <tlinden@cpan.org>
;; Keywords: languages go
;; URL: https://github.com/tlinden/kage-mode
;; License: GNU General Public License >= 3
;; Package-Requires: ((emacs "24.1"))
;; SPDX-License-Identifier: GPL-3.0
;; kage-mode is simply derived from go-mode
(define-derived-mode kage-mode go-mode "Kage shader script"
"Major mode for editing Ebitengine Kage shader files.
This mode provides all the features go-mode provides, since kage files
are go compatible.
It also supports the use of gofmt -s. If you want to use it, add this
to your config:
\(add-hook 'before-save-hook #'kage-gofmt-before-save)"
(run-hooks 'kage-mode-hook))
;; we need to have our own call to gofmt, because the one in go-mode
;; only works with *.go files, but we use the original call to it anyway
(defun kage-gofmt-before-save ()
"Execute gofmt, intended to be put into before-safe-hook"
(interactive)
(when (eq major-mode 'kage-mode) (gofmt)))
;; autoloaders
(autoload 'kage-mode "kage-mode")
(autoload 'kage-gofmt-before-save "execute gofmt on write")
(provide 'kage-mode)