diff --git a/CMakeLists.txt b/CMakeLists.txt index 2c929f5df8..b063bbe618 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -3,13 +3,11 @@ # Author: Scott A. Colcord cmake_minimum_required(VERSION 3.14) +project(coda-oss) -set(TARGET_LANGUAGE c++) set(CMAKE_CXX_STANDARD 17) set(CXX_STANDARD_REQUIRED true) -project(coda-oss) - if (EXISTS "${CMAKE_BINARY_DIR}/conanbuildinfo.cmake") # build and package with conan include("${CMAKE_BINARY_DIR}/conanbuildinfo.cmake") @@ -21,14 +19,13 @@ endif() if (${CMAKE_PROJECT_NAME} STREQUAL coda-oss) # this is the top level project - # set up warnings + # Always turn on "warnings as errors" to avoid lots of (meaningless?) build output; + # we'll dial-back warnings as necessary. if (MSVC) - # set warning level to /W3 - string(REGEX REPLACE "/W[0-4]" "" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}") - string(REGEX REPLACE "/W[0-4]" "" CMAKE_C_FLAGS "${CMAKE_C_FLAGS}") - add_compile_options(/std:c++17) + add_compile_options(/WX) # warnings as errors + add_compile_options(/MP) # multi-processor compile elseif (UNIX) - add_compile_options(-std=c++17) + add_compile_options(-Werror) # warnings as errors endif() list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake") diff --git a/modules/c++/CMakeLists.txt b/modules/c++/CMakeLists.txt index 7ca6fdffa3..34495bbfd0 100644 --- a/modules/c++/CMakeLists.txt +++ b/modules/c++/CMakeLists.txt @@ -1,10 +1,25 @@ set(TARGET_LANGUAGE c++) -# turn on warnings as errors +# turn on maximum warnings if (MSVC) - add_compile_options(/WX /W4) # /Wall + add_compile_options(/std:c++17) + + # By default, there is a /W3 on the command-line from somewhere (?); adding + # /Wn results in a compiler warning. + #add_compile_options(/W4) # /Wall + string(REGEX REPLACE "/W[0-4]" "/W4" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}") # /Wall + elseif (UNIX) - add_compile_options(-Werror -Wall -Wpedantic -Wextra) + add_compile_options(-std=c++17) + + add_compile_options(-Wall -pedantic -Wextra) + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wregister") # -Wvolatile + #set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Weffc++") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wzero-as-null-pointer-constant") + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Woverloaded-virtual") + #set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wold-style-cast") + #set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wsuggest-final-types -Wsuggest-final-methods") + #set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wsuggest-override") endif() # add an interface library for unittests diff --git a/modules/c++/coda-oss-lite.vcxproj b/modules/c++/coda-oss-lite.vcxproj index fba2d0b1f3..9b1eac0299 100644 --- a/modules/c++/coda-oss-lite.vcxproj +++ b/modules/c++/coda-oss-lite.vcxproj @@ -345,6 +345,7 @@ + diff --git a/modules/c++/coda-oss-lite.vcxproj.filters b/modules/c++/coda-oss-lite.vcxproj.filters index b409b14392..76ec00124b 100644 --- a/modules/c++/coda-oss-lite.vcxproj.filters +++ b/modules/c++/coda-oss-lite.vcxproj.filters @@ -1062,6 +1062,9 @@ sys + + sys + diff --git a/modules/c++/config/include/config/disable_compiler_warnings.h b/modules/c++/config/include/config/disable_compiler_warnings.h index a87d281089..a3b1a5125e 100644 --- a/modules/c++/config/include/config/disable_compiler_warnings.h +++ b/modules/c++/config/include/config/disable_compiler_warnings.h @@ -25,7 +25,7 @@ #include "compiler_extensions.h" -#if _MSC_VER +#if defined(_MSC_VER) // We don't care about any padding added to structs #pragma warning(disable: 4820) // '...': '...' bytes padding added after data member '...' @@ -38,6 +38,12 @@ // ??? #pragma warning(disable: 5045) // Compiler will insert Spectre mitigation for memory load if /Qspectre switch specified + +#elif defined(__GNUC__) || defined(__clang__) + +// don't care about compatibility between different -std=c++nn values +CODA_OSS_disable_warning(-Wnoexcept-type) + #endif // _MSC_VER #endif // CODA_OSS_config_disable_compiler_warnings_h_INCLUDED_ diff --git a/modules/c++/io/include/io/ByteStream.h b/modules/c++/io/include/io/ByteStream.h index fe2efe1844..a64b7efc82 100644 --- a/modules/c++/io/include/io/ByteStream.h +++ b/modules/c++/io/include/io/ByteStream.h @@ -68,20 +68,20 @@ struct CODA_OSS_API ByteStream : public SeekableInputStream, public SeekableOutp } virtual - sys::Off_T tell() + sys::Off_T tell() override { return mPosition; } virtual - sys::Off_T seek(sys::Off_T offset, Whence whence); + sys::Off_T seek(sys::Off_T offset, Whence whence) override; /*! * Returns the available bytes to read from the stream * \return the available bytes to read */ virtual - sys::Off_T available(); + sys::Off_T available() override; using OutputStream::write; using InputStream::streamTo; @@ -92,7 +92,7 @@ struct CODA_OSS_API ByteStream : public SeekableInputStream, public SeekableOutp * \param size the number of bytes to write to the stream */ virtual - void write(const void* buffer, size_t size); + void write(const void* buffer, size_t size) override; void reset() { @@ -132,7 +132,7 @@ struct CODA_OSS_API ByteStream : public SeekableInputStream, public SeekableOutp * \throw IoException * \return The number of bytes read */ - virtual sys::SSize_T readImpl(void* buffer, size_t len); + virtual sys::SSize_T readImpl(void* buffer, size_t len) override; private: std::vector mData; diff --git a/modules/c++/io/include/io/CountingStreams.h b/modules/c++/io/include/io/CountingStreams.h index bebca3a5f5..9e7707f378 100644 --- a/modules/c++/io/include/io/CountingStreams.h +++ b/modules/c++/io/include/io/CountingStreams.h @@ -48,7 +48,7 @@ struct CODA_OSS_API CountingOutputStream : public ProxyOutputStream * \param buffer The byte array to write to the stream * \param len The length of the byte array to write to the stream */ - virtual void write(const void* buffer, size_t len) + virtual void write(const void* buffer, size_t len) override { ProxyOutputStream::write(buffer, len); mByteCount += len; diff --git a/modules/c++/io/include/io/DataStream.h b/modules/c++/io/include/io/DataStream.h index 599a609e17..ec42d215eb 100644 --- a/modules/c++/io/include/io/DataStream.h +++ b/modules/c++/io/include/io/DataStream.h @@ -76,7 +76,7 @@ struct DataStream: public io::Serializable * Outputs this object into an output stream. * \param os the OutputStream to write to */ - virtual void serialize(io::OutputStream& os) + virtual void serialize(io::OutputStream& os) override { mStringStream.streamTo(os); } @@ -85,7 +85,7 @@ struct DataStream: public io::Serializable * Unpack this input stream to the object * \param is Stream to read object from */ - virtual void deserialize(io::InputStream& is) + virtual void deserialize(io::InputStream& is) override { is.streamTo(mStringStream); } diff --git a/modules/c++/io/include/io/DbgStream.h b/modules/c++/io/include/io/DbgStream.h index b582104099..0750f84566 100644 --- a/modules/c++/io/include/io/DbgStream.h +++ b/modules/c++/io/include/io/DbgStream.h @@ -89,7 +89,7 @@ struct DbgStream : public OutputStream * \param len The length * \throw IOException */ - virtual void write(const void* buffer, sys::Size_T len) + virtual void write(const void* buffer, sys::Size_T len) override { if (mOn) { diff --git a/modules/c++/io/include/io/FileInputStreamOS.h b/modules/c++/io/include/io/FileInputStreamOS.h index 14389ba1e5..6c16641b7d 100644 --- a/modules/c++/io/include/io/FileInputStreamOS.h +++ b/modules/c++/io/include/io/FileInputStreamOS.h @@ -99,7 +99,7 @@ struct CODA_OSS_API FileInputStreamOS : public SeekableInputStream * \return number of bytes which are readable * */ - virtual sys::Off_T available(); + virtual sys::Off_T available() override; /*! * Report whether or not the file is open @@ -130,7 +130,7 @@ struct CODA_OSS_API FileInputStreamOS : public SeekableInputStream * Go to the offset at the location specified. * \return The number of bytes between off and our origin. */ - virtual sys::Off_T seek(sys::Off_T off, Whence whence) + virtual sys::Off_T seek(sys::Off_T off, Whence whence) override { int from = sys::File::FROM_CURRENT; switch (whence) @@ -154,7 +154,7 @@ struct CODA_OSS_API FileInputStreamOS : public SeekableInputStream * Tell the current offset * \return The byte offset */ - virtual sys::Off_T tell() + virtual sys::Off_T tell() override { return mFile.getCurrentOffset(); } @@ -175,7 +175,7 @@ struct CODA_OSS_API FileInputStreamOS : public SeekableInputStream * \return The number of bytes read * */ - virtual sys::SSize_T readImpl(void* buffer, size_t len); + virtual sys::SSize_T readImpl(void* buffer, size_t len) override; }; } diff --git a/modules/c++/io/include/io/FileOutputStreamOS.h b/modules/c++/io/include/io/FileOutputStreamOS.h index 56fa70dd6e..9156c36f31 100644 --- a/modules/c++/io/include/io/FileOutputStreamOS.h +++ b/modules/c++/io/include/io/FileOutputStreamOS.h @@ -95,16 +95,16 @@ class FileOutputStreamOS : public SeekableOutputStream int creationFlags = sys::File::CREATE | sys::File::TRUNCATE); //! Close the file - void close() + void close() override { mFile.close(); } - virtual void flush(); + virtual void flush() override; - sys::Off_T seek(sys::Off_T offset, io::Seekable::Whence whence); + sys::Off_T seek(sys::Off_T offset, io::Seekable::Whence whence) override; - sys::Off_T tell(); + sys::Off_T tell() override; using OutputStream::write; @@ -116,7 +116,7 @@ class FileOutputStreamOS : public SeekableOutputStream * \param len the length of bytes to write * \throw IoException */ - virtual void write(const void* buffer, size_t len); + virtual void write(const void* buffer, size_t len) override; }; } diff --git a/modules/c++/io/include/io/NullStreams.h b/modules/c++/io/include/io/NullStreams.h index 40f7ed37fd..3243185305 100644 --- a/modules/c++/io/include/io/NullStreams.h +++ b/modules/c++/io/include/io/NullStreams.h @@ -41,19 +41,19 @@ struct NullInputStream : public InputStream { } - virtual sys::Off_T available() + virtual sys::Off_T available() override { return mAvailable; } virtual sys::SSize_T readln(sys::byte *cStr, - const sys::Size_T strLenPlusNullByte) + const sys::Size_T strLenPlusNullByte) override { return read(cStr, strLenPlusNullByte); } virtual sys::SSize_T streamTo(OutputStream& soi, - sys::SSize_T numBytes = IS_END) + sys::SSize_T numBytes = IS_END) override { const sys::SSize_T toProcess = (numBytes == IS_END) ? numBytes : (mAvailable >= numBytes ? numBytes : mAvailable); @@ -77,7 +77,7 @@ struct NullInputStream : public InputStream memset(buffer, 0, len); } - virtual sys::SSize_T readImpl(void* buffer, size_t len) + virtual sys::SSize_T readImpl(void* buffer, size_t len) override { const auto numToRead = mAvailable >= gsl::narrow(len) ? len : gsl::narrow(mAvailable); @@ -108,11 +108,11 @@ struct NullOutputStream : public OutputStream { } - virtual void write(const void* , size_t ) + virtual void write(const void* , size_t ) override { } - virtual void flush() + virtual void flush() override { } }; diff --git a/modules/c++/io/include/io/PipeStream.h b/modules/c++/io/include/io/PipeStream.h index eab02769eb..0a6b910355 100644 --- a/modules/c++/io/include/io/PipeStream.h +++ b/modules/c++/io/include/io/PipeStream.h @@ -76,7 +76,7 @@ struct PipeStream : InputStream * (default 0 means read until max or newline) */ virtual sys::SSize_T readln(sys::byte *cStr, - const sys::Size_T strLenPlusNullByte = 0); + const sys::Size_T strLenPlusNullByte = 0) override; /*! * The streaming occurs as follows: If the numBytes is IS_END, @@ -90,7 +90,7 @@ struct PipeStream : InputStream * input stream to the output stream */ virtual sys::SSize_T streamTo(OutputStream& soi, - sys::SSize_T numBytes = IS_END); + sys::SSize_T numBytes = IS_END) override; PipeStream(const PipeStream&) = delete; PipeStream& operator=(const PipeStream&) = delete; @@ -99,7 +99,7 @@ struct PipeStream : InputStream /*! * \brief returns the requested size in bytes from the stream */ - virtual sys::SSize_T readImpl(void* buffer, size_t len); + virtual sys::SSize_T readImpl(void* buffer, size_t len) override; sys::ExecPipe mExecPipe; diff --git a/modules/c++/io/include/io/ProxyStreams.h b/modules/c++/io/include/io/ProxyStreams.h index 806149ddea..7ec3c11c7c 100644 --- a/modules/c++/io/include/io/ProxyStreams.h +++ b/modules/c++/io/include/io/ProxyStreams.h @@ -47,7 +47,7 @@ struct CODA_OSS_API ProxyInputStream : public InputStream mProxy.release(); } - virtual sys::Off_T available() + virtual sys::Off_T available() override { return mProxy->available(); } @@ -61,7 +61,7 @@ struct CODA_OSS_API ProxyInputStream : public InputStream } protected: - virtual sys::SSize_T readImpl(void* buffer, size_t len) + virtual sys::SSize_T readImpl(void* buffer, size_t len) override { return mProxy->read(buffer, len); } @@ -93,17 +93,17 @@ struct CODA_OSS_API ProxyOutputStream : public OutputStream using OutputStream::write; - virtual void write(const void* buffer, size_t len) + virtual void write(const void* buffer, size_t len) override { mProxy->write(buffer, len); } - virtual void flush() + virtual void flush() override { mProxy->flush(); } - virtual void close() + virtual void close() override { mProxy->close(); } @@ -152,7 +152,7 @@ struct CODA_OSS_API ToggleOutputStream : public io::ProxyOutputStream return mEnabled; } - void close() + void close() override { if (mEnabled && mPtr) mPtr->close(); diff --git a/modules/c++/io/include/io/RotatingFileOutputStream.h b/modules/c++/io/include/io/RotatingFileOutputStream.h index c1c30dcefb..c766bfdb68 100644 --- a/modules/c++/io/include/io/RotatingFileOutputStream.h +++ b/modules/c++/io/include/io/RotatingFileOutputStream.h @@ -46,7 +46,7 @@ struct CODA_OSS_API RotatingFileOutputStream : public CountingOutputStream using CountingOutputStream::write; - virtual void write(const void* buffer, size_t len); + virtual void write(const void* buffer, size_t len) override; protected: std::string mFilename; diff --git a/modules/c++/io/include/io/SerializableFile.h b/modules/c++/io/include/io/SerializableFile.h index 7895bf1c45..f4244586b6 100644 --- a/modules/c++/io/include/io/SerializableFile.h +++ b/modules/c++/io/include/io/SerializableFile.h @@ -55,13 +55,13 @@ class SerializableFile: public Serializable /*! * Transfer this object into a byte stream */ - void serialize(io::OutputStream& os); + void serialize(io::OutputStream& os) override; /*! * Unpack this input stream to the object * \param is Stream to read object from */ - void deserialize(io::InputStream& is); + void deserialize(io::InputStream& is) override; protected: std::string mFilename; diff --git a/modules/c++/io/include/io/StandardStreams.h b/modules/c++/io/include/io/StandardStreams.h index 633fd7a8de..791ffded7c 100644 --- a/modules/c++/io/include/io/StandardStreams.h +++ b/modules/c++/io/include/io/StandardStreams.h @@ -62,12 +62,12 @@ struct StandardOutStream final : public OutputStream * \param len the length of bytes to read * \throw except::IOException */ - virtual void write(const void* buffer, size_t len); + virtual void write(const void* buffer, size_t len) override; /*! * Flushes stdout */ - virtual void flush(); + virtual void flush() override; using OutputStream::write; using OutputStream::writeln; @@ -91,12 +91,12 @@ struct StandardErrStream final : public OutputStream * \param len the length of bytes to read * \throw except::IOException */ - virtual void write(const void* buffer, sys::Size_T len); + virtual void write(const void* buffer, sys::Size_T len) override; /*! * Flushes stderr */ - virtual void flush(); + virtual void flush() override; protected: _STDSTREAM_DECLARE_MUTEX_SEMICOLON_ diff --git a/modules/c++/io/include/io/StringStream.h b/modules/c++/io/include/io/StringStream.h index d8a03ddb9c..80e147d51b 100644 --- a/modules/c++/io/include/io/StringStream.h +++ b/modules/c++/io/include/io/StringStream.h @@ -63,12 +63,12 @@ struct StringStreamT final : public SeekableBidirectionalStream return mData; } - sys::Off_T tell() + sys::Off_T tell() override { return mData.tellg(); } - sys::Off_T seek(sys::Off_T offset, Whence whence) + sys::Off_T seek(sys::Off_T offset, Whence whence) override { std::ios::seekdir flags = std::ios::cur; switch (whence) @@ -94,7 +94,7 @@ struct StringStreamT final : public SeekableBidirectionalStream * Returns the available bytes to read from the stream * \return the available bytes to read */ - sys::Off_T available() + sys::Off_T available() override { const auto where = tell(); @@ -112,7 +112,7 @@ struct StringStreamT final : public SeekableBidirectionalStream * \param buffer the data to write to the stream * \param size the number of bytes to write to the stream */ - void write(const void* buffer, sys::Size_T size) + void write(const void* buffer, sys::Size_T size) override { auto buffer_ = static_cast(buffer); mData.write(buffer_, gsl::narrow(size)); diff --git a/modules/c++/mem/include/mem/ComplexView.h b/modules/c++/mem/include/mem/ComplexView.h index f43ae8c5ae..6b8a60c0dc 100644 --- a/modules/c++/mem/include/mem/ComplexView.h +++ b/modules/c++/mem/include/mem/ComplexView.h @@ -35,6 +35,7 @@ #include #include "coda_oss/span.h" +#include "config/disable_compiler_warnings.h" namespace mem { diff --git a/modules/c++/mem/tests/ScratchVisualization.cpp b/modules/c++/mem/tests/ScratchVisualization.cpp index d9058e0f75..2585f7473f 100644 --- a/modules/c++/mem/tests/ScratchVisualization.cpp +++ b/modules/c++/mem/tests/ScratchVisualization.cpp @@ -329,7 +329,7 @@ int main(int argc, char** argv) const cli::Results* options(parser.parse(argc, argv)); const std::string testType(options->get("test")); - srand((unsigned)time(0)); + srand((unsigned)time(nullptr)); std::ofstream htmlFile; htmlFile.open("scratch_release.html"); diff --git a/modules/c++/mem/unittests/test_scratch_memory.cpp b/modules/c++/mem/unittests/test_scratch_memory.cpp index 421f4eb052..8ef51ee4fd 100644 --- a/modules/c++/mem/unittests/test_scratch_memory.cpp +++ b/modules/c++/mem/unittests/test_scratch_memory.cpp @@ -254,7 +254,7 @@ struct Operation TEST_CASE(testReleaseConcurrentKeys) { - srand((unsigned)time(0)); + srand((unsigned)time(nullptr)); mem::ScratchMemory scratch; std::vector operations; @@ -344,7 +344,7 @@ TEST_CASE(testReleaseConcurrentKeys) TEST_CASE(testReleaseConnectedKeys) { - srand((unsigned)time(0)); + srand((unsigned)time(nullptr)); mem::ScratchMemory scratch; std::vector operations; @@ -434,7 +434,7 @@ TEST_CASE(testReleaseConnectedKeys) TEST_CASE(testGenerateBuffersForRelease) { - srand((unsigned)time(0)); + srand((unsigned)time(nullptr)); for (unsigned int run = 0; run < 50; ++run) { diff --git a/modules/c++/mt/include/mt/BalancedRunnable1D.h b/modules/c++/mt/include/mt/BalancedRunnable1D.h index dc2248df01..c7af782fb7 100644 --- a/modules/c++/mt/include/mt/BalancedRunnable1D.h +++ b/modules/c++/mt/include/mt/BalancedRunnable1D.h @@ -74,7 +74,7 @@ class BalancedRunnable1D : public sys::Runnable { } - virtual void run() + virtual void run() override { while (true) { diff --git a/modules/c++/mt/include/mt/CPUAffinityThreadInitializerLinux.h b/modules/c++/mt/include/mt/CPUAffinityThreadInitializerLinux.h index 8fb26d8bab..ea3349939a 100644 --- a/modules/c++/mt/include/mt/CPUAffinityThreadInitializerLinux.h +++ b/modules/c++/mt/include/mt/CPUAffinityThreadInitializerLinux.h @@ -58,7 +58,7 @@ class CPUAffinityThreadInitializerLinux : * * \throws if setting the thread affinity fails */ - virtual void initialize(); + virtual void initialize() override; private: std::unique_ptr mCPU; diff --git a/modules/c++/mt/include/mt/GenerationThreadPool.h b/modules/c++/mt/include/mt/GenerationThreadPool.h index f22b6be4b0..6a2e53d2fb 100644 --- a/modules/c++/mt/include/mt/GenerationThreadPool.h +++ b/modules/c++/mt/include/mt/GenerationThreadPool.h @@ -63,7 +63,7 @@ namespace mt // If we have a thread initializer, tie down our handler to a CPU virtual void initialize(); - virtual void run(); + virtual void run() override; }; class CODA_OSS_API GenerationThreadPool : public BasicThreadPool @@ -83,7 +83,7 @@ namespace mt GenerationThreadPool(const GenerationThreadPool&) = delete; GenerationThreadPool& operator=(const GenerationThreadPool&) = delete; - virtual TiedRequestHandler *newRequestHandler() + virtual TiedRequestHandler *newRequestHandler() override { TiedRequestHandler* handler = BasicThreadPool::newRequestHandler(); assert(handler != nullptr); diff --git a/modules/c++/mt/include/mt/GenericRequestHandler.h b/modules/c++/mt/include/mt/GenericRequestHandler.h index 0382594de5..5483cc4cd7 100644 --- a/modules/c++/mt/include/mt/GenericRequestHandler.h +++ b/modules/c++/mt/include/mt/GenericRequestHandler.h @@ -55,7 +55,7 @@ class GenericRequestHandler : public sys::Runnable /*! * Dequeue and run requests in a non-terminating loop */ - virtual void run(); + virtual void run() override; protected: RunnableRequestQueue *mRequest; diff --git a/modules/c++/mt/include/mt/ThreadGroup.h b/modules/c++/mt/include/mt/ThreadGroup.h index fa06ae9bcf..7bba1cf263 100644 --- a/modules/c++/mt/include/mt/ThreadGroup.h +++ b/modules/c++/mt/include/mt/ThreadGroup.h @@ -178,7 +178,7 @@ struct CODA_OSS_API ThreadGroup /*! * Call run() on the Runnable passed to createThread */ - virtual void run(); + virtual void run() override; private: std::unique_ptr mRunnable; diff --git a/modules/c++/mt/include/mt/WorkSharingBalancedRunnable1D.h b/modules/c++/mt/include/mt/WorkSharingBalancedRunnable1D.h index 48a83e48f9..dd8e4553de 100644 --- a/modules/c++/mt/include/mt/WorkSharingBalancedRunnable1D.h +++ b/modules/c++/mt/include/mt/WorkSharingBalancedRunnable1D.h @@ -99,7 +99,7 @@ struct WorkSharingBalancedRunnable1D : public sys::Runnable WorkSharingBalancedRunnable1D(WorkSharingBalancedRunnable1D&&) = default; WorkSharingBalancedRunnable1D& operator=(WorkSharingBalancedRunnable1D&&) = delete; - virtual void run() + virtual void run() override { // Operate over this thread's range processElements(mCounter, mEndElement); diff --git a/modules/c++/mt/source/CPUAffinityInitializerLinux.cpp b/modules/c++/mt/source/CPUAffinityInitializerLinux.cpp index bc5cbdd8a8..01181be6b7 100644 --- a/modules/c++/mt/source/CPUAffinityInitializerLinux.cpp +++ b/modules/c++/mt/source/CPUAffinityInitializerLinux.cpp @@ -60,7 +60,7 @@ class AvailableCPUProvider : public AbstractNextCPUProviderLinux { } - virtual std::unique_ptr nextCPU() + virtual std::unique_ptr nextCPU() override { if (mNextCPUIndex >= mCPUs.size()) { @@ -87,7 +87,7 @@ class OffsetCPUProvider : public AbstractNextCPUProviderLinux { } - virtual std::unique_ptr nextCPU() + virtual std::unique_ptr nextCPU() override { std::unique_ptr mask(new sys::ScopedCPUMaskUnix()); CPU_SET_S(mNextCPU++, mask->getSize(), mask->getMask()); diff --git a/modules/c++/mt/tests/MTSingletonTest.cpp b/modules/c++/mt/tests/MTSingletonTest.cpp index 86405f3a03..0488595271 100644 --- a/modules/c++/mt/tests/MTSingletonTest.cpp +++ b/modules/c++/mt/tests/MTSingletonTest.cpp @@ -51,7 +51,7 @@ class StopsWhenEmpty : public GenericRequestHandler { } - void run() + void run() override { while (true) { @@ -101,7 +101,7 @@ class Thespian : public Runnable virtual ~Thespian() { } - void run() + void run() override { //__debugln__(FmtX("[%s]:", mName.c_str())); doLines(); @@ -122,7 +122,7 @@ class Soothsayer : public Thespian { } - void doLines() + void doLines() override { //__warning__("Beware the ides of March."); } diff --git a/modules/c++/mt/tests/ThreadExceptionTest.cpp b/modules/c++/mt/tests/ThreadExceptionTest.cpp index 189f12f275..efc5ee9853 100644 --- a/modules/c++/mt/tests/ThreadExceptionTest.cpp +++ b/modules/c++/mt/tests/ThreadExceptionTest.cpp @@ -29,7 +29,7 @@ class PrintChar : public sys::Runnable { } - virtual void run() + virtual void run() override { print(a); } @@ -61,7 +61,7 @@ class AddInts : public sys::Runnable { } - virtual void run() + virtual void run() override { add(x,y); } @@ -88,7 +88,7 @@ class ConcatStr: public sys::Runnable { } - virtual void run() + virtual void run() override { printConcat(x,y); } diff --git a/modules/c++/mt/unittests/ThreadGroupTest.cpp b/modules/c++/mt/unittests/ThreadGroupTest.cpp index 9622600560..09641ef551 100644 --- a/modules/c++/mt/unittests/ThreadGroupTest.cpp +++ b/modules/c++/mt/unittests/ThreadGroupTest.cpp @@ -41,7 +41,7 @@ struct MyRunTask final : public sys::Runnable (*num_deleted)++; } - virtual void run() + virtual void run() override { while (result == 1) result = *state; diff --git a/modules/c++/re/include/re/RegexPredicate.h b/modules/c++/re/include/re/RegexPredicate.h index b34f9cfb3e..ffccf71afc 100644 --- a/modules/c++/re/include/re/RegexPredicate.h +++ b/modules/c++/re/include/re/RegexPredicate.h @@ -37,7 +37,7 @@ struct RegexPredicate : public sys::FilePredicate mRegex.compile(match); } - bool operator()(const std::string& filename) const + bool operator()(const std::string& filename) const override { return mRegex.matches(filename); } diff --git a/modules/c++/str/include/str/utf8.h b/modules/c++/str/include/str/utf8.h index c4e2666a8d..27baba0859 100644 --- a/modules/c++/str/include/str/utf8.h +++ b/modules/c++/str/include/str/utf8.h @@ -391,7 +391,7 @@ class invalid_code_point final : public exception invalid_code_point(uint32_t cp) : cp(cp) { } - virtual const char* what() const noexcept + virtual const char* what() const noexcept override { return "Invalid code point"; } @@ -409,7 +409,7 @@ class invalid_utf8 final : public exception invalid_utf8(uint8_t u) : u8(u) { } - virtual const char* what() const noexcept + virtual const char* what() const noexcept override { return "Invalid UTF-8"; } @@ -427,7 +427,7 @@ class invalid_utf16 final : public exception invalid_utf16(uint16_t u) : u16(u) { } - virtual const char* what() const noexcept + virtual const char* what() const noexcept override { return "Invalid UTF-16"; } @@ -440,7 +440,7 @@ class invalid_utf16 final : public exception class not_enough_room final : public exception { public: - virtual const char* what() const noexcept + virtual const char* what() const noexcept override { return "Not enough space"; } diff --git a/modules/c++/sys/include/sys/ConditionVarPosix.h b/modules/c++/sys/include/sys/ConditionVarPosix.h index b5aef09461..2144ac63d8 100644 --- a/modules/c++/sys/include/sys/ConditionVarPosix.h +++ b/modules/c++/sys/include/sys/ConditionVarPosix.h @@ -66,17 +66,17 @@ class ConditionVarPosix final : public ConditionVarInterface /*! * Acquire the lock */ - virtual void acquireLock(); + virtual void acquireLock() override; /*! * Drop (release) the lock */ - virtual void dropLock(); + virtual void dropLock() override; /*! * Signal using pthread_cond_signal */ - virtual void signal(); + virtual void signal() override; /*! * Wait using pthread_cond_wait @@ -86,7 +86,7 @@ class ConditionVarPosix final : public ConditionVarInterface * certain systems, undefined/unfavorable behavior may * result. */ - virtual void wait(); + virtual void wait() override; /*! * Wait using pthread_cond_timed_wait. I kept this and the above @@ -99,12 +99,12 @@ class ConditionVarPosix final : public ConditionVarInterface * certain systems, undefined/unfavorable behavior may * result. */ - virtual void wait(double seconds); + virtual void wait(double seconds) override; /*! * Broadcast (notify all) */ - virtual void broadcast(); + virtual void broadcast() override; /*! * Returns the native type. diff --git a/modules/c++/sys/include/sys/Err.h b/modules/c++/sys/include/sys/Err.h index 161c27618a..c7163f35bd 100644 --- a/modules/c++/sys/include/sys/Err.h +++ b/modules/c++/sys/include/sys/Err.h @@ -168,7 +168,7 @@ struct SocketErr : public Err } //! Redefined for socket errors - virtual int getLast() const; + virtual int getLast() const override; }; diff --git a/modules/c++/sys/include/sys/Exec.h b/modules/c++/sys/include/sys/Exec.h index 27eeaedde6..baee2e581e 100644 --- a/modules/c++/sys/include/sys/Exec.h +++ b/modules/c++/sys/include/sys/Exec.h @@ -62,7 +62,7 @@ class Exec : public sys::Runnable /*! * Execute a command */ - virtual void run() + virtual void run() override { if (::system(mCmd.c_str()) == -1) { @@ -96,7 +96,7 @@ struct ExecPipe : Exec } //! start the child process and connect the pipe - virtual void run() + virtual void run() override { mOutStream = openPipe(mCmd, "r"); if (mOutStream == nullptr) diff --git a/modules/c++/sys/include/sys/File.h b/modules/c++/sys/include/sys/File.h index 613e289368..0eacf0e320 100644 --- a/modules/c++/sys/include/sys/File.h +++ b/modules/c++/sys/include/sys/File.h @@ -20,8 +20,17 @@ * */ -#ifndef __SYS_FILE_H__ -#define __SYS_FILE_H__ +#ifndef CODA_OSS_sys_File_h_INCLUDED_ +#define CODA_OSS_sys_File_h_INCLUDED_ +#pragma once + +#include +#include +#include +#include + +#include +#include #include "sys/Conf.h" #include "sys/SystemException.h" @@ -100,12 +109,22 @@ struct CODA_OSS_API File { create(path.getPath(), accessFlags, creationFlags); } + File(std::nothrow_t, const coda_oss::filesystem::path& path, + int accessFlags = READ_ONLY, int creationFlags = EXISTING) noexcept // caller MUST check isOpen() + { + create(std::nothrow, path, accessFlags, creationFlags); + } File(const Path& parent, std::string name, int accessFlags = READ_ONLY, int creationFlags = EXISTING) { create(parent.join(name).getPath(), accessFlags, creationFlags); } + File(std::nothrow_t, const coda_oss::filesystem::path& parent, const coda_oss::filesystem::path& name, + int accessFlags = READ_ONLY, int creationFlags = EXISTING) noexcept // caller MUST check isOpen() + { + create(std::nothrow, parent / name, accessFlags, creationFlags); + } /*! * Constructor. Initializes to a file. @@ -128,6 +147,11 @@ struct CODA_OSS_API File close(); } + File(const File&) = default; + File& operator=(const File&) = default; + File(File&&) = default; + File& operator=(File&&) = default; + /*! * Is the file open? * \return true if open, false if invalid handle @@ -162,8 +186,13 @@ struct CODA_OSS_API File * \param accessFlags File access flags * \param creationFlags File creation flags */ - void create(const std::string& str, int accessFlags, - int creationFlags); + void create(const std::string& str, int accessFlags, int creationFlags); + void create(std::nothrow_t, const coda_oss::filesystem::path& path, + int accessFlags, int creationFlags) // caller MUST check isOpen() + { + mHandle = createFile(path, accessFlags, creationFlags); + mPath = path.string(); + } /*! * Read from the File into a buffer 'size' bytes. @@ -235,10 +264,35 @@ struct CODA_OSS_API File protected: _SYS_HANDLE_TYPE mHandle = SYS_INVALID_HANDLE; std::string mPath; + + static _SYS_HANDLE_TYPE createFile(const coda_oss::filesystem::path&, int accessFlags, int creationFlags) noexcept; }; -} +// These routines use sys::expandEnvironmentVariables() if the initial open attempt fails. +CODA_OSS_API File make_File(const coda_oss::filesystem::path&, int accessFlags = File::READ_ONLY, int creationFlags = File::EXISTING); +CODA_OSS_API File make_File(const coda_oss::filesystem::path& parent, const coda_oss::filesystem::path& name, + int accessFlags = File::READ_ONLY, int creationFlags = File::EXISTING); + +// Call sys::expandEnvironmentVariables() if the initial fopen() fails. +CODA_OSS_API FILE* fopen(const coda_oss::filesystem::path&, const std::string& mode); +CODA_OSS_API int open(const coda_oss::filesystem::path&, int flags); +CODA_OSS_API int open(const coda_oss::filesystem::path&, int flags, int mode); +CODA_OSS_API int close(int fd); // needed to close a FD from open() + +#ifdef _WIN32 +#define CODA_OSS_stat _stat +#else +#define CODA_OSS_stat stat #endif +// Call sys::expandEnvironmentVariables() if the initial stat() attempt fails. +CODA_OSS_API int stat(const coda_oss::filesystem::path&, struct CODA_OSS_stat &buffer); + +// Call sys::expandEnvironmentVariables() if the initial open attempt fails. +CODA_OSS_API std::ifstream make_ifstream(const coda_oss::filesystem::path&, std::ios_base::openmode mode = std::ios_base::in); // https://en.cppreference.com/w/cpp/io/basic_ifstream/basic_ifstream +CODA_OSS_API void open(std::ifstream&, const coda_oss::filesystem::path&, std::ios_base::openmode mode = std::ios_base::in); // https://en.cppreference.com/w/cpp/io/basic_ifstream/open + +} +#endif // CODA_OSS_sys_File_h_INCLUDED_ diff --git a/modules/c++/sys/include/sys/FileFinder.h b/modules/c++/sys/include/sys/FileFinder.h index d3ffd5600b..be9ae0bcf8 100644 --- a/modules/c++/sys/include/sys/FileFinder.h +++ b/modules/c++/sys/include/sys/FileFinder.h @@ -51,7 +51,7 @@ struct FilePredicate struct ExistsPredicate : FilePredicate { virtual ~ExistsPredicate() = default; - virtual bool operator()(const std::string& entry) const; + virtual bool operator()(const std::string& entry) const override; }; /** @@ -60,7 +60,7 @@ struct ExistsPredicate : FilePredicate struct FileOnlyPredicate: public FilePredicate { virtual ~FileOnlyPredicate() = default; - virtual bool operator()(const std::string& entry) const; + virtual bool operator()(const std::string& entry) const override; }; /** @@ -69,7 +69,7 @@ struct FileOnlyPredicate: public FilePredicate struct DirectoryOnlyPredicate: public FilePredicate { virtual ~DirectoryOnlyPredicate() = default; - virtual bool operator()(const std::string& entry) const; + virtual bool operator()(const std::string& entry) const override; }; /** @@ -78,7 +78,7 @@ struct DirectoryOnlyPredicate: public FilePredicate struct FragmentPredicate : public FilePredicate { FragmentPredicate(const std::string& fragment, bool ignoreCase = true); - bool operator()(const std::string& entry) const; + bool operator()(const std::string& entry) const override; private: std::string mFragment; @@ -96,7 +96,7 @@ struct FragmentPredicate : public FilePredicate struct ExtensionPredicate: public FileOnlyPredicate { ExtensionPredicate(const std::string& ext, bool ignoreCase = true); - bool operator()(const std::string& filename) const; + bool operator()(const std::string& filename) const override; private: std::string mExt; @@ -111,7 +111,7 @@ struct NotPredicate : public FilePredicate NotPredicate(FilePredicate* filter, bool ownIt = false); virtual ~NotPredicate(); - virtual bool operator()(const std::string& entry) const; + virtual bool operator()(const std::string& entry) const override; protected: typedef std::pair PredicatePair; @@ -132,7 +132,7 @@ struct LogicalPredicate : public FilePredicate sys::LogicalPredicate& addPredicate(FilePredicate* filter, bool ownIt = false); - virtual bool operator()(const std::string& entry) const; + virtual bool operator()(const std::string& entry) const override; protected: bool mOrOperator = true; diff --git a/modules/c++/sys/include/sys/LocalDateTime.h b/modules/c++/sys/include/sys/LocalDateTime.h index 5f36e3c58c..5effbcaa69 100644 --- a/modules/c++/sys/include/sys/LocalDateTime.h +++ b/modules/c++/sys/include/sys/LocalDateTime.h @@ -39,15 +39,15 @@ class CODA_OSS_API LocalDateTime : public DateTime int mDST; //! @brief Set members from the tm struct value. - virtual void fromMillis(const tm& t); + virtual void fromMillis(const tm& t) override; /** * @brief Set the millis value from the members */ - virtual void toMillis(); + virtual void toMillis() override; // ! Given seconds since the epoch, provides the local time - virtual void getTime(time_t numSecondsSinceEpoch, tm& t) const; + virtual void getTime(time_t numSecondsSinceEpoch, tm& t) const override; public: /*! diff --git a/modules/c++/sys/include/sys/MutexCpp11.h b/modules/c++/sys/include/sys/MutexCpp11.h index 1a3438a7ec..b95738d349 100644 --- a/modules/c++/sys/include/sys/MutexCpp11.h +++ b/modules/c++/sys/include/sys/MutexCpp11.h @@ -50,12 +50,12 @@ struct MutexCpp11 final : public MutexInterface /*! * Lock the mutex. */ - virtual void lock(); + virtual void lock() override; /*! * Unlock the mutex. */ - virtual void unlock(); + virtual void unlock() override; /*! * Returns the native type. diff --git a/modules/c++/sys/include/sys/MutexPosix.h b/modules/c++/sys/include/sys/MutexPosix.h index e954c33129..8ffbaf88f0 100644 --- a/modules/c++/sys/include/sys/MutexPosix.h +++ b/modules/c++/sys/include/sys/MutexPosix.h @@ -54,12 +54,12 @@ class MutexPosix : public MutexInterface /*! * Lock the mutex. */ - virtual void lock(); + virtual void lock() override; /*! * Unlock the mutex. */ - virtual void unlock(); + virtual void unlock() override; /*! * Returns the native type. diff --git a/modules/c++/sys/include/sys/OSUnix.h b/modules/c++/sys/include/sys/OSUnix.h index 9e94df4902..eb1a52dd36 100644 --- a/modules/c++/sys/include/sys/OSUnix.h +++ b/modules/c++/sys/include/sys/OSUnix.h @@ -38,9 +38,9 @@ struct OSUnix final : public AbstractOS OSUnix() = default; virtual ~OSUnix() = default; - virtual std::string getPlatformName() const; + virtual std::string getPlatformName() const override; - virtual std::string getNodeName() const; + virtual std::string getNodeName() const override; /*! * Get the path delimiter for this operating system. @@ -48,7 +48,7 @@ struct OSUnix final : public AbstractOS * For unix it will be one slash / * \return The path delimiter */ - virtual const char* getDelimiter() const + virtual const char* getDelimiter() const override { return "/"; } @@ -64,64 +64,64 @@ struct OSUnix final : public AbstractOS * \param path The path to check for * \return True if it does, false otherwise */ - virtual bool exists(const std::string& path) const; + virtual bool exists(const std::string& path) const override; /*! * Move file with this path name to the newPath * \return True upon success, false if failure */ virtual bool move(const std::string& path, - const std::string& newPath) const; + const std::string& newPath) const override; /*! * Does this path resolve to a file? * \param path The path * \return True if it does, false if not */ - virtual bool isFile(const std::string& path) const; + virtual bool isFile(const std::string& path) const override; /*! * Does this path resolve to a directory? * \param path The path * \return True if it does, false if not */ - virtual bool isDirectory(const std::string& path) const; + virtual bool isDirectory(const std::string& path) const override; - virtual bool makeDirectory(const std::string& path) const; + virtual bool makeDirectory(const std::string& path) const override; - virtual Pid_T getProcessId() const; + virtual Pid_T getProcessId() const override; /*! * Retrieve the current working directory. * \return The current working directory */ - virtual std::string getCurrentWorkingDirectory() const; + virtual std::string getCurrentWorkingDirectory() const override; /*! * Change the current working directory. * \return true if the directory was changed, otherwise false. */ - virtual bool changeDirectory(const std::string& path) const; + virtual bool changeDirectory(const std::string& path) const override; /*! * Get a suitable temporary file name * \return The file name */ virtual std::string getTempName(const std::string& path = ".", - const std::string& prefix = "TMP") const; + const std::string& prefix = "TMP") const override; /*! * Return the size in bytes of a file * \return The file size */ - virtual sys::Off_T getSize(const std::string& path) const; + virtual sys::Off_T getSize(const std::string& path) const override; /** * Returns the last modified time of the file/directory */ - virtual sys::Off_T getLastModifiedTime(const std::string& path) const; + virtual sys::Off_T getLastModifiedTime(const std::string& path) const override; /*! * This is a system independent sleep function. @@ -130,59 +130,59 @@ struct OSUnix final : public AbstractOS * use nanosleep * \param milliseconds The params */ - virtual void millisleep(int milliseconds) const; + virtual void millisleep(int milliseconds) const override; - virtual std::string operator[](const std::string& s) const; + virtual std::string operator[](const std::string& s) const override; /*! * Get an environment variable */ - virtual std::string getEnv(const std::string& s) const; + virtual std::string getEnv(const std::string& s) const override; /*! * Returns true if environment variable is set, false otherwise */ - virtual bool isEnvSet(const std::string& s) const; + virtual bool isEnvSet(const std::string& s) const override; /*! * Set an environment variable */ virtual void setEnv(const std::string& var, const std::string& val, - bool overwrite); + bool overwrite) override; /*! * Unset an environment variable */ - virtual void unsetEnv(const std::string& var); + virtual void unsetEnv(const std::string& var) override; - virtual std::string getDSOSuffix() const; + virtual std::string getDSOSuffix() const override; /*! * \return the number of logical CPUs present on the machine * (includes hyperthreading) */ - virtual size_t getNumCPUs() const; + virtual size_t getNumCPUs() const override; /*! * \return the number of logical CPUs available. This will be * affected by pinning (e.g. numactl/taskset), and will * always be <= getNumCPUs. */ - virtual size_t getNumCPUsAvailable() const; + virtual size_t getNumCPUsAvailable() const override; /*! * \return the number of physical CPUs present on the machine * (excludes hyperthreading) */ - virtual size_t getNumPhysicalCPUs() const; + virtual size_t getNumPhysicalCPUs() const override; /*! * \return the number of physical CPUs available. This will be * affected by pinning (e.g. numactl/taskset), and will * always be <= getNumPhysicalCPUs. */ - virtual size_t getNumPhysicalCPUsAvailable() const; + virtual size_t getNumPhysicalCPUsAvailable() const override; /*! * Divide the available CPUs (pinned with numactl/taskset) into @@ -199,41 +199,41 @@ struct OSUnix final : public AbstractOS * getNumCPUsAvailable() - getNumPhysicalCPUsAvailable(). */ virtual void getAvailableCPUs(std::vector& physicalCPUs, - std::vector& htCPUs) const; + std::vector& htCPUs) const override; /*! * Create a symlink, pathnames can be either absolute or relative */ virtual void createSymlink(const std::string& origPathname, - const std::string& symlinkPathname) const; + const std::string& symlinkPathname) const override; /*! * Remove a symlink, pathname can be absolute or relative */ - virtual void removeSymlink(const std::string& symlinkPathname) const; + virtual void removeSymlink(const std::string& symlinkPathname) const override; /*! * Get the total RAM and available RAM on the system in megabytes */ - virtual void getMemInfo(size_t& totalPhysMem, size_t& freePhysMem) const; + virtual void getMemInfo(size_t& totalPhysMem, size_t& freePhysMem) const override; /*! * Get the absolute path to the current executable */ virtual std::string getCurrentExecutable( - const std::string& argvPathname="") const; + const std::string& argvPathname="") const override; protected: /*! * Remove file with this pathname */ - virtual void removeFile(const std::string& pathname) const; + virtual void removeFile(const std::string& pathname) const override; /*! * Remove directory with this pathname * NOTE: This will throw if the directory is not empty */ - virtual void removeDirectory(const std::string& pathname) const; + virtual void removeDirectory(const std::string& pathname) const override; }; struct DirectoryUnix final : public AbstractDirectory diff --git a/modules/c++/sys/include/sys/ProcessInterface.h b/modules/c++/sys/include/sys/ProcessInterface.h index 930a514f9d..a93d3c749d 100644 --- a/modules/c++/sys/include/sys/ProcessInterface.h +++ b/modules/c++/sys/include/sys/ProcessInterface.h @@ -60,7 +60,7 @@ template class ProcessInterface : public sys::Runnable virtual void start() = 0; virtual void waitFor() = 0; - virtual void run() = 0; + virtual void run() override = 0; protected: Pid_T mChildProcessID; diff --git a/modules/c++/sys/include/sys/ProcessUnix.h b/modules/c++/sys/include/sys/ProcessUnix.h index f435d33dbb..fed0a83044 100644 --- a/modules/c++/sys/include/sys/ProcessUnix.h +++ b/modules/c++/sys/include/sys/ProcessUnix.h @@ -48,8 +48,8 @@ class ProcessUnix : public ProcessInterface< Pid_T > {} virtual ~ProcessUnix() {} - void start(); - void waitFor(); + void start() override; + void waitFor() override; }; } diff --git a/modules/c++/sys/include/sys/SemaphorePosix.h b/modules/c++/sys/include/sys/SemaphorePosix.h index fc1731d8f0..6afaf6ada0 100644 --- a/modules/c++/sys/include/sys/SemaphorePosix.h +++ b/modules/c++/sys/include/sys/SemaphorePosix.h @@ -44,8 +44,8 @@ class SemaphorePosix : public SemaphoreInterface public: SemaphorePosix(unsigned int count = 0); virtual ~SemaphorePosix(); - void wait(); - void signal(); + void wait() override; + void signal() override; sem_t& getNative(); /*! diff --git a/modules/c++/sys/include/sys/StopWatch.h b/modules/c++/sys/include/sys/StopWatch.h index ac71fde2e0..0eab55a12a 100644 --- a/modules/c++/sys/include/sys/StopWatch.h +++ b/modules/c++/sys/include/sys/StopWatch.h @@ -66,13 +66,13 @@ class RealTimeStopWatch : public StopWatch ~RealTimeStopWatch(); - double start(); + double start() override; - double stop(); + double stop() override; - double pause(); + double pause() override; - void clear(); + void clear() override; }; class CPUStopWatch : public StopWatch @@ -88,13 +88,13 @@ class CPUStopWatch : public StopWatch ~CPUStopWatch(); - double start(); + double start() override; - double stop(); + double stop() override; - double pause(); + double pause() override; - void clear(); + void clear() override; }; } diff --git a/modules/c++/sys/include/sys/ThreadInterface.h b/modules/c++/sys/include/sys/ThreadInterface.h index 70c8d622f0..576f643471 100644 --- a/modules/c++/sys/include/sys/ThreadInterface.h +++ b/modules/c++/sys/include/sys/ThreadInterface.h @@ -212,7 +212,7 @@ struct CODA_OSS_API ThreadInterface : public Runnable * This function is called by start if no target is defined, * allowing the implementor to inherit this class directly */ - virtual void run() + virtual void run() override {} /*! diff --git a/modules/c++/sys/include/sys/ThreadPosix.h b/modules/c++/sys/include/sys/ThreadPosix.h index 596a246fcb..5e5efe8c29 100644 --- a/modules/c++/sys/include/sys/ThreadPosix.h +++ b/modules/c++/sys/include/sys/ThreadPosix.h @@ -96,7 +96,7 @@ struct ThreadPosix : public ThreadInterface /*! * The startpoint for thread processing */ - virtual void start(); + virtual void start() override; /*! @@ -110,12 +110,12 @@ struct ThreadPosix : public ThreadInterface /*! * Calls the native destroy stuff */ - virtual void kill(); + virtual void kill() override; /*! * Join the pthread */ - virtual void join(); + virtual void join() override; /*! * Calls sched_yield to yield the thread of control diff --git a/modules/c++/sys/include/sys/UTCDateTime.h b/modules/c++/sys/include/sys/UTCDateTime.h index 3f58fdaed7..7d4e712078 100644 --- a/modules/c++/sys/include/sys/UTCDateTime.h +++ b/modules/c++/sys/include/sys/UTCDateTime.h @@ -41,10 +41,10 @@ class CODA_OSS_API UTCDateTime : public DateTime /** * @brief Set the millis value from the members */ - virtual void toMillis(); + virtual void toMillis() override; //! Given seconds since the epoch, provides the UTC time - virtual void getTime(time_t numSecondsSinceEpoch, tm& t) const; + virtual void getTime(time_t numSecondsSinceEpoch, tm& t) const override; public: /*! diff --git a/modules/c++/sys/source/AbstractOS.cpp b/modules/c++/sys/source/AbstractOS.cpp index 2304f9261a..5494156802 100644 --- a/modules/c++/sys/source/AbstractOS.cpp +++ b/modules/c++/sys/source/AbstractOS.cpp @@ -415,6 +415,12 @@ std::string AbstractOS::getSpecialEnv(const std::string& envVar) const return str::toString(sys::DateTime::getEpochSeconds()); } + if (envVar == "OSTYPE") + { + // TODO: Mac + return sys::Platform == sys::PlatformType::Linux ? " linux-gnu" : "Windows"; + } + if (envVar == "OSTYPE") { // TODO: Mac diff --git a/modules/c++/sys/source/File.cpp b/modules/c++/sys/source/File.cpp new file mode 100644 index 0000000000..82fe2ab8ab --- /dev/null +++ b/modules/c++/sys/source/File.cpp @@ -0,0 +1,238 @@ +/* ========================================================================= + * This file is part of sys-c++ + * ========================================================================= + * + * (C) Copyright 2004 - 2014, MDA Information Systems LLC + * (C) Copyright 2023, Maxar Technologies, Inc. + * + * sys-c++ is free software; you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this program; If not, + * see . + * + */ + +#include "sys/File.h" + +#include + +#ifdef _WIN32 +#include +#endif + +#include "config/compiler_extensions.h" +#include "sys/Path.h" +#include "str/Manip.h" + +sys::File sys::make_File(const coda_oss::filesystem::path& path, int accessFlags, int creationFlags) +{ + sys::File retval(std::nothrow, path, accessFlags, creationFlags); + if (retval.isOpen()) + { + return retval; + } + + const auto checkIfExists = (creationFlags & sys::File::EXISTING) == sys::File::EXISTING; + auto expanded = sys::Path::expandEnvironmentVariables(path.string(), checkIfExists); + if (expanded.empty()) + { + expanded = path.string(); // Throw exception with non-empty path. + } + return sys::File(expanded, accessFlags, creationFlags); +} + +sys::File sys::make_File(const coda_oss::filesystem::path& parent, const coda_oss::filesystem::path& name, + int accessFlags, int creationFlags) +{ + sys::File retval(std::nothrow, parent, name, accessFlags, creationFlags); + if (retval.isOpen()) + { + return retval; + } + + const auto expanded_parent = sys::Path::expandEnvironmentVariables(parent.string(), coda_oss::filesystem::file_type::directory); + // 'name' probably won't work without 'parent' so no need to checkIfExists + const auto expanded_name = sys::Path::expandEnvironmentVariables(name.string(), false /*checkIfExists*/); + + // let the File constructor deal with combining the expanded paths as well as checking for existence. + return sys::File(expanded_parent, expanded_name, accessFlags, creationFlags); +} + +#ifdef _WIN32 +// '...': This function or variable may be unsafe. Consider using _sopen_s instead. +static FILE* fopen_(const std::string& fname, const std::string& mode) +{ + FILE* retval = nullptr; + const auto result = fopen_s(&retval, fname.c_str(), mode.c_str()); + if (result != 0) // "Zero if successful; ..." + { + return nullptr; + } + return retval; +} +#else +static inline FILE* fopen_(const std::string& fname, const std::string& mode) +{ + return fopen(fname.c_str(), mode.c_str()); +} +#endif + +FILE* sys::fopen(const coda_oss::filesystem::path& fname, const std::string& mode) +{ + // Call sys::expandEnvironmentVariables() if the initial fopen() fails. + auto retval = fopen_(fname.string(), mode); + if (retval != nullptr) + { + return retval; + } + + const auto r_pos = mode.find('r'); + const auto checkIfExists = r_pos != mode.npos; + const auto expanded = sys::Path::expandEnvironmentVariables(fname.string(), checkIfExists); + if (expanded.empty()) + { + return nullptr; // no need to even try fopen() + } + return fopen_(expanded, mode); +} + +#ifdef _WIN32 +#define CODA_OSS_open ::_open +#else +#define CODA_OSS_open ::open +#endif + +static inline int open_(const std::string& pathname, int flags) +{ + const auto p = pathname.c_str(); + CODA_OSS_disable_warning_push + #ifdef _MSC_VER + #pragma warning(disable: 4996) // '...': This function or variable may be unsafe. Consider using _sopen_s instead. + #endif + return CODA_OSS_open(p, flags); + CODA_OSS_disable_warning_pop +} +int sys::open(const coda_oss::filesystem::path& path, int flags) +{ + // Call sys::expandEnvironmentVariables() if the initial open() fails. + const auto retval = open_(path.string(), flags); + if (retval > -1) // "On error, -1 is returned ..." + { + return retval; + } + + constexpr bool checkIfExists = false; // TODO: look for O_CREAT ? + const auto expanded = sys::Path::expandEnvironmentVariables(path.string(), checkIfExists); + if (expanded.empty()) + { + return retval; // no need to even try another open() + } + return open_(expanded, flags); +} + +static inline int open_(const std::string& pathname, int flags, int mode) +{ + const auto p = pathname.c_str(); + CODA_OSS_disable_warning_push + #ifdef _MSC_VER + #pragma warning(disable: 4996) // '...': This function or variable may be unsafe. Consider using _sopen_s instead. + #endif + return CODA_OSS_open(p, flags, mode); + CODA_OSS_disable_warning_pop +} +int sys::open(const coda_oss::filesystem::path& path, int flags, int mode) +{ + // Call sys::expandEnvironmentVariables() if the initial open() fails. + const auto retval = open_(path.string(), flags, mode); + if (retval > -1) // "On error, -1 is returned ..." + { + return retval; + } + + constexpr bool checkIfExists = false; // TODO: look for O_CREAT ? + const auto expanded = sys::Path::expandEnvironmentVariables(path.string(), checkIfExists); + if (expanded.empty()) + { + return retval; // no need to even try another open() + } + return open_(expanded, flags, mode); +} +#undef CODA_OSS_open + +#ifdef _WIN32 +#define CODA_OSS_close ::_close +#else +#define CODA_OSS_close ::close +#endif +int sys::close(int fd) +{ + return CODA_OSS_close(fd); +} +#undef CODA_OSS_close + +#ifdef _WIN32 +#define CODA_OSS_stat_ ::_stat +#else +#define CODA_OSS_stat_ ::stat +#endif +static inline int stat_(const std::string& pathname, struct CODA_OSS_stat &buffer) +{ + const auto p = pathname.c_str(); + CODA_OSS_disable_warning_push + #ifdef _MSC_VER + #pragma warning(disable: 4996) // '...': This function or variable may be unsafe. Consider using _sopen_s instead. + #endif + return CODA_OSS_stat_(p, &buffer); + CODA_OSS_disable_warning_pop +} +#undef CODA_OSS_stat_ +int sys::stat(const coda_oss::filesystem::path& path, struct CODA_OSS_stat &buffer) +{ + // Call sys::expandEnvironmentVariables() if the initial stat() fails. + const auto retval = stat_(path.string(), buffer); + if (retval > -1) // "On error, -1 is returned ..." + { + return retval; + } + + constexpr bool checkIfExists = true; + const auto expanded = sys::Path::expandEnvironmentVariables(path.string(), checkIfExists); + if (expanded.empty()) + { + return retval; // no need to even try another stat() + } + return stat_(expanded, buffer); +} + +void sys::open(std::ifstream& ifs, const coda_oss::filesystem::path& path, std::ios_base::openmode mode) +{ + // Call sys::expandEnvironmentVariables() if the initial open() fails. + ifs.open(path.string(), mode); + if (ifs.is_open()) + { + return; + } + + const auto checkIfExists = (mode & std::ios_base::in) == std::ios_base::in; + auto expanded = sys::Path::expandEnvironmentVariables(path.string(), checkIfExists); + if (expanded.empty()) + { + expanded = path.string(); // Throw exception with non-empty path. + } + ifs.open(expanded, mode); +} +std::ifstream sys::make_ifstream(const coda_oss::filesystem::path& path, std::ios_base::openmode mode) +{ + std::ifstream retval; + open(retval, path, mode); + return retval; +} diff --git a/modules/c++/sys/source/FileUnix.cpp b/modules/c++/sys/source/FileUnix.cpp index 21e212f22b..f046f7db3d 100644 --- a/modules/c++/sys/source/FileUnix.cpp +++ b/modules/c++/sys/source/FileUnix.cpp @@ -28,19 +28,23 @@ #include #include -void sys::File::create(const std::string& str, int accessFlags, - int creationFlags) +_SYS_HANDLE_TYPE sys::File::createFile(const coda_oss::filesystem::path& str_, int accessFlags, int creationFlags) noexcept { + const auto str = str_.string(); + if (accessFlags & sys::File::WRITE_ONLY) creationFlags |= sys::File::TRUNCATE; - mHandle = open(str.c_str(), accessFlags | creationFlags, _SYS_DEFAULT_PERM); - + return open(str.c_str(), accessFlags | creationFlags, _SYS_DEFAULT_PERM); +} +void sys::File::create(const std::string& str, int accessFlags, + int creationFlags) +{ + create(std::nothrow, str, accessFlags, creationFlags); if (mHandle < 0) { - throw sys::SystemException(Ctxt(FmtX("Error opening file [%d]: [%s]", - mHandle, str.c_str()))); + throw sys::SystemException(Ctxt( + FmtX("Error opening file [%d]: [%s]", mHandle, str.c_str()))); } - mPath = str; } void sys::File::readInto(void* buffer, Size_T size) diff --git a/modules/c++/sys/source/FileWin32.cpp b/modules/c++/sys/source/FileWin32.cpp index 6db2751890..1b60a02010 100644 --- a/modules/c++/sys/source/FileWin32.cpp +++ b/modules/c++/sys/source/FileWin32.cpp @@ -26,10 +26,10 @@ #include #include "sys/File.h" -void sys::File::create(const std::string& str, - int accessFlags, - int creationFlags) +_SYS_HANDLE_TYPE sys::File::createFile(const coda_oss::filesystem::path& str_, int accessFlags, int creationFlags) noexcept { + const auto str = str_.string(); + // If the truncate bit is on AND the file does exist, // we need to set the mode to TRUNCATE_EXISTING if ((creationFlags & sys::File::TRUNCATE) && sys::OS().exists(str) ) @@ -43,18 +43,24 @@ void sys::File::create(const std::string& str, const auto dwDesiredAccess = static_cast(accessFlags); const auto dwCreationDisposition = static_cast(creationFlags); - mHandle = CreateFile(str.c_str(), + return CreateFile(str.c_str(), dwDesiredAccess, FILE_SHARE_READ, nullptr /*lpSecurityAttributes*/, dwCreationDisposition, FILE_ATTRIBUTE_NORMAL, static_cast(0) /*hTemplateFile*/); +} +void sys::File::create(const std::string& str, + int accessFlags, + int creationFlags) +{ + create(std::nothrow, str, accessFlags, creationFlags); if (mHandle == INVALID_HANDLE_VALUE) { - throw sys::SystemException(Ctxt(FmtX("Error opening file: [%s]", str.c_str()))); + throw sys::SystemException( + Ctxt(FmtX("Error opening file: [%s]", str.c_str()))); } - mPath = str; } void sys::File::readInto(void* buffer, size_t size) diff --git a/modules/c++/sys/tests/MutexTest.cpp b/modules/c++/sys/tests/MutexTest.cpp index a3dc1a0540..b30c51f791 100644 --- a/modules/c++/sys/tests/MutexTest.cpp +++ b/modules/c++/sys/tests/MutexTest.cpp @@ -42,7 +42,7 @@ std::string itos (int arg) { class DemoThread : public Thread { protected: - void run() { + void run() override { for (int i = 0 ; i < THREAD_LOOPS ; i++ ) { mutexCout.lock(); std::cout << getName() + " is running" << std::endl; diff --git a/modules/c++/sys/tests/ReadWriteMutexTest.cpp b/modules/c++/sys/tests/ReadWriteMutexTest.cpp index 1b8227fb68..262d3424cf 100644 --- a/modules/c++/sys/tests/ReadWriteMutexTest.cpp +++ b/modules/c++/sys/tests/ReadWriteMutexTest.cpp @@ -54,7 +54,7 @@ std::string BUFFER[1]; class ReadWriteThread : public Thread { protected: - void run() { + void run() override { for(int i=0; i < 5; ++i) { diff --git a/modules/c++/sys/tests/ReentrantTest.cpp b/modules/c++/sys/tests/ReentrantTest.cpp index f61823ed68..8955914862 100644 --- a/modules/c++/sys/tests/ReentrantTest.cpp +++ b/modules/c++/sys/tests/ReentrantTest.cpp @@ -29,7 +29,7 @@ class NoteThread : public Thread public: NoteThread() { std::cout << "Constructed a thread" << std::endl;} - void run() + void run() override { std::cout << "Running a thread" << std::endl;} ~NoteThread() diff --git a/modules/c++/sys/tests/ThreadFreeTest.cpp b/modules/c++/sys/tests/ThreadFreeTest.cpp index 9593239178..63e54d72a0 100644 --- a/modules/c++/sys/tests/ThreadFreeTest.cpp +++ b/modules/c++/sys/tests/ThreadFreeTest.cpp @@ -38,7 +38,7 @@ class MyRunTask : public Runnable { } - virtual void run() + virtual void run() override { result = 1; } diff --git a/modules/c++/sys/tests/ThreadTest4.cpp b/modules/c++/sys/tests/ThreadTest4.cpp index 94365acf95..f9b91cd1c1 100644 --- a/modules/c++/sys/tests/ThreadTest4.cpp +++ b/modules/c++/sys/tests/ThreadTest4.cpp @@ -35,7 +35,7 @@ class Getter : public sys::Runnable CODA_OSS_disable_warning_push CODA_OSS_DISABLE_UNREACHABLE_CODE - virtual void run() + virtual void run() override { for (int i = 0; i < 250; i++) { @@ -71,7 +71,7 @@ class Putter : public sys::Runnable CODA_OSS_disable_warning_push CODA_OSS_DISABLE_UNREACHABLE_CODE - virtual void run() + virtual void run() override { std::cout << "Putter::run: " << std::endl; diff --git a/modules/c++/sys/tests/ThreadTest5.cpp b/modules/c++/sys/tests/ThreadTest5.cpp index 560416b9e3..664109b0db 100644 --- a/modules/c++/sys/tests/ThreadTest5.cpp +++ b/modules/c++/sys/tests/ThreadTest5.cpp @@ -39,7 +39,7 @@ class TestThread : public Thread delete mVal; } - void run() + void run() override { cout << "mVal: " << *mVal << endl; } diff --git a/modules/c++/sys/unittests/test_atomic_counter.cpp b/modules/c++/sys/unittests/test_atomic_counter.cpp index fa56995992..8420b580fb 100644 --- a/modules/c++/sys/unittests/test_atomic_counter.cpp +++ b/modules/c++/sys/unittests/test_atomic_counter.cpp @@ -123,7 +123,7 @@ struct IncrementAtomicCounterT final : public sys::Runnable { } - virtual void run() + virtual void run() override { for (size_t ii = 0; ii < mNumIncrements; ++ii) { @@ -210,7 +210,7 @@ struct DecrementAtomicCounterT final : public sys::Runnable { } - virtual void run() + virtual void run() override { for (size_t ii = 0; ii < mNumDecrements; ++ii) { diff --git a/modules/c++/sys/unittests/test_os.cpp b/modules/c++/sys/unittests/test_os.cpp index d4265494bc..af07859a3f 100644 --- a/modules/c++/sys/unittests/test_os.cpp +++ b/modules/c++/sys/unittests/test_os.cpp @@ -32,6 +32,7 @@ #include #include #include +#include #include "TestCase.h" void createFile(const std::string& pathname) @@ -400,6 +401,116 @@ TEST_CASE(testFsFileSize) } } +static sys::File makeFile_() +{ +#ifdef _WIN32 + static const std::filesystem::path name("explorer.exe"); + return sys::make_File("%SystemRoot%" / name); + +#else + static const std::filesystem::path dot_cshrc(".cshrc"); + try + { + return sys::make_File("$HOME" / dot_cshrc); + } + catch (const sys::SystemException&) { } // no .cshrc; try .bashrc + + static const std::filesystem::path dot_bashrc(".bashrc"); + return sys::make_File("$HOME" / dot_bashrc); +#endif +} +TEST_CASE(test_makeFile) +{ + auto file = makeFile_(); + TEST_ASSERT_TRUE(file.isOpen()); +} + +static FILE* sys_fopen() +{ + static const std::string mode("r"); + +#ifdef _WIN32 + static const std::filesystem::path name("explorer.exe"); + return sys::fopen("%SystemRoot%" / name, mode); + +#else + static const std::filesystem::path dot_cshrc(".cshrc"); + auto retval = sys::fopen("$HOME" / dot_cshrc, mode); + if (retval != nullptr) + { + return retval; + } + // no .cshrc; try .bashrc + static const std::filesystem::path dot_bashrc(".bashrc"); + return sys::fopen("$HOME" / dot_bashrc, mode); +#endif +} +TEST_CASE(test_sys_fopen) +{ + auto fp = sys_fopen(); + TEST_ASSERT_NOT_NULL(fp); + fclose(fp); +} + +TEST_CASE(test_sys_fopen_failure) +{ + static const std::string mode("r"); + static const std::filesystem::path name("does not exist . txt"); + const auto fp = sys::fopen("$ENV_VAR_NOT_SET" / name, mode); + TEST_ASSERT_NULL(fp); +} + +static int sys_open() +{ + constexpr int flags = 0; + +#ifdef _WIN32 + static const std::filesystem::path name("explorer.exe"); + return sys::open("%SystemRoot%" / name, flags); + +#else + static const std::filesystem::path dot_cshrc(".cshrc"); + auto retval = sys::open("$HOME" / dot_cshrc, flags); + if (retval > -1) + { + return retval; + } + // no .cshrc; try .bashrc + static const std::filesystem::path dot_bashrc(".bashrc"); + return sys::open("$HOME" / dot_bashrc, flags); +#endif +} +TEST_CASE(test_sys_open) +{ + auto fd = sys_open(); + TEST_ASSERT(fd > -1); + sys::close(fd); +} + +static std::ifstream make_ifstream_() +{ +#ifdef _WIN32 + static const std::filesystem::path name("explorer.exe"); + return sys::make_ifstream("%SystemRoot%" / name); + +#else + static const std::filesystem::path dot_cshrc(".cshrc"); + auto retval = sys::make_ifstream("$HOME" / dot_cshrc); + if (retval) + { + return retval; + } + // no .cshrc; try .bashrc + static const std::filesystem::path dot_bashrc(".bashrc"); + return sys::make_ifstream("$HOME" / dot_bashrc); +#endif +} +TEST_CASE(test_make_ifstream) +{ + const auto ifs = make_ifstream_(); + TEST_ASSERT_TRUE(ifs.is_open()); +} + TEST_MAIN( //sys::AbstractOS::setArgvPathname(argv[0]); TEST_CHECK(testRecursiveRemove); @@ -411,4 +522,9 @@ TEST_MAIN( TEST_CHECK(testBacktrace); TEST_CHECK(testSpecialEnvVars); TEST_CHECK(testFsFileSize); -) + TEST_CHECK(test_makeFile); + TEST_CHECK(test_sys_fopen); + TEST_CHECK(test_sys_fopen_failure); + TEST_CHECK(test_sys_open); + TEST_CHECK(test_make_ifstream); + ) diff --git a/modules/c++/xml.lite/CMakeLists.txt b/modules/c++/xml.lite/CMakeLists.txt index 16e64e7184..ee70ab4070 100644 --- a/modules/c++/xml.lite/CMakeLists.txt +++ b/modules/c++/xml.lite/CMakeLists.txt @@ -1,6 +1,10 @@ set(MODULE_NAME xml.lite) if(ENABLE_XML) + if (UNIX) + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wno-zero-as-null-pointer-constant") + endif() + if(CONAN_PACKAGE_NAME) # import targets from xerces-c conan package find_package(coda-oss_xerces-c REQUIRED) diff --git a/modules/c++/xml.lite/include/xml/lite/UtilitiesXerces.h b/modules/c++/xml.lite/include/xml/lite/UtilitiesXerces.h index e9df3b4d6d..c9d78cfa15 100644 --- a/modules/c++/xml.lite/include/xml/lite/UtilitiesXerces.h +++ b/modules/c++/xml.lite/include/xml/lite/UtilitiesXerces.h @@ -29,10 +29,12 @@ #include #include +#include "config/compiler_extensions.h" #include "xml/lite/xml_lite_config.h" #if defined(USE_XERCES) +CODA_OSS_disable_warning_system_header_push #include #include #include @@ -52,11 +54,11 @@ #include #include -#include - #include #include +CODA_OSS_disable_warning_pop + #include #include #include diff --git a/modules/c++/xml.lite/include/xml/lite/XMLReader.h b/modules/c++/xml.lite/include/xml/lite/XMLReader.h index 8ec74f92d6..94334180df 100644 --- a/modules/c++/xml.lite/include/xml/lite/XMLReader.h +++ b/modules/c++/xml.lite/include/xml/lite/XMLReader.h @@ -38,6 +38,7 @@ #endif # include "xml/lite/XMLReaderXerces.h" + namespace xml { namespace lite diff --git a/modules/c++/zip/source/ZipEntry.cpp b/modules/c++/zip/source/ZipEntry.cpp index 2d9595f9ee..9f71cbef32 100644 --- a/modules/c++/zip/source/ZipEntry.cpp +++ b/modules/c++/zip/source/ZipEntry.cpp @@ -21,6 +21,8 @@ */ #include "zip/ZipEntry.h" +#undef Z_NULL +#define Z_NULL nullptr const static char* sZipFileMadeByStr[] = { "MS-DOS and OS/2 (FAT / VFAT / FAT32 file systems)", "Amiga", diff --git a/modules/drivers/CMakeLists.txt b/modules/drivers/CMakeLists.txt index cfe5ef7b07..2d580634e3 100644 --- a/modules/drivers/CMakeLists.txt +++ b/modules/drivers/CMakeLists.txt @@ -1,8 +1,14 @@ +# Turn off all warnings; this is code we don't control. if (MSVC) add_definitions(-D_CRT_SECURE_NO_WARNINGS -D_SCL_SECURE_NO_WARNINGS) - add_compile_options(/W3) - add_compile_options(/wd4267) # '...': conversion from '...' to '...', possible loss of data - add_compile_options(/wd4244) # '...': conversion from '...' to '...', possible loss of data + + # By default, there is a /W3 on the command-line from somewhere (?); adding + # /Wn results in a compiler warning. + #add_compile_options(/W0) + string(REGEX REPLACE "/W[0-4]" "/W0" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}") + string(REGEX REPLACE "/W[0-4]" "/W0" CMAKE_C_FLAGS "${CMAKE_C_FLAGS}") +elseif (UNIX) + add_compile_options(-w) # "Inhibit all warning messages" endif() #add_subdirectory("curl") # this is handled in coda_find_system_dependencies diff --git a/modules/drivers/hdf5/CMakeLists.txt b/modules/drivers/hdf5/CMakeLists.txt index 65db23cb38..dd8c01d3f8 100644 --- a/modules/drivers/hdf5/CMakeLists.txt +++ b/modules/drivers/hdf5/CMakeLists.txt @@ -1,4 +1,5 @@ set(MODULE_NAME hdf5) +set(TARGET_LANGUAGE c++) if(CODA_ENABLE_HDF5) # set up warnings diff --git a/modules/drivers/zlib/CMakeLists.txt b/modules/drivers/zlib/CMakeLists.txt index 7842daa03b..77ec31fa98 100644 --- a/modules/drivers/zlib/CMakeLists.txt +++ b/modules/drivers/zlib/CMakeLists.txt @@ -80,10 +80,6 @@ elseif(ENABLE_ZIP) ARCHIVE "zlib-1.2.13.tar" HASH "SHA256=A47CDCD8863424356B893B259CB57081EFDCC7FA3C2EB56CA1E881324958A2A9") - if (MSVC) - add_compile_options(/wd4996) # '...': The POSIX name for this item is deprecated. Instead, use the ISO C and C++ conformant name: .... See online help for details. - endif() - set(SOURCE_DIR "${${CMAKE_PROJECT_NAME}_${TARGET_NAME}_SOURCE_DIR}") # remove crypt.h due to name clash with glibc file(REMOVE "${SOURCE_DIR}/contrib/minizip/crypt.h") diff --git a/modules/python/CMakeLists.txt b/modules/python/CMakeLists.txt index cf7e1ad700..20c1e0873a 100644 --- a/modules/python/CMakeLists.txt +++ b/modules/python/CMakeLists.txt @@ -1,3 +1,15 @@ +set(TARGET_LANGUAGE c++) + +# Turn off all warnings; this is code we don't control. +if (MSVC) + # By default, there is a /W3 on the command-line from somewhere (?); adding + # /Wn results in a compiler warning. + #add_compile_options(/W0) + string(REGEX REPLACE "/W[0-4]" "/W0" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}") +elseif (UNIX) + add_compile_options(-w) # "Inhibit all warning messages" +endif() + add_subdirectory("config") add_subdirectory("except") add_subdirectory("sys")