[asterisk-dev] [Code Review] 3989: utils: Create ast_strsep function that ignores separators inside quotes.

George Joseph reviewboard at asterisk.org
Thu Sep 11 16:02:03 CDT 2014



> On Sept. 11, 2014, 1:29 p.m., opticron wrote:
> > This new string parsing function could use unit tests.

Good point.  I'll create a test for it.


> On Sept. 11, 2014, 1:29 p.m., opticron wrote:
> > branches/12/main/utils.c, lines 1483-1486
> > <https://reviewboard.asterisk.org/r/3989/diff/1/?file=67308#file67308line1483>
> >
> >     The way this is written, a quoted section could be opened with ' and closed with " or vice-versa. Is that a desired behavior?

Yeah, I knew this going in but I'm not sure if it's worth the extra code to keep track of complex open and close punctuation.   I'll give another look though maybe with some performance comparisons.


- George


-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
https://reviewboard.asterisk.org/r/3989/#review13284
-----------------------------------------------------------


On Sept. 10, 2014, 5:45 p.m., George Joseph wrote:
> 
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> https://reviewboard.asterisk.org/r/3989/
> -----------------------------------------------------------
> 
> (Updated Sept. 10, 2014, 5:45 p.m.)
> 
> 
> Review request for Asterisk Developers and rmudgett.
> 
> 
> Repository: Asterisk
> 
> 
> Description
> -------
> 
> I'm going to need this for my imminent manager and config
> enhancements but I thought I'd post this separately.
> 
> /*!
>   \brief Act like strsep but ignore separators inside quotes.
>   \param s Pointer to address of the the string to be processed.
>   Will be modified and can't be constant.
>   \param sep A single character delimiter.
>   \param flags controls whitespace and quote stripping.
>   \return The next token or NULL if done.
> 
>   This function acts like strsep with three exceptions...
>   The separator is a single character instead of a string.
>   Separators inside quotes are treated literally instead of like separators.
>   You can elect to have leading and trailing whitespace and quotes
>   stripped from the result.
> 
>   Like strsep, ast_strsep maintains no internal state and you can call it
>   recursively using different separators on the same storage.
> 
>   Also like strsep, for consistent results, consecutive separators are not
>   collapsed so you may get an empty string as a valid result.
> 
>   Examples:
>   \code
> 	char *mystr = ast_strdupa("abc=def,ghi='zzz=yyy,456',jkl");
> 	char *token, *token2, *token3;
> 
> 	while((token = ast_strsep(&mystr, ',', AST_SEP_STRIP))) {
> 		// 1st token will be aaa=def
> 		// 2nd token will be ghi='zzz=yyy,456'
> 		while((token2 = ast_strsep(&token, '=', AST_SEP_STRIP))) {
> 			// 1st token2 will be ghi
> 			// 2nd token2 will be zzz=yyy,456
> 			while((token3 = ast_strsep(&token2, ',', AST_SEP_STRIP))) {
> 				// 1st token3 will be zzz=yyy
> 				// 2nd token3 will be 456
> 				// and so on
> 			}
> 		}
> 		// 3rd token will be jkl
> 	}
> 
>   \endcode
>  */
> char *ast_strsep(char **s, const char sep, enum ast_strsep_flags flags);
> 
> 
> Diffs
> -----
> 
>   branches/12/main/utils.c 422963 
>   branches/12/include/asterisk/strings.h 422963 
> 
> Diff: https://reviewboard.asterisk.org/r/3989/diff/
> 
> 
> Testing
> -------
> 
> 
> Thanks,
> 
> George Joseph
> 
>

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.digium.com/pipermail/asterisk-dev/attachments/20140911/bfac309d/attachment.html>


More information about the asterisk-dev mailing list