summaryrefslogtreecommitdiff
path: root/source3/lib/charcnv.c
diff options
context:
space:
mode:
authorAndrew Tridgell <tridge@samba.org>2001-07-08 18:22:04 +0000
committerAndrew Tridgell <tridge@samba.org>2001-07-08 18:22:04 +0000
commit43dd15913468f35a0d3352530f8e0c403f194521 (patch)
tree5977f037d951e1a3598074aa799b3d48fc6dcc19 /source3/lib/charcnv.c
parent8326666b7c56b6c54380c4dc9aabd9f54691a7d3 (diff)
downloadsamba-43dd15913468f35a0d3352530f8e0c403f194521.tar.gz
samba-43dd15913468f35a0d3352530f8e0c403f194521.tar.bz2
samba-43dd15913468f35a0d3352530f8e0c403f194521.zip
fixed the auto-initialisation of the iconv descriptors
(This used to be commit 66632782c583356550446638a832cc46a99f9f62)
Diffstat (limited to 'source3/lib/charcnv.c')
-rw-r--r--source3/lib/charcnv.c22
1 files changed, 11 insertions, 11 deletions
diff --git a/source3/lib/charcnv.c b/source3/lib/charcnv.c
index 30dfd2c504..b96c960ec1 100644
--- a/source3/lib/charcnv.c
+++ b/source3/lib/charcnv.c
@@ -65,7 +65,7 @@ void init_iconv(char *unix_charset, char *dos_charset)
destlen - maximal length allowed for string
return the number of bytes occupied in the destination
****************************************************************************/
-static size_t convert_string(smb_iconv_t descriptor,
+static size_t convert_string(smb_iconv_t *descriptor,
void const *src, size_t srclen,
void *dest, size_t destlen)
{
@@ -80,7 +80,7 @@ static size_t convert_string(smb_iconv_t descriptor,
init_iconv(NULL, NULL);
}
- if (descriptor == (smb_iconv_t)-1) {
+ if (*descriptor == (smb_iconv_t)-1) {
/* conversion not supported, use as is */
int len = MIN(srclen,destlen);
memcpy(dest,src,len);
@@ -89,7 +89,7 @@ static size_t convert_string(smb_iconv_t descriptor,
i_len=srclen;
o_len=destlen;
- retval=smb_iconv(descriptor,&inbuf, &i_len, &outbuf, &o_len);
+ retval=smb_iconv(*descriptor,&inbuf, &i_len, &outbuf, &o_len);
if(retval==-1)
{ char *reason="unknown error";
switch(errno)
@@ -112,20 +112,20 @@ int unix_strupper(const char *src, size_t srclen, char *dest, size_t destlen)
{
int size,len;
smb_ucs2_t *buffer=(smb_ucs2_t*)cvtbuf;
- size=convert_string(unix_to_ucs2, src, srclen, buffer, sizeof(cvtbuf));
+ size=convert_string(&unix_to_ucs2, src, srclen, buffer, sizeof(cvtbuf));
len=size/2;
strupper_w(buffer);
- return convert_string(ucs2_to_unix, buffer, size, dest, destlen);
+ return convert_string(&ucs2_to_unix, buffer, size, dest, destlen);
}
int unix_strlower(const char *src, size_t srclen, char *dest, size_t destlen)
{
int size,len;
smb_ucs2_t *buffer=(smb_ucs2_t*)cvtbuf;
- size=convert_string(unix_to_ucs2, src, srclen, buffer, sizeof(cvtbuf));
+ size=convert_string(&unix_to_ucs2, src, srclen, buffer, sizeof(cvtbuf));
len=size/2;
strlower_w(buffer);
- return convert_string(ucs2_to_unix, buffer, size, dest, destlen);
+ return convert_string(&ucs2_to_unix, buffer, size, dest, destlen);
}
@@ -165,7 +165,7 @@ int push_ascii(void *dest, const char *src, int dest_len, int flags)
src_len++;
}
- return convert_string(unix_to_dos, src, src_len, dest, dest_len);
+ return convert_string(&unix_to_dos, src, src_len, dest, dest_len);
}
int push_ascii_fstring(void *dest, const char *src)
@@ -203,7 +203,7 @@ int pull_ascii(char *dest, const void *src, int dest_len, int src_len, int flags
if (flags & STR_TERMINATE) src_len = strlen(src)+1;
- ret = convert_string(dos_to_unix, src, src_len, dest, dest_len);
+ ret = convert_string(&dos_to_unix, src, src_len, dest, dest_len);
if (dest_len) dest[MIN(ret, dest_len-1)] = 0;
@@ -258,7 +258,7 @@ int push_ucs2(const void *base_ptr, void *dest, const char *src, int dest_len, i
len++;
}
- len += convert_string(unix_to_ucs2, src, src_len, dest, dest_len);
+ len += convert_string(&unix_to_ucs2, src, src_len, dest, dest_len);
return len;
}
@@ -288,7 +288,7 @@ int pull_ucs2(const void *base_ptr, char *dest, const void *src, int dest_len, i
if (flags & STR_TERMINATE) src_len = strlen_w(src)*2+2;
- ret = convert_string(ucs2_to_unix, src, src_len, dest, dest_len);
+ ret = convert_string(&ucs2_to_unix, src, src_len, dest, dest_len);
if (dest_len) dest[MIN(ret, dest_len-1)] = 0;
return src_len;