You've already forked godot
mirror of
https://github.com/godotengine/godot.git
synced 2025-11-18 14:21:41 +00:00
Fix cherry-picking issues caused by code updates
This commit is contained in:
127
thirdparty/openssl/winrt.cpp
vendored
Normal file
127
thirdparty/openssl/winrt.cpp
vendored
Normal file
@@ -0,0 +1,127 @@
|
||||
/* Snippets extracted from https://github.com/Microsoft/openssl/blob/ec7e430e06e4e3ac87c183dee33cb216814cf980/ms/winrt.cpp
|
||||
* Adapted for Godot definitions
|
||||
*/
|
||||
/* winrt.cpp
|
||||
* Copyright 2014 Microsoft Corporation
|
||||
* C++/CX Entropy/shims for Windows Phone/Windows Store platform
|
||||
* written by Alejandro Jimenez Martinez
|
||||
* (aljim@microsoft.com) for the OpenSSL project 2014.
|
||||
*/
|
||||
|
||||
#include <windows.h>
|
||||
#if defined(WINAPI_FAMILY)
|
||||
extern "C" {
|
||||
unsigned entropyRT(BYTE *buffer, unsigned len);
|
||||
void RAND_add(const void *buf, int num, double entropy);
|
||||
int RAND_poll(void);
|
||||
}
|
||||
#endif
|
||||
|
||||
unsigned entropyRT(BYTE *buffer, unsigned len) {
|
||||
using namespace Platform;
|
||||
using namespace Windows::Foundation;
|
||||
using namespace Windows::Foundation::Collections;
|
||||
using namespace Windows::Security::Cryptography;
|
||||
using namespace Windows::Storage::Streams;
|
||||
IBuffer ^ buf = CryptographicBuffer::GenerateRandom(len);
|
||||
Array<unsigned char> ^ arr;
|
||||
CryptographicBuffer::CopyToByteArray(buf, &arr);
|
||||
unsigned arrayLen = arr->Length;
|
||||
|
||||
// Make sure not to overflow the copy
|
||||
arrayLen = (arrayLen > len) ? len : arrayLen;
|
||||
memcpy(buffer, arr->Data, arrayLen);
|
||||
return arrayLen;
|
||||
}
|
||||
|
||||
int RAND_poll(void) {
|
||||
BYTE buf[60];
|
||||
unsigned collected = entropyRT(buf, sizeof(buf));
|
||||
RAND_add(buf, collected, collected);
|
||||
return 1;
|
||||
}
|
||||
|
||||
#if defined(WINRT_ENABLED)
|
||||
extern "C" {
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
void *GetModuleHandle(
|
||||
_In_opt_ LPCTSTR lpModuleName) {
|
||||
return NULL;
|
||||
}
|
||||
//no log for phone
|
||||
int RegisterEventSource(
|
||||
_In_ LPCTSTR lpUNCServerName,
|
||||
_In_ LPCTSTR lpSourceName) {
|
||||
return NULL;
|
||||
}
|
||||
|
||||
int ReportEvent(
|
||||
_In_ HANDLE hEventLog,
|
||||
_In_ WORD wType,
|
||||
_In_ WORD wCategory,
|
||||
_In_ DWORD dwEventID,
|
||||
_In_ PSID lpUserSid,
|
||||
_In_ WORD wNumStrings,
|
||||
_In_ DWORD dwDataSize,
|
||||
_In_ LPCTSTR *lpStrings,
|
||||
_In_ LPVOID lpRawData) {
|
||||
return 0;
|
||||
}
|
||||
int MessageBox(
|
||||
_In_opt_ HWND hWnd,
|
||||
_In_opt_ LPCTSTR lpText,
|
||||
_In_opt_ LPCTSTR lpCaption,
|
||||
_In_ UINT uType) {
|
||||
return 0;
|
||||
}
|
||||
int __cdecl GetProcessWindowStation(void) {
|
||||
return NULL;
|
||||
}
|
||||
BOOL __cdecl GetUserObjectInformationW(
|
||||
_In_ HANDLE hObj,
|
||||
_In_ int nIndex,
|
||||
_Out_opt_ PVOID pvInfo,
|
||||
_In_ DWORD nLength,
|
||||
_Out_opt_ LPDWORD lpnLengthNeeded) {
|
||||
return 0;
|
||||
}
|
||||
int __cdecl GetStdHandle(
|
||||
_In_ DWORD nStdHandle) {
|
||||
return 0;
|
||||
}
|
||||
BOOL DeregisterEventSource(
|
||||
_Inout_ HANDLE hEventLog) {
|
||||
return 0;
|
||||
}
|
||||
char *getenv(
|
||||
const char *varname) {
|
||||
//hardcoded environmental variables used for the appx testing application for store/phone
|
||||
if (!strcmp(varname, "OPENSSL_CONF")) {
|
||||
return "./openssl.cnf";
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
int setenv(const char *envname, const char *envval, int overwrite) {
|
||||
return -1;
|
||||
}
|
||||
int _getch(void) {
|
||||
return 0;
|
||||
}
|
||||
int _kbhit() {
|
||||
return 0;
|
||||
}
|
||||
BOOL __cdecl FlushConsoleInputBuffer(
|
||||
_In_ HANDLE hConsoleInput) {
|
||||
return 0;
|
||||
}
|
||||
int winrt_GetTickCount(void) {
|
||||
LARGE_INTEGER t;
|
||||
return (int)(QueryPerformanceCounter(&t) ? t.QuadPart : 0);
|
||||
}
|
||||
void *OPENSSL_UplinkTable[26] = { 0 };
|
||||
} //extern C
|
||||
|
||||
#endif /*defined(WINRT_ENABLED)*/
|
||||
Reference in New Issue
Block a user