2006-02-06 18:03:11 +00:00
|
|
|
/*
|
|
|
|
**********************************************************************
|
2012-06-01 20:40:48 +00:00
|
|
|
* Copyright (C) 2005-2012, International Business Machines
|
2006-02-06 18:03:11 +00:00
|
|
|
* Corporation and others. All Rights Reserved.
|
|
|
|
**********************************************************************
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "unicode/utypes.h"
|
2006-05-09 18:06:10 +00:00
|
|
|
|
|
|
|
#if !UCONFIG_NO_CONVERSION
|
2006-02-06 18:03:11 +00:00
|
|
|
#include "unicode/unistr.h"
|
|
|
|
#include "unicode/ucnv.h"
|
|
|
|
|
|
|
|
#include "csmatch.h"
|
|
|
|
|
|
|
|
#include "csrecog.h"
|
|
|
|
#include "inputext.h"
|
|
|
|
|
|
|
|
U_NAMESPACE_BEGIN
|
|
|
|
|
2006-02-06 20:45:30 +00:00
|
|
|
CharsetMatch::CharsetMatch()
|
2012-06-21 21:02:19 +00:00
|
|
|
: textIn(NULL), confidence(0), fCharsetName(NULL), fLang(NULL)
|
2006-02-06 18:03:11 +00:00
|
|
|
{
|
|
|
|
// nothing else to do.
|
|
|
|
}
|
|
|
|
|
2012-06-01 20:40:48 +00:00
|
|
|
void CharsetMatch::set(InputText *input, const CharsetRecognizer *cr, int32_t conf,
|
|
|
|
const char *csName, const char *lang)
|
2006-02-06 18:03:11 +00:00
|
|
|
{
|
|
|
|
textIn = input;
|
|
|
|
confidence = conf;
|
2012-06-01 20:40:48 +00:00
|
|
|
fCharsetName = csName;
|
|
|
|
fLang = lang;
|
2012-06-21 21:02:19 +00:00
|
|
|
if (cr != NULL) {
|
2012-06-01 20:40:48 +00:00
|
|
|
if (fCharsetName == NULL) {
|
2012-06-21 21:02:19 +00:00
|
|
|
fCharsetName = cr->getName();
|
2012-06-01 20:40:48 +00:00
|
|
|
}
|
|
|
|
if (fLang == NULL) {
|
2012-06-21 21:02:19 +00:00
|
|
|
fLang = cr->getLanguage();
|
2012-06-01 20:40:48 +00:00
|
|
|
}
|
|
|
|
}
|
2006-02-06 18:03:11 +00:00
|
|
|
}
|
|
|
|
|
2006-02-06 20:45:30 +00:00
|
|
|
const char* CharsetMatch::getName()const
|
2006-02-06 18:03:11 +00:00
|
|
|
{
|
2012-06-01 20:40:48 +00:00
|
|
|
return fCharsetName;
|
2006-02-06 18:03:11 +00:00
|
|
|
}
|
|
|
|
|
2006-02-06 20:45:30 +00:00
|
|
|
const char* CharsetMatch::getLanguage()const
|
2006-02-06 18:03:11 +00:00
|
|
|
{
|
2012-06-01 20:40:48 +00:00
|
|
|
return fLang;
|
2006-02-06 18:03:11 +00:00
|
|
|
}
|
|
|
|
|
2006-02-06 20:45:30 +00:00
|
|
|
int32_t CharsetMatch::getConfidence()const
|
2006-02-06 18:03:11 +00:00
|
|
|
{
|
|
|
|
return confidence;
|
|
|
|
}
|
|
|
|
|
2006-02-06 20:45:30 +00:00
|
|
|
int32_t CharsetMatch::getUChars(UChar *buf, int32_t cap, UErrorCode *status) const
|
2006-02-06 18:03:11 +00:00
|
|
|
{
|
|
|
|
UConverter *conv = ucnv_open(getName(), status);
|
|
|
|
int32_t result = ucnv_toUChars(conv, buf, cap, (const char *) textIn->fRawInput, textIn->fRawLength, status);
|
|
|
|
|
|
|
|
ucnv_close(conv);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
U_NAMESPACE_END
|
2006-05-09 18:06:10 +00:00
|
|
|
|
|
|
|
#endif
|