template<typename OTLStream,typename Arg1,typename...Args>
void otl_read_row(OTLStream& s,Arg1& arg1,Args&...args);
template<typename OTLStream,typename Arg1, typename...Args>
void otl_write_row(OTLStream& s,Arg1&& arg1,Args&&...args);
Here are the signatures of the nonvariadic template functions for
pre-C++11 compilers:
template<typename OTLStream,typename Arg1> void otl_read_row(OTLStream& s,Arg1& arg1);
template<typename OTLStream,typename Arg1,typename Arg2> void otl_read_row(OTLStream& s,Arg1& arg1,Arg2& arg2);
...
template<typename OTLStream,typename Arg1> void otl_write_row(OTLStream& s,Arg1& arg1);
template<typename OTLStream,typename Arg1> void otl_write_row(OTLStream& s,const Arg1& arg1);
template<typename OTLStream,typename Arg1,typename Arg2> void otl_write_row(OTLStream& s,Arg1& arg1,Arg2& arg2);
template<typename OTLStream,typename Arg1,typename Arg2> void otl_write_row(OTLStream& s,const Arg1& arg1,const Arg2& arg2);
...
Here are the signatures of the nonvariadic functions for Visual
C++ 2010, and Visual C++ 2012, which do not support variadic
templates, but do support universal
references (see the explanation below at the end of this
page):
template<typename OTLStream,typename Arg1> void otl_read_row(OTLStream& s,Arg1& arg1);
template<typename OTLStream,typename Arg1,typename Arg2> void otl_read_row(OTLStream& s,Arg1& arg1,Arg2& arg2);
...
template<typename OTLStream,typename Arg1> void otl_write_row(OTLStream& s,Arg1&& arg1);
template<typename OTLStream,typename Arg1,typename Arg2> void otl_write_row(OTLStream& s,Arg1&& arg1,Arg2&& arg2);
...
The list of nonvariadic template functions goes up to 15
parameters. The intention here is that similar (even though more
limited) functionality should be available to users of pre-C++11
compilers. When such users migrate their C++ code to a C++11
compiler, everything should just work.
otl_write_row(s,f1); is equivalent to s<<f1<<endr;where s is an otl_stream, and f1, f2... are variables of the data types that are supported by the otl_stream operators >>()/<<(). The functions are defined in the global namespace. In order to retrieve information on NULL values, instantiations of the otl_value<T> template can be used as parameters that get passed into the otl_read_row / otl_write_row functions, for example:
otl_write_row(s,f1,f2); is equivalent to s<<f1<<f2<<endr;
...
otl_read_row(s,f1); is equivalent to s>>f1>>endr;
otl_read_row(s,f1,f2); is equivalent to s>>f1>>f2>>endr;
...
There is a subtle difference between the variadic version of
these template functions and the nonvariadic version for pre-C++11
compilers. The variadic otl_write_row() uses universal references
that accept all types of parameters. The nonvariadic versions of
otl_write_row() for pre-C++11 compilers accept either all const
T&, or all non-const T&, which is more limited than the
variadic version. The
nonvariadic versions of otl_write_row() for Visual C++ 2010/2012
accept all types of parameters. "Universal references" is a term
coined by Scott Meyers. There is plenty of videos, or articles by
Scott Meyers, so if you're curious, just google "universal
references C++".
Copyright © 1996-2025, Sergei Kuchin, email: skuchin@gmail.com, skuchin@gmail.com .
Permission to use, copy, modify and redistribute this document for any purpose is hereby granted without fee, provided that the above copyright notice appear in all copies. THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.