diff options
Diffstat (limited to 'adb/shell_service.cpp')
-rw-r--r-- | adb/shell_service.cpp | 28 |
1 files changed, 18 insertions, 10 deletions
diff --git a/adb/shell_service.cpp b/adb/shell_service.cpp index e3fde2691..2e41fe649 100644 --- a/adb/shell_service.cpp +++ b/adb/shell_service.cpp @@ -175,8 +175,8 @@ bool CreateSocketpair(ScopedFd* fd1, ScopedFd* fd2) { class Subprocess { public: - Subprocess(const std::string& command, SubprocessType type, - SubprocessProtocol protocol); + Subprocess(const std::string& command, const char* terminal_type, + SubprocessType type, SubprocessProtocol protocol); ~Subprocess(); const std::string& command() const { return command_; } @@ -207,6 +207,7 @@ class Subprocess { ScopedFd* PassOutput(ScopedFd* sfd, ShellProtocol::Id id); const std::string command_; + const std::string terminal_type_; SubprocessType type_; SubprocessProtocol protocol_; pid_t pid_ = -1; @@ -220,9 +221,12 @@ class Subprocess { DISALLOW_COPY_AND_ASSIGN(Subprocess); }; -Subprocess::Subprocess(const std::string& command, SubprocessType type, - SubprocessProtocol protocol) - : command_(command), type_(type), protocol_(protocol) { +Subprocess::Subprocess(const std::string& command, const char* terminal_type, + SubprocessType type, SubprocessProtocol protocol) + : command_(command), + terminal_type_(terminal_type ? terminal_type : ""), + type_(type), + protocol_(protocol) { } Subprocess::~Subprocess() { @@ -290,6 +294,9 @@ bool Subprocess::ForkAndExec() { setenv("SHELL", pw->pw_shell, 1); setenv("USER", pw->pw_name, 1); } + if (!terminal_type_.empty()) { + setenv("TERM", terminal_type_.c_str(), 1); + } if (is_interactive()) { execl(_PATH_BSHELL, _PATH_BSHELL, "-", nullptr); @@ -644,13 +651,14 @@ void Subprocess::WaitForExit() { } // namespace -int StartSubprocess(const char *name, SubprocessType type, - SubprocessProtocol protocol) { - D("starting %s subprocess (protocol=%s): '%s'", +int StartSubprocess(const char* name, const char* terminal_type, + SubprocessType type, SubprocessProtocol protocol) { + D("starting %s subprocess (protocol=%s, TERM=%s): '%s'", type == SubprocessType::kRaw ? "raw" : "PTY", - protocol == SubprocessProtocol::kNone ? "none" : "shell", name); + protocol == SubprocessProtocol::kNone ? "none" : "shell", + terminal_type, name); - Subprocess* subprocess = new Subprocess(name, type, protocol); + Subprocess* subprocess = new Subprocess(name, terminal_type, type, protocol); if (!subprocess) { LOG(ERROR) << "failed to allocate new subprocess"; return -1; |