summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--CMakeLists.txt5
-rw-r--r--README.md2
-rw-r--r--cli/CMakeLists.txt5
-rw-r--r--cli/main.cpp4
-rw-r--r--cli/page.cpp264
-rw-r--r--cli/page.hpp83
-rw-r--r--katja/sbo.cpp4
7 files changed, 168 insertions, 199 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt
index ee00877..cdbe986 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -2,7 +2,7 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at https://mozilla.org/MPL/2.0/.
-cmake_minimum_required(VERSION 3.21)
+cmake_minimum_required(VERSION 4.0)
project(Katja)
include(CTest)
@@ -10,7 +10,8 @@ include(FetchContent)
set(CMAKE_EXPORT_COMPILE_COMMANDS 1)
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin)
-set(CMAKE_CXX_STANDARD 17)
+set(CMAKE_CXX_STANDARD 20)
+set(CMAKE_CXX_MODULE_STD 1)
add_library(katja
katja/database.cpp include/katja/database.hpp
diff --git a/README.md b/README.md
index 0ba79b5..688a064 100644
--- a/README.md
+++ b/README.md
@@ -11,7 +11,7 @@ implementation, that exposes the library to a user.
## Build instructions
```sh
-cmake -B build
+cmake -B build -G Ninja
make -C build
```
diff --git a/cli/CMakeLists.txt b/cli/CMakeLists.txt
index b11226f..533e2bc 100644
--- a/cli/CMakeLists.txt
+++ b/cli/CMakeLists.txt
@@ -4,7 +4,7 @@
FetchContent_Declare(ftxui
GIT_REPOSITORY https://github.com/ArthurSonzogni/ftxui
- GIT_TAG v6.1.8
+ GIT_TAG v6.1.9
GIT_PROGRESS TRUE
GIT_SHALLOW TRUE
EXCLUDE_FROM_ALL
@@ -18,7 +18,8 @@ FetchContent_Declare(toml11
)
FetchContent_MakeAvailable(toml11)
-add_executable(katja-cli main.cpp component.hpp component.cpp page.hpp page.cpp)
+add_executable(katja-cli main.cpp component.hpp component.cpp)
+target_sources(katja-cli PUBLIC FILE_SET all_my_modules TYPE CXX_MODULES FILES page.cpp)
target_include_directories(katja-cli PRIVATE ${Boost_INCLUDE_DIR})
target_link_libraries(katja-cli
LINK_PUBLIC katja
diff --git a/cli/main.cpp b/cli/main.cpp
index ca7a8c5..d0bf8b7 100644
--- a/cli/main.cpp
+++ b/cli/main.cpp
@@ -7,11 +7,13 @@
#include <ftxui/component/screen_interactive.hpp>
#include <ftxui/dom/elements.hpp>
+#include <ftxui/component/component.hpp>
#include <toml.hpp>
#include "katja/sbo.hpp"
#include "katja/database.hpp"
-#include "page.hpp"
+
+import page;
int main(int argc, const char **argv)
{
diff --git a/cli/page.cpp b/cli/page.cpp
index 3f83682..fe0bd5a 100644
--- a/cli/page.cpp
+++ b/cli/page.cpp
@@ -3,150 +3,198 @@
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at https://mozilla.org/MPL/2.0/.
*/
-#include "page.hpp"
+module;
#include <algorithm>
-namespace katja
+#include "component.hpp"
+
+export module page;
+
+export namespace katja
{
- ScreenContainer::ScreenContainer(std::vector<std::pair<std::string, Page>> pages, std::function<void()> on_enter)
- : on_enter(on_enter)
+ class PageBase : public ftxui::ComponentBase
{
- ftxui::Components menu_pages;
+ public:
+ virtual void Load() = 0;
+ };
- std::transform(std::cbegin(pages), std::cend(pages), std::back_inserter(menu_entries),
- [](const std::pair<std::string, Page>& pair) { return pair.first; });
- std::transform(std::cbegin(pages), std::cend(pages), std::back_inserter(this->menu_pages),
- [](const std::pair<std::string, Page>& pair) { return pair.second; });
- std::copy(std::cbegin(this->menu_pages), std::cend(this->menu_pages), std::back_inserter(menu_pages));
+ using Page = std::shared_ptr<PageBase>;
+ using Pages = std::vector<Page>;
- ftxui::MenuOption menu_option = ftxui::MenuOption::Horizontal();
- this->menu = ftxui::Toggle(&this->menu_entries, &this->menu_selected);
+ class ScreenContainer final : public ftxui::ComponentBase
+ {
+ int menu_selected{ 0 };
+ ftxui::Component menu;
+ ftxui::Component content;
+ std::vector<std::string> menu_entries;
+ Pages menu_pages;
+ std::function<void()> on_enter;
+
+ public:
+ ScreenContainer(std::vector<std::pair<std::string, Page>> pages, std::function<void()> on_enter)
+ : on_enter(on_enter)
+ {
+ ftxui::Components menu_pages;
- this->content = ftxui::Container::Tab(std::move(menu_pages), &this->menu_selected);
- }
+ std::transform(std::cbegin(pages), std::cend(pages), std::back_inserter(menu_entries),
+ [](const std::pair<std::string, Page>& pair) { return pair.first; });
+ std::transform(std::cbegin(pages), std::cend(pages), std::back_inserter(this->menu_pages),
+ [](const std::pair<std::string, Page>& pair) { return pair.second; });
+ std::copy(std::cbegin(this->menu_pages), std::cend(this->menu_pages), std::back_inserter(menu_pages));
- ftxui::Element ScreenContainer::OnRender()
- {
- return ftxui::vbox({
- this->menu->Render(),
- ftxui::separator(),
- this->content->Render()
- });
- }
+ ftxui::MenuOption menu_option = ftxui::MenuOption::Horizontal();
+ this->menu = ftxui::Toggle(&this->menu_entries, &this->menu_selected);
- bool ScreenContainer::OnEvent(ftxui::Event event)
- {
- if (event == ftxui::Event::CtrlQ && this->on_enter)
- {
- on_enter();
- return true;
+ this->content = ftxui::Container::Tab(std::move(menu_pages), &this->menu_selected);
}
- int previously = this->menu_selected;
- bool result{ false };
- if (event == ftxui::Event::CtrlP)
- {
- result = menu->OnEvent(ftxui::Event::ArrowLeft);
- }
- else if (event == ftxui::Event::CtrlN)
- {
- result = menu->OnEvent(ftxui::Event::ArrowRight);
- }
- if (previously != this->menu_selected)
+ ftxui::Element OnRender() override
{
- this->menu_pages.at(this->menu_selected)->Load();
+ return ftxui::vbox({
+ this->menu->Render(),
+ ftxui::separator(),
+ this->content->Render()
+ });
}
- if (!result)
+
+ bool OnEvent(ftxui::Event event) override
{
- result = this->menu_pages.at(this->menu_selected)->OnEvent(event);
+ if (event == ftxui::Event::CtrlQ && this->on_enter)
+ {
+ on_enter();
+ return true;
+ }
+ int previously = this->menu_selected;
+ bool result{ false };
+
+ if (event == ftxui::Event::CtrlP)
+ {
+ result = menu->OnEvent(ftxui::Event::ArrowLeft);
+ }
+ else if (event == ftxui::Event::CtrlN)
+ {
+ result = menu->OnEvent(ftxui::Event::ArrowRight);
+ }
+ if (previously != this->menu_selected)
+ {
+ this->menu_pages.at(this->menu_selected)->Load();
+ }
+ if (!result)
+ {
+ result = this->menu_pages.at(this->menu_selected)->OnEvent(event);
+ }
+ return result;
}
- return result;
- }
+ };
ftxui::Component Screen(std::vector<std::pair<std::string, Page>> pages, std::function<void()> on_enter)
{
return std::make_shared<ScreenContainer>(std::move(pages), on_enter);
}
- ftxui::Element WelcomePage::OnRender()
- {
- return ftxui::paragraph("Select an action in the menu.");
- }
-
- void WelcomePage::Load()
+ class WelcomePage final : public PageBase
{
- }
+ public:
+ void Load() override
+ {
+ }
- UpdatesPage::UpdatesPage(std::shared_ptr<struct repository> repository, package_database database)
- : repository(repository), database(database)
- {
- }
+ ftxui::Element OnRender() override
+ {
+ return ftxui::paragraph("Select an action in the menu.");
+ }
+ };
- void UpdatesPage::Load()
+ class UpdatesPage final : public PageBase
{
- this->updatable = PackageList("Updates", repository->get_updates(this->database));
- }
+ ftxui::Component updatable = PackageList("Updates");
+ std::shared_ptr<struct repository> repository;
+ package_database database;
- ftxui::Element UpdatesPage::OnRender()
- {
- return this->updatable->Render();
- }
+ public:
+ UpdatesPage(std::shared_ptr<struct repository> repository, package_database database)
+ : repository(repository), database(database)
+ {
+ }
- SearchPage::SearchPage(std::shared_ptr<struct repository> repository, const std::string& architecture)
- : repository(repository), architecture(architecture)
- {
- ftxui::InputOption search_input_option = { .multiline = false };
- this->search_input = ftxui::Input(&this->needle, "Search", search_input_option);
- this->type_input = ftxui::Radiobox(std::vector<std::string>{ "Names", "Description" }, &this->search_type);
- }
+ void Load() override
+ {
+ this->updatable = PackageList("Updates", repository->get_updates(this->database));
+ }
- void SearchPage::Load()
- {
- this->needle.erase();
- }
+ ftxui::Element OnRender() override
+ {
+ return this->updatable->Render();
+ }
+ };
- ftxui::Element SearchPage::OnRender()
+ class SearchPage final : public PageBase
{
- std::vector<ftxui::Element> lines;
-
- ftxui::FlexboxConfig config;
- config.justify_content = ftxui::FlexboxConfig::JustifyContent::SpaceAround;
- config.align_items = ftxui::FlexboxConfig::AlignItems::FlexStart;
- config.direction = ftxui::FlexboxConfig::Direction::Row;
- config.wrap = ftxui::FlexboxConfig::Wrap::NoWrap;
- config.SetGap(3, 0);
-
- return ftxui::vbox({
- ftxui::flexbox({
- this->search_input->Render(),
- ftxui::window(ftxui::text("Search in"), type_input->Render())
- }, config),
- this->search_results->Render() | ftxui::flex
- });
- }
+ std::string needle;
+ ftxui::Component search_input;
+ ftxui::Component type_input;
+ std::shared_ptr<struct repository> repository;
+ std::string architecture;
+ ftxui::Component search_results = PackageList("Results");
+ int search_type{ 0 };
+
+ public:
+ SearchPage(std::shared_ptr<struct repository> repository, const std::string& architecture)
+ : repository(repository), architecture(architecture)
+ {
+ ftxui::InputOption search_input_option = { .multiline = false };
+ this->search_input = ftxui::Input(&this->needle, "Search", search_input_option);
+ this->type_input = ftxui::Radiobox(std::vector<std::string>{ "Names", "Description" }, &this->search_type);
+ }
- bool SearchPage::OnEvent(ftxui::Event event)
- {
- if (event == ftxui::Event::Return)
+ void Load() override
{
- if (!this->needle.empty())
- {
- std::vector<package_identifier> result =
- this->repository->search_names(this->architecture, this->needle);
- this->search_results = PackageList("Search", std::move(result));
- }
- return true;
+ this->needle.erase();
}
- else if (event == ftxui::Event::ArrowUp || event == ftxui::Event::ArrowDown)
+
+ ftxui::Element OnRender() override
{
- this->search_results->OnEvent(event);
- return true;
+ std::vector<ftxui::Element> lines;
+
+ ftxui::FlexboxConfig config;
+ config.justify_content = ftxui::FlexboxConfig::JustifyContent::SpaceAround;
+ config.align_items = ftxui::FlexboxConfig::AlignItems::FlexStart;
+ config.direction = ftxui::FlexboxConfig::Direction::Row;
+ config.wrap = ftxui::FlexboxConfig::Wrap::NoWrap;
+ config.SetGap(3, 0);
+
+ return ftxui::vbox({
+ ftxui::flexbox({
+ this->search_input->Render(),
+ ftxui::window(ftxui::text("Search in"), type_input->Render())
+ }, config),
+ this->search_results->Render() | ftxui::flex
+ });
}
- else
+
+ bool OnEvent(ftxui::Event event) override
{
- return this->search_input->OnEvent(event);
+ if (event == ftxui::Event::Return)
+ {
+ if (!this->needle.empty())
+ {
+ std::vector<package_identifier> result =
+ this->repository->search_names(this->architecture, this->needle);
+ this->search_results = PackageList("Search", std::move(result));
+ }
+ return true;
+ }
+ else if (event == ftxui::Event::ArrowUp || event == ftxui::Event::ArrowDown)
+ {
+ this->search_results->OnEvent(event);
+ return true;
+ }
+ else
+ {
+ return this->search_input->OnEvent(event);
+ }
+ return false;
}
- return false;
- }
+ };
}
diff --git a/cli/page.hpp b/cli/page.hpp
deleted file mode 100644
index 3312d55..0000000
--- a/cli/page.hpp
+++ /dev/null
@@ -1,83 +0,0 @@
-/*
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at https://mozilla.org/MPL/2.0/.
- */
-#pragma once
-
-#include <ftxui/component/event.hpp>
-#include <ftxui/component/component_base.hpp>
-#include <ftxui/component/component.hpp>
-
-#include "katja/repository.hpp"
-#include "katja/database.hpp"
-
-#include "component.hpp"
-
-namespace katja
-{
- class PageBase : public ftxui::ComponentBase
- {
- public:
- virtual void Load() = 0;
- };
-
- using Page = std::shared_ptr<PageBase>;
- using Pages = std::vector<Page>;
-
- class ScreenContainer final : public ftxui::ComponentBase
- {
- int menu_selected{ 0 };
- ftxui::Component menu;
- ftxui::Component content;
- std::vector<std::string> menu_entries;
- Pages menu_pages;
- std::function<void()> on_enter;
-
- public:
- ScreenContainer(std::vector<std::pair<std::string, Page>> pages, std::function<void()> on_enter);
-
- ftxui::Element OnRender() override;
- bool OnEvent(ftxui::Event event) override;
- };
-
- ftxui::Component Screen(std::vector<std::pair<std::string, Page>> pages, std::function<void()> on_enter);
-
- class WelcomePage final : public PageBase
- {
- public:
- void Load() override;
- ftxui::Element OnRender() override;
- };
-
- class UpdatesPage final : public PageBase
- {
- ftxui::Component updatable = PackageList("Updates");
- std::shared_ptr<struct repository> repository;
- package_database database;
-
- public:
- UpdatesPage(std::shared_ptr<struct repository> repository, package_database database);
-
- void Load() override;
- ftxui::Element OnRender() override;
- };
-
- class SearchPage final : public PageBase
- {
- std::string needle;
- ftxui::Component search_input;
- ftxui::Component type_input;
- std::shared_ptr<struct repository> repository;
- std::string architecture;
- ftxui::Component search_results = PackageList("Results");
- int search_type{ 0 };
-
- public:
- SearchPage(std::shared_ptr<struct repository> repository, const std::string& architecture);
-
- void Load() override;
- ftxui::Element OnRender() override;
- bool OnEvent(ftxui::Event event) override;
- };
-}
diff --git a/katja/sbo.cpp b/katja/sbo.cpp
index fcfc3eb..b53d8ee 100644
--- a/katja/sbo.cpp
+++ b/katja/sbo.cpp
@@ -126,7 +126,7 @@ namespace katja
std::ifstream info_stream{ info_filepath };
std::string info_line, info_variable, info_value;
std::string program_name, version, homepage, email, maintainer;
- std::vector<std::string> download, md5sum, download_x86_64, md5sum_x86_64, requires;
+ std::vector<std::string> download, md5sum, download_x86_64, md5sum_x86_64, requirements;
bool continuation{ false };
while (std::getline(info_stream, info_line))
@@ -193,7 +193,7 @@ namespace katja
}
else if (info_variable == "REQUIRES")
{
- boost::split(requires, info_value, boost::is_any_of(" "), boost::token_compress_on);
+ boost::split(requirements, info_value, boost::is_any_of(" "), boost::token_compress_on);
}
}
}