all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
* describe-mode "some-mode"?
@ 2014-08-22 17:27 lee
  2014-08-22 18:21 ` Drew Adams
       [not found] ` <mailman.7404.1408731692.1147.help-gnu-emacs@gnu.org>
  0 siblings, 2 replies; 23+ messages in thread
From: lee @ 2014-08-22 17:27 UTC (permalink / raw)
  To: help-gnu-emacs

Hi,

is there a function like describe-key which describes a mode specified
by the user?

The docstring of describe-mode says it either describes the mode of the
current buffer or of the buffer given.  How can I get a description of a
mode without enabling the mode in a buffer?


-- 
GNU Emacs 24.4.50.2 (x86_64-unknown-linux-gnu, X toolkit, Xaw3d scroll bars)
 of 2014-08-17 on yun.yagibdah.de



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

* RE: describe-mode "some-mode"?
  2014-08-22 17:27 describe-mode "some-mode"? lee
@ 2014-08-22 18:21 ` Drew Adams
  2014-08-23 12:49   ` lee
       [not found]   ` <mailman.7427.1408798399.1147.help-gnu-emacs@gnu.org>
       [not found] ` <mailman.7404.1408731692.1147.help-gnu-emacs@gnu.org>
  1 sibling, 2 replies; 23+ messages in thread
From: Drew Adams @ 2014-08-22 18:21 UTC (permalink / raw)
  To: lee, help-gnu-emacs

> is there a function like describe-key which describes a mode specified
> by the user?
> 
> The docstring of describe-mode says it either describes the mode of the
> current buffer or of the buffer given.  How can I get a description of a
> mode without enabling the mode in a buffer?

Something like this will get you started. For more info (e.g. to include minor-mode info) see the definition of `describe-mode'.  You could also improve the interactive spec, to use completion against major modes or something.

(defun my-describe-mode (mode)
  (interactive (list (intern (read-string "Mode: "))))
  (with-help-window (help-buffer)
    (with-current-buffer (help-buffer)
      (insert (help-documentation mode nil 'ADD-HELP-BUTTONS)))))

On the other hand, it is OK and simple to instead create a temporary buffer, put it in the mode, and use `describe-mode' there.



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

* Re: describe-mode "some-mode"?
       [not found] ` <mailman.7404.1408731692.1147.help-gnu-emacs@gnu.org>
@ 2014-08-22 19:04   ` Emanuel Berg
  2014-08-23  3:27     ` IELM (was: Re: describe-mode "some-mode"?) Emanuel Berg
  0 siblings, 1 reply; 23+ messages in thread
From: Emanuel Berg @ 2014-08-22 19:04 UTC (permalink / raw)
  To: help-gnu-emacs

Drew Adams <drew.adams@oracle.com> writes:

> On the other hand, it is OK and simple to instead
> create a temporary buffer, put it in the mode, and
> use describe-mode' there.

It is OK, but the OP is right, and that code should be
made official, if there isn't anything else to this
extent.

Isn't there some REPL mode where, like in Clojure, you
can do for example (source n) and (doc name)?

-- 
underground experts united


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

* IELM (was: Re: describe-mode "some-mode"?)
  2014-08-22 19:04   ` Emanuel Berg
@ 2014-08-23  3:27     ` Emanuel Berg
  2014-08-23 13:20       ` describe-mode "some-mode": (documentation some-mode) (was: IELM) lee
       [not found]       ` <mailman.7429.1408800080.1147.help-gnu-emacs@gnu.org>
  0 siblings, 2 replies; 23+ messages in thread
From: Emanuel Berg @ 2014-08-23  3:27 UTC (permalink / raw)
  To: help-gnu-emacs

Emanuel Berg <embe8573@student.uu.se> writes:

> It is OK, but the OP is right, and that code should
> be made official, if there isn't anything else to
> this extent.
>
> Isn't there some REPL mode where, like in Clojure,
> you can do for example (source n) and (doc name)?

Found it (sort of).

It is `M-x ielm' and then (documentation FUNCTION). It
works only for functions. But faces and variables also
have documentation... There should be a generic such
command!

I didn't find a (source n) equivalent.

Also, the IELM and/or `documentation' doesn't seem to
wrap lines or respect the \n in the docstrings. Makes
it a lot less practical.

-- 
underground experts united


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

* Re: describe-mode "some-mode"?
  2014-08-22 18:21 ` Drew Adams
@ 2014-08-23 12:49   ` lee
  2014-08-23 15:29     ` Drew Adams
       [not found]     ` <mailman.7432.1408807808.1147.help-gnu-emacs@gnu.org>
       [not found]   ` <mailman.7427.1408798399.1147.help-gnu-emacs@gnu.org>
  1 sibling, 2 replies; 23+ messages in thread
From: lee @ 2014-08-23 12:49 UTC (permalink / raw)
  To: help-gnu-emacs

Drew Adams <drew.adams@oracle.com> writes:

