bloomberg/bde

Compilation error on latest master

tcanabrava opened this issue · 7 comments

/home/tcanabrava/Projects/bde/groups/bal/balb/balb_controlmanager.cpp: In member function ‘void BloombergLP::balb::ControlManager::printUsage(std::ostream&, const std::string_view&) const’:
/home/tcanabrava/Projects/bde/groups/bal/balb/balb_controlmanager.cpp:142:32: error: ‘endl’ is not a member of ‘bsl’; did you mean ‘end’?
  142 |     stream << preamble << bsl::endl;
      |                                ^~~~
      |                                end

Cannot reproduce. compiler and ufid to see the build failure?

hard to believe the error as bsl_iostream.h was there for last 7 years.

I don't know what to say to you...

➜  bde git:(master) /home/tcanabrava/Projects/bde-tools/bin/bde_build_env.py list  
Available compilers:
 0: gcc-12.1.0 (default)
     CXX: /usr/bin/g++
     CC : /usr/bin/gcc
     Toolchain: gcc-default
 1: clang-13.0.1 
     CXX: /usr/bin/clang++
     CC : /usr/bin/clang
     Toolchain: clang-default

➜  bde git:(master) ✗ eval `bde_build_env.py --build-type=Release 
--cpp-std=17`
➜  bde git:(master) ✗ cmake_build.py configure
➜  bde git:(master) ✗ cmake_build.py build
...

/home/tcanabrava/Projects/bde/groups/bal/balb/balb_controlmanager.cpp: 
In member function 'void 
BloombergLP::balb::ControlManager::printUsage(std::ostream&, const 
std::string_view&) const':
/home/tcanabrava/Projects/bde/groups/bal/balb/balb_controlmanager.cpp:142:32: 
error: 'endl' is not a member of 'bsl'; did you mean 'end'?
   142 |     stream << preamble << bsl::endl;
       |                                ^~~~
       |                                end
/home/tcanabrava/Projects/bde/groups/bal/balb/balb_controlmanager.cpp:149:23: 
error: 'endl' is not a member of 'bsl'; did you mean 'end'?
   149 |               << bsl::endl;
       |                       ^~~~
       |                       end

It could be a compiler bug, I manually removed bsd::endl to std::endl to make things work.

Github's emailed version of your last comment only included the first line, @tcanabrava, which sounds like a bad bug on github's part. The message sounds much better when you read the rest of it :)

What platform are you on? I see it would have picked gcc-12.1.0 there, but what OS and version and/or Linux distro
and version are you using?

Thanks!

I would wager this is the issue:
https://github.com/bloomberg/bde/blob/master/groups/bsl/bsl%2Bbslhdrs/bsl_iostream.h#L43

I.e., this file is relying on an include of bsl_iostream.h to make bsl::endl available, and that is dependent in some way on language version. I'm not sure what in the environment is causing the difference between our internal c++17 builds -- but we also haven't tested with gcc-12.

Actually, that should still be available through the transitive include of bsl_ostream.h, so I'm back to being confused....

Think we'll need more information to try and reproduce.

My current system:

Arch Linux 
➜  build git:(master) uname -a
Linux tcanabrava-laptop 5.17.8-arch1-1 #1 SMP PREEMPT Mon, 16 May 2022 20:45:27 +0000 x86_64 GNU/Linux
➜  build git:(master) ccache --version
ccache version 4.6

I have not invested too much time trying to solve this issue properly, but I have managed to get the build working in another system with the same compiler. So it could be a small difference in my system because of the different compilers installed (gcc, clang - from - package, self-compiled clang).

now, for my system I have included bsl_ostream.h directly and that seemed to solve the issue.

All the best.