unofficial mirror of help-gnu-emacs@gnu.org
 help / color / mirror / Atom feed
* why pop-to-buffer has this ugly behavior?
@ 2004-01-22 18:34 Klaus Berndl
  2004-01-22 18:43 ` Klaus Berndl
                   ` (2 more replies)
  0 siblings, 3 replies; 5+ messages in thread
From: Klaus Berndl @ 2004-01-22 18:34 UTC (permalink / raw)



This is the implementation of custom-create-buffer in GNU Emacs 21.3:

,----
| (defun custom-buffer-create (options &optional name description)
|   "Create a buffer containing OPTIONS.
| Optional NAME is the name of the buffer.
| OPTIONS should be an alist of the form ((SYMBOL WIDGET)...), where
| SYMBOL is a customization option, and WIDGET is a widget for editing
| that option."
|   (unless name (setq name "*Customization*"))
|   (kill-buffer (get-buffer-create name))
|   (pop-to-buffer (get-buffer-create name))
|   (custom-buffer-create-internal options description))
`----

I have wondered why here pop-to-buffer does not split the unsplitted window in
my frame. Then i have tested the following (The value of `pop-up-windows' is
t!): 

(pop-to-buffer (get-buffer-create "*BlaBlaBla*"))

which splits an unsplitted window in 2 windows - well!

(pop-to-buffer (get-buffer-create "*Customization*"))

which does not split an unsplitted windows in 2 - very bad and ugly!

Conclusion: pop-up-buffer must have somewhere in the c-code - or maybe
display-buffer) but anyway - some logic which decides dependent on the
buffer-name if the window should be splitted or not?! I write this not to the
bug-list because it is not really a bug but it is a strong violation of one
of the most important design-principles: "Separation of concerns".

It is not the job of pop-to-buffer to decide on the buffer-name when to split
but it is the job of libraries like cus-edit.el to decide this.

Ugly things like that makes it sometimes really hard to develop
elisp-libraries like ECB.

Ciao,
Klaus

P.S.

BTW: here is how XEmacs implements custom-create-buffer - IMO the right way:

(defun custom-buffer-create (options &optional name description)
  "Create a buffer containing OPTIONS.
Optional NAME is the name of the buffer.
OPTIONS should be an alist of the form ((SYMBOL WIDGET)...), where
SYMBOL is a customization option, and WIDGET is a widget for editing
that option."
  (unless name (setq name "*Customization*"))
  (kill-buffer (get-buffer-create name))
  (switch-to-buffer (get-buffer-create name))
  (custom-buffer-create-internal options description))




-- 
Klaus Berndl			mailto: klaus.berndl@sdm.de
sd&m AG				http://www.sdm.de
software design & management	
Carl-Wery-Str. 42, 81739 Muenchen, Germany
Tel +49 89 63812-392, Fax -220

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

* Re: why pop-to-buffer has this ugly behavior?
  2004-01-22 18:34 why pop-to-buffer has this ugly behavior? Klaus Berndl
