• r00ty@kbin.life
    link
    fedilink
    arrow-up
    3
    ·
    20 hours ago

    Maybe c# has similar. There’s \r\n or \n like c++ and Environment.NewLine.

    Probably it’s similar in that Environment.NewLine takes into account the operating system in use and I wonder if endl in c++ does the same thing?

    • vithigar@lemmy.ca
      link
      fedilink
      arrow-up
      3
      ·
      13 hours ago

      C# also has verbatim strings, in which you can just put a literal newline.

      string foo = @"This string 
      has a line break!";
      
    • unalivejoy@lemm.ee
      link
      fedilink
      English
      arrow-up
      17
      ·
      23 hours ago

      Just because the box says something is flushable doesn’t mean you should flush it.

    • mmddmm@lemm.ee
      link
      fedilink
      arrow-up
      19
      ·
      20 hours ago

      It’s a very C++ thing that the language developers saw the clusterfuck that is stream flushing on the kernel and decided that the right course of action was to create another fucking layer of hidden inconsistent flushing.

  • palordrolap@fedia.io
    link
    fedilink
    arrow-up
    3
    arrow-down
    1
    ·
    23 hours ago

    If endl is a function call and/or macro that magically knows the right line ending for whatever ultimately stores or reads the output stream, then, ugly though it is, endl is the right thing to use.

    If a language or compiler automatically “do(es) the right thing” with \n as well, then check your local style guide. Is this your code? Do what you will. Is this for your company? Better to check what’s acceptable.

    If you want to guarantee a Unix line ending use \012 instead. Or \cJ if your language is sufficiently warped.

  • Sibbo@sopuli.xyz
    link
    fedilink
    arrow-up
    3
    ·
    23 hours ago

    Wasn’t this {fmt} library merged into STL now? Does this solve this issue?

    Anyways, there was also a constant that is the OS line ending without a flush, right?

    • Fonzie!@ttrpg.network
      link
      fedilink
      arrow-up
      1
      ·
      6 hours ago

      For me the answer is “Building backend applications with it instead of CLI applications, like Lerdorf intended.”

      But also "\n" because it’s easier and PHP_EOL is just an alias for "\n"; it’s not even platform-dependent.

      • Rikudou_Sage@lemmings.world
        link
        fedilink
        arrow-up
        1
        ·
        5 hours ago

        PHP_EOL depends on your host system, it’s \r\n on Windows.

        I don’t really want to use what Lerdorf intended, PHP <= 4 was horrible, 5.x was mainly getting slowly rid of nonsense and with 7.x PHP started its slow path of redemption and entered its modern era.

        While Lerdorf’s vision was great at that time for its intended use case, I wouldn’t want to build anything serious in it.

        • Fonzie!@ttrpg.network
          link
          fedilink
          arrow-up
          1
          ·
          5 hours ago

          It actually outputs "\n" on a Windows system, but modern Windows to recognise that as enough of a newline, nowadays.

          I don’t really want to use what Lerdorf intended, PHP <= 4 was horrible

          Actually a great point!

  • Oinks@lemmy.blahaj.zone
    link
    fedilink
    English
    arrow-up
    3
    ·
    edit-2
    11 hours ago

    I am very sorry to remind everyone about the existence of Visual Basic, but it has:

    • VbCrLf
    • VbNewLine
    • ControlChars.CrLf
    • ControlChars.NewLine
    • Environment.NewLine
    • Chr(13) & Chr(10)

    And I know what you’re asking: Yes, of course all of them have subtly different behavior, and some of them only work in VB.NET and not in classic VB or VBA.

    The only thing you can rely on is that “\r\n” doesn’t work.

  • pelya@lemmy.world
    link
    fedilink
    arrow-up
    21
    ·
    edit-2
    22 hours ago

    printf is superior and more concise, and snprintf is practically the only C string manipulation function that is not painful to use.

    Try to print a 32-bit unsigned int as hexadecimal number of exactly 8 digits, using cout. You can do std::hex and std::setw(8) and std::setfill('0') and don’t forget to use std::dec afterwards, or you can just, you know, printf("%08x") like a sane person.

    Just don’t forget to use -Werror=format but that is the default option on many compilers today.

    C++23 now includes std::print which is exactly like printf but better, so the whole argument is over.

    • SqueakyBeaver@lemmy.blahaj.zone
      link
      fedilink
      arrow-up
      1
      ·
      9 minutes ago

      I went digging in cppref at the format library bc I thought c++20 or c++23 added something cool.

      Found std::print and was about to reply to this comment to share it bc I thought it was interesting. Then I read the last sentence.

      Darn you and your predicting my every move /j

  • ulterno@programming.dev
    link
    fedilink
    English
    arrow-up
    6
    ·
    edit-2
    1 hour ago

    Simple. \n when you just want a newline.
    endl when you need to flush at the moment.

    Useful in case you are printing a debug output right before some function that might do bed stuff to buffers.


    Edit: I wrote println instead of endl somehow. Guess I need more downtime