diff options
author | glebius <glebius@FreeBSD.org> | 2013-11-12 15:09:28 +0000 |
---|---|---|
committer | glebius <glebius@FreeBSD.org> | 2013-11-12 15:09:28 +0000 |
commit | 0cc3d4a1ddc4b36bc3b75abc736a4db5e562f5cb (patch) | |
tree | 271bcd6bd002ff0b47e93839ced5125357403a8e /contrib/smbfs/lib | |
parent | ce4163e4f3478c8819e2e474356811fc1c641aba (diff) | |
download | FreeBSD-src-0cc3d4a1ddc4b36bc3b75abc736a4db5e562f5cb.zip FreeBSD-src-0cc3d4a1ddc4b36bc3b75abc736a4db5e562f5cb.tar.gz |
Just disable recoding support in libsmb if built WITHOUT_ICONV.
Diffstat (limited to 'contrib/smbfs/lib')
-rw-r--r-- | contrib/smbfs/lib/smb/nls.c | 29 |
1 files changed, 25 insertions, 4 deletions
diff --git a/contrib/smbfs/lib/smb/nls.c b/contrib/smbfs/lib/smb/nls.c index 1637fa7..5c2dbd9 100644 --- a/contrib/smbfs/lib/smb/nls.c +++ b/contrib/smbfs/lib/smb/nls.c @@ -36,7 +36,6 @@ __FBSDID("$FreeBSD$"); #include <sys/types.h> -#include <iconv.h> #include <sys/sysctl.h> #include <ctype.h> #include <errno.h> @@ -47,10 +46,16 @@ __FBSDID("$FreeBSD$"); #include <err.h> #include <netsmb/smb_lib.h> +#ifdef HAVE_ICONV +#include <iconv.h> +#endif + u_char nls_lower[256]; u_char nls_upper[256]; +#ifdef HAVE_ICONV static iconv_t nls_toext, nls_toloc; +#endif int nls_setlocale(const char *name) @@ -71,9 +76,7 @@ nls_setlocale(const char *name) int nls_setrecode(const char *local, const char *external) { -#ifdef APPLE - return ENOENT; -#else +#ifdef HAVE_ICONV iconv_t icd; if (nls_toext) @@ -93,12 +96,15 @@ nls_setrecode(const char *local, const char *external) } nls_toloc = icd; return 0; +#else + return ENOENT; #endif } char * nls_str_toloc(char *dst, const char *src) { +#ifdef HAVE_ICONV char *p = dst; size_t inlen, outlen; @@ -113,11 +119,15 @@ nls_str_toloc(char *dst, const char *src) } *p = 0; return dst; +#else + return strcpy(dst, src); +#endif } char * nls_str_toext(char *dst, const char *src) { +#ifdef HAVE_ICONV char *p = dst; size_t inlen, outlen; @@ -132,11 +142,15 @@ nls_str_toext(char *dst, const char *src) } *p = 0; return dst; +#else + return strcpy(dst, src); +#endif } void * nls_mem_toloc(void *dst, const void *src, int size) { +#ifdef HAVE_ICONV char *p = dst; const char *s = src; size_t inlen, outlen; @@ -154,11 +168,15 @@ nls_mem_toloc(void *dst, const void *src, int size) outlen--; } return dst; +#else + return memcpy(dst, src, size); +#endif } void * nls_mem_toext(void *dst, const void *src, int size) { +#ifdef HAVE_ICONV char *p = dst; const char *s = src; size_t inlen, outlen; @@ -177,6 +195,9 @@ nls_mem_toext(void *dst, const void *src, int size) outlen--; } return dst; +#else + return memcpy(dst, src, size); +#endif } char * |