Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 214215dd authored by Yifan Hong's avatar Yifan Hong Committed by Automerger Merge Worker
Browse files

Merge "PairDevice to structured Parcelable." am: 7f2ce931

Original change: https://android-review.googlesource.com/c/platform/frameworks/base/+/1780473

Change-Id: I9e7a276700dcbd288984458f32499edec67a8664
parents 6c423b16 7f2ce931
Loading
Loading
Loading
Loading
+39 −0
Original line number Diff line number Diff line
/*
 * Copyright (C) 2021 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.
 */

package android.debug;

/**
 * Contains information about the client in an ADB connection.
 * @see {@link android.debug.IAdbManager#getPairedDevices()}
 * @hide
 */
parcelable PairDevice {
    /**
     * The human-readable name of the device.
     */
    String name;

    /**
     * The device's guid.
     */
    String guid;

    /**
     * Indicates whether the device is currently connected to adbd.
     */
    boolean connected;
}
 No newline at end of file
+0 −112
Original line number Diff line number Diff line
/*
 * Copyright (C) 2020 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.
 */

package android.debug;

import android.annotation.NonNull;
import android.os.Parcel;
import android.os.Parcelable;

import com.android.internal.annotations.Immutable;
import com.android.internal.util.Preconditions;

/**
 * Contains information about the client in an ADB connection.
 * @hide
 */
@Immutable
public class PairDevice implements Parcelable {
    /**
     * The human-readable name of the device.
     */
    @NonNull private final String mName;

    /**
     * The device's guid.
     */
    @NonNull private final String mGuid;

    /**
     * Indicates whether the device is currently connected to adbd.
     */
    private final boolean mConnected;

    public PairDevice(@NonNull String name, @NonNull String guid, boolean connected) {
        Preconditions.checkStringNotEmpty(name);
        Preconditions.checkStringNotEmpty(guid);
        mName = name;
        mGuid = guid;
        mConnected = connected;
    }

    /**
     * @return the device name.
     */
    @NonNull
    public String getDeviceName() {
        return mName;
    }

    /**
     * @return the device GUID.
     */
    @NonNull
    public String getGuid() {
        return mGuid;
    }

    /**
     * @return the adb connection state of the device.
     */
    public boolean isConnected() {
        return mConnected;
    }

    @Override
    public void writeToParcel(@NonNull Parcel dest, int flags) {
        dest.writeString(mName);
        dest.writeString(mGuid);
        dest.writeBoolean(mConnected);
    }

    /**
     * @return Human-readable info about the object.
     */
    @Override
    public String toString() {
        return "\n" + mName + "\n" + mGuid + "\n" + mConnected;
    }

    @Override
    public int describeContents() {
        return 0;
    }

    @NonNull
    public static final Parcelable.Creator<PairDevice> CREATOR =
            new Creator<PairDevice>() {
                @Override
                public PairDevice createFromParcel(Parcel source) {
                    return new PairDevice(source.readString(), source.readString(),
                            source.readBoolean());
                }

                @Override
                public PairDevice[] newArray(int size) {
                    return new PairDevice[size];
                }
            };
}
+9 −3
Original line number Diff line number Diff line
@@ -1362,7 +1362,10 @@ public class AdbDebuggingManager {
                if (args.length > 1) {
                    hostname = args[1];
                }
                PairDevice device = new PairDevice(fingerprints, hostname, false);
                PairDevice device = new PairDevice();
                device.name = fingerprints;
                device.guid = hostname;
                device.connected = false;
                intent.putExtra(AdbManager.WIRELESS_PAIR_DEVICE_EXTRA, device);
                mContext.sendBroadcastAsUser(intent, UserHandle.ALL);
                // Add the key into the keystore
@@ -1844,8 +1847,11 @@ public class AdbDebuggingManager {
                if (args.length > 1) {
                    hostname = args[1];
                }
                pairedDevices.put(keyEntry.getKey(), new PairDevice(
                        hostname, fingerprints, mWifiConnectedKeys.contains(keyEntry.getKey())));
                PairDevice pairDevice = new PairDevice();
                pairDevice.name = hostname;
                pairDevice.guid = fingerprints;
                pairDevice.connected = mWifiConnectedKeys.contains(keyEntry.getKey());
                pairedDevices.put(keyEntry.getKey(), pairDevice);
            }
            return pairedDevices;
        }