C++ మరియు CMake - బ్రదర్స్ ఎప్పటికీ, పార్ట్ II

C++ మరియు CMake - బ్రదర్స్ ఎప్పటికీ, పార్ట్ II

మునుపటి భాగంలో ఈ వినోదాత్మక కథ CMake బిల్డ్ సిస్టమ్ జనరేటర్‌లో హెడర్ లైబ్రరీని నిర్వహించడం గురించి మాట్లాడింది.

ఈసారి మేము దానికి సంకలనం చేసిన లైబ్రరీని జోడిస్తాము మరియు మాడ్యూల్‌లను ఒకదానితో ఒకటి లింక్ చేయడం గురించి కూడా మాట్లాడుతాము.

మునుపటిలా, అసహనం ఉన్నవారు వెంటనే చేయవచ్చు నవీకరించబడిన రిపోజిటరీకి వెళ్లండి మరియు మీ స్వంత చేతులతో ప్రతిదీ తాకండి.


కంటెంట్

  1. విభజించు
  2. జయించు

విభజించు

మన ఉన్నతమైన లక్ష్యాన్ని సాధించడానికి మనం చేయవలసిన మొదటి విషయం ఏమిటంటే, మనం అభివృద్ధి చేసే సాఫ్ట్‌వేర్‌ను వినియోగదారు దృష్టికోణం నుండి ఏకరీతిగా ఉండే యూనివర్సల్, ఐసోలేటెడ్ బ్లాక్‌లుగా విభజించడం.

మొదటి భాగంలో, అటువంటి ప్రామాణిక బ్లాక్ వివరించబడింది - హెడర్ లైబ్రరీతో కూడిన ప్రాజెక్ట్. ఇప్పుడు మన ప్రాజెక్ట్‌కి కంపైల్డ్ లైబ్రరీని యాడ్ చేద్దాం.

దీన్ని చేయడానికి, ఫంక్షన్ యొక్క అమలును తీసుకుందాం myfunc విడిగా .cpp-ఫైల్:

diff --git a/include/mylib/myfeature.hpp b/include/mylib/myfeature.hpp
index 43db388..ba62b4f 100644
--- a/include/mylib/myfeature.hpp
+++ b/include/mylib/myfeature.hpp
@@ -46,8 +46,5 @@ namespace mylib

         ~  see mystruct
      */
-    inline bool myfunc (mystruct)
-    {
-        return true;
-    }
+    bool myfunc (mystruct);
 }
diff --git a/src/mylib/myfeature.cpp b/src/mylib/myfeature.cpp
new file mode 100644
index 0000000..abb5004
--- /dev/null
+++ b/src/mylib/myfeature.cpp
@@ -0,0 +1,9 @@
+#include <mylib/myfeature.hpp>
+
+namespace mylib
+{
+    bool myfunc (mystruct)
+    {
+        return true;
+    }
+}

అప్పుడు మేము కంపైల్ చేయవలసిన లైబ్రరీని నిర్వచించాము (myfeature), ఇది మునుపటి దశలో పొందిన వాటిని కలిగి ఉంటుంది .cpp- ఫైల్. కొత్త లైబ్రరీకి ఇప్పటికే ఉన్న హెడర్‌లు అవసరం, మరియు దీన్ని అందించడానికి, ఇది ఇప్పటికే ఉన్న ప్రయోజనంతో ముడిపడి ఉంటుంది మరియు ఉండాలి mylib. అంతేకాకుండా, వాటి మధ్య కనెక్షన్ పబ్లిక్, అంటే లక్ష్యం కనెక్ట్ చేయబడే ప్రతిదీ myfeature, స్వయంచాలకంగా లోడ్ మరియు లక్ష్యాన్ని స్వీకరిస్తుంది mylib (అల్లడం పద్ధతుల గురించి మరింత).

