feat(core): Throttle writes to stdout

This commit is contained in:
Michael Carlberg 2016-06-01 01:07:23 +02:00
parent f033e0e7e5
commit a6ec504513
6 changed files with 73 additions and 2 deletions

View file

@ -160,6 +160,17 @@ the resulting output might not be award-winning.
`🟊 = module is still flagged as work in progress`
### Application settings
~~~ ini
[settings]
; Limit the amount of events sent to lemonbar within a set timeframe:
; - "Allow <throttle_limit> updates within <throttle_ms> of time"
; Default values:
;throttle_limit = 5
;throttle_ms = 50
~~~
### Module `internal/backlight`
~~~ ini
[module/backlight]

7
config
View file

@ -1,3 +1,10 @@
[settings]
; Limit the amount of events sent to lemonbar within a set timeframe:
; - "Allow <throttle_limit> updates within <throttle_ms> of time"
; Default values:
throttle_limit = 5
throttle_ms = 50
;
; Bar configurations
; ---------------------------------------

View file

@ -1,3 +1,10 @@
[settings]
; Limit the amount of events sent to lemonbar within a set timeframe:
; - "Allow <throttle_limit> updates within <throttle_ms> of time"
; Default values:
;throttle_limit = 5
;throttle_ms = 50
[bar/example]
width = 100%
height = 25

View file

@ -1,3 +1,10 @@
[settings]
; Limit the amount of events sent to lemonbar within a set timeframe:
; - "Allow <throttle_limit> updates within <throttle_ms> of time"
; Default values:
;throttle_limit = 5
;throttle_ms = 50
[bar/example]
width = 100%
height = 25

View file

@ -1,3 +1,10 @@
[settings]
; Limit the amount of events sent to lemonbar within a set timeframe:
; - "Allow <throttle_limit> updates within <throttle_ms> of time"
; Default values:
;throttle_limit = 5
;throttle_ms = 50
[bar/example]
width = 100%
height = 25

View file

@ -3,6 +3,7 @@
#include <stdlib.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <deque>
#include "eventloop.hpp"
#include "services/command.hpp"
@ -98,10 +99,41 @@ void EventLoop::add_stdin_subscriber(const std::string& module_name)
void EventLoop::loop_write()
{
std::deque<std::chrono::high_resolution_clock::time_point> ticks;
// Allow <throttle_limit> ticks within <throttle_ms> timeframe
const auto throttle_limit = config::get<unsigned int>("settings", "throttle_limit", 5);
const auto throttle_ms = std::chrono::duration<double, std::milli>(config::get<unsigned int>("settings", "throttle_ms", 50));
while (this->running()) {
try {
if (this->registry->wait())
this->write_stdout();
if (!this->registry->wait())
continue;
auto now = std::chrono::high_resolution_clock::now();
// Expire previous ticks
while (ticks.size() > 0) {
if ((now - ticks.front()) < throttle_ms)
break;
ticks.pop_front();
}
// Place the new tick in the bottom of the deck
ticks.emplace_back(std::chrono::high_resolution_clock::now());
// Have we reached the limit?
if (ticks.size() >= throttle_limit) {
log_debug("Throttling write to stdout");
std::this_thread::sleep_for(throttle_ms * ticks.size());
if (ticks.size() - 1 >= throttle_limit)
continue;
}
this->write_stdout();
} catch (Exception &e) {
this->logger->error(e.what());
return;