• Faresh@lemmy.ml
    link
    fedilink
    English
    arrow-up
    54
    arrow-down
    1
    ·
    edit-2
    14 days ago

    Writing it in assembly would make it pretty much the opposite of portable (not accounting for emulation), since you are directly giving instructions to a specific hardware and OS.

      • __dev@lemmy.world
        link
        fedilink
        English
        arrow-up
        12
        ·
        14 days ago

        That’s no less true than games written in C, or otherwise with few dependencies. Doom is way more portable than RCT precisely because it’s written in C instead of assembly.

      • Faresh@lemmy.ml
        link
        fedilink
        English
        arrow-up
        5
        ·
        edit-2
        14 days ago

        you’re not usually directly accessing/working on the hardware

        I mean, you are. Sure, there’s a layer of abstraction when doing tasks that require the intervention of the kernel, but you are still dealing with cpu registers and stuff like that. Merely by writing in assembly you are making your software less portable because you are writing for a specific ISA that only a certain family of processors can read, and talking with the kernel through an API or ABI that is specific to the kernel (standards like Posix mitigate the latter part somewhat, but some systems (windows) aren’t Posix compilant).