Преобразование проекта
This commit is contained in:
@@ -16,25 +16,8 @@ set(TRGT_headers ${TRGT_hpp})
|
||||
add_library(${TRGT} INTERFACE)
|
||||
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)
|
||||
|
||||
generate_pkgconfig(myx-${TRGT} COMPONENT base-dev INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
|
||||
install(FILES ${TRGT_headers} COMPONENT base-dev
|
||||
myx_cmake_generate_pkgconfig(${TRGT} BASENAME myx-${TRGT} INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
|
||||
install(FILES ${TRGT_headers} COMPONENT dev
|
||||
DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}/backports/compiler)
|
||||
|
||||
# Цель, используемая только для установки заголовочных файлов без компиляции проекта
|
||||
|
@@ -17,27 +17,10 @@ set(TRGT_headers ${TRGT_hpp})
|
||||
add_library(${TRGT} INTERFACE)
|
||||
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)
|
||||
|
||||
generate_pkgconfig(myx-${TRGT} COMPONENT base-dev INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
|
||||
install(FILES ${TRGT_headers} COMPONENT base-dev
|
||||
myx_cmake_generate_pkgconfig(${TRGT} BASENAME myx-${TRGT} INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
|
||||
install(FILES ${TRGT_headers} COMPONENT dev
|
||||
DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}/backports/cpp)
|
||||
|
||||
# Цель, используемая только для установки заголовочных файлов без компиляции проекта
|
||||
add_custom_target(${TRGT}-install-headers COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=base-dev -P
|
||||
add_custom_target(${TRGT}-install-headers COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=dev -P
|
||||
"${CMAKE_BINARY_DIR}/cmake_install.cmake")
|
||||
|
@@ -25,7 +25,7 @@
|
||||
#include <string>
|
||||
#include <type_traits>
|
||||
|
||||
namespace std {
|
||||
namespace std { //-V1061
|
||||
|
||||
template< class T, class E, class = void >
|
||||
struct is_contiguous_container : std::false_type {}; // NOLINT
|
||||
|
@@ -16,27 +16,10 @@ set(TRGT_headers ${TRGT_hpp})
|
||||
add_library(${TRGT} INTERFACE)
|
||||
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)
|
||||
|
||||
install(FILES ${TRGT_headers} COMPONENT base-dev
|
||||
install(FILES ${TRGT_headers} COMPONENT dev
|
||||
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
|
||||
add_custom_target(${TRGT}-install-headers COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=dev -P
|
||||
"${CMAKE_BINARY_DIR}/cmake_install.cmake")
|
||||
|
@@ -19,27 +19,12 @@ set(TRGT_headers ${TRGT_hpp})
|
||||
add_library(${TRGT} INTERFACE)
|
||||
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)
|
||||
|
||||
generate_pkgconfig(myx-${TRGT} COMPONENT base-dev INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
|
||||
install(FILES ${TRGT_headers} COMPONENT base-dev
|
||||
myx_cmake_generate_pkgconfig(${TRGT} BASENAME myx-${TRGT} INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
|
||||
install(FILES ${TRGT_headers} COMPONENT dev
|
||||
DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}/${TRGT})
|
||||
|
||||
# Цель, используемая только для установки заголовочных файлов без компиляции проекта
|
||||
add_custom_target(${TRGT}-install-headers COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=base-dev -P
|
||||
add_custom_target(${TRGT}-install-headers COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=dev -P
|
||||
"${CMAKE_BINARY_DIR}/cmake_install.cmake")
|
||||
|
@@ -91,11 +91,11 @@ public:
|
||||
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 ); }
|
||||
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 ); }
|
||||
std::string toStdString() { return( std::to_string( transform( m_data ) ) ); }
|
||||
#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 ) ) ); }
|
||||
#endif
|
||||
}; // 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( 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 ); }
|
||||
std::string toStdString() { return( std::to_string( transform( m_data ) ) ); }
|
||||
#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 ) ) ); }
|
||||
#endif
|
||||
}; // class BigEndianType
|
||||
|
@@ -1,6 +1,7 @@
|
||||
#ifndef MYX_CORE_LIMITS_HPP_
|
||||
#define MYX_CORE_LIMITS_HPP_
|
||||
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <limits>
|
||||
|
@@ -11,37 +11,18 @@ set(TRGT_hpp ${CMAKE_CURRENT_SOURCE_DIR}/paths.hpp)
|
||||
set(TRGT_headers ${TRGT_hpp})
|
||||
# cmake-format: on
|
||||
|
||||
add_common_library(${TRGT} OUTPUT_NAME myx-${TRGT} SOURCES ${TRGT_cpp} ${TRGT_headers})
|
||||
common_target_properties(${TRGT})
|
||||
|
||||
# Создание цели для проверки утилитой 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})
|
||||
add_library(${TRGT} OBJECT ${TRGT_cpp} ${TRGT_headers})
|
||||
set_target_properties(${TRGT} PROPERTIES OUTPUT_NAME myx-${TRGT})
|
||||
myx_cmake_common_target_properties(${TRGT})
|
||||
myx_cmake_add_static_library(${TRGT})
|
||||
myx_cmake_add_shared_library(${TRGT})
|
||||
|
||||
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})
|
||||
if(BUILD_SHARED_LIBS)
|
||||
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
|
||||
myx_cmake_generate_pkgconfig(${TRGT} BASENAME myx-${TRGT} INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
|
||||
install(FILES ${TRGT_headers} COMPONENT dev
|
||||
DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}/${TRGT})
|
||||
|
||||
# Цель, используемая только для установки заголовочных файлов без компиляции проекта
|
||||
add_custom_target(${TRGT}-install-headers COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=base-dev -P
|
||||
add_custom_target(${TRGT}-install-headers COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=dev -P
|
||||
"${CMAKE_BINARY_DIR}/cmake_install.cmake")
|
||||
|
@@ -18,12 +18,12 @@ namespace myx {
|
||||
|
||||
namespace filesystem {
|
||||
|
||||
/** @brief Класс, предоставляющий методы для получения стандартных путей к каталогам и файлам */
|
||||
//* @brief Класс, предоставляющий методы для получения стандартных путей к каталогам и файлам
|
||||
class Paths
|
||||
{
|
||||
enum class HierarchyType : intptr_t
|
||||
{
|
||||
/** @brief Тип расположения файлов не определён */
|
||||
//* @brief Тип расположения файлов не определён
|
||||
kUndefined = 0x00,
|
||||
/** @brief Не определено ни одно из типовых размещений файлов
|
||||
* @details Если исполняемый файл не находится в каталоге bin или не найдены
|
||||
@@ -31,17 +31,17 @@ class Paths
|
||||
* что все файлы находятся в одном каталоге с исполняемым файлом
|
||||
*/
|
||||
kFlat = 0x01,
|
||||
/** @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии /opt */
|
||||
//* @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии /opt
|
||||
kOpt = 0x02,
|
||||
/** @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии / usr */
|
||||
//* @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии / usr
|
||||
kUsr = 0x03,
|
||||
/** @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии /usr/local */
|
||||
//* @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии /usr/local
|
||||
kUsrLocal = 0x04,
|
||||
/** @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии /usr/local/ORG (используется для работ в проекте Сирена) */
|
||||
//* @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии /usr/local/ORG (используется для работ в проекте Сирена)
|
||||
kUsrLocalOrg = 0x05,
|
||||
/** @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии /home */
|
||||
//* @brief Исполняемый файл и сопутствующие каталоги находятся в иерахии /home
|
||||
kHome = 0x06,
|
||||
/** @brief Исполняемый файл и сопутствующие каталоги находятся в каталоге программного проекта */
|
||||
//* @brief Исполняемый файл и сопутствующие каталоги находятся в каталоге программного проекта
|
||||
kDevelopment = 0x07
|
||||
};
|
||||
|
||||
@@ -61,16 +61,16 @@ public:
|
||||
return( sPaths );
|
||||
}
|
||||
|
||||
/** @brief Обновление путей с учётом расположения исполняемого файла */
|
||||
//* @brief Обновление путей с учётом расположения исполняемого файла
|
||||
bool init( bool autodetect = true );
|
||||
|
||||
/** @brief Создание стандартных системных каталогов */
|
||||
//* @brief Создание стандартных системных каталогов
|
||||
bool makeDefaultSystemDirectories();
|
||||
|
||||
/** @brief Создание стандартных пользовательских каталогов */
|
||||
//* @brief Создание стандартных пользовательских каталогов
|
||||
bool makeDefaultUserDirectories();
|
||||
|
||||
/** @brief Создание стандартных каталогов */
|
||||
//* @brief Создание стандартных каталогов
|
||||
bool makeDefaultDirectories();
|
||||
|
||||
/** @brief Поиск существующего файла настойки.
|
||||
@@ -82,63 +82,63 @@ public:
|
||||
*/
|
||||
QString findConfigFile( const QString& configFileName = QLatin1String( "" ) );
|
||||
|
||||
/** @brief Имя исполняемого файла */
|
||||
//* @brief Имя исполняемого файла
|
||||
const QString& executableName() const;
|
||||
|
||||
/** @brief Полный путь к исполняемому файлу */
|
||||
//* @brief Полный путь к исполняемому файлу
|
||||
const QString& executableFilePath() const;
|
||||
|
||||
/** @brief Полный путь к каталогу с исполняемым файлом */
|
||||
//* @brief Полный путь к каталогу с исполняемым файлом
|
||||
const QString& executableDirectory() const;
|
||||
|
||||
/** @brief Путь к общему пользовательскому каталогу для файлов работы (темы) */
|
||||
//* @brief Путь к общему пользовательскому каталогу для файлов работы (темы)
|
||||
const QString& userThemeDirectory() const;
|
||||
|
||||
/** @brief Путь к общему системному каталогу для файлов работы (темы) */
|
||||
//* @brief Путь к общему системному каталогу для файлов работы (темы)
|
||||
const QString& systemThemeDirectory() const;
|
||||
|
||||
/** @brief Полный путь к пользовательскому каталогу с файлами настройки */
|
||||
//* @brief Полный путь к пользовательскому каталогу с файлами настройки
|
||||
const QString& userConfigDirectory() const;
|
||||
|
||||
/** @brief Полный путь к системному каталогу с файлами настройки */
|
||||
//* @brief Полный путь к системному каталогу с файлами настройки
|
||||
const QString& systemConfigDirectory() const;
|
||||
|
||||
/** @brief Полный путь к пользовательскому каталогу с изменяемыми файлами */
|
||||
//* @brief Полный путь к пользовательскому каталогу с изменяемыми файлами
|
||||
const QString& userVarDataDirectory() const;
|
||||
|
||||
/** @brief Полный путь к системному каталогу с изменяемыми файлами */
|
||||
//* @brief Полный путь к системному каталогу с изменяемыми файлами
|
||||
const QString& systemVarDataDirectory() const;
|
||||
|
||||
/** @brief Полный путь к пользовательскому каталогу с неизменяемыми файлами */
|
||||
//* @brief Полный путь к пользовательскому каталогу с неизменяемыми файлами
|
||||
const QString& userConstDataDirectory() const;
|
||||
|
||||
/** @brief Полный путь к системному каталогу с неизменяемыми файлами */
|
||||
//* @brief Полный путь к системному каталогу с неизменяемыми файлами
|
||||
const QString& systemConstDataDirectory() const;
|
||||
|
||||
/** @brief Полный путь к пользовательскому каталогу с журналами работы */
|
||||
//* @brief Полный путь к пользовательскому каталогу с журналами работы
|
||||
const QString& userLogDirectory() const;
|
||||
|
||||
/** @brief Полный путь к системному каталогу с журналами работы */
|
||||
//* @brief Полный путь к системному каталогу с журналами работы
|
||||
const QString& systemLogDirectory() const;
|
||||
|
||||
/** @brief Полный путь к каталогу с временными файлами */
|
||||
//* @brief Полный путь к каталогу с временными файлами
|
||||
const QString& tempDirectory() const;
|
||||
|
||||
/** @brief Полный путь к домашнему каталогу текущего пользователя */
|
||||
//* @brief Полный путь к домашнему каталогу текущего пользователя
|
||||
const QString& homeDirectory() const;
|
||||
|
||||
/** @brief Имя каталога для проекта */
|
||||
//* @brief Имя каталога для проекта
|
||||
const QString& projectDirectory() const;
|
||||
|
||||
/** @brief Название организации */
|
||||
//* @brief Название организации
|
||||
const QString& organizationName() const;
|
||||
void setOrganizationName( const QString& name );
|
||||
|
||||
/** @brief Название работы (темы) */
|
||||
//* @brief Название работы (темы)
|
||||
const QString& themeName() const;
|
||||
void setThemeName( const QString& name );
|
||||
|
||||
/** @brief Название программного проекта */
|
||||
//* @brief Название программного проекта
|
||||
const QString& projectName() const;
|
||||
void setProjectName( const QString& name );
|
||||
|
||||
@@ -147,67 +147,67 @@ protected:
|
||||
~Paths() = default;
|
||||
|
||||
private:
|
||||
/** @brief Тип расположения файлов по каталогам */
|
||||
//* @brief Тип расположения файлов по каталогам
|
||||
HierarchyType m_hierarchyType { HierarchyType::kFlat };
|
||||
|
||||
/** @brief Автоматически определять значения organizationName, themeName и projectName
|
||||
* @detail Если true, то пытаться автоматически определять значения переменных
|
||||
* на основании полного пути к исполняемому файлу.
|
||||
* Иначе использовать значения переменных, указанные пользователем.
|
||||
/** @brief Автоматически определять значения organizationName, themeName и projectName
|
||||
* @details Если true, то пытаться автоматически определять значения переменных
|
||||
* на основании полного пути к исполняемому файлу.
|
||||
* Иначе использовать значения переменных, указанные пользователем.
|
||||
*/
|
||||
bool m_autodetect { true };
|
||||
|
||||
/** @brief Название организации */
|
||||
//* @brief Название организации
|
||||
QString m_organizationName;
|
||||
|
||||
/** @brief Название работы (темы) */
|
||||
//* @brief Название работы (темы)
|
||||
QString m_themeName;
|
||||
|
||||
/** @brief Номер версии установленного пакета */
|
||||
//* @brief Номер версии установленного пакета
|
||||
QString m_version;
|
||||
|
||||
/** @brief Имя проекта, которое используется при формировании имён файлов и каталогов */
|
||||
//* @brief Имя проекта, которое используется при формировании имён файлов и каталогов
|
||||
QString m_projectName;
|
||||
|
||||
QString m_executableName;
|
||||
QString m_executableFilePath;
|
||||
QString m_executableDirectory;
|
||||
|
||||
/** @brief Общий каталог для файлов проекта */
|
||||
//* @brief Общий каталог для файлов проекта
|
||||
QString m_projectDirectory;
|
||||
|
||||
/** @brief Путь к каталогу с временными файлами */
|
||||
//* @brief Путь к каталогу с временными файлами
|
||||
QString m_tempDirectory;
|
||||
/** @brief Путь к домашнему каталогу текущего пользователя */
|
||||
//* @brief Путь к домашнему каталогу текущего пользователя
|
||||
QString m_homeDirectory;
|
||||
/** @brief Путь к общему пользовательскому каталогу настроек */
|
||||
//* @brief Путь к общему пользовательскому каталогу настроек
|
||||
QString m_configDirectory;
|
||||
/** @brief Путь к общему пользовательскому каталогу данных */
|
||||
//* @brief Путь к общему пользовательскому каталогу данных
|
||||
QString m_dataDirectory;
|
||||
|
||||
/** @brief Путь к общему пользовательскому каталогу для файлов работы (темы) */
|
||||
//* @brief Путь к общему пользовательскому каталогу для файлов работы (темы)
|
||||
QString m_userThemeDirectory;
|
||||
/** @brief Путь к общему системному каталогу для файлов работы (темы) */
|
||||
//* @brief Путь к общему системному каталогу для файлов работы (темы)
|
||||
QString m_systemThemeDirectory;
|
||||
|
||||
/** @brief Путь к пользовательскому каталогу с изменяемыми файлами */
|
||||
//* @brief Путь к пользовательскому каталогу с изменяемыми файлами
|
||||
QString m_userVarDataDirectory;
|
||||
/** @brief Путь к системному каталогу с изменяемыми файлами */
|
||||
//* @brief Путь к системному каталогу с изменяемыми файлами
|
||||
QString m_systemVarDataDirectory;
|
||||
|
||||
/** @brief Путь к пользовательскому каталогу с неизменяемыми файлами */
|
||||
//* @brief Путь к пользовательскому каталогу с неизменяемыми файлами
|
||||
QString m_userConstDataDirectory;
|
||||
/** @brief Путь к системному каталогу с неизменяемыми файлами */
|
||||
//* @brief Путь к системному каталогу с неизменяемыми файлами
|
||||
QString m_systemConstDataDirectory;
|
||||
|
||||
/** @brief Путь к пользовательскому каталогу с журналами работы */
|
||||
//* @brief Путь к пользовательскому каталогу с журналами работы
|
||||
QString m_userLogDirectory;
|
||||
/** @brief Путь к системному каталогу с журналами работы */
|
||||
//* @brief Путь к системному каталогу с журналами работы
|
||||
QString m_systemLogDirectory;
|
||||
|
||||
/** @brief Путь к пользовательскому каталогу с файлами настройки */
|
||||
//* @brief Путь к пользовательскому каталогу с файлами настройки
|
||||
QString m_userConfigDirectory;
|
||||
/** @brief Путь к системному каталогу с файлами настройки */
|
||||
//* @brief Путь к системному каталогу с файлами настройки
|
||||
QString m_systemConfigDirectory;
|
||||
|
||||
QRegularExpression m_binDirRegex;
|
||||
|
@@ -32,39 +32,18 @@ set(TRGT_headers ${TRGT_moc_hpp} ${TRGT_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}
|
||||
${TRGT_moc_private_hpp} ${TRGT_headers})
|
||||
common_target_properties(${TRGT})
|
||||
|
||||
# Создание цели для проверки утилитой 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} ${TRGT_moc_private_hpp})
|
||||
add_library(${TRGT} OBJECT ${TRGT_cpp} ${TRGT_moc_cpp} ${TRGT_moc_private_hpp} ${TRGT_headers})
|
||||
set_target_properties(${TRGT} PROPERTIES OUTPUT_NAME myx-${TRGT})
|
||||
myx_cmake_common_target_properties(${TRGT})
|
||||
myx_cmake_add_static_library(${TRGT})
|
||||
myx_cmake_add_shared_library(${TRGT})
|
||||
|
||||
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})
|
||||
if(BUILD_SHARED_LIBS)
|
||||
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
|
||||
myx_cmake_generate_pkgconfig(${TRGT} BASENAME myx-${TRGT} INSTALL_LIBRARY ${MYXLIB_BUILD_LIBRARIES})
|
||||
install(FILES ${TRGT_headers} COMPONENT dev
|
||||
DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}/${TRGT})
|
||||
|
||||
# Цель, используемая только для установки заголовочных файлов без компиляции проекта
|
||||
add_custom_target(${TRGT}-install-headers COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=base-dev -P
|
||||
add_custom_target(${TRGT}-install-headers COMMAND "${CMAKE_COMMAND}" -DCMAKE_INSTALL_COMPONENT=dev -P
|
||||
"${CMAKE_BINARY_DIR}/cmake_install.cmake")
|
||||
|
@@ -16,8 +16,8 @@ void message_logger_handler( QtMsgType type, const QMessageLogContext& context,
|
||||
if ( messageLoggersList.isEmpty() )
|
||||
{
|
||||
QByteArray localMsg = msg.toLocal8Bit();
|
||||
const char* file = context.file ? context.file : "";
|
||||
const char* function = context.function ? context.function : "";
|
||||
const char* file = context.file != nullptr ? context.file : "";
|
||||
const char* function = context.function != nullptr ? context.function : "";
|
||||
switch ( type )
|
||||
{
|
||||
case QtDebugMsg:
|
||||
@@ -40,8 +40,8 @@ void message_logger_handler( QtMsgType type, const QMessageLogContext& context,
|
||||
break;
|
||||
case QtCriticalMsg:
|
||||
// fprintf( stderr, "Critical: %s (%s:%u, %s)\n", localMsg.constData(), file, context.line, function );
|
||||
fprintf( stderr, "%s\n", localMsg.constData() );
|
||||
break;
|
||||
// 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() );
|
||||
@@ -53,23 +53,23 @@ void message_logger_handler( QtMsgType type, const QMessageLogContext& context,
|
||||
switch ( type )
|
||||
{
|
||||
case QtDebugMsg:
|
||||
for ( auto& m: qAsConst( messageLoggersList ) )
|
||||
for ( const auto& m: qAsConst( messageLoggersList ) )
|
||||
{ if ( m->isEnabled() ) { m->debug( context, msg ); } }
|
||||
break;
|
||||
case QtInfoMsg:
|
||||
for ( auto& m: qAsConst( messageLoggersList ) )
|
||||
for ( const auto& m: qAsConst( messageLoggersList ) )
|
||||
{ if ( m->isEnabled() ) { m->info( context, msg ); } }
|
||||
break;
|
||||
case QtWarningMsg:
|
||||
for ( auto& m: qAsConst( messageLoggersList ) )
|
||||
for ( const auto& m: qAsConst( messageLoggersList ) )
|
||||
{ if ( m->isEnabled() ) { m->warning( context, msg ); } }
|
||||
break;
|
||||
case QtCriticalMsg:
|
||||
for ( auto& m: qAsConst( messageLoggersList ) )
|
||||
for ( const auto& m: qAsConst( messageLoggersList ) )
|
||||
{ if ( m->isEnabled() ) { m->critical( context, msg ); } }
|
||||
break;
|
||||
case QtFatalMsg:
|
||||
for ( auto& m: qAsConst( messageLoggersList ) )
|
||||
for ( const auto& m: qAsConst( messageLoggersList ) )
|
||||
{ if ( m->isEnabled() ) { m->fatal( context, msg ); } }
|
||||
break;
|
||||
} // switch
|
||||
|
@@ -18,8 +18,8 @@ PosixSignalWatcherPrivate::~PosixSignalWatcherPrivate() = default;
|
||||
PosixSignalWatcherPrivate::PosixSignalWatcherPrivate( PosixSignalWatcher* q ) :
|
||||
q_ptr( q )
|
||||
{
|
||||
#if MYX_QT_HAS_POSIX_SIGNALS
|
||||
// Create socket pair
|
||||
#ifdef Q_OS_UNIX
|
||||
// Create socket pair
|
||||
if ( ::socketpair( AF_UNIX, SOCK_STREAM, 0, mSockpair.data() ) != 0 )
|
||||
{
|
||||
qDebug() << "PosixSignalWatcher: socketpair: " << ::strerror( errno );
|
||||
@@ -61,8 +61,8 @@ MYXLIB_INLINE void PosixSignalWatcherPrivate::watchForSignal( int signal )
|
||||
return;
|
||||
}
|
||||
|
||||
#if MYX_QT_HAS_POSIX_SIGNALS
|
||||
// Register a sigaction which will write to the socket pair
|
||||
#ifdef Q_OS_UNIX
|
||||
// Register a sigaction which will write to the socket pair
|
||||
struct sigaction sigact; //NOLINT
|
||||
sigact.sa_handler = PosixSignalWatcherPrivate::signalHandler; //NOLINT
|
||||
sigact.sa_flags = 0;
|
||||
|
@@ -6,25 +6,19 @@
|
||||
#include <myx/core/config.hpp>
|
||||
#include <myx/qt/posix_signal_watcher.hpp>
|
||||
|
||||
#include <QObject>
|
||||
#include <QMap>
|
||||
#include <QObject>
|
||||
#include <QSocketNotifier>
|
||||
#include <QtDebug>
|
||||
|
||||
#include <array>
|
||||
#include <memory>
|
||||
|
||||
#ifdef Q_OS_WIN
|
||||
#define MYX_QT_HAS_POSIX_SIGNALS 0
|
||||
#else
|
||||
#define MYX_QT_HAS_POSIX_SIGNALS 1
|
||||
#endif
|
||||
|
||||
#if MYX_QT_HAS_POSIX_SIGNALS
|
||||
#ifdef Q_OS_UNIX
|
||||
#include <cerrno>
|
||||
#include <csignal>
|
||||
#include <sys/socket.h>
|
||||
#include <unistd.h>
|
||||
#include <cerrno>
|
||||
#endif
|
||||
|
||||
namespace myx {
|
||||
@@ -42,7 +36,7 @@ class PosixSignalWatcherPrivate : public QObject
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
PosixSignalWatcherPrivate( PosixSignalWatcher* q );
|
||||
explicit PosixSignalWatcherPrivate( PosixSignalWatcher* q );
|
||||
~PosixSignalWatcherPrivate();
|
||||
|
||||
void watchForSignal( int signal );
|
||||
|
Reference in New Issue
Block a user