]> git.saurik.com Git - wxWidgets.git/blame - include/wx/tokenzr.h
don't use a floating point value as a boolean flag; gcc4 (correctly) complains when...
[wxWidgets.git] / include / wx / tokenzr.h
CommitLineData
f4ada568 1/////////////////////////////////////////////////////////////////////////////
7c968cee
VZ
2// Name: wx/tokenzr.h
3// Purpose: String tokenizer - a C++ replacement for strtok(3)
f4ada568 4// Author: Guilhem Lavaux
1e6feb95 5// Modified by: (or rather rewritten by) Vadim Zeitlin
f4ada568
GL
6// Created: 04/22/98
7// RCS-ID: $Id$
8// Copyright: (c) Guilhem Lavaux
65571936 9// Licence: wxWindows licence
f4ada568
GL
10/////////////////////////////////////////////////////////////////////////////
11
12#ifndef _WX_TOKENZRH
13#define _WX_TOKENZRH
14
f4ada568
GL
15#include "wx/object.h"
16#include "wx/string.h"
df5168c4 17#include "wx/arrstr.h"
bbf8fc53 18
7c968cee
VZ
19// ----------------------------------------------------------------------------
20// constants
21// ----------------------------------------------------------------------------
22
bbf8fc53
VZ
23// default: delimiters are usual white space characters
24#define wxDEFAULT_DELIMITERS (_T(" \t\r\n"))
f4ada568 25
7c968cee
VZ
26// wxStringTokenizer mode flags which determine its behaviour
27enum wxStringTokenizerMode
28{
29 wxTOKEN_INVALID = -1, // set by def ctor until SetString() is called
30 wxTOKEN_DEFAULT, // strtok() for whitespace delims, RET_EMPTY else
31 wxTOKEN_RET_EMPTY, // return empty token in the middle of the string
32 wxTOKEN_RET_EMPTY_ALL, // return trailing empty tokens too
33 wxTOKEN_RET_DELIMS, // return the delim with token (implies RET_EMPTY)
34 wxTOKEN_STRTOK // behave exactly like strtok(3)
35};
36
37// ----------------------------------------------------------------------------
38// wxStringTokenizer: replaces infamous strtok() and has some other features
39// ----------------------------------------------------------------------------
40
bddd7a8d 41class WXDLLIMPEXP_BASE wxStringTokenizer : public wxObject
85833f5c 42{
f4ada568 43public:
7c968cee
VZ
44 // ctors and initializers
45 // default ctor, call SetString() later
46 wxStringTokenizer() { m_mode = wxTOKEN_INVALID; }
47 // ctor which gives us the string
48 wxStringTokenizer(const wxString& str,
bbf8fc53 49 const wxString& delims = wxDEFAULT_DELIMITERS,
7c968cee
VZ
50 wxStringTokenizerMode mode = wxTOKEN_DEFAULT);
51
52 // args are same as for the non default ctor above
53 void SetString(const wxString& str,
bbf8fc53 54 const wxString& delims = wxDEFAULT_DELIMITERS,
7c968cee
VZ
55 wxStringTokenizerMode mode = wxTOKEN_DEFAULT);
56
57 // reinitialize the tokenizer with the same delimiters/mode
58 void Reinit(const wxString& str);
85833f5c 59
7c968cee
VZ
60 // tokens access
61 // count them
bbf8fc53 62 size_t CountTokens() const;
7c968cee
VZ
63 // did we reach the end of the string?
64 bool HasMoreTokens() const;
65 // get the next token, will return empty string if !HasMoreTokens()
bbf8fc53 66 wxString GetNextToken();
85833f5c 67
7c968cee
VZ
68 // get current tokenizer state
69 // returns the part of the string which remains to tokenize (*not* the
70 // initial string)
bbf8fc53 71 wxString GetString() const { return m_string; }
85833f5c 72
7c968cee
VZ
73 // returns the current position (i.e. one index after the last
74 // returned token or 0 if GetNextToken() has never been called) in the
75 // original string
bbf8fc53 76 size_t GetPosition() const { return m_pos; }
dbdb39b2 77
7c968cee
VZ
78 // misc
79 // get the current mode - can be different from the one passed to the
80 // ctor if it was wxTOKEN_DEFAULT
81 wxStringTokenizerMode GetMode() const { return m_mode; }
82
83 // backwards compatibility section from now on
84 // -------------------------------------------
85
bbf8fc53
VZ
86 // for compatibility only, use GetNextToken() instead
87 wxString NextToken() { return GetNextToken(); }
85833f5c 88
7c968cee
VZ
89 // compatibility only, don't use
90 void SetString(const wxString& to_tokenize,
91 const wxString& delims,
06b466c7 92 bool WXUNUSED(ret_delim))
7c968cee
VZ
93 {
94 SetString(to_tokenize, delims, wxTOKEN_RET_DELIMS);
95 }
96
97 wxStringTokenizer(const wxString& to_tokenize,
98 const wxString& delims,
99 bool ret_delim)
100 {
101 SetString(to_tokenize, delims, ret_delim);
102 }
103
2224580a 104protected:
7c968cee
VZ
105 bool IsOk() const { return m_mode != wxTOKEN_INVALID; }
106
bbf8fc53
VZ
107 wxString m_string, // the (rest of) string to tokenize
108 m_delims; // all delimiters
109
110 size_t m_pos; // the position in the original string
111
7c968cee
VZ
112 wxStringTokenizerMode m_mode; // see wxTOKEN_XXX values
113
114 bool m_hasMore; // do we have more (possible empty) tokens?
f4ada568
GL
115};
116
1e6feb95
VZ
117// ----------------------------------------------------------------------------
118// convenience function which returns all tokens at once
119// ----------------------------------------------------------------------------
120
121// the function takes the same parameters as wxStringTokenizer ctor and returns
122// the array containing all tokens
bddd7a8d 123wxArrayString WXDLLIMPEXP_BASE
1e6feb95
VZ
124wxStringTokenize(const wxString& str,
125 const wxString& delims = wxDEFAULT_DELIMITERS,
126 wxStringTokenizerMode mode = wxTOKEN_DEFAULT);
127
85833f5c 128#endif // _WX_TOKENZRH