2018-01-21 09:19:18 +01:00
# include "tests.h"
# include "string_buffer.h"
2019-05-24 20:25:33 +02:00
# include "wcwidth.h"
2018-05-06 13:11:03 +02:00
# include <wchar.h>
2019-08-14 21:01:57 +02:00
# if defined(FT_HAVE_UTF8)
# include "utf8.h"
# endif
2018-01-21 09:19:18 +01:00
2018-03-31 12:33:37 +02:00
size_t strchr_count ( const char * str , char ch ) ;
size_t wstrchr_count ( const wchar_t * str , wchar_t ch ) ;
2019-08-14 21:01:57 +02:00
# if defined(FT_HAVE_UTF8)
size_t utf8chr_count ( const void * str , utf8_int32_t ch ) ;
# endif
2018-03-05 19:08:14 +01:00
2018-03-31 12:33:37 +02:00
const char * str_n_substring_beg ( const char * str , char ch_separator , size_t n ) ;
const wchar_t * wstr_n_substring_beg ( const wchar_t * str , wchar_t ch_separator , size_t n ) ;
2019-08-14 21:01:57 +02:00
# ifdef FT_HAVE_UTF8
const void * utf8_n_substring_beg ( const void * str , utf8_int32_t ch_separator , size_t n ) ;
# endif
2018-03-05 19:08:14 +01:00
2018-03-31 12:33:37 +02:00
fort_status_t str_n_substring ( const char * str , char ch_separator , size_t n , const char * * begin , const char * * end ) ;
void wstr_n_substring ( const wchar_t * str , wchar_t ch_separator , size_t n , const wchar_t * * begin , const wchar_t * * end ) ;
2019-08-14 21:01:57 +02:00
# ifdef FT_HAVE_UTF8
void utf8_n_substring ( const void * str , utf8_int32_t ch_separator , size_t n , const void * * begin , const void * * end ) ;
# endif
2018-03-05 19:08:14 +01:00
2018-01-21 09:19:18 +01:00
void test_strchr_count ( void ) ;
void test_str_n_substring ( void ) ;
2019-08-14 21:01:57 +02:00
void test_buffer_text_visible_width ( void ) ;
void test_buffer_text_visible_height ( void ) ;
2019-05-24 20:25:33 +02:00
# if defined(FT_HAVE_WCHAR)
void test_wchar_basics ( void ) ;
# endif
2019-08-14 21:01:57 +02:00
void test_print_n_strings ( void ) ;
2018-01-21 09:19:18 +01:00
2018-03-19 21:07:18 +01:00
void test_string_buffer ( void )
2018-01-21 09:19:18 +01:00
{
test_strchr_count ( ) ;
test_str_n_substring ( ) ;
2019-08-14 21:01:57 +02:00
test_buffer_text_visible_width ( ) ;
test_buffer_text_visible_height ( ) ;
2019-05-24 20:25:33 +02:00
# if defined(FT_HAVE_WCHAR)
test_wchar_basics ( ) ;
# endif
2019-08-14 21:01:57 +02:00
test_print_n_strings ( ) ;
2018-01-21 09:19:18 +01:00
}
void test_strchr_count ( void )
{
assert_true ( strchr_count ( NULL , ' \n ' ) = = 0 ) ;
assert_true ( strchr_count ( " " , ' \n ' ) = = 0 ) ;
assert_true ( strchr_count ( " asbd " , ' \n ' ) = = 0 ) ;
assert_true ( strchr_count ( " asbd \n " , ' \n ' ) = = 1 ) ;
assert_true ( strchr_count ( " \n asbd " , ' \n ' ) = = 1 ) ;
assert_true ( strchr_count ( " a \n sbd " , ' \n ' ) = = 1 ) ;
assert_true ( strchr_count ( " \n 12 \n 123 " , ' \n ' ) = = 2 ) ;
assert_true ( strchr_count ( " \n 12 \n 123 \n " , ' \n ' ) = = 3 ) ;
assert_true ( strchr_count ( " \n \n \n " , ' \n ' ) = = 3 ) ;
assert_true ( strchr_count ( " \n 123123 \n 123123 \n \n \n 123 " , ' \n ' ) = = 5 ) ;
assert_true ( strchr_count ( " 1a23123a123123aaa123 " , ' a ' ) = = 5 ) ;
2018-03-05 19:08:14 +01:00
assert_true ( wstrchr_count ( NULL , L ' \n ' ) = = 0 ) ;
assert_true ( wstrchr_count ( L " " , L ' \n ' ) = = 0 ) ;
assert_true ( wstrchr_count ( L " asbd " , L ' \n ' ) = = 0 ) ;
assert_true ( wstrchr_count ( L " asbd \n " , L ' \n ' ) = = 1 ) ;
assert_true ( wstrchr_count ( L " \n asbd " , L ' \n ' ) = = 1 ) ;
assert_true ( wstrchr_count ( L " a \n sbd " , L ' \n ' ) = = 1 ) ;
assert_true ( wstrchr_count ( L " \n 12 \n 123 " , L ' \n ' ) = = 2 ) ;
assert_true ( wstrchr_count ( L " \n 12 \n 123 \n " , L ' \n ' ) = = 3 ) ;
assert_true ( wstrchr_count ( L " \n \n \n " , ' \n ' ) = = 3 ) ;
assert_true ( wstrchr_count ( L " \n 123123 \n 123123 \n \n \n 123 " , L ' \n ' ) = = 5 ) ;
assert_true ( wstrchr_count ( L " 1 \xffff y23123 \xffff y123123 \xffff y \xffff y \xffff y123 " , L ' \ xffff ' ) = = 5 ) ;
2019-08-14 21:01:57 +02:00
# ifdef FT_HAVE_UTF8
assert_true ( utf8chr_count ( NULL , ' \n ' ) = = 0 ) ;
assert_true ( utf8chr_count ( " " , ' \n ' ) = = 0 ) ;
assert_true ( utf8chr_count ( " asbd " , ' \n ' ) = = 0 ) ;
assert_true ( utf8chr_count ( " Chinese L視野無限廣, 窗外有藍天 " , ' \n ' ) = = 0 ) ;
assert_true ( utf8chr_count ( " Hindi ऋषियों को सताने वाले दुष्ट राक्षसों के राजा रावण का सर्वनाश करने वाले विष्णुवतार भगवान श्रीराम, अयोध्या के महाराज दशरथ के बड़े सपुत्र थे। " , ' \n ' ) = = 0 ) ;
assert_true ( utf8chr_count ( " Portuguese Luís argüia à Júlia que «brações, fé, chá, óxido, pôr, zângão» eram palavras do português. " , ' \n ' ) = = 0 ) ;
assert_true ( utf8chr_count ( " Russian В чащах юга жил бы цитрус? Да, но фальшивый экземпляръ! " , ' \n ' ) = = 0 ) ;
assert_true ( utf8chr_count ( " Spanish La niña, viéndose atrapada en el áspero baúl índigo y sintiendo asfixia, lloró de vergüenza; mientras que la frustrada madre llamaba a su hija diciendo: ¿Dónde estás Waleska? " , ' \n ' ) = = 0 ) ;
assert_true ( utf8chr_count ( " asbd \n " , ' \n ' ) = = 1 ) ;
assert_true ( utf8chr_count ( " \n asbd " , ' \n ' ) = = 1 ) ;
assert_true ( utf8chr_count ( " a \n sbd " , ' \n ' ) = = 1 ) ;
assert_true ( utf8chr_count ( " Chinese L視野無限 \n 廣,窗外有藍天 " , ' \n ' ) = = 1 ) ;
assert_true ( utf8chr_count ( " Hindi ऋषियों को सताने वा \n ले दुष्ट राक्षसों के राजा रावण का सर्वनाश करने वाले विष्णुवतार भगवान श्रीराम, अयोध्या के महाराज दशरथ के बड़े सपुत्र थे। " , ' \n ' ) = = 1 ) ;
assert_true ( utf8chr_count ( " Portuguese Luís argüi \n a à Júlia que «brações, fé, chá, óxido, pôr, zângão» eram palavras do português. " , ' \n ' ) = = 1 ) ;
assert_true ( utf8chr_count ( " Russian В чащах \n юга жил бы цитрус? Да, но фальшивый экземпляръ! " , ' \n ' ) = = 1 ) ;
assert_true ( utf8chr_count ( " Spanish La niña, vié \n ndose atrapada en el áspero baúl índigo y sintiendo asfixia, lloró de vergüenza; mientras que la frustrada madre llamaba a su hija diciendo: ¿Dónde estás Waleska? " , ' \n ' ) = = 1 ) ;
assert_true ( utf8chr_count ( " \n 12 \n 123 " , ' \n ' ) = = 2 ) ;
assert_true ( utf8chr_count ( " \n 12 \n 123 \n " , ' \n ' ) = = 3 ) ;
assert_true ( utf8chr_count ( " \n \n \n " , ' \n ' ) = = 3 ) ;
assert_true ( utf8chr_count ( " \n 123123 \n 123123 \n \n \n 123 " , ' \n ' ) = = 5 ) ;
assert_true ( utf8chr_count ( " Chinese L視野無限 \n 廣,窗外有 \n 藍天 " , ' \n ' ) = = 2 ) ;
assert_true ( utf8chr_count ( " Hindi ऋषियों को सताने वा \n ले दुष्ट राक्षसों के राजा \n रावण का सर्वना \n श करने वाले विष्णुवतार भगवान श्रीराम, अयोध्या के महाराज दशरथ के बड़े सपुत्र थे। " , ' \n ' ) = = 3 ) ;
assert_true ( utf8chr_count ( " Portuguese Luís argüi \n a à Júlia que «brações, fé, chá, óxido, \n pôr, zângão» eram pal \n avras do portu \n guês. " , ' \n ' ) = = 4 ) ;
assert_true ( utf8chr_count ( " Russian В чащах \n юга жил бы ц \n итрус? Да, но фальшивый экземпляръ! " , ' \n ' ) = = 2 ) ;
assert_true ( utf8chr_count ( " Spanish La niña, vié \n ndose atrapada en el \n \n \n áspero baúl índigo y \n sintiendo asfixia, lloró de vergüenza; mientras que la frustrada madre llamaba a su hija diciendo: ¿Dónde estás Waleska? " , ' \n ' ) = = 5 ) ;
assert_true ( utf8chr_count ( " 1a23123a123123aaa123 " , ' a ' ) = = 5 ) ;
# endif
}
void assert_str_equal_strong ( const char * str1 , const char * str2 ,
const char * file ,
int line ,
const char * function )
{
if ( ! str1 & & ! str2 )
return ;
if ( ( str1 & & ! str2 ) | | ( ! str1 & & str2 ) ) {
fprintf ( stderr , " %s:%d(%s):Abort! Not equals strings: \n " , file , line , function ) ;
exit ( EXIT_FAILURE ) ;
} else if ( strcmp ( str1 , str2 ) ! = 0 ) {
fprintf ( stderr , " %s:%d(%s):Abort! Not equals strings: \n " , file , line , function ) ;
exit ( EXIT_FAILURE ) ;
}
2018-01-21 09:19:18 +01:00
}
2019-08-14 21:01:57 +02:00
# define ASSERT_STR_EQUAL_STRONG(str1, str2) assert_str_equal_strong(str1, str2, __FILE__,__LINE__, __func__)
2018-01-21 09:19:18 +01:00
void test_str_n_substring ( void )
{
const char * empty_str = " " ;
assert_true ( str_n_substring_beg ( empty_str , ' \n ' , 0 ) = = empty_str ) ;
assert_true ( str_n_substring_beg ( empty_str , ' \n ' , 1 ) = = NULL ) ;
assert_true ( str_n_substring_beg ( empty_str , ' \n ' , 2 ) = = NULL ) ;
2018-11-16 19:27:25 +01:00
# if defined(FT_HAVE_WCHAR)
2018-03-05 19:08:14 +01:00
const wchar_t * empty_wstr = L " " ;
assert_true ( wstr_n_substring_beg ( empty_wstr , L ' \n ' , 0 ) = = empty_wstr ) ;
assert_true ( wstr_n_substring_beg ( empty_wstr , L ' \n ' , 1 ) = = NULL ) ;
assert_true ( wstr_n_substring_beg ( empty_wstr , L ' \n ' , 2 ) = = NULL ) ;
2018-11-16 19:27:25 +01:00
# endif
2019-08-14 21:01:57 +02:00
# ifdef FT_HAVE_UTF8
const char * utf8_empty_str = " " ;
assert_true ( utf8_n_substring_beg ( utf8_empty_str , ' \n ' , 0 ) = = utf8_empty_str ) ;
assert_true ( utf8_n_substring_beg ( utf8_empty_str , ' \n ' , 1 ) = = NULL ) ;
assert_true ( utf8_n_substring_beg ( utf8_empty_str , ' \n ' , 2 ) = = NULL ) ;
# endif
2018-03-05 19:08:14 +01:00
2018-01-21 09:19:18 +01:00
const char * str = " 123 \n 5678 \n 9 " ;
assert_true ( str_n_substring_beg ( NULL , ' \n ' , 0 ) = = NULL ) ;
assert_true ( str_n_substring_beg ( str , ' \n ' , 0 ) = = str ) ;
assert_true ( str_n_substring_beg ( str , ' 1 ' , 0 ) = = str ) ;
assert_true ( str_n_substring_beg ( str , ' \n ' , 1 ) = = str + 4 ) ;
assert_true ( str_n_substring_beg ( str , ' \n ' , 2 ) = = str + 9 ) ;
assert_true ( str_n_substring_beg ( str , ' \n ' , 3 ) = = NULL ) ;
2018-11-16 19:27:25 +01:00
# if defined(FT_HAVE_WCHAR)
2018-03-05 19:08:14 +01:00
const wchar_t * wstr = L " 123 \n 5678 \n 9 " ;
assert_true ( wstr_n_substring_beg ( NULL , L ' \n ' , 0 ) = = NULL ) ;
assert_true ( wstr_n_substring_beg ( wstr , L ' \n ' , 0 ) = = wstr ) ;
assert_true ( wstr_n_substring_beg ( wstr , L ' 1 ' , 0 ) = = wstr ) ;
assert_true ( wstr_n_substring_beg ( wstr , L ' \n ' , 1 ) = = wstr + 4 ) ;
assert_true ( wstr_n_substring_beg ( wstr , L ' \n ' , 2 ) = = wstr + 9 ) ;
assert_true ( wstr_n_substring_beg ( wstr , L ' \n ' , 3 ) = = NULL ) ;
2018-11-16 19:27:25 +01:00
# endif
2019-08-14 21:01:57 +02:00
# ifdef FT_HAVE_UTF8
const char * utf8_str = " 123 \n 5678 \n 9 " ;
ASSERT_STR_EQUAL_STRONG ( utf8_n_substring_beg ( NULL , ' \n ' , 0 ) , NULL ) ;
ASSERT_STR_EQUAL_STRONG ( utf8_n_substring_beg ( utf8_str , ' \n ' , 0 ) , utf8_str ) ;
ASSERT_STR_EQUAL_STRONG ( utf8_n_substring_beg ( utf8_str , ' 1 ' , 0 ) , utf8_str ) ;
ASSERT_STR_EQUAL_STRONG ( utf8_n_substring_beg ( utf8_str , ' \n ' , 1 ) , " 5678 \n 9 " ) ;
ASSERT_STR_EQUAL_STRONG ( utf8_n_substring_beg ( utf8_str , ' \n ' , 2 ) , " 9 " ) ;
ASSERT_STR_EQUAL_STRONG ( utf8_n_substring_beg ( utf8_str , ' \n ' , 3 ) , NULL ) ;
# endif
2018-03-05 19:08:14 +01:00
2018-01-21 09:19:18 +01:00
const char * str2 = " \n 123 \n 56 \n \n 9 \n " ;
assert_true ( str_n_substring_beg ( str2 , ' \n ' , 0 ) = = str2 ) ;
assert_true ( str_n_substring_beg ( str2 , ' \n ' , 1 ) = = str2 + 1 ) ;
assert_true ( str_n_substring_beg ( str2 , ' \n ' , 2 ) = = str2 + 5 ) ;
assert_true ( str_n_substring_beg ( str2 , ' \n ' , 3 ) = = str2 + 8 ) ;
assert_true ( str_n_substring_beg ( str2 , ' \n ' , 4 ) = = str2 + 9 ) ;
assert_true ( str_n_substring_beg ( str2 , ' \n ' , 5 ) = = str2 + 11 ) ;
assert_true ( str_n_substring_beg ( str2 , ' \n ' , 6 ) = = NULL ) ;
2018-11-16 19:27:25 +01:00
# if defined(FT_HAVE_WCHAR)
2018-03-05 19:08:14 +01:00
const wchar_t * wstr2 = L " \xff0f y23 \xff0f y6 \xff0f \xff0f y \xff0f " ;
assert_true ( wstr_n_substring_beg ( wstr2 , L ' \ xff0f ' , 0 ) = = wstr2 ) ;
assert_true ( wstr_n_substring_beg ( wstr2 , L ' \ xff0f ' , 1 ) = = wstr2 + 1 ) ;
assert_true ( wstr_n_substring_beg ( wstr2 , L ' \ xff0f ' , 2 ) = = wstr2 + 5 ) ;
assert_true ( wstr_n_substring_beg ( wstr2 , L ' \ xff0f ' , 3 ) = = wstr2 + 8 ) ;
assert_true ( wstr_n_substring_beg ( wstr2 , L ' \ xff0f ' , 4 ) = = wstr2 + 9 ) ;
assert_true ( wstr_n_substring_beg ( wstr2 , L ' \ xff0f ' , 5 ) = = wstr2 + 11 ) ;
assert_true ( wstr_n_substring_beg ( wstr2 , L ' \ xff0f ' , 6 ) = = NULL ) ;
2018-11-16 19:27:25 +01:00
# endif
2019-08-14 21:01:57 +02:00
# ifdef FT_HAVE_UTF8
const char * utf8_str2 = " \n 123 \n 56 \n \n 9 \n " ;
ASSERT_STR_EQUAL_STRONG ( utf8_n_substring_beg ( utf8_str2 , ' \n ' , 0 ) , utf8_str2 ) ;
ASSERT_STR_EQUAL_STRONG ( utf8_n_substring_beg ( utf8_str2 , ' \n ' , 1 ) , " 123 \n 56 \n \n 9 \n " ) ;
ASSERT_STR_EQUAL_STRONG ( utf8_n_substring_beg ( utf8_str2 , ' \n ' , 2 ) , " 56 \n \n 9 \n " ) ;
ASSERT_STR_EQUAL_STRONG ( utf8_n_substring_beg ( utf8_str2 , ' \n ' , 3 ) , " \n 9 \n " ) ;
ASSERT_STR_EQUAL_STRONG ( utf8_n_substring_beg ( utf8_str2 , ' \n ' , 4 ) , " 9 \n " ) ;
ASSERT_STR_EQUAL_STRONG ( utf8_n_substring_beg ( utf8_str2 , ' \n ' , 5 ) , " " ) ;
ASSERT_STR_EQUAL_STRONG ( utf8_n_substring_beg ( utf8_str2 , ' \n ' , 6 ) , NULL ) ;
# endif
2018-03-05 19:08:14 +01:00
2018-01-21 09:19:18 +01:00
const char * beg = NULL ;
const char * end = NULL ;
str_n_substring ( empty_str , ' \n ' , 0 , & beg , & end ) ;
assert_true ( beg = = empty_str & & end = = empty_str + strlen ( empty_str ) ) ;
str_n_substring ( empty_str , ' \n ' , 1 , & beg , & end ) ;
assert_true ( beg = = NULL & & end = = NULL ) ;
str_n_substring ( empty_str , ' \n ' , 2 , & beg , & end ) ;
assert_true ( beg = = NULL & & end = = NULL ) ;
2018-11-16 19:27:25 +01:00
# if defined(FT_HAVE_WCHAR)
2018-03-05 19:08:14 +01:00
const wchar_t * wbeg = NULL ;
const wchar_t * wend = NULL ;
wstr_n_substring ( empty_wstr , L ' \n ' , 0 , & wbeg , & wend ) ;
assert_true ( wbeg = = empty_wstr & & wend = = empty_wstr + wcslen ( empty_wstr ) ) ;
wstr_n_substring ( empty_wstr , L ' \n ' , 1 , & wbeg , & wend ) ;
assert_true ( wbeg = = NULL & & wend = = NULL ) ;
wstr_n_substring ( empty_wstr , L ' \n ' , 2 , & wbeg , & wend ) ;
assert_true ( wbeg = = NULL & & wend = = NULL ) ;
2018-11-16 19:27:25 +01:00
# endif
2019-08-14 21:01:57 +02:00
# ifdef FT_HAVE_UTF8
const void * utf8_beg = NULL ;
const void * utf8_end = NULL ;
utf8_n_substring ( utf8_empty_str , ' \n ' , 0 , & utf8_beg , & utf8_end ) ;
assert_true ( utf8_beg = = utf8_empty_str & & utf8_end = = utf8_empty_str + strlen ( utf8_empty_str ) ) ;
utf8_n_substring ( utf8_empty_str , ' \n ' , 1 , & utf8_beg , & utf8_end ) ;
assert_true ( utf8_beg = = NULL & & utf8_end = = NULL ) ;
utf8_n_substring ( utf8_empty_str , ' \n ' , 2 , & utf8_beg , & utf8_end ) ;
assert_true ( utf8_beg = = NULL & & utf8_end = = NULL ) ;
# endif
2018-11-16 19:27:25 +01:00
2018-03-05 19:08:14 +01:00
2018-01-21 09:19:18 +01:00
str_n_substring ( NULL , ' \n ' , 0 , & beg , & end ) ;
assert_true ( beg = = NULL & & end = = NULL ) ;
str_n_substring ( str , ' \n ' , 0 , & beg , & end ) ;
assert_true ( beg = = str & & end = = str + 3 ) ;
str_n_substring ( str , ' 2 ' , 0 , & beg , & end ) ;
assert_true ( beg = = str & & end = = str + 1 ) ;
2018-11-16 19:27:25 +01:00
# if defined(FT_HAVE_WCHAR)
2018-03-05 19:08:14 +01:00
wstr_n_substring ( NULL , L ' \n ' , 0 , & wbeg , & wend ) ;
assert_true ( wbeg = = NULL & & wend = = NULL ) ;
wstr_n_substring ( wstr , L ' \n ' , 0 , & wbeg , & wend ) ;
assert_true ( wbeg = = wstr & & wend = = wstr + 3 ) ;
wstr_n_substring ( wstr , L ' 2 ' , 0 , & wbeg , & wend ) ;
assert_true ( wbeg = = wstr & & wend = = wstr + 1 ) ;
2018-11-16 19:27:25 +01:00
# endif
2019-08-14 21:01:57 +02:00
# ifdef FT_HAVE_UTF8
utf8_n_substring ( NULL , ' \n ' , 0 , & utf8_beg , & utf8_end ) ;
assert_true ( utf8_beg = = NULL & & utf8_end = = NULL ) ;
utf8_n_substring ( utf8_str , ' \n ' , 0 , & utf8_beg , & utf8_end ) ;
assert_true ( utf8_beg = = utf8_str & & utf8_end = = utf8_str + 3 ) ;
utf8_n_substring ( utf8_str , ' 2 ' , 0 , & utf8_beg , & utf8_end ) ;
assert_true ( utf8_beg = = utf8_str & & utf8_end = = utf8_str + 1 ) ;
# endif
2018-03-05 19:08:14 +01:00
2018-01-21 09:19:18 +01:00
str_n_substring ( str , ' \n ' , 1 , & beg , & end ) ;
2018-03-31 12:33:37 +02:00
assert_true ( beg = = str + 4 & & end = = str + 8 ) ;
2018-01-21 09:19:18 +01:00
str_n_substring ( str , ' \n ' , 2 , & beg , & end ) ;
assert_true ( beg = = str + 9 & & end = = str + strlen ( str ) ) ;
str_n_substring ( str , ' \n ' , 3 , & beg , & end ) ;
assert_true ( beg = = NULL & & end = = NULL ) ;
2018-11-16 19:27:25 +01:00
# if defined(FT_HAVE_WCHAR)
2018-03-05 19:08:14 +01:00
wstr_n_substring ( wstr , L ' \n ' , 1 , & wbeg , & wend ) ;
2018-03-31 12:33:37 +02:00
assert_true ( wbeg = = wstr + 4 & & wend = = wstr + 8 ) ;
2018-03-05 19:08:14 +01:00
wstr_n_substring ( wstr , L ' \n ' , 2 , & wbeg , & wend ) ;
assert_true ( wbeg = = wstr + 9 & & wend = = wstr + wcslen ( wstr ) ) ;
wstr_n_substring ( wstr , L ' \n ' , 3 , & wbeg , & wend ) ;
assert_true ( wbeg = = NULL & & wend = = NULL ) ;
2018-11-16 19:27:25 +01:00
# endif
2019-08-14 21:01:57 +02:00
# ifdef FT_HAVE_UTF8
utf8_n_substring ( utf8_str , ' \n ' , 1 , & utf8_beg , & utf8_end ) ;
assert_true ( utf8_beg = = utf8_str + 4 & & utf8_end = = utf8_str + 8 ) ;
utf8_n_substring ( utf8_str , ' \n ' , 2 , & utf8_beg , & utf8_end ) ;
assert_true ( utf8_beg = = utf8_str + 9 & & utf8_end = = utf8_str + strlen ( utf8_str ) ) ;
utf8_n_substring ( utf8_str , ' \n ' , 3 , & utf8_beg , & utf8_end ) ;
assert_true ( utf8_beg = = NULL & & end = = NULL ) ;
# endif
2018-01-21 09:19:18 +01:00
str_n_substring ( str2 , ' \n ' , 0 , & beg , & end ) ;
assert_true ( beg = = str2 & & end = = str2 ) ;
str_n_substring ( str2 , ' \n ' , 1 , & beg , & end ) ;
assert_true ( beg = = str2 + 1 & & end = = str2 + 4 ) ;
str_n_substring ( str2 , ' \n ' , 2 , & beg , & end ) ;
assert_true ( beg = = str2 + 5 & & end = = str2 + 7 ) ;
str_n_substring ( str2 , ' \n ' , 3 , & beg , & end ) ;
assert_true ( beg = = str2 + 8 & & end = = str2 + 8 ) ;
str_n_substring ( str2 , ' \n ' , 4 , & beg , & end ) ;
assert_true ( beg = = str2 + 9 & & end = = str2 + 10 ) ;
str_n_substring ( str2 , ' \n ' , 5 , & beg , & end ) ;
assert_true ( beg = = str2 + 11 & & end = = str2 + 11 ) ;
str_n_substring ( str2 , ' \n ' , 6 , & beg , & end ) ;
assert_true ( beg = = NULL & & end = = NULL ) ;
2018-03-05 19:08:14 +01:00
2018-11-16 19:27:25 +01:00
# if defined(FT_HAVE_WCHAR)
2018-03-05 19:08:14 +01:00
wstr_n_substring ( wstr2 , L ' \ xff0f ' , 0 , & wbeg , & wend ) ;
assert_true ( wbeg = = wstr2 & & wend = = wstr2 ) ;
wstr_n_substring ( wstr2 , L ' \ xff0f ' , 1 , & wbeg , & wend ) ;
assert_true ( wbeg = = wstr2 + 1 & & wend = = wstr2 + 4 ) ;
wstr_n_substring ( wstr2 , L ' \ xff0f ' , 2 , & wbeg , & wend ) ;
assert_true ( wbeg = = wstr2 + 5 & & wend = = wstr2 + 7 ) ;
wstr_n_substring ( wstr2 , L ' \ xff0f ' , 3 , & wbeg , & wend ) ;
assert_true ( wbeg = = wstr2 + 8 & & wend = = wstr2 + 8 ) ;
wstr_n_substring ( wstr2 , L ' \ xff0f ' , 4 , & wbeg , & wend ) ;
assert_true ( wbeg = = wstr2 + 9 & & wend = = wstr2 + 10 ) ;
wstr_n_substring ( wstr2 , L ' \ xff0f ' , 5 , & wbeg , & wend ) ;
assert_true ( wbeg = = wstr2 + 11 & & wend = = wstr2 + 11 ) ;
wstr_n_substring ( wstr2 , L ' \ xff0f ' , 6 , & wbeg , & wend ) ;
assert_true ( wbeg = = NULL & & wend = = NULL ) ;
2018-11-16 19:27:25 +01:00
# endif
2019-08-14 21:01:57 +02:00
# if defined(FT_HAVE_WCHAR)
utf8_n_substring ( utf8_str2 , ' \n ' , 0 , & utf8_beg , & utf8_end ) ;
assert_true ( utf8_beg = = utf8_str2 & & utf8_end = = utf8_str2 ) ;
utf8_n_substring ( utf8_str2 , ' \n ' , 1 , & utf8_beg , & utf8_end ) ;
assert_true ( utf8_beg = = utf8_str2 + 1 & & utf8_end = = utf8_str2 + 4 ) ;
utf8_n_substring ( utf8_str2 , ' \n ' , 2 , & utf8_beg , & utf8_end ) ;
assert_true ( utf8_beg = = utf8_str2 + 5 & & utf8_end = = utf8_str2 + 7 ) ;
utf8_n_substring ( utf8_str2 , ' \n ' , 3 , & utf8_beg , & utf8_end ) ;
assert_true ( utf8_beg = = utf8_str2 + 8 & & utf8_end = = utf8_str2 + 8 ) ;
utf8_n_substring ( utf8_str2 , ' \n ' , 4 , & utf8_beg , & utf8_end ) ;
assert_true ( utf8_beg = = utf8_str2 + 9 & & utf8_end = = utf8_str2 + 10 ) ;
utf8_n_substring ( utf8_str2 , ' \n ' , 5 , & utf8_beg , & utf8_end ) ;
assert_true ( utf8_beg = = utf8_str2 + 11 & & utf8_end = = utf8_str2 + 11 ) ;
utf8_n_substring ( utf8_str2 , ' \n ' , 6 , & utf8_beg , & utf8_end ) ;
assert_true ( utf8_beg = = NULL & & utf8_end = = NULL ) ;
# endif
2018-01-21 09:19:18 +01:00
}
2019-08-14 21:01:57 +02:00
void test_buffer_text_visible_width ( void )
2018-01-21 09:19:18 +01:00
{
2019-08-14 21:01:57 +02:00
string_buffer_t * buffer = create_string_buffer ( 200 , CHAR_BUF ) ;
buffer - > type = CHAR_BUF ;
2018-03-17 19:53:38 +01:00
char * old_value = buffer - > str . cstr ;
2018-03-05 19:08:14 +01:00
2018-03-31 12:33:37 +02:00
buffer - > str . cstr = ( char * ) " " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_width ( buffer ) = = 0 ) ;
2018-03-05 19:08:14 +01:00
2018-03-31 12:33:37 +02:00
buffer - > str . cstr = ( char * ) " \n \n \n \n " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_width ( buffer ) = = 0 ) ;
2018-03-05 19:08:14 +01:00
2018-03-31 12:33:37 +02:00
buffer - > str . cstr = ( char * ) " 12345 " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_width ( buffer ) = = 5 ) ;
2018-03-05 19:08:14 +01:00
2018-03-31 12:33:37 +02:00
buffer - > str . cstr = ( char * ) " 12345 \n 1234567 " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_width ( buffer ) = = 7 ) ;
2018-03-05 19:08:14 +01:00
2018-03-31 12:33:37 +02:00
buffer - > str . cstr = ( char * ) " 12345 \n 1234567 \n " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_width ( buffer ) = = 7 ) ;
2018-03-05 19:08:14 +01:00
2018-03-31 12:33:37 +02:00
buffer - > str . cstr = ( char * ) " 12345 \n 1234567 \n 123 " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_width ( buffer ) = = 7 ) ;
2018-03-05 19:08:14 +01:00
2018-11-16 19:27:25 +01:00
# if defined(FT_HAVE_WCHAR)
2019-08-14 21:01:57 +02:00
buffer - > type = W_CHAR_BUF ;
2018-03-05 19:08:14 +01:00
2018-03-18 10:17:33 +01:00
buffer - > str . wstr = ( wchar_t * ) L " " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_width ( buffer ) = = 0 ) ;
2018-01-21 09:19:18 +01:00
2018-03-18 10:17:33 +01:00
buffer - > str . wstr = ( wchar_t * ) L " \n \n \n \n " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_width ( buffer ) = = 0 ) ;
2018-01-21 09:19:18 +01:00
2018-03-18 10:17:33 +01:00
buffer - > str . wstr = ( wchar_t * ) L " 12345 " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_width ( buffer ) = = 5 ) ;
2018-01-21 09:19:18 +01:00
2018-03-18 10:17:33 +01:00
buffer - > str . wstr = ( wchar_t * ) L " 12345 \n 1234567 " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_width ( buffer ) = = 7 ) ;
2018-01-21 09:19:18 +01:00
2018-03-18 10:17:33 +01:00
buffer - > str . wstr = ( wchar_t * ) L " 12345 \n 1234567 \n " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_width ( buffer ) = = 7 ) ;
2018-01-21 09:19:18 +01:00
2018-03-18 10:17:33 +01:00
buffer - > str . wstr = ( wchar_t * ) L " 12345 \n 1234567 \n 123 " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_width ( buffer ) = = 7 ) ;
# endif
# if defined(FT_HAVE_UTF8)
buffer - > type = UTF8_BUF ;
buffer - > str . u8str = ( void * ) " " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 0 ) ;
buffer - > str . u8str = ( void * ) " \n \n \n \n " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 0 ) ;
buffer - > str . u8str = ( void * ) " 12345 " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 5 ) ;
buffer - > str . u8str = ( void * ) " 12345 \n 1234567 " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 7 ) ;
buffer - > str . u8str = ( void * ) " 12345 \n 1234567 \n " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 7 ) ;
buffer - > str . u8str = ( void * ) " 12345 \n 1234567 \n 123 " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 7 ) ;
/* panagrams from http://clagnut.com/blog/2380/ */
/* 10 20 30 40 50 60 70 80 90 100 110 */
buffer - > str . u8str = ( void * ) " Numbers 01234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890 " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 110 ) ;
buffer - > str . u8str = ( void * ) " Chinese 視野無限廣, 窗外有藍天 " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 22 ) ;
buffer - > str . u8str = ( void * ) " German Falsches Üben von Xylophonmusik quält jeden größeren Zwerg " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 68 ) ;
buffer - > str . u8str = ( void * ) " Greek Ταχίστη αλώπηξ βαφής ψημένη γη, δρασκελίζει υπέρ νωθρού κυνός Takhístè " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 80 ) ;
buffer - > str . u8str = ( void * ) " Irish D’ ḟuascail Íosa Úrṁac na hÓiġe Beannaiṫe pór Éaḃa agus Áḋaiṁ " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 70 ) ;
buffer - > str . u8str = ( void * ) " Japanese いろはにほへと ちりぬるを わかよたれそ つねならむ うゐ " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 39 ) ;
buffer - > str . u8str = ( void * ) " Polish Pójdźże, kiń tę chmurność w głąb flaszy " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 49 ) ;
buffer - > str . u8str = ( void * ) " Portuguese Luís argüia à Júlia que «brações, fé, chá, óxido, pôr, zângão» eram palavras do português " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 100 ) ;
buffer - > str . u8str = ( void * ) " Russian Съешь же ещё этих мягких французских булок, да выпей чаю " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 66 ) ;
buffer - > str . u8str = ( void * ) " Spanish Benjamín pidió una bebida de kiwi y fresa; Noé, sin vergüenza, la más exquisita champaña del menú " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 107 ) ;
buffer - > str . u8str = ( void * ) " Turkish Vakfı n çoğu bu huysuz genci plajda görmüştü " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 53 ) ;
/* 10 20 30 40 50 60 70 80 90 100 110 */
buffer - > str . u8str = ( void * ) " Numbers 01234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890 " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 110 ) ;
buffer - > str . u8str = ( void * ) " Chinese 視野無限廣, \n 窗外有藍天 " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 16 ) ;
buffer - > str . u8str = ( void * ) " German Falsches Üben von Xy \n lophonmusik quält \n jeden größeren Zwerg " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 30 ) ;
buffer - > str . u8str = ( void * ) " Greek Ταχίστη αλώπηξ βαφής \n ψημένη γη, δρασκελίζει \n υπέρ νωθρού \n κυνός Takhístè " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 30 ) ;
buffer - > str . u8str = ( void * ) " Irish D’ ḟuascail Íosa Úrṁa \n c na hÓiġe Beannaiṫe \n pór Éaḃa agus Áḋaiṁ " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 30 ) ;
buffer - > str . u8str = ( void * ) " Japanese いろはにほへと ちり \n ぬるを わかよたれそ つねならむ うゐ " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 20 ) ;
buffer - > str . u8str = ( void * ) " Polish Pójdźże, kiń tę chmu \n rność w głąb flaszy " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 30 ) ;
buffer - > str . u8str = ( void * ) " Portuguese Luís argüia à Júlia \n que «brações, fé, chá, \n óxido, pôr, \n zângão» eram palavras \n do português " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 30 ) ;
buffer - > str . u8str = ( void * ) " Russian Съешь же ещё этих мя \n гких французских булок, \n да выпей чаю " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 30 ) ;
buffer - > str . u8str = ( void * ) " Spanish Benjamín pidió una b \n ebida de kiwi y fresa; \n Noé, sin vergüenza, \n la más exquisita \n champaña del menú " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 30 ) ;
buffer - > str . u8str = ( void * ) " Turkish Vakfı n çoğu bu huysu \n z genci plajda gö \n rmüştü " ;
assert_true ( buffer_text_visible_width ( buffer ) = = 30 ) ;
2018-11-16 19:27:25 +01:00
# endif
2018-03-05 19:08:14 +01:00
2019-08-14 21:01:57 +02:00
buffer - > type = CHAR_BUF ;
2018-03-17 19:53:38 +01:00
buffer - > str . cstr = old_value ;
2018-01-21 09:19:18 +01:00
destroy_string_buffer ( buffer ) ;
}
2019-08-14 21:01:57 +02:00
void test_buffer_text_visible_height ( void )
2018-01-21 09:19:18 +01:00
{
2019-08-14 21:01:57 +02:00
string_buffer_t * buffer = create_string_buffer ( 200 , CHAR_BUF ) ;
buffer - > type = CHAR_BUF ;
2018-03-17 19:53:38 +01:00
char * old_value = buffer - > str . cstr ;
2018-01-21 09:19:18 +01:00
2018-03-31 12:33:37 +02:00
buffer - > str . cstr = ( char * ) " " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_height ( buffer ) = = 0 ) ;
2018-01-21 09:19:18 +01:00
2018-03-31 12:33:37 +02:00
buffer - > str . cstr = ( char * ) " \n " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_height ( buffer ) = = 2 ) ;
2018-01-21 09:19:18 +01:00
2018-03-31 12:33:37 +02:00
buffer - > str . cstr = ( char * ) " \n \n " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_height ( buffer ) = = 3 ) ;
2018-01-21 09:19:18 +01:00
2018-03-31 12:33:37 +02:00
buffer - > str . cstr = ( char * ) " \n \n \n \n " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_height ( buffer ) = = 5 ) ;
2018-01-21 09:19:18 +01:00
2018-03-31 12:33:37 +02:00
buffer - > str . cstr = ( char * ) " 12345 " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_height ( buffer ) = = 1 ) ;
2018-01-21 09:19:18 +01:00
2018-03-31 12:33:37 +02:00
buffer - > str . cstr = ( char * ) " \n 12345 " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_height ( buffer ) = = 2 ) ;
2018-01-21 09:19:18 +01:00
2018-03-31 12:33:37 +02:00
buffer - > str . cstr = ( char * ) " \n 12345 \n \n 2 " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_height ( buffer ) = = 4 ) ;
2018-01-21 09:19:18 +01:00
2018-11-16 19:27:25 +01:00
# if defined(FT_HAVE_WCHAR)
2019-08-14 21:01:57 +02:00
buffer - > type = W_CHAR_BUF ;
2018-03-18 10:17:33 +01:00
buffer - > str . wstr = ( wchar_t * ) L " " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_height ( buffer ) = = 0 ) ;
2018-03-05 19:08:14 +01:00
2018-03-18 10:17:33 +01:00
buffer - > str . wstr = ( wchar_t * ) L " \n " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_height ( buffer ) = = 2 ) ;
2018-03-05 19:08:14 +01:00
2018-03-18 10:17:33 +01:00
buffer - > str . wstr = ( wchar_t * ) L " \n \n " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_height ( buffer ) = = 3 ) ;
2018-03-05 19:08:14 +01:00
2018-03-18 10:17:33 +01:00
buffer - > str . wstr = ( wchar_t * ) L " \n \n \n \n " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_height ( buffer ) = = 5 ) ;
2018-03-05 19:08:14 +01:00
2018-03-18 10:17:33 +01:00
buffer - > str . wstr = ( wchar_t * ) L " \xff0f y2345 \xff0f " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_height ( buffer ) = = 1 ) ;
2018-03-05 19:08:14 +01:00
2018-03-18 10:17:33 +01:00
buffer - > str . wstr = ( wchar_t * ) L " \n 12345 " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_height ( buffer ) = = 2 ) ;
2018-03-05 19:08:14 +01:00
2018-03-18 10:17:33 +01:00
buffer - > str . wstr = ( wchar_t * ) L " \n 12345 \n \n 2 " ;
2019-08-14 21:01:57 +02:00
assert_true ( buffer_text_visible_height ( buffer ) = = 4 ) ;
2018-11-16 19:27:25 +01:00
# endif
2019-08-14 21:01:57 +02:00
# if defined(FT_HAVE_UTF8)
buffer - > type = UTF8_BUF ;
buffer - > str . u8str = ( void * ) " " ;
assert_true ( buffer_text_visible_height ( buffer ) = = 0 ) ;
buffer - > str . u8str = ( void * ) " \n " ;
assert_true ( buffer_text_visible_height ( buffer ) = = 2 ) ;
buffer - > str . u8str = ( void * ) " \n \n " ;
assert_true ( buffer_text_visible_height ( buffer ) = = 3 ) ;
buffer - > str . u8str = ( void * ) " \n \n \n \n " ;
assert_true ( buffer_text_visible_height ( buffer ) = = 5 ) ;
2018-03-05 19:08:14 +01:00
2019-08-14 21:01:57 +02:00
buffer - > str . u8str = ( void * ) " 12345 " ;
assert_true ( buffer_text_visible_height ( buffer ) = = 1 ) ;
2018-03-05 19:08:14 +01:00
2019-08-14 21:01:57 +02:00
buffer - > str . u8str = ( void * ) " \n 12345 " ;
assert_true ( buffer_text_visible_height ( buffer ) = = 2 ) ;
buffer - > str . u8str = ( void * ) " \n 12345 \n \n 2 " ;
assert_true ( buffer_text_visible_height ( buffer ) = = 4 ) ;
# endif
buffer - > type = CHAR_BUF ;
2018-03-17 19:53:38 +01:00
buffer - > str . cstr = old_value ;
2018-01-21 09:19:18 +01:00
destroy_string_buffer ( buffer ) ;
}
2019-05-24 20:25:33 +02:00
# if defined(FT_HAVE_WCHAR)
void test_wchar_basics ( void )
{
# if !defined(FT_MICROSOFT_COMPILER)
assert_true ( mk_wcswidth ( L " " , 0 ) = = 0 ) ;
assert_true ( mk_wcswidth ( L " 1 " , 0 ) = = 0 ) ;
assert_true ( mk_wcswidth ( L " 1 " , 1 ) = = 1 ) ;
assert_true ( mk_wcswidth ( L " λ " , 1 ) = = 1 ) ; // Greek
assert_true ( mk_wcswidth ( L " ऋ " , 1 ) = = 1 ) ; // Hindi
assert_true ( mk_wcswidth ( L " ź " , 1 ) = = 1 ) ; // Polish
assert_true ( mk_wcswidth ( L " ü " , 1 ) = = 1 ) ; // Portuguese
assert_true ( mk_wcswidth ( L " ц " , 1 ) = = 1 ) ; // Russian
assert_true ( mk_wcswidth ( L " ñ " , 1 ) = = 1 ) ; // Spanish
assert_true ( mk_wcswidth ( L " ğ " , 1 ) = = 1 ) ; // Turkish
assert_true ( mk_wcswidth ( L " ФЦУЙъхЭЯЧьЮЪЁ " , 13 ) = = 13 ) ;
assert_true ( mk_wcswidth ( L " ФЦУЙъхЭЯЧьЮЪЁ " , 14 ) = = 13 ) ;
assert_true ( mk_wcswidth ( L " ФЦУЙъхЭЯЧьЮЪЁ " , 10 ) = = 10 ) ;
/* panagrams from http://clagnut.com/blog/2380/ */
const wchar_t * str = NULL ;
/* 10 20 30 40 50 60 70 80 90 100 110 */
str = L " Numbers 01234567890123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890 " ;
assert_true ( mk_wcswidth ( str , 500 ) = = 110 ) ;
str = L " German Falsches Üben von Xylophonmusik quält jeden größeren Zwerg " ;
assert_true ( mk_wcswidth ( str , 500 ) = = 68 ) ;
str = L " Greek Ταχίστη αλώπηξ βαφής ψημένη γη, δρασκελίζει υπέρ νωθρού κυνός Takhístè " ;
assert_true ( mk_wcswidth ( str , 500 ) = = 80 ) ;
str = L " Irish D’ ḟuascail Íosa Úrṁac na hÓiġe Beannaiṫe pór Éaḃa agus Áḋaiṁ " ;
assert_true ( mk_wcswidth ( str , 500 ) = = 70 ) ;
str = L " Polish Pójdźże, kiń tę chmurność w głąb flaszy " ;
assert_true ( mk_wcswidth ( str , 500 ) = = 49 ) ;
str = L " Portuguese Luís argüia à Júlia que «brações, fé, chá, óxido, pôr, zângão» eram palavras do português " ;
assert_true ( mk_wcswidth ( str , 500 ) = = 100 ) ;
str = L " Russian Съешь же ещё этих мягких французских булок, да выпей чаю " ;
assert_true ( mk_wcswidth ( str , 500 ) = = 66 ) ;
str = L " Spanish Benjamín pidió una bebida de kiwi y fresa; Noé, sin vergüenza, la más exquisita champaña del menú " ;
assert_true ( mk_wcswidth ( str , 500 ) = = 107 ) ;
str = L " Turkish Vakfı n çoğu bu huysuz genci plajda görmüştü " ;
assert_true ( mk_wcswidth ( str , 500 ) = = 53 ) ;
# endif
}
# endif
2019-08-14 21:01:57 +02:00
static void test_print_n_strings_ ( const char * str , size_t n )
{
int sz = n * strlen ( str ) ;
{
string_buffer_t * buffer = create_string_buffer ( 200 , CHAR_BUF ) ;
conv_context_t cntx ;
cntx . buf = ( char * ) buffer_get_data ( buffer ) ;
cntx . buf_origin = ( char * ) buffer_get_data ( buffer ) ;
cntx . raw_avail = 200 ;
cntx . b_type = CHAR_BUF ;
assert_true ( print_n_strings ( & cntx , n , str ) = = sz ) ;
assert_true ( cntx . buf - cntx . buf_origin = = sz ) ;
destroy_string_buffer ( buffer ) ;
}
{
string_buffer_t * buffer = create_string_buffer ( 200 , W_CHAR_BUF ) ;
conv_context_t cntx ;
cntx . buf = ( char * ) buffer_get_data ( buffer ) ;
cntx . buf_origin = ( char * ) buffer_get_data ( buffer ) ;
cntx . raw_avail = 200 ;
cntx . b_type = W_CHAR_BUF ;
assert_true ( print_n_strings ( & cntx , n , str ) = = /*sizeof(wchar_t) **/ sz ) ;
assert_true ( cntx . buf - cntx . buf_origin = = sizeof ( wchar_t ) * sz ) ;
destroy_string_buffer ( buffer ) ;
}
{
string_buffer_t * buffer = create_string_buffer ( 200 , UTF8_BUF ) ;
conv_context_t cntx ;
cntx . buf = ( char * ) buffer_get_data ( buffer ) ;
cntx . buf_origin = ( char * ) buffer_get_data ( buffer ) ;
cntx . raw_avail = 200 ;
cntx . b_type = UTF8_BUF ;
assert_true ( print_n_strings ( & cntx , n , str ) = = sz ) ;
assert_true ( cntx . buf - cntx . buf_origin = = sz ) ;
destroy_string_buffer ( buffer ) ;
}
}
void test_print_n_strings ( void )
{
test_print_n_strings_ ( " " , 0 ) ;
test_print_n_strings_ ( " " , 1 ) ;
test_print_n_strings_ ( " " , 2 ) ;
test_print_n_strings_ ( " " , 0 ) ;
test_print_n_strings_ ( " " , 1 ) ;
test_print_n_strings_ ( " " , 2 ) ;
test_print_n_strings_ ( " foo " , 0 ) ;
test_print_n_strings_ ( " foo " , 1 ) ;
test_print_n_strings_ ( " foo " , 2 ) ;
}