diff options
Diffstat (limited to 'core/java/android/content')
| -rwxr-xr-x | core/java/android/content/IIntentReceiver.aidl | 33 | ||||
| -rw-r--r-- | core/java/android/content/IIntentSender.aidl | 26 | ||||
| -rw-r--r-- | core/java/android/content/IntentSender.aidl | 19 | ||||
| -rw-r--r-- | core/java/android/content/IntentSender.java | 255 | ||||
| -rw-r--r-- | core/java/android/content/pm/IPackageManager.aidl | 25 | ||||
| -rw-r--r-- | core/java/android/content/pm/PackageManager.java | 32 | 
6 files changed, 388 insertions, 2 deletions
| diff --git a/core/java/android/content/IIntentReceiver.aidl b/core/java/android/content/IIntentReceiver.aidl new file mode 100755 index 0000000..443db2d --- /dev/null +++ b/core/java/android/content/IIntentReceiver.aidl @@ -0,0 +1,33 @@ +/* + * Copyright (C) 2006 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.content; + +import android.content.Intent; +import android.os.Bundle; + +/** + * System private API for dispatching intent broadcasts.  This is given to the + * activity manager as part of registering for an intent broadcasts, and is + * called when it receives intents. + * + * {@hide} + */ +oneway interface IIntentReceiver { +    void performReceive(in Intent intent, int resultCode, +                        String data, in Bundle extras, boolean ordered); +} + diff --git a/core/java/android/content/IIntentSender.aidl b/core/java/android/content/IIntentSender.aidl new file mode 100644 index 0000000..b7da472 --- /dev/null +++ b/core/java/android/content/IIntentSender.aidl @@ -0,0 +1,26 @@ +/* + * Copyright (C) 2006 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.content; + +import android.content.IIntentReceiver; +import android.content.Intent; + +/** @hide */ +interface IIntentSender { +    int send(int code, in Intent intent, String resolvedType, +            IIntentReceiver finishedReceiver); +} diff --git a/core/java/android/content/IntentSender.aidl b/core/java/android/content/IntentSender.aidl new file mode 100644 index 0000000..741bc8c --- /dev/null +++ b/core/java/android/content/IntentSender.aidl @@ -0,0 +1,19 @@ +/* + * Copyright (C) 2008 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.content; + +parcelable IntentSender; diff --git a/core/java/android/content/IntentSender.java b/core/java/android/content/IntentSender.java new file mode 100644 index 0000000..4da49d9 --- /dev/null +++ b/core/java/android/content/IntentSender.java @@ -0,0 +1,255 @@ +/* + * Copyright (C) 2006 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.content; + +import android.content.Context; +import android.content.Intent; +import android.content.IIntentSender; +import android.content.IIntentReceiver; +import android.os.Bundle; +import android.os.RemoteException; +import android.os.Handler; +import android.os.IBinder; +import android.os.Parcel; +import android.os.Parcelable; +import android.util.AndroidException; + + +/** + * A description of an Intent and target action to perform with it. + * The returned object can be + * handed to other applications so that they can perform the action you + * described on your behalf at a later time. + * + * <p>By giving a IntentSender to another application, + * you are granting it the right to perform the operation you have specified + * as if the other application was yourself (with the same permissions and + * identity).  As such, you should be careful about how you build the IntentSender: + * often, for example, the base Intent you supply will have the component + * name explicitly set to one of your own components, to ensure it is ultimately + * sent there and nowhere else. + * + * <p>A IntentSender itself is simply a reference to a token maintained by + * the system describing the original data used to retrieve it.  This means + * that, even if its owning application's process is killed, the + * IntentSender itself will remain usable from other processes that + * have been given it.  If the creating application later re-retrieves the + * same kind of IntentSender (same operation, same Intent action, data, + * categories, and components, and same flags), it will receive a IntentSender + * representing the same token if that is still valid. + * + */ +public class IntentSender implements Parcelable { +    private final IIntentSender mTarget; + +    /** +     * Exception thrown when trying to send through a PendingIntent that +     * has been canceled or is otherwise no longer able to execute the request. +     */ +    public static class SendIntentException extends AndroidException { +        public SendIntentException() { +        } + +        public SendIntentException(String name) { +            super(name); +        } + +        public SendIntentException(Exception cause) { +            super(cause); +        } +    } + +    /** +     * Callback interface for discovering when a send operation has +     * completed.  Primarily for use with a IntentSender that is +     * performing a broadcast, this provides the same information as +     * calling {@link Context#sendOrderedBroadcast(Intent, String, +     * android.content.BroadcastReceiver, Handler, int, String, Bundle) +     * Context.sendBroadcast()} with a final BroadcastReceiver. +     */ +    public interface OnFinished { +        /** +         * Called when a send operation as completed. +         * +         * @param IntentSender The IntentSender this operation was sent through. +         * @param intent The original Intent that was sent. +         * @param resultCode The final result code determined by the send. +         * @param resultData The final data collected by a broadcast. +         * @param resultExtras The final extras collected by a broadcast. +         */ +        void onSendFinished(IntentSender IntentSender, Intent intent, +                int resultCode, String resultData, Bundle resultExtras); +    } + +    private static class FinishedDispatcher extends IIntentReceiver.Stub +            implements Runnable { +        private final IntentSender mIntentSender; +        private final OnFinished mWho; +        private final Handler mHandler; +        private Intent mIntent; +        private int mResultCode; +        private String mResultData; +        private Bundle mResultExtras; +        FinishedDispatcher(IntentSender pi, OnFinished who, Handler handler) { +            mIntentSender = pi; +            mWho = who; +            mHandler = handler; +        } +        public void performReceive(Intent intent, int resultCode, +                String data, Bundle extras, boolean serialized) { +            mIntent = intent; +            mResultCode = resultCode; +            mResultData = data; +            mResultExtras = extras; +            if (mHandler == null) { +                run(); +            } else { +                mHandler.post(this); +            } +        } +        public void run() { +            mWho.onSendFinished(mIntentSender, mIntent, mResultCode, +                    mResultData, mResultExtras); +        } +    } + +    /** +     * Perform the operation associated with this IntentSender, allowing the +     * caller to specify information about the Intent to use and be notified +     * when the send has completed. +     * +     * @param context The Context of the caller.  This may be null if +     * <var>intent</var> is also null. +     * @param code Result code to supply back to the IntentSender's target. +     * @param intent Additional Intent data.  See {@link Intent#fillIn +     * Intent.fillIn()} for information on how this is applied to the +     * original Intent.  Use null to not modify the original Intent. +     * @param onFinished The object to call back on when the send has +     * completed, or null for no callback. +     * @param handler Handler identifying the thread on which the callback +     * should happen.  If null, the callback will happen from the thread +     * pool of the process. +     * +     * +     * @throws SendIntentException Throws CanceledIntentException if the IntentSender +     * is no longer allowing more intents to be sent through it. +     */ +    public void sendIntent(Context context, int code, Intent intent, +            OnFinished onFinished, Handler handler) throws SendIntentException { +        try { +            String resolvedType = intent != null ? +                    intent.resolveTypeIfNeeded(context.getContentResolver()) +                    : null; +            int res = mTarget.send(code, intent, resolvedType, +                    onFinished != null +                    ? new FinishedDispatcher(this, onFinished, handler) +                    : null); +            if (res < 0) { +                throw new SendIntentException(); +            } +        } catch (RemoteException e) { +            throw new SendIntentException(); +        } +    } + +    /** +     * Comparison operator on two IntentSender objects, such that true +     * is returned then they both represent the same operation from the +     * same package. +     */ +    @Override +    public boolean equals(Object otherObj) { +        if (otherObj instanceof IntentSender) { +            return mTarget.asBinder().equals(((IntentSender)otherObj) +                    .mTarget.asBinder()); +        } +        return false; +    } + +    @Override +    public int hashCode() { +        return mTarget.asBinder().hashCode(); +    } + +    @Override +    public String toString() { +        StringBuilder sb = new StringBuilder(128); +        sb.append("IntentSender{"); +        sb.append(Integer.toHexString(System.identityHashCode(this))); +        sb.append(": "); +        sb.append(mTarget != null ? mTarget.asBinder() : null); +        sb.append('}'); +        return sb.toString(); +    } + +    public int describeContents() { +        return 0; +    } + +    public void writeToParcel(Parcel out, int flags) { +        out.writeStrongBinder(mTarget.asBinder()); +    } + +    public static final Parcelable.Creator<IntentSender> CREATOR +            = new Parcelable.Creator<IntentSender>() { +        public IntentSender createFromParcel(Parcel in) { +            IBinder target = in.readStrongBinder(); +            return target != null ? new IntentSender(target) : null; +        } + +        public IntentSender[] newArray(int size) { +            return new IntentSender[size]; +        } +    }; + +    /** +     * Convenience function for writing either a IntentSender or null pointer to +     * a Parcel.  You must use this with {@link #readIntentSenderOrNullFromParcel} +     * for later reading it. +     * +     * @param sender The IntentSender to write, or null. +     * @param out Where to write the IntentSender. +     */ +    public static void writeIntentSenderOrNullToParcel(IntentSender sender, +            Parcel out) { +        out.writeStrongBinder(sender != null ? sender.mTarget.asBinder() +                : null); +    } + +    /** +     * Convenience function for reading either a Messenger or null pointer from +     * a Parcel.  You must have previously written the Messenger with +     * {@link #writeIntentSenderOrNullToParcel}. +     * +     * @param in The Parcel containing the written Messenger. +     * +     * @return Returns the Messenger read from the Parcel, or null if null had +     * been written. +     */ +    public static IntentSender readIntentSenderOrNullFromParcel(Parcel in) { +        IBinder b = in.readStrongBinder(); +        return b != null ? new IntentSender(b) : null; +    } + +    protected IntentSender(IIntentSender target) { +        mTarget = target; +    } + +    protected IntentSender(IBinder target) { +        mTarget = IIntentSender.Stub.asInterface(target); +    } +} diff --git a/core/java/android/content/pm/IPackageManager.aidl b/core/java/android/content/pm/IPackageManager.aidl index 5f62248..1a0f31f 100644 --- a/core/java/android/content/pm/IPackageManager.aidl +++ b/core/java/android/content/pm/IPackageManager.aidl @@ -35,6 +35,7 @@ import android.content.pm.ResolveInfo;  import android.content.pm.ServiceInfo;  import android.net.Uri;  import android.app.PendingIntent; +import android.content.IntentSender;  /**   *  See {@link PackageManager} for documentation on most of the APIs @@ -243,6 +244,30 @@ interface IPackageManager {       */       void freeStorage(in long freeStorageSize,               in PendingIntent opFinishedIntent); + +    /** +     * Free storage by deleting LRU sorted list of cache files across +     * all applications. If the currently available free storage +     * on the device is greater than or equal to the requested +     * free storage, no cache files are cleared. If the currently +     * available storage on the device is less than the requested +     * free storage, some or all of the cache files across +     * all applications are deleted (based on last accessed time) +     * to increase the free storage space on the device to +     * the requested value. There is no guarantee that clearing all +     * the cache files from all applications will clear up +     * enough storage to achieve the desired value. +     * @param freeStorageSize The number of bytes of storage to be +     * freed by the system. Say if freeStorageSize is XX, +     * and the current free storage is YY, +     * if XX is less than YY, just return. if not free XX-YY number +     * of bytes if possible. +     * @param pi IntentSender call back used to +     * notify when the operation is completed.May be null +     * to indicate that no call back is desired. +     */ +     void freeStorageWithIntent(in long freeStorageSize, +             in IntentSender pi);      /**       * Delete all the cache files in an applications cache directory diff --git a/core/java/android/content/pm/PackageManager.java b/core/java/android/content/pm/PackageManager.java index 6578391..f74f3c2 100644 --- a/core/java/android/content/pm/PackageManager.java +++ b/core/java/android/content/pm/PackageManager.java @@ -22,6 +22,7 @@ import android.content.ComponentName;  import android.content.Context;  import android.content.Intent;  import android.content.IntentFilter; +import android.content.IntentSender;  import android.content.res.Resources;  import android.content.res.XmlResourceParser;  import android.graphics.drawable.Drawable; @@ -1522,7 +1523,7 @@ public abstract class PackageManager {       * @hide       */      public abstract void freeStorageAndNotify(long freeStorageSize, IPackageDataObserver observer); -     +      /**       * Free storage by deleting LRU sorted list of cache files across       * all applications. If the currently available free storage @@ -1543,12 +1544,39 @@ public abstract class PackageManager {       * @param opFinishedIntent PendingIntent call back used to       * notify when the operation is completed.May be null       * to indicate that no call back is desired. -     *  +     * +     * @deprecated       * @hide       */ +    @Deprecated      public abstract void freeStorage(long freeStorageSize, PendingIntent opFinishedIntent);      /** +     * Free storage by deleting LRU sorted list of cache files across +     * all applications. If the currently available free storage +     * on the device is greater than or equal to the requested +     * free storage, no cache files are cleared. If the currently +     * available storage on the device is less than the requested +     * free storage, some or all of the cache files across +     * all applications are deleted (based on last accessed time) +     * to increase the free storage space on the device to +     * the requested value. There is no guarantee that clearing all +     * the cache files from all applications will clear up +     * enough storage to achieve the desired value. +     * @param freeStorageSize The number of bytes of storage to be +     * freed by the system. Say if freeStorageSize is XX, +     * and the current free storage is YY, +     * if XX is less than YY, just return. if not free XX-YY number +     * of bytes if possible. +     * @param pi IntentSender call back used to +     * notify when the operation is completed.May be null +     * to indicate that no call back is desired. +     *  +     * @hide +     */ +    public abstract void freeStorageWithIntent(long freeStorageSize, IntentSender pi); + +    /**       * Retrieve the size information for a package.       * Since this may take a little while, the result will       * be posted back to the given observer.  The calling context | 