>> is there a function like describe-key which describes a mode specified
>> by the user?
>> 
>> The docstring of describe-mode says it either describes the mode of the
>> current buffer or of the buffer given.  How can I get a description of a
>> mode without enabling the mode in a buffer?
>
> Something like this will get you started. For more info (e.g. to include minor-mode info) see the definition of `describe-mode'.  You could also improve the interactive spec, to use completion against major modes or something.
>
> (defun my-describe-mode (mode)
>   (interactive (list (intern (read-string "Mode: "))))
>   (with-help-window (help-buffer)
>     (with-current-buffer (help-buffer)
>       (insert (help-documentation mode nil 'ADD-HELP-BUTTONS)))))

,----
| Compiling file /home/lee/emacs/my-helper-functions.el at Sat Aug 23 14:44:35 2014
| 
| In end of data:
| my-helper-functions.el:116:1:Warning: the function `help-documentation' is not
|     known to be defined.
`----

> On the other hand, it is OK and simple to instead create a temporary buffer, put it in the mode, and use `describe-mode' there.

Yes, I thought about writing a function to do just that and thought it
shouldn't be necessary to create a dummy-buffer to see the docstring for
a particular mode.  Emacs is self-documenting :)

It seems I'd have to do just that for now ...


-- 
GNU Emacs 24.4.50.2 (x86_64-unknown-linux-gnu, X toolkit, Xaw3d scroll bars)
 of 2014-08-17 on yun.yagibdah.de



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

* describe-mode "some-mode": (documentation some-mode) (was: IELM)
  2014-08-23  3:27     ` IELM (was: Re: describe-mode "some-mode"?) Emanuel Berg
@ 2014-08-23 13:20       ` lee
       [not found]       ` <mailman.7429.1408800080.1147.help-gnu-emacs@gnu.org>
  1 sibling, 0 replies; 23+ messages in thread
From: lee @ 2014-08-23 13:20 UTC (permalink / raw)
  To: help-gnu-emacs

Emanuel Berg <embe8573@student.uu.se> writes:

> Emanuel Berg <embe8573@student.uu.se> writes:
>
>> It is OK, but the OP is right, and that code should
>> be made official, if there isn't anything else to
>> this extent.
>>
>> Isn't there some REPL mode where, like in Clojure,
>> you can do for example (source n) and (doc name)?
>
> Found it (sort of).
>
> It is `M-x ielm' and then (documentation FUNCTION). It
> works only for functions. But faces and variables also
> have documentation... There should be a generic such
> command!
>
> I didn't find a (source n) equivalent.
>
> Also, the IELM and/or `documentation' doesn't seem to
> wrap lines or respect the \n in the docstrings. Makes
> it a lot less practical.


(defun my-describe-mode ()
  "Display the documentation of MODE."
  (interactive)
  (let ((mode (list (intern (read-string "Mode: ")))))
    (unless (functionp mode)
      (with-current-buffer (switch-to-buffer-other-window "my-describe-mode")
	(insert (documentation mode))))))


This inserts "Keyboard macro." into the buffer (without the quotes).
I'm not too sure about what I'm doing here ...

When I use (help-buffer) instead of "my-describe-mode" for a buffer, the
(help-buffer) might be read-only?


-- 
GNU Emacs 24.4.50.2 (x86_64-unknown-linux-gnu, X toolkit, Xaw3d scroll bars)
 of 2014-08-17 on yun.yagibdah.de



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

* RE: describe-mode "some-mode"?
  2014-08-23 12:49   ` lee
