all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
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@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

  parent reply	other threads:[~2013-01-12 11:08 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 19:09           ` Glenn Morris
2011-11-24 19:53             ` 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: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 14:57                 ` Stefan Monnier
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-25 14:07               ` Chong Yidong
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
2011-11-24 17:22         ` Jambunathan K
2013-01-11 16:06       ` bug#10125: RFE: require and load-path-shadowing Achim Gratz
2013-01-11 16:06       ` Achim Gratz
2013-01-11 16:56         ` Stefan Monnier
2013-01-11 16:56         ` Stefan Monnier
2013-01-11 19:53       ` 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-12 10:15       ` Achim Gratz [this message]
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 17:34                 ` Bastien
2013-01-12 17:34                 ` Bastien
2013-01-12 16:12               ` Stefan Monnier
2013-01-12 14:23             ` Bastien
2013-01-12 14:03           ` Stefan Monnier
2013-01-12 13:34         ` Bastien
2013-01-12 10:15       ` 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 10:20       ` Achim Gratz
2013-01-12 16:29       ` Achim Gratz
2013-01-12 16:29       ` 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-12 17:01       ` Achim Gratz
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-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-15 19:34       ` Achim Gratz
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@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.