mirror of
https://git.notmuchmail.org/git/notmuch
synced 2024-12-22 17:34:54 +01:00
util: add string-util.[ch]
This is to give a home to strtok_len. It's a bit silly to add a header for one routine, but it needs to be shared between several compilation units (or at least that's the most natural design).
This commit is contained in:
parent
10085656d5
commit
9ff72a83bd
3 changed files with 58 additions and 1 deletions
|
@ -3,7 +3,8 @@
|
|||
dir := util
|
||||
extra_cflags += -I$(srcdir)/$(dir)
|
||||
|
||||
libutil_c_srcs := $(dir)/xutil.c $(dir)/error_util.c $(dir)/hex-escape.c
|
||||
libutil_c_srcs := $(dir)/xutil.c $(dir)/error_util.c $(dir)/hex-escape.c \
|
||||
$(dir)/string-util.c
|
||||
|
||||
libutil_modules := $(libutil_c_srcs:.c=.o)
|
||||
|
||||
|
|
34
util/string-util.c
Normal file
34
util/string-util.c
Normal file
|
@ -0,0 +1,34 @@
|
|||
/* string-util.c - Extra or enhanced routines for null terminated strings.
|
||||
*
|
||||
* Copyright (c) 2012 Jani Nikula
|
||||
*
|
||||
* This program 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.
|
||||
*
|
||||
* This program 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 this program. If not, see http://www.gnu.org/licenses/ .
|
||||
*
|
||||
* Author: Jani Nikula <jani@nikula.org>
|
||||
*/
|
||||
|
||||
|
||||
#include "string-util.h"
|
||||
|
||||
char *
|
||||
strtok_len (char *s, const char *delim, size_t *len)
|
||||
{
|
||||
/* skip initial delims */
|
||||
s += strspn (s, delim);
|
||||
|
||||
/* length of token */
|
||||
*len = strcspn (s, delim);
|
||||
|
||||
return *len ? s : NULL;
|
||||
}
|
22
util/string-util.h
Normal file
22
util/string-util.h
Normal file
|
@ -0,0 +1,22 @@
|
|||
#ifndef _STRING_UTIL_H
|
||||
#define _STRING_UTIL_H
|
||||
|
||||
#include <string.h>
|
||||
|
||||
/* like strtok(3), but without state, and doesn't modify s. Return
|
||||
* value is indicated by pointer and length, not null terminator.
|
||||
*
|
||||
* Usage pattern:
|
||||
*
|
||||
* const char *tok = input;
|
||||
* const char *delim = " \t";
|
||||
* size_t tok_len = 0;
|
||||
*
|
||||
* while ((tok = strtok_len (tok + tok_len, delim, &tok_len)) != NULL) {
|
||||
* // do stuff with string tok of length tok_len
|
||||
* }
|
||||
*/
|
||||
|
||||
char *strtok_len (char *s, const char *delim, size_t *len);
|
||||
|
||||
#endif
|
Loading…
Reference in a new issue