summaryrefslogtreecommitdiff
path: root/source/core/slang-command-line.h
diff options
context:
space:
mode:
authorjsmall-nvidia <jsmall@nvidia.com>2021-11-10 17:33:22 -0500
committerGitHub <noreply@github.com>2021-11-10 17:33:22 -0500
commit8a9e518371df03b3f382e0fe869da83751fdda0b (patch)
tree749f9c1c79acd375ec3ee97e45a10007dd6632fa /source/core/slang-command-line.h
parent95e82acc0b32c81a9c6ac39708d18a423d8c7b1e (diff)
Interprocess communication via pipes (#2009)
* #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.
Diffstat (limited to 'source/core/slang-command-line.h')
-rw-r--r--source/core/slang-command-line.h60
1 files changed, 60 insertions, 0 deletions
diff --git a/source/core/slang-command-line.h b/source/core/slang-command-line.h
new file mode 100644
index 000000000..85ba1a331
--- /dev/null
+++ b/source/core/slang-command-line.h
@@ -0,0 +1,60 @@
+// slang-command-line.h
+#ifndef SLANG_COMMAND_LINE_H
+#define SLANG_COMMAND_LINE_H
+
+#include "slang-string.h"
+#include "slang-list.h"
+
+namespace Slang {
+
+struct CommandLine
+{
+ enum class ExecutableType
+ {
+ Unknown, ///< The executable is not specified
+ Path, ///< The executable is set as a path (ie won't be searched for)
+ Filename, ///< The executable is set as a filename
+ };
+
+ /// Add args - assumed unescaped
+ void addArg(const String& in) { m_args.add(in); }
+ void addArgs(const String* args, Int argsCount) { for (Int i = 0; i < argsCount; ++i) addArg(args[i]); }
+
+ /// Find the index of an arg which is exact match for slice
+ SLANG_INLINE Index findArgIndex(const UnownedStringSlice& slice) const { return m_args.indexOf(slice); }
+
+ /// Set the executable path.
+ /// NOTE! On some targets the executable path *must* include an extension to be able to start as a process
+ void setExecutablePath(const String& path) { m_executableType = ExecutableType::Path; m_executable = path; }
+
+ /// Set the executable path from a base directory and an executable name (no suffix such as '.exe' needed)
+ void setExecutable(const String& dir, const String& name);
+
+ /// Set a filename (such that the path will be looked up
+ void setExecutableFilename(const String& filename) { m_executableType = ExecutableType::Filename; m_executable = filename; }
+
+ /// For handling args where the switch is placed directly in front of the path
+ void addPrefixPathArg(const char* prefix, const String& path, const char* pathPostfix = nullptr);
+
+ /// Get the total number of args
+ SLANG_FORCE_INLINE Index getArgCount() const { return m_args.getCount(); }
+
+ /// Reset to the initial state
+ void reset() { *this = CommandLine(); }
+
+ /// Append the command line to out
+ void append(StringBuilder& out) const;
+ /// convert into a string
+ String toString() const;
+
+ /// Ctor
+ CommandLine():m_executableType(ExecutableType::Unknown) {}
+
+ ExecutableType m_executableType; ///< How the executable is specified
+ String m_executable; ///< Executable to run. Note that the executable is never escaped.
+ List<String> m_args; ///< The arguments (Stored *unescaped*)
+};
+
+}
+
+#endif // SLANG_COMMAND_LINE_H