Skip to content

Commit

Permalink
Squashed 'externals/coda-oss/' changes from e87c32b4de..f4d42005fa
Browse files Browse the repository at this point in the history
f4d42005fa fix build error in NITRO
ff11a5557e keep using std::complex<short> for now (#682)
c88b9c0532 types::complex<T> (#681)
d1244a0804 don't need our own make_unique in C++14 (#680)
aeec0131c5 assert()s for mem::CopyablePtr (#679)
72b0ebd603 add types::complex_short (#678)
932130a580 patch to build other projects
c00c1f203d coda-oss release 2023-06-06 (#677)
ef54bbcd53 remove more compiler warnings (#676)
dadfc5ce62 distinguish between byte-swapping a buffer and single value (#674)
90187f6cd8 more xml.lite tweaks for SIDD-3.0/ISM (#675)
eb99607720 stronger type-checking for byteSwap() (#673)
ff4f820ed8 xml.lite tweaks to support SIDD 3.0 ISM (#672)
b1de8c0e5e std::byte should be a unique type (#671)
c05bf9a028 allow enums to be byte-swapped too
1f9fd88d6d remove spurious
47684c45b8 byteSwap now uses byte buffers (#670)
cbc659db27 add swapBytes() utility from SIX (#669)
891481b64f simplify byte-swapping (#668)
540ae763e5 more byteSwap() tweaks
0774c03c46 threaded byteSwap() (#667)
d156370d36 swapping a single-byte value makes no sense
c120e3255d be sure parameter is used to avoid compiler warning
e85ec93317 --output-on-failure for CTest (#666)
e80376197b turn off "there is no warning number" warning
c5f0a5d154 A C-string may not be NULL-terminated (#665)
0c5eb29ae7 use platform-specific routines for byteSwap() (#664)
0b7d581fa6 remove transform_async() (#663)
f6489b6bef Merge branch 'main' into feature/xml.lite_tweaks
836c426a2b use function-pointers so that isConsoleOutput is only checked once
56e3c45b1b move depthPrint() functionality into non-member function in preparation for future changes
ddcd26d972 Merge branch 'main' into feature/xml.lite_tweaks
69cc0e5063 use the more rigorous create_and_check_datatype()
9efb875584 Merge branch 'main' into feature/hdf5
4d2f2f4173 more HighFive unittests (#662)
14191a844a HighFive::create_datatype() goes from C++ to HighFive
98583473fb utility routines to read string attributes
1fa75ce81e use the C API to read a string attribute
71e7b69f54 still can't figure out how to read a string attribute :-(
e96f37a69b test reading the file attributes
a25244519c getAttribute() unittest
8f12a3000b getDataType() unittest
857ff0af32 HighFive utility routines (#661)
1d687db57b writeDataSet() utility overload
106aa68945 sigh ... H5Easy::dump() fill fails on Windows/WAF :-(
2641b60b2b Merge branch 'main' into feature/hdf5
35c19e7e81 change actions to @V3 (#660)
212bbd3a36 works on local machine, but not build server ... ?
7125118b09 dump of 1D vector doesn't work :-(
c704db4352 sigh ... WAF build still failing :-(
01aae46163 does dump() of a 1D vector work?
76a53c8134 comment-out H5 writing :-(
0f0e19affe test_highfive_dump()
cb8f737957 trying to get highfive_dump() unittest working w/Windows-WAF
6584a264af does test_highfive_create() work?
cde6147ced tweak HighFive wrappers (#659)
3165668545 Revert "trying HighFive "write" unittests again"
a9ec24ca4d trying HighFive "write" unittests again
585ad49a56 tweak names of utility routines
4c91a4d97a make it easier to read a std::vector and std::vecotr<std::vector>
0217ffa26c readDataSet() now works for 1D data
95e8973f29 trying to get hdf5::lite::load() working
4d294611d4 "const" correctness
5e6305c3f7 fix load_complex()
4a134dc5f1 start work on utility routines to read complex data from HDF5
9d76a7f41e Merge branch 'main' into feature/hdf5
8f9667a240 whitepsace
ebd3fc99ea Merge branch 'main' into feature/hdf5
40091b069c comment-out writing tests for now ... need to figure our WAF bulid failure
935aa34592 be sure the dataset has real data
114b9bf33c update release notes
bd9c0b26c5 tweak HighFive utility routines
acda1ef577 turn off diagnostics around expected failures
22a7488402 readDataSet() utility routine for HighFive
bd88a8c256 HighFive writeDataSet() utility to work with our SpanRC
6142f5b339 use HighFive routines to write a HDF5 file
5bbf1abaff Use HiveFive routines to get info about the file
84fbc83789 duplicate unittests with H5Easy
f1f054c03a Merge branch 'main' into feature/hdf5
9b63ca470c fix directory names
f6f826689a fix directory names
7aeb82c336 Merge branch 'main' into feature/hdf5
d028baaebd hook up HighFive header-only library (#653)
3083b0a313 Revert "HighFive 2.6.2"
246985a7f0 Revert ""build" HighFive HDF5 library"
a8b75a5865 Revert "turn off HighFive Boost support"
ec68d5f830 Revert "Add HighFive unittests"
f1f85b9e7f Revert "get test_high_five_base more-or-less compiling"
5ea634ee15 Revert "more work on getting HighFive unittests to build"
ecc45433c7 more work on getting HighFive unittests to build
bb194788ab get test_high_five_base more-or-less compiling
d42bde0004 Add HighFive unittests
ddc86bb328 turn off HighFive Boost support
b255122d4f "build" HighFive HDF5 library
396cc3ef2a HighFive 2.6.2
5e5f9d9c0f Merge branch 'main' into feature/hdf5
ee938b4a52 changes from SIX
bb764df90b Merge branch 'main' into feature/xml.lite_tweaks
de2a243800 make derived classes 'final' if possible
14e19bcd21 Change xml lite function to virtual (#645)
8f42ac8e9e Merge branch 'main' into feature/xml.lite_tweaks
18ad90645f hdf5Write unittest
3462e11792 createFile() and writeFile() overloads
ecee81d532 fix typos
197eecfa62 sketch-out hdf5::lite::writeFile()
bd2311795e use SpanRC for writeFile(), not yet implemented
ea9af75109 simple SpanRC to hold a 2D-size and pointer
027c19ee8a createFile() unittest
1f9d07ecbc hook up createFile()
8c7e4473f0 start hooking up HDF5 writing
146e0bea3b Merge branch 'main' into feature/hdf5
88ca9fcb7f Merge branch 'main' into feature/hdf5
42b604b463 Squashed commit of the following:
10ee602c25 Merge branch 'main' into feature/hdf5
67aa42b69d restore changes from "main"
8bbfcbfbfe unittests can be simplified to match fewer "view" classes
126bb802ea Merge branch 'main' into feature/hdf5
3f8ba7a423 again, don't need a class just to convert from std::vector<> to std::span<>
24c2b489c8 Squashed commit of the following:
2703c119d4 Squashed commit of the following:
9d5228a2be don't need an entire class just to convert a std::vector<> into std::span<>
51bc931dcd Merge branch 'main' into feature/hdf5
a84f258160 Squashed commit of the following:
c4d2ed696e add missing #include guards, fix type in existing #include guard
d541525a01 use a single ComplexViewConstIterator for all views
86e6a459fe CODA_OSS_disable_warning causes GCC errors :-(
5d4b9c2cb6 only need an custom iterator for ComplexSpansView
d9f0fb1286 hook up iterators
b9329e4db0 initial pass at a ComplexViewConstIterator
6352388739 remove compiler warning about unused "constexpr" variables
b39f6096fb use the casing from H5 to make copy/pasting code slightly easier
0887b13eb4 Merge branch 'main' into feature/hdf5
bd07df1cae Consistent casing for Dataset, Datatype, Dataspace
7acd30ee23 tweak hdf5.lite dependencies
38ab914dfd Jupyter notebook for creating H5 files
95a040e0bf _small.h5 is now (correctly) FLOAT32
107e7c4876 make a simple values() member function to avoid template magic
e1feca9194 use TEST_SPECIFIC_EXCEPTION macro instead of try/catch
7383336888 readDatasetT() now throws for the wrong buffer type
6b2cc25294 Merge branch 'feature/hdf5' of github.com:mdaus/coda-oss into feature/hdf5
310f8fd3d5 can't get template magic right for copy_axis()
86b306d596 stepping through copy ctors in the debugger is annoying
f243e92d68 trying to make wrong type of buffer fail
2b10d96529 read in new sample file
a28e59d8c5 help the compiler with type deduction
49bf5e9bc2 nested_complex_float_data_small.h5
e029325fc0 utility routines to "deconstruct" and array of std::complex
dede3bd393 Merge branch 'main' into feature/hdf5
904b1ef5ec tweak class names, make_() and copy() utility routines
8237b9efbf make it harder to pass the wrong types to ComplexViews
4d9aeda2cd ComplexArrayView and ComplexParallelView utility classes
f5e367dfa6 test std::span<const std::complex<float>>
a4a2844f26 read in the nested "i" and "r" data
1156152650 sample file has subgroups
8e1b7869aa Merge branch 'feature/hdf5' of github.com:mdaus/coda-oss into feature/hdf5
9f4232a1dd update sample H5 file
8c55db73ae walk through HDF5 sub-groups
7775ed9c43 Update 123_barfoo_catdog_cx.h5
677975d7ca Matlab code to create sample H5 file
a0e7dfe07b Update test_hdf5info.cpp
0b67e1602f pass __FILE__ and __LINE__ from calling site for a more accurate exception message
86a6773213 skeleton for more sample data
85f79b0999 Merge branch 'main' into feature/hdf5
18088e9421 Merge branch 'main' into feature/hdf5
3a1d17692f Merge branch 'main' into feature/hdf5
1755c69d70 Merge branch 'main' into feature/hdf5
9ad015432d No more "11" suffix on exception names
c20d962511 Squashed commit of the following:
c88cee999b other values to be filled-in
bca4a4ecd8 incorporation NamedObject from HDF5 docs
61fa68f72e groupInfo()
460e7d7665 datasetInfo()
14eb9b764b start filling in DatasetInfo
afe5f1c3a0 start to fill in DatasetInfo
77a968c72d start filling in GroupInfo
d81bcdfd92 openGroup() to open groups (loc)
a0cd294697 comment-out "dataset" unittest for now
86e0060245 begin filling in FileInfo
366dda6ab6 a return_type_of utility is needed to deduce the return type
e219282638 explicitly pass return type to template
4937ccd11d template to reduce boilerplate when calling try_catch_H5Exceptions
b3b5ebde78 use new exception utility routines
ea1c03ef0c put exception handling/conversion in a utility routine
819a99d397 utility routine for exception handling
6f34eea979 put utilities in a separate file for easier reuse
fcbde4f241 break utility routines into smaller pieces for easier reuse
52358ea8a9 WIN32 no longer automatically defined?
5a42864722 Revert "build HDF5 with C89"
680e599e9d build HDF5 with C89
a87a071218 Merge branch 'main' into feature/hdf5
8447c1a900 Revert "sym-links instead of copying files"
db3b5e12b4 Merge branch 'main' into feature/xml.lite_tweaks
fb60b5696f Merge branch 'main' into feature/hdf5
5110a5cc81 Comments about _u and _q
1a937d32cf Merge branch 'main' into feature/xml.lite_tweaks
fa06f04d7e get ready for hdf5.lite enhancdements
b040c7c437 sym-links instead of copying files
aa431bb477 use _u for xml::lite::Uri
3d0c6d58ce fix case-sensitive #include filename
93dcd0e527 operator() for getElementByName()
75a93af859 more operator[] overloads to make attribute management easier
4ab8216f87 user-defined string literals to remove some noise around xml::lite::QName
f82f0b0fc6 Merge branch 'main' into feature/xml.lite_tweaks
ae30e36443 Merge branch 'feature/xml.lite_tweaks' of github.com:mdaus/coda-oss into feature/xml.lite_tweaks
ffdd9beb0b simplify attribute creation
9bf5414f5d simplify attribute creation
82d7a4e959 SWIG gets confused about namespaces
7a61d0741f fix bug on Element ctor uncovered by unittest
fdd7e58c1a QName is also in the xerces namespace which confuses SWIG bindings
a325b7053b operator+=() overload for addChild
daf30e6c0e Merge branch 'feature/xml.lite_tweaks' of github.com:mdaus/coda-oss into feature/xml.lite_tweaks
b887d2b476 provide overloads for Element& rather than creating new "reference" types
1fa6bba388 rename test_xmleasy.cpp
7c8c9e0f1c += overload
850da6f63d overload for std::string
4547fc5a75 use UIT-8 strings for characterData
4723462a3b convenient addChild() overloads
e48720753a copy over ElementReference from xml.easy
a4ca30a0d6 Merge branch 'main' into feature/xml.lite_tweaks
6ae9f0b715 Revert "check-in of new xml.easy (to move code between computers)"
f7466a6d75 Revert "simple routines for single element"
a5490230d6 Revert "make some operators simplier ways of calling functions"
c9a25630a6 Revert "get document creation working"
8af8710b05 Revert "free functions instead of member functions"
16c3847cb2 Revert "ElementReference distinct from Element"
7d68e156ff Revert "ElementMutableReference"
00eb2a2826 Merge branch 'main' into feature/xml.lite_tweaks
a42969c1f4 ElementMutableReference
a20ae9355e ElementReference distinct from Element
14eeeea0b5 free functions instead of member functions
4aae014b39 get document creation working
8835692699 make some operators simplier ways of calling functions
053bd1212a simple routines for single element
8bf701a2ea check-in of new xml.easy (to move code between computers)
41f959051c unittests for creating XML documents from scratch
9752d50ae2 Merge branch 'main' into feature/xml.lite_tweaks
1531d57095 by default, don't validate strings passed to Uri()
46d13d4bf7 Merge branch 'master' into feature/xml.lite_tweaks
39b547d321 remove more vestiges of Expat and LibXML
ec8274d524 remove LibXML and Expat as they're no longer used/supported.
20eeefeef6 Merge branch 'master' into feature/xml.lite_tweaks
95074b9b1a update for newer Intel compiler
7024f71e1b Merge branch 'master' into feature/xml.lite_tweaks
57b1cbc83d Merge branch 'master' into feature/xml.lite_tweaks
4b67561c3d remove validate() overload that nobody is using
fa15f1e5dc Squashed commit of the following:
1484a90909 test the new validate() API
470da70fb8 hookup StringStreamT routines
2cddf25047 begin hooking up validate() overloads
1b5d910f38 overload validate() for UTF-8 and Windows-1252
03309b8c9f Squashed commit of the following:
b72c6c5bf2 older compiler doesn't like our make_unique
af8f00307f validate UTF-8 XML on Linux
211188613e unit-test for LEGACY XML validation
3c1169d2b5 Squashed commit of the following:
3afff19cad std::filesystem::path for FileInputStreamOS
908d452f8f WIP: validate all of our sample XML files
00f9bb16bc validate against a XML schema
243d8c356c Merge branch 'master' into feature/xml.lite_tweaks
2815d707d9 fix to work with SWIG bindings. :-(
4608621326 trying (again) to remove vestiages of old code
e3c83a8587 Revert "new code should use UTF-8"
811207c920 new code should use UTF-8
0ffd835f96 Squashed commit of the following:
1e7e03ded0 Merge branch 'master' into feature/xml.lite_tweaks
c1d806affa Merge branch 'master' into feature/xml.lite_tweaks
850d3c811d str::strip() that can be easier to use than str::trim()
580ba9c8c3 explicitly =delete move
2b39831a80 Squashed commit of the following:
39eebdc23f Merge branch 'master' into feature/xml.lite_tweaks
9adf86cbaf force calling new UTF-8 write() routines
ea61b62045 Merge branch 'master' into feature/xml.lite_tweaks
8a34583fa0 overload to take schemaPaths as filesystem::path
8671b442f7 parse XML embedded in a binary file
ec4a902f14 updates from xerces.lite
80dc4d9635 updates from xerces.lite
549766d6c1 Attributes::contains() no longer catches an exception
8a645ceac3 need "sys/" when building in other environments
36af082690 super-simple URI validation
78ef28a3e2 SWIG bindings are a PITA! :-(
e9cba8491e SWIG needs help with Uri
8a8d8dc072 another routines used by pre-build SWIG bindings
818e1ec5d3 pre-build SWIG bindings use getElementByTagName() member function
067cac5d85 old compiler gets confused on unadorned QName
ba92c0ae7e more use of Uri and QName
446c7d17a7 use QName in new code
d6f8b0c836 more direct use of QName
90fff1c737 use xml::lite::QName instead of tuple<string, string>
646cbb5ed4 more direct use of QName and Uri
ba589ea3b3 make QName more robust
bab0ee8b5e createElement() -> addNewElement()
e3a145747a grab changes from six-library
32285e95c4 Merge branch 'master' into feature/xml.lite_tweaks
9f79f0bf62 Merge branch 'master' into feature/xml.lite_tweaks
a12bbc32c6 make it easier to create new Elements with a value
fc9967f986 make it easy for callers to addChild() keep a reference to the Element
4627766b7d be sure test_xmlparser works in "externals" of other projects
bf22763961 "private" is part of the name-mangling
fad92bcc8f making sure copy-ctor is implemented
f90fdcead0 consolidate common XML test code
9fc53f2d51 use str:: utility for casting
6da6f794bb still trying to find the right macro for SWIG
0c1b86c566 still trying to fix SWIG
fdc6fc9bd6 trying to fix SWIG build error
7835e8c270 SWIG needs copy-ctor
585695942d disable copy/assignment for Element, it's probably almost always wrong
391fed6135 fix double-delete caused by copying
61790fe695 retry parsing XML with Windows-1252 if first parse() fails
63cffac59e change string_encoding to match coda-oss style of PascalCase
010479bbec read an XML file we know is wrongly encoded as Windows-1252
9a05050621 more references instead of pointers
2d44b69519 Reading Windows-1252 w/o "encoding" fails
63dc7b0762 read Windows-1252 too
c9434c9cbe test as UIT-8 too
f310ccf0cf get reading from UTF-8 XML working on Windows
1fa39c2be0 get testReadUtf8XmlFile working on Linux
1a83cd8157 sys::Path is too much trouble right now
ed60aa22c9 unit-test to read XML from a file
a9336db7c6 Squashed commit of the following:
0825beb0d3 Merge branch 'master' into feature/xml.lite_tweaks
c618489be7 Merge branch 'master' into feature/xml.lite_tweaks
e8e4b8fe1d determine string_encoding based on platform
1f43bcfc26 create a new Element by using the platform to determine "characterData" encoding
961bef66b4 Merge branch 'master' into feature/xml.lite_tweaks
e9798a5 fix static_assert()
6f77728 Merge branch 'master' into feature/xml.lite_tweaks
b98d4f5 Merge branch 'master' into feature/xml.lite_tweaks
1b5abba The (old) version of SWIG we're using doesn't like certain C++11 features.
53bdeab Merge branch 'master' into feature/xml.lite_tweaks
60cf8ae "" doesn't work with decltype() in older C++
97e7247 reduce getValue() overloads by making "key" a template argument
5e6373e reduce code duplication
f9e7cfe provide castValue<T> instead of getValue(T&)
cbd0bd8 castValue<T> throws instead of returning a bool like getValue(T&)
87c7514 Merge branch 'master' into feature/xml.lite_tweaks
10cc612 make getElement*() consistent for zero or >1 results
f5b137e Merge branch 'master' into feature/xml.lite_tweaks
1765efc allow clients to specify toType() and toString() for getValue() and setValue()
df8b746 allow clients to specify their own toType/toString routines
6670272 Merge branch 'master' into feature/xml.lite_tweaks
6956311 Merge branch 'master' into feature/xml.lite_tweaks
d505f35 Merge branch 'master' into feature/xml.lite_tweaks
fbd1061 catch a BadCastException and return false from getValue()
3a78377 use a template to reduce duplicated code
0ad4b86 Merge branch 'master' into feature/xml.lite_tweaks
a848aa3 get & set the characer data as a type
f3ee1ee utility routines to set an attribute value
5952276 templates to get an attribute value convert to a specific type
0663922 miised a change in last commit
1aa458e add getValue() overloads that return true/false rather than throwing
faa6d30 added getElementByTagName() overloads as that's a very common use-case

git-subtree-dir: externals/coda-oss
git-subtree-split: f4d42005fa477ae59da193422aa2cb14b877cf0c
  • Loading branch information
Dan Smith authored and Dan Smith committed Jun 13, 2023
1 parent 55a407b commit ae3968a
Show file tree
Hide file tree
Showing 83 changed files with 2,441 additions and 485 deletions.
18 changes: 9 additions & 9 deletions .github/workflows/build_unittest.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,9 @@ jobs:
name: ${{ matrix.os }}-${{ matrix.python-version }}-CMake
runs-on: ${{ matrix.os }}
steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v3
- name: Set up Python
uses: actions/setup-python@v2
uses: actions/setup-python@v3
with:
python-version: ${{ matrix.python-version }}
- name: Install python dependencies
Expand Down Expand Up @@ -46,10 +46,10 @@ jobs:
- name: test
run: |
cd target-Release
ctest -C Release
ctest -C Release --output-on-failure
cd ..
cd target-Debug
ctest -C Debug
ctest -C Debug --output-on-failure
build-linux-cmake:
strategy:
Expand All @@ -59,9 +59,9 @@ jobs:
name: ${{ matrix.os }}-${{ matrix.python-version }}-CMake
runs-on: ${{ matrix.os }}
steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v3
- name: Set up Python
uses: actions/setup-python@v2
uses: actions/setup-python@v3
with:
python-version: ${{ matrix.python-version }}
- name: Install python dependencies
Expand All @@ -86,7 +86,7 @@ jobs:
- name: test
run: |
cd target
ctest
ctest --output-on-failure
build-waf:
strategy:
Expand All @@ -97,9 +97,9 @@ jobs:
name: ${{ matrix.os }}-${{ matrix.python-version }}-waf
runs-on: ${{ matrix.os }}
steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v3
- name: Set up Python
uses: actions/setup-python@v2
uses: actions/setup-python@v3
with:
python-version: ${{ matrix.python-version }}
- name: configure_with_swig
Expand Down
8 changes: 7 additions & 1 deletion ReleaseNotes.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,12 +11,18 @@
```
# coda-oss Release Notes

## [Release 2023-??-??](https://github.com/mdaus/coda-oss/releases/tag/2023-??-??)
## [Release 2023-06-05](https://github.com/mdaus/coda-oss/releases/tag/2023-06-05)
* *zlib* updated to [1.2.13](https://github.com/madler/zlib/releases/tag/v1.2.13).
* new `mem::ComplexView` class to make it easier to process complex data stored in parallel.
* adjust compiler flags for clean *CMake* builds.
* wrap common "file open" routines (e.g., `fopen()`) to support `sys::expandEnvironmentVariables()`.
* add header-only [HighFive](https://github.com/BlueBrain/HighFive) HDF5-wrapper library.
* Added a handful of [HighFive](https://github.com/BlueBrain/HighFive) utility routines.
* `mt::transform_async()` removed, it doesn't match C++17 techniques.'
* Revamp `sys::byteSwap()` for improved type-safety and
[better performance](https://devblogs.microsoft.com/cppblog/a-tour-of-4-msvc-backend-improvements/).
* Added case-insensitive string comparison utilties: `str::eq()` and `str::ne()`;
`xml::lite::Uri`s compare case-insensitive.

## [Release 2022-12-14](https://github.com/mdaus/coda-oss/releases/tag/2022-12-14)
* removed remaining vestiges of `std::auto_ptr`, provide `mem::AutoPtr` for the tiny handful of
Expand Down
10 changes: 8 additions & 2 deletions UnitTest/UnitTest.vcxproj
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,6 @@
<PlatformToolset>v143</PlatformToolset>
<UseOfMfc>false</UseOfMfc>
<CharacterSet>Unicode</CharacterSet>
<EnableASAN>true</EnableASAN>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">
<ConfigurationType>DynamicLibrary</ConfigurationType>
Expand All @@ -34,7 +33,6 @@
<WholeProgramOptimization>true</WholeProgramOptimization>
<UseOfMfc>false</UseOfMfc>
<CharacterSet>Unicode</CharacterSet>
<EnableASAN>true</EnableASAN>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
<ImportGroup Label="ExtensionSettings">
Expand Down Expand Up @@ -259,6 +257,10 @@
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild>
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild>
</ClCompile>
<ClCompile Include="..\modules\c++\mt\unittests\test_mt_byte_swap.cpp">
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild>
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild>
</ClCompile>
<ClCompile Include="..\modules\c++\mt\unittests\ThreadGroupTest.cpp">
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild>
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild>
Expand Down Expand Up @@ -319,6 +321,10 @@
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild>
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild>
</ClCompile>
<ClCompile Include="..\modules\c++\types\unittests\test_complex.cpp">
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild>
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild>
</ClCompile>
<ClCompile Include="..\modules\c++\types\unittests\test_page_row_col.cpp">
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</ExcludedFromBuild>
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</ExcludedFromBuild>
Expand Down
6 changes: 6 additions & 0 deletions UnitTest/UnitTest.vcxproj.filters
Original file line number Diff line number Diff line change
Expand Up @@ -219,6 +219,12 @@
<ClCompile Include="..\modules\c++\re\unittests\test_regex.cpp">
<Filter>re</Filter>
</ClCompile>
<ClCompile Include="..\modules\c++\mt\unittests\test_mt_byte_swap.cpp">
<Filter>mt</Filter>
</ClCompile>
<ClCompile Include="..\modules\c++\types\unittests\test_complex.cpp">
<Filter>types</Filter>
</ClCompile>
</ItemGroup>
<ItemGroup>
<ClInclude Include="pch.h" />
Expand Down
4 changes: 4 additions & 0 deletions UnitTest/mt.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -24,4 +24,8 @@ TEST_CLASS(work_sharing_balanced_runnable_1d_test){ public:
#include "mt/unittests/work_sharing_balanced_runnable_1d_test.cpp"
};

TEST_CLASS(test_mt_byte_swap){ public:
#include "mt/unittests/test_mt_byte_swap.cpp"
};

}
3 changes: 3 additions & 0 deletions UnitTest/pch.h
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@
#include <types/PageRowCol.h>
#include <types/RangeList.h>
#include <types/Range.h>
#include <types/complex.h>
#include <sys/Conf.h>
#include <sys/Path.h>
#include <except/Exception.h>
Expand All @@ -75,6 +76,7 @@
#include <sys/Thread.h>
#include <sys/Mutex.h>
#include <sys/FileFinder.h>
#include <sys/ByteSwap.h>
#include <import/sys.h>
#include <import/math/linear.h>
#include <import/math/poly.h>
Expand All @@ -87,6 +89,7 @@
#include <mt/RequestQueue.h>
#include <mt/ThreadPoolException.h>
#include <mt/GenerationThreadPool.h>
#include <mt/ThreadedByteSwap.h>
#include <import/mt.h>
#include <avx/extractf.h>
#include <logging/ExceptionLogger.h>
Expand Down
4 changes: 4 additions & 0 deletions UnitTest/types.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -15,4 +15,8 @@ TEST_CLASS(test_range_list){ public:
#include "types/unittests/test_range_list.cpp"
};

TEST_CLASS(test_complex){ public:
#include "types/unittests/test_complex.cpp"
};

}
2 changes: 2 additions & 0 deletions modules/c++/cli/source/ArgumentParser.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -294,6 +294,7 @@ std::unique_ptr<cli::Results> cli::ArgumentParser::parse(const std::string& prog
std::map<std::string, Argument*> longOptionsFlags;
std::vector<Argument*> positionalArgs;

positionalArgs.reserve(mArgs.size());
for (auto& arg_ : mArgs)
{
cli::Argument* arg = arg_.get();
Expand Down Expand Up @@ -336,6 +337,7 @@ std::unique_ptr<cli::Results> cli::ArgumentParser::parse(const std::string& prog
}

std::vector < std::string > explodedArgs;
explodedArgs.reserve(args.size());
// next, check for combined short options
for (size_t i = 0, s = args.size(); i < s; ++i)
{
Expand Down
9 changes: 6 additions & 3 deletions modules/c++/coda-oss-lite.vcxproj
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@
<ClInclude Include="coda_oss\include\coda_oss\bit.h" />
<ClInclude Include="coda_oss\include\coda_oss\CPlusPlus.h" />
<ClInclude Include="coda_oss\include\coda_oss\cstddef.h" />
<ClInclude Include="coda_oss\include\coda_oss\memory.h" />
<ClInclude Include="coda_oss\include\coda_oss\namespace_.h" />
<ClInclude Include="coda_oss\include\coda_oss\optional.h" />
<ClInclude Include="coda_oss\include\coda_oss\optional_.h" />
Expand Down Expand Up @@ -149,6 +148,7 @@
<ClInclude Include="mt\include\mt\RequestQueue.h" />
<ClInclude Include="mt\include\mt\Runnable1D.h" />
<ClInclude Include="mt\include\mt\Singleton.h" />
<ClInclude Include="mt\include\mt\ThreadedByteSwap.h" />
<ClInclude Include="mt\include\mt\ThreadGroup.h" />
<ClInclude Include="mt\include\mt\ThreadPlanner.h" />
<ClInclude Include="mt\include\mt\ThreadPoolException.h" />
Expand Down Expand Up @@ -191,6 +191,8 @@
<ClInclude Include="sys\include\sys\AtomicCounter.h" />
<ClInclude Include="sys\include\sys\AtomicCounterCpp11.h" />
<ClInclude Include="sys\include\sys\Backtrace.h" />
<ClInclude Include="sys\include\sys\ByteSwap.h" />
<ClInclude Include="sys\include\sys\ByteSwapValue.h" />
<ClInclude Include="sys\include\sys\ConditionVar.h" />
<ClInclude Include="sys\include\sys\ConditionVarInterface.h" />
<ClInclude Include="sys\include\sys\ConditionVarPosix.h" />
Expand Down Expand Up @@ -228,6 +230,8 @@
<ClInclude Include="sys\include\sys\SemaphoreInterface.h" />
<ClInclude Include="sys\include\sys\SemaphorePosix.h" />
<ClInclude Include="sys\include\sys\SemaphoreWin32.h" />
<ClInclude Include="sys\include\sys\Span.h" />
<ClInclude Include="sys\include\sys\SysInt.h" />
<ClInclude Include="sys\include\sys\StopWatch.h" />
<ClInclude Include="sys\include\sys\String.h" />
<ClInclude Include="sys\include\sys\SystemException.h" />
Expand All @@ -252,6 +256,7 @@
<ClInclude Include="tiff\include\tiff\KnownTags.h" />
<ClInclude Include="tiff\include\tiff\TypeFactory.h" />
<ClInclude Include="tiff\include\tiff\Utils.h" />
<ClInclude Include="types\include\types\complex.h" />
<ClInclude Include="types\include\types\PageRowCol.h" />
<ClInclude Include="types\include\types\Range.h" />
<ClInclude Include="types\include\types\RangeList.h" />
Expand Down Expand Up @@ -421,14 +426,12 @@
<ConfigurationType>DynamicLibrary</ConfigurationType>
<UseDebugLibraries>true</UseDebugLibraries>
<PlatformToolset>v143</PlatformToolset>
<EnableASAN>true</EnableASAN>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">
<ConfigurationType>DynamicLibrary</ConfigurationType>
<UseDebugLibraries>false</UseDebugLibraries>
<PlatformToolset>v143</PlatformToolset>
<WholeProgramOptimization>true</WholeProgramOptimization>
<EnableASAN>true</EnableASAN>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
<ImportGroup Label="ExtensionSettings">
Expand Down
21 changes: 18 additions & 3 deletions modules/c++/coda-oss-lite.vcxproj.filters
Original file line number Diff line number Diff line change
Expand Up @@ -30,9 +30,6 @@
<ClInclude Include="coda_oss\include\coda_oss\cstddef.h">
<Filter>coda_oss</Filter>
</ClInclude>
<ClInclude Include="coda_oss\include\coda_oss\memory.h">
<Filter>coda_oss</Filter>
</ClInclude>
<ClInclude Include="coda_oss\include\coda_oss\namespace_.h">
<Filter>coda_oss</Filter>
</ClInclude>
Expand Down Expand Up @@ -735,6 +732,24 @@
<ClInclude Include="config\include\config\disable_compiler_warnings.h">
<Filter>config</Filter>
</ClInclude>
<ClInclude Include="sys\include\sys\ByteSwap.h">
<Filter>sys</Filter>
</ClInclude>
<ClInclude Include="sys\include\sys\ByteSwapValue.h">
<Filter>sys</Filter>
</ClInclude>
<ClInclude Include="mt\include\mt\ThreadedByteSwap.h">
<Filter>mt</Filter>
</ClInclude>
<ClInclude Include="sys\include\sys\Span.h">
<Filter>sys</Filter>
</ClInclude>
<ClInclude Include="sys\include\sys\SysInt.h">
<Filter>sys</Filter>
</ClInclude>
<ClInclude Include="types\include\types\complex.h">
<Filter>types</Filter>
</ClInclude>
</ItemGroup>
<ItemGroup>
<ClCompile Include="pch.cpp" />
Expand Down
3 changes: 2 additions & 1 deletion modules/c++/coda_oss/include/coda_oss/CPlusPlus.h
Original file line number Diff line number Diff line change
Expand Up @@ -63,11 +63,12 @@
#endif // CODA_OSS_cplusplus

// Define a few macros as that's less verbose than testing against a version number
// https://en.cppreference.com/w/cpp/preprocessor/replace#Predefined_macros
#define CODA_OSS_cpp11 (CODA_OSS_cplusplus >= 201103L)
#define CODA_OSS_cpp14 (CODA_OSS_cplusplus >= 201402L)
#define CODA_OSS_cpp17 (CODA_OSS_cplusplus >= 201703L)
#define CODA_OSS_cpp20 (CODA_OSS_cplusplus >= 202002L)
#define CODA_OSS_cpp23 0
#define CODA_OSS_cpp23 (CODA_OSS_cplusplus >= 202302L)

#if !CODA_OSS_cpp14
#error "Must compile with C++14 or greater."
Expand Down
62 changes: 61 additions & 1 deletion modules/c++/coda_oss/include/coda_oss/bit.h
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,17 @@
* License along with this program; If not, http://www.gnu.org/licenses/.
*
*/
#pragma once
#ifndef CODA_OSS_coda_oss_bit_h_INCLUDED_
#define CODA_OSS_coda_oss_bit_h_INCLUDED_
#pragma once

#include <stdlib.h>
#include <stdint.h>
#ifdef __GNUC__
#include <byteswap.h> // "These functions are GNU extensions."
#endif

#include <type_traits>

#include "coda_oss/namespace_.h"
namespace coda_oss
Expand All @@ -38,6 +46,58 @@ namespace coda_oss
native = __BYTE_ORDER__
#endif
};

// https://en.cppreference.com/w/cpp/numeric/byteswap
namespace details
{
// Overloads for common types
inline constexpr uint8_t byteswap(uint8_t val) noexcept
{
return val; // no-op
}
#if defined(_MSC_VER)
// These routines should generate a single instruction; see
// https://devblogs.microsoft.com/cppblog/a-tour-of-4-msvc-backend-improvements/
inline uint16_t byteswap(uint16_t val) noexcept
{
return _byteswap_ushort(val);
}
inline uint32_t byteswap(uint32_t val) noexcept
{
return _byteswap_ulong(val);
}
inline uint64_t byteswap(uint64_t val) noexcept
{
return _byteswap_uint64(val);
}
#elif defined(__GNUC__)
inline uint16_t byteswap(uint16_t val) noexcept
{
return bswap_16(val);
}
inline uint32_t byteswap(uint32_t val) noexcept
{
return bswap_32(val);
}
inline uint64_t byteswap(uint64_t val) noexcept
{
return bswap_64(val);
}
#else
#error "No platform-specific byteswap()" // TODO: do something else?
#endif
}

template <typename T>
inline T byteswap(T n) noexcept
{
// "std::byteswap participates in overload resolution only if T satisfies integral, i.e., T is an integer type. The program is
// ill-formed if T has padding bits."
static_assert(std::is_integral<T>::value, "T must be integral");

using unsigned_t = std::make_unsigned_t<T>; // "Since C++14" https://en.cppreference.com/w/cpp/types/make_unsigned
return details::byteswap(static_cast<unsigned_t>(n));
}
}

#endif // CODA_OSS_coda_oss_bit_h_INCLUDED_
4 changes: 4 additions & 0 deletions modules/c++/coda_oss/include/coda_oss/cstddef.h
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,10 @@
#define CODA_OSS_coda_oss_cstddef_h_INCLUDED_
#pragma once

#include <stdint.h>

#include <cstddef>
#include <type_traits>

// Need a fairly decent C++ compiler to use the real GSL. This brings in more than
// we really need for span (e.g., gsl::narrow()), but it keeps things simple.
Expand All @@ -37,5 +40,6 @@ namespace coda_oss
enum class byte : unsigned char {};
#endif // GSL_BYTE_H
}
static_assert(!std::is_same<coda_oss::byte, uint8_t>::value, "'coda_oss::byte' should be a unique type.");

#endif // CODA_OSS_coda_oss_cstddef_h_INCLUDED_
Loading

0 comments on commit ae3968a

Please sign in to comment.