2021-05-10 02:32:27 +08:00
|
|
|
#include <array> // for array
|
|
|
|
#include <chrono> // for operator""s, chrono_literals
|
2021-05-02 02:40:35 +08:00
|
|
|
#include <cmath> // for sin
|
2021-05-10 02:32:27 +08:00
|
|
|
#include <functional> // for ref, reference_wrapper, function
|
2021-05-15 03:43:35 +08:00
|
|
|
#include <memory> // for allocator, shared_ptr, __shared_ptr_access
|
|
|
|
#include <string> // for wstring, basic_string, operator+, to_wstring
|
|
|
|
#include <thread> // for sleep_for, thread
|
|
|
|
#include <utility> // for move
|
|
|
|
#include <vector> // for vector
|
2020-03-23 05:32:44 +08:00
|
|
|
|
2021-05-10 02:32:27 +08:00
|
|
|
#include "ftxui/component/captured_mouse.hpp" // for ftxui
|
2021-05-15 03:43:35 +08:00
|
|
|
#include "ftxui/component/component.hpp" // for Checkbox, Renderer, Horizontal, Vertical, Input, Menu, Radiobox, Tab, Toggle
|
2021-05-10 02:32:27 +08:00
|
|
|
#include "ftxui/component/component_base.hpp" // for ComponentBase
|
|
|
|
#include "ftxui/component/event.hpp" // for Event, Event::Custom
|
|
|
|
#include "ftxui/component/input.hpp" // for InputBase
|
|
|
|
#include "ftxui/component/screen_interactive.hpp" // for Component, ScreenInteractive
|
2021-05-15 03:43:35 +08:00
|
|
|
#include "ftxui/dom/elements.hpp" // for text, operator|, color, bgcolor, Element, filler, size, vbox, flex, hbox, graph, separator, EQUAL, WIDTH, hcenter, bold, border, window, HEIGHT, Elements, hflow, flex_grow, frame, gauge, LESS_THAN, spinner, dim, GREATER_THAN
|
2021-05-10 02:32:27 +08:00
|
|
|
#include "ftxui/screen/color.hpp" // for Color, Color::BlueLight, Color::RedLight, Color::Black, Color::Blue, Color::Cyan, Color::CyanLight, Color::GrayDark, Color::GrayLight, Color::Green, Color::GreenLight, Color::Magenta, Color::MagentaLight, Color::Red, Color::White, Color::Yellow, Color::YellowLight, Color::Default
|
2019-01-27 09:33:06 +08:00
|
|
|
|
|
|
|
using namespace ftxui;
|
|
|
|
|
2021-05-13 17:44:47 +08:00
|
|
|
int main(int argc, const char* argv[]) {
|
|
|
|
auto screen = ScreenInteractive::Fullscreen();
|
2019-01-27 09:33:06 +08:00
|
|
|
|
2021-05-13 17:44:47 +08:00
|
|
|
int shift = 0;
|
2019-01-27 09:33:06 +08:00
|
|
|
|
2021-05-13 17:44:47 +08:00
|
|
|
class Graph {
|
|
|
|
public:
|
|
|
|
Graph(int* shift) : shift_(shift) {}
|
|
|
|
std::vector<int> operator()(int width, int height) {
|
|
|
|
std::vector<int> output(width);
|
|
|
|
for (int i = 0; i < width; ++i) {
|
|
|
|
float v = 0;
|
|
|
|
v += 0.1f * sin((i + *shift_) * 0.1f);
|
|
|
|
v += 0.2f * sin((i + *shift_ + 10) * 0.15f);
|
|
|
|
v += 0.1f * sin((i + *shift_) * 0.03f);
|
|
|
|
v *= height;
|
|
|
|
v += 0.5f * height;
|
|
|
|
output[i] = (int)v;
|
|
|
|
}
|
|
|
|
return output;
|
|
|
|
}
|
|
|
|
int* shift_;
|
|
|
|
};
|
2019-01-27 09:33:06 +08:00
|
|
|
|
2021-05-13 17:44:47 +08:00
|
|
|
Graph my_graph(&shift);
|
|
|
|
auto htop = Renderer([&] {
|
2020-05-21 02:36:47 +08:00
|
|
|
auto frequency = vbox({
|
|
|
|
text(L"Frequency [Mhz]") | hcenter,
|
|
|
|
hbox({
|
|
|
|
vbox({
|
|
|
|
text(L"2400 "),
|
|
|
|
filler(),
|
|
|
|
text(L"1200 "),
|
|
|
|
filler(),
|
|
|
|
text(L"0% "),
|
|
|
|
}),
|
|
|
|
graph(std::ref(my_graph)) | flex,
|
|
|
|
}) | flex,
|
|
|
|
});
|
|
|
|
|
|
|
|
auto utilization = vbox({
|
|
|
|
text(L"Utilization [%]") | hcenter,
|
|
|
|
hbox({
|
|
|
|
vbox({
|
|
|
|
text(L"100 "),
|
|
|
|
filler(),
|
|
|
|
text(L"50 "),
|
|
|
|
filler(),
|
|
|
|
text(L"0 "),
|
|
|
|
}),
|
|
|
|
graph(std::ref(my_graph)) | color(Color::RedLight),
|
|
|
|
}) | flex,
|
|
|
|
});
|
|
|
|
|
|
|
|
auto ram = vbox({
|
|
|
|
text(L"Ram [Mo]") | hcenter,
|
|
|
|
hbox({
|
|
|
|
vbox({
|
|
|
|
text(L"8192"),
|
|
|
|
filler(),
|
|
|
|
text(L"4096 "),
|
|
|
|
filler(),
|
|
|
|
text(L"0 "),
|
|
|
|
}),
|
|
|
|
graph(std::ref(my_graph)) | color(Color::BlueLight),
|
|
|
|
}) | flex,
|
|
|
|
});
|
|
|
|
|
|
|
|
return hbox({
|
|
|
|
vbox({
|
|
|
|
frequency | flex,
|
|
|
|
separator(),
|
|
|
|
utilization | flex,
|
|
|
|
}) | flex,
|
|
|
|
separator(),
|
|
|
|
ram | flex,
|
|
|
|
}) |
|
|
|
|
flex | border;
|
2021-05-13 17:44:47 +08:00
|
|
|
});
|
2019-01-27 09:33:06 +08:00
|
|
|
|
2021-05-13 17:44:47 +08:00
|
|
|
const std::vector<std::wstring> compiler_entries = {
|
|
|
|
L"gcc",
|
|
|
|
L"clang",
|
|
|
|
L"emcc",
|
|
|
|
L"game_maker",
|
|
|
|
L"Ada compilers",
|
|
|
|
L"ALGOL 60 compilers",
|
|
|
|
L"ALGOL 68 compilers",
|
|
|
|
L"Assemblers (Intel *86)",
|
|
|
|
L"Assemblers (Motorola 68*)",
|
|
|
|
L"Assemblers (Zilog Z80)",
|
|
|
|
L"Assemblers (other)",
|
|
|
|
L"BASIC Compilers",
|
|
|
|
L"BASIC interpreters",
|
|
|
|
L"Batch compilers",
|
|
|
|
L"C compilers",
|
|
|
|
L"Source-to-source compilers",
|
|
|
|
L"C++ compilers",
|
|
|
|
L"C# compilers",
|
|
|
|
L"COBOL compilers",
|
|
|
|
L"Common Lisp compilers",
|
|
|
|
L"D compilers",
|
|
|
|
L"DIBOL/DBL compilers",
|
|
|
|
L"ECMAScript interpreters",
|
|
|
|
L"Eiffel compilers",
|
|
|
|
L"Fortran compilers",
|
|
|
|
L"Go compilers",
|
|
|
|
L"Haskell compilers",
|
|
|
|
L"Java compilers",
|
|
|
|
L"Pascal compilers",
|
|
|
|
L"Perl Interpreters",
|
|
|
|
L"PHP compilers",
|
|
|
|
L"PL/I compilers",
|
|
|
|
L"Python compilers",
|
|
|
|
L"Scheme compilers and interpreters",
|
|
|
|
L"Smalltalk compilers",
|
|
|
|
L"Tcl Interpreters",
|
|
|
|
L"VMS Interpreters",
|
|
|
|
L"Rexx Interpreters",
|
|
|
|
L"CLI compilers",
|
|
|
|
};
|
2019-01-27 09:33:06 +08:00
|
|
|
|
2021-05-10 02:32:27 +08:00
|
|
|
int compiler_selected = 0;
|
|
|
|
Component compiler = Radiobox(&compiler_entries, &compiler_selected);
|
2019-01-27 09:33:06 +08:00
|
|
|
|
2021-05-10 02:32:27 +08:00
|
|
|
std::array<std::wstring, 4> options_label = {
|
|
|
|
L"-Wall",
|
|
|
|
L"-Werror",
|
|
|
|
L"-lpthread",
|
|
|
|
L"-O3",
|
|
|
|
};
|
|
|
|
std::array<bool, 4> options_state = {
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
};
|
2021-05-15 03:43:35 +08:00
|
|
|
std::wstring input_add_content;
|
|
|
|
Component input_add = Input(&input_add_content, "input files");
|
2019-01-27 09:33:06 +08:00
|
|
|
|
2021-05-10 02:32:27 +08:00
|
|
|
std::vector<std::wstring> input_entries;
|
|
|
|
int input_selected = 0;
|
|
|
|
Component input = Menu(&input_entries, &input_selected);
|
2019-01-27 09:33:06 +08:00
|
|
|
|
2021-05-10 02:32:27 +08:00
|
|
|
std::wstring executable_content_ = L"";
|
2021-05-15 03:43:35 +08:00
|
|
|
Component executable_ = Input(&executable_content_, "executable");
|
2019-01-27 09:33:06 +08:00
|
|
|
|
2021-05-10 02:32:27 +08:00
|
|
|
Component flags = Container::Vertical({
|
|
|
|
Checkbox(&options_label[0], &options_state[0]),
|
|
|
|
Checkbox(&options_label[1], &options_state[1]),
|
|
|
|
Checkbox(&options_label[2], &options_state[2]),
|
|
|
|
Checkbox(&options_label[3], &options_state[3]),
|
|
|
|
});
|
2019-01-27 09:33:06 +08:00
|
|
|
|
2021-05-13 17:44:47 +08:00
|
|
|
auto compiler_component = Container::Horizontal({
|
|
|
|
compiler,
|
|
|
|
flags,
|
|
|
|
Container::Vertical({
|
|
|
|
executable_,
|
|
|
|
Container::Horizontal({
|
|
|
|
input_add,
|
|
|
|
input,
|
|
|
|
}),
|
|
|
|
}),
|
|
|
|
});
|
|
|
|
|
|
|
|
InputBase::From(input_add)->on_enter = [&] {
|
|
|
|
input_entries.push_back(input_add_content);
|
|
|
|
input_add_content = L"";
|
|
|
|
};
|
2021-05-10 02:32:27 +08:00
|
|
|
|
2021-05-13 17:44:47 +08:00
|
|
|
auto render_command = [&] {
|
|
|
|
Elements line;
|
|
|
|
// Compiler
|
|
|
|
line.push_back(text(compiler_entries[compiler_selected]) | bold);
|
|
|
|
// flags
|
|
|
|
for (int i = 0; i < 4; ++i) {
|
|
|
|
if (options_state[i]) {
|
|
|
|
line.push_back(text(L" "));
|
|
|
|
line.push_back(text(options_label[i]) | dim);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// Executable
|
|
|
|
if (!executable_content_.empty()) {
|
2021-06-07 13:30:09 +08:00
|
|
|
line.push_back(text(L" -o ") | bold);
|
2021-05-13 17:44:47 +08:00
|
|
|
line.push_back(text(executable_content_) | color(Color::BlueLight) |
|
|
|
|
bold);
|
|
|
|
}
|
|
|
|
// Input
|
|
|
|
for (auto& it : input_entries) {
|
|
|
|
line.push_back(text(L" " + it) | color(Color::RedLight));
|
|
|
|
}
|
|
|
|
return line;
|
|
|
|
};
|
2019-01-27 09:33:06 +08:00
|
|
|
|
2021-05-13 17:44:47 +08:00
|
|
|
auto compiler_renderer = Renderer(compiler_component, [&] {
|
2021-05-10 02:32:27 +08:00
|
|
|
auto compiler_win = window(text(L"Compiler"), compiler->Render() | frame);
|
|
|
|
auto flags_win = window(text(L"Flags"), flags->Render());
|
|
|
|
auto executable_win = window(text(L"Executable:"), executable_->Render());
|
2020-05-21 02:36:47 +08:00
|
|
|
auto input_win =
|
|
|
|
window(text(L"Input"),
|
|
|
|
hbox({
|
|
|
|
vbox({
|
|
|
|
hbox({
|
|
|
|
text(L"Add: "),
|
2021-05-10 02:32:27 +08:00
|
|
|
input_add->Render(),
|
2020-05-21 02:36:47 +08:00
|
|
|
}) | size(WIDTH, EQUAL, 20) |
|
|
|
|
size(HEIGHT, EQUAL, 1),
|
|
|
|
filler(),
|
|
|
|
}),
|
|
|
|
separator(),
|
2021-05-10 02:32:27 +08:00
|
|
|
input->Render() | frame | size(HEIGHT, EQUAL, 3) | flex,
|
2020-05-21 02:36:47 +08:00
|
|
|
}));
|
|
|
|
return vbox({
|
|
|
|
hbox({
|
|
|
|
compiler_win | size(HEIGHT, LESS_THAN, 6),
|
|
|
|
flags_win,
|
|
|
|
vbox({
|
|
|
|
executable_win | size(WIDTH, EQUAL, 20),
|
|
|
|
input_win | size(WIDTH, EQUAL, 60),
|
|
|
|
}),
|
|
|
|
filler(),
|
|
|
|
}),
|
2021-05-13 17:44:47 +08:00
|
|
|
hflow(render_command()) | flex_grow,
|
2020-05-21 02:36:47 +08:00
|
|
|
}) |
|
2020-06-02 05:40:32 +08:00
|
|
|
flex_grow | border;
|
2021-05-13 17:44:47 +08:00
|
|
|
});
|
2019-01-27 09:33:06 +08:00
|
|
|
|
2021-05-13 17:44:47 +08:00
|
|
|
auto spinner_tab_renderer = Renderer([&] {
|
2019-01-27 09:33:06 +08:00
|
|
|
Elements entries;
|
2020-05-21 02:36:47 +08:00
|
|
|
for (int i = 0; i < 22; ++i) {
|
2021-05-13 17:44:47 +08:00
|
|
|
entries.push_back(spinner(i, shift / 2) | bold |
|
|
|
|
size(WIDTH, GREATER_THAN, 2) | border);
|
2019-01-27 09:33:06 +08:00
|
|
|
}
|
|
|
|
return hflow(std::move(entries)) | border;
|
2021-05-13 17:44:47 +08:00
|
|
|
});
|
2019-01-27 09:33:06 +08:00
|
|
|
|
2021-05-13 17:44:47 +08:00
|
|
|
auto color_tab_renderer = Renderer([] {
|
2020-05-21 02:36:47 +08:00
|
|
|
return hbox({
|
|
|
|
vbox({
|
|
|
|
color(Color::Default, text(L"Default")),
|
|
|
|
color(Color::Black, text(L"Black")),
|
|
|
|
color(Color::GrayDark, text(L"GrayDark")),
|
|
|
|
color(Color::GrayLight, text(L"GrayLight")),
|
|
|
|
color(Color::White, text(L"White")),
|
|
|
|
color(Color::Blue, text(L"Blue")),
|
|
|
|
color(Color::BlueLight, text(L"BlueLight")),
|
|
|
|
color(Color::Cyan, text(L"Cyan")),
|
|
|
|
color(Color::CyanLight, text(L"CyanLight")),
|
|
|
|
color(Color::Green, text(L"Green")),
|
|
|
|
color(Color::GreenLight, text(L"GreenLight")),
|
|
|
|
color(Color::Magenta, text(L"Magenta")),
|
|
|
|
color(Color::MagentaLight, text(L"MagentaLight")),
|
|
|
|
color(Color::Red, text(L"Red")),
|
|
|
|
color(Color::RedLight, text(L"RedLight")),
|
|
|
|
color(Color::Yellow, text(L"Yellow")),
|
|
|
|
color(Color::YellowLight, text(L"YellowLight")),
|
|
|
|
}),
|
|
|
|
vbox({
|
|
|
|
bgcolor(Color::Default, text(L"Default")),
|
|
|
|
bgcolor(Color::Black, text(L"Black")),
|
|
|
|
bgcolor(Color::GrayDark, text(L"GrayDark")),
|
|
|
|
bgcolor(Color::GrayLight, text(L"GrayLight")),
|
|
|
|
bgcolor(Color::White, text(L"White")),
|
|
|
|
bgcolor(Color::Blue, text(L"Blue")),
|
|
|
|
bgcolor(Color::BlueLight, text(L"BlueLight")),
|
|
|
|
bgcolor(Color::Cyan, text(L"Cyan")),
|
|
|
|
bgcolor(Color::CyanLight, text(L"CyanLight")),
|
|
|
|
bgcolor(Color::Green, text(L"Green")),
|
|
|
|
bgcolor(Color::GreenLight, text(L"GreenLight")),
|
|
|
|
bgcolor(Color::Magenta, text(L"Magenta")),
|
|
|
|
bgcolor(Color::MagentaLight, text(L"MagentaLight")),
|
|
|
|
bgcolor(Color::Red, text(L"Red")),
|
|
|
|
bgcolor(Color::RedLight, text(L"RedLight")),
|
|
|
|
bgcolor(Color::Yellow, text(L"Yellow")),
|
|
|
|
bgcolor(Color::YellowLight, text(L"YellowLight")),
|
|
|
|
}),
|
|
|
|
}) |
|
|
|
|
hcenter | border;
|
2021-05-13 17:44:47 +08:00
|
|
|
});
|
2019-01-27 23:15:42 +08:00
|
|
|
|
2021-05-13 17:44:47 +08:00
|
|
|
auto render_gauge = [&shift](int delta) {
|
2019-01-27 23:15:42 +08:00
|
|
|
float progress = (shift + delta) % 1000 / 1000.f;
|
2020-05-21 02:36:47 +08:00
|
|
|
return hbox({
|
|
|
|
text(std::to_wstring(int(progress * 100)) + L"% ") |
|
|
|
|
size(WIDTH, EQUAL, 5),
|
|
|
|
gauge(progress),
|
|
|
|
});
|
2021-05-13 17:44:47 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
auto gauge_component = Renderer([render_gauge] {
|
2020-05-21 02:36:47 +08:00
|
|
|
return vbox({
|
2021-05-13 17:44:47 +08:00
|
|
|
render_gauge(0) | color(Color::Black),
|
|
|
|
render_gauge(100) | color(Color::GrayDark),
|
|
|
|
render_gauge(50) | color(Color::GrayLight),
|
|
|
|
render_gauge(6894) | color(Color::White),
|
2020-05-21 02:36:47 +08:00
|
|
|
separator(),
|
2021-05-13 17:44:47 +08:00
|
|
|
render_gauge(6841) | color(Color::Blue),
|
|
|
|
render_gauge(9813) | color(Color::BlueLight),
|
|
|
|
render_gauge(98765) | color(Color::Cyan),
|
|
|
|
render_gauge(98) | color(Color::CyanLight),
|
|
|
|
render_gauge(9846) | color(Color::Green),
|
|
|
|
render_gauge(1122) | color(Color::GreenLight),
|
|
|
|
render_gauge(84) | color(Color::Magenta),
|
|
|
|
render_gauge(645) | color(Color::MagentaLight),
|
|
|
|
render_gauge(568) | color(Color::Red),
|
|
|
|
render_gauge(2222) | color(Color::RedLight),
|
|
|
|
render_gauge(220) | color(Color::Yellow),
|
|
|
|
render_gauge(348) | color(Color::YellowLight),
|
2020-05-21 02:36:47 +08:00
|
|
|
}) |
|
|
|
|
border;
|
2021-05-13 17:44:47 +08:00
|
|
|
});
|
2019-01-27 23:15:42 +08:00
|
|
|
|
2021-05-10 02:32:27 +08:00
|
|
|
int tab_index = 0;
|
|
|
|
std::vector<std::wstring> tab_entries = {
|
|
|
|
L"htop", L"color", L"spinner", L"gauge", L"compiler",
|
|
|
|
};
|
2021-05-13 17:44:47 +08:00
|
|
|
auto tab_selection = Toggle(&tab_entries, &tab_index);
|
2021-05-15 08:32:42 +08:00
|
|
|
auto tab_content = Container::Tab(
|
|
|
|
{
|
|
|
|
htop,
|
|
|
|
color_tab_renderer,
|
|
|
|
spinner_tab_renderer,
|
|
|
|
gauge_component,
|
|
|
|
compiler_renderer,
|
|
|
|
},
|
|
|
|
&tab_index);
|
2019-01-27 09:33:06 +08:00
|
|
|
|
2021-05-13 17:44:47 +08:00
|
|
|
auto main_container = Container::Vertical({
|
2021-05-10 02:32:27 +08:00
|
|
|
tab_selection,
|
2021-05-13 17:44:47 +08:00
|
|
|
tab_content,
|
2021-05-10 02:32:27 +08:00
|
|
|
});
|
2019-01-27 09:33:06 +08:00
|
|
|
|
2021-05-13 17:44:47 +08:00
|
|
|
auto main_renderer = Renderer(main_container, [&] {
|
2020-05-21 02:36:47 +08:00
|
|
|
return vbox({
|
|
|
|
text(L"FTXUI Demo") | bold | hcenter,
|
2021-05-10 02:32:27 +08:00
|
|
|
tab_selection->Render() | hcenter,
|
2021-05-13 17:44:47 +08:00
|
|
|
tab_content->Render() | flex,
|
2020-05-21 02:36:47 +08:00
|
|
|
});
|
2021-05-13 17:44:47 +08:00
|
|
|
});
|
2019-01-27 09:33:06 +08:00
|
|
|
|
2021-06-26 07:37:18 +08:00
|
|
|
bool refresh_ui_continue = true;
|
|
|
|
std::thread refresh_ui([&] {
|
2021-06-27 23:53:17 +08:00
|
|
|
while (refresh_ui_continue) {
|
2019-01-27 09:33:06 +08:00
|
|
|
using namespace std::chrono_literals;
|
|
|
|
std::this_thread::sleep_for(0.05s);
|
|
|
|
shift++;
|
|
|
|
screen.PostEvent(Event::Custom);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2021-05-13 17:44:47 +08:00
|
|
|
screen.Loop(main_renderer);
|
2021-06-26 07:37:18 +08:00
|
|
|
refresh_ui_continue = false;
|
|
|
|
refresh_ui.join();
|
2019-01-27 09:33:06 +08:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
2020-09-06 19:46:56 +08:00
|
|
|
|
|
|
|
// Copyright 2020 Arthur Sonzogni. All rights reserved.
|
|
|
|
// Use of this source code is governed by the MIT license that can be found in
|
|
|
|
// the LICENSE file.
|