27 comments

  • Eufrat 1 hour ago
    IMHO, this is an actual good use of what sounds like a person guiding a model to do a mass conversion. Although, I wish the porting docs were a little wordsmithed by a human, the AI generated text style is grating.

    The stakes are low, it’s mostly for fun and you can iterate on it. Compare this with Bun which was just like, “hey we converted everything to Bun to Rust from Zig, of course it works, what could possibly go wrong, I’ll totally write up a blogpost (that still doesn’t exist) explaining what we did, you can put this into your production environment soon!”

    • johnfn 1 hour ago
      I don't really get the Bun thing. Bun is running Claude Code which is probably the single most actively used development app there is. You say this was a bad use of LLMs, but it's been in production for a while and I haven't heard of any evidence that Claude Code has increased a significantly larger quantity of errors, segfaults, etc, than before.
      • Eufrat 52 minutes ago
        Some people, myself included, think that announcing a conversion from Rust to Zig as an experiment then jumping to putting it in the alpha train for public testing/consumption without any real explanation in the span of around 2 weeks is irresponsible and reckless.

        Blogposts were promised, details were hinted, but no, it’s just full steam ahead because the AI worked so well. The converted unit tests all worked, all the synthetic tests are okay, so what are you complaining about?

        At some point, it’s less about the technical questions and more about getting that pesky human buy-in.

        • johncolanduoni 14 minutes ago
          What does Bun’s governance look like? Now that Anthropic bought the company are there significant external contributors that would expected to have input on a decision like this?
      • qsort 58 minutes ago
        I agree that the Bun rewrite is much more reasonable than knee-jerk reactions imply, however:

        - I don't think Claude Code is using the Rust version yet in their official build

        - Claude Code is not a particularly complicated piece of software from an engineering perspective (nor it's particularly well-engineered, at least at the moment).

        So in my book "it runs Claude Code" would be pretty weak evidence that the rewrite is going to be successful (the tests they've done are much better evidence, but that's a topic for another time).

      • gpm 1 hour ago
        > it's been in production for a while

        Huh... it looks to me like bun has yet to cut a release post Zig->Rust port (the latest one on github is still on a branch that says it's written in zig in the readme). I assume that nothing is using the rust version yet...

        Which also cuts against the complaints about "of course it works [...] you can put this into your production environment soon!" since they don't seem to be asserting either of those things.

        • Eufrat 48 minutes ago
          The real problem is they explained nothing and just caused a lot of mistrust. The lead developer at Bun working on this project does post here from time to time and I have never seen him answer any of this. I admire his enthusiasm, but this was badly handled mostly from Bun’s side which lead to a bunch of dogpiling.

          When someone on another social media platform commented expressed some concern, his response was to ask him what the explicit bug he was talking about was and that he would generate a fix. That sound you hear is the woosh as the point flies by. And in general, this just feels like a consistent problem with Bun.

      • MuffinFlavored 1 hour ago
        > Yes, Claude Code uses Bun. In fact, Claude Code relies on it as a core dependency and ships as a self-contained Bun executable.

        I... somehow did not know that.

        • stymaar 1 hour ago
          You missed the day when they had their bun build misconfigured which ended up leaking the entirety of Claude Code's codebase? (I wish I was joking)
  • delichon 5 minutes ago
    I was bitching here the other day about GTA VI being locked down so I can't pass it on like a favorite book. But maybe if I just archive the whole package, a not-so-distant-future-ai will be able to rehydrate it onto any handy future platform at low cost.
  • namuol 2 hours ago
    > Built on EA's GPL v3 source release via fbraz3/GeneralsX (which did the heavy lifting of the macOS/Linux port — this fork adds the iOS/iPadOS port and a set of engine fixes).
    • asronline 2 hours ago
      I have a Renegade one going that does all of this from scratch (different engine) so it's def more than capable!
    • hypercube33 28 minutes ago
      This needs a backport to Winx64 since this game runs like crap on modern windows
  • xg15 1 hour ago
    > (tap-select, drag-box, long-press deselect, two-finger scroll, pinch zoom)

    This is another "AI-ism" I noticed, mostly in coding agents - they seem to be very fond of making up new "compound nouns" (and occasionally verbs) to sum up relatively complex and specific concepts into single noun phrases. I wasn't sure if it's to save tokens or if the AI uses this to get a concise "identifier" for a concept that it can refer back to later, but I found it very noticeable.

    I find the resulting sentences hard to read, though it does get better if you're aware of that tendency and make a conscious effort to parse the noun phrases. But I guess since it's just intermediate output from coding agents and not text for essays or blog posts, it's fine.

    • shibel 3 minutes ago
      I’m (sorry for the lack of humbleness) a very fluent non-native speaker and writer, and this is by far my biggest challenge with Claude. It stitches together 2-4 advanced concepts into one or two words and I always have to ask it to “unpack”.

      I don’t think it’s easy on native speakers when it happens, but it’s even harder when you’re not.

    • marginalia_nu 1 hour ago
      Haha, I do that too sometimes.

      It's a thing in some Germanic languages. Instinct is to merge nouns into word, e.g. 'lawnchair', but that gives you a red squiggly line, but 'lawn chair' also looks wrong, so 'lawn-chair' is the middle ground.

    • trentor 1 hour ago
      Maybe LLMs are just Germans.
    • f3408fh 1 hour ago
      Yes! It's infuriating. I've tried prohibiting them in my AGENTS.md but it's not 100% effective.

      --- AGENTS.md ---

      ## Plain words, not jargon

      Don't use jargon-as-shorthand. Say what you actually mean.

      - Don't say "load-bearing assumptions". Say "the assumptions the xyz depends on".

      - Don't say "cross-service". Name both services, e.g. "whether the X service can derive duration without calling the Y service". "Cross-X" is confusing because it hides which things are involved.

      - Don't deliver verdicts as abstract noun-phrases like "Cross-RCA double-counting is unfounded". Say it plainly: "I checked whether the same root cause gets counted twice across RCA runs, and it doesn't."

      ## No earth-shattering declarations

      Don't hype findings. Skip "a critical finding changes everything", "now I have the full picture", "this changes the game", etc. Just state what you found plainly. Most findings are ordinary; report them that way.

      ## Don't reflexively hedge a "yes"

      When the answer is yes, say yes. Don't soften every positive answer with a caveat: it erodes confidence in the "yes". Only add a caveat when there's a genuine, specific uncertainty worth flagging.

      • skerit 1 hour ago
        I thought it was just Opus 4.7 and 4.8 that did this. Do other models do this too?

        Anyway: in my case Opus absolutely did not follow a similar instruction in the CLAUDE.md file. (But then again: it hardly followed _any_ CLAUDE.md instruction properly)

        • embedding-shape 1 hour ago
          It's stupid, but have you tried telling it to follow it? "Make sure to follow the guidelines from AGENTS/CLAUDE.md" etc, seems to (sadly) make some difference in most harnesses and models.
        • futuraperdita 28 minutes ago
          For me, Opus 4.8's thinking traces for the chatbot will sometimes willingly ignore instructions, saying something along the lines of "I've noticed an instruction in the system instructions that states I shouldn't do this, but if I don't do this, I'll not provide the answer the user is looking for. I will ignore that instruction."
        • mikeryan 54 minutes ago
          In all my CLAUDE.md and AGENTS.md files I have a line to fix pre-existing issues. I don’t know what it is but every agent I’ve tried through Claude code (including deepseek and GLM) will actively try to avoid fixing pre-existing issues. I even added hooks to Claude and git to try to get them fixed. If I leave a bailout for myself agents will find it sit and ask if it can push with no-verify or an environment variable in the case of Claude hooks instead of trying to fix an issue it didn’t cause.
      • xg15 1 hour ago
        Yeah, I wonder if part of the reasoning is built around those phrases, and therefore it can't get rid of them easily.

        > "now I have the full picture"

        I always interpreted that phrase as a sort of marker to delimit the phase in which it explores the codebase and gathers information from the phase in which it implements the changes.

        Not sure if it's still done, but I think some months ago there was discussion that some of the phrases are injected by the inference loop to "steer" the model - e.g. "But wait" if a thought block was too short etc. Obviously such phrases couldn't be influenced by the prompt.

      • lostlogin 1 hour ago
        > Yes! It's infuriating.

        No, it’s good. When they stop doing this, it’ll be harder spot the machine slop.

    • jorl17 1 hour ago
      Excessive-hyphenization is ai-hyperfixation
    • rossant 39 minutes ago
      That, and also the very long comma-separated lists with sometimes 10+ items.
    • topgrain2 1 hour ago
      That’s… about how I might have written that.
    • mikeryan 59 minutes ago
      That and finishing a statement with an em dash — that’s what AI does.
    • daveguy 1 hour ago
      FYI, AI isn't fond of a goddamn thing. They have token prediction quirks that don't follow typical English.
      • ben_w 5 minutes ago
        Few ever cared. Find one non-pedant who would object to the personification that follows:

          "The evening settled over the city, drawing the light out of the streets one corner at a time. Windows blinked awake with lamplight, and the wind moved through the alleys restlessly, leaves brushing against walls before gathering themselves along the pavement. In the distance, the river kept its steady argument with the stone embankments. When the night pressed in, the weather became increasingly angry, until it was a raging storm."
        
        In the affective sense, evenings don't settle, and street lights are not drawn out, windows don't blink, and wind isn't restless. Weather can neither be angry, nor rage.

        But such personification is a natural part of how the English speak.

      • sawjet 32 minutes ago
        Personification is a figure of speech. What you say is technically correct but we don't need to declare this every time humans discuss how LLMs work.
  • evanjrowley 2 hours ago
    I wanna know if these techniques would be useful for Emperor: Battle for Dune (2001). It's the first 3D RTS by Westwood Studios, predating C&C Generals by just a couple years. It's popularity was hampered by intellectual property disputes and a introduction of a new faction that diverged from the book series lore. The gameplay, soundtrack, and campaign missions were awesome.
    • satvikpendem 1 hour ago
      Try it before July 7 when Fable disappears from Claude Code subscription pricing.
    • farseer 1 hour ago
      This was one of the best RTS of the era. Still holds up today. The music was also very good.
    • asronline 2 hours ago
      Let me give it a go :)
      • DANmode 59 minutes ago
        Legend in the pub.
      • gb2d_hn 1 hour ago
        Came here to see if anyone mentioned Dune Emperor. Would love to see someone succeed
    • SubiculumCode 1 hour ago
      • farseer 11 minutes ago
        No, this was a far superior sequel to Dune 2000.
    • kriro 1 hour ago
      I loved this game. First RTS I ever played :)
  • dools 1 hour ago
    How is it done "using Fable" when the first commit was Feb last year??
    • debugnik 11 minutes ago
      He forked GeneralsX and added just the last few commits.
    • Dfiesl 1 hour ago
      Probably not exclusively using Fable.
      • dools 1 hour ago
        Yeah which is a bit underhanded. Because the implication of "using Fable" is that it was done in under ... a week? So it's just a bit of click bait.
        • janalsncm 39 minutes ago
          For that to be click bait it implies people wouldn’t have clicked on it if any other model were used. IMO the more interesting fact is they ported a game over to iOS.
          • dools 23 minutes ago
            I dunno... Command and Conquer ported to macOS/iPad in 18 months using AI coding agents probably wouldn't have the same ring to it
        • Madmallard 50 minutes ago
          That's nearly every single article on the front page of HN nowadays
  • siva7 1 hour ago
    no way fable did this. It would have stopped after the words "command and conquer" and nerfed you to opus (while also landing you on some nsa watch list)
  • OsrsNeedsf2P 2 hours ago
    I'm doing something similar, using AI to make Battle for Middle Earth (same engine) "open source" with AI: https://github.com/dginovker/BFME-Source-Code
    • skerit 1 hour ago
      I've been doing something similar for some of my favourite older games. But the "byte for byte" claim has me worried. Isn't simply decompiling the sourcecode from the binary and releasing that problematic?

      It's not the "clean room" approach and companies could still claim it violates some kind of copyright and get it taken down.

    • asronline 2 hours ago
      Sweet!!
    • amcoastal 2 hours ago
      [dead]
  • wewewedxfgdf 15 minutes ago
    This is one of the best of Command and Conquer games.
  • bel8 33 minutes ago
    Title is click bait.

    This started back in February and looking at commits, Fable did only a small part of the latest commits. 19 commits out of 2000:

    https://github.com/ammaarreshi/Generals-Mac-iOS-iPad/commits...

    And maybe it wasn't even Fable, they might have downgraded to Opus.

    This is the kind of frequent misinformation that makes me skeptical of Anthropic LLM claims. Whenever I compare them to GPT 5.5 on my web dev workflows, they seem to trade blows, even Fable, which I started testing since it was re-enabled.

    Also I bet any decent LLM could have done such port. Think GLM 5.2 or similar which would probably work better because it doesn't constantly try to guess if I'm a terrorist trying to hack goverments or develop some biological weapon.

    People just don't have the resources to compare LLMs and imply whatever they used is the best thing ever and unlocked some new workflow.

    I have seen little improvement since Opus 4.6.

    • varenc 5 minutes ago
      This project is a fork and all it does is add iOS support. Commits by the repo fork owner begin 19 hours ago, so very plausible those are done with Fable. Agreed it's a bit deceptive though, since the headline makes it seem like Fable (or some LLM) did the whole thing, where really it just added iOS support. (which admittedly is non-trivial)
  • arikrahman 20 minutes ago
    Finally, I can play Zero Hour everywhere
  • pjmlp 54 minutes ago
    In the old days this would have required a proper team...
  • HaloZero 1 hour ago
    Is there any hope for Red Alert 2?
  • brailsafe 45 minutes ago
    I wonder if this will work on my iPad 3, maybe with some Swift... 3 backport code?
  • ChrisMarshallNY 1 hour ago
    Very cool.

    One big caveat with iPad and mobile, though, is battery usage. I strongly suspect that power consumption is the reason that a number of games made it to Mac, but not iPad.

  • 8note 1 hour ago
    ive had opus try movin Merlin's revenge up from director/shockwave.

    the result: http://jhedin.github.io/merlin-s-revenge/

    reasonably it works quite close to the lingo, but this is way difficult, and not just from being rusty. steve had most things triggered on the animation frame, which opus hasnt quite figured out by looking at the code and pulling stuff out of the .dir

    i do remember that playing at double scale was a lot harder in general, but theres a really clear cooldown missing between attackes

  • OsrsNeedsf2P 1 hour ago
    I just noticed a Flatpak folder in the repo. Does MacOS Support Flatpak somehow??
  • bigyabai 2 hours ago
    > rendering DirectX 8 → DXVK → Vulkan → MoltenVK → Metal

    Another great case study in why native Vulkan drivers would be a boon for Apple's mobile computing. That's quite the render pipeline...

  • vaygr 1 hour ago
    Tiberian Sun next.
  • gigatree 2 hours ago
    This is an actual dream come true
  • advenn 2 hours ago
    someone do it for debian, omg. i use debian family, it has been years, i haven't played this gem
    • asronline 2 hours ago
      I can't tell you how many new hours I've poured in it since bringing it to my iPad
    • akho 2 hours ago
      fbraz3/GeneralsX
  • Jyaif 1 hour ago
    I tell folks there's a chance GTA6 will be ported to PC before it's officially released to PC.
  • Madmallard 1 hour ago
    Does it actually play identically or is there going to be weird bugs all over the place?

    Seems like an impossible ask to verify if you don't have an immense test suite that covers everything.

  • asronline 2 hours ago
    EA released the Generals source under GPL v3, the GeneralsX project got it running on macOS/Linux, and I've taken it the rest of the way: native iOS and iPadOS builds of Zero Hour, plus Apple Silicon macOS.

    What works (all verified on a real iPad and iPhone):

    Campaign, Skirmish, and Generals Challenge: full missions, objectives, cutscenes, saves All audio: music, unit voices, EVA announcements, Challenge taunts, briefing FMVs Touch controls built for RTS: tap select, drag a selection box, long-press deselect, two-finger camera pan, pinch zoom Self-contained install: game data ships inside the app bundle It's the real engine: unmodified game logic compiled for ARM64, rendering DirectX 8 → DXVK → Vulkan → MoltenVK → Metal. Not emulation, not streaming.

    No game assets are included or distributed. You need your own copy (Steam sells Zero Hour) and a script pulls the data from your own account. Code is GPL v3.

    Repo, with a full engineering log of every bug and fix (the black-minimap one is a 2003 texture-format fallback that ate the alpha channel; worth a read if you like archaeology): https://github.com/ammaarreshi/Generals-Mac-iOS-iPad/blob/ma...

    Building: macOS is about four commands; iPhone/iPad needs Xcode and a free Apple developer account since you sideload your own build. Known issues (long-session memory on iPad, a rare backgrounding crash) are documented in the README.

    Credit: fbraz3/GeneralsX did the heavy macOS/Linux lifting, TheSuperHackers keep the community codebase alive, and EA did a genuinely good thing releasing the source. The engine fixes I found are heading upstream so every platform benefits.

    (And of course, not affiliated with or endorsed by EA, and sorry China had to deal with all of those particle cannons in that demo video)

    • debugnik 15 minutes ago
      You take credit for porting it to "Apple Silicon" macOS, both here and in the title, but that already seems to work upstream? On a quick look I didn't see any commit message of yours addressing macOS rather than iOS. What exactly did you add there?
    • digitalbase 1 hour ago
      Great stuff

      I found the bundle scripts already prefer VULKAN_SDK/VULKAN_SDK_ROOT, but the build script only scans ~/VulkanSDK

    • DANmode 23 minutes ago
      Don’t worry - China inf is for noobs

      https://youtu.be/WqWFYOxjZ54?si=1pH6Z1D33TOT4Qmg&t=453

    • 8note 1 hour ago
      nice!
  • slipperybeluga 1 hour ago
    [dead]
  • baq 2 hours ago
    When someone ported pylint to rust this place was full of ‘who will maintain this’ and met with blank stares when the answer was ‘what do you mean’ or ‘it’ll maintain itself’.

    Good job. It was inevitable, but still someone had to, please excuse me, say the words.

    • fnordpiglet 1 hour ago
      Given the game is stable and the changes would be at the integration points, and Fable was able to do the direct integration, why would the answer not be “it’ll maintain itself” at some abstract level. The decision to maintain open source is up to the maintainers and I think the answer is “no one” 99.99% of the time, but I’ll wager if someone is willing to spend the tokens on it, a CI reintegration agent would do just fine in keeping it working as the underlying dependencies have required changes (which would really be only major changes in apple apis that aren’t backwards compatible.”

      Pylint is different because it’s working against a necessarily dynamic wavefront that it has to keep parity with as it advances. All python changes, ecosystem adaptations, etc - and maintaining that with an AI harness in CI would never work. It would require a concerted effort and thought along the way.

      So it’s sort of a different beast all together. In fact I think this is a great demonstration of using AI to resurrect technology built for X to work with Y, where X is dead and Y is current. Automating this feels like a net positive and because the original software is “finished” there isn’t decision making and strategy required.

    • arjie 1 hour ago
      These LLMs are remarkable. I used Opus to revive for myself abandoned software and bring it up to date with the latest versions of the frameworks so I could add some features. And there's other software which I vendor and merge in upstream changes and self-manage. This would have been a near-impossibility in the past.

      "Who will maintain this?" appears to be "Me with an agent". And it's great.

    • adamraudonis 1 hour ago
      That was me! Checkout my latest Fable project with 4D splats: https://news.ycombinator.com/item?id=48786245