Package: hyperbole;
Reported by: <d40547914 <at> dvuadmin.net>
Date: Wed, 5 Jun 2019 20:28:01 UTC
Severity: normal
Done: Mats Lidell <matsl <at> gillsatra.se>
Bug is archived. No further changes may be made.
Message #14 received at 36107 <at> debbugs.gnu.org (full text, mbox):
From: <d40547914 <at> dvuadmin.net> To: Robert Weiner <rsw <at> gnu.org> Cc: "rswgnu <at> gmail.com" <rswgnu <at> gmail.com>, "36107 <at> debbugs.gnu.org" <36107 <at> debbugs.gnu.org> Subject: Re: bug#36107: Global Buttons Stop Functioning When Current Working Directory Changes (Forgot the Subject!) Date: Thu, 6 Jun 2019 11:58:41 +0000
Thanks for looking at it! Got an error with that code, though -- here's what I did: 1. Loaded Emacs. Hyperbole auto-loaded. 2. Invoked the "Notes" global button -- just to make sure Hyperbole was running and good to go. 3. Evaluated provided code 4. Invoked "Notes" global button again and this is what the debugger gave me: Debugger entered--Lisp error: (void-function hypb:functionp) (hypb:functionp display-executables) (cond ((stringp display-executables) (funcall hrule:action (quote exec-window-cmd) (hpath:command-string display-executables filename)) nil) ((hypb:functionp display-executables) (funcall display-executables filename) t) ((and (listp display-executables) display-executables) (setq executable (hpath:find-executable display-executables)) (if executable (funcall hrule:action (quote exec-window-cmd) (hpath:command-string executable filename)) (error "(hpath:find): No available executable from: %s" display-executables))) (t (setq path (hpath:validate path)) (if (null display-where) (setq display-where hpath:display-where)) (funcall (car (cdr (or (assq display-where hpath:display-where-alist) (assq (quote other-window) hpath:display-where-alist)))) path) (if (or hash anchor) (hpath:to-markup-anchor hash anchor)) t)) (let ((display-executables (hpath:find-program path)) executable) (cond ((stringp display-executables) (funcall hrule:action (quote exec-window-cmd) (hpath:command-string display-executables filename)) nil) ((hypb:functionp display-executables) (funcall display-executables filename) t) ((and (listp display-executables) display-executables) (setq executable (hpath:find-executable display-executables)) (if executable (funcall hrule:action (quote exec-window-cmd) (hpath:command-string executable filename)) (error "(hpath:find): No available executable from: %s" display-executables))) (t (setq path (hpath:validate path)) (if (null display-where) (setq display-where hpath:display-where)) (funcall (car (cdr (or (assq display-where hpath:display-where-alist) (assq ... hpath:display-where-alist)))) path) (if (or hash anchor) (hpath:to-markup-anchor hash anchor)) t))) (cond (modifier (cond ((eq modifier 33) (funcall hrule:action (quote exec-shell-cmd) filename)) ((eq modifier 38) (funcall hrule:action (quote exec-window-cmd) filename)) ((eq modifier 45) (load filename))) nil) (t (let ((display-executables (hpath:find-program path)) executable) (cond ((stringp display-executables) (funcall hrule:action (quote exec-window-cmd) (hpath:command-string display-executables filename)) nil) ((hypb:functionp display-executables) (funcall display-executables filename) t) ((and (listp display-executables) display-executables) (setq executable (hpath:find-executable display-executables)) (if executable (funcall hrule:action (quote exec-window-cmd) (hpath:command-string executable filename)) (error "(hpath:find): No available executable from: %s" display-executables))) (t (setq path (hpath:validate path)) (if (null display-where) (setq display-where hpath:display-where)) (funcall (car (cdr ...)) path) (if (or hash anchor) (hpath:to-markup-anchor hash anchor)) t))))) (let ((case-fold-search t) modifier loc default-directory anchor hash path) (if (string-match hpath:prefix-regexp filename) (setq modifier (aref filename 0) filename (substring filename (match-end 0)))) (setq path (hpath:substitute-value (if (string-match hpath:markup-link-anchor-regexp filename) (progn (setq hash t anchor (match-string 3 filename)) (substring filename 0 (match-end 1))) filename)) loc (hattr:get (quote hbut:current) (quote loc)) default-directory (file-name-directory (if (stringp loc) loc default-directory)) filename (hpath:absolute-to path default-directory)) (let ((remote-filename (hpath:remote-p path))) (or modifier remote-filename (file-exists-p filename) (error "(hpath:find): \"%s\" does not exist" filename)) (or modifier remote-filename (file-readable-p filename) (error "(hpath:find): \"%s\" is not readable" filename)) (if (and remote-filename (not (file-directory-p remote-filename))) (progn (copy-file remote-filename (setq path (concat hpath:tmp-prefix (file-name-nondirectory remote-filename))) t t) (setq filename (cond (anchor (concat remote-filename "#" anchor)) (hash (concat remote-filename "#")) (t path)))))) (cond (modifier (cond ((eq modifier 33) (funcall hrule:action (quote exec-shell-cmd) filename)) ((eq modifier 38) (funcall hrule:action (quote exec-window-cmd) filename)) ((eq modifier 45) (load filename))) nil) (t (let ((display-executables (hpath:find-program path)) executable) (cond ((stringp display-executables) (funcall hrule:action (quote exec-window-cmd) (hpath:command-string display-executables filename)) nil) ((hypb:functionp display-executables) (funcall display-executables filename) t) ((and (listp display-executables) display-executables) (setq executable (hpath:find-executable display-executables)) (if executable (funcall hrule:action ... ...) (error "(hpath:find): No available executable from: %s" display-executables))) (t (setq path (hpath:validate path)) (if (null display-where) (setq display-where hpath:display-where)) (funcall (car ...) path) (if (or hash anchor) (hpath:to-markup-anchor hash anchor)) t)))))) hpath:find("../Org/Notes.org") #f(compiled-function (path &optional point) (interactive #f(compiled-function () #<bytecode 0x1ff0aed>)) #<bytecode 0x1ee53dd>)("../Org/Notes.org") apply(#f(compiled-function (path &optional point) (interactive #f(compiled-function () #<bytecode 0x23136a5>)) #<bytecode 0x1ee53dd>) "../Org/Notes.org") eval((apply action args)) actype:act(actypes::link-to-file "../Org/Notes.org") apply(actype:act actypes::link-to-file "../Org/Notes.org") hbut:act(hbut:current) gbut:act("Notes") funcall-interactively(gbut:act "Notes") call-interactively(gbut:act) hui:menu-act(hyperbole nil nil nil) hyperbole(nil nil nil nil) funcall-interactively(hyperbole nil nil nil nil) call-interactively(hyperbole nil nil) command-execute(hyperbole)
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.