It still feels nuts to me that we have all this stuff and yet when entering/exiting 'work mode' I have to either leave everything running indefinitely or reposition all my work apps every time I launch them.
It’s especially bad when I need to restart the browser because then all the windows get collected into one space again. Also annoying that relaunching the browser reopens all those windows in the first place.
I like the idea of this app for launching a collection of apps together but the application is the wrong level of granularity. I don’t want all of my browser windows at once. I want just one of them along with the windows of other applications that match that task.
I bet there’s some combination of tools I could cobble together and customize to achieve this but I don’t want to work that hard at it. I really should be able to just open up a new space, open up and arrange all the windows I want to work with on tasks for that space, and then press save and give it a name.
Then I should be able to close that space and reopen it by name any time I like, with all of the windows exactly as I left them, regardless of whether or not any of those applications are open on other spaces.
Xerox Star & Smalltalk had the task-centric approach and Alan Kay @alankay has said that Steve Jobs/Apple missed that aspect in their takeaway from their visit: "(they) missed a few things about the GUI. For example, that it had unlimited and persistent “desktops” which could be used to sustain work/projects over time without having to tear down and build up, and without stovepiped apps, etc."
https://www.quora.com/What-was-it-like-to-be-at-Xerox-PARC-w...
So happy that I could remember enough of this story to find that link.
Neither of these are, of course, user-friendly for the vast majority of people. But they do afford some thoughts, concepts, and mechanisms which might be used in task-oriented UI design.
But Alan Kay was talking about task-centric, not document-centric, which I'd argue Lisa wasn't quite doing fully.
Happy to talk about this more if you think I'm mistaken. And you'll need to let Alan Kay know :)
This is the browser's decision, not macOS's, though. At least for Firefox, you can turn it off ("Open previous windows and tabs" in General > Startup).
I guess what I really want isn’t possible without either ugly hacks or a total rearchitect of the operating system: the elimination of the “stovepipe” applications paradigm.
Applications should not own their windows, the operating system should. In practice this would mean an application is not a program you invoke by clicking on it. Instead it should be a library you install that tells the operating system how to read, display, edit, and write certain kinds of documents or document-like resources (such as web pages).
Then it would be easy for the operating system to offer unlimited persistent desktops that need to only remember which resources are open and a bit of metadata controlling the appearance of each window (position, shape, size, view setting).
I guess one can image a "skinnable" OS, where the OS enforces, say, one approach to window management on all apps, but there are options for what the One True Window Management strategy is. I'm sure I'm describing something in Linux, but I'm a Mac user and so not used to such freedom.
It’s a shame we don’t have better task support. macOS has been slowly shidting further towards app-centric workfkows. I suppose this is in line with app stores, web apps and mobile OSs being the more common computer interfaces now. It’s disappointing, in my opinion.
Here's a playlist of demos of great but obsolete operating systems: https://www.youtube.com/playlist?list=PLfF-zlMNYMd_ZioGb0BKd...
There is an app called Stay that remembers positions of Windows based on the app, title, etc. I used it for a while, but not recently. https://cordlessdog.com/stay/
There is an app, Workspaces, I think, but it's not useful enough to bother using.
Probably should be a macos feature one day
What is an activity in KDE and what can I do with it? https://askubuntu.com/a/705835
I’ve been a Moom user for a long time, and the craziest thing to me is when they had to change⁽²⁾ from using a miniature rectangular grid for positioning and resizing a window to a slanted hexagonal grid because of a patent⁽³⁾.
Then leave the windows of an app open as you quit it. When you next launch the app its windows will restore to their previous size and position. If you close the windows first, then the app will restore to having no windows open.
May not work for every case.
I have a bunch on windows in an app, that tend to move to a different monitor after the machine goes to sleep.
Each window has a different title, which is something KM can act on, so I've made an action that moves each individual window to a specific place. I've tied this action to Alt-P (for "place"), so I can manually correct when they've drifted.
So it's not a generic "put all windows where I left them" solution, but it's a hell of a lot better than manually doing the same thing several times a day.
Apple does not provide APIs for that. A handful of apps control spaces, and all of them by automating GUI actions.
If I've one frustration with computer interfaces, dating back to the 1990s, it's this. If anything it's become worse with time as apps, both desktop and mobile though especially the latter, become more self-centric, to the point of having their own, non-filesystem-based, data silos. I understand some of the security reasons for this (apps are themselves increasingly untrusted and untrustworthy, and data-sharing is a significant risk). But it is extraordinarily frustrating when trying to work with multiple tools.
Modern MacOS is particularly pernicious in that I'm often working between multiple applications, but on the same project, and the friction of raising and lowering all app-associated windows as I cycle between these, often navigating to a workspace I'd not meant to go to, is quietly maddening.
The Linux / X-Windows notion of focus-follows-mouse addresses this somewhat. Your current app is whatever the mouse happens to be on top of. On MacOS this simply isn't available, though there are some ... hints of this. E.g., if I happen to have the mouse over a browser window I can scroll that window with the mouse. But if I then, say, hit Cmd-W to close that tab ... suddenly the actually focused app which I'd forgetten about gets a kick in its nethers. This happens to me several times a week, if not per day.
I don't know that Stapler is the true solution to this, but it does seem to track in that direction.
For example, the dominant atomic concept in Xerox Star was the document [1]. Documents are an abstraction just above files. A webpage is a document, but is made up of numerous files like the graphics, fonts, executable scripts, etc. Document oriented systems like Star also deemphasize applications. The system is supposed to open up the correct application(s) when you choose to interact with a document. But even with this as the core abstraction, the system still had to provide methods to work directly with files and applications.
Other systems, like Plan 9, nixes, MS-DOS, CP/M, etc. focus on the file as the atomic primitive and try to build around that. But when things moved to GUIs, many of the development teams focused on the Applications. Windows 3.x famously only showed users organized collections of applications, with file management as just another application. But Windows 3.x was sitting on top of DOS which oriented itself around files. The nixes in the meanwhile forgot about documents almost entirely.
Where I think they've failed to evolve is not in reimplementing these three things over and over, but in assembling them into useful, higher-level, abstractions. What I really think is missing is a way to assemble two higher-levels: workplaces which implement workflows.
Pipes and scripts sort of mimic workflows, and desktops sort of mimic workplaces, but these concepts have really stalled and there's almost no real system-level tooling for building these things, especially in a GUI. For example, scripts are really used as a kind of a way to assemble pipes into pseudo applications + automation, but it's hard to turn them into real workflow tools, and desktops just allow you to dump a bunch of application windows and files into one place, but there isn't any real scoping to it.
Thanks for filling in the gaps for all of us who don’t just use one app at a time!
[1]: https://bunchapp.co/
The documents saved by Stapler are also plain text (JSON). But because the app is trying to be a model citizen in the current model of macOS security/annoyance, it contains the file bookmarks that macOS gives us (which are binary blobs encoded as Base64 text, so incomprehensible to mere humans) rather than the human-readable file paths you might expect. Kind of annoying, but there we go!
I've had a desire for something like this (windows/linux) -- what would be cool is if it knew the window size and layouts?
So you could do a launch group that will do the whole desktops workspace - and can be saved (but also has a reset button to snap back to the layout if you mix things up. Support for a second desktop to launch then to - so you can throw one context cluster on each...)
---
Weren't you the one who lost all their archive content? What was the timeline with all of that?
If you want the Document to control the properies of the desktop, then I would write a little Automator app, shell script, Shortcut, etc. to do that and then add that to the Stapler Document. Use all available tools together.
---
Internet Archive: yes, that was me. Most of my account data is still gone. I don't think the deleted data will ever be restored. And so it goes. The blog post about that one has been updated with this info. Thanks for asking.
Most IT people around me, like myself, enjoy building things. A side project is a good opportunity to do so "just because", without bullshit you don't like - no bureaucracy or approval, no story points, no project meetings, no design documents, writing tests and documentation is up to you. You just sit down, do, and get the feeling of actually making progress in a reasonable time and at the end of the day, having built something. It's energizing.
Sometimes, it is about the product though, and you build yourself a nice tool because you aren't happy with what's out there. Of course, the two goals can often be combined - and at the very least, some useful product is a good excuse to practice the enjoyable hobby.
I tried adding a folder and Visual Studio Code as the things to open (because Visual Studio Code can open, well, anything, and this way I could at least start up a workspace) and got the same result.
LaunchList 0.8 (2009) is 880KB (Intel-only)
...but interestingly LaunchList contained an unused "test" icon file weighing 320KB(!) so really it is 560KB.
Edit: ah, I think you're referring to Mac OS X Classic Environment running old system in which you're running the old Desk Accessory. Matryoshka dolls!
Applications/3D\ Tic-Tac-Toe
data 'alis' (1) {
$"0000 0000 00B2 0002 0000 026D 6F00 0000"
/* .....?.....mo... */
$"0000 0000 0000 0000 0000 0000 0000 0000"
/* ................ */
$"0000 0000 0000 9DEE E656 4244 0003 0000"
/* ......???VBD.... */
$"0002 0A57 6F72 6B69 6E67 4441 7300 0000"
/* ..?WorkingDAs... */
$"0000 0000 0000 0000 0000 0000 0000 0000"
/* ................ */
$"0000 0000 0000 0000 0000 0000 0000 0000"
/* ................ */
$"0000 0000 0000 0000 0000 0000 0000 0000"
/* ................ */
$"0000 0000 001C 9D5B 7887 4446 494C 444D"
/* ......?[x?DFILDM */
$"4F56 FFFF FFFF 0000 0002 0000 0000 0000"
/* OV????.......... */
$"0000 0000 0000 0000 0002 6D6F 0002 000D"
/* ..........mo.... */
$"6D6F 3A57 6F72 6B69 6E67 4441 7300 FFFF"
/* mo:WorkingDAs.?? */
$"0000"
/* .. */
};
data 'DRVR' (12, "\0x003D Tic-Tac-Toe") {
$"6400 003C 0042 D3C3 0056 00DA 0100 00DA"
/* d..<.B??.V.?...? */
$"00DE 0E33 4420 5469 632D 5461 632D 546F"
/* .?.3D Tic-Tac-To */
$"6500 3350 6C61 7920 4D61 6369 6E74 6F73"
/* e.3Play Macintos */
$"683B 506C 6179 2041 2048 756D 616E 3B28"
/* h;Play A Human;( */
$"2D3B 596F 7520 5374 6172 743B 4D61 6320"
/* -;You Start;Mac */
$"5374 6172 7473 4AA9 001E 667E 2849 42A7"
/* StartsJ?..f~(IB? */
$"42A7 487A 04A2 487A FFAA 4267 3F3C 0010"
/* B?Hz.?Hz??Bg?<.. */
$"70FF 2F00 3F3C 0100 42A7 A913 205F 2948"
/* p?/.?<..B??. _)H */
$"001E 316C 0018 006C 41E8 0020 2255 43E9"
/* ..1l...lA?. "UC? */
$"FFE0 20D9 20D9 598F 3F3C D3C3 487A FF74"
/* ?? ? ?Y??<??Hz?t */
$"A931 2F17 2F17 2F17 487A FF78 A933 3F3C"
/* ?1/././.Hz?x?3?< */
$"0001 1F3C 0001 A945 3F3C 0004 1F3C 0001"
/* ...<..?E?<...<.. */
$"A945 4267 A935 A937 41FA 0408 4298 4298"
/* ?EBg?5?7A?..B?B? */
$"4298 4298 20F8 0A02 4258 7000 4E75 2029"
/* B?B? ??.BXp.Nu ) */
$"001E 67F6 42A9 001E 2F00 A914 598F 3F3C"
/* ..g?B?../.?.Y??< */
$"D3C3 A949 3F3C D3C3 A936 A937 A932 60DA"
/* ?éI?<?é6?7?2`? */
$"48E7 00F8 2869 001E 3028 001A 0440 0040"
/* H?.?(i..0(...@.@ */
$"664A 2668 001C 2F0C A873 3013 5340 6700"
/* fJ&h../.?s0.S@g. */
$"01FC 5B40 6668 2F0C 2F17 A922 486C 0010"
/* .?[@fh/./.?"Hl.. */
$"A8A3 41FA 03D2 2F20 2F20 2655 7603 2F0F"
/* ??A?.?/ / &Uv./. */
$"486B FFF0 A8A5 2F0F 3F3C 0048 4267 A8A8"
/* Hk??/.?<.HBg?? */
$"51CB FFEC 508F 6162 A923 6032 5340 6700"
/* Q???P?ab?#`2S@g. */
$"024E 5340 6624 2F0C A873 5D8F 2F0F A972"
/* .NS@f$/.?s]?/.?r */
$"486C 0010 A8AD 4A1F 6706 487A 0392 6006"
/* Hl..??J.g.Hz.?`. */
$"2055 4868 FF94 A851 6004 5340 673E 4CDF"
/* UHh???Q`.S@g>L? */
$"1F00 2F38 08FC 6000 FF42 3400 48C2 84FC"
/* ../8.?`.?B4.H? */
$"0010 E54A 41FA 032C 2230 2000 4842 D442"
/* ..?JA?.,"0 .HB?B */
$"E4A9 0241 0003 48C1 4E75 7800 7A3F 3004"
/* ?.A..H?Nux.z?0. */
$"61D8 6170 5244 51CD FFF6 4E75 3028 001E"
/* a?apRDQ???Nu0(.. */
$"3600 5340 0C40 0002 6422 41FA 02F6 4298"
/* 6.S@.@..d"A?.?B? */
$"4298 4298 4298 30D8 4A40 6704 3140 FFFE"
/* B?B?B?0?J@g.1@?? */
$"3080 61C6 2F0C A91F 7803 601A 5540 41FA"
/* 0?a?/.?.x.`.U@A? */
$"02E2 3080 41FA 02CC 2018 8098 8098 8098"
/* .?0?A?.? .?????? */
$"6602 3098 7801 598F 3F3C D3C3 A949 2F17"
/* f.0?x.Y??<?éI/. */
$"3F03 1F3C 0001 A945 B943 3F03 4227 A945"
/* ?..<..?E?C?.B'?E */
$"6000 FF5C 2F01 6126 221F 48C1 EB49 41FA"
/* `.?\/.a&".H??IA? */
$"0312 D1C1 43FA 02A2 2288 2F09 486C 0002"
/* ..??C?.?"?/?Hl.. */
$"487A 029C 2F17 4267 42A7 A8EC 4E75 48C0"
/* Hz.?/.BgB???NuH? */
$"80FC 0010 2200 4241 4841 82FC 0004 2401"
/* ??..".BAHA??..$. */
$"4842 C0FC 0048 C4FC 0010 D042 C2FC 0010"
/* HB??.H??..?B??.. */
$"4840 3001 4840 41FA 0276 43FA 026A 2320"
/* H@0.H@A?.vC?.j# */
$"2320 2F09 2F00 A8A8 4E75 48C0 48C1 48E7"
/* # /?/.??NuH?H?H? */
$"C000 80FC 0010 4840 D040 E1A9 41FA 0224"
/* ?.??..H@?@?A?.$ */
$"4840 E548 83B0 0000 4CDF 0003 2601 6100"
/* H@?H??..L?..&.a. */
$"FF74 45FA 0386 7800 7A00 7E4B 1A22 1822"
/* ?tE?.?x.z.~K."." */
$"7C03 3004 6100 FEC4 B203 6638 D805 51CE"
/* |.0.a.?IJ.f8?.Q? */
$"FFF2 3F07 7E0B 7C03 1812 2004 6100 FF70"
/* ???.~.|... .a.?p */
$"5189 2038 0A02 D191 2F09 A8A4 D805 51CE"
/* Q? 8?.ё/ƨ??.Q? */
$"FFEA 7008 2040 A03B 51CF FFDC 3E1F 41FA"
/* ??p. @?;Q???>.A? */
$"01D4 4250 51CF FFB6 6000 FE74 47EB 000A"
/* .?BPQ???`.?tG?.? */
$"2F0B A871 41FA 01BE 3018 677E 4A50 6604"
/* /.?qA?.?0.g~JPf. */
$"5540 6776 7804 7000 302B 0002 80FC 0048"
/* U@gvx.p.0+..??.H */
$"B044 6466 E968 3600 4840 5140 E868 D640"
/* ?Ddf?h6.H@Q@?h?@ */
$"7000 3013 5140 E868 B044 644E E548 D640"
/* p.0.Q@?h?DdN?H?@ */
$"3003 6100 FE36 6642 6100 FEF4 5189 2038"
/* 0.a.?6fBa.??Q? 8 */
$"0A02 D191 7800 2F0B A972 558F 2F13 487A"
/* ?.ёx./.?rU?/.Hz */
$"016E A8AD B817 6708 1817 487A 0162 A8A4"
/* .n???.g...Hz.b?? */
$"A973 4A1F 66E0 4A04 6710 3003 41FA 0146"
/* ?sJ.f?J.g.0.A?.F */
$"3210 0A50 0003 6000 FEF2 6000 FDE2 41FA"
/* 2.?P..`.??`.??A? */
$"0134 3018 5540 66F2 4A50 66EE 41FA 0114"
/* .40.U@f?JPf?A?.. */
$"2018 C098 C098 C098 72FF B280 67DC 45FA"
/* .??????r???g?E? */
$"0102 7022 4262 51C8 FFFC 47FA 026E 7800"
/* ..p"BbQ???G?.nx. */
$"7A00 7E4B 1A23 1823 7600 1483 7C03 3004"
/* z.~K.#.#v..?|.0. */
$"6100 FDA8 1581 6002 6710 5212 4A03 6602"
/* a.??.?`.g.R.J.f. */
$"1601 B203 6704 4212 76FF D805 51CE FFE0"
/* ..?.g.B.v??.Q??? */
$"7000 1012 6718 D000 E12B 7C03 1813 4A32"
/* p...g.?.?+|...J2 */
$"6002 6604 8732 4006 D805 51CE FFF2 51CF"
/* `.f.?2@.?.Q???Q? */
$"FFB4 45FA 009E 7E3F 7200 1422 B202 6404"
/* ??E?.?~?r.."?.d. */
$"1202 2007 51CF FFF4 4A01 6610 723F 558F"
/* .. .Q???J.f.r?U? */
$"A861 301F C041 6100 FD42 66F2 3600 6100"
/* ?a0.?Aa.?Bf?6.a. */
$"FDFE 5189 2038 0A02 D191 7E05 487A 0080"
/* ??Q? 8?.ё~.Hz.? */
$"A8A4 7005 2040 A03B 51CF FFF2 41FA 0066"
/* ??p. @?;Q???A?.f */
$"30BC 0001 3003 7202 6000 FE10 0000 0000"
/* 0?..0.r.`.?..... */
$"0000 0000 0000 0000 0000 0000 0000 0000"
/* ................ */
$"0000 0000 0000 0000 0000 0000 0000 0000"
/* ................ */
$"0000 0000 0000 0000 0000 0000 0000 0000"
/* ................ */
$"0000 0000 0000 0000 0000 0000 0000 0000"
/* ................ */
$"0000 0000 0000 0000 0000 0000 0000 0000"
/* ................ */
$"0000 0000 0000 0000 0000 0000 0002 0000"
/* ................ */
$"0000 0000 0000 0008 0008 0018 0018 0009"
/* ...............? */
$"0009 004A 004A 0032 0064 0082 018C 0780"
/* .?.J.J.2.d.?.?.? */
$"0440 0840 0C80 1380 1100 2100 2200 4200"
/* .@.@.?.?..!.".B. */
$"4400 8400 8800 F000 E000 C000 8000 0780"
/* D.?.?.?.?.?.?..? */
$"07C0 0FC0 0F80 1F80 1F00 3F00 3E00 7E00"
/* .?.?.?.?..?.>.~. */
$"7C00 FC00 F800 F000 0000 0000 0000 0010"
/* |.?.?.?......... */
$"0000 FFFF 8000 8000 8000 8000 8000 8000"
/* ..???.?.?.?.?.?. */
$"8000 8000 8000 8000 8000 8000 8000 8000"
/* ?.?.?.?.?.?.?.?. */
$"8000 FFFF 8000 8000 83E0 8FF8 8E38 9C1C"
/* ?.???.?.?????8?. */
$"980C 980C 980C 9C1C 8E38 8FF8 83E0 8000"
/* ?.?.?.?.?8?????. */
$"8000 FFFF 8000 8000 980C 9C1C 8E38 8770"
/* ?.???.?.?.?.?8?p */
$"83E0 81C0 83E0 8770 8E38 9C1C 980C 8000"
/* ???????p?8?.?.?. */
$"8000 0001 0401 0801 0C01 1001 1401 1801"
/* ?............... */
$"1C01 2001 2401 2801 2C01 3001 3401 3801"
/* .. .$.(.,.0.4.8. */
$"3C01 0004 0104 0204 0304 1004 1104 1204"
/* <............... */
$"1304 2004 2104 2204 2304 3004 3104 3204"
/* .. .!.".#.0.1.2. */
$"3304 0010 0110 0210 0310 0410 0510 0610"
/* 3............... */
$"0710 0810 0910 0A10 0B10 0C10 0D10 0E10"
/* ....?.?......... */
$"0F10 0014 0114 0214 0314 0011 0411 0811"
/* ................ */
$"0C11 030F 070F 0B0F 0F0F 0C0C 0D0C 0E0C"
/* ................ */
$"0F0C 0005 1005 2005 3005 0303 1303 2303"
/* ...... .0.....#. */
$"3303 0015 0313 0C0D 0F0B 0C0D 0F0B"
/* 3............. \*/
};
The editor is a native macOS window that's kind of like list view in a file manager, or a spreadsheet, or a little folder...depending on your point of view. Plus some menu commands and keyboard equivalents.
The items in each list are macOS "bookmarks" which are a type of authorised/verified/secure alias (in fact, they're still called aliases in the code) that have been around for about 10–15 years. They contain the path plus a bunch more info. As macOS becomes more locked-down the recommended way of accessing files is to retrieve these bookmarks through the normal layers of system permissions and security. Without the bookmarks, for example just using plain text paths, I would not be able to show the full images in Quick Look or easily launch the list items. A key benefit is that the bookmark will still resolve if the file is moved somewhere else on the same disk, or even to a different volume!
Here's more info on file bookmarks: https://eclecticlight.co/2020/05/21/bookmarks-a-type-of-alia...
I store the items as JSON in the saved file, simply because I prefer it to XML (which is the main/default option). I wanted the files to still be human readable and editable to a degree.
The files are launched using the default app specified by that file, so it can be changed on a per-file basis. Individual images might open in an image editor, image viewer, app to run OCR, script to run OCR on it, etc.
Can we make it more like Stapler?