mirror of
https://github.com/jkcoxson/idevice.git
synced 2026-03-02 06:26:15 +01:00
Separate headers into cpp source files
This commit is contained in:
64
cpp/examples/ideviceinfo.cpp
Normal file
64
cpp/examples/ideviceinfo.cpp
Normal file
@@ -0,0 +1,64 @@
|
||||
// Jackson Coxson
|
||||
|
||||
#include <idevice++/lockdown.hpp>
|
||||
#include <idevice++/provider.hpp>
|
||||
#include <idevice++/usbmuxd.hpp>
|
||||
#include <iostream>
|
||||
#include <optional>
|
||||
|
||||
int main() {
|
||||
idevice_init_logger(Debug, Disabled, NULL);
|
||||
|
||||
IdeviceFFI::FfiError e;
|
||||
std::optional<IdeviceFFI::UsbmuxdConnection> u =
|
||||
IdeviceFFI::UsbmuxdConnection::default_new(0, e);
|
||||
if (!u) {
|
||||
std::cerr << "failed to connect to usbmuxd";
|
||||
std::cerr << e.message;
|
||||
}
|
||||
|
||||
auto devices = u->get_devices(e);
|
||||
if (!devices) {
|
||||
std::cerr << "failed to get devices from usbmuxd";
|
||||
std::cerr << e.message;
|
||||
}
|
||||
if (devices->empty()) {
|
||||
std::cerr << "no devices connected";
|
||||
std::cerr << e.message;
|
||||
}
|
||||
|
||||
auto& dev = (*devices)[0];
|
||||
|
||||
auto udid = dev.get_udid();
|
||||
if (!udid) {
|
||||
std::cerr << "no udid\n";
|
||||
return 1;
|
||||
}
|
||||
|
||||
auto id = dev.get_id();
|
||||
if (!id) {
|
||||
std::cerr << "no id\n";
|
||||
return 1;
|
||||
}
|
||||
|
||||
IdeviceFFI::UsbmuxdAddr addr = IdeviceFFI::UsbmuxdAddr::default_new();
|
||||
auto prov =
|
||||
IdeviceFFI::Provider::usbmuxd_new(std::move(addr), /*tag*/ 0, *udid, *id, "reeeeeeeee", e);
|
||||
if (!prov) {
|
||||
std::cerr << "provider failed: " << e.message << "\n";
|
||||
return 1;
|
||||
}
|
||||
|
||||
auto client = IdeviceFFI::Lockdown::connect(*prov, e);
|
||||
if (!client) {
|
||||
std::cerr << "lockdown connect failed: " << e.message << "\n";
|
||||
return 1;
|
||||
}
|
||||
|
||||
auto values = client->get_value("", "", e);
|
||||
if (!values) {
|
||||
std::cerr << "get values failed: " << e.message << "\n";
|
||||
return 1;
|
||||
}
|
||||
plist_free(*values);
|
||||
}
|
||||
Reference in New Issue
Block a user