packaging
This commit is contained in:
parent
57063cb17f
commit
b30a695ffc
@ -10,14 +10,13 @@ constexpr int paddingX = 10;
|
||||
constexpr int paddingY = 3;
|
||||
|
||||
// See https://docs.gtk.org/Pango/type_func.FontDescription.from_string.html
|
||||
constexpr const char *font = "Source Sans Pro 12";
|
||||
constexpr const char *font = "Sans 12";
|
||||
|
||||
constexpr ColorScheme colorInactive = {Color(0xbb, 0xbb, 0xbb), Color(0x22, 0x22, 0x22)};
|
||||
constexpr ColorScheme colorActive = {Color(0xee, 0xee, 0xee), Color(0x00, 0x55, 0x77)};
|
||||
constexpr const char *termcmd[] = {"foot", nullptr};
|
||||
|
||||
constexpr Button buttons[] = {
|
||||
{ ClkTagBar, BTN_LEFT, toggleview, {0} },
|
||||
{ ClkTagBar, BTN_LEFT, view, {0} },
|
||||
{ ClkTagBar, BTN_RIGHT, tag, {0} },
|
||||
{ ClkTagBar, BTN_MIDDLE, toggletag, {0} },
|
60
src/line_buffer.hpp
Normal file
60
src/line_buffer.hpp
Normal file
@ -0,0 +1,60 @@
|
||||
// somebar - dwl bar
|
||||
// See LICENSE file for copyright and license details.
|
||||
|
||||
#pragma once
|
||||
#include <array>
|
||||
#include <string.h>
|
||||
|
||||
// reads data from Reader, and passes complete lines to Handler.
|
||||
template<size_t N>
|
||||
class LineBuffer {
|
||||
std::array<char, N> _buffer;
|
||||
size_t _bytesBuffered {0};
|
||||
size_t _bytesConsumed {0};
|
||||
bool _discardLine {0};
|
||||
public:
|
||||
template<typename Reader, typename Handler>
|
||||
size_t readLines(const Reader& reader, const Handler& handler)
|
||||
{
|
||||
auto d = _buffer.data();
|
||||
while (true) {
|
||||
auto bytesRead = reader(d + _bytesBuffered, _buffer.size() - _bytesBuffered);
|
||||
if (bytesRead <= 0) {
|
||||
return bytesRead;
|
||||
}
|
||||
|
||||
_bytesBuffered += bytesRead;
|
||||
char* linePosition = nullptr;
|
||||
do {
|
||||
char* lineStart = d + _bytesConsumed;
|
||||
linePosition = static_cast<char*>(memchr(
|
||||
lineStart,
|
||||
'\n',
|
||||
_bytesBuffered - _bytesConsumed));
|
||||
|
||||
if (linePosition) {
|
||||
int lineLength = linePosition - lineStart;
|
||||
if (!_discardLine) {
|
||||
handler(lineStart, lineLength);
|
||||
}
|
||||
_bytesConsumed += lineLength + 1;
|
||||
_discardLine = false;
|
||||
}
|
||||
} while (linePosition);
|
||||
|
||||
size_t bytesRemaining = _bytesBuffered - _bytesConsumed;
|
||||
if (bytesRemaining == _buffer.size()) {
|
||||
// line too long
|
||||
_discardLine = true;
|
||||
_bytesBuffered = 0;
|
||||
_bytesConsumed = 0;
|
||||
} else if (bytesRemaining > 0 && _bytesConsumed > 0) {
|
||||
// move the last partial message to the front of the buffer, so a full-sized
|
||||
// message will fit
|
||||
memmove(d, d+_bytesConsumed, bytesRemaining);
|
||||
_bytesBuffered = bytesRemaining;
|
||||
_bytesConsumed = 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
};
|
Loading…
x
Reference in New Issue
Block a user