ALT Linux Team development discussions
 help / color / mirror / Atom feed
From: Alexey Voinov <voins@altlinux.ru>
To: ALT Devel discussion list <devel@lists.altlinux.org>
Subject: Re: [devel] Страшно старая бага в emacs'е
Date: Sat, 25 Aug 2007 22:43:36 +0400
Message-ID: <m3y7fzlajr.fsf@altlinux.ru> (raw)
In-Reply-To: <m2zm0fsrou.fsf@eugene-home.ikz.ru> (Eugene Vlasov's message of "Sat\, 25 Aug 2007 18\:51\:29 +0600")

[-- Attachment #1: Type: text/plain, Size: 8276 bytes --]

Eugene Vlasov <eugene@ikz.ru> writes:

> On Sat, 25 Aug 2007 12:30:47 +0400 Alexey Voinov wrote:
>
>> Раз уж зашёл об это разговор, то у меня есть предложение: а не
>> избавиться ли от site-start.el вообще? А для того, чтобы новые
>> пользователи не пугались, им можно оставить default.el. Это и даст
>> возможность немного упростить код загрузчика, и позволит при желании
>> отключать загрузку всего этого умолчательного без хаков типа
>> создания волшебных файлов.
>
> А будет ли это удачным решением? Существующая схема хоть и не очень
> красиво. но позволяет отключать загрузку файлов настройки по частям, а
> default.el можно отключить только всю разом. Кроме того, эти настройки
> будут загружаться после пользовательского инит-файла, и возможно будут
> перекрывать настройки пользователя - а это может быть для пользователя
> неожиданным.
Во-первых, никто не запрещает не выключать загрузку default.el и
выключать загружаемое им по частям, точно так же, как и сейчас.

Во-вторых, пердлагаю пробежаться по файликам, которые там загружаются
и посмотреть что можно выкинуть, а что можно исправить так, чтобы
пользовательская настройка всегда имела приоритет:

~ 00auto-compr.el - не нужен совершенно. auto-comression-mode
    включается сейчас по умолчанию. В этом можно убедиться запустив
    $ emacs -Q --batch --eval '(print auto-compression-mode)' --> t
    Наш локальный файлик тут ничего уже не включает. Можно
    поковыряться и найти кто же именно это делает, но мне, честно
    говоря, немного лень этим заниматься. :) Выкидываем?

~ 00macros.el - Этими макросами хоть кто-нибудь реально пользуется?
    Это, конечно, моё мнение, но помоему (when window-system ...) или
    (when noninteractive ...) и читается проще, и выглядит
    красивше. :) Если ими кто-то пользуется в ~/.emacs, то, видимо,
    придётся оставить. Но, если уж так, то я бы их положил в
    какой-нибудь отдельный файлик, который надо былобы (require ...)
    перед использованием, ну или autoload какой...

~ 10fontlock.el - переменная font-lock-mode-maximum-decoration кодом
    emacs не используется, зато есть такая переменная
    font-lock-maximum-decoration, которая по умолчанию установлена в
    t. Режим global-font-lock-mode тоже имеет вполне разумные
    умолчания - будет включён, если не указать --basic-display при
    запуске.  Переменные font-lock-use-default-fonts и
    font-lock-use-default-colors тоже не оказывают никакого влияния на
    внешний вид. выкидываем?

~ 10frames.el - cursor-type имеет значение box по умолчанию. А вот
    полезность выставления в синий цвет всего, что bold-italic, если
    запущены в консоли, для меня, честно говоря, абсолютно
    неочевидна. :)

