* [devel] GNU Emacs load-path setting
@ 2003-03-27 17:59 Sergey Vlasov
2003-03-29 17:00 ` Ivan Zakharyaschev
0 siblings, 1 reply; 2+ messages in thread
From: Sergey Vlasov @ 2003-03-27 17:59 UTC (permalink / raw)
To: ALT Developers List
Hello!
У нас сейчас наблюдается некоторый бардак с настройкой load-path в
GNU Emacs.
С одной стороны, скрипты в пакетах, кладущиеся в
/etc/emacs/site-start.d, добавляют каталоги в load-path - и это само по
себе не вызывает проблем. Однако в GNU Emacs 21 при загрузке
используются файлы subdirs.el, в частности,
/usr/share/emacs/site-lisp/subdirs.el, где написано:
(if (fboundp 'normal-top-level-add-subdirs-to-load-path)
(normal-top-level-add-subdirs-to-load-path))
Функция normal-top-level-add-subdirs-to-load-path рекурсивно добавляет
все подкаталоги текущего каталога (в данном случае site-lisp) в
load-path. Таким образом, имеем две проблемы:
1) Если файл в /etc/emacs/site-start.d использует просто cons для
добавления к load-path, получаются дублирующиеся элементы в load-path.
В принципе это мелочь, но лучше использовать add-to-list.
2) Рекурсивное добавление всех подкаталогов site-lisp недопустимо -
некоторые пакеты содержат подкаталоги, файлы в которых пересекаются по
именам со стандартными файлами Emacs; такие подкаталоги не должны
попадать в load-path. В этих подкаталогах необходимо создать (пустой)
файл с именем .nosearch, чтобы запретить их добавление в load-path; см.
описание normal-top-level-add-subdirs-to-load-path.
Вообще, если мы не будем поддерживать GNU Emacs < 21, можно повыкидывать
из всех скриптов в /etc/emacs/site-start.d модификацию load-path.
--
Sergey Vlasov
^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: [devel] GNU Emacs load-path setting
2003-03-27 17:59 [devel] GNU Emacs load-path setting Sergey Vlasov
@ 2003-03-29 17:00 ` Ivan Zakharyaschev
0 siblings, 0 replies; 2+ messages in thread
From: Ivan Zakharyaschev @ 2003-03-29 17:00 UTC (permalink / raw)
To: ALT Developers List
Hello!
Согласен с тем, что сказал Сергей.
On Thu, 27 Mar 2003, Sergey Vlasov wrote:
> 2) Рекурсивное добавление всех подкаталогов site-lisp
> недопустимо -
> некоторые пакеты содержат подкаталоги, файлы в которых
> пересекаются по
> именам со стандартными файлами Emacs; такие подкаталоги не
А если не со стандатрными, а друг с другом, то ведь тоже плохо.
(Два пакета содержат в подкаталогах файл с одинаковым именем.)
Так что полным решением будет, наверное, добавление .nosearch во
все подкаталоги, в попадании которых в load-path нет
необходимости.
> должны
> попадать в load-path. В этих подкаталогах необходимо создать
> (пустой)
> файл с именем .nosearch, чтобы запретить их добавление в
> load-path; см.
> описание normal-top-level-add-subdirs-to-load-path.
>
> Вообще, если мы не будем поддерживать GNU Emacs < 21, можно
> повыкидывать
> из всех скриптов в /etc/emacs/site-start.d модификацию
> load-path.
--
С наилучшими пожеланиями,
Иван Захарьящев, Москва
JID: imz at altlinux.org
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2003-03-29 17:00 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2003-03-27 17:59 [devel] GNU Emacs load-path setting Sergey Vlasov
2003-03-29 17:00 ` Ivan Zakharyaschev
ALT Linux Team development discussions
This inbox may be cloned and mirrored by anyone:
git clone --mirror http://lore.altlinux.org/devel/0 devel/git/0.git
# If you have public-inbox 1.1+ installed, you may
# initialize and index your mirror using the following commands:
public-inbox-init -V2 devel devel/ http://lore.altlinux.org/devel \
devel@altlinux.org devel@altlinux.ru devel@lists.altlinux.org devel@lists.altlinux.ru devel@linux.iplabs.ru mandrake-russian@linuxteam.iplabs.ru sisyphus@linuxteam.iplabs.ru
public-inbox-index devel
Example config snippet for mirrors.
Newsgroup available over NNTP:
nntp://lore.altlinux.org/org.altlinux.lists.devel
AGPL code for this site: git clone https://public-inbox.org/public-inbox.git