1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-12 09:18:10 +03:00
samba-mirror/source3/torture/t_push_ucs2.c
Derrell Lipman 9c15bd311d r13212: r12414@cabra: derrell | 2006-01-28 17:52:17 -0500
lp_load() could not be called multiple times to modify parameter settings based
 on reading from multiple configuration settings.  Each time, it initialized all
 of the settings back to their defaults before reading the specified
 configuration file.

 This patch adds a parameter to lp_load() specifying whether the settings should
 be initialized.  It does, however, still force the settings to be initialized
 the first time, even if the request was to not initialize them.  (Not doing so
 could wreak havoc due to uninitialized values.)
(This used to be commit f2a24de769)
2007-10-10 11:06:18 -05:00

55 lines
1.0 KiB
C

/*
* Copyright (C) 2003 by Martin Pool
* Copyright (C) 2003 by Andrew Bartlett
*
* Test harness for push_ucs2
*/
#include "includes.h"
static int check_push_ucs2(const char *orig)
{
smb_ucs2_t *dest = NULL;
char *orig2 = NULL;
int ret;
push_ucs2_allocate(&dest, orig);
pull_ucs2_allocate(&orig2, dest);
ret = strcmp(orig, orig2);
if (ret) {
fprintf(stderr, "orig: %s\n", orig);
fprintf(stderr, "orig (UNIX -> UCS2 -> UNIX): %s\n", orig2);
}
SAFE_FREE(dest);
SAFE_FREE(orig2);
return ret;
}
int main(int argc, char *argv[])
{
int i, ret = 0;
int count = 1;
/* Needed to initialize character set */
lp_load("/dev/null", True, False, False, True);
if (argc < 2) {
fprintf(stderr, "usage: %s STRING1 [COUNT]\n"
"Checks that a string translated UNIX->UCS2->UNIX is unchanged\n"
"Should be always 0\n",
argv[0]);
return 2;
}
if (argc >= 3)
count = atoi(argv[2]);
for (i = 0; ((i < count) && (!ret)); i++)
ret = check_push_ucs2(argv[1]);
printf("%d\n", ret);
return 0;
}