adb: split shell_service.h into client/daemon/protocol parts.
Test: treehugger Change-Id: I67042f6b29a8a07619b8d56e7376d49b956a840c
This commit is contained in:
parent
edec033b26
commit
86acb863ff
8 changed files with 41 additions and 37 deletions
|
@ -59,7 +59,7 @@
|
|||
#include "client/file_sync_client.h"
|
||||
#include "commandline.h"
|
||||
#include "services.h"
|
||||
#include "shell_service.h"
|
||||
#include "shell_protocol.h"
|
||||
#include "sysdeps/chrono.h"
|
||||
#include "sysdeps/memory.h"
|
||||
|
||||
|
|
|
@ -106,6 +106,7 @@
|
|||
#include "adb_unique_fd.h"
|
||||
#include "adb_utils.h"
|
||||
#include "security_log_tags.h"
|
||||
#include "shell_protocol.h"
|
||||
|
||||
namespace {
|
||||
|
||||
|
|
34
adb/daemon/shell_service.h
Normal file
34
adb/daemon/shell_service.h
Normal file
|
@ -0,0 +1,34 @@
|
|||
/*
|
||||
* Copyright (C) 2018 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
|
||||
enum class SubprocessType {
|
||||
kPty,
|
||||
kRaw,
|
||||
};
|
||||
|
||||
enum class SubprocessProtocol {
|
||||
kNone,
|
||||
kShell,
|
||||
};
|
||||
|
||||
// Forks and starts a new shell subprocess. If |name| is empty an interactive
|
||||
// shell is started, otherwise |name| is executed non-interactively.
|
||||
//
|
||||
// Returns an open FD connected to the subprocess or -1 on failure.
|
||||
int StartSubprocess(const char* name, const char* terminal_type, SubprocessType type,
|
||||
SubprocessProtocol protocol);
|
|
@ -27,6 +27,7 @@
|
|||
|
||||
#include "adb.h"
|
||||
#include "adb_io.h"
|
||||
#include "shell_protocol.h"
|
||||
#include "sysdeps.h"
|
||||
|
||||
class ShellServiceTest : public ::testing::Test {
|
||||
|
|
|
@ -54,10 +54,10 @@
|
|||
#include "daemon/file_sync_service.h"
|
||||
#include "daemon/framebuffer_service.h"
|
||||
#include "daemon/set_verity_enable_state_service.h"
|
||||
#include "daemon/shell_service.h"
|
||||
#endif
|
||||
#include "remount_service.h"
|
||||
#include "services.h"
|
||||
#include "shell_service.h"
|
||||
#include "socket_spec.h"
|
||||
#include "sysdeps.h"
|
||||
#include "transport.h"
|
||||
|
|
|
@ -14,16 +14,7 @@
|
|||
* limitations under the License.
|
||||
*/
|
||||
|
||||
// This file contains classes and functionality to launch shell subprocesses
|
||||
// in adbd and communicate between those subprocesses and the adb client.
|
||||
//
|
||||
// The main features exposed here are:
|
||||
// 1. A ShellPacket class to wrap data in a simple protocol. Both adbd and
|
||||
// the adb client use this class to transmit data between them.
|
||||
// 2. Functions to launch a subprocess on the adbd side.
|
||||
|
||||
#ifndef SHELL_SERVICE_H_
|
||||
#define SHELL_SERVICE_H_
|
||||
#pragma once
|
||||
|
||||
#include <stdint.h>
|
||||
|
||||
|
@ -124,26 +115,3 @@ class ShellProtocol {
|
|||
|
||||
DISALLOW_COPY_AND_ASSIGN(ShellProtocol);
|
||||
};
|
||||
|
||||
#if !ADB_HOST
|
||||
|
||||
enum class SubprocessType {
|
||||
kPty,
|
||||
kRaw,
|
||||
};
|
||||
|
||||
enum class SubprocessProtocol {
|
||||
kNone,
|
||||
kShell,
|
||||
};
|
||||
|
||||
// Forks and starts a new shell subprocess. If |name| is empty an interactive
|
||||
// shell is started, otherwise |name| is executed non-interactively.
|
||||
//
|
||||
// Returns an open FD connected to the subprocess or -1 on failure.
|
||||
int StartSubprocess(const char* name, const char* terminal_type,
|
||||
SubprocessType type, SubprocessProtocol protocol);
|
||||
|
||||
#endif // !ADB_HOST
|
||||
|
||||
#endif // SHELL_SERVICE_H_
|
|
@ -14,7 +14,7 @@
|
|||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include "shell_service.h"
|
||||
#include "shell_protocol.h"
|
||||
|
||||
#include <string.h>
|
||||
|
||||
|
|
|
@ -14,7 +14,7 @@
|
|||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include "shell_service.h"
|
||||
#include "shell_protocol.h"
|
||||
|
||||
#include <gtest/gtest.h>
|
||||
|
||||
|
|
Loading…
Reference in a new issue