• T. Hex@lemmy.dbzer0.com
    link
    fedilink
    arrow-up
    4
    ·
    2 years ago

    Can’t call it Windows 9

    But that actually made sense! They care about backwards compatibility.

    For those not in the know: some legacy software checked if the OS name began with “Windows 9” to differentiate between 95 and future versions.

    • dan@upvote.au
      link
      fedilink
      arrow-up
      1
      ·
      edit-2
      2 years ago

      some legacy software checked if the OS name began with “Windows 9” to differentiate between 95 and future versions.

      This is a myth. Windows doesn’t even have an API to give you the marketing name of the OS. Internally, Windows 95 is version 4.0 and Windows 98 is 4.1. The API to get the version returns the major and minor version separately, so to check for Windows 95 you’d check if majorVersion = 4 and minorVersion = 0.

      Edit: This is the return type from the API: https://learn.microsoft.com/en-us/windows/win32/api/winnt/ns-winnt-osversioninfoexa

      • T. Hex@lemmy.dbzer0.com
        link
        fedilink
        arrow-up
        1
        ·
        2 years ago

        Maybe it’s a myth, but it sure sounds plausible. The software that checks the “Windows 9” substring doesn’t even have to exist for this to be reason they chose to skip to version 10 — they just had to be concerned that it might exist.

        Sure, maybe there’s no C function that returns the string, but there’s a ver command. It would be trivial to shell out to the command. https://en.wikipedia.org/wiki/Ver_(command)

        This doesn’t prove anything, but there are a TON of examples of code that checks for the substring. It’s not hard to imagine that code written circa 2000 would not be future proof. https://sourcegraph.com/search?q=context:global+“\“windows+9\””&patternType=keyword&sm=0

        • dan@upvote.au
          link
          fedilink
          arrow-up
          1
          ·
          2 years ago

          but there are a TON of examples of code that checks for the substring

          oh

          oh no

          There’s code in the JDK that does that??

          I really wish I didn’t see that.

            • dan@upvote.au
              link
              fedilink
              arrow-up
              1
              ·
              2 years ago

              I’ve been a software developer for 20 years and this comment is too real. Some days I’m amazed that any software even works at all.

              • intensely_human@lemm.ee
                link
                fedilink
                arrow-up
                1
                ·
                2 years ago

                Having worked in both food service and software, I encourage you not to visit the kitchen of any restaurants you enjoy either.

    • puttputt@beehaw.org
      link
      fedilink
      arrow-up
      1
      ·
      2 years ago

      The reason they checked that it started with “Windows 9” was because it worked for “Windows 95” and “Windows 98”

      • Wrrzag@lemmy.ml
        link
        fedilink
        arrow-up
        1
        ·
        2 years ago

        Because it checks if the version starts with the string “Windows 9*”, not wether the number is less than 9.

    • activ8r@sh.itjust.works
      link
      fedilink
      arrow-up
      0
      ·
      2 years ago

      It makes sense why they did it, but their messed up versioning was the cause to begin with. You should always assume Devs will cut corners in inappropriate ways.

          • Octopus1348@lemy.lol
            link
            fedilink
            arrow-up
            1
            ·
            2 years ago

            I once heard some YouTuber say Windows uses \ in path names instead of / like everyone else because Microsoft thinks backwards.

            • dan@upvote.au
              link
              fedilink
              arrow-up
              4
              ·
              2 years ago

              As what often happens, using \ for paths is for backwards compatibility.

              Neither CP/M nor MS-DOS 1.0 had folders. When folders were added in MS-DOS 2.0, the syntax had to be backwards compatible. DOS already used forward slashes for command-line options (e.g. DIR /W) so using them for folders would have been ambiguous - does that DIR command have a /W option, or is it viewing the contents of the W directory at the root of the drive? Backslashes weren’t used for anything so they used them for folders.

              This is the same reason why you can’t create files with device names like con, lpt1, and so on. DOS 2.0 has to retain backwards compatibility with 1.0 where you could do something like TYPE foo.txt > LPT1 to send a document to a printer. The device names are reserved globally so they can work regardless of what folder you’re in.

          • Honytawk@lemmy.zip
            link
            fedilink
            arrow-up
            1
            ·
            2 years ago

            Well, better to be backwards with backwards compatibility than to just be backwards.

            looks at Apple