Make naming better, move some code around.

This commit is contained in:
Chris Marsh 2017-06-29 16:04:44 -07:00
parent 22e34d48c9
commit 0768b06ec1

View file

@ -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();
}
} }