emacs-diffs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

feature/native-comp f055f52 1/2: * Fix two find function functions for n


From: Andrea Corallo
Subject: feature/native-comp f055f52 1/2: * Fix two find function functions for native compilation
Date: Sun, 8 Mar 2020 17:53:45 -0400 (EDT)

branch: feature/native-comp
commit f055f523216d6aa5fe2b59984e0aed81ca80b66e
Author: Andrea Corallo <address@hidden>
Commit: Andrea Corallo <address@hidden>

    * Fix two find function functions for native compilation
    
    `find-function-library' and `find-library-name' gets fixed for new eln
    compilation directory layout.
---
 lisp/emacs-lisp/find-func.el | 11 +++++++++--
 1 file changed, 9 insertions(+), 2 deletions(-)

diff --git a/lisp/emacs-lisp/find-func.el b/lisp/emacs-lisp/find-func.el
index 86b5e54..21c1002 100644
--- a/lisp/emacs-lisp/find-func.el
+++ b/lisp/emacs-lisp/find-func.el
@@ -184,8 +184,15 @@ See the functions `find-function' and `find-variable'."
 LIBRARY should be a string (the name of the library)."
   ;; If the library is byte-compiled, try to find a source library by
   ;; the same name.
-  (when (string-match "\\.el\\([cn]\\(\\..*\\)?\\)\\'" library)
+  (cond
+   ((string-match "\\.el\\(c\\(\\..*\\)?\\)\\'" library)
     (setq library (replace-match "" t t library)))
+   ((string-match "\\.eln$" library)
+    ;; From help-fns.el.
+    (setq library (expand-file-name (concat (file-name-base library)
+                                            ".el")
+                                   (concat (file-name-directory library)
+                                            "..")))))
   (or
    (locate-file library
                 (or find-function-source-path load-path)
@@ -439,7 +446,7 @@ message about the whole chain of aliases."
     (cons function
           (cond
            ((autoloadp def) (nth 1 def))
-           ((subrp def)
+           ((and (subrp def) (not (subr-native-elisp-p def)))
             (if lisp-only
                 (error "%s is a built-in function" function))
             (help-C-file-name def 'subr))



reply via email to

[Prev in Thread] Current Thread [Next in Thread]