diff --git a/CMakeLists.txt b/CMakeLists.txt
index 108045c..0de77b8 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -64,6 +64,17 @@ target_compile_features(mylib INTERFACE cxx_std_17)

 add_library(Mylib::mylib ALIAS mylib)

+###################################################################################################
+##
+##      Компилируемая библиотека
+##
+###################################################################################################
+
+add_library(myfeature src/mylib/myfeature.cpp)
+target_link_libraries(myfeature PUBLIC mylib)
+
+add_library(Mylib::myfeature ALIAS myfeature)
+

తర్వాత, సిస్టమ్‌లో కొత్త లైబ్రరీ కూడా ఇన్‌స్టాల్ చేయబడిందని మేము నిర్ధారిస్తాము:

@@ -72,7 +83,7 @@ add_library(Mylib::mylib ALIAS mylib)

 install(DIRECTORY include/mylib DESTINATION include)

-install(TARGETS mylib EXPORT MylibConfig)
+install(TARGETS mylib myfeature EXPORT MylibConfig)
 install(EXPORT MylibConfig NAMESPACE Mylib:: DESTINATION share/Mylib/cmake)

 include(CMakePackageConfigHelpers)

ప్రయోజనం కోసం అని గమనించాలి myfeature, దాని కోసం mylib ఉపసర్గతో మారుపేరు సృష్టించబడింది Mylib::. సిస్టమ్‌లో ఇన్‌స్టాలేషన్ కోసం వాటిని ఎగుమతి చేసేటప్పుడు అదే రెండు ప్రయోజనాల కోసం వ్రాయబడుతుంది. దీనివల్ల ఏదైనా లక్ష్యాలతో ఏకరీతిలో పనిచేయడం సాధ్యమవుతుంది బైండింగ్ పథకం.

దీని తర్వాత, యూనిట్ పరీక్షలను కొత్త లైబ్రరీతో లింక్ చేయడమే మిగిలి ఉంది (ఫంక్షన్ myfunc శీర్షిక నుండి తీసివేయబడింది, కాబట్టి ఇప్పుడు మీరు లింక్ చేయాలి):

diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt
index 5620be4..bc1266c 100644
--- a/test/CMakeLists.txt
+++ b/test/CMakeLists.txt
@@ -4,7 +4,7 @@ add_executable(mylib-unit-tests test_main.cpp)
 target_sources(mylib-unit-tests PRIVATE mylib/myfeature.cpp)
 target_link_libraries(mylib-unit-tests
     PRIVATE
-        Mylib::mylib
+        Mylib::myfeature
         doctest::doctest
 )

శీర్షికలు (Mylib::mylib) ఇప్పుడు మీరు విడిగా కనెక్ట్ చేయవలసిన అవసరం లేదు, ఎందుకంటే, ఇప్పటికే చెప్పినట్లుగా, అవి స్వయంచాలకంగా లైబ్రరీతో పాటు కనెక్ట్ చేయబడతాయి (Mylib::myfeature).

మరియు కొత్తగా వచ్చిన లైబ్రరీని పరిగణనలోకి తీసుకుని కవరేజ్ కొలతలను నిర్ధారించడానికి కొన్ని సూక్ష్మ నైపుణ్యాలను జోడిద్దాం:

@@ -15,11 +15,16 @@ if(MYLIB_COVERAGE AND GCOVR_EXECUTABLE)
     target_compile_options(mylib-unit-tests PRIVATE --coverage)
     target_link_libraries(mylib-unit-tests PRIVATE gcov)

+    target_compile_options(myfeature PRIVATE --coverage)
+    target_link_libraries(myfeature PRIVATE gcov)
+
     add_custom_target(coverage
         COMMAND
             ${GCOVR_EXECUTABLE}
-                --root=${PROJECT_SOURCE_DIR}/include/
-                --object-directory=${CMAKE_CURRENT_BINARY_DIR}
+                --root=${PROJECT_SOURCE_DIR}/
+                --filter=${PROJECT_SOURCE_DIR}/include
+                --filter=${PROJECT_SOURCE_DIR}/src
+                --object-directory=${PROJECT_BINARY_DIR}
         DEPENDS
             check
     )

