blob: b5cabedec59fa3f8cc689d5f2650e80a42687cfd [file] [log] [blame]
// Copyright 2014 PDFium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com
#include "xfa/fgas/crt/fgas_system.h"
#include <algorithm>
#include "core/fxcrt/include/fx_system.h"
namespace {
inline FX_BOOL FX_isupper(int32_t ch) {
return ch >= 'A' && ch <= 'Z';
}
inline int32_t FX_tolower(int32_t ch) {
return FX_isupper(ch) ? (ch + 0x20) : ch;
}
} // namespace
int32_t FX_wcsnicmp(const FX_WCHAR* s1, const FX_WCHAR* s2, size_t count) {
ASSERT(s1 && s2 && count > 0);
FX_WCHAR wch1 = 0;
FX_WCHAR wch2 = 0;
while (count-- > 0) {
wch1 = (FX_WCHAR)FX_tolower(*s1++);
wch2 = (FX_WCHAR)FX_tolower(*s2++);
if (wch1 != wch2) {
break;
}
}
return wch1 - wch2;
}
FX_FLOAT FX_wcstof(const FX_WCHAR* pwsStr, int32_t iLength, int32_t* pUsedLen) {
ASSERT(pwsStr);
if (iLength < 0) {
iLength = FXSYS_wcslen(pwsStr);
}
if (iLength == 0) {
return 0.0f;
}
int32_t iUsedLen = 0;
FX_BOOL bNegtive = FALSE;
switch (pwsStr[iUsedLen]) {
case '-':
bNegtive = TRUE;
case '+':
iUsedLen++;
break;
}
FX_FLOAT fValue = 0.0f;
while (iUsedLen < iLength) {
FX_WCHAR wch = pwsStr[iUsedLen];
if (wch >= L'0' && wch <= L'9') {
fValue = fValue * 10.0f + (wch - L'0');
} else {
break;
}
iUsedLen++;
}
if (iUsedLen < iLength && pwsStr[iUsedLen] == L'.') {
FX_FLOAT fPrecise = 0.1f;
while (++iUsedLen < iLength) {
FX_WCHAR wch = pwsStr[iUsedLen];
if (wch >= L'0' && wch <= L'9') {
fValue += (wch - L'0') * fPrecise;
fPrecise *= 0.1f;
} else {
break;
}
}
}
if (pUsedLen) {
*pUsedLen = iUsedLen;
}
return bNegtive ? -fValue : fValue;
}