8294293: Remove unused _width and _newlines field in outputStream

Reviewed-by: rehn, dholmes
This commit is contained in:
Johan Sjölen 2022-09-30 14:45:40 +00:00 committed by Coleen Phillimore
parent c2ce43cbb0
commit 052a924985
2 changed files with 17 additions and 22 deletions

View File

@ -43,20 +43,16 @@
extern "C" void jio_print(const char* s, size_t len); extern "C" void jio_print(const char* s, size_t len);
extern "C" int jio_printf(const char *fmt, ...); extern "C" int jio_printf(const char *fmt, ...);
outputStream::outputStream(int width) { outputStream::outputStream() {
_width = width;
_position = 0; _position = 0;
_newlines = 0;
_precount = 0; _precount = 0;
_indentation = 0; _indentation = 0;
_scratch = NULL; _scratch = NULL;
_scratch_len = 0; _scratch_len = 0;
} }
outputStream::outputStream(int width, bool has_time_stamps) { outputStream::outputStream(bool has_time_stamps) {
_width = width;
_position = 0; _position = 0;
_newlines = 0;
_precount = 0; _precount = 0;
_indentation = 0; _indentation = 0;
_scratch = NULL; _scratch = NULL;
@ -64,11 +60,12 @@ outputStream::outputStream(int width, bool has_time_stamps) {
if (has_time_stamps) _stamp.update(); if (has_time_stamps) _stamp.update();
} }
void outputStream::update_position(const char* s, size_t len) { bool outputStream::update_position(const char* s, size_t len) {
bool saw_newline = false;
for (size_t i = 0; i < len; i++) { for (size_t i = 0; i < len; i++) {
char ch = s[i]; char ch = s[i];
if (ch == '\n') { if (ch == '\n') {
_newlines += 1; saw_newline = true;
_precount += _position + 1; _precount += _position + 1;
_position = 0; _position = 0;
} else if (ch == '\t') { } else if (ch == '\t') {
@ -79,6 +76,7 @@ void outputStream::update_position(const char* s, size_t len) {
_position += 1; _position += 1;
} }
} }
return saw_newline;
} }
// Execute a vsprintf, using the given buffer if necessary. // Execute a vsprintf, using the given buffer if necessary.
@ -400,7 +398,6 @@ void stringStream::zero_terminate() {
void stringStream::reset() { void stringStream::reset() {
assert(_is_frozen == false, "Modification forbidden"); assert(_is_frozen == false, "Modification forbidden");
_written = 0; _precount = 0; _position = 0; _written = 0; _precount = 0; _position = 0;
_newlines = 0;
zero_terminate(); zero_terminate();
} }
@ -893,17 +890,17 @@ void defaultStream::write(const char* s, size_t len) {
intx holder = hold(thread_id); intx holder = hold(thread_id);
if (DisplayVMOutput && if (DisplayVMOutput &&
(_outer_xmlStream == NULL || !_outer_xmlStream->inside_attrs())) { (_outer_xmlStream == nullptr || !_outer_xmlStream->inside_attrs())) {
// print to output stream. It can be redirected by a vfprintf hook // print to output stream. It can be redirected by a vfprintf hook
jio_print(s, len); jio_print(s, len);
} }
// print to log file // print to log file
if (has_log_file()) { if (has_log_file() && _outer_xmlStream != nullptr) {
int nl0 = _newlines; _outer_xmlStream->write_text(s, len);
xmlTextStream::write(s, len); bool nl = update_position(s, len);
// flush the log file too, if there were any newlines // flush the log file too, if there were any newlines
if (nl0 != _newlines){ if (nl) {
flush(); flush();
} }
} else { } else {

View File

@ -48,15 +48,14 @@ class outputStream : public ResourceObj {
protected: protected:
int _indentation; // current indentation int _indentation; // current indentation
int _width; // width of the page int _position; // visual position on the current line
int _position; // position on the current line uint64_t _precount; // number of chars output, less than _position
int _newlines; // number of '\n' output so far
julong _precount; // number of chars output, less _position
TimeStamp _stamp; // for time stamps TimeStamp _stamp; // for time stamps
char* _scratch; // internal scratch buffer for printf char* _scratch; // internal scratch buffer for printf
size_t _scratch_len; // size of internal scratch buffer size_t _scratch_len; // size of internal scratch buffer
void update_position(const char* s, size_t len); // Returns whether a newline was seen or not
bool update_position(const char* s, size_t len);
static const char* do_vsnprintf(char* buffer, size_t buflen, static const char* do_vsnprintf(char* buffer, size_t buflen,
const char* format, va_list ap, const char* format, va_list ap,
bool add_cr, bool add_cr,
@ -71,8 +70,8 @@ class outputStream : public ResourceObj {
public: public:
// creation // creation
outputStream(int width = 80); outputStream();
outputStream(int width, bool has_time_stamps); outputStream(bool has_time_stamps);
// indentation // indentation
outputStream& indent(); outputStream& indent();
@ -86,7 +85,6 @@ class outputStream : public ResourceObj {
void move_to(int col, int slop = 6, int min_space = 2); void move_to(int col, int slop = 6, int min_space = 2);
// sizing // sizing
int width() const { return _width; }
int position() const { return _position; } int position() const { return _position; }
julong count() const { return _precount + _position; } julong count() const { return _precount + _position; }
void set_count(julong count) { _precount = count - _position; } void set_count(julong count) { _precount = count - _position; }