diff --git a/libs/console/piscreen.cpp b/libs/console/piscreen.cpp
index fba57853..70521fda 100644
--- a/libs/console/piscreen.cpp
+++ b/libs/console/piscreen.cpp
@@ -17,16 +17,17 @@
along with this program. If not, see .
*/
#include "piscreen.h"
+
#include "piincludes_p.h"
#ifndef WINDOWS
-# include
# include
+# include
# include
#else
-# include
# include
+# include
# ifndef COMMON_LVB_UNDERSCORE
-# define COMMON_LVB_UNDERSCORE 0x8000
+# define COMMON_LVB_UNDERSCORE 0x8000
# endif
#endif
@@ -66,11 +67,11 @@ void PIScreen::SystemConsole::begin() {
int w, h;
#ifdef WINDOWS
PRIVATE->ulcoord.X = 0;
- PRIVATE->hOut = GetStdHandle(STD_OUTPUT_HANDLE);
+ PRIVATE->hOut = GetStdHandle(STD_OUTPUT_HANDLE);
GetConsoleScreenBufferInfo(PRIVATE->hOut, &PRIVATE->sbi);
- PRIVATE->dattr = PRIVATE->sbi.wAttributes;
- w = PRIVATE->sbi.srWindow.Right - PRIVATE->sbi.srWindow.Left;
- h = PRIVATE->sbi.srWindow.Bottom - PRIVATE->sbi.srWindow.Top;
+ PRIVATE->dattr = PRIVATE->sbi.wAttributes;
+ w = PRIVATE->sbi.srWindow.Right - PRIVATE->sbi.srWindow.Left;
+ h = PRIVATE->sbi.srWindow.Bottom - PRIVATE->sbi.srWindow.Top;
PRIVATE->ulcoord.Y = PRIVATE->sbi.srWindow.Top;
GetConsoleMode(PRIVATE->hOut, &PRIVATE->smode);
GetConsoleCursorInfo(PRIVATE->hOut, &PRIVATE->curinfo);
@@ -135,9 +136,9 @@ void PIScreen::SystemConsole::clear() {
void PIScreen::SystemConsole::resize(int w, int h) {
if (w == pwidth && h == pheight) return;
- width = piMaxi(w, 0);
- height = piMaxi(h, 0);
- pwidth = width;
+ width = piMaxi(w, 0);
+ height = piMaxi(h, 0);
+ pwidth = width;
pheight = height;
cells.resize(height);
pcells.resize(height);
@@ -158,7 +159,7 @@ void PIScreen::SystemConsole::resize(int w, int h) {
void PIScreen::SystemConsole::print() {
if (mouse_x >= 0 && mouse_x < width && mouse_y >= 0 && mouse_y < height) {
- ///cells[mouse_y][mouse_x].format.flags ^= Inverse;
+ /// cells[mouse_y][mouse_x].format.flags ^= Inverse;
}
#ifdef WINDOWS
PRIVATE->srect = PRIVATE->sbi.srWindow;
@@ -186,10 +187,10 @@ void PIScreen::SystemConsole::print() {
int k = j * dw + i;
Cell & c(cells[j + dy0][i + dx0]);
PRIVATE->chars[k].Char.UnicodeChar = 0;
- PRIVATE->chars[k].Char.AsciiChar = c.symbol.toConsole1Byte();
- PRIVATE->chars[k].Attributes = attributes(c);
+ PRIVATE->chars[k].Char.AsciiChar = c.symbol.toConsole1Byte();
+ PRIVATE->chars[k].Attributes = attributes(c);
}
- //piCout << "draw" << dw << dh;
+ // piCout << "draw" << dw << dh;
PRIVATE->bs.X = dw;
PRIVATE->bs.Y = dh;
PRIVATE->srect.Left += dx0;
@@ -228,7 +229,7 @@ void PIScreen::SystemConsole::print() {
if (!s.isEmpty()) {
moveTo(si, sj);
PICout::stdoutPIString(s);
- //printf("%s", s.data());
+ // printf("%s", s.data());
s.clear();
}
}
@@ -240,33 +241,37 @@ void PIScreen::SystemConsole::print() {
#ifdef WINDOWS
-#define FOREGROUND_MASK (FOREGROUND_RED | FOREGROUND_GREEN | FOREGROUND_BLUE)
-#define BACKGROUND_MASK (BACKGROUND_RED | BACKGROUND_GREEN | BACKGROUND_BLUE)
+# define FOREGROUND_MASK (FOREGROUND_RED | FOREGROUND_GREEN | FOREGROUND_BLUE)
+# define BACKGROUND_MASK (BACKGROUND_RED | BACKGROUND_GREEN | BACKGROUND_BLUE)
ushort PIScreen::SystemConsole::attributes(const PIScreenTypes::Cell & c) {
WORD attr = PRIVATE->dattr;
- if (c.format.flags & Bold) attr |= FOREGROUND_INTENSITY;
- else attr &= ~FOREGROUND_INTENSITY;
- if (c.format.flags & Underline) attr |= COMMON_LVB_UNDERSCORE;
- else attr &= ~COMMON_LVB_UNDERSCORE;
+ if (c.format.flags & Bold)
+ attr |= FOREGROUND_INTENSITY;
+ else
+ attr &= ~FOREGROUND_INTENSITY;
+ if (c.format.flags & Underline)
+ attr |= COMMON_LVB_UNDERSCORE;
+ else
+ attr &= ~COMMON_LVB_UNDERSCORE;
switch (c.format.color_char) {
- case Black: attr = (attr & ~FOREGROUND_MASK); break;
- case Red: attr = (attr & ~FOREGROUND_MASK) | FOREGROUND_RED; break;
- case Green: attr = (attr & ~FOREGROUND_MASK) | FOREGROUND_GREEN; break;
- case Blue: attr = (attr & ~FOREGROUND_MASK) | FOREGROUND_BLUE; break;
- case Cyan: attr = (attr & ~FOREGROUND_MASK) | FOREGROUND_GREEN | FOREGROUND_BLUE; break;
+ case Black: attr = (attr & ~FOREGROUND_MASK); break;
+ case Red: attr = (attr & ~FOREGROUND_MASK) | FOREGROUND_RED; break;
+ case Green: attr = (attr & ~FOREGROUND_MASK) | FOREGROUND_GREEN; break;
+ case Blue: attr = (attr & ~FOREGROUND_MASK) | FOREGROUND_BLUE; break;
+ case Cyan: attr = (attr & ~FOREGROUND_MASK) | FOREGROUND_GREEN | FOREGROUND_BLUE; break;
case Magenta: attr = (attr & ~FOREGROUND_MASK) | FOREGROUND_RED | FOREGROUND_BLUE; break;
- case Yellow: attr = (attr & ~FOREGROUND_MASK) | FOREGROUND_RED | FOREGROUND_GREEN; break;
- case White: attr = attr | FOREGROUND_MASK; break;
+ case Yellow: attr = (attr & ~FOREGROUND_MASK) | FOREGROUND_RED | FOREGROUND_GREEN; break;
+ case White: attr = attr | FOREGROUND_MASK; break;
}
switch (c.format.color_back) {
- case Black: attr = (attr & ~BACKGROUND_MASK); break;
- case Red: attr = (attr & ~BACKGROUND_MASK) | BACKGROUND_RED; break;
- case Green: attr = (attr & ~BACKGROUND_MASK) | BACKGROUND_GREEN; break;
- case Blue: attr = (attr & ~BACKGROUND_MASK) | BACKGROUND_BLUE; break;
- case Cyan: attr = (attr & ~BACKGROUND_MASK) | BACKGROUND_GREEN | BACKGROUND_BLUE; break;
+ case Black: attr = (attr & ~BACKGROUND_MASK); break;
+ case Red: attr = (attr & ~BACKGROUND_MASK) | BACKGROUND_RED; break;
+ case Green: attr = (attr & ~BACKGROUND_MASK) | BACKGROUND_GREEN; break;
+ case Blue: attr = (attr & ~BACKGROUND_MASK) | BACKGROUND_BLUE; break;
+ case Cyan: attr = (attr & ~BACKGROUND_MASK) | BACKGROUND_GREEN | BACKGROUND_BLUE; break;
case Magenta: attr = (attr & ~BACKGROUND_MASK) | BACKGROUND_RED | BACKGROUND_BLUE; break;
- case Yellow: attr = (attr & ~BACKGROUND_MASK) | BACKGROUND_RED | BACKGROUND_GREEN; break;
- case White: attr = attr | BACKGROUND_MASK; break;
+ case Yellow: attr = (attr & ~BACKGROUND_MASK) | BACKGROUND_RED | BACKGROUND_GREEN; break;
+ case White: attr = attr | BACKGROUND_MASK; break;
}
if ((c.format.flags & Inverse) == Inverse) {
uchar f = attr & 0xFF;
@@ -276,8 +281,8 @@ ushort PIScreen::SystemConsole::attributes(const PIScreenTypes::Cell & c) {
}
return attr;
}
-#undef FOREGROUND_MASK
-#undef BACKGROUND_MASK
+# undef FOREGROUND_MASK
+# undef BACKGROUND_MASK
void PIScreen::SystemConsole::getWinCurCoord() {
GetConsoleScreenBufferInfo(PRIVATE->hOut, &PRIVATE->csbi);
@@ -292,36 +297,37 @@ void PIScreen::SystemConsole::clearLine() {
void PIScreen::SystemConsole::newLine() {
getWinCurCoord();
- PRIVATE->ccoord.X = 0; PRIVATE->ccoord.Y++;
+ PRIVATE->ccoord.X = 0;
+ PRIVATE->ccoord.Y++;
SetConsoleCursorPosition(PRIVATE->hOut, PRIVATE->ccoord);
}
-#else // WINDOWS
+#else // WINDOWS
PIString PIScreen::SystemConsole::formatString(const PIScreenTypes::Cell & c) {
PIString ts = PIStringAscii("\e[0");
switch (c.format.color_char) {
- case Black: ts += PIStringAscii(";30"); break;
- case Red: ts += PIStringAscii(";31"); break;
- case Green: ts += PIStringAscii(";32"); break;
- case Blue: ts += PIStringAscii(";34"); break;
- case Cyan: ts += PIStringAscii(";36"); break;
+ case Black: ts += PIStringAscii(";30"); break;
+ case Red: ts += PIStringAscii(";31"); break;
+ case Green: ts += PIStringAscii(";32"); break;
+ case Blue: ts += PIStringAscii(";34"); break;
+ case Cyan: ts += PIStringAscii(";36"); break;
case Magenta: ts += PIStringAscii(";35"); break;
- case Yellow: ts += PIStringAscii(";33"); break;
- case White: ts += PIStringAscii(";37"); break;
+ case Yellow: ts += PIStringAscii(";33"); break;
+ case White: ts += PIStringAscii(";37"); break;
}
switch (c.format.color_back) {
- case Black: ts += PIStringAscii(";40"); break;
- case Red: ts += PIStringAscii(";41"); break;
- case Green: ts += PIStringAscii(";42"); break;
- case Blue: ts += PIStringAscii(";44"); break;
- case Cyan: ts += PIStringAscii(";46"); break;
+ case Black: ts += PIStringAscii(";40"); break;
+ case Red: ts += PIStringAscii(";41"); break;
+ case Green: ts += PIStringAscii(";42"); break;
+ case Blue: ts += PIStringAscii(";44"); break;
+ case Cyan: ts += PIStringAscii(";46"); break;
case Magenta: ts += PIStringAscii(";45"); break;
- case Yellow: ts += PIStringAscii(";43"); break;
- case White: ts += PIStringAscii(";47"); break;
+ case Yellow: ts += PIStringAscii(";43"); break;
+ case White: ts += PIStringAscii(";47"); break;
}
- if ((c.format.flags & Bold ) == Bold ) ts += PIStringAscii(";1");
+ if ((c.format.flags & Bold) == Bold) ts += PIStringAscii(";1");
if ((c.format.flags & Underline) == Underline) ts += PIStringAscii(";4");
- if ((c.format.flags & Blink ) == Blink ) ts += PIStringAscii(";5");
- if ((c.format.flags & Inverse ) == Inverse ) ts += PIStringAscii(";7");
+ if ((c.format.flags & Blink) == Blink) ts += PIStringAscii(";5");
+ if ((c.format.flags & Inverse) == Inverse) ts += PIStringAscii(";7");
return ts + 'm';
}
#endif // WINDOWS
@@ -358,8 +364,16 @@ void PIScreen::SystemConsole::clearScreen() {
void PIScreen::SystemConsole::clearScreenLower() {
#ifdef WINDOWS
getWinCurCoord();
- FillConsoleOutputAttribute(PRIVATE->hOut, PRIVATE->dattr, width * height - width * PRIVATE->ccoord.Y + PRIVATE->ccoord.X, PRIVATE->ccoord, &PRIVATE->written);
- FillConsoleOutputCharacter(PRIVATE->hOut, ' ', width * height - width * PRIVATE->ccoord.Y + PRIVATE->ccoord.X, PRIVATE->ccoord, &PRIVATE->written);
+ FillConsoleOutputAttribute(PRIVATE->hOut,
+ PRIVATE->dattr,
+ width * height - width * PRIVATE->ccoord.Y + PRIVATE->ccoord.X,
+ PRIVATE->ccoord,
+ &PRIVATE->written);
+ FillConsoleOutputCharacter(PRIVATE->hOut,
+ ' ',
+ width * height - width * PRIVATE->ccoord.Y + PRIVATE->ccoord.X,
+ PRIVATE->ccoord,
+ &PRIVATE->written);
#else
printf("\e[0m\e[J");
#endif
@@ -384,17 +398,17 @@ void PIScreen::SystemConsole::showCursor() {
}
-
+// PIScreen
PIScreen::PIScreen(bool startNow, PIKbdListener::KBFunc slot): PIThread(), drawer_(console.cells), root("rootTile") {
setName("screen");
setPriority(piLow);
needLockRun(true);
- mouse_ = false;
- ret_func = slot;
+ mouse_ = false;
+ ret_func = slot;
tile_focus = tile_dialog = nullptr;
- root.screen = this;
- listener = new PIKbdListener(key_eventS, this, startNow);
+ root.screen = this;
+ listener = new PIKbdListener(key_eventS, this, startNow);
CONNECT1(void, PIKbdListener::MouseEvent, listener, mouseEvent, this, mouse_event);
CONNECT1(void, PIKbdListener::WheelEvent, listener, wheelEvent, this, wheel_event);
if (startNow) start();
@@ -410,7 +424,7 @@ PIScreen::~PIScreen() {
void PIScreen::setMouseEnabled(bool on) {
- mouse_ = on;
+ mouse_ = on;
console.mouse_x = console.mouse_y = -1;
}
@@ -422,14 +436,12 @@ void PIScreen::key_event(PIKbdListener::KeyEvent key) {
return;
*/
PIScreenTile * rtile = rootTile();
- if (tile_dialog)
- rtile = tile_dialog;
+ if (tile_dialog) rtile = tile_dialog;
bool used = nextFocus(rtile, key);
if (used) return;
if (!used && tile_focus) {
if (tile_focus->visible) {
- if (tile_focus->keyEvent(key))
- return;
+ if (tile_focus->keyEvent(key)) return;
}
}
if (ret_func != 0) ret_func(key, data_);
@@ -437,14 +449,14 @@ void PIScreen::key_event(PIKbdListener::KeyEvent key) {
}
-PIVector PIScreen::prepareMouse(PIKbdListener::MouseEvent * e) {
- PIVector ret;
+PIVector PIScreen::prepareMouse(PIKbdListener::MouseEvent * e) {
+ PIVector ret;
if (!mouse_ || !e) return ret;
- console.mouse_x = e->x;
- console.mouse_y = e->y;
- PIVector tl = tilesUnderMouse(e->x, e->y);
- bool ff = false;
- piForeachR (PIScreenTile * t, tl) {
+ console.mouse_x = e->x;
+ console.mouse_y = e->y;
+ PIVector tl = tilesUnderMouse(e->x, e->y);
+ bool ff = false;
+ piForeachR(PIScreenTile * t, tl) {
if (!ff) {
if (t->focus_flags[FocusOnMouse] && (e->action == PIKbdListener::MouseButtonPress)) {
t->setFocus();
@@ -455,20 +467,19 @@ PIVector PIScreen::prepareMouse(PIKbdListener::MouseEvent * e)
ff = true;
}
}
-
}
return tl;
}
-PIVector PIScreen::tilesUnderMouse(int x, int y) {
- PIVector ret;
+PIVector PIScreen::tilesUnderMouse(int x, int y) {
+ PIVector ret;
if (x < 0 || x >= console.width || y < 0 || y >= console.height) return ret;
PIScreenTile * ct = tile_dialog ? tile_dialog : rootTile();
- bool f = true;
+ bool f = true;
while (ct) {
if (!f) ret << ct;
- f = false;
+ f = false;
ct = ct->childUnderMouse(x, y);
}
return ret;
@@ -476,27 +487,25 @@ PIVector PIScreen::tilesUnderMouse(int x, int y) {
void PIScreen::mouse_event(PIKbdListener::MouseEvent me) {
- PIVector tl = prepareMouse(&me);
+ PIVector tl = prepareMouse(&me);
if (tl.isEmpty()) return;
- piForeachR (PIScreenTile * t, tl)
+ piForeachR(PIScreenTile * t, tl)
if (t->mouseEvent(me)) break;
}
void PIScreen::wheel_event(PIKbdListener::WheelEvent we) {
- PIVector tl = prepareMouse(&we);
+ PIVector tl = prepareMouse(&we);
if (tl.isEmpty()) return;
- piForeachR (PIScreenTile * t, tl)
+ piForeachR(PIScreenTile * t, tl)
if (t->wheelEvent(we)) break;
-
}
bool PIScreen::nextFocus(PIScreenTile * rt, PIKbdListener::KeyEvent key) {
- PIVector vtl = rt->children(true), ftl;
- piForeach (PIScreenTile * t, vtl) {
- if (t->focus_flags[CanHasFocus])
- ftl << t;
+ PIVector vtl = rt->children(true), ftl;
+ piForeach(PIScreenTile * t, vtl) {
+ if (t->focus_flags[CanHasFocus]) ftl << t;
}
int ind = -1;
for (int i = 0; i < ftl.size_s(); ++i)
@@ -504,18 +513,15 @@ bool PIScreen::nextFocus(PIScreenTile * rt, PIKbdListener::KeyEvent key) {
ind = i;
break;
}
- if (ind < 0)
- tile_focus = 0;
+ if (ind < 0) tile_focus = 0;
if (ftl.isEmpty())
tile_focus = 0;
else {
if (tile_focus)
- if (!tile_focus->visible)
- tile_focus = 0;
+ if (!tile_focus->visible) tile_focus = 0;
int next = tile_focus ? 0 : 1;
if (tile_focus) {
- if (tile_focus->focus_flags[NextByTab] && key.key == PIKbdListener::Tab)
- next = 1;
+ if (tile_focus->focus_flags[NextByTab] && key.key == PIKbdListener::Tab) next = 1;
if (tile_focus->focus_flags[NextByArrowsHorizontal]) {
if (key.key == PIKbdListener::LeftArrow) next = -1;
if (key.key == PIKbdListener::RightArrow) next = 1;
@@ -525,16 +531,16 @@ bool PIScreen::nextFocus(PIScreenTile * rt, PIKbdListener::KeyEvent key) {
if (key.key == PIKbdListener::DownArrow) next = 1;
}
}
- //piCout << ftl.size() << ind << next;
+ // piCout << ftl.size() << ind << next;
if (next != 0) {
- PIVector tl = rt->children();
- piForeach (PIScreenTile * t, tl)
+ PIVector tl = rt->children();
+ piForeach(PIScreenTile * t, tl)
t->has_focus = false;
if (!ftl.isEmpty()) {
ind += next;
if (ind >= ftl.size_s()) ind = 0;
if (ind < 0) ind = ftl.size_s() - 1;
- tile_focus = ftl[ind];
+ tile_focus = ftl[ind];
tile_focus->has_focus = true;
}
return true;
@@ -550,22 +556,19 @@ void PIScreen::tileEventInternal(PIScreenTile * t, TileEvent e) {
void PIScreen::tileRemovedInternal(PIScreenTile * t) {
- if (tile_dialog == t)
- tile_dialog = 0;
+ if (tile_dialog == t) tile_dialog = 0;
}
void PIScreen::tileSetFocusInternal(PIScreenTile * t) {
PIScreenTile * rt = rootTile();
- if (tile_dialog)
- rt = tile_dialog;
- PIVector tl = rt->children(), ftl;
- piForeach (PIScreenTile * i, tl)
+ if (tile_dialog) rt = tile_dialog;
+ PIVector tl = rt->children(), ftl;
+ piForeach(PIScreenTile * i, tl)
i->has_focus = false;
tile_focus = t;
if (!tile_focus) return;
- if (tile_focus->focus_flags[CanHasFocus])
- tile_focus->has_focus = true;
+ if (tile_focus->focus_flags[CanHasFocus]) tile_focus->has_focus = true;
}
@@ -612,16 +615,21 @@ void PIScreen::run() {
if (tile_dialog) {
int sw(0), sh(0);
tile_dialog->sizeHint(sw, sh);
- sw = piClampi(sw, tile_dialog->minimumWidth, tile_dialog->maximumWidth);
- sh = piClampi(sh, tile_dialog->minimumHeight, tile_dialog->maximumHeight);
- tile_dialog->x_ = (console.width - sw) / 2;
- tile_dialog->y_ = (console.height - sh) / 2;
- tile_dialog->width_ = sw;
+ sw = piClampi(sw, tile_dialog->minimumWidth, tile_dialog->maximumWidth);
+ sh = piClampi(sh, tile_dialog->minimumHeight, tile_dialog->maximumHeight);
+ tile_dialog->x_ = (console.width - sw) / 2;
+ tile_dialog->y_ = (console.height - sh) / 2;
+ tile_dialog->width_ = sw;
tile_dialog->height_ = sh;
tile_dialog->layout();
int dx = tile_dialog->x_ - 1, dy = tile_dialog->y_ - 1, dw = tile_dialog->width_, dh = tile_dialog->height_;
- drawer_.drawFrame(dx, dy, dx + dw + 1, dy + dh + 1, (Color)tile_dialog->back_format.color_char,
- (Color)tile_dialog->back_format.color_back, (CharFlags)tile_dialog->back_format.flags);
+ drawer_.drawFrame(dx,
+ dy,
+ dx + dw + 1,
+ dy + dh + 1,
+ (Color)tile_dialog->back_format.color_char,
+ (Color)tile_dialog->back_format.color_back,
+ (CharFlags)tile_dialog->back_format.flags);
tile_dialog->drawEventInternal(&drawer_);
}
console.print();
@@ -635,10 +643,8 @@ void PIScreen::end() {
PIScreenTile * PIScreen::tileByName(const PIString & name) {
- PIVector tl(tiles());
- piForeach (PIScreenTile * t, tl)
- if (t->name() == name)
- return t;
+ PIVector tl(tiles());
+ piForeach(PIScreenTile * t, tl)
+ if (t->name() == name) return t;
return 0;
}
-
diff --git a/libs/console/piscreentiles.cpp b/libs/console/piscreentiles.cpp
index 7a340680..e73f95c1 100644
--- a/libs/console/piscreentiles.cpp
+++ b/libs/console/piscreentiles.cpp
@@ -18,6 +18,7 @@
*/
#include "piscreentiles.h"
+
#include "piscreendrawer.h"
@@ -37,7 +38,7 @@ TileSimple::TileSimple(const TileSimple::Row & r): PIScreenTile() {
void TileSimple::sizeHint(int & w, int & h) const {
w = h = 0;
- piForeachC (Row & r, content)
+ piForeachC(Row & r, content)
w = piMaxi(w, r.first.size_s());
h = content.size_s();
}
@@ -57,13 +58,13 @@ void TileSimple::drawEvent(PIScreenDrawer * d) {
}
-
+// TileScrollBar
TileScrollBar::TileScrollBar(const PIString & n) {
direction = Vertical;
thickness = 1;
minimum_ = value_ = 0;
- maximum_ = 100;
+ maximum_ = 100;
}
@@ -122,15 +123,15 @@ bool TileScrollBar::mouseEvent(PIKbdListener::MouseEvent me) {
}
-
+// TileList
TileList::TileList(const PIString & n, SelectionMode sm): PIScreenTile(n) {
- alignment = Left;
+ alignment = Left;
focus_flags = CanHasFocus | NextByArrowsHorizontal | NextByTab | FocusOnMouseOrWheel;
lhei = offset = cur = 0;
- mouse_sel = false;
- selection_mode = sm;
- scroll = new TileScrollBar();
+ mouse_sel = false;
+ selection_mode = sm;
+ scroll = new TileScrollBar();
scroll->size_policy = Ignore;
addTile(scroll);
}
@@ -138,26 +139,26 @@ TileList::TileList(const PIString & n, SelectionMode sm): PIScreenTile(n) {
void TileList::sizeHint(int & w, int & h) const {
w = h = 0;
- piForeachC (Row & r, content)
+ piForeachC(Row & r, content)
w = piMaxi(w, r.first.size_s());
h = 3;
}
void TileList::resizeEvent(int w, int h) {
- scroll->x_ = x_ + width_ - 1;
- scroll->y_ = y_;
- scroll->width_ = 1;
+ scroll->x_ = x_ + width_ - 1;
+ scroll->y_ = y_;
+ scroll->width_ = 1;
scroll->height_ = height_;
}
void TileList::drawEvent(PIScreenDrawer * d) {
- lhei = height_ - 2;
+ lhei = height_ - 2;
int is = piClampi(offset, 0, piMaxi(0, content.size_s() - 1)), ie = piClampi(offset + lhei, 0, content.size_s());
if (is > 0) d->drawText(x_, y_, PIString(" /\\ ").repeat(width_ / 4), Green, Default, Bold);
if (ie < content.size_s()) d->drawText(x_, y_ + height_ - 1, PIString(" \\/ ").repeat(width_ / 4), Green, Default, Bold);
- //piCout << is << ie << offset << lhei << content.size_s();
+ // piCout << is << ie << offset << lhei << content.size_s();
for (int i = is; i < ie; ++i) {
Row & r(content[i]);
bool sel = i == cur && has_focus;
@@ -172,7 +173,7 @@ void TileList::drawEvent(PIScreenDrawer * d) {
case Right: rx = x_ + width_ - 1 - r.first.size_s(); break;
};
CharFlags cf = r.second.flags;
- Color cc = (Color)r.second.color_char;
+ Color cc = (Color)r.second.color_char;
if (selected[i]) {
cf |= Bold;
cc = Yellow;
@@ -188,9 +189,7 @@ bool TileList::keyEvent(PIKbdListener::KeyEvent key) {
lhei = height_ - 2;
int oo(0), osp = piMini(3, lhei / 4);
switch (key.key) {
- case PIKbdListener::PageUp:
- cur -= lhei / 2;
- oo -= lhei / 2;
+ case PIKbdListener::PageUp: cur -= lhei / 2; oo -= lhei / 2;
case PIKbdListener::UpArrow:
cur--;
oo--;
@@ -207,7 +206,8 @@ bool TileList::keyEvent(PIKbdListener::KeyEvent key) {
switch (selection_mode) {
case NoSelection: return false;
case SingleSelection:
- if (selected.isEmpty()) selected << cur;
+ if (selected.isEmpty())
+ selected << cur;
else {
bool add = !selected[cur];
selected.clear();
@@ -216,8 +216,10 @@ bool TileList::keyEvent(PIKbdListener::KeyEvent key) {
raiseEvent(TileEvent(SelectionChanged));
return true;
case MultiSelection:
- if (selected[cur]) selected.remove(cur);
- else selected << cur;
+ if (selected[cur])
+ selected.remove(cur);
+ else
+ selected << cur;
raiseEvent(TileEvent(SelectionChanged));
break;
}
@@ -238,17 +240,14 @@ bool TileList::keyEvent(PIKbdListener::KeyEvent key) {
if (offset >= content.size_s() - lhei) offset = content.size_s() - lhei;
if (offset < 0) offset = 0;
return true;
- case PIKbdListener::Home:
- cur = offset = 0;
- return true;
+ case PIKbdListener::Home: cur = offset = 0; return true;
case PIKbdListener::End:
- cur = content.size_s() - 1;
+ cur = content.size_s() - 1;
offset = content.size_s() - lhei;
if (offset < 0) offset = 0;
return true;
case PIKbdListener::Return:
- if (cur >= 0 && cur < content.size_s())
- raiseEvent(TileEvent(RowPressed, cur));
+ if (cur >= 0 && cur < content.size_s()) raiseEvent(TileEvent(RowPressed, cur));
return true;
case '*':
if (selection_mode == TileList::MultiSelection) {
@@ -278,12 +277,8 @@ bool TileList::mouseEvent(PIKbdListener::MouseEvent me) {
if (mp < 0 || mp >= content.size_s()) return true;
cur = mp;
switch (me.action) {
- case PIKbdListener::MouseButtonPress:
- mouse_sel = !selected.contains(cur);
- break;
- case PIKbdListener::MouseButtonDblClick:
- keyEvent(PIKbdListener::KeyEvent(PIKbdListener::Return));
- return true;
+ case PIKbdListener::MouseButtonPress: mouse_sel = !selected.contains(cur); break;
+ case PIKbdListener::MouseButtonDblClick: keyEvent(PIKbdListener::KeyEvent(PIKbdListener::Return)); return true;
default: break;
}
if (me.buttons[PIKbdListener::MouseRight]) {
@@ -294,8 +289,10 @@ bool TileList::mouseEvent(PIKbdListener::MouseEvent me) {
raiseEvent(TileEvent(SelectionChanged));
break;
case MultiSelection:
- if (mouse_sel) selected << cur;
- else selected.remove(cur);
+ if (mouse_sel)
+ selected << cur;
+ else
+ selected.remove(cur);
raiseEvent(TileEvent(SelectionChanged));
break;
default: break;
@@ -311,7 +308,7 @@ bool TileList::wheelEvent(PIKbdListener::WheelEvent we) {
}
-
+// TileButton
TileButton::TileButton(const PIString & n): PIScreenTile(n) {
focus_flags = CanHasFocus | NextByTab | NextByArrowsAll | FocusOnMouse;
@@ -327,7 +324,7 @@ void TileButton::sizeHint(int & w, int & h) const {
void TileButton::drawEvent(PIScreenDrawer * d) {
Color cb = has_focus ? Blue : Cyan;
Color ct = has_focus ? White : Black;
- int ff = has_focus ? Bold : 0;
+ int ff = has_focus ? Bold : 0;
d->fillRect(x_, y_, x_ + width_, y_ + 1, ' ', Default, cb);
d->drawText(x_, y_, "[", ct, Transparent, ff);
d->drawText(x_ + (width_ - text.size_s()) / 2, y_, text, ct, Transparent, ff);
@@ -351,25 +348,25 @@ bool TileButton::mouseEvent(PIKbdListener::MouseEvent me) {
}
-
+// TileButtons
TileButtons::TileButtons(const PIString & n): PIScreenTile(n) {
focus_flags = CanHasFocus | NextByTab | FocusOnMouse;
- direction = Horizontal;
- alignment = PIScreenTypes::Center;
- cur = 0;
+ direction = Horizontal;
+ alignment = PIScreenTypes::Center;
+ cur = 0;
}
void TileButtons::sizeHint(int & w, int & h) const {
w = h = 0;
if (direction == Horizontal) {
- piForeachC (Button & b, content)
+ piForeachC(Button & b, content)
w += b.first.size_s() + 4;
w += piMaxi(0, content.size_s() - 1) * 2;
h += 1;
} else {
- piForeachC (Button & b, content)
+ piForeachC(Button & b, content)
w = piMaxi(w, b.first.size_s() + 4);
h += content.size_s();
h += piMaxi(0, content.size_s() - 1);
@@ -387,12 +384,11 @@ void TileButtons::drawEvent(PIScreenDrawer * d) {
case PIScreenTypes::Right: dx = width_ - shw; break;
default: break;
}
- if (direction == PIScreenTypes::Horizontal)
- cx += dx;
+ if (direction == PIScreenTypes::Horizontal) cx += dx;
for (int i = 0; i < content.size_s(); ++i) {
Color cb = Cyan;
Color ct = Black;
- int ff = 0;
+ int ff = 0;
if (i == cur && has_focus) {
cb = Blue;
ct = White;
@@ -430,9 +426,7 @@ bool TileButtons::keyEvent(PIKbdListener::KeyEvent key) {
if (cur >= content.size_s()) cur = content.size_s() - 1;
return true;
case PIKbdListener::Space:
- case PIKbdListener::Return:
- raiseEvent(TileEvent(ButtonSelected, cur));
- return true;
+ case PIKbdListener::Return: raiseEvent(TileEvent(ButtonSelected, cur)); return true;
};
return PIScreenTile::keyEvent(key);
}
@@ -441,8 +435,7 @@ bool TileButtons::keyEvent(PIKbdListener::KeyEvent key) {
bool TileButtons::mouseEvent(PIKbdListener::MouseEvent me) {
if (me.action == PIKbdListener::MouseMove || me.action == PIKbdListener::MouseButtonPress) {
for (int i = 0; i < btn_rects.size_s(); ++i)
- if (me.x >= btn_rects[i].x0 && me.x < btn_rects[i].x1 &&
- me.y >= btn_rects[i].y0 && me.y < btn_rects[i].y1) {
+ if (me.x >= btn_rects[i].x0 && me.x < btn_rects[i].x1 && me.y >= btn_rects[i].y0 && me.y < btn_rects[i].y1) {
cur = i;
break;
}
@@ -454,11 +447,11 @@ bool TileButtons::mouseEvent(PIKbdListener::MouseEvent me) {
}
-
+// TileCheck
TileCheck::TileCheck(const PIString & n): PIScreenTile(n) {
focus_flags = CanHasFocus | NextByTab | NextByArrowsAll | FocusOnMouse;
- toggled = false;
+ toggled = false;
}
@@ -471,7 +464,7 @@ void TileCheck::sizeHint(int & w, int & h) const {
void TileCheck::drawEvent(PIScreenDrawer * d) {
Color cb = has_focus ? Blue : Cyan;
Color ct = has_focus ? White : Black;
- int ff = has_focus ? Bold : 0;
+ int ff = has_focus ? Bold : 0;
PIString cs("[ ]");
if (toggled) cs[1] = '*';
d->fillRect(x_, y_, x_ + width_, y_ + 1, ' ', Default, cb);
@@ -499,12 +492,12 @@ bool TileCheck::mouseEvent(PIKbdListener::MouseEvent me) {
}
-
+// TileProgress
TileProgress::TileProgress(const PIString & n): PIScreenTile(n) {
maximum = 100.;
- value = 0.;
- suffix = " %";
+ value = 0.;
+ suffix = " %";
}
@@ -515,7 +508,7 @@ void TileProgress::sizeHint(int & w, int & h) const {
void TileProgress::drawEvent(PIScreenDrawer * d) {
- int v = maximum == 0. ? 0 : piClampd(piRoundd(value / maximum * 100.), 0, 100);
+ int v = maximum == 0. ? 0 : piClampd(piRoundd(value / maximum * 100.), 0, 100);
PIString s = prefix + PIString::fromNumber(piRoundd(value)) + suffix;
int w = piRoundd(v / 100. * width_), sx = (width_ - s.size_s()) / 2;
d->fillRect(x_, y_, x_ + width_, y_ + 1, ' ', Default, Cyan);
@@ -532,10 +525,10 @@ void TileProgress::drawEvent(PIScreenDrawer * d) {
}
-
+// TilePICout
TilePICout::TilePICout(const PIString & n): TileList(n) {
- max_lines = 1024;
+ max_lines = 1024;
selection_mode = TileList::SingleSelection;
PICout::setOutputDevices(PICout::Buffer);
}
@@ -545,14 +538,13 @@ void TilePICout::drawEvent(PIScreenDrawer * d) {
PIString out = PICout::getBufferAndClear();
if (!out.isEmpty()) {
PIStringList l = out.split("\n");
- bool scroll = (cur == content.size_s() - 1) || !has_focus;
- piForeachC (PIString & s, l)
+ bool scroll = (cur == content.size_s() - 1) || !has_focus;
+ piForeachC(PIString & s, l)
content << TileList::Row(s.trimmed(), format);
- if (content.size_s() > max_lines)
- content.remove(0, content.size_s() - max_lines);
+ if (content.size_s() > max_lines) content.remove(0, content.size_s() - max_lines);
if (scroll) {
offset = piMaxi(0, content.size_s() - lhei);
- cur = content.size_s() - 1;
+ cur = content.size_s() - 1;
}
}
TileList::drawEvent(d);
@@ -569,16 +561,16 @@ bool TilePICout::keyEvent(PIKbdListener::KeyEvent key) {
}
-
+// TileInput
TileInput::TileInput(const PIString & n): PIScreenTile(n) {
- focus_flags = CanHasFocus | NextByTab | FocusOnMouse;
+ focus_flags = CanHasFocus | NextByTab | FocusOnMouse;
back_format.color_back = White;
- format.color_char = Black;
- format.color_back = White;
- max_length = 1024;
+ format.color_char = Black;
+ format.color_back = White;
+ max_length = 1024;
cur = offset = 0;
- inv = false;
+ inv = false;
}
@@ -591,10 +583,8 @@ void TileInput::sizeHint(int & w, int & h) const {
void TileInput::drawEvent(PIScreenDrawer * d) {
PIString ps = text.mid(offset, width_ - 2);
d->drawText(x_ + 1, y_, ps, (Color)format.color_char, Transparent, (CharFlags)format.flags);
- if (offset > 0)
- d->drawText(x_, y_, "<", Green, Black, Bold);
- if (text.size_s() - offset >= width_ - 2)
- d->drawText(x_ + width_ - 1, y_, ">", Green, Black, Bold);
+ if (offset > 0) d->drawText(x_, y_, "<", Green, Black, Bold);
+ if (text.size_s() - offset >= width_ - 2) d->drawText(x_ + width_ - 1, y_, ">", Green, Black, Bold);
if (!has_focus) return;
Color cb = (Color)format.color_char, cc = (Color)format.color_back;
if (tm_blink.elapsed_m() >= 650) {
@@ -641,14 +631,13 @@ bool TileInput::keyEvent(PIKbdListener::KeyEvent key) {
reserCursor();
return true;
case PIKbdListener::End:
- cur = text.size_s();
+ cur = text.size_s();
offset = text.size_s() - lwid;
if (offset < 0) offset = 0;
reserCursor();
return true;
case PIKbdListener::Backspace:
- if (cur > text.size_s() || text.isEmpty())
- return true;
+ if (cur > text.size_s() || text.isEmpty()) return true;
text.remove(cur - 1, 1);
cur--;
if (cur > text.size_s()) cur = text.size_s();
@@ -658,8 +647,7 @@ bool TileInput::keyEvent(PIKbdListener::KeyEvent key) {
reserCursor();
return true;
case PIKbdListener::Delete:
- if (cur >= text.size_s() || text.isEmpty())
- return true;
+ if (cur >= text.size_s() || text.isEmpty()) return true;
text.remove(cur, 1);
if (cur < 0) cur = 0;
if (cur > text.size_s()) cur = text.size_s();
@@ -685,8 +673,7 @@ bool TileInput::keyEvent(PIKbdListener::KeyEvent key) {
case PIKbdListener::F9:
case PIKbdListener::F10:
case PIKbdListener::F11:
- case PIKbdListener::F12:
- break;
+ case PIKbdListener::F12: break;
default:
text.insert(cur, PIChar((ushort)key.key));
cur++;
diff --git a/libs/main/introspection/piintrospection_containers.h b/libs/main/introspection/piintrospection_containers.h
index 8151c072..0bd72f15 100644
--- a/libs/main/introspection/piintrospection_containers.h
+++ b/libs/main/introspection/piintrospection_containers.h
@@ -25,16 +25,16 @@
struct PIP_EXPORT PIIntrospectionContainersType {
~PIIntrospectionContainersType();
void finish();
- uint id = 0;
- const char * name = nullptr;
+ uint id = 0;
+ const char * name = nullptr;
const char * demangled = "?";
- bool inited = false;
- bool has_demangled = false;
+ bool inited = false;
+ bool has_demangled = false;
};
#if defined(PIP_INTROSPECTION) && !defined(PIP_FORCE_NO_PIINTROSPECTION)
-#include "piintrospection_base.h"
+# include "piintrospection_base.h"
class PIIntrospectionContainers;
@@ -45,6 +45,7 @@ public:
static PIIntrospectionContainersType ret = create();
return ret;
}
+
private:
static PIIntrospectionContainersType create() {
PIIntrospectionContainersType ret;
@@ -54,35 +55,39 @@ private:
}
};
-#define PIINTROSPECTION_CONTAINERS (PIIntrospectionContainersInterface::instance())
+# define PIINTROSPECTION_CONTAINERS (PIIntrospectionContainersInterface::instance())
-# define PIINTROSPECTION_CONTAINER_NEW(t, isz) PIINTROSPECTION_CONTAINERS->containerNew (PIIntrospectionContainersTypeInfo::get(), isz);
-# define PIINTROSPECTION_CONTAINER_DELETE(t) PIINTROSPECTION_CONTAINERS->containerDelete(PIIntrospectionContainersTypeInfo::get());
-# define PIINTROSPECTION_CONTAINER_ALLOC(t, cnt) PIINTROSPECTION_CONTAINERS->containerAlloc (PIIntrospectionContainersTypeInfo::get(), cnt);
-# define PIINTROSPECTION_CONTAINER_FREE(t, cnt) PIINTROSPECTION_CONTAINERS->containerFree (PIIntrospectionContainersTypeInfo::get(), cnt);
-# define PIINTROSPECTION_CONTAINER_USED(t, cnt) PIINTROSPECTION_CONTAINERS->containerUsed (PIIntrospectionContainersTypeInfo::get(), cnt);
-# define PIINTROSPECTION_CONTAINER_UNUSED(t, cnt) PIINTROSPECTION_CONTAINERS->containerUnused(PIIntrospectionContainersTypeInfo::get(), cnt);
+// clang-format off
+# define PIINTROSPECTION_CONTAINER_NEW (t, isz) PIINTROSPECTION_CONTAINERS->containerNew (PIIntrospectionContainersTypeInfo::get(), isz);
+# define PIINTROSPECTION_CONTAINER_DELETE(t ) PIINTROSPECTION_CONTAINERS->containerDelete(PIIntrospectionContainersTypeInfo::get() );
+# define PIINTROSPECTION_CONTAINER_ALLOC (t, cnt) PIINTROSPECTION_CONTAINERS->containerAlloc (PIIntrospectionContainersTypeInfo::get(), cnt);
+# define PIINTROSPECTION_CONTAINER_FREE (t, cnt) PIINTROSPECTION_CONTAINERS->containerFree (PIIntrospectionContainersTypeInfo::get(), cnt);
+# define PIINTROSPECTION_CONTAINER_USED (t, cnt) PIINTROSPECTION_CONTAINERS->containerUsed (PIIntrospectionContainersTypeInfo::get(), cnt);
+# define PIINTROSPECTION_CONTAINER_UNUSED(t, cnt) PIINTROSPECTION_CONTAINERS->containerUnused(PIIntrospectionContainersTypeInfo::get(), cnt);
+// clang-format on
class PIP_EXPORT PIIntrospectionContainersInterface {
friend class PIIntrospection;
friend class PIIntrospectionServer;
+
public:
__PIINTROSPECTION_SINGLETON_H__(Containers)
+ // clang-format off
void containerNew (const PIIntrospectionContainersType & ti, uint isz);
void containerDelete(const PIIntrospectionContainersType & ti);
void containerAlloc (const PIIntrospectionContainersType & ti, ullong cnt);
void containerFree (const PIIntrospectionContainersType & ti, ullong cnt);
void containerUsed (const PIIntrospectionContainersType & ti, ullong cnt);
void containerUnused(const PIIntrospectionContainersType & ti, ullong cnt);
+ // clang-format on
PIIntrospectionContainers * p;
+
private:
PIIntrospectionContainersInterface();
~PIIntrospectionContainersInterface();
-
-
};
@@ -96,5 +101,4 @@ private:
#endif
-
#endif // PIINTROSPECTION_CONTAINERS_H
diff --git a/libs/main/introspection/piintrospection_containers_p.h b/libs/main/introspection/piintrospection_containers_p.h
index da0049be..77b39cc8 100644
--- a/libs/main/introspection/piintrospection_containers_p.h
+++ b/libs/main/introspection/piintrospection_containers_p.h
@@ -20,10 +20,12 @@
#ifndef PIINTROSPECTION_CONTAINERS_P_H
#define PIINTROSPECTION_CONTAINERS_P_H
+#include "piintrospection_containers.h"
#include "pispinlock.h"
+#include "pistring.h"
+
#include