~ruther/guix-local

47a67d34b2b5f01e7092442cb318c61d1876dc25 — Nicolas Goaziou 2 years ago 8855e30
gnu: emacs-haskell-mode: Update to 17.5.

* gnu/packages/emacs-xyz.scm (emacs-haskell-mode): Update to 17.5.
* gnu/packages/patches/emacs-haskell-mode-no-redefine-builtin.patch: Delete
file.
* gnu/local.mk (dist_patch_DATA): Apply file deletion.

Change-Id: Ic7d11737af87995610ecf2c3178320901991423d
3 files changed, 2 insertions(+), 80 deletions(-)

M gnu/local.mk
M gnu/packages/emacs-xyz.scm
D gnu/packages/patches/emacs-haskell-mode-no-redefine-builtin.patch
M gnu/local.mk => gnu/local.mk +0 -1
@@ 1114,7 1114,6 @@ dist_patch_DATA =						\
  %D%/packages/patches/emacs-git-email-missing-parens.patch	\
  %D%/packages/patches/emacs-fix-scheme-indent-function.patch	\
  %D%/packages/patches/emacs-json-reformat-fix-tests.patch	\
  %D%/packages/patches/emacs-haskell-mode-no-redefine-builtin.patch	\
  %D%/packages/patches/emacs-helpful-fix-tests.patch	\
  %D%/packages/patches/emacs-highlight-stages-add-gexp.patch	\
  %D%/packages/patches/emacs-lispy-fix-thread-last-test.patch   \

M gnu/packages/emacs-xyz.scm => gnu/packages/emacs-xyz.scm +2 -4
@@ 2403,7 2403,7 @@ replacement.")
(define-public emacs-haskell-mode
  (package
    (name "emacs-haskell-mode")
    (version "17.4")
    (version "17.5")
    (source
     (origin
       (method git-fetch)


@@ 2412,9 2412,7 @@ replacement.")
             (commit (string-append "v" version))))
       (file-name (git-file-name name version))
       (sha256
        (base32 "03j94fgw1bljbjqmikbn9mnrfifxf7g9zrb727zmnnrjwyi0wd4n"))
       (patches
        (search-patches "emacs-haskell-mode-no-redefine-builtin.patch"))))
        (base32 "0ndi986rxq9gz61ss2vazadn7rn0niv1gnpk9nfq9sw3m336glsf"))))
    (propagated-inputs
     (list emacs-dash))
    (native-inputs

D gnu/packages/patches/emacs-haskell-mode-no-redefine-builtin.patch => gnu/packages/patches/emacs-haskell-mode-no-redefine-builtin.patch +0 -75
@@ 1,75 0,0 @@
From faa95a784d2c74c72e70367a5d531df6dd61aeab Mon Sep 17 00:00:00 2001
From: Steve Purcell <steve@sanityinc.com>
Date: Sun, 6 Aug 2023 16:41:48 +0200
Subject: [PATCH] Don't redefine built-in function

Fixes #1817
---
 tests/haskell-indent-tests.el      | 14 ++++++++------
 tests/haskell-indentation-tests.el | 14 ++++++++------
 2 files changed, 16 insertions(+), 12 deletions(-)

diff --git a/tests/haskell-indent-tests.el b/tests/haskell-indent-tests.el
index 7196405b8..9a3de4ad3 100644
--- a/tests/haskell-indent-tests.el
+++ b/tests/haskell-indent-tests.el
@@ -40,11 +40,13 @@
 ;;                    (haskell-indent-put-region-in-literate (point-min) (point-max) -1)
 ;;                    (buffer-substring-no-properties (point-min) (point-max))))))
 
-(defsubst string-trim-left (string)
-  "Remove leading whitespace from STRING."
-  (if (string-match "\\`[ \t\n\r]+" string)
-      (replace-match "" t t string)
-    string))
+(if (fboundp 'string-trim-left)
+    (defalias 'haskell--string-trim-left 'string-trim-left)
+  (defun haskell--string-trim-left (string &optional regexp)
+    "Remove leading whitespace from STRING."
+    (if (string-match (concat "\\`\\(?:" (or regexp "[ \t\n\r]+") "\\)") string)
+        (substring string (match-end 0))
+      string)))
 
 (defun haskell-indent-format-info (info)
   (if (cdr info)
@@ -128,7 +130,7 @@ macro quotes them for you."
          :expected-result
          ,(if allow-failure :failed :passed)
          (haskell-indent-check
-          ,(string-trim-left source)
+          ,(haskell--string-trim-left source)
           ,@(mapcar (lambda (x)
                       (list 'quote x))
                     test-cases))))))
diff --git a/tests/haskell-indentation-tests.el b/tests/haskell-indentation-tests.el
index 4889b76a7..cd783a4f4 100644
--- a/tests/haskell-indentation-tests.el
+++ b/tests/haskell-indentation-tests.el
@@ -33,11 +33,13 @@
 
 ;;; Code:
 
-(defsubst string-trim-left (string)
-  "Remove leading whitespace from STRING."
-  (if (string-match "\\`[ \t\n\r]+" string)
-      (replace-match "" t t string)
-    string))
+(if (fboundp 'string-trim-left)
+    (defalias 'haskell--string-trim-left 'string-trim-left)
+  (defun haskell--string-trim-left (string &optional regexp)
+    "Remove leading whitespace from STRING."
+    (if (string-match (concat "\\`\\(?:" (or regexp "[ \t\n\r]+") "\\)") string)
+        (substring string (match-end 0))
+      string)))
 
 (defun haskell-indentation-check (source &rest test-cases)
   "Check if `haskell-indentation-find-indentations' returns expected results.
@@ -115,7 +117,7 @@ macro quotes them for you."
          :expected-result
          ,(if allow-failure :failed :passed)
          (haskell-indentation-check
-          ,(string-trim-left source)
+          ,(haskell--string-trim-left source)
           ,@(mapcar (lambda (x)
                       (list 'quote x))
                     test-cases))))))