From mboxrd@z Thu Jan 1 00:00:00 1970 From: Matt Price Subject: Re: naming and/or directly addressing particular windows? Date: Sun, 2 Dec 2012 00:31:52 -0500 Message-ID: References: <9480173485434C39B7ACE90E55A0FBD7@us.oracle.com> Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1 Return-path: Received: from eggs.gnu.org ([208.118.235.92]:39444) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1Tf29k-00082w-05 for emacs-orgmode@gnu.org; Sun, 02 Dec 2012 00:31:57 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1Tf29i-0006WQ-JB for emacs-orgmode@gnu.org; Sun, 02 Dec 2012 00:31:55 -0500 In-Reply-To: <9480173485434C39B7ACE90E55A0FBD7@us.oracle.com> List-Id: "General discussions about Org-mode." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: emacs-orgmode-bounces+geo-emacs-orgmode=m.gmane.org@gnu.org Sender: emacs-orgmode-bounces+geo-emacs-orgmode=m.gmane.org@gnu.org To: Drew Adams Cc: Bastien , Help-gnu-emacs@gnu.org, Org Mode , drain On Sat, Dec 1, 2012 at 10:59 AM, Drew Adams wrote: >> Anyway: is it possible to give/get a name for a window that persists >> long enough to be called in functions? > > This might help: > > (defun icicle-make-window-alist (&optional all-p) > "Return an alist of entries (WNAME . WINDOW), where WNAME names WINDOW. > The name of the buffer in a window is used as its name, unless there > is more than one window displaying the same buffer. In that case, > WNAME includes a suffix [NUMBER], to make it a unique name. The > NUMBER order among window names that differ only by their [NUMBER] is > arbitrary. > > Non-nil argument ALL-P means use windows from all visible frames. > Otherwise, use only windows from the selected frame." > (lexical-let ((win-alist ()) > (count 2) > wname new-name) > (walk-windows (lambda (w) > (setq wname (buffer-name (window-buffer w))) > (if (not (assoc wname win-alist)) > (push (cons wname w) win-alist) > (setq new-name wname) > (while (assoc new-name win-alist) > (setq new-name (format "%s[%d]" wname count) > count (1+ count))) > (push (cons new-name w) win-alist)) > (setq count 2)) > 'no-mini > (if all-p 'visible 'this-frame)) > win-alist)) > > (This is used in command `icicle-select-window-by-name', which in turn is the > action function for multi-command `icicle-select-window'. Code here: > http://www.emacswiki.org/emacs-en/download/icicles-cmd1.el.) > > I'm guessing that there are other, similar functions available on Emacs Wiki - > start here, perhaps: http://www.emacswiki.org/emacs/CategoryWindows > I'm slowly starting to understand. I now have this primitive code, which at least sets up the windows the way I want them: (defun my-windows-function () "Trying to figure out how to get a nice windows config for writers-room-mode" (interactive ) (global-linum-mode 0) (delete-other-windows) (setq my-this-win (selected-window)) (setq my-winlist '()) (add-to-list 'my-winlist (cons 'guide (selected-window)) ) (split-window-horizontally) (fix-window-horizontal-size 35) (windmove-right) (add-to-list 'my-winlist (cons 'main (selected-window)) ) (split-window-horizontally) (windmove-right) (fix-window-horizontal-size 35) (add-to-list 'my-winlist (cons 'metadata (selected-window)) ) (split-window-vertically) (windmove-down) (add-to-list 'my-winlist (cons 'not-sure-what-this-is-for (selected-window)) ) (select-window(cdr(assoc 'guide my-winlist)) ) ) The final select-window ommand demonstrates that I can now address the windows by name (yay!). The next step for me is to rewrite the existing org-tree-to-indirect-buffer function so that it reliably sends org subtree indirect buffers to the "main" window (in the middle column of the frame). The function starts at line 7091 of org.el: http://orgmode.org/w/org-mode.git/blob/lisp/org.el I'm not having an easy time figuring out how that function decides which window to use when creating and focussing on the new indirect buffer. I can see (and the documentation states) that a choice is first made between using a new or dedicated frame, or the same frame with either the original or another window. But the code to put the buffer in another window in the same frame is quite simple: ((eq org-indirect-buffer-display 'other-window) (pop-to-buffer ibuf)) I've been chasing the code down to native emacs functions -- pop-to-buffer ends up relying on display-buffer -- but I haven't yet found a place where I an specify a particular window for the new buffer. Does anyone else know a way? Thanks again, Matt