@ 2004-01-22 18:43 ` Klaus Berndl
  2004-01-22 19:04 ` Stefan Monnier
  2004-01-22 19:35 ` Kevin Rodgers
  2 siblings, 0 replies; 5+ messages in thread
From: Klaus Berndl @ 2004-01-22 18:43 UTC (permalink / raw)



Oops, please excuse making such noise..... next time i should switch on my
brain before complaining ;-)

Just examined the value of same-window-regexps........... which contains a
regexp for these *Customize...* buffers...

Please ignore my previous posting and please excuse!

<Blush>
Klaus

On 22 Jan 2004, Klaus Berndl wrote:



>  
>  This is the implementation of custom-create-buffer in GNU Emacs 21.3:
>  
>  ,----
> | (defun custom-buffer-create (options &optional name description)
> |   "Create a buffer containing OPTIONS.
> | Optional NAME is the name of the buffer.
> | OPTIONS should be an alist of the form ((SYMBOL WIDGET)...), where
> | SYMBOL is a customization option, and WIDGET is a widget for editing
> | that option."
> |   (unless name (setq name "*Customization*"))
> |   (kill-buffer (get-buffer-create name))
> |   (pop-to-buffer (get-buffer-create name))
> |   (custom-buffer-create-internal options description))
>  `----
>  
>  I have wondered why here pop-to-buffer does not split the unsplitted window
>  in my frame. Then i have tested the following (The value of
>  `pop-up-windows' is t!):
>  
>  (pop-to-buffer (get-buffer-create "*BlaBlaBla*"))
>  
>  which splits an unsplitted window in 2 windows - well!
>  
>  (pop-to-buffer (get-buffer-create "*Customization*"))
>  
>  which does not split an unsplitted windows in 2 - very bad and ugly!
>  
>  Conclusion: pop-up-buffer must have somewhere in the c-code - or maybe
>  display-buffer) but anyway - some logic which decides dependent on the
>  buffer-name if the window should be splitted or not?! I write this not to
>  the bug-list because it is not really a bug but it is a strong violation of
>  one of the most important design-principles: "Separation of concerns".
>  
>  It is not the job of pop-to-buffer to decide on the buffer-name when to
>  split but it is the job of libraries like cus-edit.el to decide this.
>  
>  Ugly things like that makes it sometimes really hard to develop
>  elisp-libraries like ECB.
>  
>  Ciao,
>  Klaus
>  
>  P.S.
>  
>  BTW: here is how XEmacs implements custom-create-buffer - IMO the right
>  way:
>  
>  (defun custom-buffer-create (options &optional name description)
>    "Create a buffer containing OPTIONS.
>  Optional NAME is the name of the buffer.
>  OPTIONS should be an alist of the form ((SYMBOL WIDGET)...), where
>  SYMBOL is a customization option, and WIDGET is a widget for editing
>  that option."
>    (unless name (setq name "*Customization*"))
>    (kill-buffer (get-buffer-create name))
>    (switch-to-buffer (get-buffer-create name))
>    (custom-buffer-create-internal options description))

-- 
Klaus Berndl			mailto: klaus.berndl@sdm.de
sd&m AG				http://www.sdm.de
software design & management	
Carl-Wery-Str. 42, 81739 Muenchen, Germany
Tel +49 89 63812-392, Fax -220

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

* Re: why pop-to-buffer has this ugly behavior?
  2004-01-22 18:34 why pop-to-buffer has this ugly behavior? Klaus Berndl
  2004-01-22 18:43 ` Klaus Berndl
@ 2004-01-22 19:04 ` Stefan Monnier
  2004-01-22 19:13   ` Klaus Berndl
  2004-01-22 19:35 ` Kevin Rodgers
  2 siblings, 1 reply; 5+ messages in thread
From: Stefan Monnier @ 2004-01-22 19:04 UTC (permalink / raw)


> It is not the job of pop-to-buffer to decide on the buffer-name when to split
> but it is the job of libraries like cus-edit.el to decide this.

Separation of concern implies that cus-edit should not need to care and
should not decide whether to split a window or create a new frame.
It should be decided by the user's preference.

Now, the bhavior of pop-to-buffer is sufficiently complex and customizable
that I can't tell you why you see this difference, but it does not only
depend on the buffer name but also on the current window (whether it's
a minibuffer or a dedicated window, for example).

> BTW: here is how XEmacs implements custom-create-buffer - IMO the right way:

This way [i.e. using switch-to-buffer] breaks when called from the
minibuffer, breaks when called from a dedicated window, and might not
correspond to the user's preference.

If all code used pop-to-buffer, ECB could solve all its problems by only
customizing pop-to-buffer, so it obviously does not inherently make things
hard for ECB-like libraries, quite the opposite.


        Stefan

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

* Re: why pop-to-buffer has this ugly behavior?
  2004-01-22 19:04 ` Stefan Monnier
@ 2004-01-22 19:13   ` Klaus Berndl
  0 siblings, 0 replies; 5+ messages in thread
From: Klaus Berndl @ 2004-01-22 19:13 UTC (permalink / raw)



I have already sent a followup to my first posting where i apologize for my
noise - was my fault - have forgotten the existence of
`same-window-regexps'...

So again: Please excuse!
Klaus

On Thu, 22 Jan 2004, Stefan Monnier wrote:



> > It is not the job of pop-to-buffer to decide on the buffer-name when to
> > split but it is the job of libraries like cus-edit.el to decide this.
>  
>  Separation of concern implies that cus-edit should not need to care and
>  should not decide whether to split a window or create a new frame.
>  It should be decided by the user's preference.
>  
>  Now, the bhavior of pop-to-buffer is sufficiently complex and customizable
>  that I can't tell you why you see this difference, but it does not only
>  depend on the buffer name but also on the current window (whether it's
>  a minibuffer or a dedicated window, for example).
>  
> > BTW: here is how XEmacs implements custom-create-buffer - IMO the right
> > way:
>  
>  This way [i.e. using switch-to-buffer] breaks when called from the
>  minibuffer, breaks when called from a dedicated window, and might not
>  correspond to the user's preference.
>  
>  If all code used pop-to-buffer, ECB could solve all its problems by only
>  customizing pop-to-buffer, so it obviously does not inherently make things
>  hard for ECB-like libraries, quite the opposite.
>  
>  
>          Stefan

-- 
Klaus Berndl			mailto: klaus.berndl@sdm.de
sd&m AG				http://www.sdm.de
software design & management	
Carl-Wery-Str. 42, 81739 Muenchen, Germany
Tel +49 89 63812-392, Fax -220

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

* Re: why pop-to-buffer has this ugly behavior?
  2004-01-22 18:34 why pop-to-buffer has this ugly behavior? Klaus Berndl
  2004-01-22 18:43 ` Klaus Berndl
  2004-01-22 19:04 ` Stefan Monnier
@ 2004-01-22 19:35 ` Kevin Rodgers
  2 siblings, 0 replies; 5+ messages in thread
From: Kevin Rodgers @ 2004-01-22 19:35 UTC (permalink / raw)


Klaus Berndl wrote:

> I have wondered why here pop-to-buffer does not split the unsplitted window in
> my frame. Then i have tested the following (The value of `pop-up-windows' is
> t!): 
> 
> (pop-to-buffer (get-buffer-create "*BlaBlaBla*"))
> 
> which splits an unsplitted window in 2 windows - well!
> 
> (pop-to-buffer (get-buffer-create "*Customization*"))
> 
> which does not split an unsplitted windows in 2 - very bad and ugly!
> 
> Conclusion: pop-up-buffer must have somewhere in the c-code - or maybe
> display-buffer) but anyway - some logic which decides dependent on the
> buffer-name if the window should be splitted or not?! I write this not to the
> bug-list because it is not really a bug but it is a strong violation of one
> of the most important design-principles: "Separation of concerns".

C-h v same-window-regexps


-- 
Kevin Rodgers

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

end of thread, other threads:[~2004-01-22 19:35 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2004-01-22 18:34 why pop-to-buffer has this ugly behavior? Klaus Berndl
2004-01-22 18:43 ` Klaus Berndl
2004-01-22 19:04 ` Stefan Monnier
2004-01-22 19:13   ` Klaus Berndl
2004-01-22 19:35 ` Kevin Rodgers

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).