<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Hacker News: buzzybee</title><link>https://news.ycombinator.com/user?id=buzzybee</link><description>Hacker News RSS</description><docs>https://hnrss.org/</docs><generator>hnrss v2.1.1</generator><lastBuildDate>Wed, 06 May 2026 21:39:29 +0000</lastBuildDate><atom:link href="https://hnrss.org/user?id=buzzybee" rel="self" type="application/rss+xml"></atom:link><item><title><![CDATA[New comment by buzzybee in "Iodine: A full superset of Java with enhancements"]]></title><description><![CDATA[
<p>RemObjects is not unknown. You're just new.</p>
]]></description><pubDate>Sat, 02 Sep 2017 20:35:00 +0000</pubDate><link>https://news.ycombinator.com/item?id=15158063</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=15158063</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=15158063</guid></item><item><title><![CDATA[New comment by buzzybee in "FizzleFade"]]></title><description><![CDATA[
<p>FizzleFade is also found in Microprose games from the era (e.g. Railroad Tycoon, Civilization), sometimes in full-screen transitions and other times to fade in single sprites. But more relevantly to "id software history", you can find it in Origin's Space Rogue, which John Romero contributed to. A likely possibility is that he picked up the trick on this or a previous project while at Origin.<p>It's also possible to use a slower "arbitrary PRNG and bump" scheme that tests the VRAM for the desired values(e.g. if it were a sprite, by running the blit at that pixel address and testing) and walks forwards or backwards until an unset value is found. If the walk can be done fast enough, it'll execute at the same framerate as an LFSR cycle-length fade. It can be further supplemented with an estimation heuristic or a low-resolution map to generate unique patterns. It's just less speedy and mathematically interesting to do that.</p>
]]></description><pubDate>Tue, 29 Aug 2017 10:06:55 +0000</pubDate><link>https://news.ycombinator.com/item?id=15123240</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=15123240</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=15123240</guid></item><item><title><![CDATA[New comment by buzzybee in "Motive.c: The Soul of the Sims (1997)"]]></title><description><![CDATA[
<p>It enables the coder to engage in some late binding without engaging in a lot of casts or more elaborate metaprogramming: the enum index used for assignment is itself an assignable value and therefore can be passed around and manipulated if the algorithm needs it. It's a very intentional tradeoff of structure and long-term clarity for a faster turnaround to make design changes.<p>I haven't even checked to see if the final program uses it. It's the kind of thing, though, that you might go in thinking, "maybe I will need that", and it doesn't add too much overhead to your prototype.</p>
]]></description><pubDate>Sun, 13 Aug 2017 02:47:45 +0000</pubDate><link>https://news.ycombinator.com/item?id=15001215</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=15001215</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=15001215</guid></item><item><title><![CDATA[New comment by buzzybee in "Does OO really match the way we think (1997) [pdf]"]]></title><description><![CDATA[
<p>My strategy for personal coding recently has shifted towards a sincere exploitation of automatic programming(in a manner similar to model-driven development or language-oriented programming, or the research of VPRI). The overall feedback loop looks like this:<p>* Write an initial mockup that exercises APIs and data paths in an imperative, mostly-straightline coding style<p>* Write a source code generator that reproduces part of the mockup by starting with the original code as a string and gradually reworking it into a smaller specification.<p>* Now maintain and extend the code generator, and write new mockup elements to develop features.<p>The mockup doesn't have to be 100% correct or clean, nor does the code generator have to be 100% clean itself, nor does 100% of the code have to be automated(as long as clear separation between hand-written modules and automatic ones exists), but the mockup is necessary as a skeleton to guide the initial development, and similar, comprehensible output one layer down is a design goal. Language-level macro systems are not typically sufficient for this task since they tend to obscure their resulting output, and thus become harder to debug. Languages that can deal well with strings and sum types, on the other hand, are golden as generator sources since they'll add another layer of checks.<p>I'm still only using this for personal code, but it's gradually becoming more "real" in my head as I pursue it: the thing that stopped me before was developing the right feedback loop, and I'm convinced that the way to go is with a pretty lean base implementation(Go is an example of how much language power I'd want to be using in the target output) and an assumption that you're building a bespoke generator for the application, that won't be used anywhere else.<p>Source code generation gets a bad rap because the immediate payoffs are rare, and it's easy to take an undisciplined approach that just emits unreadable boilerplate without gaining anything, but the potential benefits are huge and make me not really care about design patterns or frameworks or traditional "paradigms" anymore. Those don't achieve anywhere near the same amount of empowerment.</p>
]]></description><pubDate>Sat, 12 Aug 2017 08:37:07 +0000</pubDate><link>https://news.ycombinator.com/item?id=14997062</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=14997062</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=14997062</guid></item><item><title><![CDATA[New comment by buzzybee in "Cleaning a Dirty Sponge Only Helps Its Worst Bacteria"]]></title><description><![CDATA[
<p>I do microwave the sponge after use, for about 2 minutes so that it's bone dry. The reasoning is simple: most of the bacteria are going to hang out in the water. It's still going to be infected, but it doesn't have to be <i>disinfected</i>. It just has to remain close enough to the ambient load of the kitchen that it doesn't obviously inflame my hands when I pick it up. After all, my hands are germy too, most of the time. The soap, water, and pressure applied during cleaning are supposed to do most of the work.</p>
]]></description><pubDate>Sat, 05 Aug 2017 19:01:58 +0000</pubDate><link>https://news.ycombinator.com/item?id=14937297</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=14937297</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=14937297</guid></item><item><title><![CDATA[New comment by buzzybee in "Lindy effect"]]></title><description><![CDATA[
<p>The longest possible chess game:<p><a href="https://www.chess.com/blog/kurtgodden/the-longest-possible-chess-game" rel="nofollow">https://www.chess.com/blog/kurtgodden/the-longest-possible-c...</a><p>Chess AIs, perhaps needless to say, are very good at computing at the depth necessary to win drawn-out endgames.</p>
]]></description><pubDate>Mon, 31 Jul 2017 07:33:30 +0000</pubDate><link>https://news.ycombinator.com/item?id=14890121</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=14890121</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=14890121</guid></item><item><title><![CDATA[New comment by buzzybee in "Microsoft Paint to be killed off after 32 years"]]></title><description><![CDATA[
<p>IME real users don't care about the app being aesthetically different, but they do care if the common idioms have changed(e.g. position of OK/Cancel). That shouldn't depend on your toolkit, though.</p>
]]></description><pubDate>Mon, 24 Jul 2017 18:35:47 +0000</pubDate><link>https://news.ycombinator.com/item?id=14841334</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=14841334</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=14841334</guid></item><item><title><![CDATA[New comment by buzzybee in "Microsoft Paint to be killed off after 32 years"]]></title><description><![CDATA[
<p>Some time ago someone recommended SpeedCrunch to me for calculator stuff and I use it all the time now. It's a little bit less intuitive since it takes a syntax instead of presenting buttons, but it does a ton more.</p>
]]></description><pubDate>Mon, 24 Jul 2017 18:32:38 +0000</pubDate><link>https://news.ycombinator.com/item?id=14841308</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=14841308</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=14841308</guid></item><item><title><![CDATA[New comment by buzzybee in "Bitcoin May Have Solved Its Scaling Problem"]]></title><description><![CDATA[
<p>Worse-is-better: we already "solved" it with altcoins.</p>
]]></description><pubDate>Sat, 22 Jul 2017 11:56:22 +0000</pubDate><link>https://news.ycombinator.com/item?id=14826722</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=14826722</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=14826722</guid></item><item><title><![CDATA[New comment by buzzybee in "A hacker stole $31M of Ether – how it happened, and what it means for Ethereum"]]></title><description><![CDATA[
<p>Regarding smart contracts and other inventions of cryptocurrency: I think, most of all, the crypto market is absolutely vicious, in a way that both capital markets and technology companies haven't seen(in the public eye) for many, many years. As of right now there's still some faith left that Ethereum is going to go places because firms keep trying to use the technology on the basis of hype. Unlike with most overhyped and half-baked tech, though, the failures do not get shoved in the back room for some hapless dev or ops team to deal with. This is like if Apple and Google had daily columns on the front page showing every bug or support issue that they experienced in the past 24 hours.<p>And that's been true right from the beginning with Bitcoin: scams, schemes, heists, data loss - the headlines scream blood all the time. We've never had that kind of "mean time to disaster" in technology before. The status quo was that something would fail, but the failure would never quite get back to the individual or company that produced it. They would spin it away, and no careers would be harmed. But the likes of Solidity produces a meat-grinder, a blind destroyer of any who dare enter calling themselves rockstar.<p>I think it's kind of awesome and beautiful, in that sense. It will induce a maturation throughout the economy to adapt to this new pressure. But like adolescence, it can be an ugly work in progress, and I don't expect Ethereum itself to be a survivor at this rate.</p>
]]></description><pubDate>Fri, 21 Jul 2017 06:40:28 +0000</pubDate><link>https://news.ycombinator.com/item?id=14818527</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=14818527</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=14818527</guid></item><item><title><![CDATA[New comment by buzzybee in "Go's work-stealing scheduler"]]></title><description><![CDATA[
<p>This is not a valid argument when the line in question is dealing entirely with abstract constructs(which it is) and all of the variables are function-local, declared on the very same screen, and several of them exist as aliases for more complex constructs. If you haven't encountered a need for this approach, you just haven't had to write really mathy code before. Mathy code derives  little value from longer names, but it does benefit from density.<p>If you really think something is wrong with it, post ideas for longer names that will clarify and not substantially impact density. I would probably conventionally use "n0" and "n1" instead of "m" and "n" to represent "n-1", "n" - but the usage he has is consistent throughout the file, which is more than I can say of my stuff sometimes.</p>
]]></description><pubDate>Tue, 18 Jul 2017 17:01:53 +0000</pubDate><link>https://news.ycombinator.com/item?id=14798130</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=14798130</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=14798130</guid></item><item><title><![CDATA[New comment by buzzybee in "The $100B per year back pain industry is mostly a hoax"]]></title><description><![CDATA[
<p>I've been on the "sleep on exercise mat with some blankets" train for years, but a few months back, stepped it up by eliminating pillows. I still gravitate towards getting something under my head, but it turns out that I only need another small blanket or cloth. I wake at more consistent hours and no longer experience numbness in my arms when waking. I believe there are many more "details" I can improve too. I got into training fast and slow breathing patterns for different activities, which seems to help both the training and the recovery. A plainer diet seems to help a lot of things, although it's hard to reconcile this against the constant imposition of the world to eat pizza and drink beer.</p>
]]></description><pubDate>Wed, 05 Jul 2017 01:22:52 +0000</pubDate><link>https://news.ycombinator.com/item?id=14699422</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=14699422</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=14699422</guid></item><item><title><![CDATA[New comment by buzzybee in "The $100B per year back pain industry is mostly a hoax"]]></title><description><![CDATA[
<p>The core is so important. Core + breathing exercises will improve any other activity.</p>
]]></description><pubDate>Tue, 04 Jul 2017 23:51:46 +0000</pubDate><link>https://news.ycombinator.com/item?id=14699062</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=14699062</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=14699062</guid></item><item><title><![CDATA[New comment by buzzybee in "RFC: Evolving Rust Through Epochs"]]></title><description><![CDATA[
<p>Contrast with FPC's compiler mode pragmas for different dialects. [0] FPC shows the effects of this story in the long term: there are several major divergences in behavior supported by the modes, and some individual features can be toggled per-unit or sometimes with a finer grain. [1] Since you're allowed to mix and match  different units, the fragmentation poses little threat to any individual programmer, and it's possible to dial in assertions, optimizations, and calling conventions in a targeted fashion.<p>[0] <a href="https://www.freepascal.org/docs-html/user/userse33.html" rel="nofollow">https://www.freepascal.org/docs-html/user/userse33.html</a><p>[1] <a href="https://www.freepascal.org/docs-html/prog/progch1.html#progse2.html" rel="nofollow">https://www.freepascal.org/docs-html/prog/progch1.html#progs...</a></p>
]]></description><pubDate>Tue, 04 Jul 2017 23:29:23 +0000</pubDate><link>https://news.ycombinator.com/item?id=14698970</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=14698970</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=14698970</guid></item><item><title><![CDATA[New comment by buzzybee in "Ask HN: Code examples to find out if a person is addicted to “overengineering”"]]></title><description><![CDATA[
<p>Here's an easy challenge: Ask the overengineer to solve problems without introducing any new classes or functions. This starves the overengineer of oxygen, reducing their abstraction options to "loop", "branch", and "add variable". The resulting giant switch statement in a loop is likely to be a relatively clean architecture.</p>
]]></description><pubDate>Mon, 26 Jun 2017 19:24:08 +0000</pubDate><link>https://news.ycombinator.com/item?id=14639521</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=14639521</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=14639521</guid></item><item><title><![CDATA[New comment by buzzybee in "Go and Simplicity Debt"]]></title><description><![CDATA[
<p>I've been musing about these sorts of issues of "what is really complex" lately, too. I started evaluating new languages for low-level application code again after spending a lot of time overly close to web browsers, and then ended up deciding that Free Pascal beat them on the stuff I cared about, relative to C compilers as a baseline:<p>* Best-in-class compile times<p>* Modules; preprocessor is relevant, but not dominant<p>* Generics, variant records, function and operator overloads, exceptions, safe string and dynamic array types<p>* Libraries for common things, with a reasonably conventional style: APIs, containers, bindings, etc.<p>* No GC; pointers are available, but language features discourage casual usage. RAII pattern is achievable.<p>* Strong + static types, nominal types and type aliasing.<p>* Good IDE support, mature tooling, compiler has very broad platform support.<p>The new languages do win on a lot of the language-feature aspects(particularly memory safety when performing deep optimizations), but they don't have as good a story on the tooling. The compile speed is a major feature and is only likely to remain advantageous over time - and the features already in place are quite effective at limiting source code size, boilerplate, and dangerous constructs. This despite "Pascal is verbose" being memetic.<p>And if I want more high-level power, I've found that writing a FSM is the most probable path to achieving it. A FSM that embraces the problem domain is a tiny compiler: input source constructs, FSM checks them, applies appropriate algorithms, then emits a list of actions. More power? Add a second FSM to make it a two-pass compiler. Add a stack, or attach it to a database. If it has to be fast, it can generate code in the last step, too. Those things add tons of power to model the problem and aren't heavily dependent on language-side support.</p>
]]></description><pubDate>Thu, 15 Jun 2017 22:41:52 +0000</pubDate><link>https://news.ycombinator.com/item?id=14565079</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=14565079</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=14565079</guid></item><item><title><![CDATA[New comment by buzzybee in "Why Events Are a Bad Idea (for high-concurrency servers) (2003) [pdf]"]]></title><description><![CDATA[
<p>When the paper was written, the jury was still definitely out on good concurrency practices for applications: the computing world(apart from mainframes, which of course had learned every lesson 30 years earlier, but nobody paid much attention to) had only relatively recently exited the era where one might ordinarily synchronize your co-processing units at the instruction level, with hand-tuned assembly, just like any other piece of external hardware. Cooperative, event-based programming is familiar to this style. Asynchronous primitives backed by hardware scheduling were the "new kid" for a lot of programmers.<p>So, like with every technology, there was some exuberance and overuse of a novel formalism which shows up in this paper: "scales to 100,000 threads", it proclaims. Not much later, interest in "green threading" and "lightweight concurrency" grew as a way to get some of the architectural benefits of being asynchronous while mitigating waste from large numbers of threads, and consensus shifted towards mixing the approaches, which seems to have converged on the few-threads, message-queue-per-thread approach.</p>
]]></description><pubDate>Tue, 13 Jun 2017 23:03:34 +0000</pubDate><link>https://news.ycombinator.com/item?id=14549407</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=14549407</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=14549407</guid></item><item><title><![CDATA[New comment by buzzybee in "10x engineers take long naps"]]></title><description><![CDATA[
<p>I'm seeing it as a feedback loop problem, again. Managers and stakeholders have an easy time remarking on surfaced progress. The developer has to think and communicate everything else. Going purely hands-off doesn't work, because then the developer will tend to wander towards working on the wrong problems and get mired in them. Neither does chaining them down to a deadline, since that creates rushed, ill-considered work.<p>So the people who are perceptually 10x tend to have hit on a strategy that keeps them in the feedback zone without being overly concerned about surfacing everything right this second, and have management that cooperate with their strategy.</p>
]]></description><pubDate>Tue, 13 Jun 2017 21:17:51 +0000</pubDate><link>https://news.ycombinator.com/item?id=14548729</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=14548729</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=14548729</guid></item><item><title><![CDATA[New comment by buzzybee in "Is Software Engineering Possible?"]]></title><description><![CDATA[
<p>You wouldn't be alone as a philosopher-developer, there are a decent number of us out there.<p>However - shipping code is often very organic, cultivated stuff which foils attempts to establish a coherent philosophy, a through-line of "how it works" - it works because it worked the day before, all that changed was that a little bit more was added. Repeat till broken, then refactor back to sanity(else abandon ship). It's Sisyphean hill-climbing.<p>This in turn plays into the falsity of "engineering" as a way to describe what's going on with a lot of code. You can do it in the small, but at any scale the codebase habitually becomes a living organism. And that tends to get puzzle-solver types excited, because if it's alive and keeps changing, then they will have endless problems to solve forever!<p>So I believe the philosophers of the crowd ultimately tend to move away from the applications coalface and look for something relatively smaller that does allow some time for reflection and distillation of the problem.</p>
]]></description><pubDate>Sat, 10 Jun 2017 20:20:35 +0000</pubDate><link>https://news.ycombinator.com/item?id=14529020</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=14529020</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=14529020</guid></item><item><title><![CDATA[New comment by buzzybee in "Code boilerplate: Is it always bad?"]]></title><description><![CDATA[
<p>I followed Carmack's suggestion and never looked back. I write simpler code on average now, and I spend less time having to re-read it too because I'm changing the same lines less often. What I lose in terseness in the short-term, I regain in being able to spot key abstractions that are more crucial to long-term program health. It plays well with debugging since there are fewer places where state can act at a distance.<p>It's very unfashionable advice in some circles, though. It sounds just enough like "go back to writing unstructured copy-paste spaghetti" to trigger some people's kneejerk. But the ground rules of "don't take subroutines, don't jump backwards" actually keep it from getting too far out of control, because they align you towards code that only uses enough flexibility for the task at hand, hence there's a lower likelihood of missing something. Very good practice for greenfield code where you might reflexively add a generalization that you don't use. I can still get better at it.<p>Edit: And one of the most important things it taught me, is that I can use scope blocks and a comment instead of a function, and it'll be sufficient.</p>
]]></description><pubDate>Sat, 10 Jun 2017 06:03:28 +0000</pubDate><link>https://news.ycombinator.com/item?id=14526341</link><dc:creator>buzzybee</dc:creator><comments>https://news.ycombinator.com/item?id=14526341</comments><guid isPermaLink="false">https://news.ycombinator.com/item?id=14526341</guid></item></channel></rss>