git-svn-id: svn://db.shs.com.ru/pip@249 12ceb7fc-bf1f-11e4-8940-5bc7170c53b5
This commit is contained in:
8
main.cpp
8
main.cpp
@@ -31,9 +31,9 @@ public:
|
|||||||
T dot(VC<N, T> a) {T res = T(); for (uint i=0; i<N; i++) res += v[i] * a.v[N - i - 1]; return res;}
|
T dot(VC<N, T> a) {T res = T(); for (uint i=0; i<N; i++) res += v[i] * a.v[N - i - 1]; return res;}
|
||||||
};
|
};
|
||||||
|
|
||||||
class TerminalTile: public PIScreenTile {
|
class TileTerminal: public PIScreenTile {
|
||||||
public:
|
public:
|
||||||
TerminalTile(PITerminal * t = 0): term(t) {
|
TileTerminal(PITerminal * t = 0): term(t) {
|
||||||
focus_flags = PIScreenTypes::CanHasFocus;
|
focus_flags = PIScreenTypes::CanHasFocus;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -42,7 +42,7 @@ private:
|
|||||||
//piCout << "draw" << visible;
|
//piCout << "draw" << visible;
|
||||||
if (!term) return;
|
if (!term) return;
|
||||||
PIVector<PIVector<PIScreenTypes::Cell> > c = term->content();
|
PIVector<PIVector<PIScreenTypes::Cell> > c = term->content();
|
||||||
d->fillRect(x, y, x + width, y + height, c);
|
d->fillRect(x_, y_, x_ + width_, y_ + height_, c);
|
||||||
}
|
}
|
||||||
bool keyEvent(PIKbdListener::KeyEvent key) {
|
bool keyEvent(PIKbdListener::KeyEvent key) {
|
||||||
//piCout << "key";
|
//piCout << "key";
|
||||||
@@ -67,7 +67,7 @@ private:
|
|||||||
int main (int argc, char * argv[]) {
|
int main (int argc, char * argv[]) {
|
||||||
PIScreen screen;
|
PIScreen screen;
|
||||||
PITerminal term;
|
PITerminal term;
|
||||||
TerminalTile tt(&term);
|
TileTerminal tt(&term);
|
||||||
screen.rootTile()->addTile(&tt);
|
screen.rootTile()->addTile(&tt);
|
||||||
tt.setFocus();
|
tt.setFocus();
|
||||||
screen.enableExitCapture();
|
screen.enableExitCapture();
|
||||||
|
|||||||
@@ -199,8 +199,8 @@ public:
|
|||||||
|
|
||||||
void getCursor(int & x, int & y) {
|
void getCursor(int & x, int & y) {
|
||||||
GetConsoleScreenBufferInfo(console, &sbi);
|
GetConsoleScreenBufferInfo(console, &sbi);
|
||||||
x = sbi.dwCursorPosition.X + sbi.srWindow.Left;
|
x = sbi.dwCursorPosition.X - sbi.srWindow.Left;
|
||||||
y = sbi.dwCursorPosition.Y + sbi.srWindow.Top;
|
y = sbi.dwCursorPosition.Y - sbi.srWindow.Top;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -472,8 +472,8 @@ void PIScreen::begin() {
|
|||||||
|
|
||||||
void PIScreen::run() {
|
void PIScreen::run() {
|
||||||
console.prepare();
|
console.prepare();
|
||||||
root.width = drawer_.width = console.width;
|
root.width_ = drawer_.width = console.width;
|
||||||
root.height = drawer_.height = console.height;
|
root.height_ = drawer_.height = console.height;
|
||||||
root.layout();
|
root.layout();
|
||||||
root.drawEventInternal(&drawer_);
|
root.drawEventInternal(&drawer_);
|
||||||
if (tile_dialog) {
|
if (tile_dialog) {
|
||||||
@@ -481,12 +481,12 @@ void PIScreen::run() {
|
|||||||
tile_dialog->sizeHint(sw, sh);
|
tile_dialog->sizeHint(sw, sh);
|
||||||
sw = piClampi(sw, tile_dialog->minimumWidth, tile_dialog->maximumWidth);
|
sw = piClampi(sw, tile_dialog->minimumWidth, tile_dialog->maximumWidth);
|
||||||
sh = piClampi(sh, tile_dialog->minimumHeight, tile_dialog->maximumHeight);
|
sh = piClampi(sh, tile_dialog->minimumHeight, tile_dialog->maximumHeight);
|
||||||
tile_dialog->x = (console.width - sw) / 2;
|
tile_dialog->x_ = (console.width - sw) / 2;
|
||||||
tile_dialog->y = (console.height - sh) / 2;
|
tile_dialog->y_ = (console.height - sh) / 2;
|
||||||
tile_dialog->width = sw;
|
tile_dialog->width_ = sw;
|
||||||
tile_dialog->height = sh;
|
tile_dialog->height_ = sh;
|
||||||
tile_dialog->layout();
|
tile_dialog->layout();
|
||||||
int dx = tile_dialog->x - 1, dy = tile_dialog->y - 1, dw = tile_dialog->width, dh = tile_dialog->height;
|
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,
|
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);
|
(Color)tile_dialog->back_format.color_back, (CharFlags)tile_dialog->back_format.flags);
|
||||||
tile_dialog->drawEventInternal(&drawer_);
|
tile_dialog->drawEventInternal(&drawer_);
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ PIScreenTile::PIScreenTile(const PIString & n, Direction d, SizePolicy p): PIObj
|
|||||||
size_policy = p;
|
size_policy = p;
|
||||||
focus_flags = 0;
|
focus_flags = 0;
|
||||||
screen = 0;
|
screen = 0;
|
||||||
minimumWidth = minimumHeight = x = y = width = height = pw = ph = 0;
|
minimumWidth = minimumHeight = x_ = y_ = width_ = height_ = pw = ph = 0;
|
||||||
maximumWidth = maximumHeight = 65535;
|
maximumWidth = maximumHeight = 65535;
|
||||||
marginLeft = marginRight = marginTop = marginBottom = spacing = 0;
|
marginLeft = marginRight = marginTop = marginBottom = spacing = 0;
|
||||||
parent = 0;
|
parent = 0;
|
||||||
@@ -121,7 +121,7 @@ void PIScreenTile::drawEventInternal(PIScreenDrawer * d) {
|
|||||||
//d->clearRect(x, y, x + width, y + height);
|
//d->clearRect(x, y, x + width, y + height);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
d->fillRect(x, y, x + width, y + height, back_symbol, (Color)back_format.color_char, (Color)back_format.color_back, back_format.flags);
|
d->fillRect(x_, y_, x_ + width_, y_ + height_, back_symbol, (Color)back_format.color_char, (Color)back_format.color_back, back_format.flags);
|
||||||
drawEvent(d);
|
drawEvent(d);
|
||||||
piForeach (PIScreenTile * t, tiles)
|
piForeach (PIScreenTile * t, tiles)
|
||||||
t->drawEventInternal(d);
|
t->drawEventInternal(d);
|
||||||
@@ -155,8 +155,8 @@ void PIScreenTile::sizeHint(int & w, int & h) const {
|
|||||||
void PIScreenTile::layout() {
|
void PIScreenTile::layout() {
|
||||||
if (tiles.isEmpty() || !visible) return;
|
if (tiles.isEmpty() || !visible) return;
|
||||||
int as(0), ts(0), ts2(0), ecnt(0), pcnt(0);
|
int as(0), ts(0), ts2(0), ecnt(0), pcnt(0);
|
||||||
ts = (direction == Horizontal) ? (width - marginLeft - marginRight) : (height - marginTop - marginBottom);
|
ts = (direction == Horizontal) ? (width_ - marginLeft - marginRight) : (height_ - marginTop - marginBottom);
|
||||||
ts2 = (direction != Horizontal) ? (width - marginLeft - marginRight) : (height - marginTop - marginBottom);
|
ts2 = (direction != Horizontal) ? (width_ - marginLeft - marginRight) : (height_ - marginTop - marginBottom);
|
||||||
ts -= spacing * (tiles.size_s() - 1);
|
ts -= spacing * (tiles.size_s() - 1);
|
||||||
PIVector<int> hints(tiles.size_s());
|
PIVector<int> hints(tiles.size_s());
|
||||||
PIVector<float> asizes(tiles.size_s());
|
PIVector<float> asizes(tiles.size_s());
|
||||||
@@ -218,25 +218,25 @@ void PIScreenTile::layout() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
int cx = x + marginLeft, cy = y + marginTop;
|
int cx = x_ + marginLeft, cy = y_ + marginTop;
|
||||||
for (int i = 0; i < tiles.size_s(); ++i) {
|
for (int i = 0; i < tiles.size_s(); ++i) {
|
||||||
PIScreenTile * t(tiles[i]);
|
PIScreenTile * t(tiles[i]);
|
||||||
if (!t->visible) continue;
|
if (!t->visible) continue;
|
||||||
t->x = cx;
|
t->x_ = cx;
|
||||||
t->y = cy;
|
t->y_ = cy;
|
||||||
if (direction == Horizontal) {
|
if (direction == Horizontal) {
|
||||||
t->width = hints[i];
|
t->width_ = hints[i];
|
||||||
t->height = ts2;
|
t->height_ = ts2;
|
||||||
cx += hints[i] + spacing;
|
cx += hints[i] + spacing;
|
||||||
} else {
|
} else {
|
||||||
t->width = ts2;
|
t->width_ = ts2;
|
||||||
t->height = hints[i];
|
t->height_ = hints[i];
|
||||||
cy += hints[i] + spacing;
|
cy += hints[i] + spacing;
|
||||||
}
|
}
|
||||||
if (t->pw != t->width || t->ph != t->height)
|
if (t->pw != t->width_ || t->ph != t->height_)
|
||||||
t->resizeEvent(t->width, t->height);
|
t->resizeEvent(t->width_, t->height_);
|
||||||
t->pw = t->width;
|
t->pw = t->width_;
|
||||||
t->ph = t->height;
|
t->ph = t->height_;
|
||||||
t->layout();
|
t->layout();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -46,6 +46,11 @@ public:
|
|||||||
bool hasFocus() const {return has_focus;}
|
bool hasFocus() const {return has_focus;}
|
||||||
void setMargins(int m) {marginLeft = marginRight = marginTop = marginBottom = m;}
|
void setMargins(int m) {marginLeft = marginRight = marginTop = marginBottom = m;}
|
||||||
void setMargins(int l, int r, int t, int b) {marginLeft = l; marginRight = r; marginTop = t; marginBottom = b;}
|
void setMargins(int l, int r, int t, int b) {marginLeft = l; marginRight = r; marginTop = t; marginBottom = b;}
|
||||||
|
|
||||||
|
int x() const {return x_;}
|
||||||
|
int y() const {return y_;}
|
||||||
|
int width() const {return width_;}
|
||||||
|
int height() const {return height_;}
|
||||||
|
|
||||||
PIScreenTypes::Direction direction;
|
PIScreenTypes::Direction direction;
|
||||||
PIScreenTypes::SizePolicy size_policy;
|
PIScreenTypes::SizePolicy size_policy;
|
||||||
@@ -81,7 +86,7 @@ protected:
|
|||||||
PIVector<PIScreenTile * > tiles;
|
PIVector<PIScreenTile * > tiles;
|
||||||
PIScreenTile * parent;
|
PIScreenTile * parent;
|
||||||
PIScreenTypes::PIScreenBase * screen;
|
PIScreenTypes::PIScreenBase * screen;
|
||||||
int x, y, width, height;
|
int x_, y_, width_, height_;
|
||||||
bool has_focus;
|
bool has_focus;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|||||||
@@ -48,11 +48,11 @@ void TileSimple::drawEvent(PIScreenDrawer * d) {
|
|||||||
Row & r(content[i]);
|
Row & r(content[i]);
|
||||||
int rx = 0;
|
int rx = 0;
|
||||||
switch (alignment) {
|
switch (alignment) {
|
||||||
case Left: rx = x; break;
|
case Left: rx = x_; break;
|
||||||
case Center: rx = x + (width - r.first.size_s()) / 2; break;
|
case Center: rx = x_ + (width_ - r.first.size_s()) / 2; break;
|
||||||
case Right: rx = x + width - r.first.size_s(); break;
|
case Right: rx = x_ + width_ - r.first.size_s(); break;
|
||||||
};
|
};
|
||||||
d->drawText(rx, y + i, r.first, (Color)r.second.color_char, (Color)r.second.color_back, r.second.flags);
|
d->drawText(rx, y_ + i, r.first, (Color)r.second.color_char, (Color)r.second.color_back, r.second.flags);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -77,23 +77,23 @@ void TileList::sizeHint(int & w, int & h) const {
|
|||||||
|
|
||||||
void TileList::drawEvent(PIScreenDrawer * d) {
|
void TileList::drawEvent(PIScreenDrawer * d) {
|
||||||
vert_line = d->artChar(PIScreenDrawer::LineVertical);
|
vert_line = d->artChar(PIScreenDrawer::LineVertical);
|
||||||
lhei = height - 2;
|
lhei = height_ - 2;
|
||||||
//int osp = piMini(3, lhei / 4);
|
//int osp = piMini(3, lhei / 4);
|
||||||
int is = piClampi(offset, 0, piMaxi(0, content.size_s() - 1)), ie = piClampi(offset + lhei, 0, content.size_s());
|
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 (is > 0) d->drawText(x_, y_, 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) {
|
for (int i = is; i < ie; ++i) {
|
||||||
Row & r(content[i]);
|
Row & r(content[i]);
|
||||||
bool sel = i == cur && has_focus;
|
bool sel = i == cur && has_focus;
|
||||||
if (sel) {
|
if (sel) {
|
||||||
int cy = y + i - is + 1;
|
int cy = y_ + i - is + 1;
|
||||||
d->drawLine(x, cy, x + width - 2, cy, ' ', Default, Blue);
|
d->drawLine(x_, cy, x_ + width_ - 2, cy, ' ', Default, Blue);
|
||||||
}
|
}
|
||||||
int rx(0);
|
int rx(0);
|
||||||
switch (alignment) {
|
switch (alignment) {
|
||||||
case Left: rx = x; break;
|
case Left: rx = x_; break;
|
||||||
case Center: rx = x + (width - 1 - r.first.size_s()) / 2; break;
|
case Center: rx = x_ + (width_ - 1 - r.first.size_s()) / 2; break;
|
||||||
case Right: rx = x + width - 1 - r.first.size_s(); break;
|
case Right: rx = x_ + width_ - 1 - r.first.size_s(); break;
|
||||||
};
|
};
|
||||||
CharFlags cf = r.second.flags;
|
CharFlags cf = r.second.flags;
|
||||||
Color cc = (Color)r.second.color_char;
|
Color cc = (Color)r.second.color_char;
|
||||||
@@ -101,18 +101,18 @@ void TileList::drawEvent(PIScreenDrawer * d) {
|
|||||||
cf |= Bold;
|
cf |= Bold;
|
||||||
cc = Yellow;
|
cc = Yellow;
|
||||||
}
|
}
|
||||||
d->drawText(rx, y + i - is + 1, r.first, cc, sel ? Blue : Default, cf);
|
d->drawText(rx, y_ + i - is + 1, r.first, cc, sel ? Blue : Default, cf);
|
||||||
}
|
}
|
||||||
int cx = x + width - 1;
|
int cx = x_ + width_ - 1;
|
||||||
d->drawLine(cx, y + 1, cx, y + height - 2, vert_line, Green);
|
d->drawLine(cx, y_ + 1, cx, y_ + height_ - 2, vert_line, Green);
|
||||||
if (content.size_s() > 1)
|
if (content.size_s() > 1)
|
||||||
d->drawPixel(cx, y + piRound(float(cur) / (content.size_s() - 1) * (lhei - 1)) + 1, ' ', Green, Green);
|
d->drawPixel(cx, y_ + piRound(float(cur) / (content.size_s() - 1) * (lhei - 1)) + 1, ' ', Green, Green);
|
||||||
if (ie < content.size_s()) d->drawText(x, y + height - 1, 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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool TileList::keyEvent(PIKbdListener::KeyEvent key) {
|
bool TileList::keyEvent(PIKbdListener::KeyEvent key) {
|
||||||
lhei = height - 2;
|
lhei = height_ - 2;
|
||||||
int oo(0), osp = piMini(3, lhei / 4);
|
int oo(0), osp = piMini(3, lhei / 4);
|
||||||
switch (key.key) {
|
switch (key.key) {
|
||||||
case PIKbdListener::PageUp:
|
case PIKbdListener::PageUp:
|
||||||
@@ -216,10 +216,10 @@ void TileButton::drawEvent(PIScreenDrawer * d) {
|
|||||||
Color cb = has_focus ? Blue : Cyan;
|
Color cb = has_focus ? Blue : Cyan;
|
||||||
Color ct = has_focus ? White : Black;
|
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->fillRect(x_, y_, x_ + width_, y_ + 1, ' ', Default, cb);
|
||||||
d->drawText(x, y, "[", ct, Transparent, ff);
|
d->drawText(x_, y_, "[", ct, Transparent, ff);
|
||||||
d->drawText(x + (width - text.size_s()) / 2, y, text, ct, Transparent, ff);
|
d->drawText(x_ + (width_ - text.size_s()) / 2, y_, text, ct, Transparent, ff);
|
||||||
d->drawText(x + width - 1, y, "]", ct, Transparent, ff);
|
d->drawText(x_ + width_ - 1, y_, "]", ct, Transparent, ff);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -259,12 +259,12 @@ void TileButtons::sizeHint(int & w, int & h) const {
|
|||||||
|
|
||||||
|
|
||||||
void TileButtons::drawEvent(PIScreenDrawer * d) {
|
void TileButtons::drawEvent(PIScreenDrawer * d) {
|
||||||
int cx = x, cy = y, shw, shh;
|
int cx = x_, cy = y_, shw, shh;
|
||||||
sizeHint(shw, shh);
|
sizeHint(shw, shh);
|
||||||
int dx = 0;
|
int dx = 0;
|
||||||
switch (alignment) {
|
switch (alignment) {
|
||||||
case PIScreenTypes::Center: dx = (width - shw) / 2; break;
|
case PIScreenTypes::Center: dx = (width_ - shw) / 2; break;
|
||||||
case PIScreenTypes::Right: dx = width - shw; break;
|
case PIScreenTypes::Right: dx = width_ - shw; break;
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
if (direction == PIScreenTypes::Horizontal)
|
if (direction == PIScreenTypes::Horizontal)
|
||||||
@@ -281,7 +281,7 @@ void TileButtons::drawEvent(PIScreenDrawer * d) {
|
|||||||
Button & b(content[i]);
|
Button & b(content[i]);
|
||||||
int cw = b.first.size_s() + 2, xo(0);
|
int cw = b.first.size_s() + 2, xo(0);
|
||||||
if (direction == Vertical) {
|
if (direction == Vertical) {
|
||||||
cw = width - 2;
|
cw = width_ - 2;
|
||||||
xo = (cw - b.first.size_s()) / 2 - 1;
|
xo = (cw - b.first.size_s()) / 2 - 1;
|
||||||
}
|
}
|
||||||
d->fillRect(cx, cy, cx + cw + 2, cy + 1, ' ', Default, cb);
|
d->fillRect(cx, cy, cx + cw + 2, cy + 1, ' ', Default, cb);
|
||||||
@@ -337,9 +337,9 @@ void TileCheck::drawEvent(PIScreenDrawer * d) {
|
|||||||
int ff = has_focus ? Bold : 0;
|
int ff = has_focus ? Bold : 0;
|
||||||
PIString cs("[ ]");
|
PIString cs("[ ]");
|
||||||
if (toggled) cs[1] = '*';
|
if (toggled) cs[1] = '*';
|
||||||
d->fillRect(x, y, x + width, y + 1, ' ', Default, cb);
|
d->fillRect(x_, y_, x_ + width_, y_ + 1, ' ', Default, cb);
|
||||||
d->drawText(x, y, cs, ct, Transparent, ff);
|
d->drawText(x_, y_, cs, ct, Transparent, ff);
|
||||||
d->drawText(x + 4, y, text, ct, Transparent, ff);
|
d->drawText(x_ + 4, y_, text, ct, Transparent, ff);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -371,17 +371,17 @@ void TileProgress::sizeHint(int & w, int & h) const {
|
|||||||
void TileProgress::drawEvent(PIScreenDrawer * d) {
|
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;
|
PIString s = prefix + PIString::fromNumber(piRoundd(value)) + suffix;
|
||||||
int w = piRoundd(v / 100. * width), sx = (width - s.size_s()) / 2;
|
int w = piRoundd(v / 100. * width_), sx = (width_ - s.size_s()) / 2;
|
||||||
d->fillRect(x, y, x + width, y + 1, ' ', Default, Cyan);
|
d->fillRect(x_, y_, x_ + width_, y_ + 1, ' ', Default, Cyan);
|
||||||
d->fillRect(x, y, x + w, y + 1, ' ', Default, Blue);
|
d->fillRect(x_, y_, x_ + w, y_ + 1, ' ', Default, Blue);
|
||||||
if (w < sx)
|
if (w < sx)
|
||||||
d->drawText(x + sx, y, s, Black, Transparent);
|
d->drawText(x_ + sx, y_, s, Black, Transparent);
|
||||||
else if (w >= sx + s.size_s())
|
else if (w >= sx + s.size_s())
|
||||||
d->drawText(x + sx, y, s, White, Transparent);
|
d->drawText(x_ + sx, y_, s, White, Transparent);
|
||||||
else {
|
else {
|
||||||
int fw = w - sx;
|
int fw = w - sx;
|
||||||
d->drawText(x + sx, y, s.left(fw), White, Transparent);
|
d->drawText(x_ + sx, y_, s.left(fw), White, Transparent);
|
||||||
d->drawText(x + sx + fw, y, s.cutLeft(fw), Black, Transparent);
|
d->drawText(x_ + sx + fw, y_, s.cutLeft(fw), Black, Transparent);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -443,12 +443,12 @@ void TileInput::sizeHint(int & w, int & h) const {
|
|||||||
|
|
||||||
|
|
||||||
void TileInput::drawEvent(PIScreenDrawer * d) {
|
void TileInput::drawEvent(PIScreenDrawer * d) {
|
||||||
PIString ps = text.mid(offset, width - 2);
|
PIString ps = text.mid(offset, width_ - 2);
|
||||||
d->drawText(x + 1, y, ps, (Color)format.color_char, Transparent, (CharFlags)format.flags);
|
d->drawText(x_ + 1, y_, ps, (Color)format.color_char, Transparent, (CharFlags)format.flags);
|
||||||
if (offset > 0)
|
if (offset > 0)
|
||||||
d->drawText(x, y, "<", Green, Black, Bold);
|
d->drawText(x_, y_, "<", Green, Black, Bold);
|
||||||
if (text.size_s() - offset >= width - 2)
|
if (text.size_s() - offset >= width_ - 2)
|
||||||
d->drawText(x + width - 1, y, ">", Green, Black, Bold);
|
d->drawText(x_ + width_ - 1, y_, ">", Green, Black, Bold);
|
||||||
if (!has_focus) return;
|
if (!has_focus) return;
|
||||||
Color cb = (Color)format.color_char, cc = (Color)format.color_back;
|
Color cb = (Color)format.color_char, cc = (Color)format.color_back;
|
||||||
if (tm_blink.elapsed_m() >= 650) {
|
if (tm_blink.elapsed_m() >= 650) {
|
||||||
@@ -456,12 +456,12 @@ void TileInput::drawEvent(PIScreenDrawer * d) {
|
|||||||
inv = !inv;
|
inv = !inv;
|
||||||
}
|
}
|
||||||
if (inv) piSwap(cb, cc);
|
if (inv) piSwap(cb, cc);
|
||||||
d->drawText(x + 1 + cur - offset, y, text.mid(cur, 1).expandLeftTo(1, ' '), cc, cb, (CharFlags)format.flags);
|
d->drawText(x_ + 1 + cur - offset, y_, text.mid(cur, 1).expandLeftTo(1, ' '), cc, cb, (CharFlags)format.flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool TileInput::keyEvent(PIKbdListener::KeyEvent key) {
|
bool TileInput::keyEvent(PIKbdListener::KeyEvent key) {
|
||||||
int lwid = piMaxi(0, width - 2);
|
int lwid = piMaxi(0, width_ - 2);
|
||||||
int oo(0), osp = piMini(3, lwid / 4);
|
int oo(0), osp = piMini(3, lwid / 4);
|
||||||
lwid--;
|
lwid--;
|
||||||
switch (key.key) {
|
switch (key.key) {
|
||||||
|
|||||||
@@ -124,6 +124,16 @@ void PITerminal::write(PIKbdListener::SpecialKey k, PIKbdListener::KeyModifiers
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void PITerminal::write(PIKbdListener::KeyEvent ke) {
|
||||||
|
if (isSpecialKey(ke.key)) write((PIKbdListener::SpecialKey)ke.key, ke.modifiers);
|
||||||
|
else {
|
||||||
|
PIByteArray ba;
|
||||||
|
ba << uchar(PIChar(ke.key).toConcole1Byte());
|
||||||
|
write(ba);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
PIVector<PIVector<PIScreenTypes::Cell> > PITerminal::content() {
|
PIVector<PIVector<PIScreenTypes::Cell> > PITerminal::content() {
|
||||||
readConsole();
|
readConsole();
|
||||||
return cells;
|
return cells;
|
||||||
|
|||||||
@@ -44,6 +44,7 @@ public:
|
|||||||
|
|
||||||
void write(const PIByteArray & d);
|
void write(const PIByteArray & d);
|
||||||
void write(PIKbdListener::SpecialKey k, PIKbdListener::KeyModifiers m);
|
void write(PIKbdListener::SpecialKey k, PIKbdListener::KeyModifiers m);
|
||||||
|
void write(PIKbdListener::KeyEvent ke);
|
||||||
PIVector<PIVector<PIScreenTypes::Cell> > content();
|
PIVector<PIVector<PIScreenTypes::Cell> > content();
|
||||||
static bool isSpecialKey(int k);
|
static bool isSpecialKey(int k);
|
||||||
|
|
||||||
|
|||||||
@@ -271,7 +271,7 @@ public:
|
|||||||
/** \fn void tickEvent(void * data, int delimiter)
|
/** \fn void tickEvent(void * data, int delimiter)
|
||||||
* \brief Raise on timer tick
|
* \brief Raise on timer tick
|
||||||
* \details \b Data can be set with function \a setData(void * data) or from constructor.
|
* \details \b Data can be set with function \a setData(void * data) or from constructor.
|
||||||
* \b Delimiter if frequency delimiter, 1 for main loop. */
|
* \b Delimiter is frequency delimiter, 1 for main loop. */
|
||||||
|
|
||||||
|
|
||||||
//! \}
|
//! \}
|
||||||
|
|||||||
@@ -9,21 +9,65 @@ extern PIScreen * screen;
|
|||||||
|
|
||||||
Daemon::Remote::Remote(const PIString & n): PIThread() {
|
Daemon::Remote::Remote(const PIString & n): PIThread() {
|
||||||
setName(n);
|
setName(n);
|
||||||
|
term = 0;
|
||||||
ft.setName(n);
|
ft.setName(n);
|
||||||
ft.setPacketSize(3984);
|
ft.setPacketSize(3984);
|
||||||
CONNECTU(&ft, sendRequest, this, ftSendRequest)
|
CONNECTU(&ft, sendRequest, this, ftSendRequest)
|
||||||
CONNECTU(&ft, receiveFilesFinished, this, ftReceived)
|
CONNECTU(&ft, receiveFilesFinished, this, ftReceived)
|
||||||
CONNECTU(&ft, sendFilesFinished, this, ftSended)
|
CONNECTU(&ft, sendFilesFinished, this, ftSended)
|
||||||
|
CONNECTU(&term_timer, tickEvent, this, termTimerTick)
|
||||||
dir_my = PIDir::current();
|
dir_my = PIDir::current();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Daemon::Remote::~Remote() {
|
Daemon::Remote::~Remote() {
|
||||||
|
shellClose();
|
||||||
ft.stop();
|
ft.stop();
|
||||||
stop(true);
|
stop(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Daemon::Remote::shellOpen() {
|
||||||
|
if (term) return;
|
||||||
|
term = new PITerminal();
|
||||||
|
term->initialize();
|
||||||
|
term_timer.start(40);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Daemon::Remote::shellClose() {
|
||||||
|
if (!term) return;
|
||||||
|
//piCoutObj << "shellClose ...";
|
||||||
|
term_timer.stop();
|
||||||
|
term_timer.waitForFinish(100);
|
||||||
|
term->destroy();
|
||||||
|
delete term;
|
||||||
|
term = 0;
|
||||||
|
//piCoutObj << "shellClose ok";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Daemon::Remote::shellResize(int w, int h) {
|
||||||
|
if (!term) return;
|
||||||
|
term->resize(w, h);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Daemon::Remote::shellKeySend(PIKbdListener::KeyEvent k) {
|
||||||
|
if (!term) return;
|
||||||
|
term->write(k);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Daemon::Remote::termTimerTick() {
|
||||||
|
if (!term) return;
|
||||||
|
PIVector<PIVector<PIScreenTypes::Cell> > cells = term->content();
|
||||||
|
PIByteArray ba;
|
||||||
|
ba << int(ShellContent) << cells;
|
||||||
|
sendRequest(name(), ba);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void Daemon::Remote::startAction(Daemon::PacketType a, const PIString & dir, const PIStringList & fl) {
|
void Daemon::Remote::startAction(Daemon::PacketType a, const PIString & dir, const PIStringList & fl) {
|
||||||
_fl = fl;
|
_fl = fl;
|
||||||
if (!dir.isEmpty())
|
if (!dir.isEmpty())
|
||||||
@@ -209,7 +253,8 @@ void Daemon::TileFileProgress::tileEvent(PIScreenTile * t, TileEvent e) {
|
|||||||
Daemon::Daemon(): inited__(false), PIPeer(pisd_prefix + PISystemInfo::instance()->hostname + "_" + PIString(rand() % 100)) {
|
Daemon::Daemon(): inited__(false), PIPeer(pisd_prefix + PISystemInfo::instance()->hostname + "_" + PIString(rand() % 100)) {
|
||||||
// setName("Daemon");
|
// setName("Daemon");
|
||||||
dtimer.setName("__S__Daemon_timer");
|
dtimer.setName("__S__Daemon_timer");
|
||||||
mode = offset = cur = height = 0;
|
mode = rmNone;
|
||||||
|
offset = cur = height = 0;
|
||||||
CONNECTU(screen, keyPressed, this, keyEvent)
|
CONNECTU(screen, keyPressed, this, keyEvent)
|
||||||
CONNECTU(&dtimer, tickEvent, this, timerEvent)
|
CONNECTU(&dtimer, tickEvent, this, timerEvent)
|
||||||
CONNECTU(&fm, tileKey, this, fmKeyEvent)
|
CONNECTU(&fm, tileKey, this, fmKeyEvent)
|
||||||
@@ -251,13 +296,21 @@ Daemon::Daemon(): inited__(false), PIPeer(pisd_prefix + PISystemInfo::instance()
|
|||||||
tile_fm->hide();
|
tile_fm->hide();
|
||||||
|
|
||||||
tile_file_progress = new TileFileProgress();
|
tile_file_progress = new TileFileProgress();
|
||||||
|
|
||||||
|
tile_shell = new TileTerminal("shell");
|
||||||
|
tile_shell->hide();
|
||||||
|
CONNECTU(tile_shell, resizeRequest, this, shResizeRequest)
|
||||||
|
CONNECTU(tile_shell, keyPressed, this, shKeyEvent)
|
||||||
|
CONNECTU(tile_shell, closeRequest, this, requestCloseShell)
|
||||||
|
CONNECTU(tile_shell, closeRequest, this, escPressed)
|
||||||
|
|
||||||
|
|
||||||
tile_root->addTile(tile_header);
|
tile_root->addTile(tile_header);
|
||||||
tile_root->addTile(list_daemons);
|
tile_root->addTile(list_daemons);
|
||||||
tile_root->addTile(list_actions);
|
tile_root->addTile(list_actions);
|
||||||
tile_root->addTile(tile_info);
|
tile_root->addTile(tile_info);
|
||||||
tile_root->addTile(tile_fm);
|
tile_root->addTile(tile_fm);
|
||||||
|
tile_root->addTile(tile_shell);
|
||||||
|
|
||||||
CONNECTU(screen, tileEvent, this, tileEvent)
|
CONNECTU(screen, tileEvent, this, tileEvent)
|
||||||
reinit();
|
reinit();
|
||||||
@@ -266,9 +319,12 @@ Daemon::Daemon(): inited__(false), PIPeer(pisd_prefix + PISystemInfo::instance()
|
|||||||
|
|
||||||
|
|
||||||
Daemon::~Daemon() {
|
Daemon::~Daemon() {
|
||||||
|
requestCloseShell();
|
||||||
PIVector<Remote*> rl = remotes.values();
|
PIVector<Remote*> rl = remotes.values();
|
||||||
piForeach (Remote * r, rl)
|
piForeach (Remote * r, rl) {
|
||||||
|
r->shellClose();
|
||||||
delete r;
|
delete r;
|
||||||
|
}
|
||||||
remotes.clear();
|
remotes.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -278,6 +334,40 @@ PIScreenTile * Daemon::tile() const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Daemon::escPressed() {
|
||||||
|
if (mode == rmNone)
|
||||||
|
menuRequest();
|
||||||
|
else {
|
||||||
|
if (mode > rmSelectMode) {
|
||||||
|
mode = rmSelectMode;
|
||||||
|
screen->lock();
|
||||||
|
tile_info->content.clear();
|
||||||
|
screen->unlock();
|
||||||
|
showActionList();
|
||||||
|
} else
|
||||||
|
disconnect();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Daemon::shResizeRequest() {
|
||||||
|
Remote * r = remotes.value(conn_name, 0);
|
||||||
|
if (!r) return;
|
||||||
|
PIByteArray ba;
|
||||||
|
ba << int(ShellResizeRequest) << int(tile_shell->width()) << int(tile_shell->height());
|
||||||
|
send(conn_name, ba);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Daemon::shKeyEvent(PIKbdListener::KeyEvent k) {
|
||||||
|
Remote * r = remotes.value(conn_name, 0);
|
||||||
|
if (!r) return;
|
||||||
|
PIByteArray ba;
|
||||||
|
ba << int(ShellKeyEvent) << k;
|
||||||
|
send(conn_name, ba);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void Daemon::localSend(const PIString & p_name, const PIByteArray & data) {
|
void Daemon::localSend(const PIString & p_name, const PIByteArray & data) {
|
||||||
//piCoutObj << "localSend" << localft.stateString();
|
//piCoutObj << "localSend" << localft.stateString();
|
||||||
PIByteArray h; h << int(FileTransfer);
|
PIByteArray h; h << int(FileTransfer);
|
||||||
@@ -292,6 +382,7 @@ void Daemon::hideAll() {
|
|||||||
tile_info->hide();
|
tile_info->hide();
|
||||||
list_daemons->hide();
|
list_daemons->hide();
|
||||||
tile_fm->hide();
|
tile_fm->hide();
|
||||||
|
tile_shell->hide();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -344,12 +435,20 @@ void Daemon::tileEvent(PIScreenTile * t, TileEvent e) {
|
|||||||
if (e.type == TileList::RowPressed) {
|
if (e.type == TileList::RowPressed) {
|
||||||
PIMutexLocker ml(remote_mutex);
|
PIMutexLocker ml(remote_mutex);
|
||||||
switch (e.data.toInt()) {
|
switch (e.data.toInt()) {
|
||||||
case 0: mode = 2; showTile(tile_info, "Information"); break;
|
case 0:
|
||||||
|
mode = rmInformation;
|
||||||
|
showTile(tile_info, "Information");
|
||||||
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
mode = 3;
|
mode = rmFileManager;
|
||||||
showTile(tile_fm, "File manager");
|
showTile(tile_fm, "File manager");
|
||||||
requestChDir(".");
|
requestChDir(".");
|
||||||
break;
|
break;
|
||||||
|
case 2:
|
||||||
|
mode = rmShell;
|
||||||
|
showTile(tile_shell, "Shell");
|
||||||
|
requestOpenShell();
|
||||||
|
break;
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -363,18 +462,7 @@ void Daemon::keyEvent(PIKbdListener::KeyEvent key) {
|
|||||||
if (screen->dialogTile()) return;
|
if (screen->dialogTile()) return;
|
||||||
switch (key.key) {
|
switch (key.key) {
|
||||||
case PIKbdListener::Esc:
|
case PIKbdListener::Esc:
|
||||||
if (mode == 0)
|
escPressed();
|
||||||
menuRequest();
|
|
||||||
else {
|
|
||||||
if (mode > 1) {
|
|
||||||
mode = 1;
|
|
||||||
screen->lock();
|
|
||||||
tile_info->content.clear();
|
|
||||||
screen->unlock();
|
|
||||||
showActionList();
|
|
||||||
} else
|
|
||||||
disconnect();
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
@@ -478,7 +566,7 @@ void Daemon::timerEvent(void * _d, int delim) {
|
|||||||
piForeachC (PIString & i, available_daemons)
|
piForeachC (PIString & i, available_daemons)
|
||||||
list_daemons->content << TileList::Row(i, CellFormat());
|
list_daemons->content << TileList::Row(i, CellFormat());
|
||||||
screen->unlock();
|
screen->unlock();
|
||||||
if (delim == 5 && mode == 2) {
|
if (delim == 5 && mode == rmInformation) {
|
||||||
if (conn_name.isEmpty()) return;
|
if (conn_name.isEmpty()) return;
|
||||||
PIByteArray ba; ba << int(RequestHostInfo);
|
PIByteArray ba; ba << int(RequestHostInfo);
|
||||||
send(conn_name, ba);
|
send(conn_name, ba);
|
||||||
@@ -502,13 +590,13 @@ PIStringList Daemon::availableDaemons() {
|
|||||||
void Daemon::connectToDaemon(const PIString & dn) {
|
void Daemon::connectToDaemon(const PIString & dn) {
|
||||||
if (dn.isEmpty()) return;
|
if (dn.isEmpty()) return;
|
||||||
conn_name = pisd_prefix + dn;
|
conn_name = pisd_prefix + dn;
|
||||||
mode = 1;
|
mode = rmSelectMode;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Daemon::disconnect() {
|
void Daemon::disconnect() {
|
||||||
conn_name.clear();
|
conn_name.clear();
|
||||||
mode = 0;
|
mode = rmNone;
|
||||||
showMainList();
|
showMainList();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -547,6 +635,7 @@ void Daemon::peerDisconnected(const PIString & p_name) {
|
|||||||
PIMutexLocker ml(remote_mutex);
|
PIMutexLocker ml(remote_mutex);
|
||||||
Remote * dt = remotes.value(p_name, 0);
|
Remote * dt = remotes.value(p_name, 0);
|
||||||
if (!dt) return;
|
if (!dt) return;
|
||||||
|
dt->shellClose();
|
||||||
if (tile_file_progress->ft == &(dt->ft)) {
|
if (tile_file_progress->ft == &(dt->ft)) {
|
||||||
tile_file_progress->close(false);
|
tile_file_progress->close(false);
|
||||||
}
|
}
|
||||||
@@ -615,7 +704,7 @@ void Daemon::dataReceived(const PIString & from, const PIByteArray & data) {
|
|||||||
Remote * r = remotes.value(from);
|
Remote * r = remotes.value(from);
|
||||||
PIString dir;
|
PIString dir;
|
||||||
int type; ba >> type;
|
int type; ba >> type;
|
||||||
// piCout << "rec from " << from << type << r;
|
//piCout << "rec from " << from << type << r;
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case RequestHostInfo:
|
case RequestHostInfo:
|
||||||
makeMyHostInfo();
|
makeMyHostInfo();
|
||||||
@@ -689,6 +778,32 @@ void Daemon::dataReceived(const PIString & from, const PIByteArray & data) {
|
|||||||
r->cryptFiles(files);
|
r->cryptFiles(files);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case ShellOpen:
|
||||||
|
if (!r) return;
|
||||||
|
r->shellOpen();
|
||||||
|
break;
|
||||||
|
case ShellClose:
|
||||||
|
if (!r) return;
|
||||||
|
r->shellClose();
|
||||||
|
break;
|
||||||
|
case ShellContent: {
|
||||||
|
if (!r) return;
|
||||||
|
PIVector<PIVector<PIScreenTypes::Cell> > cells;
|
||||||
|
ba >> cells;
|
||||||
|
tile_shell->setContent(cells);
|
||||||
|
} break;
|
||||||
|
case ShellResizeRequest: {
|
||||||
|
if (!r) return;
|
||||||
|
int w, h;
|
||||||
|
ba >> w >> h;
|
||||||
|
r->shellResize(w, h);
|
||||||
|
} break;
|
||||||
|
case ShellKeyEvent: {
|
||||||
|
if (!r) return;
|
||||||
|
PIKbdListener::KeyEvent k;
|
||||||
|
ba >> k;
|
||||||
|
r->shellKeySend(k);
|
||||||
|
} break;
|
||||||
};
|
};
|
||||||
if (!rba.isEmpty()) send(from, rba);
|
if (!rba.isEmpty()) send(from, rba);
|
||||||
}
|
}
|
||||||
@@ -703,6 +818,24 @@ void Daemon::sendDirToRemote(Remote * r) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Daemon::requestOpenShell() {
|
||||||
|
Remote * r = remotes.value(conn_name, 0);
|
||||||
|
if (!r) return;
|
||||||
|
PIByteArray ba;
|
||||||
|
ba << int(ShellOpen);
|
||||||
|
send(conn_name, ba);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Daemon::requestCloseShell() {
|
||||||
|
Remote * r = remotes.value(conn_name, 0);
|
||||||
|
if (!r) return;
|
||||||
|
PIByteArray ba;
|
||||||
|
ba << int(ShellClose);
|
||||||
|
send(conn_name, ba);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void Daemon::makeMyHostInfo() {
|
void Daemon::makeMyHostInfo() {
|
||||||
info_my.execCommand = PISystemInfo::instance()->execCommand;
|
info_my.execCommand = PISystemInfo::instance()->execCommand;
|
||||||
info_my.hostname = PISystemInfo::instance()->hostname;
|
info_my.hostname = PISystemInfo::instance()->hostname;
|
||||||
|
|||||||
@@ -7,6 +7,8 @@
|
|||||||
#include "pidatatransfer.h"
|
#include "pidatatransfer.h"
|
||||||
#include "pifiletransfer.h"
|
#include "pifiletransfer.h"
|
||||||
#include "file_manager.h"
|
#include "file_manager.h"
|
||||||
|
#include "terminal_tile.h"
|
||||||
|
#include "piterminal.h"
|
||||||
|
|
||||||
extern PISystemMonitor sys_mon;
|
extern PISystemMonitor sys_mon;
|
||||||
|
|
||||||
@@ -42,7 +44,7 @@ public:
|
|||||||
|
|
||||||
void showMainList() {showTile(list_daemons, "Select daemon");}
|
void showMainList() {showTile(list_daemons, "Select daemon");}
|
||||||
void showActionList() {showTile(list_actions, "Select action");}
|
void showActionList() {showTile(list_actions, "Select action");}
|
||||||
void showLocalFilemanager() {mode = 3; showTile(tile_fm, "File manager");}
|
void showLocalFilemanager() {mode = rmFileManager; showTile(tile_fm, "File manager");}
|
||||||
|
|
||||||
PIStringList availableDaemons();
|
PIStringList availableDaemons();
|
||||||
void connectToDaemon(const PIString & dn);
|
void connectToDaemon(const PIString & dn);
|
||||||
@@ -73,9 +75,23 @@ private:
|
|||||||
MkDir,
|
MkDir,
|
||||||
CryptFiles,
|
CryptFiles,
|
||||||
|
|
||||||
FileTransfer = 30
|
FileTransfer = 30,
|
||||||
|
|
||||||
|
ShellOpen = 40,
|
||||||
|
ShellClose,
|
||||||
|
ShellContent,
|
||||||
|
ShellResizeRequest,
|
||||||
|
ShellKeyEvent
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
enum RemoteMode {
|
||||||
|
rmNone,
|
||||||
|
rmSelectMode,
|
||||||
|
rmInformation,
|
||||||
|
rmFileManager,
|
||||||
|
rmShell
|
||||||
|
};
|
||||||
|
|
||||||
class Remote: public PIThread {
|
class Remote: public PIThread {
|
||||||
PIOBJECT_SUBCLASS(Remote, PIThread)
|
PIOBJECT_SUBCLASS(Remote, PIThread)
|
||||||
@@ -87,6 +103,10 @@ private:
|
|||||||
void updateDir() {startAction(Daemon::RequestChangeDir, PIString(), PIStringList());}
|
void updateDir() {startAction(Daemon::RequestChangeDir, PIString(), PIStringList());}
|
||||||
void makeDir(const PIString & dir) {startAction(Daemon::MkDir, dir, PIStringList() << "");}
|
void makeDir(const PIString & dir) {startAction(Daemon::MkDir, dir, PIStringList() << "");}
|
||||||
void cryptFiles(const PIStringList & fl) {startAction(Daemon::CryptFiles, PIString(), fl);}
|
void cryptFiles(const PIStringList & fl) {startAction(Daemon::CryptFiles, PIString(), fl);}
|
||||||
|
void shellOpen();
|
||||||
|
void shellClose();
|
||||||
|
void shellResize(int w, int h);
|
||||||
|
void shellKeySend(PIKbdListener::KeyEvent k);
|
||||||
EVENT_HANDLER1(void, ftSendRequest, PIByteArray &, data) {PIByteArray h; h << int(FileTransfer); data.insert(0, h); sendRequest(name(), data);}
|
EVENT_HANDLER1(void, ftSendRequest, PIByteArray &, data) {PIByteArray h; h << int(FileTransfer); data.insert(0, h); sendRequest(name(), data);}
|
||||||
EVENT_HANDLER1(void, ftReceived, bool, ok) {receiveFinished(name(), ok);}
|
EVENT_HANDLER1(void, ftReceived, bool, ok) {receiveFinished(name(), ok);}
|
||||||
EVENT_HANDLER1(void, ftSended, bool, ok) {sendFinished(name(), ok);}
|
EVENT_HANDLER1(void, ftSended, bool, ok) {sendFinished(name(), ok);}
|
||||||
@@ -96,6 +116,7 @@ private:
|
|||||||
EVENT2(sendFinished, const PIString & , p_name, bool, ok)
|
EVENT2(sendFinished, const PIString & , p_name, bool, ok)
|
||||||
EVENT2(changeDirFinished, const PIString & , p_name, const PIString & , dir)
|
EVENT2(changeDirFinished, const PIString & , p_name, const PIString & , dir)
|
||||||
EVENT_HANDLER1(void, received, PIByteArray & , data) {ft.received(data);}
|
EVENT_HANDLER1(void, received, PIByteArray & , data) {ft.received(data);}
|
||||||
|
EVENT_HANDLER(void, termTimerTick);
|
||||||
|
|
||||||
void startAction(PacketType a, const PIString & dir, const PIStringList & fl);
|
void startAction(PacketType a, const PIString & dir, const PIStringList & fl);
|
||||||
void run();
|
void run();
|
||||||
@@ -105,6 +126,8 @@ private:
|
|||||||
PIFileTransfer ft;
|
PIFileTransfer ft;
|
||||||
PIStringList _fl;
|
PIStringList _fl;
|
||||||
PacketType action;
|
PacketType action;
|
||||||
|
PITimer term_timer;
|
||||||
|
PITerminal * term;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void updateDirEntries();
|
void updateDirEntries();
|
||||||
@@ -134,11 +157,16 @@ private:
|
|||||||
EVENT_HANDLER2(void, sendRequest, const PIString &, p_name, const PIByteArray &, data) {send(p_name, data);}
|
EVENT_HANDLER2(void, sendRequest, const PIString &, p_name, const PIByteArray &, data) {send(p_name, data);}
|
||||||
EVENT_HANDLER1(void, fmKeyEvent, PIKbdListener::KeyEvent, key);
|
EVENT_HANDLER1(void, fmKeyEvent, PIKbdListener::KeyEvent, key);
|
||||||
EVENT_HANDLER3(void, fmActionRequest, bool, remote_tile, FileManager::Action, type, PIVariant, data);
|
EVENT_HANDLER3(void, fmActionRequest, bool, remote_tile, FileManager::Action, type, PIVariant, data);
|
||||||
|
EVENT_HANDLER (void, shResizeRequest);
|
||||||
|
EVENT_HANDLER1(void, shKeyEvent, PIKbdListener::KeyEvent, k);
|
||||||
EVENT_HANDLER2(void, timerEvent, void * , _d, int, delim);
|
EVENT_HANDLER2(void, timerEvent, void * , _d, int, delim);
|
||||||
EVENT_HANDLER2(void, filesReceived, const PIString & , p_name, bool, ok);
|
EVENT_HANDLER2(void, filesReceived, const PIString & , p_name, bool, ok);
|
||||||
EVENT_HANDLER2(void, dirChanged, const PIString & , p_name, const PIString & , dir);
|
EVENT_HANDLER2(void, dirChanged, const PIString & , p_name, const PIString & , dir);
|
||||||
EVENT_HANDLER2(void, closeFileDialog, const PIString & , p_name, bool, ok);
|
EVENT_HANDLER2(void, closeFileDialog, const PIString & , p_name, bool, ok);
|
||||||
EVENT_HANDLER2(void, localSend, const PIString & , p_name, const PIByteArray &, data);
|
EVENT_HANDLER2(void, localSend, const PIString & , p_name, const PIByteArray &, data);
|
||||||
|
EVENT_HANDLER (void, escPressed);
|
||||||
|
EVENT_HANDLER (void, requestOpenShell);
|
||||||
|
EVENT_HANDLER (void, requestCloseShell);
|
||||||
EVENT(menuRequest)
|
EVENT(menuRequest)
|
||||||
void hideAll();
|
void hideAll();
|
||||||
void showTile(PIScreenTile * t, const PIString & header = PIString());
|
void showTile(PIScreenTile * t, const PIString & header = PIString());
|
||||||
@@ -163,9 +191,11 @@ private:
|
|||||||
TileSimple * tile_info, * tile_header;
|
TileSimple * tile_info, * tile_header;
|
||||||
TileList * list_daemons, * list_actions;
|
TileList * list_daemons, * list_actions;
|
||||||
TileFileProgress * tile_file_progress;
|
TileFileProgress * tile_file_progress;
|
||||||
|
TileTerminal * tile_shell;
|
||||||
PIFileTransfer localft;
|
PIFileTransfer localft;
|
||||||
Remote * _self;
|
Remote * _self;
|
||||||
int mode, offset, cur, height;
|
RemoteMode mode;
|
||||||
|
int offset, cur, height;
|
||||||
bool inited__;
|
bool inited__;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -201,9 +201,9 @@ void FileManager::TileDir::buildNames() {
|
|||||||
scol = scol.expandRightTo(9, ' ') + "| " + e.time_modification.toString("dd.MM hh:mm:ss") + " | "
|
scol = scol.expandRightTo(9, ' ') + "| " + e.time_modification.toString("dd.MM hh:mm:ss") + " | "
|
||||||
+ e.perm_user.toString() + " " + e.perm_group.toString() + " " + e.perm_other.toString();
|
+ e.perm_user.toString() + " " + e.perm_group.toString() + " " + e.perm_other.toString();
|
||||||
fcol = t + e.name();
|
fcol = t + e.name();
|
||||||
if (fcol.size_s() >= width - 2 - scol.size_s())
|
if (fcol.size_s() >= width_ - 2 - scol.size_s())
|
||||||
fcol = fcol.left(width - 5 - scol.size_s()) + "...";
|
fcol = fcol.left(width_ - 5 - scol.size_s()) + "...";
|
||||||
fcol.expandRightTo(width - 1 - scol.size_s(), ' ');
|
fcol.expandRightTo(width_ - 1 - scol.size_s(), ' ');
|
||||||
content << Row(fcol + scol, CellFormat(cc, Transparent, cf));
|
content << Row(fcol + scol, CellFormat(cc, Transparent, cf));
|
||||||
}
|
}
|
||||||
unlock();
|
unlock();
|
||||||
|
|||||||
44
utils/system_daemon/terminal_tile.cpp
Normal file
44
utils/system_daemon/terminal_tile.cpp
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
#include "terminal_tile.h"
|
||||||
|
#include "piscreendrawer.h"
|
||||||
|
|
||||||
|
|
||||||
|
TileTerminal::TileTerminal(const PIString & n): PIScreenTile(n) {
|
||||||
|
focus_flags = PIScreenTypes::CanHasFocus;
|
||||||
|
size_policy = PIScreenTypes::Expanding;
|
||||||
|
lastp[0] = lastp[1] = lastp[2] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void TileTerminal::drawEvent(PIScreenDrawer * d) {
|
||||||
|
//piCout << "draw" << visible;
|
||||||
|
//PIVector<PIVector<PIScreenTypes::Cell> > c = term->content();
|
||||||
|
d->fillRect(x_, y_, x_ + width_, y_ + height_, cells);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool TileTerminal::keyEvent(PIKbdListener::KeyEvent key) {
|
||||||
|
lastp[0] = lastp[1];
|
||||||
|
lastp[1] = lastp[2];
|
||||||
|
lastp[2] = char(key.key);
|
||||||
|
if (lastp[0] == '\e' && lastp[1] == '~' && lastp[2] == '.') {
|
||||||
|
closeRequest();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
//piCout << "key";
|
||||||
|
/*if (!term) return false;
|
||||||
|
if (PITerminal::isSpecialKey(key.key)) term->write((PIKbdListener::SpecialKey)key.key, key.modifiers);
|
||||||
|
else {
|
||||||
|
PIByteArray ba;
|
||||||
|
ba << PIChar(key.key).toConcole1Byte();
|
||||||
|
term->write(ba);
|
||||||
|
}*/
|
||||||
|
keyPressed(key);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void TileTerminal::resizeEvent(int w, int h) {
|
||||||
|
/*if (!term) return;
|
||||||
|
term->resize(w, h);*/
|
||||||
|
resizeRequest();
|
||||||
|
}
|
||||||
30
utils/system_daemon/terminal_tile.h
Normal file
30
utils/system_daemon/terminal_tile.h
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
#ifndef TERMINAL_TILE_H
|
||||||
|
#define TERMINAL_TILE_H
|
||||||
|
|
||||||
|
#include "piscreentile.h"
|
||||||
|
#include "pikbdlistener.h"
|
||||||
|
|
||||||
|
|
||||||
|
class TileTerminal: public PIScreenTile {
|
||||||
|
PIOBJECT_SUBCLASS(TileTerminal, PIScreenTile)
|
||||||
|
public:
|
||||||
|
TileTerminal(const PIString & n);
|
||||||
|
|
||||||
|
void setContent(const PIVector<PIVector<PIScreenTypes::Cell> > & c) {cells = c;}
|
||||||
|
|
||||||
|
EVENT(resizeRequest)
|
||||||
|
EVENT1(keyPressed, PIKbdListener::KeyEvent, k)
|
||||||
|
EVENT(closeRequest)
|
||||||
|
|
||||||
|
private:
|
||||||
|
void drawEvent(PIScreenDrawer * d);
|
||||||
|
bool keyEvent(PIKbdListener::KeyEvent key);
|
||||||
|
void resizeEvent(int w, int h);
|
||||||
|
|
||||||
|
PIVector<PIVector<PIScreenTypes::Cell> > cells;
|
||||||
|
char lastp[3];
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#endif // TERMINAL_TILE_H
|
||||||
Reference in New Issue
Block a user