On Saturday, the ISO C++ committee completed the second-last design meeting of C++26, held in Hagenberg, Austria. There is just one meeting left before the C++26 feature set is finalized in June 2025 and draft C++26 is sent out for its international comment ballot (aka “Committee Draft” or “CD”), and C++26 is on track to be technically finalized two more meetings after that in early 2026.

  • FizzyOrange@programming.dev
    link
    fedilink
    arrow-up
    0
    ·
    2 months ago

    Hardened standard library is going to make the times when I am forced to use C++ a lot more pleasant. Does anyone know how you will enable it? I think it’s pretty much guaranteed that they’re not going to take the sensible route of making it opt-out, and if it’s too difficult to enable nobody is going to bother.

    • lambalicious@lemmy.sdf.org
      link
      fedilink
      English
      arrow-up
      1
      ·
      1 day ago

      I think it’s pretty much guaranteed that they’re not going to take the sensible route of making it opt-out,

      Because that’s not the sensible route in the future, whether we like it or not. Hardened STL is being announced in the papers as “we are going to start with these silly one-line fixes that in theory should perturb no one, but as we iterate over this we’re gonna start breaking things”, which is not what you want to hear from the default.

      One good example: placing enforced bounds check into the operator[] of std::array<> of all places. People keep telling me that I should be using std::array instead of normal C arrays, but then punish me for using std::array? That ends up making people revert to the True Old Ways That Work (aka: C arrays).

      • FizzyOrange@programming.dev
        link
        fedilink
        arrow-up
        2
        ·
        1 day ago

        Bounds checks are not punishing you. Obviously the right way to do this would be to make operator[] be bounds checked by default but only if you use -std=c++29 or whatever, and then also add a .at_unchecked() method for when you want to opt out of the bounds checks.

        • lambalicious@lemmy.sdf.org
          link
          fedilink
          English
          arrow-up
          1
          ·
          5 hours ago

          .at_unchecked()

          What kind of barbarism is that?

          Doing that kind of split would kill genericity (more than it already is). If I’m using [] is because what I want is, more or less, to just access the value; not to maybe randomly and without any kind of source-level control or projected time/space boundaries go to the blockchain to check if the Rust devs are in the mood today to have blessed the given statement with the arguments given.

          Frick. At least give me something like [checked(5)] or [unchecked(5)] for a more natural syntax. The more considering it has been possible to add compile-time checked access with something like [integral_constant<size_t,5>{}] since at least C++03! It just needs someone to propose a standardized notation shortcut. Or if there was some way to inquire or static_assert that the checks on the natural syntax are actually elided if I’m doing them myself elsewhere. But at it stands, uglifying the syntax is the worst of all worlds.

          • FizzyOrange@programming.dev
            link
            fedilink
            arrow-up
            1
            ·
            3 hours ago

            What on earth are you talking about? I honestly can’t even understand what objection you’re trying to make.

            Wait, wait! Are you under the impression that .at() is a function call and operator[] is …not? What?

    • Paul@feddit.dk
      link
      fedilink
      English
      arrow-up
      1
      ·
      1 month ago

      One of the reasons they got through with it is that the big three already has it, so I guess… Update and read the documentation of your compiler of choice?