Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
34d5811420 | ||
|
|
86e28a6e25 | ||
|
|
9f113bdb93 | ||
|
|
8670d6db58 |
@@ -9,7 +9,8 @@ homepage = "https://github.com/cocool97/adb_client"
|
|||||||
keywords = ["adb", "android", "tcp", "usb"]
|
keywords = ["adb", "android", "tcp", "usb"]
|
||||||
license = "MIT"
|
license = "MIT"
|
||||||
repository = "https://github.com/cocool97/adb_client"
|
repository = "https://github.com/cocool97/adb_client"
|
||||||
version = "2.1.15"
|
version = "2.1.16"
|
||||||
|
rust-version = "1.85.1"
|
||||||
|
|
||||||
# To build locally when working on a new release
|
# To build locally when working on a new release
|
||||||
[patch.crates-io]
|
[patch.crates-io]
|
||||||
|
|||||||
@@ -8,6 +8,9 @@
|
|||||||
<a href="https://crates.io/crates/adb_client">
|
<a href="https://crates.io/crates/adb_client">
|
||||||
<img alt="crates.io" src="https://img.shields.io/crates/v/adb_client.svg"/>
|
<img alt="crates.io" src="https://img.shields.io/crates/v/adb_client.svg"/>
|
||||||
</a>
|
</a>
|
||||||
|
<a href="https://crates.io/crates/adb_client">
|
||||||
|
<img alt="msrv" src="https://img.shields.io/crates/msrv/adb_client/latest"/>
|
||||||
|
</a>
|
||||||
<a href="https://github.com/cocool97/adb_client/actions">
|
<a href="https://github.com/cocool97/adb_client/actions">
|
||||||
<img alt="ci status" src="https://github.com/cocool97/adb_client/actions/workflows/rust-build.yml/badge.svg"/>
|
<img alt="ci status" src="https://github.com/cocool97/adb_client/actions/workflows/rust-build.yml/badge.svg"/>
|
||||||
</a>
|
</a>
|
||||||
|
|||||||
@@ -7,6 +7,7 @@ license.workspace = true
|
|||||||
name = "adb_cli"
|
name = "adb_cli"
|
||||||
readme = "README.md"
|
readme = "README.md"
|
||||||
repository.workspace = true
|
repository.workspace = true
|
||||||
|
rust-version.workspace = true
|
||||||
version.workspace = true
|
version.workspace = true
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
|
|||||||
@@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
[](./LICENSE-MIT)
|
[](./LICENSE-MIT)
|
||||||

|

|
||||||
|

