GDAL
cpl_string.h
Go to the documentation of this file.
1/**********************************************************************
2 *
3 * Name: cpl_string.h
4 * Project: CPL - Common Portability Library
5 * Purpose: String and StringList functions.
6 * Author: Daniel Morissette, dmorissette@mapgears.com
7 *
8 **********************************************************************
9 * Copyright (c) 1998, Daniel Morissette
10 * Copyright (c) 2008-2014, Even Rouault <even dot rouault at spatialys.com>
11 *
12 * SPDX-License-Identifier: MIT
13 ****************************************************************************/
14
15#ifndef CPL_STRING_H_INCLUDED
16#define CPL_STRING_H_INCLUDED
17
18#include "cpl_error.h"
19#include "cpl_conv.h"
20#include "cpl_vsi.h"
21
22#include <stdbool.h>
23
45
47
48char CPL_DLL **CSLAddString(char **papszStrList,
49 const char *pszNewString) CPL_WARN_UNUSED_RESULT;
50char CPL_DLL **
51CSLAddStringMayFail(char **papszStrList,
52 const char *pszNewString) CPL_WARN_UNUSED_RESULT;
53int CPL_DLL CSLCount(CSLConstList papszStrList);
54const char CPL_DLL *CSLGetField(CSLConstList, int);
55void CPL_DLL CPL_STDCALL CSLDestroy(char **papszStrList);
56char CPL_DLL **CSLDuplicate(CSLConstList papszStrList) CPL_WARN_UNUSED_RESULT;
57char CPL_DLL **CSLMerge(char **papszOrig,
59
60char CPL_DLL **CSLTokenizeString(const char *pszString) CPL_WARN_UNUSED_RESULT;
61char CPL_DLL **
62CSLTokenizeStringComplex(const char *pszString, const char *pszDelimiter,
63 int bHonourStrings,
64 int bAllowEmptyTokens) CPL_WARN_UNUSED_RESULT;
65char CPL_DLL **CSLTokenizeString2(const char *pszString,
66 const char *pszDelimiter,
67 int nCSLTFlags) CPL_WARN_UNUSED_RESULT;
68
70#define CSLT_HONOURSTRINGS 0x0001
72#define CSLT_ALLOWEMPTYTOKENS 0x0002
74#define CSLT_PRESERVEQUOTES 0x0004
76#define CSLT_PRESERVEESCAPES 0x0008
78#define CSLT_STRIPLEADSPACES 0x0010
80#define CSLT_STRIPENDSPACES 0x0020
81
82int CPL_DLL CSLPrint(CSLConstList papszStrList, FILE *fpOut);
83char CPL_DLL **CSLLoad(const char *pszFname) CPL_WARN_UNUSED_RESULT;
84char CPL_DLL **CSLLoad2(const char *pszFname, int nMaxLines, int nMaxCols,
86int CPL_DLL CSLSave(CSLConstList papszStrList, const char *pszFname);
87
88char CPL_DLL **
89CSLInsertStrings(char **papszStrList, int nInsertAtLineNo,
91char CPL_DLL **CSLInsertString(char **papszStrList, int nInsertAtLineNo,
92 const char *pszNewLine) CPL_WARN_UNUSED_RESULT;
93char CPL_DLL **
94CSLRemoveStrings(char **papszStrList, int nFirstLineToDelete, int nNumToRemove,
95 char ***ppapszRetStrings) CPL_WARN_UNUSED_RESULT;
96int CPL_DLL CSLFindString(CSLConstList papszList, const char *pszTarget);
97int CPL_DLL CSLFindStringCaseSensitive(CSLConstList papszList,
98 const char *pszTarget);
99int CPL_DLL CSLPartialFindString(CSLConstList papszHaystack,
100 const char *pszNeedle);
101int CPL_DLL CSLFindName(CSLConstList papszStrList, const char *pszName);
102int CPL_DLL CSLFetchBoolean(CSLConstList papszStrList, const char *pszKey,
103 int bDefault);
104
105/* TODO: Deprecate CSLTestBoolean. Remove in GDAL 3.x. */
106int CPL_DLL CSLTestBoolean(const char *pszValue);
107/* Do not use CPLTestBoolean in C++ code. Use CPLTestBool. */
108int CPL_DLL CPLTestBoolean(const char *pszValue);
109
110bool CPL_DLL CPLTestBool(const char *pszValue);
111bool CPL_DLL CPLFetchBool(CSLConstList papszStrList, const char *pszKey,
112 bool bDefault);
113
114CPLErr CPL_DLL CPLParseMemorySize(const char *pszValue, GIntBig *pnValue,
115 bool *pbUnitSpecified);
116
117const char CPL_DLL *CPLParseNameValue(const char *pszNameValue, char **ppszKey);
118const char CPL_DLL *CPLParseNameValueSep(const char *pszNameValue,
119 char **ppszKey, char chSep);
120
121const char CPL_DLL *CSLFetchNameValue(CSLConstList papszStrList,
122 const char *pszName);
123const char CPL_DLL *CSLFetchNameValueDef(CSLConstList papszStrList,
124 const char *pszName,
125 const char *pszDefault);
126char CPL_DLL **CSLFetchNameValueMultiple(CSLConstList papszStrList,
127 const char *pszName);
128char CPL_DLL **CSLAddNameValue(char **papszStrList, const char *pszName,
129 const char *pszValue) CPL_WARN_UNUSED_RESULT;
130char CPL_DLL **CSLSetNameValue(char **papszStrList, const char *pszName,
131 const char *pszValue) CPL_WARN_UNUSED_RESULT;
132void CPL_DLL CSLSetNameValueSeparator(char **papszStrList,
133 const char *pszSeparator);
134
135char CPL_DLL **CSLParseCommandLine(const char *pszCommandLine);
136
138#define CPLES_BackslashQuotable 0
140#define CPLES_XML 1
142#define CPLES_URL 2
144#define CPLES_SQL 3
146#define CPLES_CSV 4
149#define CPLES_XML_BUT_QUOTES 5
151#define CPLES_CSV_FORCE_QUOTING 6
153#define CPLES_SQLI 7
154
155char CPL_DLL *CPLEscapeString(const char *pszString, int nLength,
156 int nScheme) CPL_WARN_UNUSED_RESULT;
157char CPL_DLL *CPLUnescapeString(const char *pszString, int *pnLength,
158 int nScheme) CPL_WARN_UNUSED_RESULT;
159
160char CPL_DLL *CPLBinaryToHex(int nBytes,
161 const GByte *pabyData) CPL_WARN_UNUSED_RESULT;
162GByte CPL_DLL *CPLHexToBinary(const char *pszHex,
163 int *pnBytes) CPL_WARN_UNUSED_RESULT;
164
165char CPL_DLL *CPLBase64Encode(int nBytes,
166 const GByte *pabyData) CPL_WARN_UNUSED_RESULT;
168
176
177CPLValueType CPL_DLL CPLGetValueType(const char *pszValue);
178
179int CPL_DLL CPLToupper(int c);
180int CPL_DLL CPLTolower(int c);
181
182size_t CPL_DLL CPLStrlcpy(char *pszDest, const char *pszSrc, size_t nDestSize);
183size_t CPL_DLL CPLStrlcat(char *pszDest, const char *pszSrc, size_t nDestSize);
184size_t CPL_DLL CPLStrnlen(const char *pszStr, size_t nMaxLen);
185
186/* -------------------------------------------------------------------- */
187/* Locale independent formatting functions. */
188/* -------------------------------------------------------------------- */
189int CPL_DLL CPLvsnprintf(char *str, size_t size,
190 CPL_FORMAT_STRING(const char *fmt), va_list args)
192
193/* ALIAS_CPLSNPRINTF_AS_SNPRINTF might be defined to enable GCC 7 */
194/* -Wformat-truncation= warnings, but shouldn't be set for normal use */
195#if defined(ALIAS_CPLSNPRINTF_AS_SNPRINTF)
196#define CPLsnprintf snprintf
197#else
198int CPL_DLL CPLsnprintf(char *str, size_t size,
199 CPL_FORMAT_STRING(const char *fmt), ...)
201#endif
202
204#if defined(GDAL_COMPILATION) && !defined(DONT_DEPRECATE_SPRINTF)
205int CPL_DLL CPLsprintf(char *str, CPL_FORMAT_STRING(const char *fmt), ...)
206 CPL_PRINT_FUNC_FORMAT(2, 3) CPL_WARN_DEPRECATED("Use CPLsnprintf instead");
207#else
208int CPL_DLL CPLsprintf(char *str, CPL_FORMAT_STRING(const char *fmt), ...)
210#endif
212int CPL_DLL CPLprintf(CPL_FORMAT_STRING(const char *fmt), ...)
214
215/* For some reason Doxygen_Suppress is needed to avoid warning. Not sure why */
217/* caution: only works with limited number of formats */
218int CPL_DLL CPLsscanf(const char *str, CPL_SCANF_FORMAT_STRING(const char *fmt),
219 ...) CPL_SCAN_FUNC_FORMAT(2, 3);
221
222const char CPL_DLL *CPLSPrintf(CPL_FORMAT_STRING(const char *fmt), ...)
224char CPL_DLL **CSLAppendPrintf(char **papszStrList,
225 CPL_FORMAT_STRING(const char *fmt), ...)
227int CPL_DLL CPLVASPrintf(char **buf, CPL_FORMAT_STRING(const char *fmt),
228 va_list args) CPL_PRINT_FUNC_FORMAT(2, 0);
229
230/* -------------------------------------------------------------------- */
231/* RFC 23 character set conversion/recoding API (cpl_recode.cpp). */
232/* -------------------------------------------------------------------- */
234#define CPL_ENC_LOCALE ""
236#define CPL_ENC_UTF8 "UTF-8"
238#define CPL_ENC_UTF16 "UTF-16"
240#define CPL_ENC_UCS2 "UCS-2"
242#define CPL_ENC_UCS4 "UCS-4"
244#define CPL_ENC_ASCII "ASCII"
246#define CPL_ENC_ISO8859_1 "ISO-8859-1"
247
248int CPL_DLL CPLEncodingCharSize(const char *pszEncoding);
250void CPL_DLL CPLClearRecodeWarningFlags(void);
252char CPL_DLL *CPLRecode(const char *pszSource, const char *pszSrcEncoding,
253 const char *pszDstEncoding)
255char CPL_DLL *
256CPLRecodeFromWChar(const wchar_t *pwszSource, const char *pszSrcEncoding,
257 const char *pszDstEncoding) CPL_WARN_UNUSED_RESULT;
258wchar_t CPL_DLL *
259CPLRecodeToWChar(const char *pszSource, const char *pszSrcEncoding,
260 const char *pszDstEncoding) CPL_WARN_UNUSED_RESULT;
261int CPL_DLL CPLIsUTF8(const char *pabyData, int nLen);
262bool CPL_DLL CPLIsASCII(const char *pabyData, size_t nLen);
263char CPL_DLL *CPLForceToASCII(const char *pabyData, int nLen,
264 char chReplacementChar) CPL_WARN_UNUSED_RESULT;
265char CPL_DLL *CPLUTF8ForceToASCII(const char *pszStr, char chReplacementChar)
267int CPL_DLL CPLStrlenUTF8(const char *pszUTF8Str)
269 CPL_WARN_DEPRECATED("Use CPLStrlenUTF8Ex() instead")
271 ;
272size_t CPL_DLL CPLStrlenUTF8Ex(const char *pszUTF8Str);
273int CPL_DLL CPLCanRecode(const char *pszTestStr, const char *pszSrcEncoding,
274 const char *pszDstEncoding) CPL_WARN_UNUSED_RESULT;
276
277#if defined(__cplusplus) && !defined(CPL_SUPRESS_CPLUSPLUS)
278
279extern "C++"
280{
281 std::string CPL_DLL CPLRemoveSQLComments(const std::string &osInput);
282}
283
284#endif
285
286/************************************************************************/
287/* CPLString */
288/************************************************************************/
289
290#if defined(__cplusplus) && !defined(CPL_SUPRESS_CPLUSPLUS)
291
292extern "C++"
293{
294#ifndef DOXYGEN_SKIP
295#include <string>
296#include <vector>
297#endif
298
299// VC++ implicitly applies __declspec(dllexport) to template base classes
300// of classes marked with __declspec(dllexport).
301// Hence, if marked with CPL_DLL, VC++ would export symbols for the
302// specialization of std::basic_string<char>, since it is a base class of
303// CPLString. As a result, if an application linked both gdal.dll and a static
304// library that (implicitly) instantiates std::string (almost all do!), then the
305// linker would emit an error concerning duplicate symbols for std::string. The
306// least intrusive solution is to not mark the whole class with
307// __declspec(dllexport) for VC++, but only its non-inline methods.
308#ifdef _MSC_VER
309#define CPLSTRING_CLASS_DLL
310#define CPLSTRING_METHOD_DLL CPL_DLL
311#else
313#define CPLSTRING_CLASS_DLL CPL_DLL
314#define CPLSTRING_METHOD_DLL
316#endif
317
319 class CPLSTRING_CLASS_DLL CPLString : public std::string
320 {
321 public:
324 {
325 }
326
328 // cppcheck-suppress noExplicitConstructor
329 CPLString(const std::string &oStr) : std::string(oStr)
330 {
331 }
332
334 // cppcheck-suppress noExplicitConstructor
335 CPLString(const char *pszStr) : std::string(pszStr)
336 {
337 }
338
340 CPLString(const char *pszStr, size_t n) : std::string(pszStr, n)
341 {
342 }
343
345 operator const char *(void) const
346 {
347 return c_str();
348 }
349
351 char &operator[](std::string::size_type i)
352 {
353 return std::string::operator[](i);
354 }
355
357 const char &operator[](std::string::size_type i) const
358 {
359 return std::string::operator[](i);
360 }
361
363 char &operator[](int i)
364 {
365 return std::string::operator[](
366 static_cast<std::string::size_type>(i));
367 }
368
370 const char &operator[](int i) const
371 {
372 return std::string::operator[](
373 static_cast<std::string::size_type>(i));
374 }
375
377 void Clear()
378 {
379 resize(0);
380 }
381
385 void Seize(char *pszValue)
386 {
387 if (pszValue == nullptr)
388 Clear();
389 else
390 {
391 *this = pszValue;
392 CPLFree(pszValue);
393 }
394 }
395
396 /* There seems to be a bug in the way the compiler count indices...
397 * Should be CPL_PRINT_FUNC_FORMAT (1, 2) */
398 CPLSTRING_METHOD_DLL CPLString &
399 Printf(CPL_FORMAT_STRING(const char *pszFormat), ...)
401 CPLSTRING_METHOD_DLL CPLString &
402 vPrintf(CPL_FORMAT_STRING(const char *pszFormat), va_list args)
404 CPLSTRING_METHOD_DLL CPLString &
405 FormatC(double dfValue, const char *pszFormat = nullptr);
406 CPLSTRING_METHOD_DLL CPLString &Trim();
407 CPLSTRING_METHOD_DLL CPLString &Recode(const char *pszSrcEncoding,
408 const char *pszDstEncoding);
409 CPLSTRING_METHOD_DLL CPLString &replaceAll(const std::string &osBefore,
410 const std::string &osAfter);
411 CPLSTRING_METHOD_DLL CPLString &replaceAll(const std::string &osBefore,
412 char chAfter);
413 CPLSTRING_METHOD_DLL CPLString &replaceAll(char chBefore,
414 const std::string &osAfter);
415 CPLSTRING_METHOD_DLL CPLString &replaceAll(char chBefore, char chAfter);
416
417 /* case insensitive find alternates */
418 CPLSTRING_METHOD_DLL size_t ifind(const std::string &str,
419 size_t pos = 0) const;
420 CPLSTRING_METHOD_DLL size_t ifind(const char *s, size_t pos = 0) const;
421 CPLSTRING_METHOD_DLL CPLString &toupper(void);
422 CPLSTRING_METHOD_DLL CPLString &tolower(void);
423
424 CPLSTRING_METHOD_DLL bool endsWith(const std::string &osStr) const;
425
426 CPLSTRING_METHOD_DLL CPLString URLEncode() const;
427
428 private:
429 operator void *(void) = delete;
430 };
431
432#undef CPLSTRING_CLASS_DLL
433#undef CPLSTRING_METHOD_DLL
434
435 CPLString CPL_DLL CPLOPrintf(CPL_FORMAT_STRING(const char *pszFormat), ...)
437 CPLString CPL_DLL CPLOvPrintf(CPL_FORMAT_STRING(const char *pszFormat),
438 va_list args) CPL_PRINT_FUNC_FORMAT(1, 0);
439 CPLString CPL_DLL CPLQuotedSQLIdentifier(const char *pszIdent);
440
441 /* -------------------------------------------------------------------- */
442 /* URL processing functions, here since they depend on CPLString. */
443 /* -------------------------------------------------------------------- */
444 CPLString CPL_DLL CPLURLGetValue(const char *pszURL, const char *pszKey);
445 CPLString CPL_DLL CPLURLAddKVP(const char *pszURL, const char *pszKey,
446 const char *pszValue);
447
448 /************************************************************************/
449 /* CPLStringList */
450 /************************************************************************/
451
453 class CPL_DLL CPLStringList
454 {
455 char **papszList = nullptr;
456 mutable int nCount = 0;
457 mutable int nAllocation = 0;
458 bool bOwnList = false;
459 bool bIsSorted = false;
460
461 bool MakeOurOwnCopy();
462 bool EnsureAllocation(int nMaxLength);
463 int FindSortedInsertionPoint(const char *pszLine);
464
465 public:
466 CPLStringList();
467 explicit CPLStringList(char **papszList, int bTakeOwnership = TRUE);
468 explicit CPLStringList(CSLConstList papszList);
469 explicit CPLStringList(const std::vector<std::string> &aosList);
470 explicit CPLStringList(std::initializer_list<const char *> oInitList);
471 CPLStringList(const CPLStringList &oOther);
472 CPLStringList(CPLStringList &&oOther);
473 ~CPLStringList();
474
475 static const CPLStringList BoundToConstList(CSLConstList papszList);
476
477 CPLStringList &Clear();
478
480 inline void clear()
481 {
482 Clear();
483 }
484
486 int size() const
487 {
488 return Count();
489 }
490
491 int Count() const;
492
494 bool empty() const
495 {
496 return Count() == 0;
497 }
498
499 CPLStringList &AddString(const char *pszNewString);
500 CPLStringList &AddString(const std::string &newString);
501 CPLStringList &AddStringDirectly(char *pszNewString);
502
504 void push_back(const char *pszNewString)
505 {
506 AddString(pszNewString);
507 }
508
510 void push_back(const std::string &osStr)
511 {
512 AddString(osStr.c_str());
513 }
514
515 CPLStringList &InsertString(int nInsertAtLineNo, const char *pszNewLine)
516 {
517 return InsertStringDirectly(nInsertAtLineNo, CPLStrdup(pszNewLine));
518 }
519
520 CPLStringList &InsertStringDirectly(int nInsertAtLineNo,
521 char *pszNewLine);
522
523 // CPLStringList &InsertStrings( int nInsertAtLineNo, char
524 // **papszNewLines ); CPLStringList &RemoveStrings( int
525 // nFirstLineToDelete, int nNumToRemove=1 );
526
528 int FindString(const char *pszTarget) const
529 {
530 return CSLFindString(papszList, pszTarget);
531 }
532
535 int PartialFindString(const char *pszNeedle) const
536 {
537 return CSLPartialFindString(papszList, pszNeedle);
538 }
539
540 int FindName(const char *pszName) const;
541 bool FetchBool(const char *pszKey, bool bDefault) const;
542 // Deprecated.
543 int FetchBoolean(const char *pszKey, int bDefault) const;
544 const char *FetchNameValue(const char *pszKey) const;
545 const char *FetchNameValueDef(const char *pszKey,
546 const char *pszDefault) const;
547 CPLStringList &AddNameValue(const char *pszKey, const char *pszValue);
548 CPLStringList &SetNameValue(const char *pszKey, const char *pszValue);
549
550 CPLStringList &Assign(char **papszListIn, int bTakeOwnership = TRUE);
551
553 CPLStringList &operator=(char **papszListIn)
554 {
555 return Assign(papszListIn, TRUE);
556 }
557
559 CPLStringList &operator=(const CPLStringList &oOther);
561 CPLStringList &operator=(CSLConstList papszListIn);
563 CPLStringList &operator=(CPLStringList &&oOther);
564
566 char *operator[](int i);
567
569 char *operator[](size_t i)
570 {
571 return (*this)[static_cast<int>(i)];
572 }
573
575 const char *operator[](int i) const;
576
578 const char *operator[](size_t i) const
579 {
580 return (*this)[static_cast<int>(i)];
581 }
582
584 const char *operator[](const char *pszKey) const
585 {
586 return FetchNameValue(pszKey);
587 }
588
590 inline const char *front() const
591 {
592 return papszList[0];
593 }
594
596 inline const char *back() const
597 {
598 return papszList[size() - 1];
599 }
600
602 const char *const *begin() const
603 {
604 return papszList ? &papszList[0] : nullptr;
605 }
606
608 const char *const *end() const
609 {
610 return papszList ? &papszList[size()] : nullptr;
611 }
612
614 char **List()
615 {
616 return papszList;
617 }
618
621 {
622 return papszList;
623 }
624
625 char **StealList();
626
627 CPLStringList &Sort();
628
630 int IsSorted() const
631 {
632 return bIsSorted;
633 }
634
636 operator char **(void)
637 {
638 return List();
639 }
640
642 operator CSLConstList(void) const
643 {
644 return List();
645 }
646
648 operator std::vector<std::string>(void) const
649 {
650 return std::vector<std::string>{begin(), end()};
651 }
652
653 private:
654 operator void *(void) = delete;
655 };
656
657#ifdef GDAL_COMPILATION
658
659#include <iterator> // For std::input_iterator_tag
660#include <memory>
661#include <string_view>
662#include <utility> // For std::pair
663
665 struct CPL_DLL CSLDestroyReleaser
666 {
667 void operator()(char **papszStr) const
668 {
669 CSLDestroy(papszStr);
670 }
671 };
672
674
676 using CSLUniquePtr = std::unique_ptr<char *, CSLDestroyReleaser>;
677
680 using CPLCharUniquePtr = std::unique_ptr<char, VSIFreeReleaser>;
681
682 namespace cpl
683 {
684
686
688 template <class StringType>
689 inline bool starts_with(const StringType &str, const char *prefix)
690 {
691 const size_t prefixLen = strlen(prefix);
692 return str.size() >= prefixLen &&
693 str.compare(0, prefixLen, prefix, prefixLen) == 0;
694 }
695
697 template <class StringType>
698 inline bool starts_with(const StringType &str, const std::string &prefix)
699 {
700 return str.size() >= prefix.size() &&
701 str.compare(0, prefix.size(), prefix) == 0;
702 }
703
705 template <class StringType>
706 inline bool starts_with(const StringType &str, std::string_view prefix)
707 {
708 return str.size() >= prefix.size() &&
709 str.compare(0, prefix.size(), prefix) == 0;
710 }
711
713 template <class StringType>
714 inline bool ends_with(const StringType &str, const char *suffix)
715 {
716 const size_t suffixLen = strlen(suffix);
717 return str.size() >= suffixLen &&
718 str.compare(str.size() - suffixLen, suffixLen, suffix,
719 suffixLen) == 0;
720 }
721
723 template <class StringType>
724 inline bool ends_with(const StringType &str, const std::string &suffix)
725 {
726 return str.size() >= suffix.size() &&
727 str.compare(str.size() - suffix.size(), suffix.size(), suffix) ==
728 0;
729 }
730
732 template <class StringType>
733 inline bool ends_with(const StringType &str, std::string_view suffix)
734 {
735 return str.size() >= suffix.size() &&
736 str.compare(str.size() - suffix.size(), suffix.size(), suffix) ==
737 0;
738 }
739
741 struct CPL_DLL CSLIterator
742 {
743 using iterator_category = std::input_iterator_tag;
744 using difference_type = std::ptrdiff_t;
745 using value_type = const char *;
746 using pointer = value_type *;
747 using reference = value_type &;
748
749 CSLConstList m_papszList = nullptr;
750 bool m_bAtEnd = false;
751
752 inline const char *operator*() const
753 {
754 return *m_papszList;
755 }
756
757 inline CSLIterator &operator++()
758 {
759 if (m_papszList)
760 ++m_papszList;
761 return *this;
762 }
763
764 bool operator==(const CSLIterator &other) const;
765
766 inline bool operator!=(const CSLIterator &other) const
767 {
768 return !(operator==(other));
769 }
770 };
771
773
778 struct CPL_DLL CSLIteratorWrapper
779 {
780 public:
782 inline explicit CSLIteratorWrapper(CSLConstList papszList)
783 : m_papszList(papszList)
784 {
785 }
786
788 inline CSLIterator begin() const
789 {
790 return {m_papszList, false};
791 }
792
794 inline CSLIterator end() const
795 {
796 return {m_papszList, true};
797 }
798
799 private:
800 CSLConstList m_papszList;
801 };
802
807 inline CSLIteratorWrapper Iterate(CSLConstList papszList)
808 {
809 return CSLIteratorWrapper{papszList};
810 }
811
813 inline CSLIteratorWrapper Iterate(const CPLStringList &aosList)
814 {
815 return Iterate(aosList.List());
816 }
817
819
821 inline CSLIteratorWrapper Iterate(char **) = delete;
822
824
827 struct CPL_DLL CSLNameValueIterator
828 {
829 using iterator_category = std::input_iterator_tag;
830 using difference_type = std::ptrdiff_t;
831 using value_type = std::pair<const char *, const char *>;
832 using pointer = value_type *;
833 using reference = value_type &;
834
835 CSLConstList m_papszList = nullptr;
836 bool m_bReturnNullKeyIfNotNameValue = false;
837 std::string m_osKey{};
838
839 value_type operator*();
840
841 inline CSLNameValueIterator &operator++()
842 {
843 if (m_papszList)
844 ++m_papszList;
845 return *this;
846 }
847
848 inline bool operator==(const CSLNameValueIterator &other) const
849 {
850 return m_papszList == other.m_papszList;
851 }
852
853 inline bool operator!=(const CSLNameValueIterator &other) const
854 {
855 return !(operator==(other));
856 }
857 };
858
860
872 struct CPL_DLL CSLNameValueIteratorWrapper
873 {
874 public:
876 inline explicit CSLNameValueIteratorWrapper(
877 CSLConstList papszList, bool bReturnNullKeyIfNotNameValue)
878 : m_papszList(papszList),
879 m_bReturnNullKeyIfNotNameValue(bReturnNullKeyIfNotNameValue)
880 {
881 }
882
884 inline CSLNameValueIterator begin() const
885 {
886 return {m_papszList, m_bReturnNullKeyIfNotNameValue};
887 }
888
890 CSLNameValueIterator end() const;
891
892 private:
893 CSLConstList m_papszList;
894 const bool m_bReturnNullKeyIfNotNameValue;
895 };
896
913 inline CSLNameValueIteratorWrapper
914 IterateNameValue(CSLConstList papszList,
915 bool bReturnNullKeyIfNotNameValue = false)
916 {
917 return CSLNameValueIteratorWrapper{papszList,
918 bReturnNullKeyIfNotNameValue};
919 }
920
922 inline CSLNameValueIteratorWrapper
923 IterateNameValue(const CPLStringList &aosList,
924 bool bReturnNullKeyIfNotNameValue = false)
925 {
926 return IterateNameValue(aosList.List(), bReturnNullKeyIfNotNameValue);
927 }
928
930
932 inline CSLIteratorWrapper IterateNameValue(char **, bool = false) = delete;
933
935
937 inline std::vector<std::string> ToVector(CSLConstList papszList)
938 {
939 return CPLStringList::BoundToConstList(papszList);
940 }
941
942 inline std::vector<std::string> ToVector(char **) = delete;
943
944 } // namespace cpl
945
946#endif
947
948} // extern "C++"
949
950#endif /* def __cplusplus && !CPL_SUPRESS_CPLUSPLUS */
951
952#endif /* CPL_STRING_H_INCLUDED */
String list class designed around our use of C "char**" string lists.
Definition cpl_string.h:454
CPLStringList & Assign(char **papszListIn, int bTakeOwnership=TRUE)
Assign a list of strings.
Definition cplstringlist.cpp:272
const char * operator[](size_t i) const
Return string at specified index.
Definition cpl_string.h:578
const char * operator[](const char *pszKey) const
Return value corresponding to pszKey, or nullptr.
Definition cpl_string.h:584
int IsSorted() const
Returns whether the list is sorted.
Definition cpl_string.h:630
bool empty() const
Return whether the list is empty.
Definition cpl_string.h:494
const char *const * end() const
end() implementation
Definition cpl_string.h:608
CPLStringList & operator=(CSLConstList papszListIn)
Assignment operator.
void push_back(const std::string &osStr)
Add a string to the list.
Definition cpl_string.h:510
CPLStringList & InsertString(int nInsertAtLineNo, const char *pszNewLine)
Insert into the list at identified location.
Definition cpl_string.h:515
char ** List()
Return list.
Definition cpl_string.h:614
void clear()
Clear the list.
Definition cpl_string.h:480
void push_back(const char *pszNewString)
Add a string to the list.
Definition cpl_string.h:504
int Count() const
Definition cplstringlist.cpp:299
CPLStringList & operator=(char **papszListIn)
Assignment operator.
Definition cpl_string.h:553
CPLStringList & InsertStringDirectly(int nInsertAtLineNo, char *pszNewLine)
Insert into the list at identified location.
Definition cplstringlist.cpp:919
char * operator[](int i)
Return string at specified index.
Definition cplstringlist.cpp:608
char * operator[](size_t i)
Return string at specified index.
Definition cpl_string.h:569
const char * FetchNameValue(const char *pszKey) const
Fetch value associated with this key name.
Definition cplstringlist.cpp:843
int size() const
Return size of list.
Definition cpl_string.h:486
CSLConstList List() const
Return list.
Definition cpl_string.h:620
const char * front() const
Return first element.
Definition cpl_string.h:590
CPLStringList & Clear()
Clear the string list.
Definition cplstringlist.cpp:241
const char *const * begin() const
begin() implementation
Definition cpl_string.h:602
int FindString(const char *pszTarget) const
Return index of pszTarget in the list, or -1.
Definition cpl_string.h:528
const char * back() const
Return last element.
Definition cpl_string.h:596
static const CPLStringList BoundToConstList(CSLConstList papszList)
Return a CPLStringList that wraps the passed list.
Definition cplstringlist.cpp:158
int PartialFindString(const char *pszNeedle) const
Return index of pszTarget in the list (using partial search), or -1.
Definition cpl_string.h:535
CPLStringList & AddString(const char *pszNewString)
Add a string to the list.
Definition cplstringlist.cpp:445
Convenient string class based on std::string.
Definition cpl_string.h:320
void Clear()
Clear the string.
Definition cpl_string.h:377
CPLString(void)
Constructor.
Definition cpl_string.h:323
const char & operator[](std::string::size_type i) const
Return character at specified index.
Definition cpl_string.h:357
CPLString(const std::string &oStr)
Constructor.
Definition cpl_string.h:329
void Seize(char *pszValue)
Assign specified string and take ownership of it (assumed to be allocated with CPLMalloc()).
Definition cpl_string.h:385
char & operator[](int i)
Return character at specified index.
Definition cpl_string.h:363
const char & operator[](int i) const
Return character at specified index.
Definition cpl_string.h:370
char & operator[](std::string::size_type i)
Return character at specified index.
Definition cpl_string.h:351
CPLString(const char *pszStr, size_t n)
Constructor.
Definition cpl_string.h:340
CPLString(const char *pszStr)
Constructor.
Definition cpl_string.h:335
Various convenience functions for CPL.
#define CPLFree
Alias of VSIFree().
Definition cpl_conv.h:90
CPL error handling services.
CPLErr
Error category.
Definition cpl_error.h:37
#define CPL_SCAN_FUNC_FORMAT(format_idx, arg_idx)
Tag a function to have scanf() formatting.
Definition cpl_port.h:846
#define CPL_C_END
Macro to end a block of C symbols.
Definition cpl_port.h:289
#define CPL_C_START
Macro to start a block of C symbols.
Definition cpl_port.h:285
#define CPL_FORMAT_STRING(arg)
Macro into which to wrap the format argument of a printf-like function.
Definition cpl_port.h:860
#define CPL_RETURNS_NONNULL
Qualifier for a function that does not return NULL.
Definition cpl_port.h:908
#define CPL_PRINT_FUNC_FORMAT(format_idx, arg_idx)
Tag a function to have printf() formatting.
Definition cpl_port.h:844
char ** CSLConstList
Type of a constant null-terminated list of nul terminated strings.
Definition cpl_port.h:1087
#define CPL_WARN_UNUSED_RESULT
Qualifier to warn when the return value of a function is not used.
Definition cpl_port.h:870
#define CPL_SCANF_FORMAT_STRING(arg)
Macro into which to wrap the format argument of a sscanf-like function.
Definition cpl_port.h:862
unsigned char GByte
Unsigned byte type.
Definition cpl_port.h:175
long long GIntBig
Large signed integer type (generally 64-bit integer type).
Definition cpl_port.h:205
int CSLFindStringCaseSensitive(CSLConstList papszList, const char *pszTarget)
Find a string within a string list(case sensitive).
Definition cpl_string.cpp:687
int CPLvsnprintf(char *str, size_t size, const char *fmt, va_list args)
vsnprintf() wrapper that is not sensitive to LC_NUMERIC settings.
Definition cpl_string.cpp:1128
char * CPLEscapeString(const char *pszString, int nLength, int nScheme)
Apply escaping to string to preserve special characters.
Definition cpl_string.cpp:2215
char * CPLBinaryToHex(int nBytes, const GByte *pabyData)
Binary to hexadecimal translation.
Definition cpl_string.cpp:2789
std::string CPLRemoveSQLComments(const std::string &osInput)
Remove SQL comments from a string.
Definition cpl_string.cpp:3181
char ** CSLTokenizeStringComplex(const char *pszString, const char *pszDelimiter, int bHonourStrings, int bAllowEmptyTokens)
Obsolete tokenizing api.
Definition cpl_string.cpp:750
int CPLprintf(const char *fmt,...)
sprintf() wrapper that is not sensitive to LC_NUMERIC settings.
Definition cpl_string.cpp:1400
int CPLBase64DecodeInPlace(GByte *pszBase64)
Decode base64 string "pszBase64" (null terminated) in place.
Definition cpl_base64.cpp:90
char ** CSLAddNameValue(char **papszStrList, const char *pszName, const char *pszValue)
Add a new entry to a StringList of "Name=Value" pairs, ("Name:Value" pairs are also supported for bac...
Definition cpl_string.cpp:2016
size_t CPLStrlenUTF8Ex(const char *pszUTF8Str)
Return the number of UTF-8 characters of a nul-terminated string.
Definition cpl_recode.cpp:1198
CPLString CPLQuotedSQLIdentifier(const char *pszIdent)
Return a CPLString of the SQL quoted identifier.
Definition cplstring.cpp:571
CPLString CPLOPrintf(const char *pszFormat,...)
Return a CPLString with the content of sprintf().
Definition cplstring.cpp:539
size_t CPLStrlcat(char *pszDest, const char *pszSrc, size_t nDestSize)
Appends a source string to a destination buffer.
Definition cpl_string.cpp:3080
int CSLPrint(CSLConstList papszStrList, FILE *fpOut)
Print a StringList to fpOut.
Definition cpl_string.cpp:445
char * CPLForceToASCII(const char *pabyData, int nLen, char chReplacementChar)
Return a new string that is made only of ASCII characters.
Definition cpl_recode.cpp:296
char ** CSLTokenizeString2(const char *pszString, const char *pszDelimiter, int nCSLTFlags)
Tokenize a string.
Definition cpl_string.cpp:817
CPLString CPLURLGetValue(const char *pszURL, const char *pszKey)
Return the value matching a key from a key=value pair in a URL.
Definition cplstring.cpp:458
size_t CPLStrlcpy(char *pszDest, const char *pszSrc, size_t nDestSize)
Copy source string to a destination buffer.
Definition cpl_string.cpp:3024
const char * CSLFetchNameValue(CSLConstList papszStrList, const char *pszName)
In a StringList of "Name=Value" pairs, look for the first value associated with the specified name.
Definition cpl_string.cpp:1678
char * CPLRecodeFromWChar(const wchar_t *pwszSource, const char *pszSrcEncoding, const char *pszDstEncoding)
Convert wchar_t string to UTF-8.
Definition cpl_recode.cpp:163
int CPLsnprintf(char *str, size_t size, const char *fmt,...)
snprintf() wrapper that is not sensitive to LC_NUMERIC settings.
Definition cpl_string.cpp:1347
bool CPLIsASCII(const char *pabyData, size_t nLen)
Test if a string is encoded as ASCII.
Definition cpl_recode.cpp:260
CPLValueType
Type of value.
Definition cpl_string.h:171
@ CPL_VALUE_INTEGER
Integer.
Definition cpl_string.h:174
@ CPL_VALUE_STRING
String.
Definition cpl_string.h:172
@ CPL_VALUE_REAL
Real number.
Definition cpl_string.h:173
void CSLDestroy(char **papszStrList)
Free string list.
Definition cpl_string.cpp:185
bool CPLFetchBool(CSLConstList papszStrList, const char *pszKey, bool bDefault)
Check for boolean key value.
Definition cpl_string.cpp:1607
int CSLFindName(CSLConstList papszStrList, const char *pszName)
Find StringList entry with given key name.
Definition cpl_string.cpp:1710
CPLErr CPLParseMemorySize(const char *pszValue, GIntBig *pnValue, bool *pbUnitSpecified)
Parse a memory size from a string.
Definition cpl_string.cpp:1751
const char * CPLParseNameValueSep(const char *pszNameValue, char **ppszKey, char chSep)
Parse NAME<Sep>VALUE string into name and value components.
Definition cpl_string.cpp:1933
int CPLTolower(int c)
Converts a (ASCII) uppercase character to lowercase.
Definition cpl_string.cpp:3167
int CPLCanRecode(const char *pszTestStr, const char *pszSrcEncoding, const char *pszDstEncoding)
Checks if it is possible to recode a string from one encoding to another.
Definition cpl_recode.cpp:1226
const char * CSLGetField(CSLConstList, int)
Fetches the indicated field, being careful not to crash if the field doesn't exist within this string...
Definition cpl_string.cpp:158
int CSLFindString(CSLConstList papszList, const char *pszTarget)
Find a string within a string list (case insensitive).
Definition cpl_string.cpp:654
int CSLSave(CSLConstList papszStrList, const char *pszFname)
Write a StringList to a text file.
Definition cpl_string.cpp:396
bool CPLTestBool(const char *pszValue)
Test what boolean value contained in the string.
Definition cpl_string.cpp:1535
char ** CSLParseCommandLine(const char *pszCommandLine)
Tokenize command line arguments in a list of strings.
Definition cpl_string.cpp:3137
const char * CSLFetchNameValueDef(CSLConstList papszStrList, const char *pszName, const char *pszDefault)
Same as CSLFetchNameValue() but return pszDefault in case of no match.
Definition cpl_string.cpp:1651
int CSLCount(CSLConstList papszStrList)
Return number of items in a string list.
Definition cpl_string.cpp:132
char ** CSLAddString(char **papszStrList, const char *pszNewString)
Append a string to a StringList and return a pointer to the modified StringList.
Definition cpl_string.cpp:68
size_t CPLStrnlen(const char *pszStr, size_t nMaxLen)
Returns the length of a NUL terminated string by reading at most the specified number of bytes.
Definition cpl_string.cpp:3114
char * CPLUTF8ForceToASCII(const char *pszStr, char chReplacementChar)
Return a new string that is made only of ASCII characters.
Definition cpl_recode.cpp:347
char ** CSLInsertString(char **papszStrList, int nInsertAtLineNo, const char *pszNewLine)
Insert a string at a given line number inside a StringList.
Definition cpl_string.cpp:546
void CSLSetNameValueSeparator(char **papszStrList, const char *pszSeparator)
Replace the default separator (":" or "=") with the passed separator in the given name/value list.
Definition cpl_string.cpp:2136
int CPLIsUTF8(const char *pabyData, int nLen)
Test if a string is encoded as UTF-8.
Definition cpl_recode_stub.cpp:500
int CSLPartialFindString(CSLConstList papszHaystack, const char *pszNeedle)
Find a substring within a string list.
Definition cpl_string.cpp:719
char ** CSLTokenizeString(const char *pszString)
Tokenizes a string and returns a StringList with one string for each token.
Definition cpl_string.cpp:740
char ** CSLFetchNameValueMultiple(CSLConstList papszStrList, const char *pszName)
In a StringList of "Name=Value" pairs, look for all the values with the specified name.
Definition cpl_string.cpp:1981
CPLValueType CPLGetValueType(const char *pszValue)
Detect the type of the value contained in a string, whether it is a real, an integer or a string Lead...
Definition cpl_string.cpp:2889
char ** CSLSetNameValue(char **papszStrList, const char *pszName, const char *pszValue)
Assign value to name in StringList.
Definition cpl_string.cpp:2055
char ** CSLRemoveStrings(char **papszStrList, int nFirstLineToDelete, int nNumToRemove, char ***ppapszRetStrings)
Remove strings inside a StringList.
Definition cpl_string.cpp:572
char ** CSLLoad(const char *pszFname)
Load a text file into a string list.
Definition cpl_string.cpp:381
char * CPLRecode(const char *pszSource, const char *pszSrcEncoding, const char *pszDstEncoding)
Convert a string from a source encoding to a destination encoding.
Definition cpl_recode.cpp:79
char ** CSLLoad2(const char *pszFname, int nMaxLines, int nMaxCols, CSLConstList papszOptions)
Load a text file into a string list.
Definition cpl_string.cpp:305
CPLString CPLURLAddKVP(const char *pszURL, const char *pszKey, const char *pszValue)
Return a new URL with a new key=value pair.
Definition cplstring.cpp:490
int CSLFetchBoolean(CSLConstList papszStrList, const char *pszKey, int bDefault)
DEPRECATED.
Definition cpl_string.cpp:1640
int CPLStrlenUTF8(const char *pszUTF8Str)
Return the number of UTF-8 characters of a nul-terminated string.
Definition cpl_recode.cpp:1164
char ** CSLInsertStrings(char **papszStrList, int nInsertAtLineNo, CSLConstList papszNewLines)
Copies the contents of a StringList inside another StringList before the specified line.
Definition cpl_string.cpp:481
CPLString CPLOvPrintf(const char *pszFormat, va_list args)
Return a CPLString with the content of vsprintf().
Definition cplstring.cpp:558
char ** CSLDuplicate(CSLConstList papszStrList)
Clone a string list.
Definition cpl_string.cpp:213
const char * CPLParseNameValue(const char *pszNameValue, char **ppszKey)
Parse NAME=VALUE string into name and value components.
Definition cpl_string.cpp:1886
int CSLTestBoolean(const char *pszValue)
Test what boolean value contained in the string.
Definition cpl_string.cpp:1560
int CPLToupper(int c)
Converts a (ASCII) lowercase character to uppercase.
Definition cpl_string.cpp:3152
GByte * CPLHexToBinary(const char *pszHex, int *pnBytes)
Hexadecimal to binary translation.
Definition cpl_string.cpp:2850
char ** CSLMerge(char **papszOrig, CSLConstList papszOverride)
Merge two lists.
Definition cpl_string.cpp:258
char ** CSLAddStringMayFail(char **papszStrList, const char *pszNewString)
Same as CSLAddString() but may return NULL in case of (memory) failure.
Definition cpl_string.cpp:77
int CPLEncodingCharSize(const char *pszEncoding)
Return bytes per character for encoding.
Definition cpl_recode.cpp:1118
char * CPLUnescapeString(const char *pszString, int *pnLength, int nScheme)
Unescape a string.
Definition cpl_string.cpp:2565
char * CPLBase64Encode(int nBytes, const GByte *pabyData)
Base64 encode a buffer.
Definition cpl_base64.cpp:196
int CPLTestBoolean(const char *pszValue)
Test what boolean value contained in the string.
Definition cpl_string.cpp:1582
wchar_t * CPLRecodeToWChar(const char *pszSource, const char *pszSrcEncoding, const char *pszDstEncoding)
Convert UTF-8 string to a wchar_t string.
Definition cpl_recode.cpp:219
Standard C Covers.
OGRLayer::FeatureIterator begin(OGRLayer *poLayer)
Return begin of feature iterator.
Definition ogrsf_frmts.h:470
OGRLayer::FeatureIterator end(OGRLayer *poLayer)
Return end of feature iterator.
Definition ogrsf_frmts.h:478