This does not happen with any other chromium based browser

My phone locale is set to Italian with English as second language. IP address is Italian. I’m not understanding why sites like f-droid, Google dev documentation, gitlab, are all defaulting to Chinese as I can’t read it…

Sometimes I can find a link to switch back to either English or Italian, but the next visit they revert to Chinese…

    • Wispy2891@lemmy.worldOP
      link
      fedilink
      arrow-up
      35
      arrow-down
      1
      ·
      2 months ago

      Cool site!

      Now I know what’s going on. I added Chinese as a third language because of a bug of an app that defaults to gibberish if it’s not specified.

      Firefox is sending

      it-IT,en-US;q=0.8,zh-Hans-CN;q=0.5,zh-CN;q=0.3

      While chromium sends

      it-IT,it;q=0.9,en-US;q=0.8,en;q=0.7,zh-CN;q=0.6,zh;q=0.5

      I checked some implementations of the check and some of them are bugged and assume that the language tag has only one hyphen. So they read zh-Hans-CN;q=0.5 and instead of understanding it as “priority 0.5 for zh-Hans-CN”, they understand it as “maximum priority for zh-Hans and priority 0.5 for CN”

      Screenshot of wrong parsing for the string sent by Firefox (the chromium one is parsed correctly)

      screenshot of a software error

      Now what to do… It’s impossible to contact Google to fix their implementation of language detection…

      • BananaTrifleViolin@lemmy.world
        link
        fedilink
        English
        arrow-up
        7
        ·
        2 months ago

        Can you remove zh-Hans-cn from Firefox and just keep zh-cn?

        Zh-Hans is redundant here - it is for simplified Chinese, while zh-Hant would be used for traditional chinese. But both are not well implemented and usually people only use the country codes. Zh-cn is already simplified Chinese. Zh-TW (for Taiwan) is often used to cover traditional chinese.

        It’d be interesting to see if you get the same bug if zh-hans-cn is added to chrome, as it seems its the actual language tag that is causing the issue and possibly not related to the specific browser at all.

      • merdaverse@lemmy.zip
        link
        fedilink
        arrow-up
        5
        ·
        edit-2
        2 months ago

        It’s impossible to contact Google to fix their implementation of language detection…

        What do you mean by this? If the site parses the header incorrectly and displays a wrong language, then it’s a bug of the website, not the browser. You also said that chromium sends headers that are parsed correctly.

        • Wispy2891@lemmy.worldOP
          link
          fedilink
          arrow-up
          6
          arrow-down
          1
          ·
          2 months ago

          I mean that Google needs to fix their android dev documentation site to parse the header correctly, and I feel very unlikely that they’re going to fix if their own browser doesn’t send an header like that and doesn’t have the problem

      • jcr@jlai.lu
        link
        fedilink
        Français
        arrow-up
        4
        ·
        2 months ago

        At last ! Thanks for sharing the results, it was feeling weird having to change anytime going on gnu.org or whatever

      • x00z@lemmy.world
        link
        fedilink
        English
        arrow-up
        2
        ·
        2 months ago

        Now what to do… It’s impossible to contact Google to fix their implementation of language detection…

        Your browser just sends the headers and doesn’t do any detection by itself, besides having a list of ‘locale to locale strings’. It’s possible that the 2 hyphens go against the official local spec. But from what I remember it does seem to be the correct locale string. So the problem would be in the implementation of the websites that display it wrong.

        • Wispy2891@lemmy.worldOP
          link
          fedilink
          arrow-up
          2
          ·
          2 months ago

          The header is parsed incorrectly on Google servers and return html in the wrong language. It’s google, f-droid , gitlab and many others that have to fix the parsing bug, which is very unlikely

          • Xatolos@reddthat.com
            link
            fedilink
            arrow-up
            4
            arrow-down
            1
            ·
            2 months ago

            At the beginning of your post, you wrote that “This does not happen with any other chromium based browser”. This would indicate that it’s a unique problem to Firefox and would in turn be a Gecko engine issue. Now, if this was an issue with other browsers, then I’d agree with you.

            • Wispy2891@lemmy.worldOP
              link
              fedilink
              arrow-up
              2
              ·
              edit-2
              2 months ago

              After investigating, it’s because chromium browsers don’t send “zh-Hans-CN” in the request header and it turns out that many server side language detection implementations are buggy.

              So, it’s not technically a Firefox bug, but, considering the minuscule share of people that are

              1. Using Firefox on Android (on desktop it can be fixed, and on iOS it’s WebKit-based)
              2. Having, at the same time, a language different than English as primary, and simplified Chinese as tertiary or less priority

              It’s extremely unlikely that hundreds of separate website owners will fix their implementation

              I’m guessing the people with this issue are in the orders of dozens, not thousands

  • Successful_Try543@feddit.org
    link
    fedilink
    arrow-up
    5
    ·
    edit-2
    2 months ago

    Have you checked the language settings of Firefox itself? (Assuming it just happens when using Firefox and not the native Browser)

    • Wispy2891@lemmy.worldOP
      link
      fedilink
      arrow-up
      3
      ·
      edit-2
      2 months ago

      on mobile the only setting available it’s for the UI language and there’s not the extensive language panel setting that is available on desktop. about:config is also missing

  • zorblitz@mander.xyz
    link
    fedilink
    arrow-up
    2
    ·
    2 months ago

    You might have chinese as one of the languages in your phone’s language settings. Try removing it