|
||||||
|
|
||||||
Rust binary providing an improved version of `adb` CLI.
|
Rust binary providing an improved version of `adb` CLI.
|
||||||
|
|
||||||
@@ -10,7 +11,7 @@ Rust binary providing an improved version of `adb` CLI.
|
|||||||
This crate provides a lightweight binary based on the `adb_client` crate. You can install it by running the following command :
|
This crate provides a lightweight binary based on the `adb_client` crate. You can install it by running the following command :
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
cargo install adb_cli
|
cargo install adb_cli
|
||||||
```
|
```
|
||||||
|
|
||||||
Usage is quite simple, and tends to look like `adb`:
|
Usage is quite simple, and tends to look like `adb`:
|
||||||
@@ -64,4 +65,4 @@ Options:
|
|||||||
-p, --product-id <PID> Hexadecimal product id of this USB device
|
-p, --product-id <PID> Hexadecimal product id of this USB device
|
||||||
-k, --private-key <PATH_TO_PRIVATE_KEY> Path to a custom private key to use for authentication
|
-k, --private-key <PATH_TO_PRIVATE_KEY> Path to a custom private key to use for authentication
|
||||||
-h, --help Print help
|
-h, --help Print help
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ pub fn handle_host_commands(server_command: ServerCommand<HostCommand>) -> Resul
|
|||||||
match server_command.command {
|
match server_command.command {
|
||||||
HostCommand::Version => {
|
HostCommand::Version => {
|
||||||
let version = adb_server.version()?;
|
let version = adb_server.version()?;
|
||||||
log::info!("Android Debug Bridge version {}", version);
|
log::info!("Android Debug Bridge version {version}");
|
||||||
log::info!("Package version {}-rust", std::env!("CARGO_PKG_VERSION"));
|
log::info!("Package version {}-rust", std::env!("CARGO_PKG_VERSION"));
|
||||||
}
|
}
|
||||||
HostCommand::Kill => {
|
HostCommand::Kill => {
|
||||||
@@ -18,18 +18,18 @@ pub fn handle_host_commands(server_command: ServerCommand<HostCommand>) -> Resul
|
|||||||
if long {
|
if long {
|
||||||
log::info!("List of devices attached (extended)");
|
log::info!("List of devices attached (extended)");
|
||||||
for device in adb_server.devices_long()? {
|
for device in adb_server.devices_long()? {
|
||||||
log::info!("{}", device);
|
log::info!("{device}");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
log::info!("List of devices attached");
|
log::info!("List of devices attached");
|
||||||
for device in adb_server.devices()? {
|
for device in adb_server.devices()? {
|
||||||
log::info!("{}", device);
|
log::info!("{device}");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
HostCommand::TrackDevices => {
|
HostCommand::TrackDevices => {
|
||||||
let callback = |device: DeviceShort| {
|
let callback = |device: DeviceShort| {
|
||||||
log::info!("{}", device);
|
log::info!("{device}");
|
||||||
Ok(())
|
Ok(())
|
||||||
};
|
};
|
||||||
log::info!("Live list of devices attached");
|
log::info!("Live list of devices attached");
|
||||||
@@ -65,7 +65,7 @@ pub fn handle_host_commands(server_command: ServerCommand<HostCommand>) -> Resul
|
|||||||
MdnsCommand::Services => {
|
MdnsCommand::Services => {
|
||||||
log::info!("List of discovered mdns services");
|
log::info!("List of discovered mdns services");
|
||||||
for service in adb_server.mdns_services()? {
|
for service in adb_server.mdns_services()? {
|
||||||
log::info!("{}", service);
|
log::info!("{service}");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -132,10 +132,10 @@ fn main() -> Result<()> {
|
|||||||
}
|
}
|
||||||
DeviceCommands::Stat { path } => {
|
DeviceCommands::Stat { path } => {
|
||||||
let stat_response = device.stat(&path)?;
|
let stat_response = device.stat(&path)?;
|
||||||
println!("{}", stat_response);
|
println!("{stat_response}");
|
||||||
}
|
}
|
||||||
DeviceCommands::Reboot { reboot_type } => {
|
DeviceCommands::Reboot { reboot_type } => {
|
||||||
log::info!("Reboots device in mode {:?}", reboot_type);
|
log::info!("Reboots device in mode {reboot_type:?}");
|
||||||
device.reboot(reboot_type.into())?
|
device.reboot(reboot_type.into())?
|
||||||
}
|
}
|
||||||
DeviceCommands::Push { filename, path } => {
|
DeviceCommands::Push { filename, path } => {
|
||||||
@@ -152,7 +152,7 @@ fn main() -> Result<()> {
|
|||||||
device.install(&path)?;
|
device.install(&path)?;
|
||||||
}
|
}
|
||||||
DeviceCommands::Uninstall { package } => {
|
DeviceCommands::Uninstall { package } => {
|
||||||
log::info!("Uninstalling the package {}...", package);
|
log::info!("Uninstalling the package {package}...");
|
||||||
device.uninstall(&package)?;
|
device.uninstall(&package)?;
|
||||||
}
|
}
|
||||||
DeviceCommands::Framebuffer { path } => {
|
DeviceCommands::Framebuffer { path } => {
|
||||||
|
|||||||
@@ -7,6 +7,7 @@ license.workspace = true
|
|||||||
name = "adb_client"
|
name = "adb_client"
|
||||||
readme = "README.md"
|
readme = "README.md"
|
||||||
repository.workspace = true
|
repository.workspace = true
|
||||||
|
rust-version.workspace = true
|
||||||
version.workspace = true
|
version.workspace = true
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
|
|||||||
@@ -3,6 +3,7 @@
|
|||||||
[](./LICENSE-MIT)
|
[](./LICENSE-MIT)
|
||||||
[](https://docs.rs/adb_client)
|
[](https://docs.rs/adb_client)
|
||||||
[](https://crates.io/crates/adb_client)
|
[](https://crates.io/crates/adb_client)
|
||||||
|

|
||||||
|
|
||||||
Rust library implementing ADB protocol.
|
Rust library implementing ADB protocol.
|
||||||
|
|
||||||
|
|||||||
@@ -144,8 +144,7 @@ impl<T: ADBMessageTransport> ADBMessageDevice<T> {
|
|||||||
MessageCommand::Write => return Ok(()),
|
MessageCommand::Write => return Ok(()),
|
||||||
c => {
|
c => {
|
||||||
return Err(RustADBError::ADBRequestFailed(format!(
|
return Err(RustADBError::ADBRequestFailed(format!(
|
||||||
"Wrong command received {}",
|
"Wrong command received {c}"
|
||||||
c
|
|
||||||
)));
|
)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -19,15 +19,20 @@ use crate::device::adb_transport_message::{AUTH_RSAPUBLICKEY, AUTH_SIGNATURE, AU
|
|||||||
use crate::{Result, RustADBError, USBTransport};
|
use crate::{Result, RustADBError, USBTransport};
|
||||||
|
|
||||||
pub fn read_adb_private_key<P: AsRef<Path>>(private_key_path: P) -> Result<Option<ADBRsaKey>> {
|
pub fn read_adb_private_key<P: AsRef<Path>>(private_key_path: P) -> Result<Option<ADBRsaKey>> {
|
||||||
Ok(read_to_string(private_key_path.as_ref()).map(|pk| {
|
// Try to read the private key file from given path
|
||||||
match ADBRsaKey::new_from_pkcs8(&pk) {
|
// If the file is not found, return None
|
||||||
Ok(pk) => Some(pk),
|
// If there is another error while reading the file, return this error
|
||||||
Err(e) => {
|
// Else, return the private key content
|
||||||
log::error!("Error while create RSA private key: {e}");
|
let pk = match read_to_string(private_key_path.as_ref()) {
|
||||||
None
|
Ok(pk) => pk,
|
||||||
}
|
Err(e) if e.kind() == std::io::ErrorKind::NotFound => return Ok(None),
|
||||||
}
|
Err(e) => return Err(e.into()),
|
||||||
})?)
|
};
|
||||||
|
|
||||||
|
match ADBRsaKey::new_from_pkcs8(&pk) {
|
||||||
|
Ok(pk) => Ok(Some(pk)),
|
||||||
|
Err(e) => Err(e),
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Search for adb devices with known interface class and subclass values
|
/// Search for adb devices with known interface class and subclass values
|
||||||
@@ -51,8 +56,7 @@ pub fn search_adb_devices() -> Result<Option<(u16, u16)>> {
|
|||||||
(None, _) => Ok(None),
|
(None, _) => Ok(None),
|
||||||
(Some(identifiers), None) => Ok(Some(*identifiers)),
|
(Some(identifiers), None) => Ok(Some(*identifiers)),
|
||||||
(Some((vid1, pid1)), Some((vid2, pid2))) => Err(RustADBError::DeviceNotFound(format!(
|
(Some((vid1, pid1)), Some((vid2, pid2))) => Err(RustADBError::DeviceNotFound(format!(
|
||||||
"Found two Android devices {:04x}:{:04x} and {:04x}:{:04x}",
|
"Found two Android devices {vid1:04x}:{pid1:04x} and {vid2:04x}:{pid2:04x}",
|
||||||
vid1, pid1, vid2, pid2
|
|
||||||
))),
|
))),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -135,9 +139,15 @@ impl ADBUSBDevice {
|
|||||||
transport: USBTransport,
|
transport: USBTransport,
|
||||||
private_key_path: PathBuf,
|
private_key_path: PathBuf,
|
||||||
) -> Result<Self> {
|
) -> Result<Self> {
|
||||||
let private_key = match read_adb_private_key(private_key_path)? {
|
let private_key = match read_adb_private_key(&private_key_path)? {
|
||||||
Some(pk) => pk,
|
Some(pk) => pk,
|
||||||
None => ADBRsaKey::new_random()?,
|
None => {
|
||||||
|
log::warn!(
|
||||||
|
"No private key found at path {}. Using a temporary random one.",
|
||||||
|
private_key_path.display()
|
||||||
|
);
|
||||||
|
ADBRsaKey::new_random()?
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
let mut s = Self {
|
let mut s = Self {
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ impl<T: ADBMessageTransport> ADBMessageDevice<T> {
|
|||||||
|
|
||||||
let file_size = apk_file.metadata()?.len();
|
let file_size = apk_file.metadata()?.len();
|
||||||
|
|
||||||
self.open_session(format!("exec:cmd package 'install' -S {}\0", file_size).as_bytes())?;
|
self.open_session(format!("exec:cmd package 'install' -S {file_size}\0").as_bytes())?;
|
||||||
|
|
||||||
let transport = self.get_transport().clone();
|
let transport = self.get_transport().clone();
|
||||||
|
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ use crate::{
|
|||||||
|
|
||||||
impl<T: ADBMessageTransport> ADBMessageDevice<T> {
|
impl<T: ADBMessageTransport> ADBMessageDevice<T> {
|
||||||
pub(crate) fn reboot(&mut self, reboot_type: RebootType) -> Result<()> {
|
pub(crate) fn reboot(&mut self, reboot_type: RebootType) -> Result<()> {
|
||||||
self.open_session(format!("reboot:{}\0", reboot_type).as_bytes())?;
|
self.open_session(format!("reboot:{reboot_type}\0").as_bytes())?;
|
||||||
|
|
||||||
self.get_transport_mut()
|
self.get_transport_mut()
|
||||||
.read_message()
|
.read_message()
|
||||||
|
|||||||
@@ -2,13 +2,13 @@ use crate::{ADBMessageTransport, Result, device::adb_message_device::ADBMessageD
|
|||||||
|
|
||||||
impl<T: ADBMessageTransport> ADBMessageDevice<T> {
|
impl<T: ADBMessageTransport> ADBMessageDevice<T> {
|
||||||
pub(crate) fn uninstall(&mut self, package_name: &str) -> Result<()> {
|
pub(crate) fn uninstall(&mut self, package_name: &str) -> Result<()> {
|
||||||
self.open_session(format!("exec:cmd package 'uninstall' {}\0", package_name).as_bytes())?;
|
self.open_session(format!("exec:cmd package 'uninstall' {package_name}\0").as_bytes())?;
|
||||||
|
|
||||||
let final_status = self.get_transport_mut().read_message()?;
|
let final_status = self.get_transport_mut().read_message()?;
|
||||||
|
|
||||||
match final_status.into_payload().as_slice() {
|
match final_status.into_payload().as_slice() {
|
||||||
b"Success\n" => {
|
b"Success\n" => {
|
||||||
log::info!("Package {} successfully uninstalled", package_name);
|
log::info!("Package {package_name} successfully uninstalled");
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
d => Err(crate::RustADBError::ADBRequestFailed(String::from_utf8(
|
d => Err(crate::RustADBError::ADBRequestFailed(String::from_utf8(
|
||||||
|
|||||||
@@ -30,8 +30,7 @@ impl ADBEmulatorDevice {
|
|||||||
let groups = EMULATOR_REGEX
|
let groups = EMULATOR_REGEX
|
||||||
.captures(&identifier)
|
.captures(&identifier)
|
||||||
.ok_or(RustADBError::DeviceNotFound(format!(
|
.ok_or(RustADBError::DeviceNotFound(format!(
|
||||||
"Device {} is likely not an emulator",
|
"Device {identifier} is likely not an emulator"
|
||||||
identifier
|
|
||||||
)))?;
|
)))?;
|
||||||
|
|
||||||
let port = groups
|
let port = groups
|
||||||
|
|||||||
@@ -63,8 +63,8 @@ impl Display for AdbServerCommand {
|
|||||||
AdbServerCommand::Reboot(reboot_type) => {
|
AdbServerCommand::Reboot(reboot_type) => {
|
||||||
write!(f, "reboot:{reboot_type}")
|
write!(f, "reboot:{reboot_type}")
|
||||||
}
|
}
|
||||||
AdbServerCommand::Connect(addr) => write!(f, "host:connect:{}", addr),
|
AdbServerCommand::Connect(addr) => write!(f, "host:connect:{addr}"),
|
||||||
AdbServerCommand::Disconnect(addr) => write!(f, "host:disconnect:{}", addr),
|
AdbServerCommand::Disconnect(addr) => write!(f, "host:disconnect:{addr}"),
|
||||||
AdbServerCommand::Pair(addr, code) => {
|
AdbServerCommand::Pair(addr, code) => {
|
||||||
write!(f, "host:pair:{code}:{addr}")
|
write!(f, "host:pair:{code}:{addr}")
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -32,7 +32,7 @@ impl ADBServer {
|
|||||||
Ok(service) => {
|
Ok(service) => {
|
||||||
vec_services.push(MDNSServices::try_from(service.as_bytes())?);
|
vec_services.push(MDNSServices::try_from(service.as_bytes())?);
|
||||||
}
|
}
|
||||||
Err(e) => log::error!("{}", e),
|
Err(e) => log::error!("{e}"),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -64,7 +64,7 @@ impl ADBServerDevice {
|
|||||||
"DONE" => {
|
"DONE" => {
|
||||||
return Ok(());
|
return Ok(());
|
||||||
}
|
}
|
||||||
x => log::error!("Got an unknown response {}", x),
|
x => log::error!("Got an unknown response {x}"),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -48,8 +48,7 @@ impl<R: Read> Read for ADBRecvCommandReader<R> {
|
|||||||
)))
|
)))
|
||||||
}
|
}
|
||||||
_ => Err(std::io::Error::other(format!(
|
_ => Err(std::io::Error::other(format!(
|
||||||
"Unknown response from device {:#?}",
|
"Unknown response from device {header:#?}"
|
||||||
header
|
|
||||||
))),
|
))),
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -31,8 +31,7 @@ impl ADBServerDevice {
|
|||||||
Ok(data.into())
|
Ok(data.into())
|
||||||
}
|
}
|
||||||
x => Err(RustADBError::UnknownResponseType(format!(
|
x => Err(RustADBError::UnknownResponseType(format!(
|
||||||
"Unknown response {}",
|
"Unknown response {x}"
|
||||||
x
|
|
||||||
))),
|
))),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -15,7 +15,7 @@ impl ADBServerDevice {
|
|||||||
|
|
||||||
match &data[0..read_amount] {
|
match &data[0..read_amount] {
|
||||||
b"Success\n" => {
|
b"Success\n" => {
|
||||||
log::info!("Package {} successfully uninstalled", package_name);
|
log::info!("Package {package_name} successfully uninstalled");
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
d => Err(crate::RustADBError::ADBRequestFailed(String::from_utf8(
|
d => Err(crate::RustADBError::ADBRequestFailed(String::from_utf8(
|
||||||
|
|||||||
@@ -99,13 +99,13 @@ impl TCPServerTransport {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Gets the body length from a LittleEndian value
|
/// Gets the body length from a LittleEndian value
|
||||||
pub(crate) fn get_body_length(&mut self) -> Result<u32> {
|
pub(crate) fn get_body_length(&self) -> Result<u32> {
|
||||||
let length_buffer = self.read_body_length()?;
|
let length_buffer = self.read_body_length()?;
|
||||||
Ok(LittleEndian::read_u32(&length_buffer))
|
Ok(LittleEndian::read_u32(&length_buffer))
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Read 4 bytes representing body length
|
/// Read 4 bytes representing body length
|
||||||
fn read_body_length(&mut self) -> Result<[u8; 4]> {
|
fn read_body_length(&self) -> Result<[u8; 4]> {
|
||||||
let mut length_buffer = [0; 4];
|
let mut length_buffer = [0; 4];
|
||||||
self.get_raw_connection()?.read_exact(&mut length_buffer)?;
|
self.get_raw_connection()?.read_exact(&mut length_buffer)?;
|
||||||
|
|
||||||
|
|||||||
@@ -109,7 +109,7 @@ impl TcpTransport {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_current_connection(&mut self) -> Result<Arc<Mutex<CurrentConnection>>> {
|
fn get_current_connection(&self) -> Result<Arc<Mutex<CurrentConnection>>> {
|
||||||
self.current_connection
|
self.current_connection
|
||||||
.as_ref()
|
.as_ref()
|
||||||
.ok_or(RustADBError::IOError(std::io::Error::new(
|
.ok_or(RustADBError::IOError(std::io::Error::new(
|
||||||
@@ -175,8 +175,7 @@ impl TcpTransport {
|
|||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
c => Err(RustADBError::ADBRequestFailed(format!(
|
c => Err(RustADBError::ADBRequestFailed(format!(
|
||||||
"Wrong command received {}",
|
"Wrong command received {c}"
|
||||||
c
|
|
||||||
))),
|
))),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -40,8 +40,7 @@ impl USBTransport {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Err(RustADBError::DeviceNotFound(format!(
|
Err(RustADBError::DeviceNotFound(format!(
|
||||||
"cannot find USB device with vendor_id={} and product_id={}",
|
"cannot find USB device with vendor_id={vendor_id} and product_id={product_id}",
|
||||||
vendor_id, product_id
|
|
||||||
)))
|
)))
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -151,12 +150,7 @@ impl USBTransport {
|
|||||||
let write_amount = handle.write_bulk(endpoint.address, &data[offset..end], timeout)?;
|
let write_amount = handle.write_bulk(endpoint.address, &data[offset..end], timeout)?;
|
||||||
offset += write_amount;
|
offset += write_amount;
|
||||||
|
|
||||||
log::trace!(
|
log::trace!("wrote chunk of size {write_amount} - {offset}/{data_len}",)
|
||||||
"wrote chunk of size {} - {}/{}",
|
|
||||||
write_amount,
|
|
||||||
offset,
|
|
||||||
data_len
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if offset % max_packet_size == 0 {
|
if offset % max_packet_size == 0 {
|
||||||
@@ -175,11 +169,11 @@ impl ADBTransport for USBTransport {
|
|||||||
let (read_endpoint, write_endpoint) = self.find_endpoints(&device)?;
|
let (read_endpoint, write_endpoint) = self.find_endpoints(&device)?;
|
||||||
|
|
||||||
Self::configure_endpoint(&device, &read_endpoint)?;
|
Self::configure_endpoint(&device, &read_endpoint)?;
|
||||||
log::debug!("got read endpoint: {:?}", read_endpoint);
|
log::debug!("got read endpoint: {read_endpoint:?}");
|
||||||
self.read_endpoint = Some(read_endpoint);
|
self.read_endpoint = Some(read_endpoint);
|
||||||
|
|
||||||
Self::configure_endpoint(&device, &write_endpoint)?;
|
Self::configure_endpoint(&device, &write_endpoint)?;
|
||||||
log::debug!("got write endpoint: {:?}", write_endpoint);
|
log::debug!("got write endpoint: {write_endpoint:?}");
|
||||||
self.write_endpoint = Some(write_endpoint);
|
self.write_endpoint = Some(write_endpoint);
|
||||||
|
|
||||||
self.handle = Some(Arc::new(device));
|
self.handle = Some(Arc::new(device));
|
||||||
@@ -197,7 +191,7 @@ impl ADBTransport for USBTransport {
|
|||||||
let endpoint = self.read_endpoint.as_ref().or(self.write_endpoint.as_ref());
|
let endpoint = self.read_endpoint.as_ref().or(self.write_endpoint.as_ref());
|
||||||
if let Some(endpoint) = &endpoint {
|
if let Some(endpoint) = &endpoint {
|
||||||
match handle.release_interface(endpoint.iface) {
|
match handle.release_interface(endpoint.iface) {
|
||||||
Ok(_) => log::debug!("succesfully released interface"),
|
Ok(()) => log::debug!("succesfully released interface"),
|
||||||
Err(e) => log::error!("error while release interface: {e}"),
|
Err(e) => log::error!("error while release interface: {e}"),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,6 +9,7 @@ name = "pyadb_client"
|
|||||||
readme = "README.md"
|
readme = "README.md"
|
||||||
repository.workspace = true
|
repository.workspace = true
|
||||||
version.workspace = true
|
version.workspace = true
|
||||||
|
rust-version.workspace = true
|
||||||
|
|
||||||
[lib]
|
[lib]
|
||||||
crate-type = ["cdylib", "rlib"]
|
crate-type = ["cdylib", "rlib"]
|
||||||
|
|||||||
Reference in New Issue
Block a user