Compare commits

...

45 Commits

Author SHA1 Message Date
3bdf4ceda3 Требуемая версия myx-cmake поднята для 0.4.5 2021-12-29 13:36:44 +03:00
1e635fc7bb Чистка проекта 2021-12-24 15:09:46 +03:00
6f2d2361fd Обновление для совместимости с новой версией myx-cmake 2021-12-24 14:30:39 +03:00
6c1728bce0 Преобразование проекта 2021-12-12 22:55:05 +03:00
6dbde42d6f Удаление лишних зависимостей 2021-12-10 15:08:52 +03:00
023b493eff Удаление лишних зависимостей 2021-12-10 15:08:44 +03:00
31a3fc3dc7 Удаление лишних зависимостей 2021-12-10 15:08:38 +03:00
52c618c590 Удаление лишних зависимостей 2021-12-10 15:08:04 +03:00
ece9b7cf70 Обновление подмодулей 2021-10-07 09:19:51 +03:00
bb580c0938 Правка сигнатуры для компиляции в Smolensk 1.5 2021-09-20 11:41:14 +03:00
547a127956 Исправлен деструктор 2021-09-20 11:35:36 +03:00
554ab7efdf Ещё вариант 2021-09-20 11:34:33 +03:00
7319a202c3 Новый вариант 2021-09-20 11:32:28 +03:00
c1235edaa9 Правка для Smolensk 1.5 2021-09-20 11:24:37 +03:00
a4ea9864be Правка для Smolensk 1.5 2021-09-20 11:22:05 +03:00
347ef3d46d Классы и пример для журналирования (простой вывод и в syslog) 2021-09-17 14:35:10 +03:00
b21def5945 Обновление подмодулей 2021-08-02 18:00:55 +03:00
cfe4fe8a2e Обновление подмодулей 2021-08-02 14:34:42 +03:00
11c572a96c Merge branch 'master' of gitlab.2:f1x1t/myxlib 2021-07-27 13:30:27 +03:00
e3d5243f80 Обновление CMLib 2021-07-27 13:30:01 +03:00
3f633ee15c Обновление подмодулей 2021-07-06 05:35:28 +03:00
458dcd82c6 Обновление подмодулей 2021-07-06 05:00:46 +03:00
a4b181a838 Поддержка версии Elbrus-D 2021-07-05 13:43:04 +03:00
2261982479 Определение параметров текущей ОС во время выполнения 2021-07-05 13:11:00 +03:00
d159417bbb Обновление подмодулей 2021-07-05 10:58:56 +03:00
66ddb8a1fb Merge branch 'master' of gitlab.2:f1x1t/myxlib 2021-07-02 10:50:25 +03:00
dd1010a826 Обновление подмодулей 2021-07-02 10:50:18 +03:00
35ad2e1db8 Обновление подмодулей 2021-06-30 16:54:16 +03:00
7d0c2f68d6 Обновление подмодулей 2021-06-30 10:48:29 +03:00
7396f77054 Модули для поиска с помощью CMake 2021-06-24 11:38:58 +03:00
3d3690ca64 Цель для установки заголовочных файлов 2021-06-24 11:36:53 +03:00
105ed96f5f Обновление подмодулей 2021-06-24 10:39:43 +03:00
5645c5ea31 Примеры скриптов для поиска через find_package 2021-06-22 17:35:13 +03:00
e63e6a4c8a Обновление подмодулей 2021-06-21 13:02:54 +03:00
a017ca6814 Поддержка использования внешней CMLib 2021-06-18 01:16:37 +03:00
8114675c1c Удалён подмодуль cmake/doc 2021-06-18 00:59:05 +03:00
d839fa6ed4 Обновление CMLib 2021-06-17 15:51:28 +03:00
a368091252 Инициализация по умолчанию в конструкторе 2021-06-16 11:43:13 +03:00
9468f95dd3 Обновление CMLib 2021-06-15 10:46:37 +03:00
56a0b595d2 Merge branch 'master' of gitlab.2:f1x1t/myxlib 2021-06-12 14:52:34 +03:00
716545e49c Обновление подмодулей 2021-06-12 14:52:25 +03:00
b575634554 Обновление подмодулей 2021-06-11 09:52:58 +03:00
299dabf295 Путь к общему каталогу для темы (работы) 2021-06-11 08:52:57 +03:00
a29cea6f61 Упрощение и правка автоопределения в /opt 2021-06-11 08:21:00 +03:00
360b2b41d1 Переименования 2021-06-10 07:21:54 +03:00
45 changed files with 4157 additions and 474 deletions

43
.gitignore vendored
View File