~ 10initial-features.el - next-line-add-newlines устанавливается в
    значение nil по умолчанию. Режим show-paren-mode выставлять только
    если пользователь ничего не выставил явно. Это можно сделать вот
    так, например:

     (defun autoloadp (sym)
       (let ((obj (symbol-function sym)))
         (and (consp obj)
	      (eq 'autoload (car obj)))))

     (when (autoloadp 'show-paren-mode)
       (show-paren-mode t))

    Функция autoloadp ещё наверняка пригодится, так что её можно в
    какое-нибудь общее место определить. С column-number-mode такой
    фокус не пройдёт, оно всё время загружено. Но это, в общем-то и не
    страшно. Тот, кто будет обращать внимание на лишнюю циферку в
    mode-line скорее всего сможет разобраться как это выключить.
    Flyspell, здорово, конечно, но только код там с ошибкой. Если
    (flyspell-mode-off) заменить на (flyspell-mode nil), то вполне
    может работать. Но ничто не мешает этому коду вызваться после
    пользовательского.

    При необходимости повыключать все такие штуки, можно
    порекомендовать использовать after-init-hook.
    
~ 10keys.el - Привязка del на \C-d как-то не очень и нужна, и без неё
    всё работает. \M-O H и \M-O F - какие-то странные комбинации,
    откуда они появились? Про хак для xkb ничего не скажу, не
    пользуюсь им. Попробовал бы кто-нибудь из тех кто пользуется без
    этого хака. Работает?

~ 10more-cyrillic - в файле только комментарии и остался. Выкидываем?

~ 10mouse.el - переменная mouse-wheel-follow-mouse и так
    устанавливается в t. mwheel-install по-моему тоже уже не надо явно
    вызывать. mouse-wheel-mode после emacs -Q у меня устанавливается в
    t. xterm-mouse-mode дёргать можно если оно autoloadp. Точно так же
    и t-mouse-mode.

~ 10selection.el - С pc-selection-mode обходимся точно так же, как и с
    show-paren-mode. Переменная pc-select-selection-keys-only и так
    имеет значение по умолчанию nil. pc-select-meta-moves-sexps
    устанавливать только если никто не трогал pc-selection-mode. С
    transient-mark-mode та же беда, что и с column-number-mode. Можно
    на самом деле ещё подумать и что-нибудь обязательно придумается.

Это всё из emacs-base. Если пробежаться по другим пакетам, которые
оставляют в /etc/emacs/site-start.d свои файлики, то там тоже ловится
очень немало пустых файлов, да и забавного там тоже немало.

Я тут подумал, на самом деле, что если повыкидывать из этих скриптов
весь мусор, то с этим даже и эить можно будет в режиме
site-start.el. :)


-- 
Best Regards!
Alexey Voinov

voins@voins.program.ru
voins@altlinux.ru

[-- Attachment #2: Type: application/pgp-signature, Size: 188 bytes --]

  reply	other threads:[~2007-08-25 18:43 UTC|newest]

Thread overview: 24+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2007-08-24 23:20 Michael Pozhidaev
2007-08-25  7:45 ` Igor Vlasenko
2007-08-25  8:30   ` Alexey Voinov
2007-08-25 12:51     ` Eugene Vlasov
2007-08-25 18:43       ` Alexey Voinov [this message]
2007-08-25 20:35         ` [devel] emacs-base " Eugene Vlasov
2007-08-25 22:51         ` [devel] " Igor Vlasenko
2007-08-25 17:09     ` Michael Pozhidaev
2007-08-25 16:23   ` Michael Pozhidaev
2007-08-25 16:45     ` Alexey I. Froloff
2007-08-25 17:14       ` Michael Pozhidaev
2007-08-25 22:10         ` Eugene Vlasov
2007-08-25 22:37           ` Michael Pozhidaev
2007-08-26 13:43             ` Eugene Vlasov
2007-08-26 15:51               ` Alexey Voinov
2007-08-26 16:50                 ` Michael Pozhidaev
2007-08-26 18:59                   ` Alexey Voinov
2007-08-26 20:35                     ` Michael Pozhidaev
2007-08-26 15:58               ` Michael Pozhidaev
2007-08-25 21:47     ` Igor Vlasenko
2007-08-25 22:56       ` Michael Pozhidaev
2007-08-25 23:37         ` Igor Vlasenko
2007-08-25 23:50           ` Michael Pozhidaev
2007-08-25 10:28 ` Eugene Vlasov

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=m3y7fzlajr.fsf@altlinux.ru \
    --to=voins@altlinux.ru \
    --cc=devel@lists.altlinux.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

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