diff options
author | Suren A. Chilingaryan <csa@dside.dyndns.org> | 2005-12-31 00:10:22 +0000 |
---|---|---|
committer | Suren A. Chilingaryan <csa@dside.dyndns.org> | 2005-12-31 00:10:22 +0000 |
commit | 690b7da850a2a241ca220b21938ec114c919d87b (patch) | |
tree | 900be0b1dea1811be61ab4ed29d303bb895f8ec4 /src/recode.c | |
parent | 907199c194af0cb3912219b808aab13df763c022 (diff) | |
download | librcc-690b7da850a2a241ca220b21938ec114c919d87b.tar.gz librcc-690b7da850a2a241ca220b21938ec114c919d87b.tar.bz2 librcc-690b7da850a2a241ca220b21938ec114c919d87b.tar.xz librcc-690b7da850a2a241ca220b21938ec114c919d87b.zip |
64bit fixes
+ Fixed segmentation on 64 bit systems
+ SPEC file usable in both 32 and 64 bit environments
Diffstat (limited to 'src/recode.c')
-rw-r--r-- | src/recode.c | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/src/recode.c b/src/recode.c index 9e19078..8c6cc40 100644 --- a/src/recode.c +++ b/src/recode.c @@ -511,17 +511,20 @@ rcc_string rccSizedFrom(rcc_context ctx, rcc_class_id class_id, const char *buf, } } else icnv = ctx->iconv_from[class_id]; - + if (icnv) { ret = rccIConvInternal(ctx, icnv, buf, len); - if (ret == (size_t)-1) return NULL; + if (ret == (size_t)-1) { + rccMutexUnLock(ctx->mutex); + return NULL; + } if ((rccGetOption(ctx, RCC_OPTION_TRANSLATE))&&(rccGetClassType(ctx, class_id) == RCC_CLASS_TRANSLATE_FROM)) { config = rccGetCurrentConfig(ctx); translate = rccRecodeTranslate(&config , class_id, ctx->tmpbuffer); if (translate) language_id = rccConfigGetLanguage(config); } - + result = rccCreateString(language_id, translate?translate:ctx->tmpbuffer, translate?0:ret); } else { if ((rccGetOption(ctx, RCC_OPTION_TRANSLATE))&&(rccGetClassType(ctx, class_id) == RCC_CLASS_TRANSLATE_FROM)) { |