Class-ify ui_out_hdr

This patch makes ui_out_hdr (the object that represents an ui-out table
header) a proper C++ class.  No behavior changes, it's all about
encapsulation.

gdb/ChangeLog:

	* ui-out.c (struct ui_out_hdr): Replace with ...
	(class ui_out_hdr): ... this.
	(append_header_to_list): Update.
	(get_next_header): Update.
	(ui_out_query_field): Update.
This commit is contained in:
Simon Marchi 2016-12-01 16:02:00 -05:00 committed by Simon Marchi
parent c520961526
commit 37e20dd659
2 changed files with 77 additions and 27 deletions

View File

@ -1,3 +1,11 @@
2016-12-01 Simon Marchi <simon.marchi@polymtl.ca>
* ui-out.c (struct ui_out_hdr): Replace with ...
(class ui_out_hdr): ... this.
(append_header_to_list): Update.
(get_next_header): Update.
(ui_out_query_field): Update.
2016-12-01 Simon Marchi <simon.marchi@polymtl.ca>
* mi/mi-out.c (mi_table_header): Change char * args to

View File

@ -29,15 +29,65 @@
#include <memory>
#include <string>
/* table header structures */
/* A header of a ui_out_table. */
struct ui_out_hdr
class ui_out_hdr
{
int colno;
int width;
enum ui_align alignment;
std::string col_name;
std::string col_hdr;
public:
explicit ui_out_hdr (int number, int min_width, ui_align alignment,
const std::string &name, const std::string &header)
: m_number (number),
m_min_width (min_width),
m_alignment (alignment),
m_name (name),
m_header (header)
{
}
int number () const
{
return m_number;
}
int min_width () const
{
return m_min_width;
}
ui_align alignment () const
{
return m_alignment;
}
const std::string &header () const
{
return m_header;
}
const std::string &name () const
{
return m_name;
}
private:
/* The number of the table column this header represents, 1-based. */
int m_number;
/* Minimal column width in characters. May or may not be applicable,
depending on the actual implementation of ui_out. */
int m_min_width;
/* Alignment of the content in the column. May or may not be applicable,
depending on the actual implementation of ui_out. */
ui_align m_alignment;
/* Internal column name, used to internally refer to the column. */
std::string m_name;
/* Printed header text of the column. */
std::string m_header;
};
struct ui_out_level
@ -705,17 +755,9 @@ append_header_to_list (struct ui_out *uiout,
const std::string &col_name,
const std::string &col_hdr)
{
std::unique_ptr<ui_out_hdr> temphdr (new ui_out_hdr ());
temphdr->width = width;
temphdr->alignment = alignment;
/* Make our own copy of the strings, since the lifetime of the original
versions may be too short. */
temphdr->col_hdr = col_hdr;
temphdr->col_name = col_name;
temphdr->colno = uiout->table.headers.size () + 1;
std::unique_ptr<ui_out_hdr> temphdr(
new ui_out_hdr (uiout->table.headers.size () + 1, width,
alignment, col_name, col_hdr));
uiout->table.headers.push_back (std::move (temphdr));
}
@ -736,10 +778,10 @@ get_next_header (struct ui_out *uiout,
ui_out_hdr *hdr = uiout->table.headers_iterator->get ();
*colno = hdr->colno;
*width = hdr->width;
*alignment = hdr->alignment;
*col_hdr = hdr->col_hdr.c_str ();
*colno = hdr->number ();
*width = hdr->min_width ();
*alignment = hdr->alignment ();
*col_hdr = hdr->header ().c_str ();
/* Advance the header pointer to the next entry. */
uiout->table.headers_iterator++;
@ -814,11 +856,11 @@ ui_out_query_field (struct ui_out *uiout, int colno,
{
ui_out_hdr *hdr = uiout->table.headers[index].get ();
gdb_assert (colno == hdr->colno);
gdb_assert (colno == hdr->number ());
*width = hdr->width;
*alignment = hdr->alignment;
*col_name = hdr->col_name.c_str ();
*width = hdr->min_width ();
*alignment = hdr->alignment ();
*col_name = hdr->name ().c_str ();
return 1;
}