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

Commit c6756c22 authored by Yuanjia Hsu's avatar Yuanjia Hsu Committed by Automerger Merge Worker
Browse files

Revert "Exports API to allow RULE_MATCH_UID support both RECORDE..." am: 24c28a09 am: 16bc108d

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

Change-Id: Ic99393449fa3e4abfd6db3911f41476ebf37aded
parents bec44fbf 16bc108d
Loading
Loading
Loading
Loading
+0 −4
Original line number Diff line number Diff line
@@ -5410,8 +5410,6 @@ package android.media.audiopolicy {
    field public static final int MIX_STATE_DISABLED = -1; // 0xffffffff
    field public static final int MIX_STATE_IDLE = 0; // 0x0
    field public static final int MIX_STATE_MIXING = 1; // 0x1
    field public static final int MIX_TYPE_PLAYERS = 0; // 0x0
    field public static final int MIX_TYPE_RECORDERS = 1; // 0x1
    field public static final int ROUTE_FLAG_LOOP_BACK = 2; // 0x2
    field public static final int ROUTE_FLAG_RENDER = 1; // 0x1
  }
@@ -5425,7 +5423,6 @@ package android.media.audiopolicy {
  }
  public class AudioMixingRule {
    method public int getTargetMixType();
    field public static final int RULE_MATCH_ATTRIBUTE_CAPTURE_PRESET = 2; // 0x2
    field public static final int RULE_MATCH_ATTRIBUTE_USAGE = 1; // 0x1
    field public static final int RULE_MATCH_UID = 4; // 0x4
@@ -5440,7 +5437,6 @@ package android.media.audiopolicy {
    method public android.media.audiopolicy.AudioMixingRule build();
    method public android.media.audiopolicy.AudioMixingRule.Builder excludeMixRule(int, Object) throws java.lang.IllegalArgumentException;
    method public android.media.audiopolicy.AudioMixingRule.Builder excludeRule(android.media.AudioAttributes, int) throws java.lang.IllegalArgumentException;
    method @NonNull public android.media.audiopolicy.AudioMixingRule.Builder setTargetMixType(int);
  }
  public class AudioPolicy {
+2 −0
Original line number Diff line number Diff line
@@ -113,10 +113,12 @@ public class AudioMix {
     */
    public static final int MIX_TYPE_INVALID = -1;
    /**
     * @hide
     * Mix type indicating playback streams are mixed.
     */
    public static final int MIX_TYPE_PLAYERS = 0;
    /**
     * @hide
     * Mix type indicating recording streams are mixed.
     */
    public static final int MIX_TYPE_RECORDERS = 1;
+7 −30
Original line number Diff line number Diff line
@@ -16,9 +16,6 @@

package android.media.audiopolicy;

import static java.lang.annotation.RetentionPolicy.SOURCE;

import android.annotation.IntDef;
import android.annotation.NonNull;
import android.annotation.SystemApi;
import android.compat.annotation.UnsupportedAppUsage;
@@ -27,7 +24,6 @@ import android.os.Build;
import android.os.Parcel;
import android.util.Log;

import java.lang.annotation.Retention;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.Objects;
@@ -203,19 +199,7 @@ public class AudioMixingRule {
    }

    private final int mTargetMixType;

    /** @hide */
    @IntDef({AudioMix.MIX_TYPE_PLAYERS, AudioMix.MIX_TYPE_RECORDERS})
    @Retention(SOURCE)
    public @interface MixType {}

    /**
     * Gets target mix type of the mixing rule.
     */
    public @MixType int getTargetMixType() {
        return mTargetMixType;
    }

    int getTargetMixType() { return mTargetMixType; }
    @UnsupportedAppUsage(maxTargetSdk = Build.VERSION_CODES.R, trackingBug = 170729553)
    private final ArrayList<AudioMixMatchCriterion> mCriteria;
    /** @hide */
@@ -485,24 +469,17 @@ public class AudioMixingRule {
        }

        /**
         * Sets target mix type of the mixing rule.
         * Set target mix type of the mixing rule.
         *
         * <p>Note: If the mix type was not specified, it will be decided automatically by matched
         * mixing rule. For example, {@link AudioMixingRule#RULE_MATCH_ATTRIBUTE_USAGE} or {@link
         * AudioMixingRule#RULE_MATCH_USERID} applied {@link AudioMix#MIX_TYPE_PLAYERS}, {@link
         * AudioMixingRule#RULE_MATCH_ATTRIBUTE_CAPTURE_PRESET} applied {@link
         * AudioMix#MIX_TYPE_RECORDERS}. For {@link AudioMixingRule#RULE_MATCH_UID}, the mix type
         * could be {@link AudioMix#MIX_TYPE_PLAYERS} or {@link AudioMix#MIX_TYPE_RECORDERS}, and
         * {@link AudioMix#MIX_TYPE_PLAYERS} is the default value.
         * <p>Note: If the mix type was not specified, it will be decided automatically by mixing
         * rule. For {@link #RULE_MATCH_UID}, the default type is {@link AudioMix#MIX_TYPE_PLAYERS}.
         *
         * @param mixType {@link AudioMix#MIX_TYPE_PLAYERS} or {@link AudioMix#MIX_TYPE_RECORDERS}
         * @return the same Builder instance.
         *
         * @hide
         */
        public @NonNull Builder setTargetMixType(@MixType int mixType) {
            if (mixType != AudioMix.MIX_TYPE_PLAYERS && mixType != AudioMix.MIX_TYPE_RECORDERS) {
                throw new IllegalArgumentException("Illegal argument for mix type");
            }

        public @NonNull Builder setTargetMixType(int mixType) {
            mTargetMixType = mixType;
            Log.i("AudioMixingRule", "Builder setTargetMixType " + mixType);
            return this;