Skip to content

Conversation

@maloel
Copy link
Contributor

@maloel maloel commented May 24, 2023

The viewer has a setting:
image
The default is to log to console, minimum level Warning.

This did nothing in Windows. It does not affect the Debug Console Window in the Viewer.

This changes:

  • When turned on, it will attempt to connect to a parent console
    • if run from a console, the console will show logs
    • if run from GUI (or GUI debugger), a console window will not open
  • Added rsutils function to ensure_console() which we now use when calling log_to_console
  • Fixed the code so it will turn OFF console output if the user unchecks this box (it left it on before!)

NOTE that I had to make this work in both Shared and Static builds. In the former, anything outside of librealsense will not affect the librealsense logs - so I had to place the console-opening inside librealsense (originally it was only in the Viewer).

@maloel maloel requested a review from Nir-Az May 24, 2023 06:34
config_file::instance().set_default(configurations::viewer::is_measuring, false);
config_file::instance().set_default(configurations::viewer::log_to_console, true);
config_file::instance().set_default(configurations::viewer::log_to_console,
#ifdef WIN32
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks like bad alignment.
I suggest

auto default_log_to_console = true;
// In Windows, there is no console by default
#ifdef WIN32
  default_log_to_console = false;
#endif
config_file::instance().set_default(configurations::viewer::log_to_console, default_log_to_console );

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'll change

src/log.h Outdated
void log_to_console(rs2_log_severity min_severity)
{
if( min_severity != RS2_LOG_SEVERITY_NONE )
rsutils::os::ensure_console();
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Did you test how python on Windows behave with this code?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Everything behaves the same -- python is usually started from a console.
Only thing new is that, if there is no console, a new window will pop up (on Windows).

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

👍

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

One thing we could do is create a console if the build is a debug build, with the idea being that, when debugging, you do want to see the debug in a separate window...

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think the current implementation is better.
Let's not surprise the users.

@maloel maloel merged commit 773d3d4 into IntelRealSense:development May 25, 2023
@maloel maloel deleted the development branch May 25, 2023 07:48
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants