Make naming better, move some code around.
This commit is contained in:
parent
22e34d48c9
commit
0768b06ec1
1 changed files with 28 additions and 39 deletions
|
@ -26,7 +26,7 @@ static DiscordEventHandlers Handlers{};
|
||||||
static RpcMessageFrame Frame;
|
static RpcMessageFrame Frame;
|
||||||
|
|
||||||
// if only there was a standard library function for this
|
// if only there was a standard library function for this
|
||||||
size_t StringCopy(char* dest, const char* src, size_t maxBytes) {
|
size_t StringCopy(char* dest, const char* src, size_t maxBytes = UINT32_MAX) {
|
||||||
if (!dest || !src || !maxBytes) {
|
if (!dest || !src || !maxBytes) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -38,19 +38,7 @@ size_t StringCopy(char* dest, const char* src, size_t maxBytes) {
|
||||||
return copied - 1;
|
return copied - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t StringCopy(char* dest, const char* src) {
|
void JsonWriteEscapedString(char*& dest, const char* src)
|
||||||
if (!dest || !src) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
size_t copied;
|
|
||||||
for (copied = 1; *src; ++copied) {
|
|
||||||
*dest++ = *src++;
|
|
||||||
}
|
|
||||||
*dest = 0;
|
|
||||||
return copied - 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
void EscapeString(char*& dest, const char* src)
|
|
||||||
{
|
{
|
||||||
for (char c = *src++; c; c = *src++) {
|
for (char c = *src++; c; c = *src++) {
|
||||||
switch (c) {
|
switch (c) {
|
||||||
|
@ -86,7 +74,7 @@ void EscapeString(char*& dest, const char* src)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename T> void NumberToString(char*& dest, T number)
|
template<typename T> void JsonWriteNumber(char*& dest, T number)
|
||||||
{
|
{
|
||||||
if (!number) {
|
if (!number) {
|
||||||
*dest++ = '0';
|
*dest++ = '0';
|
||||||
|
@ -128,7 +116,7 @@ void JsonWriteStringProp(char*& dest, const char* name, const char* value)
|
||||||
{
|
{
|
||||||
JsonWritePropName(dest, name);
|
JsonWritePropName(dest, name);
|
||||||
*dest++ = '"';
|
*dest++ = '"';
|
||||||
EscapeString(dest, value);
|
JsonWriteEscapedString(dest, value);
|
||||||
*dest++ = '"';
|
*dest++ = '"';
|
||||||
JsonWritePropSep(dest);
|
JsonWritePropSep(dest);
|
||||||
}
|
}
|
||||||
|
@ -138,7 +126,7 @@ void JsonWriteNumberAsStringProp(char*& dest, const char* name, T value)
|
||||||
{
|
{
|
||||||
JsonWritePropName(dest, name);
|
JsonWritePropName(dest, name);
|
||||||
*dest++ = '"';
|
*dest++ = '"';
|
||||||
NumberToString(dest, value);
|
JsonWriteNumber(dest, value);
|
||||||
*dest++ = '"';
|
*dest++ = '"';
|
||||||
JsonWritePropSep(dest);
|
JsonWritePropSep(dest);
|
||||||
}
|
}
|
||||||
|
@ -147,7 +135,7 @@ template<typename T>
|
||||||
void JsonWriteNumberProp(char*& dest, const char* name, T value)
|
void JsonWriteNumberProp(char*& dest, const char* name, T value)
|
||||||
{
|
{
|
||||||
JsonWritePropName(dest, name);
|
JsonWritePropName(dest, name);
|
||||||
NumberToString(dest, value);
|
JsonWriteNumber(dest, value);
|
||||||
JsonWritePropSep(dest);
|
JsonWritePropSep(dest);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -221,11 +209,14 @@ void JsonWriteRichPresenceObj(char*& dest, const DiscordRichPresence* presence)
|
||||||
*(dest - 1) = '}';
|
*(dest - 1) = '}';
|
||||||
}
|
}
|
||||||
|
|
||||||
void OpenConnection()
|
void ConnectionOpen()
|
||||||
{
|
{
|
||||||
for (;;) {
|
for (;;) {
|
||||||
PipeHandle = CreateFileW(PipeName, GENERIC_READ | GENERIC_WRITE, 0, nullptr, OPEN_EXISTING, 0, nullptr);
|
PipeHandle = CreateFileW(PipeName, GENERIC_READ | GENERIC_WRITE, 0, nullptr, OPEN_EXISTING, 0, nullptr);
|
||||||
if (PipeHandle != INVALID_HANDLE_VALUE) {
|
if (PipeHandle != INVALID_HANDLE_VALUE) {
|
||||||
|
if (Handlers.ready) {
|
||||||
|
Handlers.ready();
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -241,7 +232,7 @@ void OpenConnection()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CloseConnection()
|
void ConnectionClose()
|
||||||
{
|
{
|
||||||
CloseHandle(PipeHandle);
|
CloseHandle(PipeHandle);
|
||||||
PipeHandle = INVALID_HANDLE_VALUE;
|
PipeHandle = INVALID_HANDLE_VALUE;
|
||||||
|
@ -250,6 +241,20 @@ void CloseConnection()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ConnectionWrite(const void* data, size_t length)
|
||||||
|
{
|
||||||
|
if (PipeHandle == INVALID_HANDLE_VALUE) {
|
||||||
|
ConnectionOpen();
|
||||||
|
if (PipeHandle == INVALID_HANDLE_VALUE) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
BOOL success = WriteFile(PipeHandle, &Frame, Frame.length, nullptr, nullptr);
|
||||||
|
if (!success) {
|
||||||
|
ConnectionClose();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
} // anonymous namespace
|
} // anonymous namespace
|
||||||
|
|
||||||
void Discord_Initialize(const char* applicationId, DiscordEventHandlers* handlers)
|
void Discord_Initialize(const char* applicationId, DiscordEventHandlers* handlers)
|
||||||
|
@ -262,38 +267,22 @@ void Discord_Initialize(const char* applicationId, DiscordEventHandlers* handler
|
||||||
Handlers = {};
|
Handlers = {};
|
||||||
}
|
}
|
||||||
|
|
||||||
OpenConnection();
|
ConnectionOpen();
|
||||||
|
|
||||||
if (PipeHandle != INVALID_HANDLE_VALUE) {
|
|
||||||
if (Handlers.ready) {
|
|
||||||
Handlers.ready();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Discord_Shutdown()
|
void Discord_Shutdown()
|
||||||
{
|
{
|
||||||
Handlers = {};
|
Handlers = {};
|
||||||
CloseConnection();
|
ConnectionClose();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Discord_UpdatePresence(const DiscordRichPresence* presence)
|
void Discord_UpdatePresence(const DiscordRichPresence* presence)
|
||||||
{
|
{
|
||||||
if (PipeHandle == INVALID_HANDLE_VALUE) {
|
|
||||||
OpenConnection();
|
|
||||||
if (PipeHandle == INVALID_HANDLE_VALUE) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
char* jsonWrite = Frame.message;
|
char* jsonWrite = Frame.message;
|
||||||
|
|
||||||
JsonWriteRichPresenceObj(jsonWrite, presence);
|
JsonWriteRichPresenceObj(jsonWrite, presence);
|
||||||
|
|
||||||
Frame.length = sizeof(uint32_t) + (jsonWrite - Frame.message);
|
Frame.length = sizeof(uint32_t) + (jsonWrite - Frame.message);
|
||||||
BOOL success = WriteFile(PipeHandle, &Frame, Frame.length, nullptr, nullptr);
|
|
||||||
|
|
||||||
if (!success) {
|
ConnectionWrite(&Frame, Frame.length);
|
||||||
CloseConnection();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue