From 7f98253a67d9f417f98376f0608b7dd61e0b7150 Mon Sep 17 00:00:00 2001 From: Jeremy Allison Date: Sun, 26 Dec 2004 18:51:49 +0000 Subject: r4369: Patch for bug #2190 (SWAT displaying parameters in UNIX charset) not utf8. Fixed by Shiro Yamada . Jeremy. (This used to be commit 8de04888097b3e125845340ba1a9a1bb79892e22) --- source3/web/swat.c | 24 ++++++++++++++++++------ 1 file changed, 18 insertions(+), 6 deletions(-) (limited to 'source3/web/swat.c') diff --git a/source3/web/swat.c b/source3/web/swat.c index 48537d1d04..7bd9837c37 100644 --- a/source3/web/swat.c +++ b/source3/web/swat.c @@ -193,6 +193,7 @@ static void show_parameter(int snum, struct parm_struct *parm) { int i; void *ptr = parm->ptr; + char *utf8_s1, *utf8_s2; if (parm->class == P_LOCAL && snum >= 0) { ptr = lp_local_ptr(snum, ptr); @@ -214,10 +215,17 @@ static void show_parameter(int snum, struct parm_struct *parm) char **list = *(char ***)ptr; for (;*list;list++) { /* enclose in quotes if the string contains a space */ - if ( strchr_m(*list, ' ') ) - printf("\'%s\'%s", *list, ((*(list+1))?", ":"")); - else - printf("%s%s", *list, ((*(list+1))?", ":"")); + if ( strchr_m(*list, ' ') ) { + push_utf8_allocate(&utf8_s1, *list); + push_utf8_allocate(&utf8_s2, ((*(list+1))?", ":"")); + printf("\'%s\'%s", utf8_s1, utf8_s2); + } else { + push_utf8_allocate(&utf8_s1, *list); + push_utf8_allocate(&utf8_s2, ((*(list+1))?", ":"")); + printf("%s%s", utf8_s1, utf8_s2); + } + SAFE_FREE(utf8_s1); + SAFE_FREE(utf8_s2); } } printf("\">"); @@ -238,16 +246,20 @@ static void show_parameter(int snum, struct parm_struct *parm) case P_STRING: case P_USTRING: + push_utf8_allocate(&utf8_s1, *(char **)ptr); printf("", - make_parm_name(parm->label), *(char **)ptr); + make_parm_name(parm->label), utf8_s1); + SAFE_FREE(utf8_s1); printf("", _("Set Default"), make_parm_name(parm->label),fix_backslash((char *)(parm->def.svalue))); break; case P_GSTRING: case P_UGSTRING: + push_utf8_allocate(&utf8_s1, (char *)ptr); printf("", - make_parm_name(parm->label), (char *)ptr); + make_parm_name(parm->label), utf8_s1); + SAFE_FREE(utf8_s1); printf("", _("Set Default"), make_parm_name(parm->label),fix_backslash((char *)(parm->def.svalue))); break; -- cgit