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

Commit cf373696 authored by Steven Moreland's avatar Steven Moreland
Browse files

libbinder: Status writeOverParcel

For errors written to the parcel late.

Bug: 211823183
Test: aidl_integration_test
Change-Id: I036a016e143408bf1c3cb4f67f622c7e0dac91bf
parent ea7659e0
Loading
Loading
Loading
Loading
+6 −0
Original line number Diff line number Diff line
@@ -211,6 +211,12 @@ status_t Status::writeToParcel(Parcel* parcel) const {
    return status;
}

status_t Status::writeOverParcel(Parcel* parcel) const {
    parcel->setDataSize(0);
    parcel->setDataPosition(0);
    return writeToParcel(parcel);
}

void Status::setException(int32_t ex, const String8& message) {
    mException = ex;
    mErrorCode = ex == EX_TRANSACTION_FAILED ? FAILED_TRANSACTION : NO_ERROR;
+4 −0
Original line number Diff line number Diff line
@@ -117,6 +117,10 @@ public:
    status_t readFromParcel(const Parcel& parcel);
    status_t writeToParcel(Parcel* parcel) const;

    // Convenience API to replace a Parcel with a status value, w/o requiring
    // calling multiple APIs (makes generated code smaller).
    status_t writeOverParcel(Parcel* parcel) const;

    // Set one of the pre-defined exception types defined above.
    void setException(int32_t ex, const String8& message);
    // Set a service specific exception with error code.
+1 −0
Original line number Diff line number Diff line
@@ -98,6 +98,7 @@ cc_test {
    srcs: [
        "binderParcelUnitTest.cpp",
        "binderBinderUnitTest.cpp",
        "binderStatusUnitTest.cpp",
    ],
    shared_libs: [
        "libbinder",
+35 −0
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.
 */

#include <binder/Parcel.h>
#include <binder/Status.h>
#include <gtest/gtest.h>

using android::Parcel;
using android::binder::Status;

TEST(Status, WriteOverParcel) {
    Status status = Status::fromExceptionCode(Status::EX_NULL_POINTER);

    Parcel indirect;
    indirect.writeInt32(64);
    status.writeOverParcel(&indirect);

    Parcel direct;
    status.writeToParcel(&direct);

    EXPECT_EQ(0, indirect.compareData(direct));
}