@ -1,5 +1,6 @@
# Каталог для результатов сборки проекта # Каталог для результатов сборки проекта
_build _build
build
# Каталог для тестирования установки # Каталог для тестирования установки
_output _output
@ -13,6 +14,8 @@ files/etc/*.conf
files/lib/* files/lib/*
files/log/* files/log/*
!.gitkeep
!.gitignore
### ###
### Общие настройки для C, C++, Fortran, Qt, CMake, Ninja, LaTeX и редакторов ### Общие настройки для C, C++, Fortran, Qt, CMake, Ninja, LaTeX и редакторов
@ -43,6 +46,8 @@ files/log/*
[._]ss[a-gi-z] [._]ss[a-gi-z]
[._]sw[a-p] [._]sw[a-p]
# Project
.vimprj
# Temporary # Temporary
.netrwhist .netrwhist
*~ *~
@ -106,6 +111,10 @@ compile_commands.json
CTestTestfile.cmake CTestTestfile.cmake
_deps _deps
### CMake Patch ###
# External projects
*-prefix/
### ###
### Ninja ### Ninja
@ -162,6 +171,38 @@ target_wrapper.*
*_qmlcache.qrc *_qmlcache.qrc
### KDevelop4 ###
*.kdev4
.kdev4/
### vscode ###
.vscode/*
!.vscode/settings.json
!.vscode/tasks.json
!.vscode/launch.json
!.vscode/extensions.json
*.code-workspace
### Eclipse ###
.metadata
.settings/
.recommenders/
# TeXlipse
.texlipse
# PyDev specific (Python IDE for Eclipse)
*.pydevproject
# CDT-specific (C/C++ Development Tooling)
.cproject
# CDT- autotools
.autotools
### ###
### Latex ### Latex
### ###
@ -173,6 +214,7 @@ target_wrapper.*
*.blg *.blg
*.dvi *.dvi
*.fdb_latexmk *.fdb_latexmk
*.fls
*.glg *.glg
*.glo *.glo
*.gls *.gls
@ -195,6 +237,7 @@ target_wrapper.*
*.synctex.gz *.synctex.gz
*.toc *.toc
*.vrb *.vrb
*.xdv
*.xdy *.xdy
*.tdo *.tdo

15
.gitmodules vendored
View File

@ -1,15 +0,0 @@
[submodule "cmake/etc/uncrustify"]
path = cmake/etc/uncrustify
url = ../../f1x1t/uncrustify-config.git
[submodule "cmake/cmlib"]
path = cmake/cmlib
url = ../../f1x1t/cmlib
[submodule "cmake/find"]
path = cmake/find
url = ../../f1x1t/cmake-find
[submodule "cmake/generators"]
path = cmake/generators
url = ../../f1x1t/cmake-generators
[submodule "cmake/doc"]
path = cmake/doc
url = ../../f1x1t/cmake-doc

3371
.uncrustify.cfg Normal file

File diff suppressed because it is too large Load Diff

View File

@ -3,21 +3,13 @@ cmake_minimum_required(VERSION 3.3)
cmake_policy(VERSION 3.0.2..3.7) cmake_policy(VERSION 3.0.2..3.7)
# Название проекта # Название проекта
project(myx VERSION 0.4.0 LANGUAGES C CXX) project(myx VERSION 0.9.0 LANGUAGES C CXX)
# Обязательные переменные # Обязательные переменные
set(CMLIB_ORGANIZATION_NAME "ECS5" CACHE STRING "") set(MYX_CMAKE_ORGANIZATION_NAME "ECS5" CACHE STRING "")
set(CMLIB_AUTHOR_NAME "Андрей Астафьев" CACHE STRING "") set(MYX_CMAKE_AUTHOR_NAME "Андрей Астафьев" CACHE STRING "")
set(CMLIB_AUTHOR_EMAIL "dev@246060.ru" CACHE STRING "") set(MYX_CMAKE_AUTHOR_EMAIL "dev@246060.ru" CACHE STRING "")
set(CMLIB_DESCRIPTION "Разные функции" CACHE STRING "") set(MYX_CMAKE_DESCRIPTION "Разные функции" CACHE STRING "")
# В каталоге cmake/lib находятся файлы с библиотечными функциями
if(IS_DIRECTORY ${CMAKE_SOURCE_DIR}/cmake/cmlib)
list(INSERT CMAKE_MODULE_PATH 0 ${CMAKE_SOURCE_DIR}/cmake/cmlib)
else()
message(FATAL_ERROR "CMake library directory not exists")
endif()
list(APPEND CMAKE_MODULE_PATH ${CMAKE_SOURCE_DIR}/cmake/find)
if(NOT DEFINED MYXLIB_MASTER_PROJECT) if(NOT DEFINED MYXLIB_MASTER_PROJECT)
if(CMAKE_CURRENT_SOURCE_DIR STREQUAL CMAKE_SOURCE_DIR) if(CMAKE_CURRENT_SOURCE_DIR STREQUAL CMAKE_SOURCE_DIR)
@ -27,7 +19,7 @@ if(NOT DEFINED MYXLIB_MASTER_PROJECT)
endif() endif()
endif() endif()
include(CMLibCommon) find_package(MyxCMake 0.4.5 REQUIRED)
#cmlib_set_cxx_standard(11) #cmlib_set_cxx_standard(11)
option(MYXLIB_BUILD_EXAMPLES "Build examples" OFF) option(MYXLIB_BUILD_EXAMPLES "Build examples" OFF)
@ -42,7 +34,7 @@ find_package(Threads REQUIRED)
# Qt5 # Qt5
find_package(Qt5 COMPONENTS Core Network REQUIRED) find_package(Qt5 COMPONENTS Core Network REQUIRED)
cmlib_generate_private_config_hpp() myx_cmake_generate_private_config_header()
# Библиотеки # Библиотеки
add_subdirectory(src/myx/backports/compiler) add_subdirectory(src/myx/backports/compiler)
@ -52,6 +44,9 @@ add_subdirectory(src/myx/core)
add_subdirectory(src/myx/filesystem) add_subdirectory(src/myx/filesystem)
add_subdirectory(src/myx/qt) add_subdirectory(src/myx/qt)
# Цель, используемая только для установки заголовочных файлов без компиляции проекта
add_custom_target(myxlib-install-headers COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=dev -P
"${CMAKE_BINARY_DIR}/cmake_install.cmake")
# Примеры # Примеры
if(MYXLIB_BUILD_EXAMPLES) if(MYXLIB_BUILD_EXAMPLES)
add_subdirectory(examples/core) add_subdirectory(examples/core)
@ -62,4 +57,5 @@ if(MYXLIB_BUILD_EXAMPLES)
endif() endif()
# Документация # Документация
add_subdirectory(cmake/doc) myx_cmake_doc_doxygen(LATEX YES HTML YES)
myx_cmake_doc_breathe()

Submodule cmake/cmlib deleted from 5e600ab490

Submodule cmake/doc deleted from dc9622f57e

View File

@ -1,10 +0,0 @@
set(ORGANIZATION_NAME "ECS5")
set(AUTHOR_NAME "Андрей Астафьев")
set(DOXYGEN_PROJECT_TITLE "MyXLib")
set(DOXYGEN_GENERATE_LATEX YES)
set(DOXYGEN_GENERATE_HTML YES)
set(CPACK_COMPONENTS_ALL examples)
set(CPACK_PACKAGE_CONTACT "Andrei Astafev <dev@246060.ru>")
set(CPACK_PACKAGE_DESCRIPTION_SUMMARY "Mixed functions")

Submodule cmake/find deleted from bb640e3cf2

Submodule cmake/generators deleted from 74d499b9cb

View File

@ -5,47 +5,17 @@ set(TRGT example-core-endian)
set(TRGT_cpp ${CMAKE_CURRENT_SOURCE_DIR}/endian.cpp) set(TRGT_cpp ${CMAKE_CURRENT_SOURCE_DIR}/endian.cpp)
if(MYXLIB_BUILD_EXAMPLES) if(MYXLIB_BUILD_EXAMPLES)
# Путь поиска библиотек внутри проекта
link_directories(${CMAKE_BINARY_DIR}/${CMAKE_INSTALL_LIBDIR})
# Цель для создания исполняемого файла # Цель для создания исполняемого файла
add_executable(${TRGT} ${TRGT_cpp} ${TRGT_qrc}) add_executable(${TRGT} ${TRGT_cpp} ${TRGT_qrc})
common_target_properties(${TRGT}) myx_cmake_common_target_properties(${TRGT})
# Создание цели для проверки утилитой clang-tidy
add_clang_tidy_check(${TRGT} ${TRGT_cpp})
# Создание цели для проверки утилитой clang-analyze
add_clang_analyze_check(${TRGT} ${TRGT_cpp})
# Создание цели для проверки утилитой clazy
add_clazy_check(${TRGT} ${TRGT_cpp})
# Создание цели для проверки утилитой pvs-studio
add_pvs_check(${TRGT})
# Создание цели для автоматического форматирования кода
add_format_sources(${TRGT} ${TRGT_cpp})
# Qt5
target_include_directories(${TRGT} PRIVATE ${CMAKE_SOURCE_DIR}/src)
target_include_directories(${TRGT} SYSTEM PUBLIC ${Qt5Core_INCLUDE_DIRS})
target_include_directories(${TRGT} SYSTEM PRIVATE ${CMAKE_SOURCE_DIR}/src)
add_dependencies(${TRGT} core)
target_link_libraries(${TRGT} Qt5::Core)
target_link_libraries(${TRGT} Threads::Threads)
# Имя выходного файла для цели # Имя выходного файла для цели
set_target_properties(${TRGT} PROPERTIES OUTPUT_NAME endian-minimal) set_target_properties(${TRGT} PROPERTIES OUTPUT_NAME endian-minimal)
add_sanitizers(${TRGT}) # Qt5
target_include_directories(${TRGT} SYSTEM PUBLIC ${Qt5Core_INCLUDE_DIRS})
add_dependencies(${TRGT} core)
cotire(${TRGT}) target_link_libraries(${TRGT} Qt5::Core)
target_link_libraries(${TRGT} Threads::Threads)
add_dependencies(${TRGT} create_auxilary_symlinks)
# Правила для установки
# install(TARGETS ${TRGT} COMPONENT examples RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
endif() endif()

View File

@ -0,0 +1,21 @@
# Название основной цели в текущем каталоге
set(TRGT example-core-current-system)
# Список файлов исходных текстов
set(TRGT_cpp ${CMAKE_CURRENT_SOURCE_DIR}/current_system.cpp)
if(MYXLIB_BUILD_EXAMPLES)
# Цель для создания исполняемого файла
add_executable(${TRGT} ${TRGT_cpp} ${TRGT_qrc})
myx_cmake_common_target_properties(${TRGT})
# Имя выходного файла для цели
set_target_properties(${TRGT} PROPERTIES OUTPUT_NAME current-system-minimal)
# Qt5
target_include_directories(${TRGT} SYSTEM PUBLIC ${Qt5Core_INCLUDE_DIRS})
add_dependencies(${TRGT} core)
target_link_libraries(${TRGT} Qt5::Core)
target_link_libraries(${TRGT} Threads::Threads)
endif()

View File

@ -0,0 +1,23 @@
#include <myx/core/config.hpp>
#include <myx/core/current_system.hpp>
#include <QDebug>
//NOLINTNEXTLINE
#define CMLIB_PROJECT_NAME "myxlib"
namespace MC = myx::core;
int main( int argc, char** argv )
{
(void)argc;
(void)argv;
MC::CurrentSystem& currentSystem = MC::CurrentSystem::instance();
qDebug() << "Current OS: " << QString::fromStdString( currentSystem.os() );
qDebug() << "OS distrib: " << QString::fromStdString( currentSystem.distribution() );
qDebug() << "OS variant: " << QString::fromStdString( currentSystem.variant() );
qDebug() << "OS version: " << QString::fromStdString( currentSystem.version() );
return( 0 );
} // main

View File

@ -1 +1,2 @@
add_subdirectory(01_endian) add_subdirectory(01_endian)
add_subdirectory(02_current-system)

View File

@ -5,48 +5,18 @@ set(TRGT example-filesystem-paths)
set(TRGT_cpp ${CMAKE_CURRENT_SOURCE_DIR}/paths.cpp) set(TRGT_cpp ${CMAKE_CURRENT_SOURCE_DIR}/paths.cpp)
if(MYXLIB_BUILD_EXAMPLES) if(MYXLIB_BUILD_EXAMPLES)
# Путь поиска библиотек внутри проекта
link_directories(${CMAKE_BINARY_DIR}/${CMAKE_INSTALL_LIBDIR})
# Цель для создания исполняемого файла # Цель для создания исполняемого файла
add_executable(${TRGT} ${TRGT_cpp} ${TRGT_qrc}) add_executable(${TRGT} ${TRGT_cpp} ${TRGT_qrc})
common_target_properties(${TRGT}) myx_cmake_common_target_properties(${TRGT})
# Создание цели для проверки утилитой clang-tidy
add_clang_tidy_check(${TRGT} ${TRGT_cpp})
# Создание цели для проверки утилитой clang-analyze
add_clang_analyze_check(${TRGT} ${TRGT_cpp})
# Создание цели для проверки утилитой clazy
add_clazy_check(${TRGT} ${TRGT_cpp})
# Создание цели для проверки утилитой pvs-studio
add_pvs_check(${TRGT})
# Создание цели для автоматического форматирования кода
add_format_sources(${TRGT} ${TRGT_cpp})
# Qt5
target_include_directories(${TRGT} PRIVATE ${CMAKE_SOURCE_DIR}/src)
target_include_directories(${TRGT} SYSTEM PUBLIC ${Qt5Core_INCLUDE_DIRS})
target_include_directories(${TRGT} SYSTEM PRIVATE ${CMAKE_SOURCE_DIR}/src)
add_dependencies(${TRGT} core filesystem)
target_link_libraries(${TRGT} filesystem_static)
target_link_libraries(${TRGT} Qt5::Core)
target_link_libraries(${TRGT} Threads::Threads)
# Имя выходного файла для цели # Имя выходного файла для цели
set_target_properties(${TRGT} PROPERTIES OUTPUT_NAME filesystem-minimal) set_target_properties(${TRGT} PROPERTIES OUTPUT_NAME filesystem-minimal)
add_sanitizers(${TRGT}) # Qt5
target_include_directories(${TRGT} SYSTEM PUBLIC ${Qt5Core_INCLUDE_DIRS})
add_dependencies(${TRGT} core filesystem)
cotire(${TRGT}) target_link_libraries(${TRGT} filesystem-static)
target_link_libraries(${TRGT} Qt5::Core)
add_dependencies(${TRGT} create_auxilary_symlinks) target_link_libraries(${TRGT} Threads::Threads)
# Правила для установки
# install(TARGETS ${TRGT} COMPONENT examples RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
endif() endif()

View File

@ -18,19 +18,19 @@ int main( int argc, char** argv )
QCoreApplication::setApplicationName( QStringLiteral( CMLIB_PROJECT_NAME ) ); QCoreApplication::setApplicationName( QStringLiteral( CMLIB_PROJECT_NAME ) );
MF::Paths& paths = MF::Paths::instance(); MF::Paths& paths = MF::Paths::instance();
paths.init();
qDebug() << "prefixDirectory : " << paths.projectDirectory(); qDebug() << "prefixDirectory : " << paths.projectDirectory();
qDebug() << "executableName : " << paths.executableName(); qDebug() << "executableName : " << paths.executableName();
qDebug() << "executableFilePath : " << paths.executableFilePath(); qDebug() << "executableFilePath : " << paths.executableFilePath();
qDebug() << "executableDirectory : " << paths.executableDirectory(); qDebug() << "executableDirectory : " << paths.executableDirectory() << endl;
qDebug() << "systemThemeDirectory : " << paths.systemThemeDirectory();
qDebug() << "systemConfigDirectory : " << paths.systemConfigDirectory(); qDebug() << "systemConfigDirectory : " << paths.systemConfigDirectory();
qDebug() << "systemConstDataDirectory : " << paths.systemConstDataDirectory(); qDebug() << "systemConstDataDirectory : " << paths.systemConstDataDirectory();
qDebug() << "systemVarDataDirectory : " << paths.systemVarDataDirectory(); qDebug() << "systemVarDataDirectory : " << paths.systemVarDataDirectory();
qDebug() << "systemLogDirectory : " << paths.systemLogDirectory(); qDebug() << "systemLogDirectory : " << paths.systemLogDirectory() << endl;
qDebug() << "userThemeDirectory : " << paths.userThemeDirectory();
qDebug() << "userConfigDirectory : " << paths.userConfigDirectory(); qDebug() << "userConfigDirectory : " << paths.userConfigDirectory();
qDebug() << "userConstDataDirectory : " << paths.userConstDataDirectory(); qDebug() << "userConstDataDirectory : " << paths.userConstDataDirectory();
qDebug() << "userVarDataDirectory : " << paths.userVarDataDirectory(); qDebug() << "userVarDataDirectory : " << paths.userVarDataDirectory();

View File

@ -4,56 +4,26 @@ set(TRGT example-qt-translators)
# Список файлов исходных текстов # Список файлов исходных текстов
set(TRGT_cpp ${CMAKE_CURRENT_SOURCE_DIR}/translators.cpp) set(TRGT_cpp ${CMAKE_CURRENT_SOURCE_DIR}/translators.cpp)
qt5_translation( myx_cmake_qt5_translation(
TRGT_qrc TRGT_qrc
OUTPUT_DIR ${CMAKE_SOURCE_DIR}/l10n OUTPUT_DIR ${CMAKE_SOURCE_DIR}/l10n
BASE_NAME ${TRGT} BASE_NAME ${TRGT}
LANGUAGES ru_RU) LANGUAGES ru_RU)
if(MYXLIB_BUILD_EXAMPLES) if(MYXLIB_BUILD_EXAMPLES)
# Путь поиска библиотек внутри проекта
link_directories(${CMAKE_BINARY_DIR}/${CMAKE_INSTALL_LIBDIR})
# Цель для создания исполняемого файла # Цель для создания исполняемого файла
add_executable(${TRGT} ${TRGT_cpp} ${TRGT_qrc}) add_executable(${TRGT} ${TRGT_cpp} ${TRGT_qrc})
common_target_properties(${TRGT}) myx_cmake_common_target_properties(${TRGT})
# Создание цели для проверки утилитой clang-tidy
add_clang_tidy_check(${TRGT} ${TRGT_cpp})
# Создание цели для проверки утилитой clang-analyze
add_clang_analyze_check(${TRGT} ${TRGT_cpp})
# Создание цели для проверки утилитой clazy
add_clazy_check(${TRGT} ${TRGT_cpp})
# Создание цели для проверки утилитой pvs-studio
add_pvs_check(${TRGT})
# Создание цели для автоматического форматирования кода
add_format_sources(${TRGT} ${TRGT_cpp})
# Qt5
target_include_directories(${TRGT} PRIVATE ${CMAKE_SOURCE_DIR}/src)
target_include_directories(${TRGT} SYSTEM PUBLIC ${Qt5Core_INCLUDE_DIRS})
target_include_directories(${TRGT} SYSTEM PRIVATE ${CMAKE_SOURCE_DIR}/src)
add_dependencies(${TRGT} core qt)
target_link_libraries(${TRGT} qt_static)
target_link_libraries(${TRGT} Qt5::Core)
target_link_libraries(${TRGT} Threads::Threads)
# Имя выходного файла для цели # Имя выходного файла для цели
set_target_properties(${TRGT} PROPERTIES OUTPUT_NAME qt-translators) set_target_properties(${TRGT} PROPERTIES OUTPUT_NAME qt-translators)
add_sanitizers(${TRGT}) # Qt5
target_include_directories(${TRGT} SYSTEM PUBLIC ${Qt5Core_INCLUDE_DIRS})
add_dependencies(${TRGT} core qt)
cotire(${TRGT}) target_link_libraries(${TRGT} qt-static)
add_dependencies(${TRGT} create_auxilary_symlinks) target_link_libraries(${TRGT} Qt5::Core)
target_link_libraries(${TRGT} Threads::Threads)
# Правила для установки
# install(TARGETS ${TRGT} COMPONENT examples RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
endif() endif()

View File

@ -5,49 +5,19 @@ set(TRGT example-qt-posix-signal-watcher)
set(TRGT_cpp ${CMAKE_CURRENT_SOURCE_DIR}/posix_signal_watcher.cpp) set(TRGT_cpp ${CMAKE_CURRENT_SOURCE_DIR}/posix_signal_watcher.cpp)
if(MYXLIB_BUILD_EXAMPLES) if(MYXLIB_BUILD_EXAMPLES)
# Путь поиска библиотек внутри проекта
link_directories(${CMAKE_BINARY_DIR}/${CMAKE_INSTALL_LIBDIR})
# Цель для создания исполняемого файла # Цель для создания исполняемого файла
add_executable(${TRGT} ${TRGT_cpp}) add_executable(${TRGT} ${TRGT_cpp})
common_target_properties(${TRGT}) myx_cmake_common_target_properties(${TRGT})
# Создание цели для проверки утилитой clang-tidy
add_clang_tidy_check(${TRGT} ${TRGT_cpp})
# Создание цели для проверки утилитой clang-analyze
add_clang_analyze_check(${TRGT} ${TRGT_cpp})
# Создание цели для проверки утилитой clazy
add_clazy_check(${TRGT} ${TRGT_cpp})
# Создание цели для проверки утилитой pvs-studio
add_pvs_check(${TRGT})
# Создание цели для автоматического форматирования кода
add_format_sources(${TRGT} ${TRGT_cpp})
# Qt5
target_include_directories(${TRGT} PRIVATE ${CMAKE_SOURCE_DIR}/src)
target_include_directories(${TRGT} SYSTEM PUBLIC ${Qt5Core_INCLUDE_DIRS})
target_include_directories(${TRGT} SYSTEM PRIVATE ${CMAKE_SOURCE_DIR}/src)
add_dependencies(${TRGT} core qt)
target_link_libraries(${TRGT} qt_static)
target_link_libraries(${TRGT} Qt5::Core)
target_link_libraries(${TRGT} Threads::Threads)
# Имя выходного файла для цели # Имя выходного файла для цели
set_target_properties(${TRGT} PROPERTIES OUTPUT_NAME qt-posix-signal-watcher) set_target_properties(${TRGT} PROPERTIES OUTPUT_NAME qt-posix-signal-watcher)
add_sanitizers(${TRGT}) # Qt5
target_include_directories(${TRGT} SYSTEM PUBLIC ${Qt5Core_INCLUDE_DIRS})
add_dependencies(${TRGT} core qt)
cotire(${TRGT}) target_link_libraries(${TRGT} qt-static)
add_dependencies(${TRGT} create_auxilary_symlinks) target_link_libraries(${TRGT} Qt5::Core)
target_link_libraries(${TRGT} Threads::Threads)
# Правила для установки
# install(TARGETS ${TRGT} COMPONENT examples RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
endif() endif()

View File

@ -0,0 +1,23 @@
# Название основной цели в текущем каталоге
set(TRGT example-qt-message-logger)
# Список файлов исходных текстов
set(TRGT_cpp ${CMAKE_CURRENT_SOURCE_DIR}/message_logger.cpp)
if(MYXLIB_BUILD_EXAMPLES)
# Цель для создания исполняемого файла
add_executable(${TRGT} ${TRGT_cpp})
myx_cmake_common_target_properties(${TRGT})
# Имя выходного файла для цели
set_target_properties(${TRGT} PROPERTIES OUTPUT_NAME qt-message-logger)
# Qt5
target_include_directories(${TRGT} SYSTEM PUBLIC ${Qt5Core_INCLUDE_DIRS})
add_dependencies(${TRGT} core qt)
target_link_libraries(${TRGT} qt-static)
target_link_libraries(${TRGT} Qt5::Core)
target_link_libraries(${TRGT} Threads::Threads)
endif()

View File

@ -0,0 +1,29 @@
#include <myx/qt/message_logger_default.hpp>
#include <myx/qt/message_logger_handler.hpp>
#include <myx/qt/message_logger_syslog.hpp>
#include <QCoreApplication>
#include <QDebug>
namespace MQ = myx::qt;
int main( int argc, char* argv[] )
{
QCoreApplication app( argc, argv );
auto mld = QSharedPointer< MQ::MessageLoggerDefault >( new MQ::MessageLoggerDefault );
MQ::messageLoggersList.append( mld );
MQ::messageLoggersList.append( mld );
auto mls = QSharedPointer< MQ::MessageLoggerSyslog >( new MQ::MessageLoggerSyslog );
MQ::messageLoggersList.append( mls );
qInstallMessageHandler( MQ::message_logger_handler );
qDebug() << "Hello from process:" << QCoreApplication::applicationPid();
qWarning() << "Warning";
qInstallMessageHandler( nullptr );
qDebug() << "Reset user handlers";
qWarning() << "Goodbye";
return( 0 );
}

View File

@ -1,2 +1,3 @@
add_subdirectory(01_translators) add_subdirectory(01_translators)
add_subdirectory(02_posix-signal-watcher) add_subdirectory(02_posix-signal-watcher)
add_subdirectory(03_message-logger)

0
files/log/.gitkeep Normal file
View File

0
files/share/.gitkeep Normal file
View File

Binary file not shown.

Before

Width:  |  Height:  |  Size: 86 KiB

View File

@ -16,27 +16,6 @@ set(TRGT_headers ${TRGT_hpp})
add_library(${TRGT} INTERFACE) add_library(${TRGT} INTERFACE)
target_sources(${TRGT} INTERFACE ${TRGT_cpp} ${TRGT_headers}) target_sources(${TRGT} INTERFACE ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой clang-tidy myx_cmake_generate_pkgconfig(${TRGT} BASENAME myx-${TRGT} INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
add_clang_tidy_check(${TRGT} ${TRGT_cpp} ${TRGT_headers}) install(FILES ${TRGT_headers} COMPONENT dev
# Создание цели для проверки утилитой clang-analyze
add_clang_analyze_check(${TRGT} ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой clazy
add_clazy_check(${TRGT} ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой pvs-studio
add_pvs_check(${TRGT})
# Создание цели для автоматического форматирования кода
add_format_sources(${TRGT} ${TRGT_cpp} ${TRGT_headers})
target_include_directories(${TRGT} INTERFACE ${CMAKE_SOURCE_DIR}/src)
generate_pkgconfig(myx-${TRGT} COMPONENT base-dev INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
install(FILES ${TRGT_headers} COMPONENT base-dev
DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}/backports/compiler) DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}/backports/compiler)
# Цель, используемая только для установки заголовочных файлов без компиляции проекта
add_custom_target(${TRGT}-install-headers COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=base-dev -P
"${CMAKE_BINARY_DIR}/cmake_install.cmake")

View File

@ -17,27 +17,6 @@ set(TRGT_headers ${TRGT_hpp})
add_library(${TRGT} INTERFACE) add_library(${TRGT} INTERFACE)
target_sources(${TRGT} INTERFACE ${TRGT_cpp} ${TRGT_headers}) target_sources(${TRGT} INTERFACE ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой clang-tidy myx_cmake_generate_pkgconfig(${TRGT} BASENAME myx-${TRGT} INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
add_clang_tidy_check(${TRGT} ${TRGT_cpp} ${TRGT_headers}) install(FILES ${TRGT_headers} COMPONENT dev
# Создание цели для проверки утилитой clang-analyze
add_clang_analyze_check(${TRGT} ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой clazy
add_clazy_check(${TRGT} ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой pvs-studio
add_pvs_check(${TRGT})
# Создание цели для автоматического форматирования кода
add_format_sources(${TRGT} ${TRGT_cpp} ${TRGT_headers})
target_include_directories(${TRGT} INTERFACE ${CMAKE_SOURCE_DIR}/src)
generate_pkgconfig(myx-${TRGT} COMPONENT base-dev INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
install(FILES ${TRGT_headers} COMPONENT base-dev
DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}/backports/cpp) DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}/backports/cpp)
# Цель, используемая только для установки заголовочных файлов без компиляции проекта
add_custom_target(${TRGT}-install-headers COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=base-dev -P
"${CMAKE_BINARY_DIR}/cmake_install.cmake")

View File

@ -25,7 +25,7 @@
#include <string> #include <string>
#include <type_traits> #include <type_traits>
namespace std { namespace std { //-V1061
template< class T, class E, class = void > template< class T, class E, class = void >
struct is_contiguous_container : std::false_type {}; // NOLINT struct is_contiguous_container : std::false_type {}; // NOLINT

View File

@ -16,27 +16,6 @@ set(TRGT_headers ${TRGT_hpp})
add_library(${TRGT} INTERFACE) add_library(${TRGT} INTERFACE)
target_sources(${TRGT} INTERFACE ${TRGT_cpp} ${TRGT_headers}) target_sources(${TRGT} INTERFACE ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой clang-tidy install(FILES ${TRGT_headers} COMPONENT dev
add_clang_tidy_check(${TRGT} ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой clang-analyze
add_clang_analyze_check(${TRGT} ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой clazy
add_clazy_check(${TRGT} ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой pvs-studio
add_pvs_check(${TRGT})
# Создание цели для автоматического форматирования кода
add_format_sources(${TRGT} ${TRGT_cpp} ${TRGT_headers})
target_include_directories(${TRGT} INTERFACE ${CMAKE_SOURCE_DIR}/src)
install(FILES ${TRGT_headers} COMPONENT base-dev
DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}/backports/qt) DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}/backports/qt)
generate_pkgconfig(myx-${TRGT} COMPONENT base-dev INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES}) myx_cmake_generate_pkgconfig(${TRGT} BASENAME myx-${TRGT} INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
# Цель, используемая только для установки заголовочных файлов без компиляции проекта
add_custom_target(${TRGT}-install-headers COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=base-dev -P
"${CMAKE_BINARY_DIR}/cmake_install.cmake")

View File

@ -9,6 +9,7 @@ set(TRGT_cpp)
set(TRGT_hpp set(TRGT_hpp
${CMAKE_CURRENT_SOURCE_DIR}/config.hpp ${CMAKE_CURRENT_SOURCE_DIR}/config.hpp
${CMAKE_CURRENT_SOURCE_DIR}/limits.hpp ${CMAKE_CURRENT_SOURCE_DIR}/limits.hpp
${CMAKE_CURRENT_SOURCE_DIR}/current_system.hpp
${CMAKE_CURRENT_SOURCE_DIR}/endian_types.hpp ${CMAKE_CURRENT_SOURCE_DIR}/endian_types.hpp
${CMAKE_CURRENT_SOURCE_DIR}/enum_bitmask_operations.hpp) ${CMAKE_CURRENT_SOURCE_DIR}/enum_bitmask_operations.hpp)
@ -18,27 +19,8 @@ set(TRGT_headers ${TRGT_hpp})
add_library(${TRGT} INTERFACE) add_library(${TRGT} INTERFACE)
target_sources(${TRGT} INTERFACE ${TRGT_cpp} ${TRGT_headers}) target_sources(${TRGT} INTERFACE ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой clang-tidy
add_clang_tidy_check(${TRGT} ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой clang-analyze
add_clang_analyze_check(${TRGT} ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой clazy
add_clazy_check(${TRGT} ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой pvs-studio
add_pvs_check(${TRGT})
# Создание цели для автоматического форматирования кода
add_format_sources(${TRGT} ${TRGT_cpp} ${TRGT_headers})
target_include_directories(${TRGT} INTERFACE ${CMAKE_SOURCE_DIR}/src) target_include_directories(${TRGT} INTERFACE ${CMAKE_SOURCE_DIR}/src)
generate_pkgconfig(myx-${TRGT} COMPONENT base-dev INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES}) myx_cmake_generate_pkgconfig(${TRGT} BASENAME myx-${TRGT} INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
install(FILES ${TRGT_headers} COMPONENT base-dev install(FILES ${TRGT_headers} COMPONENT dev
DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}/${TRGT}) DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}/${TRGT})
# Цель, используемая только для установки заголовочных файлов без компиляции проекта
add_custom_target(${TRGT}-install-headers COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=base-dev -P
"${CMAKE_BINARY_DIR}/cmake_install.cmake")

View File

@ -0,0 +1,109 @@
#ifndef MYX_CORE_CURRENT_SYSTEM_HPP_
#define MYX_CORE_CURRENT_SYSTEM_HPP_
#pragma once
#include <algorithm>
#include <limits>
#include <fstream>
#include <string>
namespace myx {
namespace core {
class CurrentSystem
{
public:
CurrentSystem( const CurrentSystem& ) = delete;
CurrentSystem& operator=( const CurrentSystem& ) = delete;
CurrentSystem( CurrentSystem&& ) = delete;
CurrentSystem& operator=( CurrentSystem&& ) = delete;
/**
* @brief instance
* @return Уникальный экземпляр класса CurrentSystem
*/
static CurrentSystem& instance()
{
static CurrentSystem sCurrentSystem;
return( sCurrentSystem );
}
std::string os() const { return( m_os ); }
std::string distribution() const { return( m_distribution ); }
std::string variant() const { return( m_variant ); }
std::string version() const { return( m_version ); }
protected:
CurrentSystem() :
m_os
(
#if defined( WIN32 ) || defined( _WIN32 ) || defined( __WIN32__ ) || defined( __NT__ )
"windows"
#elif __linux__
"linux"
#else
#error "Unknown OS"
#endif
)
{
#if defined( __e2k__ )
m_distribution = "debian";
m_variant = "elbrus";
std::ifstream file( "/etc/mcst_version" );
if ( file.is_open() )
{
std::getline( file, m_version );
file.close();
}
#else
std::ifstream file( "/etc/os-release" );
if ( file.is_open() )
{
std::string line;
while ( std::getline( file, line ) )
{
std::size_t pos = line.find( "ID=" );
if ( pos == 0 )
{
m_distribution = line.replace( pos, sizeof( "ID=" ) - 1, "" );
}
pos = line.find( "VARIANT_ID=" );
if ( pos != std::string::npos )
{
m_variant = line.replace( pos, sizeof( "VARIANT_ID=" ) - 1, "" );
}
pos = line.find( "VERSION_ID=" );
if ( pos != std::string::npos )
{
m_version = line.replace( pos, sizeof( "VERSION_ID=" ) - 1, "" );
while ( ( pos = m_version.find( '"' ) ) != std::string::npos )
{
m_version.erase( pos, sizeof( '"' ) );
}
}
}
file.close();
}
#endif // if defined( __e2k__ )
}
~CurrentSystem() = default;
private:
std::string m_os;
std::string m_distribution;
std::string m_variant;
std::string m_version;
}; // class CurrentSystem
// class CurrentSystem
} // namespace core
} // namespace myx
#endif // MYX_CORE_CURRENT_SYSTEM_HPP_

