From: Achim Gratz <Stromeko@nexgo.de>
To: 10125@debbugs.gnu.org
Subject: bug#10125: RFE: require and load-path-shadowing
Date: Sat, 12 Jan 2013 11:15:40 +0100 [thread overview]
Message-ID: <87ip72n1v7.fsf__31846.7005076402$1357988983$gmane$org@Rainer.invalid> (raw)
In-Reply-To: <81pqgh90sp.fsf@gmail.com>
Achim Gratz writes:
> Stefan Monnier writes:
>> Yes, this subroutine is never directly called from C, so placing an
>> advice should work just fine.
>
> OK, I'll give it a try.
Here's what I've come up with:
--8<---------------cut here---------------start------------->8---
;; some parts of Org might already have been used from a different
;; place, try to reload these parts from the current load-path
(defadvice require (before org-require-reload-when-shadowed
(feature &optional filename noerror)
activate compile preactivate)
"Check whether a required feature has been shadowed by changing
`load-path' after it has been loaded and reload that feature from
current load-path in this case."
(when (featurep feature)
(let ((feature-name (or filename (symbol-name feature))))
(when (string-match "^\\(org\\|ob\\)[.-]" feature-name)
(let ((feature-lib (file-name-directory (or (locate-library feature-name) "")))
(feature-dir (file-name-directory (feature-file feature))))
;(message "require-reload-when shadowed %s\n\t%s\n\t%s" feature-name feature-lib feature-dir)
(when (not (string= feature-lib feature-dir))
(message "Reloading %s" feature-name)
(unload-feature feature t)))))))
(require 'org-macs)
(require 'org-compat)
(require 'org-entities)
(require 'org-faces)
(require 'org-list)
(require 'org-pcomplete)
(require 'org-src)
(require 'org-footnote)
;; babel
(require 'ob)
(eval-and-compile (ad-unadvise 'require))
--8<---------------cut here---------------end--------------->8---
This takes care of a situation when Org is activated after some parts of
it have already been loaded (maybe via autoload) and the load-path has
been changed inbetween. This uses unload-feature although it would
probably work to just (setq features (delq feature features)).
For package manager, a slightly more general version of the above (not
conditionalized on the feature starting with "org" or "ob") could be
used around the package compilation. I haven't yet tried this, though.
Regards,
Achim.
--
+<[Q+ Matrix-12 WAVE#46+305 Neuron microQkb Andromeda XTk Blofeld]>+
Wavetables for the Waldorf Blofeld:
http://Synth.Stromeko.net/Downloads.html#BlofeldUserWavetables
next prev parent reply other threads:[~2013-01-12 10:15 UTC|newest]
Thread overview: 96+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-01-10 21:07 RFE: require and load-path-shadowing Achim Gratz
2013-01-10 23:43 ` Glenn Morris
2013-01-11 1:57 ` bug#10125: " Stefan Monnier
2011-11-24 12:12 ` 24.0.91; package.el (org): Macros in tar packages & order of byte compilation Jambunathan K
2002-01-01 0:33 ` bug#10125: " Jambunathan K
2011-11-24 13:05 ` Eli Zaretskii
2011-11-24 17:22 ` Jambunathan K
2011-11-24 17:22 ` Jambunathan K
2011-11-24 19:09 ` Glenn Morris
2011-11-24 19:53 ` Glenn Morris
2011-11-25 12:15 ` Jambunathan K
2011-11-25 12:15 ` Jambunathan K
2011-11-25 14:07 ` Chong Yidong
2011-11-25 14:07 ` Chong Yidong
2011-11-25 14:57 ` Stefan Monnier
2011-11-25 14:57 ` Stefan Monnier
2011-11-25 19:15 ` Glenn Morris
2011-11-25 19:21 ` Glenn Morris
2011-11-25 19:21 ` Glenn Morris
2011-11-25 19:15 ` Glenn Morris
2011-11-25 18:19 ` Glenn Morris
2011-11-25 18:19 ` Glenn Morris
2011-11-25 19:01 ` Glenn Morris
2011-11-25 19:01 ` Glenn Morris
2011-11-24 19:53 ` Glenn Morris
2011-11-24 22:55 ` Stelian Iancu
2011-11-24 22:55 ` Stelian Iancu
2011-11-24 23:54 ` Glenn Morris
2011-11-24 23:54 ` Glenn Morris
2011-11-25 3:31 ` Jambunathan K
2011-11-25 3:31 ` Jambunathan K
2011-11-25 12:32 ` Stelian Iancu
2011-11-25 12:58 ` Jambunathan K
2011-11-25 12:32 ` Stelian Iancu
2011-11-25 8:10 ` Eli Zaretskii
2011-11-25 18:20 ` Glenn Morris
2011-11-25 18:20 ` Glenn Morris
2011-11-25 8:10 ` Eli Zaretskii
2011-11-24 19:09 ` Glenn Morris
2013-01-11 16:06 ` bug#10125: RFE: require and load-path-shadowing Achim Gratz
2013-01-11 16:56 ` Stefan Monnier
2013-01-11 16:56 ` Stefan Monnier
2013-01-11 16:06 ` Achim Gratz
2013-01-11 19:53 ` Achim Gratz
2013-01-11 22:52 ` Stefan Monnier
2013-01-11 22:52 ` Stefan Monnier
2013-01-12 8:15 ` Eli Zaretskii
2013-01-12 8:15 ` Eli Zaretskii
2013-01-11 19:53 ` Achim Gratz
2013-01-12 10:15 ` Achim Gratz [this message]
2013-01-12 10:15 ` Achim Gratz
2013-01-12 13:34 ` Bastien
2013-01-12 13:34 ` Bastien
2013-01-12 14:03 ` Stefan Monnier
2013-01-12 14:23 ` Bastien
2013-01-12 16:12 ` Stefan Monnier
2013-01-12 16:12 ` Stefan Monnier
2013-01-12 17:34 ` Bastien
2013-01-12 17:34 ` Bastien
2013-01-12 14:23 ` Bastien
2013-01-12 14:03 ` Stefan Monnier
2013-01-12 10:20 ` Achim Gratz
2013-01-12 10:20 ` Achim Gratz
2013-01-12 12:07 ` Eli Zaretskii
2013-01-12 12:07 ` Eli Zaretskii
2013-01-12 13:28 ` Stefan Monnier
2013-01-12 13:28 ` Stefan Monnier
2013-01-12 13:55 ` Eli Zaretskii
2013-01-12 13:55 ` Eli Zaretskii
2013-01-12 18:42 ` Glenn Morris
2013-01-12 18:42 ` Glenn Morris
2013-01-12 16:29 ` Achim Gratz
2013-01-12 16:29 ` Achim Gratz
2013-01-12 17:01 ` Achim Gratz
2013-01-12 17:01 ` Achim Gratz
2013-01-12 18:39 ` Eli Zaretskii
2013-01-12 18:39 ` Eli Zaretskii
2013-01-13 7:46 ` Achim Gratz
2013-01-13 7:46 ` Achim Gratz
2013-01-13 7:52 ` Achim Gratz
2013-01-13 7:52 ` Achim Gratz
2013-01-15 19:34 ` Achim Gratz
2013-01-15 19:34 ` Achim Gratz
2013-01-16 9:45 ` Kevin Rodgers
2013-01-16 10:06 ` Andreas Schwab
2013-01-16 10:06 ` Andreas Schwab
2013-01-16 14:59 ` Kevin Rodgers
2013-01-16 14:59 ` Kevin Rodgers
2013-01-16 9:45 ` Kevin Rodgers
2013-01-11 2:45 ` Jambunathan K
2013-01-11 2:45 ` Jambunathan K
2013-01-11 1:57 ` Stefan Monnier
2013-01-11 8:21 ` Achim Gratz
2013-01-20 7:38 ` Achim Gratz
2013-01-20 20:17 ` Glenn Morris
2013-01-21 6:53 ` Achim Gratz
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to='87ip72n1v7.fsf__31846.7005076402$1357988983$gmane$org@Rainer.invalid' \
--to=stromeko@nexgo.de \
--cc=10125@debbugs.gnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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.