Skip to content(if available)orjump to list(if available)

Native frame transposition coming to Emacs 31

globnomulous

Kudos to the programmer, who is apparently still in high school: https://p.bauherren.ovh/

ilrwbwrkhv

> Your local web gangster

> My name is Pranshu, I'm currently an highschool student, on the way to become a proffesional freerider. I am ethniclly Indian(half Bihari and half Punjabi, for my brown brothers), you can find me in Brisbane, Australia, probably bathing in a public fountain.

Haha, so lovely. Reminds me of older times when the internet was cool and weird.

Buttons840

We've been seeking proof for years that Emacs still attracts new users--finally found one :D

BeetleB

Actually, he's a 40+ year old person. His obsession with Emacs is what prevented him from graduating high school all these years :-)

timacles

He opened his ~/.emacs file as a Junior in High School. Says he'll be ready to close it as soon as he gets this particular edit just right

taeric

I mean, this and native compilation. And the new json parser that landed. And... (I'm sure I could go on.)

What it doesn't have is a marketing department pushing it. But it has plenty of new users. No?

Buttons840

Joking aside, you're right. It's easy to imagine that Emacs has stagnated, but there are regular releases with improvements, some of them important fundamental improvements like native compilation.

I recently saw a Reddit post in a vim subreddit about using AI for coding, the response was "we don't do that here". I saw the same thing in the Emacs subreddit, and there's like 10 different packages for AI integrations, and, allegedly, Emacs is state-of-the-art when it comes to AI interactions through the editor (if only the user can configure it correctly). It's something I've been meaning to try.

https://www.reddit.com/r/neovim/comments/1js30ep/whats_every...

globnomulous

The comment you answered is tongue in cheek, the joke being that emacs is for old people.

sakesun

> Knows Perl/lisp/zig/ruby/C++/python, in order of most to least proficiency

Whoa. A highschooler who prefer Perl & Lisp.

sharkjacobs

I think this kid has a very promising freeriding career ahead of them

gumbojuice

I find myself very rarely using window features of emacs. Am I missing out on something? I value mostly screen space dedicated to the one thing I am doing.

grumbel

Not much. A horizontal split (C-x 2) can be quite useful to keep the top of a file in view while editing around at the bottom of a file. A vertical split (C-x 3) is useful when comparing files side by side. But that's about as far as I go, beyond that it just becomes annoying, as popups like from magit will show up in random subwindows, often rendering them unusable, due to that subwindow not being big enough.

kreetx

As a counterpoint, I pretty much always split into 2+ windows. A 2-window setup is a code + terminal setup with shortcuts to run commands on the terminal(s). On more complex projects there are typically more than one terminal windows.

My org-mode emacs instance for note taking is split into quite a few windows: ongoing work task(s), generic "today's scratch pad", various topical notes files, etc.

On the posted topic: I don't know whether the transposition would be useful for me though - as the layout is set up by screen orientation then only a 180 degree turn would make sense.

signa11

perhaps i might interest you in display-buffer-alist ?

useful resources:

1. https://protesilaos.com/codelog/2024-02-08-emacs-window-rule...

2. https://www.masteringemacs.org/article/demystifying-emacs-wi...

3. <this space is for rent>

geokon

Looks incredibly complicated, or maybe the article isn't written very clearly. It sounds like the packages are doing their own layout and you can override it from a central location .. Sometimes

SoftTalker

Seems like this new feature might help with that, if magit takes over or creates a new window, you can rotate or flip your window arrangement until it's in a usable space (if it works like most tiling window managers, which isn't entirely clear from TFA).

jerf

The default setup I've been using for years is to dedicate a desktop to emacs, break it into 3 windows horizontally, and then each of them fluidly switches between being full-frame in its bit and being cut in half. That gives me up to six contexts to operate in at once, though it's certainly some sort of code smell to need that many for some particular task! But 2, 3, and occasional dips into 4 are pretty common, as well as having something open for other reasons.

This is also part of why I try to mostly, but not super pendantically, maintain the discipline of keeping lines under 80ish characters most of the time. Occasional spill is no big deal but constant spill gets hard to read in this context.

Partially this is just out of habit of many years, but lately it's becoming an actual advantage. My most recent project has me diving through multiple codebases, none of them in the same language; I've followed some interactions through Perl, Java, PHP, and Typescript codebases in quick succession. Both having the multiple contexts, that I have years of muscle memory using, and not needing to load up separate IDEs for each of them has turned out to be really advantageous. Emacs may not be the "best" at handling any one language but I don't think there's much better at trying to handle all of them simultaneously.

camgunz

I do the same thing in Vim, which has turned me into the "please wrap to 80 cols" person, which I'm completely fine with haha.

hollerith

You are not alone. I've spent a lot of time over the years configuring Emacs not to split the frame unless I explicit ask for a split with C-x 2 (which I do very rarely). The first 6 ways I found to do it stopped working over the 33 years I've been using Emacs, so now I'm on version 7, which consists of (setq display-buffer-alist '((".*" (display-buffer-same-window)))) plus my own definition of compilation-goto-locus.

If I were a better Emacs citizen, I would lobby the maintainers to fix compilation-goto-locus so that it obeys display-buffer-alist like every other part of Emacs (that I know about, except for the *Completions* buffer, which does not need to be fixed IMHO because the *Completions* window reliably deletes itself when the user aborts or exits the minibuffer).

