X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Flibpspp%2Fstr.h;h=86ffddca32b177f828c8ce12eb8828a7ee23538c;hb=d8b3292a8c12564dbc67e59f24d626dcfbf2e274;hp=66552a396486133a7642366152f7d98b72151bf1;hpb=c1a772dd16c825866b0b1b4cfa5c1ba57a9fa48f;p=pspp diff --git a/src/libpspp/str.h b/src/libpspp/str.h index 66552a3964..86ffddca32 100644 --- a/src/libpspp/str.h +++ b/src/libpspp/str.h @@ -29,9 +29,13 @@ #include "memcasecmp.h" #include "xstrndup.h" #include "xvasprintf.h" + +#include "gl/xalloc.h" /* Miscellaneous. */ +struct substring; + void buf_reverse (char *, size_t); int buf_compare_case (const char *, const char *, size_t); int buf_compare_rpad (const char *, size_t, const char *, size_t); @@ -50,6 +54,10 @@ void str_lowercase (char *); bool str_format_26adic (unsigned long int number, bool uppercase, char buffer[], size_t); +void str_ellipsize (struct substring in, char *out, size_t out_size); + +static inline char *xstrdup_if_nonnull (const char *); + void *mempset (void *, int, size_t); /* Common character classes for use with substring and string functions. */ @@ -95,6 +103,7 @@ void ss_dealloc (struct substring *); /* Mutators. Functions that advance the beginning of a string should not be used if a substring is to be deallocated. */ +void ss_swap (struct substring *, struct substring *); void ss_truncate (struct substring *, size_t); size_t ss_rtrim (struct substring *, struct substring trim_set); size_t ss_ltrim (struct substring *, struct substring trim_set); @@ -109,8 +118,9 @@ void ss_advance (struct substring *, size_t); bool ss_match_byte (struct substring *, char); int ss_match_byte_in (struct substring *, struct substring); bool ss_match_string (struct substring *, const struct substring); +bool ss_match_string_case (struct substring *, const struct substring); int ss_get_byte (struct substring *); -size_t ss_get_bytes (struct substring *, size_t cnt, struct substring *); +size_t ss_get_bytes (struct substring *, size_t n, struct substring *); bool ss_get_until (struct substring *, char delimiter, struct substring *); size_t ss_get_long (struct substring *, long *); @@ -141,6 +151,8 @@ int ss_first_mblen (struct substring); ucs4_t ss_get_mb (struct substring *); ucs4_t ss_at_mb (struct substring, size_t ofs); int ss_at_mblen (struct substring, size_t ofs); +size_t ss_utf8_count_columns (struct substring); +struct substring ss_utf8_columns (struct substring, size_t start, size_t n); /* Variable length strings. */ @@ -221,7 +233,7 @@ char *ds_steal_cstr (struct string *); /* File input. */ bool ds_read_line (struct string *, FILE *, size_t max_length); bool ds_read_config_line (struct string *, int *line_number, FILE *); -bool ds_read_stream (struct string *, size_t size, size_t cnt, FILE *stream); +bool ds_read_stream (struct string *, size_t size, size_t n, FILE *stream); /* Append. */ void ds_put_byte (struct string *, int ch); @@ -229,6 +241,7 @@ void ds_put_byte_multiple (struct string *, int ch, size_t); void ds_put_unichar (struct string *, ucs4_t uc); void ds_put_cstr (struct string *, const char *); void ds_put_substring (struct string *, struct substring); +void ds_put_substring_multiple (struct string *, struct substring, size_t n); void ds_put_vformat (struct string *st, const char *, va_list) PRINTF_FORMAT (2, 0); void ds_put_c_vformat (struct string *st, const char *, va_list) @@ -270,15 +283,21 @@ ss_cstr (const char *cstr) return ss_buffer (cstr, strlen (cstr)); } -/* Returns a substring whose contents are the CNT characters in +/* Returns a substring whose contents are the N characters in BUFFER. */ static inline struct substring -ss_buffer (const char *buffer, size_t cnt) +ss_buffer (const char *buffer, size_t n) { struct substring ss; ss.string = (char *) buffer; - ss.length = cnt; + ss.length = n; return ss; } +static inline char * +xstrdup_if_nonnull (const char *s) +{ + return s ? xstrdup (s) : NULL; +} + #endif /* str_h */