TE
科技回声
首页24小时热榜最新最佳问答展示工作
GitHubTwitter
首页

科技回声

基于 Next.js 构建的科技新闻平台,提供全球科技新闻和讨论内容。

GitHubTwitter

首页

首页最新最佳问答展示工作

资源链接

HackerNews API原版 HackerNewsNext.js

© 2025 科技回声. 版权所有。

Ideal OS: Rebooting the Desktop Operating System

656 点作者 daureg将近 8 年前

94 条评论

joshmarinacci将近 8 年前
I&#x27;m the original author. I hadn&#x27;t planned to publicize this yet. There are still some incomplete parts, broken links, and missing screenshots. But the Internet wants what it wants.<p>Just to clarify a few things.<p>I just joined Mozilla Devrel. None of this article has anything to do with Mozilla.<p>I <i>know</i> that none of the ideas in this article are new. I am a UX expert and have 25 years experience writing professional software. I personally used BeOS, Oberon, Plan 9, Amiga, and many others. I read research papers for fun. My whole point is that all of this has been done before, but not integrated into a nice coherent whole.<p>I <i>know</i> that a modern Linux can do most of these things with Wayland, custom window managers, DBus, search indexes, hard links, etc. My point is that the technology isn&#x27;t that hard. What we need is to put all of these things into a nice coherent whole.<p>I <i>know</i> that creating a new mainstream desktop operating system is hopeless. I don&#x27;t seriously propose doing this. However, I do think creating a working prototype on a single set of hardware (RPi3?) would be very useful. It would give us fertile playground to experiment with ideas that <i>could</i> be ported to mainstream OSes.<p>And thank you to the nearly 50 people who have signed up to the discussion list. What I most wanted out of this article was to find like minded people to discuss ideas with.<p>Thanks, Josh
评论 #15060964 未加载
评论 #15062970 未加载
评论 #15067757 未加载
评论 #15060244 未加载
评论 #15070497 未加载
评论 #15062712 未加载
评论 #15061493 未加载
评论 #15060314 未加载
评论 #15065600 未加载
评论 #15060448 未加载
评论 #15060250 未加载
Damogran6将近 8 年前
So what he&#x27;s saying is: REmove all these layers because they&#x27;re bad, but add these OTHER layers because they&#x27;re good.<p>Thats how you make another AmigaOS, or Be, I&#x27;m sure Atari still has a group of a dozen folks playing with it, too.<p>The OS&#x27;s over the past 20 years haven&#x27;t shown much advancement because the advancement is happening higher up the stack. You CAN&#x27;T throw out the OS and still have ARkit. A Big Bloated Mature Moore&#x27;s Law needing OS is also stable, has hooks out the wazoo, AND A POPULATION USING IT.<p>4 guys coding in the dark on the bare metal just can&#x27;t build an OS anymore, it won&#x27;t have GPU access, it won&#x27;t have a solid TCP&#x2F;IP stack, it won&#x27;t have good USB support, or caching, or a dependable file system.<p>All of these things take a ton of time, and people, and money, and support (if you don&#x27;t have money, you need the volunteers)<p>Go build the next modern OS, I&#x27;ll see you in a couple of years.<p>I don&#x27;t WANT this to sound harsh, I&#x27;m just bitter that I saw a TON of awesome, fledgling, fresh Operating systems fall by the wayside...I used BeOS, I WANTED to use BeOS, I&#x27;da LOVED it if they&#x27;d won out over NeXT (another awesome operating system...at least that survived.)<p>At a certain level, perhaps what he wants is to leverage ChromeOS...it&#x27;s &#x27;lightweight&#x27;...but by the time it has all the tchotchkes, it&#x27;ll be fat and bloated, too.
评论 #15059282 未加载
评论 #15058645 未加载
评论 #15059212 未加载
评论 #15061281 未加载
cs702将近 8 年前
Yes, existing desktop applications and operating systems are hairballs with software layers built atop older software layers built atop even older software layers.<p>Yes, if you run the popular editor Atom on Linux, you&#x27;re running an application built atop Electron, which incorporates an entire web browser with a Javascript runtime, so the application is using browser drawing APIs, which in turn delegate drawing to lower-level APIs, which interact with a window manager that in turn relies on X...<p>Yes, it&#x27;s complexity atop complexity atop complexity all the way down.<p>But the solution is NOT to throw out a bunch of those old layers and replace them with new layers!!!<p>Quoting Joel Spolsky[1]:<p><i>&quot;There’s a subtle reason that programmers always want to throw away the code and start over. The reason is that they think the old code is a mess. And here is the interesting observation: they are probably wrong. The reason that they think the old code is a mess is because of a cardinal, fundamental law of programming: It’s harder to read code than to write it. ... The idea that new code is better than old is patently absurd. Old code has been used. It has been tested. Lots of bugs have been found, and they’ve been fixed. ... When you throw away code and start from scratch, you are throwing away all that knowledge. All those collected bug fixes. Years of programming work.&quot;</i><p>[1] <a href="https:&#x2F;&#x2F;www.joelonsoftware.com&#x2F;2000&#x2F;04&#x2F;06&#x2F;things-you-should-never-do-part-i&#x2F;" rel="nofollow">https:&#x2F;&#x2F;www.joelonsoftware.com&#x2F;2000&#x2F;04&#x2F;06&#x2F;things-you-should-...</a>
评论 #15061219 未加载
评论 #15058883 未加载
评论 #15058646 未加载
评论 #15059762 未加载
评论 #15058639 未加载
评论 #15059279 未加载
评论 #15061849 未加载
评论 #15060056 未加载
jcelerier将近 8 年前
&gt; Why can I dock and undock tabs in my web browser or in my file manager, but I can&#x27;t dock a tab between the two apps? There is no technical reason why this shouldn&#x27;t be possible.<p>that&#x27;s absolutely possible on linux with i3wm for instance<p>&gt; I&#x27;d like to pipe my Skype call to a video analysis service while I&#x27;m chatting, but I can&#x27;t really run a video stream through awk or sed.<p>awk and sed, no, but there are many CLI tools that accept video streams through pipe. e.g. FFMPEG. You wouldn&#x27;t open your video through a GUI text editor, so why would you through CLI text editors ?<p>&gt; Window Managers on traditional desktops are not context or content aware, and they are not controlable by other programs.<p>Sure they are, on linux: <a href="https:&#x2F;&#x2F;linux.die.net&#x2F;man&#x2F;1&#x2F;wmctrl" rel="nofollow">https:&#x2F;&#x2F;linux.die.net&#x2F;man&#x2F;1&#x2F;wmctrl</a><p>Fifteen years ago people were already controlling their WM through dbus: <a href="http:&#x2F;&#x2F;wiki.compiz.org&#x2F;Plugins&#x2F;Dbus#Combined_with_xdotool" rel="nofollow">http:&#x2F;&#x2F;wiki.compiz.org&#x2F;Plugins&#x2F;Dbus#Combined_with_xdotool</a><p>The thing is, no one really cares about this in practice.
评论 #15060181 未加载
评论 #15059665 未加载
spankalee将近 8 年前
This sounds a lot like Fuchsia, which is all IPC-based, has a syncable object-store[1], a physically-based renderer[2], and the UI is organized into cards and stories[3] where a story is &quot;a set of apps and&#x2F;or modules that work together for the user to achieve a goal.&quot;, and can be clustered[4] and arranged in different ways[4].<p>[1]: <a href="https:&#x2F;&#x2F;fuchsia.googlesource.com&#x2F;ledger&#x2F;" rel="nofollow">https:&#x2F;&#x2F;fuchsia.googlesource.com&#x2F;ledger&#x2F;</a><p>[2]: <a href="https:&#x2F;&#x2F;fuchsia.googlesource.com&#x2F;escher&#x2F;" rel="nofollow">https:&#x2F;&#x2F;fuchsia.googlesource.com&#x2F;escher&#x2F;</a><p>[3]: <a href="https:&#x2F;&#x2F;arstechnica.com&#x2F;gadgets&#x2F;2017&#x2F;05&#x2F;googles-fuchsia-smartphone-os-dumps-linux-has-a-wild-new-ui&#x2F;" rel="nofollow">https:&#x2F;&#x2F;arstechnica.com&#x2F;gadgets&#x2F;2017&#x2F;05&#x2F;googles-fuchsia-smar...</a><p>[4]: <a href="https:&#x2F;&#x2F;fuchsia.googlesource.com&#x2F;sysui&#x2F;#important-armadillo-non_widget-classes" rel="nofollow">https:&#x2F;&#x2F;fuchsia.googlesource.com&#x2F;sysui&#x2F;#important-armadillo-...</a><p>[5]: <a href="https:&#x2F;&#x2F;fuchsia.googlesource.com&#x2F;mondrian&#x2F;" rel="nofollow">https:&#x2F;&#x2F;fuchsia.googlesource.com&#x2F;mondrian&#x2F;</a>
评论 #15058648 未加载
评论 #15058943 未加载
评论 #15062474 未加载
zug_zug将近 8 年前
I really don&#x27;t understand the negativity here. I sense a very dismissive tone, but most of the complaints are implementation details, or that this has been tried before (so what?).<p>I think anybody who really thinks about it would have to agree modern OSes are a disgusting mess.<p>-- Why does an 8 core mac have moments that it is so busy I can&#x27;t even click anything but only see a pinwheel? It&#x27;s not the hardware. No app should have the capability, even if it tried, to slow down the OS&#x2F;UI (without root access).<p>-- Yes, it should be a database design, with permissions.<p>-- Yes, by making it a database design, all applications get the ability to share their content (i.e. make files) in a performant searchable way.<p>-- Yes, permissions is a huge issue. If every app were confined to a single directory (docker-like) then backing up an app, deleting an app, terminating an app would be a million times easier. Our OSes will never be secure until they&#x27;re rebuilt from the ground up. [Right now windows lets apps store garbage in the &#x27;registry&#x27; and linux stores your apps data strewn throughout &#x2F;var&#x2F;etc, &#x2F;var&#x2F;log, &#x2F;app&#x2F;init, .... These should all be materialized views [i.e. sym-links])<p>-- Mac Finder is cancer. If the OS were modularizable it&#x27;d be trivial for me, a software engineer, to drop-in a replacement (like you can with car parts).<p>-- By having an event-driven architecture, this gives me exact tracking on when events happened. I&#x27;d like a full record of every time a certain file changes, if file changes can&#x27;t happen without an event, and all events are indexed in the DB, then I have perfect auditability.<p>-- I could also assign permission events (throttle browser CPU to 20% max, pipe all audio from spotify to removeAds.exe, pipe all UI notifications from javaUpdater to &#x2F;dev&#x2F;null)<p>I understand the &quot;Well who&#x27;s gonna use it?&quot; question, but it&#x27;s circular reasoning. &quot;Let&#x27;s not get excited about this, because nobody will use it, because it won&#x27;t catch on, because nobody got excited about it.&quot; If you get an industry giant behind it (Linus, Google, Carmack) you can absolutely reinvent a better wheel (e.g. GIT, chrome) and displace a huge marketshare in months.
评论 #15059013 未加载
评论 #15058998 未加载
评论 #15059008 未加载
评论 #15062631 未加载
评论 #15062702 未加载
评论 #15060490 未加载
评论 #15059164 未加载
noen将近 8 年前
As a current developer, former 10 year UX designer, and developer before that, this kind of article irks me to no end.<p>He contradicts his core assertion (OS models are too complex and layered) with his first &quot;new&quot; feature.<p>Nearly everything on this manifesto has been done before, done well, and many of his gripes are completely possible in most modern OS&#x27;s. The article just ignores all of the corner cases and conflicts and trade-offs.<p>Truly understanding the technology is required to develop useful and usable interfaces.<p>I&#x27;ve witnessed hundreds of times as designers hand off beautiful patterns and workflows that can&#x27;t ever be implemented as designed. The devil is in the details.<p>One of the reasons Windows succeeded for so long is that it enabled people to do a common set of activities with minimal training and maximizing reuse of as few common patterns as possible.<p>Having worked in and on Visual Studio, it&#x27;s a great example of what happens when you build an interface that allows the user to do anything, and the developer to add anything. Immensely powerful, but 95% of the functionality is rarely if ever used, training is difficult because of the breadth and pace of change, and discovery is impossible.
评论 #15058816 未加载
评论 #15059766 未加载
评论 #15059693 未加载
评论 #15058869 未加载
评论 #15059736 未加载
评论 #15059183 未加载
评论 #15059233 未加载
avaer将近 8 年前
&gt; I suspect the root cause is simply that building a successful operating system is hard.<p>It&#x27;s hard but not that hard; tons of experimental OS-like objects have been made that meet these goals. Nobody uses them.<p>What&#x27;s hard is getting everyone on board enough for critical inertia to drive the project. Otherwise it succumbs to the chicken-and-egg problem, and we continue to use what we have because it&#x27;s &quot;good enough&quot; for what we&#x27;re trying to do right now.<p>I suspect the next better OS will come out of some big company that has the clout and marketing to encourage adoption.
评论 #15058610 未加载
评论 #15058572 未加载
评论 #15058562 未加载
评论 #15060498 未加载
dcow将近 8 年前
Android already tried things like a universal message bus and a module-based architecture and while nice it doesn&#x27;t quite live up to the promise for two reasons:<p>1. Application devs aren&#x27;t trained to architect new software. They will port old shitty software patterns from familiar systems because there&#x27;s no time to sit down and rewrite photoshop for Android. It&#x27;s sad but true.<p>2. People abuse the hell out of it. Give someone a nice thing and someone else will ruin it whether they&#x27;re trying to or not. A universal message bus has security and performance implications. Maybe if Android was a desktop os not bound by limited resources it wouldn&#x27;t have pulled out all the useful intents and neutered services, but then again the author&#x27;s point is we should remove these complex layers and clearly the having them was too complex&#x2F;powerful&#x2F;hungry for android.<p>I do think there&#x27;s a point to be made that we&#x27;re very mouse and keyboard centric at the primitive IO level and in UI design. I always wondered what the &quot;command line&quot; would look like if it was more complex than 128 ascii characters in a 1 dimensional array. But it probably wouldn&#x27;t be as intuitive for humans to interface with unless you could speak and gesture to it as the author suggests.
nwah1将近 8 年前
I agree with a lot of the critics in the comments, but I will say that the author has brought to my attention a number of features that I&#x27;m now kind of upset that I don&#x27;t have.<p>I always thought LED keyboards were stupid because they are useless, but if they could map to hotkeys in video players and such, that could be very useful, assuming you can turn off the LEDs.<p>His idea for centralized application configs and keybindings isn&#x27;t bad if we could standardize using something like TOML . The Options Framework for Wordpress plugins is an example of this kind of thing, and it does help. It won&#x27;t be possible to get all the semantics agreed upon, of course, but maybe 80% is enough.<p>Resurrecting WinFS isn&#x27;t so important, and I feel like there&#x27;d be no way to get everyone to agree on a single database unless every app were developed by one team. I actually prefer heterogeneity in the software ecosystem, to promote competition. We mainly need proper journalling filesystems with all the modern features. I liked the vision of Lennart Poettering in his blog post about stateless systems.<p>The structured command line linked to a unified message bus, allowing for simple task automation sounds really neat, but has a similar problem as WinFS. But I don&#x27;t object to either, if you can pull it off.<p>Having a homogenous base system with generic apps that all work in this way, with custom apps built by other teams is probably the compromise solution and the way things have trended anyways. As long as the base system doesn&#x27;t force the semantics on the developers, it is fine.
评论 #15061830 未加载
评论 #15059243 未加载
ghinda将近 8 年前
You have most of these, or at least very similar versions, in Plasma&#x2F;KDE today:<p>&gt; Document Database<p>This is what Akonadi was when when it came out for 4.x. Nepomuk was the semantic search framework so you could rate&#x2F;tag&#x2F;comments on files and search by them. They had some performance problems and were not very well received.<p>Nepomuk has been superseded by Baloo, so you can still tag&#x2F;rate&#x2F;comment files now.<p>Most KDE apps also use KIO slaves: <a href="https:&#x2F;&#x2F;www.maketecheasier.com&#x2F;quick-easy-guide-to-kde-kio-slaves&#x2F;" rel="nofollow">https:&#x2F;&#x2F;www.maketecheasier.com&#x2F;quick-easy-guide-to-kde-kio-s...</a><p>&gt; System Side Semantic Keybindings<p>&gt; Windows<p>Plasma 4 used to have compositor-powered tabs for any apps. Can&#x27;t say if it will be coming back to Plasma 5. Automatic app-specific colors (and other rules) are possible now.<p>&gt; Smart copy and paste<p>The clipboard plasmoid in the system tray has multiple items, automatic actions for what to do with different types of content and can be pinned, to remain visible.<p>&gt; Working Sets<p>These are very similar to how Activities work. Don&#x27;t seem to be very popular.
评论 #15061826 未加载
diegof79将近 8 年前
What the author wants is something like Squeak. The idea behind Smalltalk wasn&#x27;t to do a programming language, but a realization of the DynaBook (google for the essay &quot;History Behind Smalltalk&quot;).<p>While I agree with the author that more innovation is needed on the desktop; I think that the essay is very disinformed.<p>For example, Squeak can be seen as an OS with very few layers: everything is an object, and sys calls are primitives. As user you can play with all the layers, and re-arrange the UI as you want.<p>So why the idea didn&#x27;t took off? I don&#x27;t know exactly (but I have my hypothesis). There are many factors to balance, those many factors are the ones that makes design hard.<p>One of those factors is that people tend to put the wrong priorities of where innovation should be. A good example is what the author mentions as priorities for him. None of the items mentions fundamental problems that computer users face today (from my perspective of course).
评论 #15059107 未加载
antoineMoPa将近 8 年前
I appreciate the article for its coverage of many OS (including BeOS, wow, I should try that). What about package management though? Package management really defines the way you live under your flavor of linux, and there is a lot of room for improvement in current package managers (like decentralizing them, for example).<p>Also:<p>&gt; I know I said we would get rid of the commandline before, but I take that back. I really like the commandline as an interface sometimes, it&#x27;s the pure text nature that bothers me. Instead of chaining CLI apps together with text streams we need something richer [...]<p>I can&#x27;t agree with that, it is the plain text nature of the command line that makes it so useful and simple once you know a basic set of commands (ls,cd,find,sed,grep + whatever your specific task needs). Plain text is easy to understand and manipulate to perform whatever task you need to do. The moment you learn to chain commands and save them to a script for future use, the sky is the limit. I do agree with using voice to chain commands, but I would not complain about the plain text nature and try to bring buttons or other forms of unneeded complexity to command-line.
评论 #15058981 未加载
评论 #15059455 未加载
lake99将近 8 年前
&gt; Traditional filesystems are hierarchical, slow to search, and don&#x27;t natively store all of the metadata we need<p>I don&#x27;t know what he means by &quot;traditional&quot;, but Linux native filesystems can store all the metadata you&#x27;d want.<p>&gt; Why can&#x27;t I have a file in two places at once on my filesystem?<p>POSIX compatible filesystems have supported that for a long time already.<p>It seems to me that all the things he wants are achievable through Plan9 with its existing API. The only thing missing is the ton of elbow grease to build such apps.
评论 #15058622 未加载
hackermailman将近 8 年前
This guy wants GuixSD for 60% his feature requests, like isolated apps, version control, snapshots, ease of configuration, and ability to abstract all of it away, and Hurd for his multi-threaded ambitions, modularity, ability to do things like mount a database in a home directory to use as a fileserver, and message passing. This is slowly happening already <a href="https:&#x2F;&#x2F;fosdem.org&#x2F;2017&#x2F;schedule&#x2F;event&#x2F;guixhurd&#x2F;" rel="nofollow">https:&#x2F;&#x2F;fosdem.org&#x2F;2017&#x2F;schedule&#x2F;event&#x2F;guixhurd&#x2F;</a><p>Then he wants to completely redesign a GUI to manage it all, which sounds a lot like Firefox OS with aware desktop apps, but with the added bonus that most things that req privileges on desktop OSs no longer need them with Guix. Software drivers are implemented in user space as servers with GNU Hurd, so you can now access these things and all the functionality that comes with them, exactly what the author wants.
jmull将近 8 年前
This isn&#x27;t worth reading.<p>(It&#x27;s painfully naive, poorly reasoned, has inaccurate facts, is largely incoherent, etc. Even bad articles can serve as a nice prompt for discussion, but I don&#x27;t even think this is even good for that. I don&#x27;t we&#x27;d ever get past arguing about what it is most wrong about.)
评论 #15058995 未加载
chrisleader将近 8 年前
&quot;First of all, it’s quite common, especially in enterprise technology, for something to propose a new way to solve an existing problem. It can’t be used to solve the problem in the old way, so ‘it doesn’t work’, and proposes a new way, and so ‘no-one will want that’. This is how generational shifts work - first you try to force the new tool to fit the old workflow, and then the new tool creates a new workflow. Both parts are painful and full of denial, but the new model is ultimately much better than the old. The example I often give here is of a VP of Something or Other in a big company who every month downloads data from an internal system into a CSV, imports that into Excel and makes charts, pastes the charts into PowerPoint and makes slides and bullets, and then emails the PPT to 20 people. Tell this person that they could switch to Google Docs and they’ll laugh at you; tell them that they could do it on an iPad and they’ll fall off their chair laughing. But really, that monthly PowerPoint status report should be a live SaaS dashboard that’s always up-to-date, machine learning should trigger alerts for any unexpected and important changes, and the 10 meg email should be a Slack channel. Now ask them again if they want an iPad.&quot; - Benedict Evans
xolve将近 8 年前
Not an ideal article for anything. Looks like written with limited research, that by the end of it I an hardly keep focus.<p>&gt; Bloated stack. True, there are options which author hasn&#x27;t discussed.<p>&gt; A new filesystem and a new video encoding format. Apple created new FS and video format. These are far more fundamental changes to be glossed over as trivial in a single line.<p>&gt; CMD.exe, the terminal program which essentially still lets you run DOS apps was only replaced in 2016. And the biggest new feature of the latest Windows 10 release? They added a Linux subsystem. More layers piled on top. Linux subsytem is a great feature of Windows. Ability to run bash on Windows natively, what&#x27;s the author complaining about?<p>&gt; but how about a system wide clipboard that holds more than one item at a time? That hasn&#x27;t changed since the 80s! Heard of Klipper and similar app in KDE5&#x2F;Plasma. Its been there for so long and keeps text, images and file paths in clipboard.<p>&gt; Why can&#x27;t I have a file in two places at once on my filesystem? Hard links and soft links??<p>&gt; Filesystem tags Are there!<p>What I feel about the article is: OSes have these capabilities since long, where are the killers applications written for these?
benkuykendall将近 8 年前
The idea of system wide &quot;document database&quot; is really intriguing. I think the author identified a real pattern that could be addressed by such a change:<p>&gt; In fact, many common applications are just text editors combined with data queries. Consider iTunes, Address Book, Calendar, Alarms, Messaging, Evernote, Todo list, Bookmarks, Browser History, Password Database, and Photo manager. All of these are backed by their own unique datastore. Such wasted effort, and a block to interoperability.<p>The ability to operate on my browser history or emails as a table would be awesome! And this solves so many issues about losing weird files when trying to back up.<p>However, I would worry a lot about schema design. Surely most apps would want custom fields in addition to whatever the OS designer decided constitutes an &quot;email&quot;. This would throw interoperability out the window, and keeping it fast becomes a non-trivial DB design problem.<p>Anyone have more insights on the BeOS database or other attempts since?<p>(afterthought: like a lot of ideas in this post, this could be implemented in userspace on top of an existing OS)
mwcampbell将近 8 年前
I&#x27;m glad the author thought about screen readers and other accessibility software. Yes, easy support for alternate input methods helps. But for screen readers in particular, the most important thing is a way to access a tree of objects representing the application&#x27;s UI. Doing this efficiently over IPC is hard, at least with the existing infrastructure we have today.<p>Edit: I believe the state of the art in this area is the UI Automation API for Windows. In case the author is reading this thread, that would be a good place to continue your research.
评论 #15061846 未加载
dgreensp将近 8 年前
I love it, especially using structured data instead of text for the CLI and pipes, and replacing the file system with a database.<p>Just to rant on file systems for a sec, I learned from working on the Meteor build tool that they are slow, flaky things.<p>For example, there&#x27;s no way on any desktop operating system to read the file tree rooted at a directory and then subscribe to changes to that tree, such that the snapshot combined with the changes gives you an accurate updated snapshot. At best, an API like FSEvents on OS X will reliably (or 99% reliably) tell you when it&#x27;s time to go and re-read the tree or part of the tree, subject to inefficiency and race conditions.<p>&quot;Statting&quot; 10,000 files that you just read a second ago should be fast, right? It&#x27;ll just hit disk cache in RAM. Sometimes it is. Sometimes it isn&#x27;t. You might end up waiting a second or two.<p>And don&#x27;t get me started on Windows, where simply deleting or renaming a file, synchronously and atomically, are complex topics you could spend a couple hours reading up on so that you can avoid the common pitfalls.<p>Current file systems will make even less sense in the future, when non-volatile RAM is cheap enough to use in consumer devices, meaning that &quot;disk&quot; or flash has the same performance characteristics and addressability as RAM. Then we won&#x27;t be able to say that persisting data to a disk is hard, so of course we need these hairy file system things.<p>Putting aside how my data is physically persisted inside my computer, it&#x27;s easy to think of better base layers for applications to store, share, and sync data. A service like Dropbox or BackBlaze would be trivial to implement if not for the legacy cruft of file systems. There&#x27;s no reason my spreadsheets can&#x27;t be stored in something like a git repo, with real-time sync, provided by the OS, designed to store structured data.
评论 #15059579 未加载
评论 #15059199 未加载
jimmaswell将近 8 年前
Patently false that Windows hasn&#x27;t innovated, UX or otherwise. Start menu search, better driver containment&#x2F;other bsod reduction, multi-monitor expanding task bar, taskbar button reordering, other Explorer improvements, lots of things.
microcolonel将近 8 年前
&gt; <i>Why can&#x27;t I have a file in two places at once on my filesystem?</i><p>You can! Use hardlinks.<p>&gt; <i>Window Managers on traditional desktops are not context or content aware, and they are not controlable by other programs.</i><p>There are well established standards for controlling window managers from programs, what on earth are you talking about?<p>&gt; <i>Applications would do their drawing by requesting a graphics surface from the compositor. When they finish their drawing and are ready to update they just send a message saying: please repaint me. In practice we&#x27;d probably have a few types of surfaces for 2d and 3d graphics, and possibly raw framebuffers. The important thing is that at the end of the day it is the compositor which controls what ends up on the real screen, and when. If one app goes crazy the compositor can throttle it&#x27;s repaints to ensure the rest of the system stays live.</i><p>Just like Wayland!<p>&gt; <i>All applications become small modules that communicate through the message bus for everything. Everything. No more file system access. No hardware access. Everything is a message.</i><p>Just like flatpak!<p>&gt; <i>Smart copy and paste</i><p>This is entirely feasible with the current infrastructure.<p>&gt; <i>Could we actually build this? I suspect not. No one has done it because, quite honestly, there is no money in it. And without money there simply aren&#x27;t enough resources to build it.</i><p>Some of this is already built, and most of it is entirely feasible with existing systems. It&#x27;s probably not even that much work.
IamCarbonMan将近 8 年前
All of this is possible without throwing out any existing technology (at least for Linux and Windows; if Apple doesn&#x27;t envision a use case for something it&#x27;s very likely never going to exist on their platform). Linux compositors have the ability to manipulate the window however the hell they want, and while it&#x27;s not as popular as it used to be, you can change the default shell on Windows and use any window manager you can program. A database filesystem is two parts: a database and a filesystem. Instead of throwing out the filesystem which works just fine, add a database which offers views into the filesystem. The author is really woe-is-me about how an audio player doesn&#x27;t have a database of mp3s, but that&#x27;s something that is done all the time. Why do we have to throw out the filesystem just to have database queries? And if it&#x27;s because every app has to have their own database- no they don&#x27;t. If you&#x27;re going to rewrite all the apps anyways, then rewrite them to use the same database. Problem solved. The hardest concept to implement in this article would be the author&#x27;s idea of modern GUIs, but it can certainly be done.<p>On top of this, the trade-off of creating an entirely new OS is enormous. Sure, you can make an OS with no apps because it&#x27;s not compatible with anything that&#x27;s been created before, and then you can add your own editor and your own web browser and whatever. And people who only need those things will love it. But if you need something that the OS developer didn&#x27;t implement, you&#x27;re screwed. You want to play a game? Sorry. You want to run the software that your school or business requires? Sorry. Seriously, don&#x27;t throw out every damn thing ever made just to make a better suite of default apps.
remir将近 8 年前
Seems a lot like Fuchsia, the new OS Google is currently developing:<p><a href="https:&#x2F;&#x2F;fuchsia.googlesource.com&#x2F;docs&#x2F;+&#x2F;HEAD&#x2F;book.md" rel="nofollow">https:&#x2F;&#x2F;fuchsia.googlesource.com&#x2F;docs&#x2F;+&#x2F;HEAD&#x2F;book.md</a> <a href="https:&#x2F;&#x2F;fuchsia.googlesource.com&#x2F;modular&#x2F;+&#x2F;master&#x2F;docs&#x2F;module.md" rel="nofollow">https:&#x2F;&#x2F;fuchsia.googlesource.com&#x2F;modular&#x2F;+&#x2F;master&#x2F;docs&#x2F;modul...</a> <a href="https:&#x2F;&#x2F;fuchsia.googlesource.com&#x2F;docs&#x2F;+&#x2F;HEAD&#x2F;filesystems.md" rel="nofollow">https:&#x2F;&#x2F;fuchsia.googlesource.com&#x2F;docs&#x2F;+&#x2F;HEAD&#x2F;filesystems.md</a>
Animats将近 8 年前
If you want to study user interfaces, look at programs which solve a hard problem - 3D animation and design programs. Learn Inventor or Maya or Blender.<p>Autodesk Inventor and Blender are at opposite ends of the &quot;use the keyboard&quot; range. In Inventor, you can do almost everything with the mouse except enter numbers and filenames. Blender has a 10-page list of &quot;hotkeys&quot;. It&#x27;s worth looking at how Inventor does input. You can change point of view while in the middle of selecting something. This is essential when working on detailed objects.
vbezhenar将近 8 年前
I think that the next reboot will be unifying RAM and Disk with tremendous amount of memory (terabytes) for apps and transparent offloading of huge video and audio files into cloud. You don&#x27;t need filesystem or any persistence anymore, all your data structures are persistent. Use immutable stuff and you have unlimited Undo for the entire device life. Reboot doesn&#x27;t make sense, all you need is to flush processor registers before turning off. This experience will require rewrite OS from ground up, but it would allow for completely new user experience.
评论 #15058788 未加载
zaro将近 8 年前
&gt; I suspect the root cause is simply that building a successful operating system is hard.<p>Well, it is hard, but this is not the main source of issues. The obstacle to having nice things on the desktop is this constant competition and wheel reinvention, the lack of cooperation.<p>The article shows out some very good points, but just think of this simple fact. It&#x27;s 2017, and the ONLY filesystem that will seamlessly work with macOS, Windows and Linux at the same time is FAT, a files system which is almost 40 years old. And it is not because it is so hard to make such a filesystem. Not at all. Now this is at the core of reasons why we can&#x27;t have nice things :)
评论 #15059064 未加载
评论 #15058932 未加载
thibran将近 8 年前
Interesting to read someone else ideas about that topic, which I though myself quite a lot about. The basic building block of a better desktop OS is IMHO – and as the OP wrote – a communication contract between capabilities and the glue (a.k.a apps). I don&#x27;t think we would need that many capability-services to be able to build something useful (it doesn&#x27;t even need to be efficient at first). For the start it might be enough to wrap existing tools and expose them and see if things work or not.<p>Maybe by starting to build command-line apps and see how good the idea works (cross-platform would be nice). I guess that the resulting system would have some similarities with RxJava, which allows to compose things together (get asynchronously A &amp; B, then build C and send it to D if it contains not Foo).<p>If an app would talk to a data-service it would no longer have to know where the data is coming from or how it got there. This would allow to build a whole new kind of abstractions, e.g. data could be stored in the cloud and only downloaded to a local cache when frequently used, just to be later synced back to the cloud transparently (maybe even ahead of time because a local AI learned your usage patterns). I know that you can have such sync-things today, they are just complicated to setup, or cost a lot of money, or work only for specific things&#x2F;applications, also they are often not accessible to normal users.<p>Knowing how to interact with the command-line gives advanced users superpowers. I think it is time to give those superpowers to normal users too. And no, learning how to use the command-line is not the way to go ;-)<p>A capability-services based OS could even come with a quite interesting monetization strategy by selling extra capabilities, like storage, async-computation or AI services, beside of selling applications.
Groxx将近 8 年前
&gt;<i>Consider iTunes. iTunes stores the actual mp3 files on disk, but all metadata in a private database. Having two sources of truth causes endless problems. If you add a new song on disk you must manually tell iTunes to rescan it. If you want to make a program that works with the song database you have to reverse engineer iTunes DB format, and pray that Apple doesn&#x27;t change it. All of these problems go away with a single system wide database.</i><p>Well. Then you get Spotlight (on OSX, at least) - system-wide file&#x2F;metadata&#x2F;content search.<p>It&#x27;s great! It&#x27;s also quite slow at times. Slow (and costly) to index, slow to query (initial &#x2F; common &#x2F; by-name searches are fast, but content searches can take a second or two to find <i>anything</i> - this would be unacceptable in many applications), etc.<p>I like databases, but building a single well-performing one for all usages is quite literally impossible. Forcing everyone into a single system doesn&#x27;t tend to add up to a positive thing.
lou1306将近 8 年前
Windows 10 didn&#x27;t add any UX feature? What about Task View (Win+Tab) and virtual desktops?<p>And why bashing the Linux subsystem, which is surely not even developed by the UX team (so no waste of resources) and is a much needed feature for developers?<p>BTW, there is a really simple reason why mainstream OSs have a rather conservative design: the vast majority of people just doesn&#x27;t care and may even get angry when you change the interaction flow. Many of the ideas exposed in the post are either developer-oriented or require significant training to be used proficiently.
评论 #15059409 未加载
评论 #15058582 未加载
评论 #15058986 未加载
评论 #15058579 未加载
nickpsecurity将近 8 年前
The author keeps questioning why certain siloing like App Store happens. The author then offers technical solutions that won&#x27;t work. The reason is the siloing is intentional on part of companies developing those applications to reduce competition to boost profits. They&#x27;d rather provide the feature you desire themselves or through an app they get 30% commission on.<p>A lot of other things author talks about keep the ecosystems going. The ecosystems, esp key apps, are why many people use these desktop OS&#x27;s. Those apps and ecosystems take too much labor to clean slate. So, the new OS&#x27;s tend not to have them at all or use knock-offs that don&#x27;t work well enough. Users think they&#x27;re useless and leave after the demo.<p>The market effects usually stomp technical criteria. That&#x27;s why author&#x27;s recommendations will fail as a whole. &quot;Worse Really is Better&quot; per Richard Gabriel.
评论 #15058969 未加载
评论 #15058584 未加载
评论 #15058604 未加载
snarfy将近 8 年前
What we have today grew together organically over time like a city. To do what is described in the article is akin to demolishing the city and completely rebuilding it from scratch. But it&#x27;s not just from scratch, it&#x27;s replacing all of the infrastructure and tooling that went into building the parts of the city, like plumbing and electrical. A state of the art substation requires it&#x27;s own infrastructure to build. It&#x27;s akin to requiring a whole new compiler tool chain and software development system just to get started with rebooting the OS.<p>If this happens it&#x27;s only going to happen with a top-down design from an industry giant. Android and Fuchsia are examples of how it might happen. Will it? It seems these days nobody cares as long as the browser renders quickly.
评论 #15064350 未加载
Skunkleton将近 8 年前
In 2017 a modern operating system such as Android, iOS, or Chrome (the browser) exists as a platform. Applications developed for these platforms _must_ conform to the application model set by the platform. There is no supported way to create applications that do not conform to the design of the platform. This is in stark contrast to the &quot;1984&quot; operating systems that the OP is complaining about.<p>It is very tempting to see all the complexity of an open system and wish it was more straight forward; more like a closed system. But this is a dangerous thing to advocate. If we all only had access to closed systems, who would we be seceding control to? Do we really want our desktop operating systems to be just another fundamentally closed off walled garden?
评论 #15071040 未加载
bastijn将近 8 年前
Apart from discussing the content. Can I just express my absolute love for (longer) articles that start with a tl;dr?<p>It gives an immediate answer to &quot;do I need to read this?&quot;, and if so, what key arguments should I pay attention to?<p>Let me finish with expressing my thanks to the author for including a tl;dr.<p>Thanks!
评论 #15060093 未加载
joshmarinacci将近 8 年前
OP here. I wasn&#x27;t quite ready to share this with the world yet, but what are you gonna do.<p>I&#x27;m happy to answer your questions.
jonahss将近 8 年前
The author mentions they wished Object-based streams&#x2F;terminals existed. This is the premise of Windows Powershell, which today reminds me of nearly abandoned malls found in the Midwest: full of dreams from a decade ago, but today an empty shell lacking true utility, open to the public for wandering around.
评论 #15059808 未加载
raintrees将近 8 年前
I have been conceptualizing what it would take to abstract away the actual physical workstation into a back-end processing system and multiple UI modules physically scattered throughout my home (I work from home) and grounds.<p>For example, as in shift my workspace from my upstairs office to my downstairs work area just by signing in on the different console setup downstairs. All of my in-process work comes right back up. Right now I do this (kind of) using VMs, but they are limited when addressing hardware, and now I am multiplying that hardware.<p>Same thing with my streams - Switch my audio or video to the next room&#x2F;zone where I want to move myself to. Start researching how to correctly adjust my weed whip&#x27;s carburetor, then go out to the garage and pull up my console there where my work bench is and the dismantled tool.<p>Eventually my system would track my whereabouts, with the ability (optionally turned on) to automatically shift that IO to the closest hardware setup to me as I move around the structure&#x2F;property.<p>And do something like this for each person? So my wife has her streams? Separate back end instance, same mobility to front-end UI hardware?<p>Can this new Desktop Operating System be designed with that hardware abstraction in mind?
mherrmann将近 8 年前
What I hate is the _bloat_. Why is GarageBand forced upon me with macOS? Or iTunes? Similarly for video players etc on all the other OSs. I am perfectly capable of installing the software I need, thank you very much.
评论 #15059253 未加载
ksec将近 8 年前
I hate to say this, but an ideal Desktop OS, at least for majority of consumers is mostly here, and it is iOS 11.<p>Having use the newest iPad Pro 10.5 ( along with iOS 11 beta ), the first few hours were pure Joy, after that were frustration and anger flooding in. Because what I realize, is this tiny little tablet, costing only half a Macbook Pro or even iMac, limited by Fanless design with lower TDP, 4GB of memory, no Dedicated GPU, likely much slower SSD, provides a MUCH better user experience then the Mac or Windows PC i have ever used, that is including the latest Macbook Pro.<p>Everything is fast and buttery smooth, even the Web Browsing experience is better. The only downside is you are limited touch screen and Keyboard. I have number of times wonder If I can attach a separate monitor to use it like Samsung Desktop Dock.<p>There are far too many backward compatibility to care for with both Windows and Mac. And this is similar to the discussion in the previous Software off Rails. People are less likely to spend time optimizing when it is working good enough out of the box.
评论 #15058754 未加载
评论 #15058957 未加载
评论 #15058739 未加载
gshrikant将近 8 年前
While I&#x27;m not sure I agree with everything in the article, it does mention a point I&#x27;ve been thinking about for a while - configuration.<p>I really do think applications should try to zero-in on a few standard configuration file formats - I really don&#x27;t have a strong preference on one (although avoiding XML would be nice). It makes the system uniform and makes it easier to move between applications. Of course, applications can add extended sections to suit their need.<p>Another related point is the location of configuration files - standard Linux&#x2F;Unix has a nice hierarchy &#x2F;etc&#x2F; for and &#x2F;usr&#x2F;local&#x2F;etc and others for user-specific configurations (I&#x27;m sure Windows and OS X should have a similar hierarchy too) but different applications still end up placing their configuration files in unintuitive places.<p>I find this lack of uniformity disturbing - especially because it looks so easy (at least on the surface) to fix and the benefits would be nice - easier to learn and scriptable.<p>A last unrelated point - I don&#x27;t see why Linux distributions cannot standardize around a common repository - Debian and Ubuntu both share several packages but are yet forced to maintain separate package databases and you can&#x27;t easily mix and match packages between them. This replication of effort seems more ideological than pragmatic (of course, there probably are some practical reasons too). But I can&#x27;t see why we can&#x27;t all pool resources and share a common &#x27;universal&#x27; application repository - maybe divide it into &#x27;Free&#x27;, &#x27;Non-Free&#x27;, &#x27;Contrib&#x2F;AUR&#x27; like granular divisions so users have full freedom to choose the packages they want.<p>Like other things, I think these ideas have been implemented before but I&#x27;m a little disappointed these haven&#x27;t made it into &#x27;mainstream&#x27; OS userlands yet.
评论 #15059575 未加载
评论 #15066874 未加载
nebulous1将近 8 年前
I much preferred the second half of this to the first half.<p>However, both seemed to end up with the same fundamental flaw: he&#x27;s either underestimating or understating how absurdly difficult most of what he&#x27;s suggesting is. It&#x27;s all well and good saying that we can have a standardized system for email, with everything being passed over messages, but what about <i>everything</i> else? It&#x27;s extremely difficult to standardize an opinionated system that works for everything, which is exactly why so many operating system constructs are more general than specific. For this to all hang together you would have to standardize <i>everything</i>, which will undoubtedly turn into an insane bureaucratic mess. Not to mention that a lot of software makers actively fight against having their internal formats open.
hyperfekt将近 8 年前
This would be neat, but isn&#x27;t radical enough yet IMHO. If everything on the system is composed of pure functions operating on data, we can supercharge the OS and make everything both possible AND very simple. The whole notion of &#x27;application&#x27; is really kind of outmoded.
doggydogs94将近 8 年前
FYI, most of the author&#x27;s complaints about the command line were addressed by Microsoft in PowerShell. For example, PowerShell pipes objects, not text.
agumonkey将近 8 年前
I see <a href="https:&#x2F;&#x2F;birdhouse.org&#x2F;beos&#x2F;refugee&#x2F;trackerbase.gif" rel="nofollow">https:&#x2F;&#x2F;birdhouse.org&#x2F;beos&#x2F;refugee&#x2F;trackerbase.gif</a> for 2 seconds and I feel happy. So cute, clear, useful.
评论 #15058627 未加载
EdSharkey将近 8 年前
Hacker News is most interesting when a controversial article like this is written without all the necessary facts or research. I learned a lot about a range of existing OS and application tech just through all the refuting going on here.<p>Anyhow, my $0.02 is that all software dies. Either software lands in a niche due to its architecture and doesn&#x27;t survive industry paradigm shifts or it groans under its own weight of cruft allowing more nimble competitors to enter the market and take marketshare. I&#x27;m no fan of full-system rewrites because of the tremendous cost and typical failure, but even so all software does eventually die and replacements will emerge.<p>So, it at least makes sense for some well-heeled upstart to begin thinking about the next-gen operating system in case an opportunity presented itself to establish a market. If that upstart were me, my focus would be on productivity, performance, stability&#x2F;security.<p>Especially with regards to UX, I would focus on defining UX Guidelines and a windowing toolkit that would only change very infrequently (like once every 10-20 years.) To me, a tacky-looking, &quot;outdated&quot; UX that billions of people know by heart and can play like a fiddle is infinitely more valuable than one that changes look-and-feel year to year. My devs would be laser focused on fixing bugs and performance enhancements, not feature-itis.
al2o3cr将近 8 年前
<p><pre><code> Window Managers on traditional desktops are not context or content aware, and they are not controlable by other programs. </code></pre> My copy of Divvy is confused by this statement. :)
st3fan将近 8 年前
&gt; And if you wanted to modify your email client, or at least the one above (Mail.app, the default client for Mac), there is no clean way to extend it. There are no plugins. There is no extension API. This is the result of many layers of cruft and bloat.<p>I am going to say that it is probably a product decision in case of Mail.app.<p>Whether Mail.app is a big steaming pile of cruft and bloat inside - nobody knows. Since it is closed source.
评论 #15059239 未加载
gumby将近 8 年前
I really agree that the hermetic siloization of applications and their data over the past 30 years has been a <i>major</i> step backwards. I also wish all apps were composable.<p>It seems to require a mental shift few developers are willing to adopt however. Good luck -- you are on the right track on many things (even if I can&#x27;t imagine life without a command line).
casebash将近 8 年前
I wouldn&#x27;t say that innovation in Desktop is dead, but most of it seems to be driven by features or design patterns copied from mobile or tablet. Take for examples Windows 8 and Windows 10, Windows 8 was all about moving to an OS that could run on a whole host of devices, while Windows 10 was all about fixing up all the errors made in this transition.
mcny将近 8 年前
Hi Josh,<p>Thank you for writing this.<p>Just noticed a small typo (I think)<p>&gt; For a long time Atom couldn&#x27;t open a file larger than 2 megabytes because scrolling would be to slow.<p>to should be too.<p>Sincerely,
PrimHelios将近 8 年前
This seems to me to be written by someone who uses MacOS almost exclusively, but has touched Windows just enough to understand it. The complete lack of understanding of IPC, filesystems, scripting, and other OS fundamentals is pretty painful.<p>&gt;Why can I dock and undock tabs in my web browser or in my file manager, but I can&#x27;t dock a tab between the two apps? There is no technical reason why this shouldn&#x27;t be possible. Application windows are just bitmaps at the end of the day, but the OS guys haven&#x27;t built it because it&#x27;s not a priority.<p>I&#x27;m an idiot when it comes to operating systems (and sometimes even in general), but even <i>I</i> know why there are issues with that. You need a standardized form of IPC between the two apps, which wouldn&#x27;t happen because both devs would be convinced their way is the best. On top of that, it&#x27;s a great way to get an antitrust against you if you aren&#x27;t careful [0]<p>&gt;Why can&#x27;t I have a file in two places at once on my filesystem? Why is it fundamentally hierarchical?<p>Soft&#x2F;hard links, fam. Even Windows has them.<p>&gt;Why can[&#x27;t] I sort by tags and metadata?<p>You can in Linux, you just need to know a few commands first.<p>&gt;Any web app can be zoomed. I can just hit command + and the text grows bigger. Everything inside the window automatically rescales to adapt. Why don&#x27;t my native apps do that? Why can&#x27;t I have one window big and another small? Or even scale them automatically as I move between the windows? All of these things are trivial to do with a compositing window manager, which has been commonplace for well over a decade.<p>Decent point IMO. There&#x27;s a lot of native UI I have a hard time reading because it&#x27;s so small. That said, I think bringing in the ability to zoom native widgets would bring in a lot of issues that HTML apps have.<p>&gt;We should start by getting rid of things that don&#x27;t work very well.<p>The author doesn&#x27;t understand PCs. The entire point of these machines is backwards-compatibility, because we <i>need</i> backwards compatibility. I&#x27;m sitting next to a custom gaming PC and I have an actual serial port PCIe card because I need serial ports. Serial ports. In 2017. I&#x27;d be screwed if serial wasn&#x27;t supported anymore.<p>I won&#x27;t touch the rest of the article because I there&#x27;s a lot I disagree with, but he seems to just want to completely reinvent the &quot;modern OS&quot; as just chromebooks.<p>[0]: <a href="https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;United_States_v._Microsoft_Corp" rel="nofollow">https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;United_States_v._Microsoft_Cor...</a>.
评论 #15058996 未加载
评论 #15059672 未加载
Zigurd将近 8 年前
A few years ago I wrote a book about developing big complex networked apps. It had &quot;Enterprise&quot; in the title, based on the idea that mobile device OSs would become dominant - which they did - and that the evolution of tablet devices would continue to where powerful devices like the iPad Pro would overtake the use of Mac and Windows laptops - which they didn&#x27;t.<p>Windows and MacOS are full of compromises but are usable. Chrome OS is a contender for users that need a simpler system. What addressable segment is left? You pretty much have to make the case for replacing Windows. But you can only hope to replace the &quot;voluntary&quot; Windows seats. Many Windows users have no choice.
oconnor663将近 8 年前
&gt; Wayland is supposed to fix everything, but it&#x27;s been almost a decade in development and still isn&#x27;t ready for prime time.<p>Mutter&#x27;s Wayland implementation is the default display server for Gnome Shell right now. How much more prime time do can you get?
评论 #15059461 未加载
atemerev将近 8 年前
&quot;A solution in search of a problem&quot;.<p>What problem of mine &quot;piping my Skype stream to video analysis service&quot; is supposed to solve? Why would I want to dock and undock different application parts to all places they don&#x27;t belong? Etc.
blueworks将近 8 年前
The reference to atom and it&#x27;s performance to the underlying electron and nodejs runtime is inappropriate since another popular editor Microsoft&#x27;s VS Code which also uses electron but is very fast and is a pleasure to work with.
linguae将近 8 年前
I&#x27;ve been thinking a lot about the problem of modern desktop operating systems myself over the past year. I believe that desktop operating system environments peaked last decade. The Mac&#x27;s high water mark was Snow Leopard, the Linux desktop appeared to have gained momentum with the increasing refinement of GNOME 2 during the latter half of the 2000&#x27;s, and for me the finest Windows releases were Windows 2000 and Windows 7. Unfortunately both the Linux desktop and Windows took a step in the wrong direction when smartphones and tablets became popular and the maintainers of those desktops believed that the desktop environments should resemble the environments of these new mobile devices. This led to regressions such as early GNOME 3 and Windows 8. GNOME 3 has improved over the years and Windows 10 is an improvement over Windows 8, but GNOME 2 and Windows 7, in my opinion, are still better than their latest successors. Apple thankfully didn&#x27;t follow the footsteps of GNOME and Windows, but I feel that the Mac has stagnated since Snow Leopard.<p>I agree with the author of this article that desktop operating systems should develop into workstation operating systems. They should be able to facilitate our workflows, and ideally they should be programmable (which I have some more thoughts about in my next paragraph). In my opinion the interface should fully embrace the fact that it is a workstation and not a passive media consumption device. It should, in my opinion, be a &quot;back to basics&quot; one, something like the classic Windows 95 interface or the Platinum Mac OS interface.<p>One of the thoughts that I&#x27;ve been thinking about over the years is the lack of programmability in contemporary desktop GUIs. The environments of MS-DOS and early home computers highly encouraged users to write programs and scripts to enhance their work environment. Unix goes a step further with the idea of pipes in order to connect different tools together. Finally, the ultimate form of programmability and interaction would resemble the Smalltalk environment, where objects could send messages to each other. What would be amazing would be some sort of Smalltalk-esque GUI environment, where GUI applications could interact with each other using message passing. Unfortunately Apple and Microsoft didn&#x27;t copy this from Xerox, instead only focusing on the GUI in the early 1980s and then later in the 1980s focusing on providing an object-oriented API for GUI services (this would be realized with NeXTSTEP&#x2F;OPENSTEP&#x2F;Cocoa, which inspired failed copycat efforts such as Microsoft Cairo and Apple&#x2F;IBM Taligent, but later on inspired successful platforms such as the Java API and Microsoft .NET). The result today is largely unprogrammable GUI applications, though there are some workarounds such as AppleScript and Visual Basic for Applications (though it&#x27;s far from the Smalltalk-esque idea). The article&#x27;s suggestion for having some sort of standardized JSON application interface would be an improvement over the status quo.<p>I would love to work on such an operating system: a programmable GUI influenced by the underpinnings of Smalltalk and Symbolics Genera plus the interface and UI guidelines of the classic Mac OS. The result would be a desktop operating system that is unabashedly for desktop computer users. It would be both easy to use and easy to control.
评论 #15058909 未加载
评论 #15058762 未加载
pier25将近 8 年前
I agree with some of the points stated. For years I&#x27;ve been thinking that a tag based file system would be superior to a folder based one in many aspects.<p>macOS has tags, but the UX&#x2F;UI for interacting with them is really poor.
jacinabox将近 8 年前
In regards to the issue of file systems being non-searchable, it&#x27;s definitely worth taking a look at compressed full-text indexes: <a href="http:&#x2F;&#x2F;pizzachili.dcc.uchile.cl&#x2F;resources&#x2F;compressed_indexes_in_practice.pdf" rel="nofollow">http:&#x2F;&#x2F;pizzachili.dcc.uchile.cl&#x2F;resources&#x2F;compressed_indexes...</a><p>Under this scheme each file on disk would be stored as an index with constant factor overhead. The original file is not needed; all of the data can be decoded out of the index.
sddfd将近 8 年前
I think electron is a step into the right direction.<p>Let&#x27;s assume for a moment there weren&#x27;t the problem with JavaScript performance (because, for example, web assembly can replace it).<p>Then electron is a platform everyone can build his applications on. And once that happens, operating systems are free to shed the library cruft.<p>This is just one possible migration path, and I am not saying it&#x27;s going to happen or that it is even a good idea.<p>But if you have to write cross platform apps it seems, that this has clear advantages.
评论 #15059717 未加载
评论 #15059761 未加载
dgudkov将近 8 年前
Many interesting ideas and concepts, no question. However, if it was a startup pitch I would struggle to see a killer application. I can see <i>features</i> (some are very exciting!) here, but I&#x27;m failing to see a <i>product</i>. What kind of real-life problem would such OS solve? Is this problem worth billions of dollars required for developing a new OS and a tool kit of apps for it?
saagarjha将近 8 年前
&gt; if you wanted to modify your email client, or at least the one above (Mail.app, the default client for Mac), there is no clean way to extend it. There are no plugins.<p>Mail.app supports plugins.<p>&gt; Why can&#x27;t I have a file in two places at once on my filesystem?<p>So…a hardlink?<p>&gt; Why don&#x27;t my native apps do that?<p>Dynamic text lets you do this, but it&#x27;s mobile-only currently.<p>&gt; have started deprecating the Applescript bindings which make it work underneath<p>Since when?
jonahss将近 8 年前
Look to Mobile OSs for innovation in OS design. Like the author stated, it&#x27;s currently where the money is. It&#x27;s the closest we have to &quot;starting over&quot; and alot of things were rethought, such as security and sandboxed apps. IPC is limited to start, but slowly growing.<p>I wouldn&#x27;t be surprised if the workstation OSs of the future grew out of our current Mobile OSs
评论 #15062853 未加载
评论 #15059097 未加载
atmartins将近 8 年前
I&#x27;m surprised at all the negative, pessimistic views about looking forward with operating systems. I welcome conversations about what things could be like in the future. Obviously Google&#x27;s pondering this with Fuchsia. Maybe it will take a more vertical approach, where only certain hardware could take advantage of some features for a while.
coldtea将近 8 年前
&gt;<i>In fact, in some cases it&#x27;s worse. It took tremendous effort to get 3D accelerated Doom to work inside of X windows in the mid 2000s, something that was trivial with mid-1990s Microsoft Windows. Below is a screenshot of Processing running for the first time on a Raspberry Pi with hardware acceleration, just a couple of years ago. And it was possible only thanks to a completely custom X windows video driver. This driver is still experimental and unreleased, five years after the Raspberry Pi shipped.</i><p>That&#x27;s because of Open Source OSes though, which vendors don&#x27;t care about and volunteers aren&#x27;t enough and able to match the work needed for all things to play out of the box. Nothing about this particular example has anything to do with OS research or modern OSes being behind.<p>&gt;<i>Here&#x27;s another example. Atom is one of the most popular editors today. Developers love it because it has oodles of plugins, but let us consider how it&#x27;s written. Atom uses Electron, which is essentially an entire webbrowser married to a NodeJS runtime. That&#x27;s two Javascript engines bundled up into a single app. Electron apps use browser drawing apis which delegate to native drawing apis, which then delegate to the GPU (if you&#x27;re luck) for the actual drawing. So many layers.</i><p>Again, nothing related to modern OSes being inadequate. One could use e.g. Cocoa and get 10x what Electron offers, for 10x the speed, but it would be limited in portability.<p>&gt;<i>Even fairly simple apps are pretty complex these days. An email app, like the one above is conceptually simple. It should just be a few database queries, a text editor, and a module that knows how to communicate with IMAP and SMTP servers. Yet writing a new email client is very difficult and consumes many megabytes on disk, so few people do it.</i><p>First, I doubt one of the reasons &quot;few people do it&quot; is because it &quot;consumes many megabytes on disk&quot; (what? whatever).<p>Second, the author vastly underestimates how hard it is handling protocols like IMAP, or writing a &quot;text editor&quot; that can handle all the subtleties of email (which include almost a whole blown HTML rendering). Now, if he means &#x27;people should be able to write an emailer easily iff all constituent parts where available as libraries and widgets&#x27;, then yeah, duh!<p>&gt;<i>Mac OS X was once a shining beacon of new features, with every release showing profound progress and invention. Quartz 2D! Expose! System wide device syncing! Widgets! Today, however Apple puts little effort into their desktop operating system besides changing the theme every now and then and increasing hooks to their mobile devices.</i><p>Yeah, and writing a whole new FS, a whole new 3D graphics stack, memory compression, seamless cloud file storage, handoff, move to 64-bit everything, bitcode, and tons of other things besides. Just because they are not shiny, doesn&#x27;t mean there are no new futures there.<p>&gt;<i>A new filesystem and a new video encoding format. Really, that&#x27;s it?</i><p>Yeah, because a new FS is so trivial -- they should also rewrite the whole kernel at the same time, for extra fun.<p>&gt;<i>Why can I dock and undock tabs in my web browser or in my file manager, but I can&#x27;t dock a tab between the two apps? There is no technical reason why this shouldn&#x27;t be possible. Application windows are just bitmaps at the end of the day, but the OS guys haven&#x27;t built it because it&#x27;s not a priority.</i><p>There&#x27;s also no real reason this should be offered. Or that it should be a priority. If every possible feature someone might thing was &quot;a priority&quot; OSes would be horrible messes.<p>&gt;<i>Why can&#x27;t I have a file in two places at once on my filesystem? Why is it fundamentally hierarchical? Why can I sort by tags and metadata?</i><p>Note how you can do all those things in OS X (you can have aliases and symlinks and hard links, can add tags and metadata, and can sort by them). And in Windows I&#x27;d presume.<p>And it&#x27;s &quot;fundamentally hierarchical&quot; because that&#x27;s how we think about stuff. But it also offers all kind of non hierarchical views, Spotlight and Tags based views for one.<p>&gt;<i>Any web app can be zoomed. I can just hit command + and the text grows bigger. Everything inside the window automatically rescales to adapt. Why don&#x27;t my native apps do that? Why can&#x27;t I have one window big and another small? Or even scale them automatically as I move between the windows? All of these things are trivial to do with a compositing window manager, which has been commonplace for well over a decade.</i><p>Because bitmap assets. Suddenly all those things are not so &quot;trivial&quot;.<p>There are good arguments to be made about our OSes being held back by legacy cruft (POSIX for one) and new avenues to explore, old stuff that worked better than what we have now, etc.<p>But TFA is not making them.
ageofwant将近 8 年前
Most all the author craves for can be cobbled together from existing components. On Linux at least. If you don&#x27;t use Linux you have bigger issues to deal with first.<p>He can start by using a tiling window manager, like i3.<p>&quot;It ain&#x27;t what you don&#x27;t know that gets you into trouble. It&#x27;s what you know for sure that just ain&#x27;t so.&quot;
评论 #15059109 未加载
free_everybody将近 8 年前
Realistically, how difficult is it to write a brand new operating system like this? Could a few people with full-time jobs write a working model in a year? Maybe 10 people? Is it just too time consuming with too little of a payout? There should be more options; I think a lot of people can agree on that.
评论 #15061814 未加载
anc84将近 8 年前
&gt; It took tremendous effort to get 3D accelerated Doom to work inside of X windows in the mid 2000s, something that was trivial with mid-1990s Microsoft Windows.<p>Huh? I am not aware of a 3D accelerated Doom version on Windows in that timeframe nor that it was hard on Linux 10 years later. Any pointers?
zvrba将近 8 年前
This sounds like a rant from a person not really acquainted with operating systems.<p>&gt; Why can I dock and undock tabs in my web browser or in my file manager, but I can&#x27;t dock a tab between the two apps?<p>How would this even be semantically meaningful? What about top-level components like menus which are completely different?<p>&gt; Why can&#x27;t I have a file in two places at once on my filesystem?<p>Umm, soft and hard links do exactly that.<p>&gt; Why can&#x27;t I speak commands to my computer<p>Cortana takes a shot at that. Personally, I don&#x27;t even want to try out the feature until it has the level of comprehension corresponding to a human. Otherwise, I&#x27;ll just be guessing how to spell out my sentences &#x2F; commands..<p>&gt; or have it watch as I draw signs in the air, or better yet watch as I work to tell me when I&#x27;m tired and should take a break.<p>Because these are hard problems in computer vision, unrelated to operating systems.<p>&gt; Each application has its own part of the filesystem<p>Yes, I wouldn&#x27;t want to give up on that. It&#x27;s orderly.<p>&gt; its own config system, and its own preferences, database<p>Well, Windows unifies this in the registry. It&#x27;s somewhat unpopular.<p>&gt; Traditional filesystems are hierarchical, slow to search, and don&#x27;t natively store all of the metadata we need.<p>NTFS can store extended metadata + arbitrary data in alternate data streams. Doesn&#x27;t seem to be used very much.<p>&gt; I&#x27;d like to pipe my Skype call to a video analysis service while I&#x27;m chatting, but I can&#x27;t really run a video stream through awk or sed.<p>The video stream is a stream of bytes. Skype interprets it and constructs a video from that byte stream. Does he suggest that this interpreter should be part of the kernel? That there is one single video streaming protocol that fits all purposes?<p>&gt; Native Applications are heavy weight,<p>Um? I have yet to see a &quot;non-native&quot; application that is as snappy as a native one.<p>&gt; take a long time to develop and very siloed.<p><i>Any</i> application takes a long time to develop. If you care about stability, crash recovery, etc.<p>&gt; Wouldn&#x27;t it be easier to build a new email client if the database was already built for you?<p>Exists, integrated in the Windows OS: <a href="https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Extensible_Storage_Engine" rel="nofollow">https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Extensible_Storage_Engine</a><p>&gt; The UI would only be a few lines of code.<p>It&#x27;s logic behind the UI that&#x27;s complicated, not building the UI itself (heck, you can just draw it if you use C# or VB).<p>&gt; If you want to make a program that works with the song database you have to reverse engineer iTunes DB format<p>Even if the hypothetical document DB existed, how would one program know about the schema of other programs? Or schema versioning, or...? The problems with proprietary formats won&#x27;t just disappear, it&#x27;ll just become easier to do the wrong thing based on misinterpretation of the other program&#x27;s schema.<p>&gt; Message Bus [...] All applications become small modules that communicate through the message bus for everything.<p>COM, DCOM, CORBA... The first two are made user-friendly on Windows by C#. Don&#x27;t know whether it&#x27;s possible to snoop on COM messages, but given the thickness of the documentation on COM, I&#x27;d say the answer is &quot;yes&quot;.<p>&gt; However, this also means we have to rebuild everything from scratch.<p>Yes. Windows already exposes an insane amount of helper objects as COM components.<p>&gt; You could build a new email frontend in an afternoon...<p>In which alternate universe?<p>&gt; I really like the commandline as an interface sometimes, it&#x27;s the pure text nature that bothers me. Instead of chaining CLI apps together with text streams we need something richer, like serialized object streams (think JSON but more efficient).<p>He should read up on Powershell. It&#x27;s also extensible and can directly invoke COM components (+ all of the .net framework).<p>&gt; System Side Semantic Keybindings<p>That one may be original. I think KDE has something like this.<p>&gt; The clipboard should be visible on screen as some sort of a shelf that shows the recent items I&#x27;ve copied.<p>IIRC, I&#x27;ve seen something like this in KDE. Earlier versions of Windows had some &quot;clipboard manager&quot; too, though it seems to have disappeared in new versions. Plenty of freeware ones though.<p>&gt; In the new system all applications are tiny isolated things which only know what the system tells them.<p>That&#x27;s how Windows UWP applications behave. Appstore ones too. IIRC, some old, then-mainstream OS-es tried the kind of separation and it didn&#x27;t work well with users. Sometimes you want to share data between isolation domains.<p>&gt; None of this is New<p>No, and it seems that, feature-wise, Windows is closest to his dream OS. Now he just needs to convince programmers to use the features that are already there :-)
评论 #15059017 未加载
meesterdude将近 8 年前
&gt; I could take a snapshot of a screen. This would store the current state of everything, even my keybindings. I can continue working, but if I want I could rollback to that snapshot.<p>we can already do this with virtualization (and i make use of it extensively)
评论 #15059627 未加载
jokoon将近 8 年前
There are really millions of small things that I would make in a new desktop OS.<p>First would be to forget the whole idea of resizable windows. Windows should only tile automatically. A tab interface have shown that a simple task bar is just enough.<p>File explorers would have their columns be resized automatically... I can&#x27;t believe how both OS X and windows 10 still have this wrong.<p>Ultimately I would let applications use hardware directly instead of relying on how the OS do things. This would increase cross compatibility and developer freedom. Good bye Qt and all those horrors of the past.<p>Not to mention how there are millions of small utilities and functionalities like windirstat, foobar2000 that would be ideal to make the OS a little more useful.
michaelmrose将近 8 年前
&quot;Window Managers on traditional desktops are not context or content aware, and they are not controlable by other programs.&quot;<p>What does this mean? Some can be via IPC
OOPMan将近 8 年前
Ah, the age-old assumption among developers:<p>Everything is terrible and broken, the only way to fix it is to throw everything in the bin and start from scratch.<p>Some things never change...
untangle将近 8 年前
Perhaps the new OS prototypes could be built on top of a hypervisor. Yes, it&#x27;s a layer. But building hypervisor-up would be a nice jump-start.
jrs95将近 8 年前
I&#x27;m not really sure if a system wide document database is an improvement over Core Data or not...
djhworld将近 8 年前
I like the optimism in this post, there&#x27;s are lot of dismissive comments on here.<p>However I just don&#x27;t think any of the ideas would ever really function. The idea of letting you pipe your Skype video feed to some video analysis tool would never happen<p>Similarly you&#x27;d never get application developers to open up their apps in such a way where you can extract&#x2F;import content.
osteele将近 8 年前
This could be the first half of a good article. It&#x27;s a list of things the author cares about that variously: aren&#x27;t (yet) possible, aren&#x27;t a good idea, nobody cares enough to make happen, or (maybe) indicate a market force failure.<p>What would make this interesting (to me) is a discussion not <i>that</i> these features don&#x27;t exist, but <i>why</i>.
评论 #15059934 未加载
consultSKI将近 8 年前
&gt;&gt; think JSON but more efficient<p>Amen. Seriously tho, a lot of great insight.
d4r114将近 8 年前
PJON could fit as the message bus the author describes
SomeHacker44将近 8 年前
Please write it from the ground up in Common Lisp. :)
jackcosgrove将近 8 年前
How does this new OS handle backwards compatibility?<p>I&#x27;ve always thought the next evolution of the OS was to be a hypervisor for application containers that can communicate via a common message bus.
评论 #15060425 未加载
maxekman将近 8 年前
The suggested OS sounds a lot like Plan 9 to me.
rado将近 8 年前
macOS&#x27; recent Metal feature is great and extended my MacBook Air&#x27;s life by 2 years. People keep forgetting it.
nkristoffersen将近 8 年前
Sounds like he should be using iOS honestly.
Xorlev将近 8 年前
I believe understand the vision that the author is trying to paint. I don&#x27;t think he&#x27;s alone, but the reality is that building a full OS is a pretty massive undertaking. Additionally, his idea of simplicity may be complexity for others. I want to explore this a bit from a point of optimism, because it&#x27;s very very easy to find flaws in a manifesto that desires to redesign an operating system.<p>There&#x27;s a lot of interesting experimentation in OS-land. BeOS (and it&#x27;s successor, Haiku [1]) are called out explicitly by the author. BeOS&#x2F;Haiku use this idea of apps as modules to expose functionality across a message bus. Redox OS (A Rust OS), is built on the microkernel concept. These are both kind of on the fringe at the moment, so let me bring up one more platform that many of us use daily: the modern web browser.<p>Chrome (and Firefox, ChromeOS, etc.) actually do take many of these concepts to heart. Now, I know more about Chrome than Firefox or ChromeOS, so let me set those aside for a moment.<p>- &quot;Everything done via a message bus.&quot; This is Chrome extensions in a nutshell. - &quot;Dockable tabs in any window.&quot; - &quot;A CLI with structured data.&quot; Sorta Chrome debugger+JS. With some effort, this could be a lot more powerful. The author&#x27;s desire to pipe a video call to an analysis service is a fairly tough requirement here and obviously wouldn&#x27;t fly in Chrome either, but that isn&#x27;t to say that it&#x27;d be impossible. - &quot;A built-in document database.&quot; (IndexedDB) - &quot;Working sets.&quot; Chrome profiles -- try them! - &quot;Apps become Modules.&quot; This is more of a miss, but if you squint enough through a powerful enough lens, the APIs exposed by Chrome to extensions&#x2F;webpages are a lot like this. That said, given that everything on Chrome is more site-centric vs. computer-centric, things are namespaced vs. Spotify being able to execute arbitrary queries for MP3s.<p>Now, I&#x27;m not going to say that Chrome is IdealOS. There is much from that vision that&#x27;s missing. And I&#x27;d also say that webapps just aren&#x27;t always an acceptable substitute for native applications. Through massive wastes of computing power, we are getting closer (see: Slack, Atom, all things Electron). We aren&#x27;t there yet. I&#x27;ll always take a native app if it&#x27;s written decently.<p>It seems to me like in general much of this vision is being expressed through disparate efforts, but only a few are tackling the idea of replacing the full OS. Chrome seems best poised in many ways because it&#x27;s already on your existing OS. Yes, it&#x27;s having to use the underlying OS&#x27; APIs and such, but you can argue it&#x27;s just one more layer. ChromeOS seems to do a pretty good job of eliminating even that.<p>In general, I&#x27;m excited to see discussion on operating systems. The OSes used by the general public are already here: Android and iOS. It&#x27;s up to us to build a better future for those of us using workstations<p>Disclaimer: I do not work on Chrome, but do work for its parent organization. My views in no way reflect that of my employer&#x27;s.<p>[1] <a href="https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Haiku_(operating_system)" rel="nofollow">https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Haiku_(operating_system)</a> [2] <a href="https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Redox_(operating_system)" rel="nofollow">https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Redox_(operating_system)</a>
tomc1985将近 8 年前
I&#x27;m getting to the point where Medium articles with stock imagery are instantly ignored.
pvdebbe将近 8 年前
Complecting a GUI into an OS doesn&#x27;t sound very ideal to me.
kyberias将近 8 年前
So much incorrect stuff in the text, I stopped reading.
halo将近 8 年前
This aligns a lot with my personal thoughts about desktop operating systems, especially the document database, ala BeFS on steroids, which is something I&#x27;ve thought about for years and would be a huge improvement over the current situation in a lot of use-cases.<p>I&#x27;ve long felt that applications and &quot;package management&quot; is still extremely poor. Applications should be self-contained to a single file (software.app) and have no shared dependencies outside the OS. The OS could have built-in support for compression (e.g. software.app.compressed) for software that needs it. Each application has one settings file per user. Sending, moving and backing up software then becomes a breeze. Uninstalling becomes a matter of deleting a file.<p>No shared libraries. It&#x27;s 2017 and bandwidth and disk space are not major problems. An OS will be able to figure out when it doesn&#x27;t need to load more than one copy of a dynamic library to avoid using excess memory. The OS should be &#x27;batteries included&#x27; so truly native applications will be tiny. You want to proactively discourage ports to encourage native software, and need developers to think twice before using bloated or interconnected dependencies.<p>This greatly simplifies creating any &quot;app store&quot;&#x2F;&quot;package manager&quot;. It will largely download and update individual files.<p>All software is sandboxed, with permissions required to do anything interesting, ala iOS.<p>Title bars should be stackable to turn into tabs, ala Haiku&#x27;s stack-and-tile (<a href="https:&#x2F;&#x2F;www.haiku-os.org&#x2F;docs&#x2F;userguide&#x2F;en&#x2F;gui.html#stack-tile" rel="nofollow">https:&#x2F;&#x2F;www.haiku-os.org&#x2F;docs&#x2F;userguide&#x2F;en&#x2F;gui.html#stack-ti...</a>). Everyone uses tabs in web browsers, it is overdue to bring them as first-class features into desktop OSes, where it would greatly improve multitasking. The title bar goes from being redundant into a core feature.<p>I agree that creating a good new operating system requires starting from scratch and that is really, really hard. Broadly speaking, you want to discourage ports, as it&#x27;s a short-cut that will remove a lot of the advantages of the OS and will discourage people from creating native software. Any new OS needs to have the outright aim of making commercial software viable to be successful, which is something Linux has struggled with.<p>Any new OS needs to be very polished and slick visually, which should be one of the lessons from Mac OS X and its relative success over BeOS and NeXTSTEP, which were much less visually appealing.<p>Practically, I&#x27;ve wondered if you could focus on a single low-cost piece of hardware - a Raspberry Pi-in-a-box, perhaps, coupled with a VM version. This could limit the scope of the task and you might get a good amount of enthusiasts beyond free software evangelists.<p>I also wonder if thin translation layers over established libraries would vastly speed up development by allowing a working version to be produced much faster, even though you would want to replace them with something better in the long run.
Ezhik将近 8 年前
I was throwing out hypotheticals with a couple of friends a few days back. One problem that I felt things like Samsung DeX and Windows Continuum were trying to solve was the fact that all your devices are ultimately separate computers.<p>Your currently open apps, configuration, even things like your wallpaper - are still ultimately different across your devices. Each device has its own <i>state</i>, and while with things like cloud file syncing and Pushbullet and etc, you can make your devices at the very least aware of each other, in the end, they still have separate <i>states</i>.<p>The endgame would be to just have a single <i>state</i>, period. Your computer would be every device you have. You would be able to drag a window from your phone to your desktop to your HoloLens. Every file you have in your life, is always with you.<p>But that&#x27;s the faraway future.<p>Something possible with today&#x27;s hardware (but not software), however, would be to have phones with smart docks. Instead of just being hubs to connect the phone to a screen and a keyboard, they would also have processing power, and be proper computers in their own right to which the phone would be able to offload complex computations. But I&#x27;m thinking it should be less like an external GPU dock, and more like a server for remote compilation or video rendering. This way, for example, you&#x27;d even be able to do things like starting to render a video while your phone is docked, then undocking while the video is still rendering on the dock, or you could launch a game that runs on the dock and is controlled from your phone - something like AirPlay, but the processing takes place on the dock. So ultimately, while you still have multiple computers, there is only a single <i>state</i>, which is on your phone.<p>The software is the hard part here. We can build a smartphone and a smart dock, and have a fast enough data protocol to transfer content between each other through USB-C. But who will write the OS? Where do you get the apps? Why would Adobe bother porting After Effects to run on a <i>phone</i> of all things, and then also restructure it to be aware of the whole smart dock concept, when After Effects can do something like this today as it is? Why would game developers bother writing their games in a way that specifically supports this dock paradigm when they can get the same general idea on the Nintendo Switch for free? And so on.<p>This, just like OP&#x27;s idea, would take a reboot. The problem with a reboot is that it&#x27;s a reboot. You cannot do that. Microsoft cannot do it, which is why Windows 10 still runs very old software. Apple can&#x27;t do it, which is why Carbon was a thing. Linux can&#x27;t do that, because Red Hat and Canonical will not throw their customers under a bus.<p>But still, it&#x27;s fun to daydream. Being told to stop even imagining the impossible is not exactly going to help innovation.
ZenPsycho将近 8 年前
this runs parallel to a lot of my thoughts. one thing that you don&#x27;t quite address, and which i believe has derailed all efforts to do stuff like this, is the challenge of getting a large group of developers to agree on a single set of data formats. it is only once you nail that, that doing many of the composition&#x2F;copy&#x2F;paste things become possible. some of these formats are easy: jpeg, png, utf-8. when it comes to something like: the meta data schema for a song? a recipe? that&#x27;s a can of worms and flamewars.<p>to some extent you&#x27;ve got the DBFS thing that everything shares but that&#x27;s only of use for sharing so far as you can get easy agreement about what fieldnames should he available for a kind of thing.<p>you&#x27;ve also got security concerns. if everything shares the same database, any random bit of code can ship that data off to a russian data mining op. or corrupt your song database. or encrypt everything and ransom it. you kind of address this by puttin a layer of indirection here, and having security and access managed via the message bus, but this needs a UI, and i don&#x27;t think apple, android, or facebook has really mastered the ui for permissions.
SiempreZeus将近 8 年前
Most of the stuff he wants is either trivial, or an implementation hell that Will never happen. Hard and soft links solve the hierarchical filesystem problem, kwin has windows tabbing (nobody uses it), rewriting every single app from scratch for a theoretical gain? Sure that&#x27;s happening.<p>The only good idea is the system documents database, and it isn&#x27;t really that useful.
fundabulousrIII将近 8 年前
I used to think a system bus concentrator for disparate communications was the way forward but it always ends in tears. You have created an interrupt handling system in userspace with n * x permutations and specifications..this is the literal tower of babel and is very easily abused.
romanovcode将近 8 年前
&gt; In the screenshot below the user is lifting the edge of a window up to see what&#x27;s underneath. That&#x27;s super cool!<p>&gt; <a href="https:&#x2F;&#x2F;joshondesign.com&#x2F;&#x2F;images2&#x2F;lift-window.png" rel="nofollow">https:&#x2F;&#x2F;joshondesign.com&#x2F;&#x2F;images2&#x2F;lift-window.png</a><p>Is this a sarcasm? Because it is complete garbage.
评论 #15058755 未加载
评论 #15059325 未加载
评论 #15060256 未加载
评论 #15058680 未加载