From c51f1e27f0e307a80a57a840b2337e3226b3c2be Mon Sep 17 00:00:00 2001 From: jsmall-nvidia Date: Tue, 16 Nov 2021 08:54:55 -0500 Subject: Support around JSON-RPC (#2014) * #include an absolute path didn't work - because paths were taken to always be relative. * Use 'Process' to communicate with an command line tool. * Remove slang-win-stream * Tidy up windows ProcessUtil. * First version of BufferedReadStream. * Windows working IPC for steams. * Test proxy count option. * Split Process/ProcessUtil. Process is platform dependant. ProcessUtil are functions that are platform independent. * First implementation of Unix Process interface. * Unix process compiles on cygwin. * Fix typo in unix process. * Separate unix pipe stream error of invalid access, from pipe availability. * Fix in standard line extraction. * Make fd non blocking. * Fix issues with Windows Process streams. * Added UnixPipe. * Some fixes around UnixPipeStream. * Make a unix stream closed explicit. * Hack to debug linux process/stream. * Revert to old linux pipe handling. * Pass executable path for unit tests. Split out CommandLine into own source. * Small improvements in process/command line. * Check process behavior with crash. * Make stderr and stdout unbuffered for crash testing. * Only turn disable buffering in crash test. * Disable crash test on CI. * Fix crash on clang/linux. * Enable crash test. Remove _appendBuffer as can use StreamUtil functionality. * Added inital processing for http headers. * Small improvements to HttpHeader. * First pass HTTPPacketConnection working on windows. * Enable other Process communication tests. * Update comments. * WIP JSON RPC. * Add terminate to Process. Made JSONRPC a Util. * Small tidy up around HTTPPacketConnection. * Improve process termination options. Co-authored-by: Yong He --- tools/test-proxy/test-proxy-main.cpp | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) (limited to 'tools/test-proxy/test-proxy-main.cpp') diff --git a/tools/test-proxy/test-proxy-main.cpp b/tools/test-proxy/test-proxy-main.cpp index 9a3523d71..bcb8f2a92 100644 --- a/tools/test-proxy/test-proxy-main.cpp +++ b/tools/test-proxy/test-proxy-main.cpp @@ -223,17 +223,17 @@ static SlangResult _httpReflect(int argc, const char* const* argv) RefPtr readStream(new BufferedReadStream(stdinStream)); - RefPtr packetConnection = new HTTPPacketConnection(readStream, stdoutStream); + RefPtr connection = new HTTPPacketConnection(readStream, stdoutStream); - while (packetConnection->isActive()) + while (connection->isActive()) { // Block waiting for content (or error/closed) - SLANG_RETURN_ON_FAIL(packetConnection->waitForContent()); + SLANG_RETURN_ON_FAIL(connection->waitForResult()); // If we have content do something with it - if (packetConnection->hasContent()) + if (connection->hasContent()) { - auto content = packetConnection->getContent(); + auto content = connection->getContent(); // If it just holds 'end' then we are done const UnownedStringSlice slice((const char*)content.begin(), content.getCount()); @@ -244,10 +244,10 @@ static SlangResult _httpReflect(int argc, const char* const* argv) } // Else reflect it back - SLANG_RETURN_ON_FAIL(packetConnection->write(content.begin(), content.getCount())); + SLANG_RETURN_ON_FAIL(connection->write(content.begin(), content.getCount())); // Consume that content/packet - packetConnection->consumeContent(); + connection->consumeContent(); } } -- cgit v1.2.3