View File

@ -91,11 +91,11 @@ public:
LittleEndianType& operator^=( const T& b ) { *this = T( *this ) ^ b; return( *this ); } LittleEndianType& operator^=( const T& b ) { *this = T( *this ) ^ b; return( *this ); }
LittleEndianType& operator<<=( const T& b ) { *this = T( T( *this ) << b ); return( *this ); } LittleEndianType& operator<<=( const T& b ) { *this = T( T( *this ) << b ); return( *this ); }
LittleEndianType& operator>>=( const T& b ) { *this = T( T( *this ) >> b ); return( *this ); } LittleEndianType& operator>>=( const T& b ) { *this = T( T( *this ) >> b ); return( *this ); }
friend std::ostream& operator<<( std::ostream& out, const LittleEndianType b ) { out << T( b ); return( out ); } friend std::ostream& operator<<( std::ostream& out, const LittleEndianType &b ) { out << T( b ); return( out ); }
friend std::istream& operator>>( std::istream& in, LittleEndianType& b ) { T val; in >> val; b = val; return( in ); } friend std::istream& operator>>( std::istream& in, LittleEndianType& b ) { T val; in >> val; b = val; return( in ); }
std::string toStdString() { return( std::to_string( transform( m_data ) ) ); } std::string toStdString() { return( std::to_string( transform( m_data ) ) ); }
#ifdef QT_CORE_LIB #ifdef QT_CORE_LIB
friend QDebug& operator<<( QDebug& out, const LittleEndianType< T > b ) { out << T( b ); return( out ); } friend QDebug& operator<<( QDebug& out, const LittleEndianType< T > &b ) { out << T( b ); return( out ); }
QString toQString() { return( QString::number( transform( m_data ) ) ); } QString toQString() { return( QString::number( transform( m_data ) ) ); }
#endif #endif
}; // class LittleEndianType }; // class LittleEndianType
@ -151,11 +151,11 @@ public:
BigEndianType& operator^=( const T& b ) { *this = T( *this ) ^ b; return( *this ); } BigEndianType& operator^=( const T& b ) { *this = T( *this ) ^ b; return( *this ); }
BigEndianType& operator<<=( const T& b ) { *this = T( T( *this ) << b ); return( *this ); } BigEndianType& operator<<=( const T& b ) { *this = T( T( *this ) << b ); return( *this ); }
BigEndianType& operator>>=( const T& b ) { *this = T( T( *this ) >> b ); return( *this ); } BigEndianType& operator>>=( const T& b ) { *this = T( T( *this ) >> b ); return( *this ); }
friend std::ostream& operator<<( std::ostream& out, const BigEndianType b ) { out << T( b ); return( out ); } friend std::ostream& operator<<( std::ostream& out, const BigEndianType &b ) { out << T( b ); return( out ); }
friend std::istream& operator>>( std::istream& in, BigEndianType& b ) { T val; in >> val; b = val; return( in ); } friend std::istream& operator>>( std::istream& in, BigEndianType& b ) { T val; in >> val; b = val; return( in ); }
std::string toStdString() { return( std::to_string( transform( m_data ) ) ); } std::string toStdString() { return( std::to_string( transform( m_data ) ) ); }
#ifdef QT_CORE_LIB #ifdef QT_CORE_LIB
friend QDebug& operator<<( QDebug& out, const BigEndianType< T > b ) { out << T( b ); return( out ); } friend QDebug& operator<<( QDebug& out, const BigEndianType< T > &b ) { out << T( b ); return( out ); }
QString toQString() { return( QString::number( transform( m_data ) ) ); } QString toQString() { return( QString::number( transform( m_data ) ) ); }
#endif #endif
}; // class BigEndianType }; // class BigEndianType

View File

@ -1,6 +1,7 @@
#ifndef MYX_CORE_LIMITS_HPP_ #ifndef MYX_CORE_LIMITS_HPP_
#define MYX_CORE_LIMITS_HPP_ #define MYX_CORE_LIMITS_HPP_
#pragma once #pragma once
#include <limits> #include <limits>

View File

@ -11,37 +11,15 @@ set(TRGT_hpp ${CMAKE_CURRENT_SOURCE_DIR}/paths.hpp)
set(TRGT_headers ${TRGT_hpp}) set(TRGT_headers ${TRGT_hpp})
# cmake-format: on # cmake-format: on
add_common_library(${TRGT} OUTPUT_NAME myx-${TRGT} SOURCES ${TRGT_cpp} ${TRGT_headers}) #add_library(${TRGT} ${TRGT_cpp} ${TRGT_headers})
common_target_properties(${TRGT}) add_library(${TRGT} OBJECT ${TRGT_cpp} ${TRGT_headers})
set_target_properties(${TRGT} PROPERTIES OUTPUT_NAME myx-${TRGT})
# Создание цели для проверки утилитой clang-tidy myx_cmake_common_target_properties(${TRGT})
add_clang_tidy_check(${TRGT} ${TRGT_cpp} ${TRGT_headers}) myx_cmake_add_static_library(${TRGT})
myx_cmake_add_shared_library(${TRGT})
# Создание цели для проверки утилитой clang-analyze
add_clang_analyze_check(${TRGT} ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой clazy
add_clazy_check(${TRGT} ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой pvs-studio
add_pvs_check(${TRGT})
# Создание цели для автоматического форматирования кода
add_format_sources(${TRGT} ${TRGT_cpp} ${TRGT_headers})
target_include_directories(${TRGT} SYSTEM PUBLIC ${Qt5Core_INCLUDE_DIRS}) target_include_directories(${TRGT} SYSTEM PUBLIC ${Qt5Core_INCLUDE_DIRS})
target_include_directories(${TRGT} SYSTEM PRIVATE ${CMAKE_SOURCE_DIR}/src)
cotire(${TRGT})
install(TARGETS ${TRGT}_static COMPONENT libs-dev ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}) myx_cmake_generate_pkgconfig(${TRGT} BASENAME myx-${TRGT} INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
if(BUILD_SHARED_LIBS) install(FILES ${TRGT_headers} COMPONENT dev
install(TARGETS ${TRGT}_shared COMPONENT main LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR})
endif()
generate_pkgconfig(myx-${TRGT} COMPONENT base-dev INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
install(FILES ${TRGT_headers} COMPONENT base-dev
DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}/${TRGT}) DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}/${TRGT})
# Цель, используемая только для установки заголовочных файлов без компиляции проекта
add_custom_target(${TRGT}-install-headers COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=base-dev -P
"${CMAKE_BINARY_DIR}/cmake_install.cmake")

