/*---------------------------------------------------------------------------*\ ========= | \\ / F ield | OpenFOAM: The Open Source CFD Toolbox \\ / O peration | \\ / A nd | www.openfoam.com \\/ M anipulation | ------------------------------------------------------------------------------- Copyright (C) 2017-2023 OpenCFD Ltd. ------------------------------------------------------------------------------- License This file is part of OpenFOAM. OpenFOAM is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. OpenFOAM 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 General Public License for more details. You should have received a copy of the GNU General Public License along with OpenFOAM. If not, see . Description \*---------------------------------------------------------------------------*/ #include "SpanStream.H" #include "wordList.H" #include "IOstreams.H" #include "argList.H" #include #include using namespace Foam; Ostream& writeList(Ostream& os, const UList& list) { char buf[4]; os << list.size() << '('; for (const char c : list) { if (isprint(c)) { os << c; } else if (c == '\t') { os << "\\t"; } else if (c == '\n') { os << "\\n"; } else { ::snprintf(buf, 4, "%02X", c); os << "\\x" << buf; } } os << ')'; return os; } Ostream& toString(Ostream& os, const UList& list) { os << '"'; for (const char c : list) { os << c; } os << '"'; return os; } template void printInfo(const BufType& buf) { Info<< nl << "=========================" << endl; buf.print(Info); toString(Info, buf.list()); Info<< nl << "=========================" << endl; } template<> void printInfo(const List& buf) { Info<< nl << "=========================" << endl; toString(Info, buf); Info<< nl << "=========================" << endl; } void printTokens(Istream& is) { label count = 0; token t; while (is.good()) { is >> t; if (t.good()) { ++count; Info<<"token: " << t << endl; } } Info<< count << " tokens" << endl; } // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // // Main program: int main(int argc, char *argv[]) { // Buffer storage DynamicList storage(16); OCharStream obuf(std::move(storage)); obuf << 1002 << " " << "abcd" << " " << "def" << " " << 3.14159 << ";\n"; // Move contents to output buffer printInfo(obuf); Info< ICharStream { List data; obuf.swap(data); ibuf.swap(data); } Info<< nl; Info<< nl << "input string:"; printInfo(ibuf); Info<< nl << "orig output:"; printInfo(obuf); printTokens(ibuf); Info< newvalues(52); { for (int i=0; i<26; ++i) { newvalues[2*i+0] = char('a' + i); newvalues[2*i+1] = char('A' + i); } } ibuf.swap(newvalues); Info< chars(is.list()); Foam::reverse(chars); } is.rewind(); Info<< "get:"; while (is.get(c)) { Info<< ' ' << c; } Info<< " - end" << nl; } Info<< "\nEnd\n" << endl; return 0; } // ************************************************************************* //