@ 2014-08-23 15:29     ` Drew Adams
  2014-08-30 11:29       ` lee
       [not found]     ` <mailman.7432.1408807808.1147.help-gnu-emacs@gnu.org>
  1 sibling, 1 reply; 23+ messages in thread
From: Drew Adams @ 2014-08-23 15:29 UTC (permalink / raw)
  To: lee, help-gnu-emacs

> >> is there a function like describe-key which describes a mode specified
> >> by the user?
> >>
> >> The docstring of describe-mode says it either describes the mode of the
> >> current buffer or of the buffer given.  How can I get a description of a
> >> mode without enabling the mode in a buffer?
> >
> > Something like this will get you started. For more info (e.g. to include
> > minor-mode info) see the definition of `describe-mode'.  You could also
> > improve the interactive spec, to use completion against major modes or
> > something.
> >
> > (defun my-describe-mode (mode)
> >   (interactive (list (intern (read-string "Mode: "))))
> >   (with-help-window (help-buffer)
> >     (with-current-buffer (help-buffer)
> >       (insert (help-documentation mode nil 'ADD-HELP-BUTTONS)))))
> 
> Warning: the function `help-documentation' is not known to be defined.

My bad.  Sometimes I forget what is provided from emacs -Q and what
is from my code (I should have tested it with emacs -Q).

`help-documentation' is defined in `help-fns+.el'
(http://www.emacswiki.org/emacs-en/download/help-fns%2b.el).  It is
like the vanilla function `documentation', but it uses
`help-substitute-command-keys' so that keys mentioned in the help
become links to their doc.

Using only vanilla functions:

(defun my-describe-mode (mode)
  (interactive (list (intern (read-string "Mode: "))))
  (with-help-window (help-buffer)
    (with-current-buffer (help-buffer)
      (insert (substitute-command-keys (documentation mode))))))

> > On the other hand, it is OK and simple to instead create a temporary
> > buffer, put it in the mode, and use `describe-mode' there.
> 
> Yes, I thought about writing a function to do just that and thought it
> shouldn't be necessary to create a dummy-buffer to see the docstring for
> a particular mode.  Emacs is self-documenting :)
> 
> It seems I'd have to do just that for now ...

(defun my-describe-mode2 (mode)
  (interactive (list (intern (read-string "Mode: "))))
  (with-temp-buffer
    (funcall mode)
    (describe-mode)))

M-x my-describe-mode2 RET emacs-lisp-mode RET



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

* Re: describe-mode "some-mode"?
       [not found]     ` <mailman.7432.1408807808.1147.help-gnu-emacs@gnu.org>
@ 2014-08-24  1:56       ` Emanuel Berg
  2014-08-24  2:46         ` Drew Adams
       [not found]         ` <mailman.7448.1408848386.1147.help-gnu-emacs@gnu.org>
  0 siblings, 2 replies; 23+ messages in thread
From: Emanuel Berg @ 2014-08-24  1:56 UTC (permalink / raw)
  To: help-gnu-emacs

Drew Adams <drew.adams@oracle.com> writes:

> `help-documentation' is defined in `help-fns+.el'
> (http://www.emacswiki.org/emacs-en/download/help-fns%2b.el).
> It is like the vanilla function `documentation', but
> it uses `help-substitute-command-keys' so that keys
> mentioned in the help become links to their doc.

Why isn't such a helpful feature itself vanilla?

> Using only vanilla functions:
>
> (defun my-describe-mode (mode) (interactive (list
> (intern (read-string "Mode: ")))) (with-help-window
> (help-buffer) (with-current-buffer (help-buffer)
> (insert (substitute-command-keys (documentation
> mode))))))
>
> ...
>
> (defun my-describe-mode (mode) (interactive (list
> (intern (read-string "Mode: ")))) (with-temp-buffer
> (funcall mode) (describe-mode)))

And make one of those vanilla as well!

And then - as it seems only the lowercase m is employed
by the help system, for describing the current buffer
modes:

(global-set-key "\C-hM" 'my-describe-mode)

But, for message-mode, those don't give identical
output for me with respect to the minor modes. Perhaps
Gnus enables something in a hook that is not part of
plain message-mode. So you should be careful separating
when you want to describe a mode in general, and the
mode specifically in effect for the current buffer!

my-describe-mode:

    Enabled minor modes: Abbrev Auto-Composition
    Auto-Fill Global-Font-Lock Shell-Dirtrack
    Show-Paren Transient-Mark

describe-mode:

    Enabled minor modes: Abbrev Auto-Composition
    Auto-Fill Font-Lock Global-Font-Lock
    Gnus-Message-Citation Shell-Dirtrack Show-Paren
    Transient-Mark

-- 
underground experts united


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

* Re: describe-mode "some-mode": (documentation some-mode) (was: IELM)
       [not found]       ` <mailman.7429.1408800080.1147.help-gnu-emacs@gnu.org>
@ 2014-08-24  2:05         ` Emanuel Berg
  2014-08-30 11:42           ` describe-mode "some-mode": (documentation some-mode) lee
  0 siblings, 1 reply; 23+ messages in thread
From: Emanuel Berg @ 2014-08-24  2:05 UTC (permalink / raw)
  To: help-gnu-emacs

lee <lee@yun.yagibdah.de> writes:

> (defun my-describe-mode () "Display the documentation
> of MODE." (interactive) (let ((mode (list (intern
> (read-string "Mode: "))))) (unless (functionp mode)
> (with-current-buffer (switch-to-buffer-other-window
> "my-describe-mode") (insert (documentation mode))))))
>
> This inserts "Keyboard macro." into the buffer
> (without the quotes). I'm not too sure about what I'm
> doing here ...

What are you trying to do?

Try: `M-x ielm RET', then type

(documentation 'emacs-lisp-mode)

and hit RET. See that it works except the \n's don't
get respected, so it is all on one/the same line.

I don't think it is wise to fiddle with
`documentation', so probably some wrapper must use
`documentation' to extract the docstring, and then
output it, substituting the \n's for newlines (and
more).

Get back to you on this.

> When I use (help-buffer) instead of
> "my-describe-mode" for a buffer, the (help-buffer)
> might be read-only?

The help buffers are read-only, yes.

-- 
underground experts united


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

* Re: describe-mode "some-mode"?
       [not found]   ` <mailman.7427.1408798399.1147.help-gnu-emacs@gnu.org>
@ 2014-08-24  2:22     ` Emanuel Berg
  0 siblings, 0 replies; 23+ messages in thread
From: Emanuel Berg @ 2014-08-24  2:22 UTC (permalink / raw)
  To: help-gnu-emacs

lee <lee@yun.yagibdah.de> writes:

> Emacs is self-documenting :)

Emacs has a very clever help system that automatically
incorporates the interfaces as you add functions
(etc.). And, the help system has clever ways of
hyperlinking and accounting for the configurationism of
Emacs users, e.g., you don't "hard-document" actual
keys in docstrings, but the correct keys (for the
particular user, that may have his own keys) turn up
just the same. And more. And the documentation comes
with Emacs. Yes.

But Emacs is still not exactly self-documenting, I
wouldn't say.

Here is an example of a creative docstring: hyperlinked
(to wrap-search); keys (universal-argument will turn up
C-u for most); and, the PREFIX will turn up in the face
help-argument-name.

(defun wrap-search-again (prefix)
  "Search again for the most recent search string of `wrap-search'.
   Use \\[universal-argument] \(to set the PREFIX\) to toggle case sensitiveness."
  ; ...
  )

You can use the below defun to check your docstrings.
It is intended to check the code of packages, but you
can use it to check docstrings and just ignore what it
says that is package-related (if you are not coding a
package, of course).

(defun check-pack-style ()
  (interactive)
  (checkdoc-current-buffer t) ) ; TAKE-NOTES (report all errors)

-- 
underground experts united


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

* RE: describe-mode "some-mode"?
  2014-08-24  1:56       ` Emanuel Berg
@ 2014-08-24  2:46         ` Drew Adams
       [not found]         ` <mailman.7448.1408848386.1147.help-gnu-emacs@gnu.org>
  1 sibling, 0 replies; 23+ messages in thread
From: Drew Adams @ 2014-08-24  2:46 UTC (permalink / raw)
  To: Emanuel Berg, help-gnu-emacs

> > `help-documentation' is defined in `help-fns+.el'
> > (http://www.emacswiki.org/emacs-en/download/help-fns%2b.el).
> > It is like the vanilla function `documentation', but
> > it uses `help-substitute-command-keys' so that keys
> > mentioned in the help become links to their doc.
> 
> Why isn't such a helpful feature itself vanilla?

There are lots of helpful features that are not in vanilla Emacs.
The choice is up to the Emacs maintainers.

(And one person's helpful feature is can be another's PITA.)

> > Using only vanilla functions:...
> 
> And make one of those vanilla as well!
> And then - as it seems only the lowercase m is employed
> by the help system, for describing the current buffer
> modes: (global-set-key "\C-hM" 'my-describe-mode)
> 
> But, for message-mode, those don't give identical
> output for me with respect to the minor modes.

No, they don't - see my first message.
(It has nothing to do with `message-mode'.)
The first one does not try to include minor-mode info.
That's easily added if you want it.

The point was to show that all of this is already available,
even if not in the form of a ready-made command.  The function
`documentation' that you were looking for, is used here, for
instance.

As is typically the case, the elements of what is needed to
cobble together such a "feature" (command) are in the Emacs
code.  E.g., just look at the definition of `describe-mode'.

It often happens that a given user wants a simple command to
do XYZ, while other users don't feel such a need.  And even
the same user might feel like s?he wants an XYZ command/feature
now, especially when new to Emacs (witness the many "How do I
do this `vi' thing in Emacs?"), and s?he might find later that
s?he really does not really need/want it.

How someone interacts with Emacs changes, with time and with
changes to the code s?he uses.  Many users end up making heavy
use of this or that 3rd-party library, which changes how they use
Emacs, sometimes radically.  And core Emacs features change over
time too - usually for the better.

Some features that were practically unusable in the past (or were
at least not used much) have become things that people use all of
the time.  And sometimes all it took was a few tweaks to the UI
to make them more convenient or more powerful.

That is really the power of Emacs: that every Joe & Jane ends up
fiddling with things to slightly improve them.  This often happens
because someone has an itch to scratch.  But Emacs itself deserves
a lot of the credit, because it is an environment conducive to
customization, er, improvement.

> Perhaps Gnus enables something in a hook that is not part of
> plain message-mode. So you should be careful separating
> when you want to describe a mode in general, and the
> mode specifically in effect for the current buffer!

No, see above.  It has nothing to do with Gnus.  The first
command did not bother to include minor-mode info.



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

* Re: describe-mode "some-mode"?
       [not found] <mailman.7401.1408728471.1147.help-gnu-emacs@gnu.org>
@ 2014-08-24  3:39 ` Rusi
  2014-08-30 11:36   ` lee
  0 siblings, 1 reply; 23+ messages in thread
From: Rusi @ 2014-08-24  3:39 UTC (permalink / raw)
  To: help-gnu-emacs

On Friday, August 22, 2014 10:57:24 PM UTC+5:30, lee wrote:
> Hi,

> is there a function like describe-key which describes a mode specified
> by the user?

> The docstring of describe-mode says it either describes the mode of the
> current buffer or of the buffer given.  How can I get a description of a
> mode without enabling the mode in a buffer?

[I may be missing something but]
Why not

M-x describe-function RET mode-name

?


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

* Re: describe-mode "some-mode"?
  2014-08-23 15:29     ` Drew Adams
@ 2014-08-30 11:29       ` lee
  0 siblings, 0 replies; 23+ messages in thread
From: lee @ 2014-08-30 11:29 UTC (permalink / raw)
  To: help-gnu-emacs

Drew Adams <drew.adams@oracle.com> writes:

>> >> is there a function like describe-key which describes a mode specified
>> >> by the user?
>> >>
>> >> The docstring of describe-mode says it either describes the mode of the
>> >> current buffer or of the buffer given.  How can I get a description of a
>> >> mode without enabling the mode in a buffer?
>> >
>> > Something like this will get you started. For more info (e.g. to include
>> > minor-mode info) see the definition of `describe-mode'.  You could also
>> > improve the interactive spec, to use completion against major modes or
>> > something.
>> >
>> > (defun my-describe-mode (mode)
>> >   (interactive (list (intern (read-string "Mode: "))))
>> >   (with-help-window (help-buffer)
>> >     (with-current-buffer (help-buffer)
>> >       (insert (help-documentation mode nil 'ADD-HELP-BUTTONS)))))
>> 
>> Warning: the function `help-documentation' is not known to be defined.
>
> My bad.  Sometimes I forget what is provided from emacs -Q and what
> is from my code (I should have tested it with emacs -Q).
>
> `help-documentation' is defined in `help-fns+.el'
> (http://www.emacswiki.org/emacs-en/download/help-fns%2b.el).  It is
> like the vanilla function `documentation', but it uses
> `help-substitute-command-keys' so that keys mentioned in the help
> become links to their doc.
>
> Using only vanilla functions:
>
> (defun my-describe-mode (mode)
>   (interactive (list (intern (read-string "Mode: "))))
>   (with-help-window (help-buffer)
>     (with-current-buffer (help-buffer)
>       (insert (substitute-command-keys (documentation mode))))))

Thank you very much, that works fine! :)


-- 
GNU Emacs 24.4.50.2 (x86_64-unknown-linux-gnu, X toolkit, Xaw3d scroll bars)
 of 2014-08-17 on yun.yagibdah.de



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

* Re: describe-mode "some-mode"?
  2014-08-24  3:39 ` describe-mode "some-mode"? Rusi
@ 2014-08-30 11:36   ` lee
  0 siblings, 0 replies; 23+ messages in thread
From: lee @ 2014-08-30 11:36 UTC (permalink / raw)
  To: help-gnu-emacs

Rusi <rustompmody@gmail.com> writes:

> On Friday, August 22, 2014 10:57:24 PM UTC+5:30, lee wrote:
>> Hi,
>
>> is there a function like describe-key which describes a mode specified
>> by the user?
>
>> The docstring of describe-mode says it either describes the mode of the
>> current buffer or of the buffer given.  How can I get a description of a
>> mode without enabling the mode in a buffer?
>
> [I may be missing something but]
> Why not
>
> M-x describe-function RET mode-name

That seems to work as well, thanks :)  I even thought of it briefly and
didn't try ...


-- 
GNU Emacs 24.4.50.2 (x86_64-unknown-linux-gnu, X toolkit, Xaw3d scroll bars)
 of 2014-08-17 on yun.yagibdah.de



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

* Re: describe-mode "some-mode": (documentation some-mode)
  2014-08-24  2:05         ` Emanuel Berg
@ 2014-08-30 11:42           ` lee
  2014-08-30 22:30             ` Michael Heerdegen
  0 siblings, 1 reply; 23+ messages in thread
From: lee @ 2014-08-30 11:42 UTC (permalink / raw)
  To: help-gnu-emacs

Emanuel Berg <embe8573@student.uu.se> writes:

> lee <lee@yun.yagibdah.de> writes:
>
>> (defun my-describe-mode () "Display the documentation
>> of MODE." (interactive) (let ((mode (list (intern
>> (read-string "Mode: "))))) (unless (functionp mode)
>> (with-current-buffer (switch-to-buffer-other-window
>> "my-describe-mode") (insert (documentation mode))))))
>>
>> This inserts "Keyboard macro." into the buffer
>> (without the quotes). I'm not too sure about what I'm
>> doing here ...
>
> What are you trying to do?

I was trying to insert the documentation for a mode into a buffer.

Instead of returning the docstring for the mode, (insert (documentation
mode)) inserts "Keybaord macro." into the buffer with the function I
defined to do this.

I'm wondering why apparently (documentation mode) returns "Keyboard
macro." instead of the docstring ...

>> When I use (help-buffer) instead of
>> "my-describe-mode" for a buffer, the (help-buffer)
>> might be read-only?
>
> The help buffers are read-only, yes.

Ah, interesting:  because when I tried to insert into the help-buffer,
"Keyboard macro." was inserted in the current buffer instead.  That's
why I changed the function to use (switch-to-buffer-other-window
"my-describe-mode") instead.

What's the defined or supposed behaviour of 'insert when the buffer to
insert something into is read-only?


-- 
GNU Emacs 24.4.50.2 (x86_64-unknown-linux-gnu, X toolkit, Xaw3d scroll bars)
 of 2014-08-17 on yun.yagibdah.de



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

* Re: describe-mode "some-mode": (documentation some-mode)
  2014-08-30 11:42           ` describe-mode "some-mode": (documentation some-mode) lee
@ 2014-08-30 22:30             ` Michael Heerdegen
  0 siblings, 0 replies; 23+ messages in thread
From: Michael Heerdegen @ 2014-08-30 22:30 UTC (permalink / raw)
  To: help-gnu-emacs

lee <lee@yun.yagibdah.de> writes:

> >> (defun my-describe-mode () "Display the documentation
> >> of MODE." (interactive) (let ((mode (list (intern
> >> (read-string "Mode: "))))) (unless (functionp mode)
> >> (with-current-buffer (switch-to-buffer-other-window
> >> "my-describe-mode") (insert (documentation mode))))))
> >>
> >> This inserts "Keyboard macro." into the buffer
> >> (without the quotes). I'm not too sure about what I'm
> >> doing here ...

> Instead of returning the docstring for the mode, (insert (documentation
> mode)) inserts "Keybaord macro." into the buffer with the function I
> defined to do this.
>
> I'm wondering why apparently (documentation mode) returns "Keyboard
> macro." instead of the docstring ...

It doesn't.  You bind `mode' to a list (!) of one element, the function.
You want to bind `mode' to the function itself.  (OTOH, for the
interactive spec, you would want to return a list: the list of read
arguments, which are then bound to the argument variables.)

And then, `unless' should be a `when'.

> What's the defined or supposed behaviour of 'insert when the buffer to
> insert something into is read-only?

Raising an error.

Michael.




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

* Re: describe-mode "some-mode"?
       [not found]         ` <mailman.7448.1408848386.1147.help-gnu-emacs@gnu.org>
@ 2014-08-31 22:27           ` Emanuel Berg
  2014-09-01  3:37             ` Drew Adams
       [not found]             ` <mailman.8013.1409542696.1147.help-gnu-emacs@gnu.org>
  0 siblings, 2 replies; 23+ messages in thread
From: Emanuel Berg @ 2014-08-31 22:27 UTC (permalink / raw)
  To: help-gnu-emacs

Drew Adams <drew.adams@oracle.com> writes:

>> Why isn't such a helpful feature itself vanilla?
>
> There are lots of helpful features that are not in
> vanilla Emacs.

Yes, which is good. But I believe many should be part
of vanilla Emacs, especially those that do things that
can be considered atomic or very general.

Best example I can think of, and one I have mentioned
many times on this list, is the describe-variable-short
here [1]. It echoes the variable's value in the echo
area. Simple as that.

But there are many, many examples I've come across that
are super simple, very atomic and general but
nevertheless seemingly nowhere to be found and Google
don't show any either. Probably so easy that most
people just write it. And after finding nothing, that
is what I do as well!

> The choice is up to the Emacs maintainers.

Yes, of course. 

> (And one person's helpful feature is can be another's
> PITA.)

Only if it gets in the way!

If it doesn't, you are free to use whatever features
you like.

And: Features are good. A bicycle repair shop has all
the tools of the trade. Tools that aren't used
frequently (but still, sometimes) are put on hooks on
the wall. They don't bother anyone but when they are
needed, they are right there.

> No, they don't - see my first message. (It has nothing
> to do with `message-mode'.)

That's what I used to test.

> The first one does not try to include minor-mode
> info. That's easily added if you want it.

I don't have an opinion if they should be included -
probably not, if this is to describe the major mode. I
just thought the functions were identical.

> The point was to show that all of this is already
> available, even if not in the form of a ready-made
> command. The function `documentation' that you were
> looking for, is used here, for instance.

Yeah, well, in a way everything is always available
with programming but now I talk in the sense
"instantly" available, i.e., the existence of such a
command.

> As is typically the case, the elements of what is
> needed to cobble together such a "feature" (command)
> are in the Emacs code. E.g., just look at the
> definition of `describe-mode'.

Yes, I know, I have myself done such thing hundreds of
times. Some of those times it has been called for, but
many times it is to my mind features that are not
specific to me but should be there for everyone. Next
time I come across such a situation, I'll report it to
this list and hopefully someone can tell me if such a
feature exists, if it exists somewhere else (if so, how
to look for it), and if no to both questions, where I
should publish my solution for the next guy around.
Right now, this discussion is a bit hollow because I
don't have such an example. [Read on, I remembered
several writing this.]

> It often happens that a given user wants a simple
> command to do XYZ, while other users don't feel such
> a need.

If a user wants XYZ, and there is already X, Y, and Z,
I don't think XYZ should be added, unless that's the
only use case for X, Y, and Z.

But if the user want W, and W isn't related to the
user's taste or personality - it is just a simple unit
of computation - then it should be added.

There is one `degrees-to-radians' in float-sup.el. But
it is a macro, not a function. I like it a function.
That is super-simple for me to do. But I still think
there should be such a function in vanilla Emacs. Is
it? If not, where should I look for it? If I don't find
it, where should I publish it if I write it?

Here is another example.

(defun yank-pop-back (&optional arg)
  (interactive "*p")
  (yank-pop (if arg (* arg -1) -1)) )

> And core Emacs features change over time too - usually
> for the better.

Yes, of course.

[1] http://user.it.uu.se/~embe8573/conf/emacs-init/help.el

-- 
underground experts united


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

* RE: describe-mode "some-mode"?
  2014-08-31 22:27           ` Emanuel Berg
@ 2014-09-01  3:37             ` Drew Adams
       [not found]             ` <mailman.8013.1409542696.1147.help-gnu-emacs@gnu.org>
  1 sibling, 0 replies; 23+ messages in thread
From: Drew Adams @ 2014-09-01  3:37 UTC (permalink / raw)
  To: Emanuel Berg, help-gnu-emacs

> If a user wants XYZ, and there is already X, Y, and Z,
> I don't think XYZ should be added, unless that's the
> only use case for X, Y, and Z.

If you want something added to vanilla Emacs, use
`M-x report-emacs-bug'.  That is for enhancement requests
and bug reports.  It will bring the request to the attention
of Emacs Dev, you will get their response, and the request
or issue will be tracked.



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

* Elispers all around the world (was: Re: describe-mode "some-mode"?)
       [not found]             ` <mailman.8013.1409542696.1147.help-gnu-emacs@gnu.org>
@ 2014-09-01 21:37               ` Emanuel Berg
  2014-09-01 22:27                 ` Jorge Araya Navarro
                                   ` (3 more replies)
  0 siblings, 4 replies; 23+ messages in thread
From: Emanuel Berg @ 2014-09-01 21:37 UTC (permalink / raw)
  To: help-gnu-emacs

Drew Adams <drew.adams@oracle.com> writes:

> If you want something added to vanilla Emacs, use
> `M-x report-emacs-bug'. That is for enhancement
> requests and bug reports. It will bring the request
> to the attention of Emacs Dev, you will get their
> response, and the request or issue will be tracked.

You don't think that the thousands of Joe Elisp Hackers
all over the world with their .emacs and .gnus and
private libraries; and all the packages in ELPA, MELPA,
and Marmalade; and all the code in the EmacsWiki; and
all the code published on Usenet and listbots and on
the SX sites and other forums - you don't think this
total diaspora could benefit from a more elaborate
review system than `report-emacs-bug'?

-- 
underground experts united


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

* Re: Elispers all around the world (was: Re: describe-mode "some-mode"?)
  2014-09-01 21:37               ` Elispers all around the world (was: Re: describe-mode "some-mode"?) Emanuel Berg
@ 2014-09-01 22:27                 ` Jorge Araya Navarro
  2014-09-01 22:29                 ` Drew Adams
                                   ` (2 subsequent siblings)
  3 siblings, 0 replies; 23+ messages in thread
From: Jorge Araya Navarro @ 2014-09-01 22:27 UTC (permalink / raw)
  To: help-gnu-emacs


Emanuel Berg writes:

> Drew Adams <drew.adams@oracle.com> writes:
>
>> If you want something added to vanilla Emacs, use
>> `M-x report-emacs-bug'. That is for enhancement
>> requests and bug reports. It will bring the request
>> to the attention of Emacs Dev, you will get their
>> response, and the request or issue will be tracked.
>
> You don't think that the thousands of Joe Elisp Hackers
> all over the world with their .emacs and .gnus and
> private libraries; and all the packages in ELPA, MELPA,
> and Marmalade; and all the code in the EmacsWiki; and
> all the code published on Usenet and listbots and on
> the SX sites and other forums - you don't think this
> total diaspora could benefit from a more elaborate
> review system than `report-emacs-bug'?

Well, that escalated quickly.

-- 
Pax et bonum.
Jorge Araya Navarro.
Diseñador Publicitario, Programador Python y colaborador en Parabola
 GNU/Linux-libre
https://es.gravatar.com/shackr



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

* RE: Elispers all around the world (was: Re: describe-mode "some-mode"?)
  2014-09-01 21:37               ` Elispers all around the world (was: Re: describe-mode "some-mode"?) Emanuel Berg
  2014-09-01 22:27                 ` Jorge Araya Navarro
@ 2014-09-01 22:29                 ` Drew Adams
       [not found]                 ` <mailman.8073.1409610571.1147.help-gnu-emacs@gnu.org>
       [not found]                 ` <mailman.8074.1409610608.1147.help-gnu-emacs@gnu.org>
  3 siblings, 0 replies; 23+ messages in thread
From: Drew Adams @ 2014-09-01 22:29 UTC (permalink / raw)
  To: Emanuel Berg, help-gnu-emacs

> > If you want something added to vanilla Emacs, use
> > `M-x report-emacs-bug'. That is for enhancement
> > requests and bug reports. It will bring the request
> > to the attention of Emacs Dev, you will get their
> > response, and the request or issue will be tracked.
> 
> You don't think that the thousands of Joe Elisp Hackers
> all over the world with their .emacs and .gnus and
> private libraries; and all the packages in ELPA, MELPA,
> and Marmalade; and all the code in the EmacsWiki; and
> all the code published on Usenet and listbots and on
> the SX sites and other forums - you don't think this
> total diaspora could benefit from a more elaborate
> review system than `report-emacs-bug'?

Same advice applies.

If you want your "more elaborate review system" to come
into being to benefit that diaspora, and if you want it to
be available in Emacs itself or to affect anything that is
distributed with GNU Emacs, then `M-x report-emacs-bug' is
the best way to communicate your suggestion about it.

Your suggestion can include code, of course, if you have
some to offer for this.

And if you want that but you have nothing concrete or
specific to request or offer now, and you want to invite
discussion about your incipient idea that might eventually
lead to something real, you can open a thread to discuss
it on emacs-devel@gnu.org, the Emacs development list.

In short, such developments do not fall from the sky.
If you want to affect GNU Emacs then my advice is to
contact those who develop and maintain it.

All of this applies *IF* you care about affecting vanilla
Emacs - see that qualification in the first line you quoted,
above.



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

* Re: Elispers all around the world (was: Re: describe-mode "some-mode"?)
       [not found]                 ` <mailman.8073.1409610571.1147.help-gnu-emacs@gnu.org>
@ 2014-09-01 23:10                   ` Emanuel Berg
  0 siblings, 0 replies; 23+ messages in thread
From: Emanuel Berg @ 2014-09-01 23:10 UTC (permalink / raw)
  To: help-gnu-emacs

Drew Adams <drew.adams@oracle.com> writes:

> All of this applies *IF* you care about affecting
> vanilla Emacs - see that qualification in the first
> line you quoted, above.

No, I don't really care if it is in the vanilla Emacs
or not. It it is good, it would make sense for it to
be. But as long as it is available and easily
integrated it isn't that important. Example: I use
Emacs-W3M and Gnus every day. Gnus is part of Emacs and
Emacs-W3M is not. That doesn't bother me, I can't say.
To me they are as much parts of Emacs. For other people
that might not find Emacs-W3M for this reason or might
run into problems installing/upgrading it, perhaps it
is a problem, I don't know. (Note: What I remember
installing Emacs-W3M is child's play.)

The way I would to it are along the lines:

1. You have a problem.

2. By specifying the problem, you are presented with
   the available solutions to that problem. Some of
   those solutions may be only partial matches, but
   they can be beneficial to you, still.

3. If you don't find a solution, you solve it, but it
   doesn't stop there: you submit your solution and
   describe formally or semi-formally what problem your
   solution aims to solve. So the next time someone
   faces this problem, your solution will be displayed
   at (2).

In time, it'll be clear that most problems only get one
or two solutions that are serious and have passed the
test of time, also receiving the famous distributed
peer-to-peer review to get the last details figured out
and perfected.

In even more time - yes, the most popular solutions
should (most often) be added to vanilla Emacs if they
solve problems that are general in nature. (But this
shouldn't be automatized, of course.)

As an experiment why such a system is beneficial, just
code whatever in Elisp. Then pick a line at random.
Pretend you didn't know how to do that, or that that
function didn't exist. Use Google to search for a
solution. Many times you get Common Lisp or even C
solutions! (And to use Google to find Elisp code -
brr!)

In the AI world, this type of system is called an
expert system. It is usually implemented as a finite
state machine with the transitions based on probability
theory.

-- 
underground experts united


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

* Re: Elispers all around the world (was: Re: describe-mode "some-mode"?)
       [not found]                 ` <mailman.8074.1409610608.1147.help-gnu-emacs@gnu.org>
@ 2014-09-01 23:17                   ` Emanuel Berg
  0 siblings, 0 replies; 23+ messages in thread
From: Emanuel Berg @ 2014-09-01 23:17 UTC (permalink / raw)
  To: help-gnu-emacs

Jorge Araya Navarro <elcorreo@deshackra.com> writes:

> Well, that escalated quickly.

See my reply to Mr. Adams' posts.

It is not just about submitting suggestions, it is
about searching for what you want and then contributing
your suggestions so that not people have to do the same
thing, over and over.

I am not in principle against "reinventing the wheel" -
it may be interesting to do so, and fun - it is more,
you shouldn't have to do it, if and when you don't want
to.

Many, many times have a coded things that I have been
100% sure has been coded many, many times before me.
Sometimes I have not cared to even look: even if I had
been able to find it (not certain), and even if that
would have saved me time (compared to coding it), it is
just so unpleasant to Google for Elisp (and browse
forums with a bunch of morons being angry with each
other, read threads that just stops with no solution,
etc.) - I might as well write it myself.

-- 
underground experts united


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

end of thread, other threads:[~2014-09-01 23:17 UTC | newest]

Thread overview: 23+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-08-22 17:27 describe-mode "some-mode"? lee
2014-08-22 18:21 ` Drew Adams
2014-08-23 12:49   ` lee
2014-08-23 15:29     ` Drew Adams
2014-08-30 11:29       ` lee
     [not found]     ` <mailman.7432.1408807808.1147.help-gnu-emacs@gnu.org>
2014-08-24  1:56       ` Emanuel Berg
2014-08-24  2:46         ` Drew Adams
     [not found]         ` <mailman.7448.1408848386.1147.help-gnu-emacs@gnu.org>
2014-08-31 22:27           ` Emanuel Berg
2014-09-01  3:37             ` Drew Adams
     [not found]             ` <mailman.8013.1409542696.1147.help-gnu-emacs@gnu.org>
2014-09-01 21:37               ` Elispers all around the world (was: Re: describe-mode "some-mode"?) Emanuel Berg
2014-09-01 22:27                 ` Jorge Araya Navarro
2014-09-01 22:29                 ` Drew Adams
     [not found]                 ` <mailman.8073.1409610571.1147.help-gnu-emacs@gnu.org>
2014-09-01 23:10                   ` Emanuel Berg
     [not found]                 ` <mailman.8074.1409610608.1147.help-gnu-emacs@gnu.org>
2014-09-01 23:17                   ` Emanuel Berg
     [not found]   ` <mailman.7427.1408798399.1147.help-gnu-emacs@gnu.org>
2014-08-24  2:22     ` describe-mode "some-mode"? Emanuel Berg
     [not found] ` <mailman.7404.1408731692.1147.help-gnu-emacs@gnu.org>
2014-08-22 19:04   ` Emanuel Berg
2014-08-23  3:27     ` IELM (was: Re: describe-mode "some-mode"?) Emanuel Berg
2014-08-23 13:20       ` describe-mode "some-mode": (documentation some-mode) (was: IELM) lee
     [not found]       ` <mailman.7429.1408800080.1147.help-gnu-emacs@gnu.org>
2014-08-24  2:05         ` Emanuel Berg
2014-08-30 11:42           ` describe-mode "some-mode": (documentation some-mode) lee
2014-08-30 22:30             ` Michael Heerdegen
     [not found] <mailman.7401.1408728471.1147.help-gnu-emacs@gnu.org>
2014-08-24  3:39 ` describe-mode "some-mode"? Rusi
2014-08-30 11:36   ` lee

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.