View File

@ -14,14 +14,17 @@ namespace myx {
namespace filesystem { namespace filesystem {
MYXLIB_INLINE Paths::Paths() : MYXLIB_INLINE Paths::Paths() :
m_binDirRegex ( "/s*bin$" ), m_binDirRegex ( QStringLiteral( "/s*bin$" ) ),
m_unityBinDirRegex( "/bin/unity$" ) m_unityBinDirRegex( QStringLiteral( "/bin/unity$" ) )
{ {
QFileInfo procSelfExe( QStringLiteral( "/proc/self/exe" ) ); QFileInfo procSelfExe( QStringLiteral( "/proc/self/exe" ) );
QFileInfo currentExecutable = procSelfExe.canonicalFilePath(); QFileInfo currentExecutable = procSelfExe.canonicalFilePath();
m_executableName = currentExecutable.fileName(); m_executableName = currentExecutable.fileName();
m_executableFilePath = currentExecutable.absoluteFilePath(); m_executableFilePath = currentExecutable.absoluteFilePath();
m_executableDirectory = currentExecutable.absolutePath(); m_executableDirectory = currentExecutable.absolutePath();
// Инициализация значениями по умолчанию
init();
} }
@ -54,61 +57,66 @@ MYXLIB_INLINE bool Paths::init( bool autodetect )
} // Paths::init } // Paths::init
MYXLIB_INLINE void Paths::setupSystemDirectories( const QString& defaultProjectDirectory, MYXLIB_INLINE void Paths::setupSystemDirectories( const QString& projectDir,
const QString& defaultEtcDirectory, const QString& etcDir,
const QString& defaultConstDataDirectory, const QString& constDataDir,
const QString& defaultVarDataDirectory, const QString& varDataDir,
const QString& defaultLogDirectory ) const QString& logDir )
{ {
QFileInfo prefixDirInfo { defaultProjectDirectory }; QFileInfo prefixDirInfo { projectDir };
if ( prefixDirInfo.isDir() && prefixDirInfo.isReadable() ) if ( prefixDirInfo.isDir() && prefixDirInfo.isReadable() )
{ {
m_projectDirectory = defaultProjectDirectory; m_projectDirectory = projectDir;
} }
else else
{ {
m_projectDirectory = QStringLiteral( "." ); m_projectDirectory = QStringLiteral( "." );
} }
QFileInfo etcDirInfo { defaultEtcDirectory }; QFileInfo etcDirInfo { etcDir };
if ( etcDirInfo.isDir() && etcDirInfo.isReadable() ) if ( etcDirInfo.isDir() && etcDirInfo.isReadable() )
{ {
m_systemConfigDirectory = defaultEtcDirectory; m_systemConfigDirectory = etcDir;
} }
else else
{ {
m_systemConfigDirectory = m_userConfigDirectory; m_systemConfigDirectory = m_userConfigDirectory;
} }
QFileInfo constDataDirInfo { defaultConstDataDirectory }; QFileInfo constDataDirInfo { constDataDir };
if ( constDataDirInfo.isDir() && constDataDirInfo.isReadable() ) if ( constDataDirInfo.isDir() && constDataDirInfo.isReadable() )
{ {
m_systemConstDataDirectory = defaultConstDataDirectory; m_systemConstDataDirectory = constDataDir;
} }
else else
{ {
m_systemConstDataDirectory = m_userConstDataDirectory; m_systemConstDataDirectory = m_userConstDataDirectory;
} }
QFileInfo varDataDirInfo { defaultVarDataDirectory }; QFileInfo varDataDirInfo { varDataDir };
if ( varDataDirInfo.isDir() && varDataDirInfo.isWritable() ) if ( varDataDirInfo.isDir() && varDataDirInfo.isWritable() )
{ {
m_systemVarDataDirectory = defaultVarDataDirectory; m_systemVarDataDirectory = varDataDir;
} }
else else
{ {
m_systemVarDataDirectory = m_userVarDataDirectory; m_systemVarDataDirectory = m_userVarDataDirectory;
} }
QFileInfo logDirInfo { defaultLogDirectory }; QFileInfo logDirInfo { logDir };
if ( logDirInfo.isDir() && logDirInfo.isWritable() ) if ( logDirInfo.isDir() && logDirInfo.isWritable() )
{ {
m_systemLogDirectory = defaultLogDirectory; m_systemLogDirectory = logDir;
} }
else else
{ {
m_systemLogDirectory = m_userLogDirectory; m_systemLogDirectory = m_userLogDirectory;
} }
if ( !m_organizationName.isEmpty() && !m_themeName.isEmpty() )
{
m_systemThemeDirectory = "/opt/" + m_organizationName + "-" + m_themeName;
}
} // Paths::setupSystemDirectories } // Paths::setupSystemDirectories
@ -118,7 +126,11 @@ MYXLIB_INLINE void Paths::setupUserDirectories()
if ( !m_organizationName.isEmpty() ) if ( !m_organizationName.isEmpty() )
{ {
prefix = "/" + m_organizationName; prefix = "/" + m_organizationName;
if ( !m_themeName.isEmpty() ) { prefix.append( "-" + m_themeName ); } if ( !m_themeName.isEmpty() )
{
prefix.append( "-" + m_themeName );
m_userThemeDirectory = m_dataDirectory + prefix;
}
} }
prefix.append( "/" + m_projectName ); prefix.append( "/" + m_projectName );
m_userConfigDirectory = m_configDirectory + prefix; m_userConfigDirectory = m_configDirectory + prefix;
@ -211,11 +223,11 @@ MYXLIB_INLINE void Paths::calculatePaths( HierarchyType hType )
break; break;
case HierarchyType::kHome: case HierarchyType::kHome:
m_projectDirectory = m_homeDirectory; setupSystemDirectories( m_homeDirectory,
m_systemConfigDirectory = m_userConfigDirectory; m_userConfigDirectory,
m_systemConstDataDirectory = m_userConstDataDirectory; m_userConstDataDirectory,
m_systemVarDataDirectory = m_userVarDataDirectory; m_userVarDataDirectory,
m_systemLogDirectory = m_userLogDirectory; m_userLogDirectory );
break; break;
case HierarchyType::kDevelopment: case HierarchyType::kDevelopment:
@ -241,30 +253,28 @@ MYXLIB_INLINE void Paths::processOptHierarhy()
if ( m_autodetect ) if ( m_autodetect )
{ {
QRegularExpression regex( "^/opt/(.+?)-(.+?)/(.+?)/" ); QRegularExpression regex( QStringLiteral( "^/opt/(.+?)/(.+?)/" ) );
QRegularExpressionMatch match = regex.match( m_executableDirectory ); QRegularExpressionMatch match = regex.match( m_executableDirectory );
if ( match.hasMatch() ) if ( match.hasMatch() )
{ {
m_organizationName = match.captured( 1 ); m_organizationName = match.captured( 1 );
m_themeName = match.captured( 2 ); m_projectName = match.captured( 2 );
m_projectName = match.captured( 3 );
QRegularExpression vr( "(.+?)\\.(.+)" ); QRegularExpression themeRegex( QStringLiteral( "(.+?)-(.+)" ) );
QRegularExpressionMatch vm = vr.match( m_themeName ); QRegularExpressionMatch themeMatch = themeRegex.match( m_organizationName );
if ( vm.hasMatch() ) if ( themeMatch.hasMatch() )
{ {
m_themeName = vm.captured( 1 ); m_themeName = themeMatch.captured( 2 );
m_version = vm.captured( 2 ); m_organizationName = themeMatch.captured( 1 );
} }
}
else QRegularExpression versionRegex( QStringLiteral( "(.+?)\\.(.+)" ) );
{ QRegularExpressionMatch versionMatch = versionRegex.match( m_projectName );
regex.setPattern( "^/opt/(.+?)/(.+?)/" ); if ( versionMatch.hasMatch() )
match = regex.match( m_executableDirectory );
if ( match.hasMatch() )
{ {
m_organizationName = match.captured( 1 ); m_projectName = versionMatch.captured( 1 );
m_projectName = match.captured( 2 ); m_version = versionMatch.captured( 2 );
} }
} }
} }
@ -284,10 +294,10 @@ MYXLIB_INLINE bool Paths::makeDefaultSystemDirectories()
bool status = true; bool status = true;
QDir dir; QDir dir;
if ( !dir.mkpath( m_systemConfigDirectory ) ) { status = false; }
if ( !dir.mkpath( m_systemVarDataDirectory ) ) { status = false; }
if ( !dir.mkpath( m_systemConstDataDirectory ) ) { status = false; } if ( !dir.mkpath( m_systemConstDataDirectory ) ) { status = false; }
if ( !dir.mkpath( m_systemLogDirectory ) ) { status = false; } if ( !dir.mkpath( m_systemLogDirectory ) ) { status = false; }
if ( !dir.mkpath( m_systemConfigDirectory ) ) { status = false; }
if ( !dir.mkpath( m_systemVarDataDirectory ) ) { status = false; }
return( status ); return( status );
} }
@ -298,10 +308,10 @@ MYXLIB_INLINE bool Paths::makeDefaultUserDirectories()
bool status = true; bool status = true;
QDir dir; QDir dir;
if ( !dir.mkpath( m_userConfigDirectory ) ) { status = false; }
if ( !dir.mkpath( m_userVarDataDirectory ) ) { status = false; }
if ( !dir.mkpath( m_userConstDataDirectory ) ) { status = false; } if ( !dir.mkpath( m_userConstDataDirectory ) ) { status = false; }
if ( !dir.mkpath( m_userLogDirectory ) ) { status = false; } if ( !dir.mkpath( m_userLogDirectory ) ) { status = false; }
if ( !dir.mkpath( m_userConfigDirectory ) ) { status = false; }
if ( !dir.mkpath( m_userVarDataDirectory ) ) { status = false; }
return( status ); return( status );
} }
@ -349,6 +359,18 @@ MYXLIB_INLINE const QString& Paths::systemConfigDirectory() const
} }
MYXLIB_INLINE const QString& Paths::userThemeDirectory() const
{
return( m_userThemeDirectory );
}
MYXLIB_INLINE const QString& Paths::systemThemeDirectory() const
{
return( m_systemThemeDirectory );
}
MYXLIB_INLINE const QString& Paths::userVarDataDirectory() const MYXLIB_INLINE const QString& Paths::userVarDataDirectory() const
{ {
return( m_userVarDataDirectory ); return( m_userVarDataDirectory );

View File

@ -18,12 +18,12 @@ namespace myx {
namespace filesystem { namespace filesystem {
/** @brief Класс, предоставляющий методы для получения стандартных путей к каталогам и файлам */ //* @brief Класс, предоставляющий методы для получения стандартных путей к каталогам и файлам
class Paths class Paths
{ {
enum class HierarchyType : intptr_t enum class HierarchyType : intptr_t
{ {
/** @brief Тип расположения файлов не определён */ //* @brief Тип расположения файлов не определён
kUndefined = 0x00, kUndefined = 0x00,
/** @brief Не определено ни одно из типовых размещений файлов /** @brief Не определено ни одно из типовых размещений файлов
* @details Если исполняемый файл не находится в каталоге bin или не найдены * @details Если исполняемый файл не находится в каталоге bin или не найдены
@ -31,17 +31,17 @@ class Paths
* что все файлы находятся в одном каталоге с исполняемым файлом * что все файлы находятся в одном каталоге с исполняемым файлом
*/ */
kFlat = 0x01, kFlat = 0x01,
/** @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии /opt */ //* @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии /opt
kOpt = 0x02, kOpt = 0x02,
/** @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии / usr */ //* @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии / usr
kUsr = 0x03, kUsr = 0x03,
/** @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии /usr/local */ //* @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии /usr/local
kUsrLocal = 0x04, kUsrLocal = 0x04,
/** @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии /usr/local/ORG (используется для работ в проекте Сирена) */ //* @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии /usr/local/ORG (используется для работ в проекте Сирена)
kUsrLocalOrg = 0x05, kUsrLocalOrg = 0x05,
/** @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии /home */ //* @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии /home
kHome = 0x06, kHome = 0x06,
/** @brief Исполняемый файл и сопутствующие каталоги находятся в каталоге программного проекта */ //* @brief Исполняемый файл и сопутствующие каталоги находятся в каталоге программного проекта
kDevelopment = 0x07 kDevelopment = 0x07
}; };
@ -61,16 +61,16 @@ public:
return( sPaths ); return( sPaths );
} }
/** @brief Обновление путей с учётом расположения исполняемого файла */ //* @brief Обновление путей с учётом расположения исполняемого файла
bool init( bool autodetect = true ); bool init( bool autodetect = true );
/** @brief Создание стандартных системных каталогов */ //* @brief Создание стандартных системных каталогов
bool makeDefaultSystemDirectories(); bool makeDefaultSystemDirectories();
/** @brief Создание стандартных пользовательских каталогов */ //* @brief Создание стандартных пользовательских каталогов
bool makeDefaultUserDirectories(); bool makeDefaultUserDirectories();
/** @brief Создание стандартных каталогов */ //* @brief Создание стандартных каталогов
bool makeDefaultDirectories(); bool makeDefaultDirectories();
/** @brief Поиск существующего файла настойки. /** @brief Поиск существующего файла настойки.
@ -82,60 +82,63 @@ public:
*/ */
QString findConfigFile( const QString& configFileName = QLatin1String( "" ) ); QString findConfigFile( const QString& configFileName = QLatin1String( "" ) );
/** @brief Имя исполняемого файла */ //* @brief Имя исполняемого файла
const QString& executableName() const; const QString& executableName() const;
/** @brief Полный путь к исполняемому файлу */ //* @brief Полный путь к исполняемому файлу
const QString& executableFilePath() const; const QString& executableFilePath() const;
/** @brief Полный путь к каталогу с исполняемым файлом */ //* @brief Полный путь к каталогу с исполняемым файлом
const QString& executableDirectory() const; const QString& executableDirectory() const;
/** @brief Полный путь к пользовательскому каталогу с файлами настройки */ //* @brief Путь к общему пользовательскому каталогу для файлов работы (темы)
const QString& userThemeDirectory() const;
//* @brief Путь к общему системному каталогу для файлов работы (темы)
const QString& systemThemeDirectory() const;
//* @brief Полный путь к пользовательскому каталогу с файлами настройки
const QString& userConfigDirectory() const; const QString& userConfigDirectory() const;
/** @brief Полный путь к системному каталогу с файлами настройки */ //* @brief Полный путь к системному каталогу с файлами настройки
const QString& systemConfigDirectory() const; const QString& systemConfigDirectory() const;
/** @brief Полный путь к пользовательскому каталогу с изменяемыми файлами */ //* @brief Полный путь к пользовательскому каталогу с изменяемыми файлами
const QString& userVarDataDirectory() const; const QString& userVarDataDirectory() const;
/** @brief Полный путь к системному каталогу с изменяемыми файлами */ //* @brief Полный путь к системному каталогу с изменяемыми файлами
const QString& systemVarDataDirectory() const; const QString& systemVarDataDirectory() const;
/** @brief Полный путь к пользовательскому каталогу с неизменяемыми файлами */ //* @brief Полный путь к пользовательскому каталогу с неизменяемыми файлами
const QString& userConstDataDirectory() const; const QString& userConstDataDirectory() const;
/** @brief Полный путь к системному каталогу с неизменяемыми файлами */ //* @brief Полный путь к системному каталогу с неизменяемыми файлами
const QString& systemConstDataDirectory() const; const QString& systemConstDataDirectory() const;
/** @brief Полный путь к пользовательскому каталогу с журналами работы */ //* @brief Полный путь к пользовательскому каталогу с журналами работы
const QString& userLogDirectory() const; const QString& userLogDirectory() const;
/** @brief Полный путь к системному каталогу с журналами работы */ //* @brief Полный путь к системному каталогу с журналами работы
const QString& systemLogDirectory() const; const QString& systemLogDirectory() const;
/** @brief Полный путь к каталогу с временными файлами */ //* @brief Полный путь к каталогу с временными файлами
const QString& tempDirectory() const; const QString& tempDirectory() const;
/** @brief Полный путь к домашнему каталогу текущего пользователя */ //* @brief Полный путь к домашнему каталогу текущего пользователя
const QString& homeDirectory() const; const QString& homeDirectory() const;
/** @brief Имя каталога для работы (темы) */ //* @brief Имя каталога для проекта
const QString& themeDirectory() const;
/** @brief Имя каталога для проекта */
const QString& projectDirectory() const; const QString& projectDirectory() const;
/** @brief Название организации */ //* @brief Название организации
const QString& organizationName() const; const QString& organizationName() const;
void setOrganizationName( const QString& name ); void setOrganizationName( const QString& name );
/** @brief Название работы (темы) */ //* @brief Название работы (темы)
const QString& themeName() const; const QString& themeName() const;
void setThemeName( const QString& name ); void setThemeName( const QString& name );
/** @brief Название программного проекта */ //* @brief Название программного проекта
const QString& projectName() const; const QString& projectName() const;
void setProjectName( const QString& name ); void setProjectName( const QString& name );
@ -144,75 +147,77 @@ protected:
~Paths() = default; ~Paths() = default;
private: private:
/** @brief Тип расположения файлов по каталогам */ //* @brief Тип расположения файлов по каталогам
HierarchyType m_hierarchyType { HierarchyType::kFlat }; HierarchyType m_hierarchyType { HierarchyType::kFlat };
/** @brief Автоматически определять значения organizationName, themeName и projectName /** @brief Автоматически определять значения organizationName, themeName и projectName
* @detail Если true, то пытаться автоматически определять значения переменных * @details Если true, то пытаться автоматически определять значения переменных
* на основании полного пути к исполняемому файлу. * на основании полного пути к исполняемому файлу.
* Иначе использовать значения переменных, указанные пользователем. * Иначе использовать значения переменных, указанные пользователем.
*/ */
bool m_autodetect { true }; bool m_autodetect { true };
/** @brief Название организации */ //* @brief Название организации
QString m_organizationName; QString m_organizationName;
/** @brief Название работы (темы) */ //* @brief Название работы (темы)
QString m_themeName; QString m_themeName;
/** @brief Номер версии установленного пакета */ //* @brief Номер версии установленного пакета
QString m_version; QString m_version;
/** @brief Имя проекта, которое используется при формировании имён файлов и каталогов */ //* @brief Имя проекта, которое используется при формировании имён файлов и каталогов
QString m_projectName; QString m_projectName;
QString m_executableName; QString m_executableName;
QString m_executableFilePath; QString m_executableFilePath;
QString m_executableDirectory; QString m_executableDirectory;
/** @brief Общий каталог для файлов работы (темы) */ //* @brief Общий каталог для файлов проекта
QString m_themeDirectory;
/** @brief Общий каталог для файлов проекта */
QString m_projectDirectory; QString m_projectDirectory;
/** @brief Путь к каталогу с временными файлами */ //* @brief Путь к каталогу с временными файлами
QString m_tempDirectory; QString m_tempDirectory;
/** @brief Путь к домашнему каталогу текущего пользователя */ //* @brief Путь к домашнему каталогу текущего пользователя
QString m_homeDirectory; QString m_homeDirectory;
/** @brief Путь к общему пользовательскому каталогу настроек */ //* @brief Путь к общему пользовательскому каталогу настроек
QString m_configDirectory; QString m_configDirectory;
/** @brief Путь к общему пользовательскому каталогу данных */ //* @brief Путь к общему пользовательскому каталогу данных
QString m_dataDirectory; QString m_dataDirectory;
/** @brief Путь к пользовательскому каталогу с изменяемыми файлами */ //* @brief Путь к общему пользовательскому каталогу для файлов работы (темы)
QString m_userThemeDirectory;
//* @brief Путь к общему системному каталогу для файлов работы (темы)
QString m_systemThemeDirectory;
//* @brief Путь к пользовательскому каталогу с изменяемыми файлами
QString m_userVarDataDirectory; QString m_userVarDataDirectory;
/** @brief Путь к системному каталогу с изменяемыми файлами */ //* @brief Путь к системному каталогу с изменяемыми файлами
QString m_systemVarDataDirectory; QString m_systemVarDataDirectory;
/** @brief Путь к пользовательскому каталогу с неизменяемыми файлами */ //* @brief Путь к пользовательскому каталогу с неизменяемыми файлами
QString m_userConstDataDirectory; QString m_userConstDataDirectory;
/** @brief Путь к системному каталогу с неизменяемыми файлами */ //* @brief Путь к системному каталогу с неизменяемыми файлами
QString m_systemConstDataDirectory; QString m_systemConstDataDirectory;
/** @brief Путь к пользовательскому каталогу с журналами работы */ //* @brief Путь к пользовательскому каталогу с журналами работы
QString m_userLogDirectory; QString m_userLogDirectory;
/** @brief Путь к системному каталогу с журналами работы */ //* @brief Путь к системному каталогу с журналами работы
QString m_systemLogDirectory; QString m_systemLogDirectory;
/** @brief Путь к пользовательскому каталогу с файлами настройки */ //* @brief Путь к пользовательскому каталогу с файлами настройки
QString m_userConfigDirectory; QString m_userConfigDirectory;
/** @brief Путь к системному каталогу с файлами настройки */ //* @brief Путь к системному каталогу с файлами настройки
QString m_systemConfigDirectory; QString m_systemConfigDirectory;
QRegularExpression m_binDirRegex; QRegularExpression m_binDirRegex;
QRegularExpression m_unityBinDirRegex; QRegularExpression m_unityBinDirRegex;
void setupSystemDirectories( const QString& defaultProjectDirectory, void setupSystemDirectories( const QString& projectDir,
const QString& defaultEtcDirectory, const QString& etcDir,
const QString& defaultConstDataDirectory, const QString& constDataDir,
const QString& defaultVarDataDirectory, const QString& varDataDir,
const QString& defaultLogDirectory ); const QString& logDir );
void setupUserDirectories(); void setupUserDirectories();
HierarchyType getHierarchyType(); HierarchyType getHierarchyType();

View File

@ -6,6 +6,9 @@ set(TRGT qt)
set(TRGT_cpp set(TRGT_cpp
${CMAKE_CURRENT_SOURCE_DIR}/posix_signal_watcher.cpp ${CMAKE_CURRENT_SOURCE_DIR}/posix_signal_watcher.cpp
${CMAKE_CURRENT_SOURCE_DIR}/translators.cpp ${CMAKE_CURRENT_SOURCE_DIR}/translators.cpp
${CMAKE_CURRENT_SOURCE_DIR}/message_logger_default.cpp
${CMAKE_CURRENT_SOURCE_DIR}/message_logger_handler.cpp
${CMAKE_CURRENT_SOURCE_DIR}/message_logger_syslog.cpp
) )
set(TRGT_moc_hpp set(TRGT_moc_hpp
@ -18,6 +21,10 @@ set(TRGT_moc_private_hpp
set(TRGT_hpp set(TRGT_hpp
${CMAKE_CURRENT_SOURCE_DIR}/translators.hpp ${CMAKE_CURRENT_SOURCE_DIR}/translators.hpp
${CMAKE_CURRENT_SOURCE_DIR}/message_logger.hpp
${CMAKE_CURRENT_SOURCE_DIR}/message_logger_default.hpp
${CMAKE_CURRENT_SOURCE_DIR}/message_logger_handler.hpp
${CMAKE_CURRENT_SOURCE_DIR}/message_logger_syslog.hpp
) )
set(TRGT_headers ${TRGT_moc_hpp} ${TRGT_hpp}) set(TRGT_headers ${TRGT_moc_hpp} ${TRGT_hpp})
@ -25,39 +32,14 @@ set(TRGT_headers ${TRGT_moc_hpp} ${TRGT_hpp})
qt5_wrap_cpp(TRGT_moc_cpp ${TRGT_moc_private_hpp} ${TRGT_moc_hpp}) qt5_wrap_cpp(TRGT_moc_cpp ${TRGT_moc_private_hpp} ${TRGT_moc_hpp})
add_common_library(${TRGT} OUTPUT_NAME myx-${TRGT} SOURCES ${TRGT_cpp} ${TRGT_moc_cpp} add_library(${TRGT} OBJECT ${TRGT_cpp} ${TRGT_moc_cpp} ${TRGT_moc_private_hpp} ${TRGT_headers})
${TRGT_moc_private_hpp} ${TRGT_headers}) set_target_properties(${TRGT} PROPERTIES OUTPUT_NAME myx-${TRGT})
common_target_properties(${TRGT}) myx_cmake_common_target_properties(${TRGT})
myx_cmake_add_static_library(${TRGT})
# Создание цели для проверки утилитой clang-tidy myx_cmake_add_shared_library(${TRGT})
add_clang_tidy_check(${TRGT} ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой clang-analyze
add_clang_analyze_check(${TRGT} ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой clazy
add_clazy_check(${TRGT} ${TRGT_cpp} ${TRGT_headers})
# Создание цели для проверки утилитой pvs-studio
add_pvs_check(${TRGT})
# Создание цели для автоматического форматирования кода
add_format_sources(${TRGT} ${TRGT_cpp} ${TRGT_headers} ${TRGT_moc_private_hpp})
target_include_directories(${TRGT} SYSTEM PUBLIC ${Qt5Core_INCLUDE_DIRS}) target_include_directories(${TRGT} SYSTEM PUBLIC ${Qt5Core_INCLUDE_DIRS})
target_include_directories(${TRGT} SYSTEM PRIVATE ${CMAKE_SOURCE_DIR}/src)
target_include_directories(${TRGT} PRIVATE ${CMAKE_CURRENT_BINARY_DIR})
cotire(${TRGT})
install(TARGETS ${TRGT}_static COMPONENT libs-dev ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}) myx_cmake_generate_pkgconfig(${TRGT} BASENAME myx-${TRGT} INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
if(BUILD_SHARED_LIBS) install(FILES ${TRGT_headers} COMPONENT dev
install(TARGETS ${TRGT}_shared COMPONENT main LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR})
endif()
generate_pkgconfig(myx-${TRGT} COMPONENT base-dev INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
install(FILES ${TRGT_headers} COMPONENT base-dev
DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}/${TRGT}) DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}/${TRGT})
# Цель, используемая только для установки заголовочных файлов без компиляции проекта
add_custom_target(${TRGT}-install-headers COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=base-dev -P
"${CMAKE_BINARY_DIR}/cmake_install.cmake")

View File

@ -0,0 +1,44 @@
#ifndef MYX_QT_MESSAGE_LOGGER_HPP_
#define MYX_QT_MESSAGE_LOGGER_HPP_
#pragma once
#include <myx/backports/qt/common.hpp>
#include <myx/core/config.hpp>
#include <QList>
#include <QMessageLogContext>
#include <QSharedPointer>
#include <QString>
namespace myx {
namespace qt {
class MessageLogger
{
public:
virtual ~MessageLogger() noexcept ( true ) = default;
virtual void debug( const QMessageLogContext& context, const QString& ) = 0;
virtual void info( const QMessageLogContext& context, const QString& ) = 0;
virtual void warning( const QMessageLogContext& context, const QString& ) = 0;
virtual void critical( const QMessageLogContext& context, const QString& ) = 0;
virtual void fatal( const QMessageLogContext& context, const QString& ) = 0;
void setEnabled( bool v = true ) { m_enabled = v; }
bool isEnabled() { return( m_enabled ); }
protected:
bool m_enabled { true };
};
using MessageLoggersList = QList< QSharedPointer< MessageLogger > >;
extern MessageLoggersList messageLoggersList;
} // namespace qt
} // namespace myx
#endif // ifndef MYX_QT_MESSAGE_LOGGER_HPP_

View File

@ -0,0 +1,46 @@
#include <myx/backports/qt/common.hpp>
#include <myx/core/config.hpp>
#include <myx/qt/message_logger_default.hpp>
#include <QtDebug>
namespace myx {
namespace qt {
void MessageLoggerDefault::debug( const QMessageLogContext& context, const QString& msg )
{
Q_UNUSED( context )
fprintf( stderr, "D: %s\n", msg.toUtf8().data() );
}
void MessageLoggerDefault::info( const QMessageLogContext& context, const QString& msg )
{
Q_UNUSED( context )
fprintf( stderr, "I: %s\n", msg.toUtf8().data() );
}
void MessageLoggerDefault::warning( const QMessageLogContext& context, const QString& msg )
{
Q_UNUSED( context )
fprintf( stderr, "W: %s\n", msg.toUtf8().data() );
}
void MessageLoggerDefault::critical( const QMessageLogContext& context, const QString& msg )
{
Q_UNUSED( context )
}
void MessageLoggerDefault::fatal( const QMessageLogContext& context, const QString& msg )
{
Q_UNUSED( context )
}
} // namespace qt
} // namespace myx

View File

@ -0,0 +1,31 @@
#ifndef MYX_QT_MESSAGE_LOGGER_DEFAULT_HPP_
#define MYX_QT_MESSAGE_LOGGER_DEFAULT_HPP_
#pragma once
#include <myx/backports/qt/common.hpp>
#include <myx/core/config.hpp>
#include <myx/qt/message_logger.hpp>
namespace myx {
namespace qt {
class MessageLoggerDefault : public MessageLogger
{
public:
virtual ~MessageLoggerDefault() noexcept ( true ) = default;
void debug( const QMessageLogContext& context, const QString& msg ) override;
void info( const QMessageLogContext& context, const QString& msg ) override;
void warning( const QMessageLogContext& context, const QString& msg ) override;
void critical( const QMessageLogContext& context, const QString& msg ) override;
void fatal( const QMessageLogContext& context, const QString& msg ) override;
};
} // namespace qt
} // namespace myx
#endif // ifndef MYX_QT_MESSAGE_LOGGER_DEFAULT_HPP_

View File

@ -0,0 +1,81 @@
#include <myx/backports/qt/common.hpp>
#include <myx/core/config.hpp>
#include <myx/qt/message_logger.hpp>
#include <QtDebug>
namespace myx {
namespace qt {
MessageLoggersList messageLoggersList;
void message_logger_handler( QtMsgType type, const QMessageLogContext& context, const QString& msg )
{
if ( messageLoggersList.isEmpty() )
{
QByteArray localMsg = msg.toLocal8Bit();
const char* file = context.file != nullptr ? context.file : "";
const char* function = context.function != nullptr ? context.function : "";
switch ( type )
{
case QtDebugMsg:
#ifndef QT_NO_DEBUG_OUTPUT
// fprintf( stderr, "Debug: %s (%s:%u, %s)\n", localMsg.constData(), file, context.line, function );
fprintf( stderr, "%s\n", localMsg.constData() );
#endif
break;
case QtInfoMsg:
#ifndef QT_NO_INFO_OUTPUT
// fprintf( stderr, "Info: %s (%s:%u, %s)\n", localMsg.constData(), file, context.line, function );
fprintf( stderr, "%s\n", localMsg.constData() );
#endif
break;
case QtWarningMsg:
#ifndef QT_NO_WARNING_OUTPUT
// fprintf( stderr, "Warning: %s (%s:%u, %s)\n", localMsg.constData(), file, context.line, function );
fprintf( stderr, "%s\n", localMsg.constData() );
#endif
break;
case QtCriticalMsg:
// fprintf( stderr, "Critical: %s (%s:%u, %s)\n", localMsg.constData(), file, context.line, function );
// fprintf( stderr, "%s\n", localMsg.constData() );
// break;
case QtFatalMsg:
// fprintf( stderr, "Fatal: %s (%s:%u, %s)\n", localMsg.constData(), file, context.line, function );
fprintf( stderr, "%s\n", localMsg.constData() );
break;
} // switch
}
else
{
switch ( type )
{
case QtDebugMsg:
for ( const auto& m: qAsConst( messageLoggersList ) )
{ if ( m->isEnabled() ) { m->debug( context, msg ); } }
break;
case QtInfoMsg:
for ( const auto& m: qAsConst( messageLoggersList ) )
{ if ( m->isEnabled() ) { m->info( context, msg ); } }
break;
case QtWarningMsg:
for ( const auto& m: qAsConst( messageLoggersList ) )
{ if ( m->isEnabled() ) { m->warning( context, msg ); } }
break;
case QtCriticalMsg:
for ( const auto& m: qAsConst( messageLoggersList ) )
{ if ( m->isEnabled() ) { m->critical( context, msg ); } }
break;
case QtFatalMsg:
for ( const auto& m: qAsConst( messageLoggersList ) )
{ if ( m->isEnabled() ) { m->fatal( context, msg ); } }
break;
} // switch
}
} // message_logger_handler
} // namespace qt
} // namespace myx

View File

@ -0,0 +1,20 @@
#ifndef MYX_QT_MESSAGE_LOGGER_HANDLER_HPP_
#define MYX_QT_MESSAGE_LOGGER_HANDLER_HPP_
#pragma once
#include <myx/backports/qt/common.hpp>
#include <myx/core/config.hpp>
#include <myx/qt/message_logger.hpp>
namespace myx {
namespace qt {
void message_logger_handler( QtMsgType type, const QMessageLogContext& context, const QString& msg );
} // namespace qt
} // namespace myx
#endif // ifndef MYX_QT_MESSAGE_LOGGER_HANDLER_HPP_

View File

@ -0,0 +1,61 @@
#include <myx/backports/qt/common.hpp>
#include <myx/core/config.hpp>
#include <myx/qt/message_logger_syslog.hpp>
#include <syslog.h>
namespace myx {
namespace qt {
MessageLoggerSyslog::MessageLoggerSyslog() :
MessageLogger()
{
// openlog( nullptr, LOG_ODELAY, LOG_USER );
}
MessageLoggerSyslog::~MessageLoggerSyslog() noexcept ( true )
{
closelog();
}
void MessageLoggerSyslog::debug( const QMessageLogContext& context, const QString& msg )
{
Q_UNUSED( context )
syslog( LOG_DEBUG, "%s\n", msg.toUtf8().data() );
}
void MessageLoggerSyslog::info( const QMessageLogContext& context, const QString& msg )
{
Q_UNUSED( context )
syslog( LOG_INFO, "%s\n", msg.toUtf8().data() );
}
void MessageLoggerSyslog::warning( const QMessageLogContext& context, const QString& msg )
{
Q_UNUSED( context )
syslog( LOG_WARNING, "%s\n", msg.toUtf8().data() );
}
void MessageLoggerSyslog::critical( const QMessageLogContext& context, const QString& msg )
{
Q_UNUSED( context )
syslog( LOG_CRIT, "%s\n", msg.toUtf8().data() );
}
void MessageLoggerSyslog::fatal( const QMessageLogContext& context, const QString& msg )
{
Q_UNUSED( context )
syslog( LOG_EMERG, "%s\n", msg.toUtf8().data() );
}
} // namespace qt
} // namespace myx

View File

@ -0,0 +1,32 @@
#ifndef MYX_QT_MESSAGE_LOGGER_SYSLOG_HPP_
#define MYX_QT_MESSAGE_LOGGER_SYSLOG_HPP_
#pragma once
#include <myx/backports/qt/common.hpp>
#include <myx/core/config.hpp>
#include <myx/qt/message_logger.hpp>
namespace myx {
namespace qt {
class MessageLoggerSyslog : public MessageLogger
{
public:
MessageLoggerSyslog();
virtual ~MessageLoggerSyslog() noexcept ( true );
void debug( const QMessageLogContext& context, const QString& msg ) override;
void info( const QMessageLogContext& context, const QString& msg ) override;
void warning( const QMessageLogContext& context, const QString& msg ) override;
void critical( const QMessageLogContext& context, const QString& msg ) override;
void fatal( const QMessageLogContext& context, const QString& msg ) override;
};
} // namespace qt
} // namespace myx
#endif // ifndef MYX_QT_MESSAGE_LOGGER_SYSLOG_HPP_

View File

@ -18,8 +18,8 @@ PosixSignalWatcherPrivate::~PosixSignalWatcherPrivate() = default;
PosixSignalWatcherPrivate::PosixSignalWatcherPrivate( PosixSignalWatcher* q ) : PosixSignalWatcherPrivate::PosixSignalWatcherPrivate( PosixSignalWatcher* q ) :
q_ptr( q ) q_ptr( q )
{ {
#if MYX_QT_HAS_POSIX_SIGNALS #ifdef Q_OS_UNIX
// Create socket pair // Create socket pair
if ( ::socketpair( AF_UNIX, SOCK_STREAM, 0, mSockpair.data() ) != 0 ) if ( ::socketpair( AF_UNIX, SOCK_STREAM, 0, mSockpair.data() ) != 0 )
{ {
qDebug() << "PosixSignalWatcher: socketpair: " << ::strerror( errno ); qDebug() << "PosixSignalWatcher: socketpair: " << ::strerror( errno );
@ -61,8 +61,8 @@ MYXLIB_INLINE void PosixSignalWatcherPrivate::watchForSignal( int signal )
return; return;
} }
#if MYX_QT_HAS_POSIX_SIGNALS #ifdef Q_OS_UNIX
// Register a sigaction which will write to the socket pair // Register a sigaction which will write to the socket pair
struct sigaction sigact; //NOLINT struct sigaction sigact; //NOLINT
sigact.sa_handler = PosixSignalWatcherPrivate::signalHandler; //NOLINT sigact.sa_handler = PosixSignalWatcherPrivate::signalHandler; //NOLINT
sigact.sa_flags = 0; sigact.sa_flags = 0;

View File

@ -6,25 +6,19 @@
#include <myx/core/config.hpp> #include <myx/core/config.hpp>
#include <myx/qt/posix_signal_watcher.hpp> #include <myx/qt/posix_signal_watcher.hpp>
#include <QObject>
#include <QMap> #include <QMap>
#include <QObject>
#include <QSocketNotifier> #include <QSocketNotifier>
#include <QtDebug> #include <QtDebug>
#include <array> #include <array>
#include <memory> #include <memory>
#ifdef Q_OS_WIN #ifdef Q_OS_UNIX
#define MYX_QT_HAS_POSIX_SIGNALS 0 #include <cerrno>
#else
#define MYX_QT_HAS_POSIX_SIGNALS 1
#endif
#if MYX_QT_HAS_POSIX_SIGNALS
#include <csignal> #include <csignal>
#include <sys/socket.h> #include <sys/socket.h>
#include <unistd.h> #include <unistd.h>
#include <cerrno>
#endif #endif
namespace myx { namespace myx {
@ -42,7 +36,7 @@ class PosixSignalWatcherPrivate : public QObject
Q_OBJECT Q_OBJECT
public: public:
PosixSignalWatcherPrivate( PosixSignalWatcher* q ); explicit PosixSignalWatcherPrivate( PosixSignalWatcher* q );
~PosixSignalWatcherPrivate(); ~PosixSignalWatcherPrivate();
void watchForSignal( int signal ); void watchForSignal( int signal );