PrinterId.java revision c43639c3067dda5df189fb3cbf14f256c17e677d
14b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov/*
24b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov * Copyright (C) 2013 The Android Open Source Project
34b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov *
44b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov * Licensed under the Apache License, Version 2.0 (the "License");
54b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov * you may not use this file except in compliance with the License.
64b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov * You may obtain a copy of the License at
74b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov *
84b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov *      http://www.apache.org/licenses/LICENSE-2.0
94b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov *
104b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov * Unless required by applicable law or agreed to in writing, software
114b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov * distributed under the License is distributed on an "AS IS" BASIS,
124b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
134b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov * See the License for the specific language governing permissions and
144b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov * limitations under the License.
154b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov */
164b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov
174b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganovpackage android.print;
184b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov
19c43639c3067dda5df189fb3cbf14f256c17e677dPhilip P. Moltmannimport android.annotation.NonNull;
204b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganovimport android.content.ComponentName;
214b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganovimport android.os.Parcel;
224b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganovimport android.os.Parcelable;
2355b409a97cf6376399a0940313ea852368727d6fSvetoslav Ganovimport android.text.TextUtils;
244b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov
254b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov/**
264b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov * This class represents the unique id of a printer.
274b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov */
284b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganovpublic final class PrinterId implements Parcelable {
294b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov
308c43376ea83a67414bd6823a472b76d41160239eSvetoslav Ganov    private final ComponentName mServiceName;
314b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov
32798bed6cc7d273e72b0253288605db9cd2b57740Svetoslav Ganov    private final String mLocalId;
334b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov
344b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    /**
354b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov     * Creates a new instance.
364b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov     *
378c43376ea83a67414bd6823a472b76d41160239eSvetoslav Ganov     * @param serviceName The managing print service.
38798bed6cc7d273e72b0253288605db9cd2b57740Svetoslav Ganov     * @param localId The locally unique id within the managing service.
394b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov     *
404b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov     * @hide
414b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov     */
42798bed6cc7d273e72b0253288605db9cd2b57740Svetoslav Ganov    public PrinterId(ComponentName serviceName, String localId) {
438c43376ea83a67414bd6823a472b76d41160239eSvetoslav Ganov        mServiceName = serviceName;
44798bed6cc7d273e72b0253288605db9cd2b57740Svetoslav Ganov        mLocalId = localId;
454b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    }
464b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov
474b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    private PrinterId(Parcel parcel) {
488c43376ea83a67414bd6823a472b76d41160239eSvetoslav Ganov        mServiceName = parcel.readParcelable(null);
49798bed6cc7d273e72b0253288605db9cd2b57740Svetoslav Ganov        mLocalId = parcel.readString();
504b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    }
514b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov
524b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    /**
534b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov     * The id of the print service this printer is managed by.
544b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov     *
554b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov     * @return The print service component name.
564b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov     *
574b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov     * @hide
584b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov     */
598c43376ea83a67414bd6823a472b76d41160239eSvetoslav Ganov    public ComponentName getServiceName() {
608c43376ea83a67414bd6823a472b76d41160239eSvetoslav Ganov        return mServiceName;
614b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    }
624b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov
634b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    /**
64798bed6cc7d273e72b0253288605db9cd2b57740Svetoslav Ganov     * Gets the id of this printer which is unique in the context
654b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov     * of the print service that manages it.
664b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov     *
678c43376ea83a67414bd6823a472b76d41160239eSvetoslav Ganov     * @return The printer name.
684b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov     */
69c43639c3067dda5df189fb3cbf14f256c17e677dPhilip P. Moltmann    public @NonNull String getLocalId() {
70798bed6cc7d273e72b0253288605db9cd2b57740Svetoslav Ganov        return mLocalId;
714b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    }
724b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov
734b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    @Override
744b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    public int describeContents() {
754b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        return 0;
764b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    }
774b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov
784b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    @Override
794b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    public void writeToParcel(Parcel parcel, int flags) {
808c43376ea83a67414bd6823a472b76d41160239eSvetoslav Ganov        parcel.writeParcelable(mServiceName, flags);
81798bed6cc7d273e72b0253288605db9cd2b57740Svetoslav Ganov        parcel.writeString(mLocalId);
824b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    }
834b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov
844b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    @Override
854b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    public boolean equals(Object object) {
864b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        if (this == object) {
874b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov            return true;
884b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        }
894b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        if (object == null) {
904b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov            return false;
914b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        }
924b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        if (getClass() != object.getClass()) {
934b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov            return false;
944b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        }
954b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        PrinterId other = (PrinterId) object;
968c43376ea83a67414bd6823a472b76d41160239eSvetoslav Ganov        if (mServiceName == null) {
978c43376ea83a67414bd6823a472b76d41160239eSvetoslav Ganov            if (other.mServiceName != null) {
984b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov                return false;
994b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov            }
1008c43376ea83a67414bd6823a472b76d41160239eSvetoslav Ganov        } else if (!mServiceName.equals(other.mServiceName)) {
1014b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov            return false;
1024b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        }
103798bed6cc7d273e72b0253288605db9cd2b57740Svetoslav Ganov        if (!TextUtils.equals(mLocalId, other.mLocalId)) {
1044b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov            return false;
1054b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        }
1064b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        return true;
1074b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    }
1084b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov
1094b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    @Override
1104b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    public int hashCode() {
1114b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        final int prime = 31;
1124b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        int hashCode = 1;
1138c43376ea83a67414bd6823a472b76d41160239eSvetoslav Ganov        hashCode = prime * hashCode + ((mServiceName != null)
1148c43376ea83a67414bd6823a472b76d41160239eSvetoslav Ganov                ? mServiceName.hashCode() : 1);
115798bed6cc7d273e72b0253288605db9cd2b57740Svetoslav Ganov        hashCode = prime * hashCode + mLocalId.hashCode();
1164b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        return hashCode;
1174b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    }
1184b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov
1194b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    @Override
1204b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    public String toString() {
1214b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        StringBuilder builder = new StringBuilder();
1224b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        builder.append("PrinterId{");
123798bed6cc7d273e72b0253288605db9cd2b57740Svetoslav Ganov        builder.append("serviceName=").append(mServiceName.flattenToString());
124798bed6cc7d273e72b0253288605db9cd2b57740Svetoslav Ganov        builder.append(", localId=").append(mLocalId);
1254b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        builder.append('}');
1264b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        return builder.toString();
1274b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    }
1284b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov
1294b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    public static final Parcelable.Creator<PrinterId> CREATOR =
1304b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov            new Creator<PrinterId>() {
1314b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        @Override
1324b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        public PrinterId createFromParcel(Parcel parcel) {
1334b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov            return new PrinterId(parcel);
1344b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        }
1354b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov
1364b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        @Override
1374b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        public PrinterId[] newArray(int size) {
1384b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov            return new PrinterId[size];
1394b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov        }
1404b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov    };
1414b9a4d16872bbb50712e007b419ac0b35ff1582dSvetoslav Ganov}
142