git-svn-id: svn://db.shs.com.ru/pip@534 12ceb7fc-bf1f-11e4-8940-5bc7170c53b5
This commit is contained in:
@@ -204,6 +204,12 @@ endif()
|
|||||||
if(APPLE)
|
if(APPLE)
|
||||||
add_definitions(-D_FILE_OFFSET_BITS=64 -D_LARGEFILE64_SOURCE)
|
add_definitions(-D_FILE_OFFSET_BITS=64 -D_LARGEFILE64_SOURCE)
|
||||||
endif()
|
endif()
|
||||||
|
if ((NOT DEFINED LIBPROJECT) AND (DEFINED ANDROID_PLATFORM))
|
||||||
|
include_directories(${ANDROID_SYSTEM_LIBRARY_PATH}/usr/include)
|
||||||
|
#set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -I${ANDROID_NDK}/sysroot/usr/include")
|
||||||
|
#message("${ANDROID_SYSTEM_LIBRARY_PATH}/usr/include")
|
||||||
|
#message("${ANDROID_NDK}/sysroot/usr/include")
|
||||||
|
endif()
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
list(APPEND LIBS_MAIN ws2_32 iphlpapi psapi)
|
list(APPEND LIBS_MAIN ws2_32 iphlpapi psapi)
|
||||||
else()
|
else()
|
||||||
@@ -340,6 +346,11 @@ if(LIB)
|
|||||||
install(FILES ${HDRS} DESTINATION ${MINGW_INCLUDE}/pip)
|
install(FILES ${HDRS} DESTINATION ${MINGW_INCLUDE}/pip)
|
||||||
install(TARGETS ${PIP_LIBS_TARGETS} DESTINATION ${MINGW_LIB})
|
install(TARGETS ${PIP_LIBS_TARGETS} DESTINATION ${MINGW_LIB})
|
||||||
install(TARGETS ${PIP_LIBS_TARGETS} DESTINATION ${MINGW_BIN})
|
install(TARGETS ${PIP_LIBS_TARGETS} DESTINATION ${MINGW_BIN})
|
||||||
|
find_library(STDLIB "stdc++-6")
|
||||||
|
#message("${STDLIB}")
|
||||||
|
if (STDLIB)
|
||||||
|
file(COPY "${STDLIB}" DESTINATION "${CMAKE_CURRENT_BINARY_DIR}/utils/code_model_generator")
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
else()
|
else()
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
|
|||||||
@@ -19,7 +19,7 @@
|
|||||||
|
|
||||||
#include "picrypt.h"
|
#include "picrypt.h"
|
||||||
#ifdef PIP_CRYPT
|
#ifdef PIP_CRYPT
|
||||||
# include "sodium.h"
|
# include <sodium.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
@@ -28,7 +28,7 @@ const char hash_def_key[] = "_picrypt_";
|
|||||||
|
|
||||||
PICrypt::PICrypt() {
|
PICrypt::PICrypt() {
|
||||||
#ifdef PIP_CRYPT
|
#ifdef PIP_CRYPT
|
||||||
if (!sodium_init()) piCout << "[PICrypt]" << "Error while initialize sodium!";
|
if (!init()) piCout << "[PICrypt]" << "Error while initialize sodium!";
|
||||||
nonce_.resize(crypto_secretbox_NONCEBYTES);
|
nonce_.resize(crypto_secretbox_NONCEBYTES);
|
||||||
key_.resize(crypto_secretbox_KEYBYTES);
|
key_.resize(crypto_secretbox_KEYBYTES);
|
||||||
randombytes_buf(key_.data(), key_.size());
|
randombytes_buf(key_.data(), key_.size());
|
||||||
@@ -77,7 +77,7 @@ PIByteArray PICrypt::crypt(const PIByteArray & data, PIByteArray key) {
|
|||||||
if (key.size() != crypto_secretbox_KEYBYTES)
|
if (key.size() != crypto_secretbox_KEYBYTES)
|
||||||
key.resize(crypto_secretbox_KEYBYTES, ' ');
|
key.resize(crypto_secretbox_KEYBYTES, ' ');
|
||||||
//return PIByteArray();
|
//return PIByteArray();
|
||||||
if (!sodium_init()) return retba;
|
if (!init()) return retba;
|
||||||
PIByteArray n;
|
PIByteArray n;
|
||||||
retba.resize(data.size() + crypto_secretbox_MACBYTES);
|
retba.resize(data.size() + crypto_secretbox_MACBYTES);
|
||||||
n.resize(crypto_secretbox_NONCEBYTES);
|
n.resize(crypto_secretbox_NONCEBYTES);
|
||||||
@@ -123,7 +123,7 @@ PIByteArray PICrypt::decrypt(const PIByteArray & crypt_data, PIByteArray key, bo
|
|||||||
if (ok) *ok = false;
|
if (ok) *ok = false;
|
||||||
return PIByteArray();
|
return PIByteArray();
|
||||||
}
|
}
|
||||||
if (!sodium_init()) return retba;
|
if (!init()) return retba;
|
||||||
PIByteArray n;
|
PIByteArray n;
|
||||||
n.resize(crypto_secretbox_NONCEBYTES);
|
n.resize(crypto_secretbox_NONCEBYTES);
|
||||||
retba.resize(crypt_data.size() - n.size() - crypto_secretbox_MACBYTES);
|
retba.resize(crypt_data.size() - n.size() - crypto_secretbox_MACBYTES);
|
||||||
@@ -144,7 +144,7 @@ PIByteArray PICrypt::decrypt(const PIByteArray & crypt_data, PIByteArray key, bo
|
|||||||
PIByteArray PICrypt::hash(const PIString & secret) {
|
PIByteArray PICrypt::hash(const PIString & secret) {
|
||||||
PIByteArray hash;
|
PIByteArray hash;
|
||||||
#ifdef PIP_CRYPT
|
#ifdef PIP_CRYPT
|
||||||
if (!sodium_init()) return hash;
|
if (!init()) return hash;
|
||||||
hash.resize(crypto_generichash_BYTES);
|
hash.resize(crypto_generichash_BYTES);
|
||||||
PIByteArray s(secret.data(), secret.size());
|
PIByteArray s(secret.data(), secret.size());
|
||||||
crypto_generichash(hash.data(), hash.size(), s.data(), s.size(), (const uchar*)hash_def_key, sizeof(hash_def_key) - 1);
|
crypto_generichash(hash.data(), hash.size(), s.data(), s.size(), (const uchar*)hash_def_key, sizeof(hash_def_key) - 1);
|
||||||
@@ -159,7 +159,7 @@ ullong PICrypt::shorthash(const PIString& s, PIByteArray key) {
|
|||||||
ullong hash = 0;
|
ullong hash = 0;
|
||||||
#ifdef PIP_CRYPT
|
#ifdef PIP_CRYPT
|
||||||
if (crypto_shorthash_BYTES != sizeof(hash)) piCout << "[PICrypt]" << "internal error: bad hash size";
|
if (crypto_shorthash_BYTES != sizeof(hash)) piCout << "[PICrypt]" << "internal error: bad hash size";
|
||||||
if (!sodium_init()) return hash;
|
if (!init()) return hash;
|
||||||
if (key.size() != crypto_shorthash_KEYBYTES) {
|
if (key.size() != crypto_shorthash_KEYBYTES) {
|
||||||
piCout << "[PICrypt]" << "invalid key size" << key.size() << ", shoud be" << crypto_shorthash_KEYBYTES << ", filled zeros";
|
piCout << "[PICrypt]" << "invalid key size" << key.size() << ", shoud be" << crypto_shorthash_KEYBYTES << ", filled zeros";
|
||||||
key.resize(crypto_shorthash_KEYBYTES, 0);
|
key.resize(crypto_shorthash_KEYBYTES, 0);
|
||||||
@@ -176,7 +176,7 @@ ullong PICrypt::shorthash(const PIString& s, PIByteArray key) {
|
|||||||
PIByteArray PICrypt::generateKey() {
|
PIByteArray PICrypt::generateKey() {
|
||||||
PIByteArray hash;
|
PIByteArray hash;
|
||||||
#ifdef PIP_CRYPT
|
#ifdef PIP_CRYPT
|
||||||
if (!sodium_init()) return hash;
|
if (!init()) return hash;
|
||||||
hash.resize(crypto_secretbox_KEYBYTES);
|
hash.resize(crypto_secretbox_KEYBYTES);
|
||||||
randombytes_buf(hash.data(), hash.size());
|
randombytes_buf(hash.data(), hash.size());
|
||||||
#else
|
#else
|
||||||
@@ -206,4 +206,19 @@ size_t PICrypt::sizeCrypt() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool PICrypt::init() {
|
||||||
|
#ifdef PIP_CRYPT
|
||||||
|
static bool inited = false;
|
||||||
|
if (inited) return true;
|
||||||
|
//piCout << "[PICrypt]" << "init ...";
|
||||||
|
inited = sodium_init();
|
||||||
|
//piCout << "[PICrypt]" << "init" << inited;
|
||||||
|
return inited;
|
||||||
|
#else
|
||||||
|
piCout << "[PICrypt]" << "Warning: PICrypt is disabled, to enable install sodium library and build pip with -DCRYPT=";
|
||||||
|
#endif
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -32,6 +32,9 @@ char * __sysoemname__ = 0;
|
|||||||
#ifdef BLACKBERRY
|
#ifdef BLACKBERRY
|
||||||
# include <ctype.h>
|
# include <ctype.h>
|
||||||
#endif
|
#endif
|
||||||
|
//#ifdef ANDROID
|
||||||
|
# include <wchar.h>
|
||||||
|
//#endif
|
||||||
|
|
||||||
/*! \class PIChar
|
/*! \class PIChar
|
||||||
* \brief Unicode char
|
* \brief Unicode char
|
||||||
@@ -110,7 +113,14 @@ PIChar PIChar::fromUTF8(const char * c) {
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
ret.ch = *(ushort*)c;
|
//#ifdef ANDROID
|
||||||
|
wchar_t wc(0);
|
||||||
|
mbstate_t s;
|
||||||
|
mbrtowc(&wc, c, 4, &s);
|
||||||
|
ret.ch = wc;
|
||||||
|
return ret;
|
||||||
|
//#endif
|
||||||
|
// ret.ch = *(ushort*)c;
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -21,6 +21,9 @@
|
|||||||
#ifdef PIP_ICU
|
#ifdef PIP_ICU
|
||||||
# include "unicode/ucnv.h"
|
# include "unicode/ucnv.h"
|
||||||
#endif
|
#endif
|
||||||
|
//#ifdef ANDROID
|
||||||
|
# include <wchar.h>
|
||||||
|
//#endif
|
||||||
|
|
||||||
/*! \class PIString
|
/*! \class PIString
|
||||||
* \brief String class
|
* \brief String class
|
||||||
@@ -217,25 +220,7 @@ void PIString::appendFromChars(const char * c, int s, const char * cp) {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
sz = mbtowc(&wc, &(c[i]), 4);
|
sz = mbtowc(&wc, &(c[i]), 4);
|
||||||
//cout << sz << endl;
|
push_back(PIChar(int(wc)));
|
||||||
switch (sz) {
|
|
||||||
case 4:
|
|
||||||
push_back(PIChar(*(int*)&(c[i])));
|
|
||||||
i += 3;
|
|
||||||
continue;
|
|
||||||
case 3:
|
|
||||||
push_back(PIChar(*(int*)&(c[i])));
|
|
||||||
back().ch &= 0xFFFFFF;
|
|
||||||
i += 2;
|
|
||||||
continue;
|
|
||||||
case 2:
|
|
||||||
push_back(PIChar(*(short * )&(c[i])));
|
|
||||||
++i;
|
|
||||||
continue;
|
|
||||||
default:
|
|
||||||
push_back(PIChar(c[i]));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -332,19 +317,28 @@ void PIString::buildData(const char * cp) const {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
uint wc;
|
wchar_t wc;
|
||||||
uchar tc;
|
char tc[4];
|
||||||
|
mbstate_t s;
|
||||||
|
int sz(0);
|
||||||
//printf("PIString::data %d\n", size_s());
|
//printf("PIString::data %d\n", size_s());
|
||||||
for (int i = 0, j = 0; i < size_s(); ++i) {
|
for (int i = 0; i < size_s(); ++i) {
|
||||||
wc = uint(at(i).unicode16Code());
|
if (at(i).isAscii()) {
|
||||||
|
data_.push_back(uchar(at(i).toAscii()));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
wc = at(i).toWChar();
|
||||||
|
sz = piClampi(wcrtomb(tc, wc, &s), 0, 4);
|
||||||
|
for (int b = 0; b < sz; ++b)
|
||||||
|
data_.push_back(uchar(tc[b]));
|
||||||
//printf("__%d_%d\n", i, wc);
|
//printf("__%d_%d\n", i, wc);
|
||||||
tc = wc & 0xFF;
|
/*tc = wc & 0xFF;
|
||||||
while (tc) {
|
while (tc) {
|
||||||
data_.push_back(uchar(tc)); ++j;
|
data_.push_back(uchar(tc));
|
||||||
wc >>= 8;
|
wc >>= 8;
|
||||||
tc = wc & 0xFF;
|
tc = wc & 0xFF;
|
||||||
//printf("____%d\n", wc);
|
//printf("____%d\n", wc);
|
||||||
}
|
}*/
|
||||||
/*if (at(i).isAscii())
|
/*if (at(i).isAscii())
|
||||||
data_.push_back(uchar(at(i).toAscii()));
|
data_.push_back(uchar(at(i).toAscii()));
|
||||||
else {
|
else {
|
||||||
@@ -429,7 +423,7 @@ PIString & PIString::operator +=(const char * str) {
|
|||||||
|
|
||||||
PIString & PIString::operator +=(const wchar_t * str) {
|
PIString & PIString::operator +=(const wchar_t * str) {
|
||||||
//cout << "wc" << endl;
|
//cout << "wc" << endl;
|
||||||
int l = 0, sz;
|
/*int l = 0, sz;
|
||||||
char * c = new char[MB_CUR_MAX];
|
char * c = new char[MB_CUR_MAX];
|
||||||
while (str[l] != 0) ++l;
|
while (str[l] != 0) ++l;
|
||||||
for (int i = 0; i < l; ++i) {
|
for (int i = 0; i < l; ++i) {
|
||||||
@@ -450,7 +444,10 @@ PIString & PIString::operator +=(const wchar_t * str) {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
delete[] c;
|
delete[] c;*/
|
||||||
|
int i = -1;
|
||||||
|
while (str[++i])
|
||||||
|
push_back(PIChar(int(str[i])));
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -67,6 +67,8 @@ public:
|
|||||||
static size_t sizeCrypt();
|
static size_t sizeCrypt();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
static bool init();
|
||||||
|
|
||||||
PIByteArray nonce_, key_;
|
PIByteArray nonce_, key_;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user