Return to CsvStringParse.h CVS log | Up to [Pegasus] / pegasus / src / Clients / cliutils |
File: [Pegasus] / pegasus / src / Clients / cliutils / CsvStringParse.h
(download)
Revision: 1.1, Wed May 30 04:30:42 2012 UTC (12 years, 1 month ago) by ajay.rao Branch: MAIN CVS Tags: preBug9676, postBug9676, TASK-TASK_PEP362_RestfulService_branch-root, TASK-TASK_PEP362_RestfulService_branch-merged_out_from_trunk, TASK-TASK_PEP362_RestfulService_branch-merged_in_to_trunk, TASK-TASK_PEP362_RestfulService_branch-merged_in_from_branch, TASK-TASK_PEP362_RestfulService_branch-branch, TASK-PEP362_RestfulService-root, TASK-PEP362_RestfulService-merged_out_to_branch, TASK-PEP362_RestfulService-merged_out_from_trunk, TASK-PEP362_RestfulService-merged_in_to_trunk, TASK-PEP362_RestfulService-merged_in_from_branch, TASK-PEP362_RestfulService-branch, TASK-PEP317_pullop-merged_out_from_trunk, TASK-PEP317_pullop-merged_in_to_trunk, RELEASE_2_14_1, RELEASE_2_14_0-RC2, RELEASE_2_14_0-RC1, RELEASE_2_14_0, RELEASE_2_14-root, RELEASE_2_14-branch, RELEASE_2_13_0-RC2, RELEASE_2_13_0-RC1, RELEASE_2_13_0-FC, RELEASE_2_13_0, RELEASE_2_13-root, RELEASE_2_13-branch, RELEASE_2_12_1-RC1, RELEASE_2_12_1, RELEASE_2_12_0-RC1, RELEASE_2_12_0-FC, RELEASE_2_12_0, RELEASE_2_12-root, RELEASE_2_12-branch, HEAD, CIMRS_WORK_20130824 Branch point for: TASK-PEP317_pullop-branch BUG#: 9267 TITLE: Moving csvStringParse to a place available to all Clients DESCRIPTION: |
//%LICENSE//////////////////////////////////////////////////////////////// //// //// Licensed to The Open Group (TOG) under one or more contributor license //// agreements. Refer to the OpenPegasusNOTICE.txt file distributed with //// this work for additional information regarding copyright ownership. //// Each contributor licenses this file to you under the OpenPegasus Open //// Source License; you may not use this file except in compliance with the //// License. //// //// Permission is hereby granted, free of charge, to any person obtaining a //// copy of this software and associated documentation files (the "Software"), //// to deal in the Software without restriction, including without limitation //// the rights to use, copy, modify, merge, publish, distribute, sublicense, //// and/or sell copies of the Software, and to permit persons to whom the //// Software is furnished to do so, subject to the following conditions: //// //// The above copyright notice and this permission notice shall be included //// in all copies or substantial portions of the Software. //// //// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS //// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF //// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. //// IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY //// CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, //// TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE //// SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. ///////////////////////////////////////////////////////////////////////////// #ifndef Pegasus_CsvStringParse_h #define Pegasus_CsvStringParse_h #include <Pegasus/Common/Exception.h> #include <Pegasus/Common/String.h> #include <Pegasus/Common/Config.h> #include <Clients/cliutils/Linkage.h> PEGASUS_NAMESPACE_BEGIN /****************************************************************************** Parser for comma-separated-strings (csv). This parser takes into account quoted strings the " character and returns everything within a quoted block in the string in one batch. It also considers the backslash "\" escape character to escape single double quotes. Example: csvStringParse x (inputstring, ','); while (x.more()) rtnString = x.next(); ******************************************************************************/ class PEGASUS_CLIUTILS_LINKAGE csvStringParse { public: /* Define a string to parse for comma separated values and the separation character */ csvStringParse(const String& csvString, const int separator); /* determine if there is more to parse @return true if there is more to parse */ Boolean more(); /* get next string from input. Note that this will continue to return empty strings if you parse past the point where more() returns false. @return String */ String next(); private: enum parsestate {INDQUOTE, INSQUOTE, NOTINQUOTE}; Uint32 _idx; int _separator; Uint32 _end; String _inputString; }; PEGASUS_NAMESPACE_END #endif
No CVS admin address has been configured |
Powered by ViewCVS 0.9.2 |