Skip to content

Commit

Permalink
[stats] add hpa_gratuitous stat #2199
Browse files Browse the repository at this point in the history
  • Loading branch information
dankamongmen committed Oct 28, 2021
1 parent 8817806 commit 935e96a
Show file tree
Hide file tree
Showing 6 changed files with 31 additions and 4 deletions.
10 changes: 10 additions & 0 deletions NEWS.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,16 @@ rearrangements of Notcurses.
`notcurses_options`, for which I make no apology. If you've been avoiding
deprecated functionality, ABI3 ought require small changes, if any.

* 2.4.9 (not yet released)
* On transition between `ncplane`s (on terminals implementing complex wide
glyphs), Notcurses now always issues an `hpa` sequence to force horizontal
positioning. This fixes a number of longstanding bugs in e.g. the
`[uniblock]` and `[whiteout]` demos at the cost of some extra control
sequences. For more information, see
[issue 2199](https://github.com/dankamongmen/notcurses/issues/2199). The
number of `hpa`s issued in this manner is tracked in a new stat,
`hpa_gratuitous`.

* 2.4.8 (2021-10-23)
* Added new functions `notcurses_canpixel()` and `notcurses_osversion()`.
* `notcurses_get()` now evaluates its timeout against `CLOCK_MONOTONIC`
Expand Down
1 change: 1 addition & 0 deletions USAGE.md
Original file line number Diff line number Diff line change
Expand Up @@ -3587,6 +3587,7 @@ typedef struct ncstats {
uint64_t sprixelbytes; // sprixel bytes emitted
uint64_t appsync_updates; // application-synchronized updates
uint64_t input_errors; // errors processing control sequences/utf8
uint64_t hpa_gratuitous; // unnecessary hpas issued
// current state -- these can decrease
uint64_t fbbytes; // total bytes devoted to all active framebuffers
Expand Down
11 changes: 11 additions & 0 deletions doc/man/man3/notcurses_stats.3.md
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ typedef struct ncstats {
uint64_t appsync_updates; // application-synchronized updates
uint64_t input_events; // inputs received or synthesized
uint64_t input_errors; // errors processing input
uint64_t hpa_gratuitous; // gratuitous HPAs issued

// current state -- these can decrease
uint64_t fbbytes; // bytes devoted to framebuffers
Expand Down Expand Up @@ -117,6 +118,15 @@ include move/delete operations, nor glyphs used to erase sprixels.
**input_errors** is the number of errors while processing input, e.g.
malformed control sequences or invalid UTF-8 (see **utf8(7)**).

**hpa_gratuitous** is the number of **hpa** (horizontal position absolute,
see **terminfo(5)**) control sequences issued where not strictly necessary.
This is done to cope with fundamental ambiguities regarding glyph
width. It is not generally possible to know how wide a glyph will be rendered
on a given combination of font, font rendering engine, and terminal. Indeed, it
is not even generally possible to know how many glyphs will result from a
sequence of EGCs. As a result, Notcurses sometimes issues "gratuitous" **hpa**
controls.

# NOTES

Unsuccessful render operations do not contribute to the render timing stats.
Expand All @@ -138,4 +148,5 @@ object on success, or **NULL** on failure.
**mmap(2)**,
**notcurses(3)**,
**notcurses_render(3)**,
**terminfo(5)**,
**utf8(7)**
1 change: 1 addition & 0 deletions include/notcurses/notcurses.h
Original file line number Diff line number Diff line change
Expand Up @@ -1541,6 +1541,7 @@ typedef struct ncstats {
uint64_t sprixelbytes; // sprixel bytes emitted
uint64_t input_errors; // errors processing control sequences/utf8
uint64_t input_events; // characters returned to userspace
uint64_t hpa_gratuitous; // unnecessary hpas issued
} ncstats;

// Allocate an ncstats object. Use this rather than allocating your own, since
Expand Down
10 changes: 7 additions & 3 deletions src/lib/stats.c
Original file line number Diff line number Diff line change
Expand Up @@ -152,6 +152,7 @@ void notcurses_stats_reset(notcurses* nc, ncstats* stats){
stash->appsync_updates += nc->stats.s.appsync_updates;
stash->input_errors += nc->stats.s.input_errors;
stash->input_events += nc->stats.s.input_events;
stash->hpa_gratuitous += nc->stats.s.hpa_gratuitous;

stash->fbbytes = nc->stats.s.fbbytes;
stash->planes = nc->stats.s.planes;
Expand Down Expand Up @@ -208,18 +209,21 @@ void summarize_stats(notcurses* nc){
stats->input_events,
stats->input_events == 1 ? "" : "s");
}
fprintf(stderr, "%s%"PRIu64" failed render%s, %"PRIu64" failed raster%s, %"PRIu64" refresh%s, %"PRIu64" input error%s" NL,
fprintf(stderr, "%s%"PRIu64" failed render%s, %"PRIu64" failed raster%s, %"
PRIu64" refresh%s, %"PRIu64" input error%s" NL,
clreol, stats->failed_renders, stats->failed_renders == 1 ? "" : "s",
stats->failed_writeouts, stats->failed_writeouts == 1 ? "" : "s",
stats->refreshes, stats->refreshes == 1 ? "" : "es",
stats->input_errors, stats->input_errors == 1 ? "" : "s");
fprintf(stderr, "%sRGB emits:elides: def %"PRIu64":%"PRIu64" fg %"PRIu64":%"PRIu64" bg %"PRIu64":%"PRIu64"" NL,
fprintf(stderr, "%sRGB emits:elides: def %"PRIu64":%"PRIu64" fg %"PRIu64":%"
PRIu64" bg %"PRIu64":%"PRIu64" Ghpa: %"PRIu64 NL,
clreol, stats->defaultemissions,
stats->defaultelisions,
stats->fgemissions,
stats->fgelisions,
stats->bgemissions,
stats->bgelisions);
stats->bgelisions,
stats->hpa_gratuitous);
fprintf(stderr, "%sCell emits:elides: %"PRIu64":%"PRIu64" (%.2f%%) %.2f%% %.2f%% %.2f%%" NL,
clreol, stats->cellemissions, stats->cellelisions,
(stats->cellemissions + stats->cellelisions) == 0 ? 0 :
Expand Down
2 changes: 1 addition & 1 deletion src/lib/termdesc.c
Original file line number Diff line number Diff line change
Expand Up @@ -423,7 +423,7 @@ send_initial_queries(int fd, bool minimal, bool noaltscreen){
}
}
size_t len = strlen(queries);
loginfo("sending %lluB queries\n", (unsigned long long)len);
loginfo("sending %lluB\n", (unsigned long long)len);
if(blocking_write(fd, queries, len)){
return -1;
}
Expand Down

0 comments on commit 935e96a

Please sign in to comment.