మీరు మరిన్ని లైబ్రరీలు, ఎక్జిక్యూటబుల్స్ మొదలైనవాటిని జోడించవచ్చు. ప్రాజెక్ట్‌లో అవి ఒకదానికొకటి ఎంత ఖచ్చితంగా కనెక్ట్ అయ్యాయో పట్టింపు లేదు. మా మాడ్యూల్ యొక్క ఇంటర్‌ఫేస్ ఏ లక్ష్యాలు అనేవి మాత్రమే ముఖ్యమైన విషయం, అంటే అవి బయటకు వస్తాయి.

జయించు

ఇప్పుడు మనకు ప్రామాణిక బ్లాక్ మాడ్యూల్‌లు ఉన్నాయి మరియు మేము వాటిని ఆధిపత్యం చేయగలము: వాటిని ఏదైనా సంక్లిష్టత యొక్క నిర్మాణంగా కంపోజ్ చేయండి, వాటిని సిస్టమ్‌లోకి ఇన్‌స్టాల్ చేయడం లేదా వాటిని ఒకే అసెంబ్లీ సిస్టమ్‌లో కలిసి లింక్ చేయడం.

సిస్టమ్‌లోకి ఇన్‌స్టాలేషన్

మాడ్యూల్‌ని ఉపయోగించే ఎంపికలలో ఒకటి మా మాడ్యూల్‌ను సిస్టమ్‌లోకి ఇన్‌స్టాల్ చేయడం.

cmake --build путь/к/сборочной/директории --target install

ఆ తరువాత, ఇది ఆదేశాన్ని ఉపయోగించి ఏదైనా ఇతర ప్రాజెక్ట్‌కి కనెక్ట్ చేయబడింది find_package.

find_package(Mylib 1.0 REQUIRED)

సబ్‌మాడ్యూల్‌గా కనెక్షన్

కమాండ్‌ని ఉపయోగించి సబ్‌మాడ్యూల్‌గా మా ప్రాజెక్ట్‌తో ఫోల్డర్‌ను మరొక ప్రాజెక్ట్‌కి కనెక్ట్ చేయడం మరొక ఎంపిక add_subdirectory.

ఉపయోగం

బైండింగ్ పద్ధతులు భిన్నంగా ఉంటాయి, కానీ ఫలితం ఒకే విధంగా ఉంటుంది. రెండు సందర్భాల్లో, మా మాడ్యూల్‌ని ఉపయోగించి ప్రాజెక్ట్‌లో గోల్‌లు అందుబాటులో ఉంటాయి Mylib::myfeature и Mylib::mylib, దీనిని ఉపయోగించవచ్చు, ఉదాహరణకు, ఇలా:

add_executable(some_executable some.cpp sources.cpp)
target_link_libraries(some_executable PRIVATE Mylib::myfeature)

ప్రత్యేకంగా మా విషయంలో, లైబ్రరీ Mylib::myfeature లైబ్రరీతో లింక్ చేయడానికి అవసరమైనప్పుడు కనెక్ట్ చేయాలి libmyfeature. తగినంత శీర్షికలు ఉంటే, లైబ్రరీని ఉపయోగించడం విలువ Mylib::mylib.

CMake లక్ష్యాలు గమ్మత్తైనవి కావచ్చు, ఉదాహరణకు, కొన్ని లక్షణాలు, డిపెండెన్సీలు మొదలైనవాటిని ఫార్వార్డ్ చేయడానికి మాత్రమే ఉద్దేశించబడింది. అదే సమయంలో, వారితో పనిచేయడం అదే విధంగా జరుగుతుంది.

మనం పొందవలసింది అదే.

మూలం: www.habr.com

ఒక వ్యాఖ్యను జోడించండి