Moved string library functions to .c instead of inlined, because they're not that small.

pull/13171/head
Joshua Haberman 15 years ago
parent 3f0d126b2a
commit ab0f2b8bba
  1. 47
      src/upb_data.c
  2. 56
      src/upb_data.h

@ -97,6 +97,11 @@ void upb_string_resize(upb_string *s, upb_strlen_t byte_len) {
s->common.byte_len = byte_len; s->common.byte_len = byte_len;
} }
upb_string *upb_string_getref(upb_string *s, int ref_flags) {
if(_upb_data_incref(&s->common.base, ref_flags)) return s;
return upb_strdup(s);
}
upb_string *upb_strreadfile(const char *filename) { upb_string *upb_strreadfile(const char *filename) {
FILE *f = fopen(filename, "rb"); FILE *f = fopen(filename, "rb");
if(!f) return false; if(!f) return false;
@ -115,6 +120,48 @@ error:
return NULL; return NULL;
} }
upb_string *upb_strdupc(const char *src) {
upb_string *copy = upb_string_new();
upb_strlen_t len = strlen(src);
char *buf = upb_string_getrwbuf(copy, len);
memcpy(buf, src, len);
return copy;
}
void upb_strcat(upb_string *s, upb_string *append) {
upb_strlen_t s_len = upb_strlen(s);
upb_strlen_t append_len = upb_strlen(append);
upb_strlen_t newlen = s_len + append_len;
memcpy(upb_string_getrwbuf(s, newlen) + s_len,
upb_string_getrobuf(append), append_len);
}
void upb_strcpy(upb_string *dest, upb_string *src) {
upb_strlen_t src_len = upb_strlen(src);
memcpy(upb_string_getrwbuf(dest, src_len), upb_string_getrobuf(src), src_len);
}
upb_string *upb_strslice(upb_string *s, int offset, int len) {
upb_string *slice = upb_string_new();
len = UPB_MIN((upb_strlen_t)len, upb_strlen(s) - (upb_strlen_t)offset);
memcpy(upb_string_getrwbuf(slice, len), upb_string_getrobuf(s) + offset, len);
return slice;
}
upb_string *upb_strdup(upb_string *s) {
upb_string *copy = upb_string_new();
upb_strcpy(copy, s);
return copy;
}
int upb_strcmp(upb_string *s1, upb_string *s2) {
upb_strlen_t common_length = UPB_MIN(upb_strlen(s1), upb_strlen(s2));
int common_diff = memcmp(upb_string_getrobuf(s1), upb_string_getrobuf(s2),
common_length);
return common_diff ==
0 ? ((int)upb_strlen(s1) - (int)upb_strlen(s2)) : common_diff;
}
/* upb_array ******************************************************************/ /* upb_array ******************************************************************/

@ -206,11 +206,6 @@ union upb_string {
// Caller owns one ref on it. The returned string will not be frozen. // Caller owns one ref on it. The returned string will not be frozen.
upb_string *upb_string_new(void); upb_string *upb_string_new(void);
// Creates a new string which is a duplicate of the given string. If
// refcounted is true, the new string is refcounted, otherwise the caller
// has exlusive ownership of it.
INLINE upb_string *upb_strdup(upb_string *s);
// INTERNAL-ONLY: // INTERNAL-ONLY:
// Frees the given string, alone with any memory the string owned. // Frees the given string, alone with any memory the string owned.
void _upb_string_free(upb_string *s); void _upb_string_free(upb_string *s);
@ -218,10 +213,7 @@ void _upb_string_free(upb_string *s);
// Returns a string to which caller owns a ref, and contains the same contents // Returns a string to which caller owns a ref, and contains the same contents
// as src. The returned value may be a copy of src, if the requested flags // as src. The returned value may be a copy of src, if the requested flags
// were incompatible with src's. // were incompatible with src's.
INLINE upb_string *upb_string_getref(upb_string *s, int ref_flags) { upb_string *upb_string_getref(upb_string *s, int ref_flags);
if(_upb_data_incref(&s->common.base, ref_flags)) return s;
return upb_strdup(s);
}
// The caller releases a ref on src, which it must previously have owned a ref // The caller releases a ref on src, which it must previously have owned a ref
// on. // on.
@ -270,52 +262,26 @@ INLINE bool upb_streql(upb_string *s1, upb_string *s2) {
} }
} }
INLINE int upb_strcmp(upb_string *s1, upb_string *s2) { // Like strcmp().
upb_strlen_t common_length = UPB_MIN(upb_strlen(s1), upb_strlen(s2)); int upb_strcmp(upb_string *s1, upb_string *s2);
int common_diff = memcmp(upb_string_getrobuf(s1), upb_string_getrobuf(s2),
common_length);
return common_diff ==
0 ? ((int)upb_strlen(s1) - (int)upb_strlen(s2)) : common_diff;
}
INLINE void upb_strcpy(upb_string *dest, upb_string *src) { // Replaces the contents of "dest" with the contents of "src".
upb_strlen_t src_len = upb_strlen(src); void upb_strcpy(upb_string *dest, upb_string *src);
memcpy(upb_string_getrwbuf(dest, src_len), upb_string_getrobuf(src), src_len);
}
INLINE upb_string *upb_strdup(upb_string *s) { // Returns a new string whose contents are a copy of s.
upb_string *copy = upb_string_new(); upb_string *upb_strdup(upb_string *s);
upb_strcpy(copy, s);
return copy;
}
INLINE upb_string *upb_strdupc(const char *src) { // Like upb_strdup(), but duplicates a C NULL-terminated string.
upb_string *copy = upb_string_new(); upb_string *upb_strdupc(const char *src);
upb_strlen_t len = strlen(src);
char *buf = upb_string_getrwbuf(copy, len);
memcpy(buf, src, len);
return copy;
}
// Appends 'append' to 's' in-place, resizing s if necessary. // Appends 'append' to 's' in-place, resizing s if necessary.
INLINE void upb_strcat(upb_string *s, upb_string *append) { void upb_strcat(upb_string *s, upb_string *append);
upb_strlen_t s_len = upb_strlen(s);
upb_strlen_t append_len = upb_strlen(append);
upb_strlen_t newlen = s_len + append_len;
memcpy(upb_string_getrwbuf(s, newlen) + s_len,
upb_string_getrobuf(append), append_len);
}
// Returns a string that is a substring of the given string. Currently this // Returns a string that is a substring of the given string. Currently this
// returns a copy, but in the future this may return an object that references // returns a copy, but in the future this may return an object that references
// the original string data instead of copying it. Both now and in the future, // the original string data instead of copying it. Both now and in the future,
// the caller owns a ref on whatever is returned. // the caller owns a ref on whatever is returned.
INLINE upb_string *upb_strslice(upb_string *s, int offset, int len) { upb_string *upb_strslice(upb_string *s, int offset, int len);
upb_string *slice = upb_string_new();
len = UPB_MIN((upb_strlen_t)len, upb_strlen(s) - (upb_strlen_t)offset);
memcpy(upb_string_getrwbuf(slice, len), upb_string_getrobuf(s) + offset, len);
return slice;
}
// Reads an entire file into a newly-allocated string (caller owns one ref). // Reads an entire file into a newly-allocated string (caller owns one ref).
upb_string *upb_strreadfile(const char *filename); upb_string *upb_strreadfile(const char *filename);

Loading…
Cancel
Save