Fixed spaces -> tabs and a 32/64 bit issue
This commit is contained in:
parent
796919294a
commit
ec0f7ff79f
12
client.d
12
client.d
|
@ -70,8 +70,8 @@ int main(string[] args)
|
||||||
ubyte[] message = msgpack.pack(request);
|
ubyte[] message = msgpack.pack(request);
|
||||||
ubyte[] messageBuffer = new ubyte[message.length + message.length.sizeof];
|
ubyte[] messageBuffer = new ubyte[message.length + message.length.sizeof];
|
||||||
auto messageLength = message.length;
|
auto messageLength = message.length;
|
||||||
messageBuffer[0 .. 8] = (cast(ubyte*) &messageLength)[0 .. 8];
|
messageBuffer[0 .. size_t.sizeof] = (cast(ubyte*) &messageLength)[0 .. size_t.sizeof];
|
||||||
messageBuffer[8 .. $] = message[];
|
messageBuffer[size_t.sizeof .. $] = message[];
|
||||||
return socket.send(messageBuffer) == messageBuffer.length ? 0 : 1;
|
return socket.send(messageBuffer) == messageBuffer.length ? 0 : 1;
|
||||||
}
|
}
|
||||||
else if (importPaths.length > 0)
|
else if (importPaths.length > 0)
|
||||||
|
@ -87,8 +87,8 @@ int main(string[] args)
|
||||||
ubyte[] message = msgpack.pack(request);
|
ubyte[] message = msgpack.pack(request);
|
||||||
ubyte[] messageBuffer = new ubyte[message.length + message.length.sizeof];
|
ubyte[] messageBuffer = new ubyte[message.length + message.length.sizeof];
|
||||||
auto messageLength = message.length;
|
auto messageLength = message.length;
|
||||||
messageBuffer[0 .. 8] = (cast(ubyte*) &messageLength)[0 .. 8];
|
messageBuffer[0 .. size_t.sizeof] = (cast(ubyte*) &messageLength)[0 .. size_t.sizeof];
|
||||||
messageBuffer[8 .. $] = message[];
|
messageBuffer[size_t.sizeof .. $] = message[];
|
||||||
return socket.send(messageBuffer) == messageBuffer.length ? 0 : 1;
|
return socket.send(messageBuffer) == messageBuffer.length ? 0 : 1;
|
||||||
}
|
}
|
||||||
else if (cursorPos == size_t.max)
|
else if (cursorPos == size_t.max)
|
||||||
|
@ -141,8 +141,8 @@ int main(string[] args)
|
||||||
socket.blocking = true;
|
socket.blocking = true;
|
||||||
ubyte[] messageBuffer = new ubyte[message.length + message.length.sizeof];
|
ubyte[] messageBuffer = new ubyte[message.length + message.length.sizeof];
|
||||||
auto messageLength = message.length;
|
auto messageLength = message.length;
|
||||||
messageBuffer[0 .. 8] = (cast(ubyte*) &messageLength)[0 .. 8];
|
messageBuffer[0 .. size_t.sizeof] = (cast(ubyte*) &messageLength)[0 .. size_t.sizeof];
|
||||||
messageBuffer[8 .. $] = message[];
|
messageBuffer[size_t.sizeof .. $] = message[];
|
||||||
auto bytesSent = socket.send(messageBuffer);
|
auto bytesSent = socket.send(messageBuffer);
|
||||||
|
|
||||||
// Get response and write it out
|
// Get response and write it out
|
||||||
|
|
102
server.d
102
server.d
|
@ -37,29 +37,29 @@ enum CONFIG_FILE_PATH = "~/.config/dcd";
|
||||||
|
|
||||||
int main(string[] args)
|
int main(string[] args)
|
||||||
{
|
{
|
||||||
ushort port = 9166;
|
ushort port = 9166;
|
||||||
bool help;
|
bool help;
|
||||||
string[] importPaths;
|
string[] importPaths;
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
getopt(args, "port|p", &port, "I", &importPaths, "help|h", &help);
|
getopt(args, "port|p", &port, "I", &importPaths, "help|h", &help);
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
stderr.writeln(e.msg);
|
stderr.writeln(e.msg);
|
||||||
printHelp(args[0]);
|
printHelp(args[0]);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
importPaths ~= loadConfiguredImportDirs();
|
importPaths ~= loadConfiguredImportDirs();
|
||||||
|
|
||||||
auto socket = new TcpSocket(AddressFamily.INET);
|
auto socket = new TcpSocket(AddressFamily.INET);
|
||||||
socket.blocking = true;
|
socket.blocking = true;
|
||||||
socket.setOption(SocketOptionLevel.SOCKET, SocketOption.REUSEADDR, true);
|
socket.setOption(SocketOptionLevel.SOCKET, SocketOption.REUSEADDR, true);
|
||||||
socket.bind(new InternetAddress("127.0.0.1", port));
|
socket.bind(new InternetAddress("127.0.0.1", port));
|
||||||
socket.listen(0);
|
socket.listen(0);
|
||||||
scope (exit)
|
scope (exit)
|
||||||
{
|
{
|
||||||
writeln("Shutting down sockets...");
|
writeln("Shutting down sockets...");
|
||||||
socket.shutdown(SocketShutdown.BOTH);
|
socket.shutdown(SocketShutdown.BOTH);
|
||||||
|
@ -71,42 +71,42 @@ int main(string[] args)
|
||||||
ModuleCache.addImportPath(path);
|
ModuleCache.addImportPath(path);
|
||||||
writeln("Import directories: ", ModuleCache.getImportPaths());
|
writeln("Import directories: ", ModuleCache.getImportPaths());
|
||||||
|
|
||||||
ubyte[1024 * 1024 * 4] buffer = void; // 4 megabytes should be enough for anybody...
|
ubyte[] buffer = new ubyte[1024 * 1024 * 4]; // 4 megabytes should be enough for anybody...
|
||||||
|
|
||||||
writeln("Startup complete");
|
writeln("Startup complete");
|
||||||
|
|
||||||
while (true)
|
while (true)
|
||||||
{
|
{
|
||||||
auto s = socket.accept();
|
auto s = socket.accept();
|
||||||
s.blocking = true;
|
s.blocking = true;
|
||||||
scope (exit)
|
scope (exit)
|
||||||
{
|
{
|
||||||
s.shutdown(SocketShutdown.BOTH);
|
s.shutdown(SocketShutdown.BOTH);
|
||||||
s.close();
|
s.close();
|
||||||
}
|
}
|
||||||
ptrdiff_t bytesReceived = s.receive(buffer);
|
ptrdiff_t bytesReceived = s.receive(buffer);
|
||||||
size_t messageLength;
|
size_t messageLength;
|
||||||
// bit magic!
|
// bit magic!
|
||||||
(cast(ubyte*) &messageLength)[0..8] = buffer[0..8];
|
(cast(ubyte*) &messageLength)[0..size_t.sizeof] = buffer[0..size_t.sizeof];
|
||||||
while (bytesReceived < messageLength + 8)
|
while (bytesReceived < messageLength + size_t.sizeof)
|
||||||
{
|
{
|
||||||
auto b = s.receive(buffer[bytesReceived .. $]);
|
auto b = s.receive(buffer[bytesReceived .. $]);
|
||||||
if (b == Socket.ERROR)
|
if (b == Socket.ERROR)
|
||||||
{
|
{
|
||||||
bytesReceived = Socket.ERROR;
|
bytesReceived = Socket.ERROR;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
bytesReceived += b;
|
bytesReceived += b;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (bytesReceived == Socket.ERROR)
|
if (bytesReceived == Socket.ERROR)
|
||||||
{
|
{
|
||||||
writeln("Socket recieve failed");
|
writeln("Socket recieve failed");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
AutocompleteRequest request;
|
AutocompleteRequest request;
|
||||||
msgpack.unpack(buffer[8 .. bytesReceived], request);
|
msgpack.unpack(buffer[size_t.sizeof .. bytesReceived], request);
|
||||||
if (request.kind == RequestKind.addImport)
|
if (request.kind == RequestKind.addImport)
|
||||||
{
|
{
|
||||||
foreach (path; request.importPaths)
|
foreach (path; request.importPaths)
|
||||||
|
@ -115,7 +115,7 @@ int main(string[] args)
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
else if (request.kind == RequestKind.clearCache)
|
else if (request.kind == RequestKind.clearCache)
|
||||||
{
|
{
|
||||||
writeln("Clearing cache.");
|
writeln("Clearing cache.");
|
||||||
ModuleCache.clear();
|
ModuleCache.clear();
|
||||||
|
@ -126,12 +126,12 @@ int main(string[] args)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
AutocompleteResponse response = complete(request, importPaths);
|
AutocompleteResponse response = complete(request, importPaths);
|
||||||
ubyte[] responseBytes = msgpack.pack(response);
|
ubyte[] responseBytes = msgpack.pack(response);
|
||||||
assert(s.send(responseBytes) == responseBytes.length);
|
assert(s.send(responseBytes) == responseBytes.length);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue