unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* bug#12721: 24.2; package-installed-p behavior on emacs startup
@ 2012-10-24 12:45 kostafey
  2012-10-24 17:32 ` Glenn Morris
  2012-10-24 17:53 ` Stefan Monnier
  0 siblings, 2 replies; 11+ messages in thread
From: kostafey @ 2012-10-24 12:45 UTC (permalink / raw)
  To: 12721

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

How the function package-installed-p should behave on emacs startup if
some package is already installed? It seems that it returns nil for
installed package on emacs startup.

Here is the full .emacs file (used for this test):

(require 'package)
(message "**** auto-complete is installed: %s ****" (package-installed-p
'auto-complete))

auto-complete package is installed for this moument, but during emacs
sturtup *Messages* buffer shows:

**** auto-complete is installed: nil ****

But after sturtup the evaluation of the expression

(message "**** auto-complete is installed: %s ****" (package-installed-p
'auto-complete))

returns:

**** auto-complete is installed: t ****

But how it is possible to install just not already installed packages on
startup. For this moument all packages are re-downloaded and reinstalled
for me during every emacs startup.


In GNU Emacs 24.2.1 (i386-mingw-nt5.1.2600)
 of 2012-08-29 on MARVIN
Windowing system distributor `Microsoft Corp.', version 5.1.2600
Configured using:
 `configure --with-gcc (4.6) --cflags
 -ID:/devel/emacs/libs/libXpm-3.5.8/include
 -ID:/devel/emacs/libs/libXpm-3.5.8/src
 -ID:/devel/emacs/libs/libpng-dev_1.4.3-1/include
 -ID:/devel/emacs/libs/zlib-dev_1.2.5-2/include
 -ID:/devel/emacs/libs/giflib-4.1.4-1/include
 -ID:/devel/emacs/libs/jpeg-6b-4/include
 -ID:/devel/emacs/libs/tiff-3.8.2-1/include
 -ID:/devel/emacs/libs/gnutls-3.0.9/include'

Important settings:
  value of $LC_ALL: nil
  value of $LC_COLLATE: nil
  value of $LC_CTYPE: nil
  value of $LC_MESSAGES: nil
  value of $LC_MONETARY: nil
  value of $LC_NUMERIC: nil
  value of $LC_TIME: nil
  value of $LANG: RUS
  value of $XMODIFIERS: nil
  locale-coding-system: cp1251
  default enable-multibyte-characters: t

Major mode: Fundamental

Minor modes in effect:
  tooltip-mode: t
  mouse-wheel-mode: t
  tool-bar-mode: t
  menu-bar-mode: t
  file-name-shadow-mode: t
  global-font-lock-mode: t
  font-lock-mode: t
  blink-cursor-mode: t
  auto-composition-mode: t
  auto-encryption-mode: t
  auto-compression-mode: t
  line-number-mode: t
  transient-mark-mode: t

Recent input:
<help-echo> <help-echo> <help-echo> <help-echo> <help-echo>
<help-echo> <help-echo> <help-echo> <help-echo> <help-echo>
<help-echo> <help-echo> <help-echo> <help-echo> <help-echo>
<menu-bar> <buffer> C-a <help-echo> <help-echo> <help-echo>
<menu-bar> <file> <open-file> <help-echo> <help-echo>
<tool-bar> <open-file> <down-mouse-1> <mouse-1> C-x
C-e <help-echo> <help-echo> <menu-bar> <buffer> C-a
<help-echo> <help-echo> <help-echo> <help-echo> <help-echo>
<help-echo> <help-echo> <help-echo> <help-echo> <menu-bar>
<help-menu> <send-emacs-bug-report>

Recent messages:
**** auto-complete is installed: nil ****
memoize-wrap-frame-local: Symbol's function definition is void: gensym
Quit
Loading vc-git...done
**** auto-complete is installed: t ****
"**** auto-complete is installed: t ****"

Load-path shadows:
None found.

Features:
(shadow sort gnus-util mail-extr emacsbug message format-spec rfc822 mml
easymenu mml-sec mm-decode mm-bodies mm-encode mail-parse rfc2231
mailabbrev gmm-utils mailheader sendmail regexp-opt rfc2047 rfc2045
ietf-drums mm-util mail-prsvr mail-utils vc-git finder-inf package
tabulated-list time-date tooltip ediff-hook vc-hooks lisp-float-type
mwheel dos-w32 disp-table ls-lisp w32-win w32-vars tool-bar dnd fontset
image fringe lisp-mode register page menu-bar rfn-eshadow timer select
scroll-bar mouse jit-lock font-lock syntax facemenu font-core frame cham
georgian utf-8-lang misc-lang vietnamese tibetan thai tai-viet lao
korean japanese hebrew greek romanian slovak czech european ethiopic
indian cyrillic chinese case-table epa-hook jka-cmpr-hook help simple
abbrev minibuffer loaddefs button faces cus-face files text-properties
overlay sha1 md5 base64 format env code-pages mule custom widget
hashtable-print-readable backquote make-network-process multi-tty emacs)

[-- Attachment #2: Type: text/html, Size: 5474 bytes --]

^ permalink raw reply	[flat|nested] 11+ messages in thread

* bug#12721: 24.2; package-installed-p behavior on emacs startup
  2012-10-24 12:45 bug#12721: 24.2; package-installed-p behavior on emacs startup kostafey
@ 2012-10-24 17:32 ` Glenn Morris
  2012-10-24 17:53 ` Stefan Monnier
  1 sibling, 0 replies; 11+ messages in thread
From: Glenn Morris @ 2012-10-24 17:32 UTC (permalink / raw)
  To: kostafey; +Cc: 12721

kostafey wrote:

> How the function package-installed-p should behave on emacs startup if
> some package is already installed? It seems that it returns nil for
> installed package on emacs startup.

It needs package-initialize to have been run, which is only done after
your init file has been read, as documented eg in C-h v
package-enable-at-startup. Maybe you could run package-initialize
explicitly and set package-enable-at-startup to nil? Or use
after-init-hook?





^ permalink raw reply	[flat|nested] 11+ messages in thread

* bug#12721: 24.2; package-installed-p behavior on emacs startup
  2012-10-24 12:45 bug#12721: 24.2; package-installed-p behavior on emacs startup kostafey
  2012-10-24 17:32 ` Glenn Morris
@ 2012-10-24 17:53 ` Stefan Monnier
  2012-10-25  5:13   ` kostafey
  1 sibling, 1 reply; 11+ messages in thread
From: Stefan Monnier @ 2012-10-24 17:53 UTC (permalink / raw)
  To: kostafey; +Cc: 12721

> (require 'package)
> (message "**** auto-complete is installed: %s ****" (package-installed-p
> 'auto-complete))

IIUC rather than (require 'package) you need to (package-initialize).


        Stefan





^ permalink raw reply	[flat|nested] 11+ messages in thread

* bug#12721: 24.2; package-installed-p behavior on emacs startup
  2012-10-24 17:53 ` Stefan Monnier
@ 2012-10-25  5:13   ` kostafey
  2012-10-25 12:39     ` Stefan Monnier
  0 siblings, 1 reply; 11+ messages in thread
From: kostafey @ 2012-10-25  5:13 UTC (permalink / raw)
  To: 12721

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

> IIUC rather than (require 'package) you need to (package-initialize).

Thank you a lot!
(package-initialize) works fine.
The issue should be closed.

[-- Attachment #2: Type: text/html, Size: 202 bytes --]

^ permalink raw reply	[flat|nested] 11+ messages in thread

* bug#12721: 24.2; package-installed-p behavior on emacs startup
  2012-10-25  5:13   ` kostafey
@ 2012-10-25 12:39     ` Stefan Monnier
  2012-10-26  1:33       ` Richard Stallman
  0 siblings, 1 reply; 11+ messages in thread
From: Stefan Monnier @ 2012-10-25 12:39 UTC (permalink / raw)
  To: kostafey; +Cc: 12721-done

>> IIUC rather than (require 'package) you need to (package-initialize).
> Thank you a lot!
> (package-initialize) works fine.

I've changed package-installed-p to signal an error if called before
package-initialize.  Thank you, closing,


        Stefan





^ permalink raw reply	[flat|nested] 11+ messages in thread

* bug#12721: 24.2; package-installed-p behavior on emacs startup
  2012-10-25 12:39     ` Stefan Monnier
@ 2012-10-26  1:33       ` Richard Stallman
  2012-10-26  2:05         ` Stefan Monnier
  0 siblings, 1 reply; 11+ messages in thread
From: Richard Stallman @ 2012-10-26  1:33 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: 12721-done, kostafey

Why make package-installed-p something different from featurep?

-- 
Dr Richard Stallman
President, Free Software Foundation
51 Franklin St
Boston MA 02110
USA
www.fsf.org  www.gnu.org
Skype: No way! That's nonfree (freedom-denying) software.
  Use Ekiga or an ordinary phone call






^ permalink raw reply	[flat|nested] 11+ messages in thread

* bug#12721: 24.2; package-installed-p behavior on emacs startup
  2012-10-26  1:33       ` Richard Stallman
@ 2012-10-26  2:05         ` Stefan Monnier
  2012-10-27  1:14           ` Richard Stallman
  0 siblings, 1 reply; 11+ messages in thread
From: Stefan Monnier @ 2012-10-26  2:05 UTC (permalink / raw)
  To: rms; +Cc: 12721-done, kostafey

> Why make package-installed-p something different from featurep?

`featurep' typically indicates if a particular file has been loaded,
whereas `package-installed-p' indicates whether the package is available
(e.g. can be loaded).


        Stefan





^ permalink raw reply	[flat|nested] 11+ messages in thread

* bug#12721: 24.2; package-installed-p behavior on emacs startup
  2012-10-26  2:05         ` Stefan Monnier
@ 2012-10-27  1:14           ` Richard Stallman
  2012-10-27  2:43             ` Stefan Monnier
  0 siblings, 1 reply; 11+ messages in thread
From: Richard Stallman @ 2012-10-27  1:14 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: 12721-done, kostafey

    `featurep' typically indicates if a particular file has been loaded,
    whereas `package-installed-p' indicates whether the package is available
    (e.g. can be loaded).

Should it be `package-available-p'?

-- 
Dr Richard Stallman
President, Free Software Foundation
51 Franklin St
Boston MA 02110
USA
www.fsf.org  www.gnu.org
Skype: No way! That's nonfree (freedom-denying) software.
  Use Ekiga or an ordinary phone call






^ permalink raw reply	[flat|nested] 11+ messages in thread

* bug#12721: 24.2; package-installed-p behavior on emacs startup
  2012-10-27  1:14           ` Richard Stallman
@ 2012-10-27  2:43             ` Stefan Monnier
  2012-10-27 18:19               ` Richard Stallman
  0 siblings, 1 reply; 11+ messages in thread
From: Stefan Monnier @ 2012-10-27  2:43 UTC (permalink / raw)
  To: rms; +Cc: 12721-done, kostafey

>     `featurep' typically indicates if a particular file has been loaded,
>     whereas `package-installed-p' indicates whether the package is available
>     (e.g. can be loaded).
> Should it be `package-available-p'?

It's probably not worse, but I don't see why it would be better.


        Stefan





^ permalink raw reply	[flat|nested] 11+ messages in thread

* bug#12721: 24.2; package-installed-p behavior on emacs startup
  2012-10-27  2:43             ` Stefan Monnier
@ 2012-10-27 18:19               ` Richard Stallman
  2012-10-27 21:54                 ` Stefan Monnier
  0 siblings, 1 reply; 11+ messages in thread
From: Richard Stallman @ 2012-10-27 18:19 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: 12721-done, kostafey

    >     `featurep' typically indicates if a particular file has been loaded,
    >     whereas `package-installed-p' indicates whether the package is available
    >     (e.g. can be loaded).
    > Should it be `package-available-p'?

    It's probably not worse, but I don't see why it would be better.

I guess it depends how clear the current name is.
It wasn't clear to me that "installed" means "installed in your system",
but maybe most people will understand it.

-- 
Dr Richard Stallman
President, Free Software Foundation
51 Franklin St
Boston MA 02110
USA
www.fsf.org  www.gnu.org
Skype: No way! That's nonfree (freedom-denying) software.
  Use Ekiga or an ordinary phone call






^ permalink raw reply	[flat|nested] 11+ messages in thread

* bug#12721: 24.2; package-installed-p behavior on emacs startup
  2012-10-27 18:19               ` Richard Stallman
@ 2012-10-27 21:54                 ` Stefan Monnier
  0 siblings, 0 replies; 11+ messages in thread
From: Stefan Monnier @ 2012-10-27 21:54 UTC (permalink / raw)
  To: rms; +Cc: 12721-done, kostafey

> I guess it depends how clear the current name is.
> It wasn't clear to me that "installed" means "installed in your system",
> but maybe most people will understand it.

Yes, I think it is fairly logical, matching the
`package-install' command.


        Stefan





^ permalink raw reply	[flat|nested] 11+ messages in thread

end of thread, other threads:[~2012-10-27 21:54 UTC | newest]

Thread overview: 11+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-10-24 12:45 bug#12721: 24.2; package-installed-p behavior on emacs startup kostafey
2012-10-24 17:32 ` Glenn Morris
2012-10-24 17:53 ` Stefan Monnier
2012-10-25  5:13   ` kostafey
2012-10-25 12:39     ` Stefan Monnier
2012-10-26  1:33       ` Richard Stallman
2012-10-26  2:05         ` Stefan Monnier
2012-10-27  1:14           ` Richard Stallman
2012-10-27  2:43             ` Stefan Monnier
2012-10-27 18:19               ` Richard Stallman
2012-10-27 21:54                 ` Stefan Monnier

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).