taeric

On my large screen, I find that having two windows is often quite useful. Sometimes three, but not for long.

Main use cases are:

  * Look at a "template" file as I'm working.  
  * The "occur" window 
  * Really, any grep output
  * Compilation window (This is how I run all tests)
I'd love to have it so that "output" is in the other window at all times. I haven't really found a way for that to work, too well. Especially since often working on websites. The idea behind skewer-mode is really enticing to me. I have yet to actually make that work, though.

a_e_k

Good list. A few more for me:

    * Implementation/header pairs in C++
    * Language REPLs (e.g., Python)
    * Quick calculations in Calc while coding
    * Checking dates on the calendar
    * Magit status
    * Diff buffers (especially diff-buffer-with-file)
    * Listing neighboring files with dired
    * Notes on a code base/task in an Org mode file

kmstout

For reading anything of length, I like to split horizontally into three balanced windows [1], put the buffer in all of them, and `M-x follow-mode'. At that point, I get a nice columnar display that makes better use of the screen real estate.

If you do this, you can make paging snappier and more predictable like so:

  (setf scroll-preserve-screen-position t)
  (setf next-screen-context-lines 0)
For many of the websites that I use, this arrangement combines nicely with eww to make a very screen-efficient browsing experience.

---

[1] That is, three windows of the same size side-by-side.

a_e_k

> balanced windows [1]

> [1] That is, three windows of the same size side-by-side.

`C-x +` (M-x balance-windows) for those who don't know . There's also M-x balance-windows-area.

noelwelsh

I usually have a vertical split, because it is useful to be able to refer to something else (e.g. other code, docs) while I work on my main task. I'll often have a pop up with a terminal or similar than I can bring up or dismiss with Doom shortcuts. That usually lives at the bottom. Occasionally three windows side by side is useful.

I cannot imagine using the features discussed in TFA though. They don't seem to solve anything for me.

BeetleB

Beyond the obvious answer (looking at two files at once, or a shell, or compilation buffer, or docs), I have a much simpler reason. My monitor is wide enough that if I have only one window, then all the text will be on the left end of the monitor, which means I'm constantly turning my head to work, leading to neck strain.

So even if I'm working on one thing, I do C-x 2 and use the right window, because then the beginning of the text is aligned to the center of my screen.

Yes, this is because I insist on running Emacs maximized.

codr7

C-x 3, I do the same :)

geokon

I'd love to use more than one window, but they're completely unpredictable and really hard to configure the way you want. Magit buffers will open in one way, Cider Error buffers open in some other way. And the behavior will also change based on your frame size... You can sometimes configure them, but only from the limited behaviors provided by the package itself. The behaviors are different in different packages and there is no configuration/coordination in the "runtime"

funcDropShadow

There is a central configuration, see here https://news.ycombinator.com/item?id=43642743

eddieh

I’m confused, is this operating on Emacs’ frames or windows.

** For those here that are not Emacs users these terms mean the opposite of what you’re likely used to.

skydhash

For those that don’t know. Emacs was there before windows managers was the norm (I think), so after splitting the emacs view, each part was called a window.

The whole view is called a frame and store the window layout. You can create as many frames as you, each with its own layout and in terminal mode, they would swap like i3 workspaces. But in graphic mode (GUI) they are what we call window today, what emacs users refer as windows would be panes.

tom_

It operates on frames, moving the windows inside them, similar to how transposing a matrix moves around the values it contains.

smitty1e

The joy of this is that emacs doesn't care if you have a desktop or if you're headless in a terminal. Which sounds a but morbid.

taeric

Any chance folks have pointers on how I could do this for the windows of my desktop? Running PopOS and would love to setup some keyboard macros to setup common window arrangements. I am embarrassed that I have basically no idea where to start in doing that, though. :( Would I be looking to do a Gnome plugin?

dfc

Sway/i3/etc?

taeric

Do I really have to jump to a new compositor/window manager to get this? Seems like I should be able to query the state of my desktop without doing that. :(

yjftsjthsd-h

In theory if GNOME exposes enough API surface then sure you can write a plugin to do it. I'm rather under the impression that GNOME is not particularly friendly to that kind of customization work, though. Perhaps it's better these days; I haven't paid it as much attention since jumping ship. It is entirely possible that it would be less overall work to switch to a window manager that enthusiastically exposes all the API surface you could ever ask for, but don't let that stop you from looking into it.

null

[deleted]

a_e_k

Oh, this will be nice. I've had a home-grown (rotate-windows) function in my config for a long time. I love it when I can shrink my config because core now has an equivalent.

null

[deleted]

null

[deleted]

masutaka

I once created a custom function that toggles between vertical and horizontal splits of two windows. It’s quite handy. https://github.com/masutaka/dotfiles-public/blob/66c976fb069...

mediumsmart

I am on macOS with a split screen browser left and emacs in the right half. Max 2 window vertical split in that frame and if needed a C-x 5 2 which opens a full screen frame workspace to the right for a c-x 3 side by side layout. That’s it - all the other buffers are backstage partying until they get called.

kfajdsl

This is great! I often have a situation where I have a nice three pane split with one split vertically and another one horizontal in one of the vertical panes, but if I close the big vertical pane, I now just have two wide horizontal panes and have to recreate the layout.