[C] Made string functions internal
This commit is contained in:
parent
dc4eb3761d
commit
00083ee16a
62
lib/fort.c
62
lib/fort.c
@ -291,22 +291,42 @@ struct string_buffer {
|
|||||||
enum str_buf_type type;
|
enum str_buf_type type;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
string_buffer_t *create_string_buffer(size_t number_of_chars, enum str_buf_type type);
|
string_buffer_t *create_string_buffer(size_t number_of_chars, enum str_buf_type type);
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
void destroy_string_buffer(string_buffer_t *buffer);
|
void destroy_string_buffer(string_buffer_t *buffer);
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
fort_status_t realloc_string_buffer_without_copy(string_buffer_t *buffer);
|
fort_status_t realloc_string_buffer_without_copy(string_buffer_t *buffer);
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
fort_status_t fill_buffer_from_string(string_buffer_t *buffer, const char *str);
|
fort_status_t fill_buffer_from_string(string_buffer_t *buffer, const char *str);
|
||||||
|
|
||||||
|
#ifdef FT_HAVE_WCHAR
|
||||||
|
FT_INTERNAL
|
||||||
fort_status_t fill_buffer_from_wstring(string_buffer_t *buffer, const wchar_t *str);
|
fort_status_t fill_buffer_from_wstring(string_buffer_t *buffer, const wchar_t *str);
|
||||||
|
#endif /* FT_HAVE_WCHAR */
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
size_t buffer_text_height(string_buffer_t *buffer);
|
size_t buffer_text_height(string_buffer_t *buffer);
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
size_t string_buffer_capacity(const string_buffer_t *buffer);
|
size_t string_buffer_capacity(const string_buffer_t *buffer);
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
void *buffer_get_data(string_buffer_t *buffer);
|
void *buffer_get_data(string_buffer_t *buffer);
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
size_t buffer_text_width(string_buffer_t *buffer);
|
size_t buffer_text_width(string_buffer_t *buffer);
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
int buffer_printf(string_buffer_t *buffer, size_t buffer_row, char *buf, size_t buf_len, const context_t *context);
|
int buffer_printf(string_buffer_t *buffer, size_t buffer_row, char *buf, size_t buf_len, const context_t *context);
|
||||||
|
|
||||||
|
#ifdef FT_HAVE_WCHAR
|
||||||
|
FT_INTERNAL
|
||||||
int buffer_wprintf(string_buffer_t *buffer, size_t buffer_row, wchar_t *buf, size_t buf_len, const context_t *context);
|
int buffer_wprintf(string_buffer_t *buffer, size_t buffer_row, wchar_t *buf, size_t buf_len, const context_t *context);
|
||||||
|
#endif /* FT_HAVE_WCHAR */
|
||||||
|
|
||||||
#endif /* STRING_BUFFER_H */
|
#endif /* STRING_BUFFER_H */
|
||||||
|
|
||||||
@ -653,7 +673,6 @@ fort_row_t *get_row_and_create_if_not_exists(ft_table_t *table, size_t row);
|
|||||||
FT_INTERNAL
|
FT_INTERNAL
|
||||||
string_buffer_t *get_cur_str_buffer_and_create_if_not_exists(ft_table_t *table);
|
string_buffer_t *get_cur_str_buffer_and_create_if_not_exists(ft_table_t *table);
|
||||||
|
|
||||||
|
|
||||||
FT_INTERNAL
|
FT_INTERNAL
|
||||||
fort_status_t table_rows_and_cols_geometry(const ft_table_t *table,
|
fort_status_t table_rows_and_cols_geometry(const ft_table_t *table,
|
||||||
size_t **col_width_arr_p, size_t *col_width_arr_sz,
|
size_t **col_width_arr_p, size_t *col_width_arr_sz,
|
||||||
@ -2864,6 +2883,8 @@ static size_t buf_str_len(const string_buffer_t *buf)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
size_t strchr_count(const char *str, char ch)
|
size_t strchr_count(const char *str, char ch)
|
||||||
{
|
{
|
||||||
if (str == NULL)
|
if (str == NULL)
|
||||||
@ -2879,6 +2900,8 @@ size_t strchr_count(const char *str, char ch)
|
|||||||
return count;
|
return count;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
size_t wstrchr_count(const wchar_t *str, wchar_t ch)
|
size_t wstrchr_count(const wchar_t *str, wchar_t ch)
|
||||||
{
|
{
|
||||||
if (str == NULL)
|
if (str == NULL)
|
||||||
@ -2894,6 +2917,8 @@ size_t wstrchr_count(const wchar_t *str, wchar_t ch)
|
|||||||
return count;
|
return count;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
const char *str_n_substring_beg(const char *str, char ch_separator, size_t n)
|
const char *str_n_substring_beg(const char *str, char ch_separator, size_t n)
|
||||||
{
|
{
|
||||||
if (str == NULL)
|
if (str == NULL)
|
||||||
@ -2914,6 +2939,8 @@ const char *str_n_substring_beg(const char *str, char ch_separator, size_t n)
|
|||||||
return str ? (str + 1) : NULL;
|
return str ? (str + 1) : NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
const wchar_t *wstr_n_substring_beg(const wchar_t *str, wchar_t ch_separator, size_t n)
|
const wchar_t *wstr_n_substring_beg(const wchar_t *str, wchar_t ch_separator, size_t n)
|
||||||
{
|
{
|
||||||
if (str == NULL)
|
if (str == NULL)
|
||||||
@ -2934,6 +2961,8 @@ const wchar_t *wstr_n_substring_beg(const wchar_t *str, wchar_t ch_separator, si
|
|||||||
return str ? (str + 1) : NULL;
|
return str ? (str + 1) : NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
void str_n_substring(const char *str, char ch_separator, size_t n, const char **begin, const char **end)
|
void str_n_substring(const char *str, char ch_separator, size_t n, const char **begin, const char **end)
|
||||||
{
|
{
|
||||||
const char *beg = str_n_substring_beg(str, ch_separator, n);
|
const char *beg = str_n_substring_beg(str, ch_separator, n);
|
||||||
@ -2953,6 +2982,8 @@ void str_n_substring(const char *str, char ch_separator, size_t n, const char **
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
void wstr_n_substring(const wchar_t *str, wchar_t ch_separator, size_t n, const wchar_t **begin, const wchar_t **end)
|
void wstr_n_substring(const wchar_t *str, wchar_t ch_separator, size_t n, const wchar_t **begin, const wchar_t **end)
|
||||||
{
|
{
|
||||||
const wchar_t *beg = wstr_n_substring_beg(str, ch_separator, n);
|
const wchar_t *beg = wstr_n_substring_beg(str, ch_separator, n);
|
||||||
@ -2973,6 +3004,7 @@ void wstr_n_substring(const wchar_t *str, wchar_t ch_separator, size_t n, const
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
string_buffer_t *create_string_buffer(size_t number_of_chars, enum str_buf_type type)
|
string_buffer_t *create_string_buffer(size_t number_of_chars, enum str_buf_type type)
|
||||||
{
|
{
|
||||||
size_t sz = (number_of_chars) * (type == CharBuf ? sizeof(char) : sizeof(wchar_t));
|
size_t sz = (number_of_chars) * (type == CharBuf ? sizeof(char) : sizeof(wchar_t));
|
||||||
@ -2996,6 +3028,8 @@ string_buffer_t *create_string_buffer(size_t number_of_chars, enum str_buf_type
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
void destroy_string_buffer(string_buffer_t *buffer)
|
void destroy_string_buffer(string_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
if (buffer == NULL)
|
if (buffer == NULL)
|
||||||
@ -3005,6 +3039,8 @@ void destroy_string_buffer(string_buffer_t *buffer)
|
|||||||
F_FREE(buffer);
|
F_FREE(buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
fort_status_t realloc_string_buffer_without_copy(string_buffer_t *buffer)
|
fort_status_t realloc_string_buffer_without_copy(string_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
assert(buffer);
|
assert(buffer);
|
||||||
@ -3018,6 +3054,8 @@ fort_status_t realloc_string_buffer_without_copy(string_buffer_t *buffer)
|
|||||||
return FT_SUCCESS;
|
return FT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
fort_status_t fill_buffer_from_string(string_buffer_t *buffer, const char *str)
|
fort_status_t fill_buffer_from_string(string_buffer_t *buffer, const char *str)
|
||||||
{
|
{
|
||||||
assert(buffer);
|
assert(buffer);
|
||||||
@ -3041,6 +3079,9 @@ fort_status_t fill_buffer_from_string(string_buffer_t *buffer, const char *str)
|
|||||||
return FT_SUCCESS;
|
return FT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef FT_HAVE_WCHAR
|
||||||
|
FT_INTERNAL
|
||||||
fort_status_t fill_buffer_from_wstring(string_buffer_t *buffer, const wchar_t *str)
|
fort_status_t fill_buffer_from_wstring(string_buffer_t *buffer, const wchar_t *str)
|
||||||
{
|
{
|
||||||
assert(buffer);
|
assert(buffer);
|
||||||
@ -3063,9 +3104,10 @@ fort_status_t fill_buffer_from_wstring(string_buffer_t *buffer, const wchar_t *s
|
|||||||
|
|
||||||
return FT_SUCCESS;
|
return FT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
#endif /* FT_HAVE_WCHAR */
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
size_t buffer_text_height(string_buffer_t *buffer)
|
size_t buffer_text_height(string_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
if (buffer == NULL || buffer->str.data == NULL || buf_str_len(buffer) == 0) {
|
if (buffer == NULL || buffer->str.data == NULL || buf_str_len(buffer) == 0) {
|
||||||
@ -3077,6 +3119,8 @@ size_t buffer_text_height(string_buffer_t *buffer)
|
|||||||
return 1 + wstrchr_count(buffer->str.wstr, L'\n');
|
return 1 + wstrchr_count(buffer->str.wstr, L'\n');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
size_t buffer_text_width(string_buffer_t *buffer)
|
size_t buffer_text_width(string_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
size_t max_length = 0;
|
size_t max_length = 0;
|
||||||
@ -3111,7 +3155,7 @@ size_t buffer_text_width(string_buffer_t *buffer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
int buffer_printf(string_buffer_t *buffer, size_t buffer_row, char *buf, size_t buf_len, const context_t *context)
|
int buffer_printf(string_buffer_t *buffer, size_t buffer_row, char *buf, size_t buf_len, const context_t *context)
|
||||||
{
|
{
|
||||||
#define CHAR_TYPE char
|
#define CHAR_TYPE char
|
||||||
@ -3198,6 +3242,8 @@ clear:
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef FT_HAVE_WCHAR
|
||||||
|
FT_INTERNAL
|
||||||
int buffer_wprintf(string_buffer_t *buffer, size_t buffer_row, wchar_t *buf, size_t buf_len, const context_t *context)
|
int buffer_wprintf(string_buffer_t *buffer, size_t buffer_row, wchar_t *buf, size_t buf_len, const context_t *context)
|
||||||
{
|
{
|
||||||
#define CHAR_TYPE wchar_t
|
#define CHAR_TYPE wchar_t
|
||||||
@ -3282,7 +3328,10 @@ clear:
|
|||||||
#undef STR_N_SUBSTRING
|
#undef STR_N_SUBSTRING
|
||||||
#undef STR_ITER_WIDTH
|
#undef STR_ITER_WIDTH
|
||||||
}
|
}
|
||||||
|
#endif /* FT_HAVE_WCHAR */
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
size_t string_buffer_capacity(const string_buffer_t *buffer)
|
size_t string_buffer_capacity(const string_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
assert(buffer);
|
assert(buffer);
|
||||||
@ -3292,13 +3341,14 @@ size_t string_buffer_capacity(const string_buffer_t *buffer)
|
|||||||
return buffer->data_sz / sizeof(wchar_t);
|
return buffer->data_sz / sizeof(wchar_t);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
void *buffer_get_data(string_buffer_t *buffer)
|
void *buffer_get_data(string_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
assert(buffer);
|
assert(buffer);
|
||||||
return buffer->str.data;
|
return buffer->str.data;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/********************************************************
|
/********************************************************
|
||||||
End of file "string_buffer.c"
|
End of file "string_buffer.c"
|
||||||
********************************************************/
|
********************************************************/
|
||||||
|
@ -32,6 +32,8 @@ static size_t buf_str_len(const string_buffer_t *buf)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
size_t strchr_count(const char *str, char ch)
|
size_t strchr_count(const char *str, char ch)
|
||||||
{
|
{
|
||||||
if (str == NULL)
|
if (str == NULL)
|
||||||
@ -47,6 +49,8 @@ size_t strchr_count(const char *str, char ch)
|
|||||||
return count;
|
return count;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
size_t wstrchr_count(const wchar_t *str, wchar_t ch)
|
size_t wstrchr_count(const wchar_t *str, wchar_t ch)
|
||||||
{
|
{
|
||||||
if (str == NULL)
|
if (str == NULL)
|
||||||
@ -62,6 +66,8 @@ size_t wstrchr_count(const wchar_t *str, wchar_t ch)
|
|||||||
return count;
|
return count;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
const char *str_n_substring_beg(const char *str, char ch_separator, size_t n)
|
const char *str_n_substring_beg(const char *str, char ch_separator, size_t n)
|
||||||
{
|
{
|
||||||
if (str == NULL)
|
if (str == NULL)
|
||||||
@ -82,6 +88,8 @@ const char *str_n_substring_beg(const char *str, char ch_separator, size_t n)
|
|||||||
return str ? (str + 1) : NULL;
|
return str ? (str + 1) : NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
const wchar_t *wstr_n_substring_beg(const wchar_t *str, wchar_t ch_separator, size_t n)
|
const wchar_t *wstr_n_substring_beg(const wchar_t *str, wchar_t ch_separator, size_t n)
|
||||||
{
|
{
|
||||||
if (str == NULL)
|
if (str == NULL)
|
||||||
@ -102,6 +110,8 @@ const wchar_t *wstr_n_substring_beg(const wchar_t *str, wchar_t ch_separator, si
|
|||||||
return str ? (str + 1) : NULL;
|
return str ? (str + 1) : NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
void str_n_substring(const char *str, char ch_separator, size_t n, const char **begin, const char **end)
|
void str_n_substring(const char *str, char ch_separator, size_t n, const char **begin, const char **end)
|
||||||
{
|
{
|
||||||
const char *beg = str_n_substring_beg(str, ch_separator, n);
|
const char *beg = str_n_substring_beg(str, ch_separator, n);
|
||||||
@ -121,6 +131,8 @@ void str_n_substring(const char *str, char ch_separator, size_t n, const char **
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
void wstr_n_substring(const wchar_t *str, wchar_t ch_separator, size_t n, const wchar_t **begin, const wchar_t **end)
|
void wstr_n_substring(const wchar_t *str, wchar_t ch_separator, size_t n, const wchar_t **begin, const wchar_t **end)
|
||||||
{
|
{
|
||||||
const wchar_t *beg = wstr_n_substring_beg(str, ch_separator, n);
|
const wchar_t *beg = wstr_n_substring_beg(str, ch_separator, n);
|
||||||
@ -141,6 +153,7 @@ void wstr_n_substring(const wchar_t *str, wchar_t ch_separator, size_t n, const
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
string_buffer_t *create_string_buffer(size_t number_of_chars, enum str_buf_type type)
|
string_buffer_t *create_string_buffer(size_t number_of_chars, enum str_buf_type type)
|
||||||
{
|
{
|
||||||
size_t sz = (number_of_chars) * (type == CharBuf ? sizeof(char) : sizeof(wchar_t));
|
size_t sz = (number_of_chars) * (type == CharBuf ? sizeof(char) : sizeof(wchar_t));
|
||||||
@ -164,6 +177,8 @@ string_buffer_t *create_string_buffer(size_t number_of_chars, enum str_buf_type
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
void destroy_string_buffer(string_buffer_t *buffer)
|
void destroy_string_buffer(string_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
if (buffer == NULL)
|
if (buffer == NULL)
|
||||||
@ -173,6 +188,8 @@ void destroy_string_buffer(string_buffer_t *buffer)
|
|||||||
F_FREE(buffer);
|
F_FREE(buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
fort_status_t realloc_string_buffer_without_copy(string_buffer_t *buffer)
|
fort_status_t realloc_string_buffer_without_copy(string_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
assert(buffer);
|
assert(buffer);
|
||||||
@ -186,6 +203,8 @@ fort_status_t realloc_string_buffer_without_copy(string_buffer_t *buffer)
|
|||||||
return FT_SUCCESS;
|
return FT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
fort_status_t fill_buffer_from_string(string_buffer_t *buffer, const char *str)
|
fort_status_t fill_buffer_from_string(string_buffer_t *buffer, const char *str)
|
||||||
{
|
{
|
||||||
assert(buffer);
|
assert(buffer);
|
||||||
@ -209,6 +228,9 @@ fort_status_t fill_buffer_from_string(string_buffer_t *buffer, const char *str)
|
|||||||
return FT_SUCCESS;
|
return FT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef FT_HAVE_WCHAR
|
||||||
|
FT_INTERNAL
|
||||||
fort_status_t fill_buffer_from_wstring(string_buffer_t *buffer, const wchar_t *str)
|
fort_status_t fill_buffer_from_wstring(string_buffer_t *buffer, const wchar_t *str)
|
||||||
{
|
{
|
||||||
assert(buffer);
|
assert(buffer);
|
||||||
@ -231,9 +253,10 @@ fort_status_t fill_buffer_from_wstring(string_buffer_t *buffer, const wchar_t *s
|
|||||||
|
|
||||||
return FT_SUCCESS;
|
return FT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
#endif /* FT_HAVE_WCHAR */
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
size_t buffer_text_height(string_buffer_t *buffer)
|
size_t buffer_text_height(string_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
if (buffer == NULL || buffer->str.data == NULL || buf_str_len(buffer) == 0) {
|
if (buffer == NULL || buffer->str.data == NULL || buf_str_len(buffer) == 0) {
|
||||||
@ -245,6 +268,8 @@ size_t buffer_text_height(string_buffer_t *buffer)
|
|||||||
return 1 + wstrchr_count(buffer->str.wstr, L'\n');
|
return 1 + wstrchr_count(buffer->str.wstr, L'\n');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
size_t buffer_text_width(string_buffer_t *buffer)
|
size_t buffer_text_width(string_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
size_t max_length = 0;
|
size_t max_length = 0;
|
||||||
@ -279,7 +304,7 @@ size_t buffer_text_width(string_buffer_t *buffer)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
int buffer_printf(string_buffer_t *buffer, size_t buffer_row, char *buf, size_t buf_len, const context_t *context)
|
int buffer_printf(string_buffer_t *buffer, size_t buffer_row, char *buf, size_t buf_len, const context_t *context)
|
||||||
{
|
{
|
||||||
#define CHAR_TYPE char
|
#define CHAR_TYPE char
|
||||||
@ -366,6 +391,8 @@ clear:
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef FT_HAVE_WCHAR
|
||||||
|
FT_INTERNAL
|
||||||
int buffer_wprintf(string_buffer_t *buffer, size_t buffer_row, wchar_t *buf, size_t buf_len, const context_t *context)
|
int buffer_wprintf(string_buffer_t *buffer, size_t buffer_row, wchar_t *buf, size_t buf_len, const context_t *context)
|
||||||
{
|
{
|
||||||
#define CHAR_TYPE wchar_t
|
#define CHAR_TYPE wchar_t
|
||||||
@ -450,7 +477,10 @@ clear:
|
|||||||
#undef STR_N_SUBSTRING
|
#undef STR_N_SUBSTRING
|
||||||
#undef STR_ITER_WIDTH
|
#undef STR_ITER_WIDTH
|
||||||
}
|
}
|
||||||
|
#endif /* FT_HAVE_WCHAR */
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
size_t string_buffer_capacity(const string_buffer_t *buffer)
|
size_t string_buffer_capacity(const string_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
assert(buffer);
|
assert(buffer);
|
||||||
@ -460,9 +490,10 @@ size_t string_buffer_capacity(const string_buffer_t *buffer)
|
|||||||
return buffer->data_sz / sizeof(wchar_t);
|
return buffer->data_sz / sizeof(wchar_t);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
void *buffer_get_data(string_buffer_t *buffer)
|
void *buffer_get_data(string_buffer_t *buffer)
|
||||||
{
|
{
|
||||||
assert(buffer);
|
assert(buffer);
|
||||||
return buffer->str.data;
|
return buffer->str.data;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -22,21 +22,41 @@ struct string_buffer {
|
|||||||
enum str_buf_type type;
|
enum str_buf_type type;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
string_buffer_t *create_string_buffer(size_t number_of_chars, enum str_buf_type type);
|
string_buffer_t *create_string_buffer(size_t number_of_chars, enum str_buf_type type);
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
void destroy_string_buffer(string_buffer_t *buffer);
|
void destroy_string_buffer(string_buffer_t *buffer);
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
fort_status_t realloc_string_buffer_without_copy(string_buffer_t *buffer);
|
fort_status_t realloc_string_buffer_without_copy(string_buffer_t *buffer);
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
fort_status_t fill_buffer_from_string(string_buffer_t *buffer, const char *str);
|
fort_status_t fill_buffer_from_string(string_buffer_t *buffer, const char *str);
|
||||||
|
|
||||||
|
#ifdef FT_HAVE_WCHAR
|
||||||
|
FT_INTERNAL
|
||||||
fort_status_t fill_buffer_from_wstring(string_buffer_t *buffer, const wchar_t *str);
|
fort_status_t fill_buffer_from_wstring(string_buffer_t *buffer, const wchar_t *str);
|
||||||
|
#endif /* FT_HAVE_WCHAR */
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
size_t buffer_text_height(string_buffer_t *buffer);
|
size_t buffer_text_height(string_buffer_t *buffer);
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
size_t string_buffer_capacity(const string_buffer_t *buffer);
|
size_t string_buffer_capacity(const string_buffer_t *buffer);
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
void *buffer_get_data(string_buffer_t *buffer);
|
void *buffer_get_data(string_buffer_t *buffer);
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
size_t buffer_text_width(string_buffer_t *buffer);
|
size_t buffer_text_width(string_buffer_t *buffer);
|
||||||
|
|
||||||
|
FT_INTERNAL
|
||||||
int buffer_printf(string_buffer_t *buffer, size_t buffer_row, char *buf, size_t buf_len, const context_t *context);
|
int buffer_printf(string_buffer_t *buffer, size_t buffer_row, char *buf, size_t buf_len, const context_t *context);
|
||||||
|
|
||||||
|
#ifdef FT_HAVE_WCHAR
|
||||||
|
FT_INTERNAL
|
||||||
int buffer_wprintf(string_buffer_t *buffer, size_t buffer_row, wchar_t *buf, size_t buf_len, const context_t *context);
|
int buffer_wprintf(string_buffer_t *buffer, size_t buffer_row, wchar_t *buf, size_t buf_len, const context_t *context);
|
||||||
|
#endif /* FT_HAVE_WCHAR */
|
||||||
|
|
||||||
#endif /* STRING_BUFFER_H */
|
#endif /* STRING_BUFFER_H */
|
||||||
|
@ -33,7 +33,6 @@ fort_row_t *get_row_and_create_if_not_exists(ft_table_t *table, size_t row);
|
|||||||
FT_INTERNAL
|
FT_INTERNAL
|
||||||
string_buffer_t *get_cur_str_buffer_and_create_if_not_exists(ft_table_t *table);
|
string_buffer_t *get_cur_str_buffer_and_create_if_not_exists(ft_table_t *table);
|
||||||
|
|
||||||
|
|
||||||
FT_INTERNAL
|
FT_INTERNAL
|
||||||
fort_status_t table_rows_and_cols_geometry(const ft_table_t *table,
|
fort_status_t table_rows_and_cols_geometry(const ft_table_t *table,
|
||||||
size_t **col_width_arr_p, size_t *col_width_arr_sz,
|
size_t **col_width_arr_p, size_t *col_width_arr_sz,
|
||||||
|
Loading…
Reference in New Issue
Block a user