154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project/*
254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Copyright (C) 2006 The Android Open Source Project
354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project *
454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * you may not use this file except in compliance with the License.
654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * You may obtain a copy of the License at
754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project *
854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project *
1054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
1154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
1254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * See the License for the specific language governing permissions and
1454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * limitations under the License.
1554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */
1654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
1754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Projectpackage android.content;
1854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
1954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Projectimport android.net.Uri;
2054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Projectimport android.os.Parcel;
2154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Projectimport android.os.Parcelable;
2254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Projectimport android.os.PatternMatcher;
2354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Projectimport android.util.AndroidException;
2454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Projectimport android.util.Log;
2554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Projectimport android.util.Printer;
262269d1572e5fcfb725ea55f5764d8c3280d69f6dDianne Hackborn
272269d1572e5fcfb725ea55f5764d8c3280d69f6dDianne Hackbornimport com.android.internal.util.XmlUtils;
2854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
2937051cdd8624c4821bb68169be427061c48ad837Gilles Debunneimport org.xmlpull.v1.XmlPullParser;
3037051cdd8624c4821bb68169be427061c48ad837Gilles Debunneimport org.xmlpull.v1.XmlPullParserException;
3137051cdd8624c4821bb68169be427061c48ad837Gilles Debunneimport org.xmlpull.v1.XmlSerializer;
3237051cdd8624c4821bb68169be427061c48ad837Gilles Debunne
3337051cdd8624c4821bb68169be427061c48ad837Gilles Debunneimport java.io.IOException;
3437051cdd8624c4821bb68169be427061c48ad837Gilles Debunneimport java.util.ArrayList;
3537051cdd8624c4821bb68169be427061c48ad837Gilles Debunneimport java.util.Iterator;
3637051cdd8624c4821bb68169be427061c48ad837Gilles Debunneimport java.util.Set;
3737051cdd8624c4821bb68169be427061c48ad837Gilles Debunne
3854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project/**
3954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Structured description of Intent values to be matched.  An IntentFilter can
4054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * match against actions, categories, and data (either via its type, scheme,
4154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * and/or path) in an Intent.  It also includes a "priority" value which is
4254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * used to order multiple matching filters.
4354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project *
4454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * <p>IntentFilter objects are often created in XML as part of a package's
4554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * {@link android.R.styleable#AndroidManifest AndroidManifest.xml} file,
4654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * using {@link android.R.styleable#AndroidManifestIntentFilter intent-filter}
4754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * tags.
4854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project *
4954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * <p>There are three Intent characteristics you can filter on: the
5054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * <em>action</em>, <em>data</em>, and <em>categories</em>.  For each of these
5154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * characteristics you can provide
5254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * multiple possible matching values (via {@link #addAction},
53df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn * {@link #addDataType}, {@link #addDataScheme}, {@link #addDataSchemeSpecificPart},
54df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn * {@link #addDataAuthority}, {@link #addDataPath}, and {@link #addCategory}, respectively).
5554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * For actions, the field
5654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * will not be tested if no values have been given (treating it as a wildcard);
5754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * if no data characteristics are specified, however, then the filter will
5854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * only match intents that contain no data.
5954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project *
6054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * <p>The data characteristic is
6154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * itself divided into three attributes: type, scheme, authority, and path.
6254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Any that are
6354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * specified must match the contents of the Intent.  If you specify a scheme
6454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * but no type, only Intent that does not have a type (such as mailto:) will
6554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * match; a content: URI will never match because they always have a MIME type
6654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * that is supplied by their content provider.  Specifying a type with no scheme
6754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * has somewhat special meaning: it will match either an Intent with no URI
6854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * field, or an Intent with a content: or file: URI.  If you specify neither,
6954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * then only an Intent with no data or type will match.  To specify an authority,
7054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * you must also specify one or more schemes that it is associated with.
7154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * To specify a path, you also must specify both one or more authorities and
7254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * one or more schemes it is associated with.
7354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project *
74b54e7a3d9f60ac605f404f9eb3c5e92ca51bbd23Joe Fernandez * <div class="special reference">
75b54e7a3d9f60ac605f404f9eb3c5e92ca51bbd23Joe Fernandez * <h3>Developer Guides</h3>
76b54e7a3d9f60ac605f404f9eb3c5e92ca51bbd23Joe Fernandez * <p>For information about how to create and resolve intents, read the
77b54e7a3d9f60ac605f404f9eb3c5e92ca51bbd23Joe Fernandez * <a href="{@docRoot}guide/topics/intents/intents-filters.html">Intents and Intent Filters</a>
78b54e7a3d9f60ac605f404f9eb3c5e92ca51bbd23Joe Fernandez * developer guide.</p>
79b54e7a3d9f60ac605f404f9eb3c5e92ca51bbd23Joe Fernandez * </div>
80b54e7a3d9f60ac605f404f9eb3c5e92ca51bbd23Joe Fernandez *
81b54e7a3d9f60ac605f404f9eb3c5e92ca51bbd23Joe Fernandez * <h3>Filter Rules</h3>
8254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * <p>A match is based on the following rules.  Note that
8354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * for an IntentFilter to match an Intent, three conditions must hold:
8454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * the <strong>action</strong> and <strong>category</strong> must match, and
8554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * the data (both the <strong>data type</strong> and
860ea920d8396e4c8596ddeaa5bd130fd012d9c4b9Dianne Hackborn * <strong>data scheme+authority+path</strong> if specified) must match
870ea920d8396e4c8596ddeaa5bd130fd012d9c4b9Dianne Hackborn * (see {@link #match(ContentResolver, Intent, boolean, String)} for more details
880ea920d8396e4c8596ddeaa5bd130fd012d9c4b9Dianne Hackborn * on how the data fields match).
8954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project *
9054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * <p><strong>Action</strong> matches if any of the given values match the
91a53ee35754d22e58978c9fd81396e599e00bac18Dianne Hackborn * Intent action; if the filter specifies no actions, then it will only match
92a53ee35754d22e58978c9fd81396e599e00bac18Dianne Hackborn * Intents that do not contain an action.
9354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project *
9454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * <p><strong>Data Type</strong> matches if any of the given values match the
9554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Intent type.  The Intent
9654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * type is determined by calling {@link Intent#resolveType}.  A wildcard can be
9754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * used for the MIME sub-type, in both the Intent and IntentFilter, so that the
9854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * type "audio/*" will match "audio/mpeg", "audio/aiff", "audio/*", etc.
99b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn * <em>Note that MIME type matching here is <b>case sensitive</b>, unlike
100b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn * formal RFC MIME types!</em>  You should thus always use lower case letters
101b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn * for your MIME types.
10254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project *
10354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * <p><strong>Data Scheme</strong> matches if any of the given values match the
10454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Intent data's scheme.
10554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * The Intent scheme is determined by calling {@link Intent#getData}
10654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * and {@link android.net.Uri#getScheme} on that URI.
107b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn * <em>Note that scheme matching here is <b>case sensitive</b>, unlike
108b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn * formal RFC schemes!</em>  You should thus always use lower case letters
109b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn * for your schemes.
11054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project *
111df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn * <p><strong>Data Scheme Specific Part</strong> matches if any of the given values match
112df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn * the Intent's data scheme specific part <em>and</em> one of the data schemes in the filter
113df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn * has matched the Intent, <em>or</em> no scheme specific parts were supplied in the filter.
114df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn * The Intent scheme specific part is determined by calling
115df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn * {@link Intent#getData} and {@link android.net.Uri#getSchemeSpecificPart} on that URI.
116df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn * <em>Note that scheme specific part matching is <b>case sensitive</b>.</em>
117df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn *
11854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * <p><strong>Data Authority</strong> matches if any of the given values match
119df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn * the Intent's data authority <em>and</em> one of the data schemes in the filter
12054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * has matched the Intent, <em>or</em> no authories were supplied in the filter.
12154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * The Intent authority is determined by calling
12254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * {@link Intent#getData} and {@link android.net.Uri#getAuthority} on that URI.
123b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn * <em>Note that authority matching here is <b>case sensitive</b>, unlike
124b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn * formal RFC host names!</em>  You should thus always use lower case letters
125b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn * for your authority.
126b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn *
12754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * <p><strong>Data Path</strong> matches if any of the given values match the
12854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * Intent's data path <em>and</em> both a scheme and authority in the filter
12954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * has matched against the Intent, <em>or</em> no paths were supplied in the
13054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * filter.  The Intent authority is determined by calling
13154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * {@link Intent#getData} and {@link android.net.Uri#getPath} on that URI.
13254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project *
13354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * <p><strong>Categories</strong> match if <em>all</em> of the categories in
13454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * the Intent match categories given in the filter.  Extra categories in the
13554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * filter that are not in the Intent will not cause the match to fail.  Note
13654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * that unlike the action, an IntentFilter with no categories
13754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project * will only match an Intent that does not have any categories.
13854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project */
13954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Projectpublic class IntentFilter implements Parcelable {
14054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private static final String SGLOB_STR = "sglob";
14154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private static final String PREFIX_STR = "prefix";
14254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private static final String LITERAL_STR = "literal";
14354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private static final String PATH_STR = "path";
14454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private static final String PORT_STR = "port";
14554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private static final String HOST_STR = "host";
14654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private static final String AUTH_STR = "auth";
147df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    private static final String SSP_STR = "ssp";
14854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private static final String SCHEME_STR = "scheme";
14954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private static final String TYPE_STR = "type";
15054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private static final String CAT_STR = "cat";
15154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private static final String NAME_STR = "name";
15254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private static final String ACTION_STR = "action";
15354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
15454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
15554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * The filter {@link #setPriority} value at which system high-priority
15654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * receivers are placed; that is, receivers that should execute before
15754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * application code. Applications should never use filters with this or
15854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * higher priorities.
15954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
16054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see #setPriority
16154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
16254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static final int SYSTEM_HIGH_PRIORITY = 1000;
16354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
16454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
16554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * The filter {@link #setPriority} value at which system low-priority
16654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * receivers are placed; that is, receivers that should execute after
16754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * application code. Applications should never use filters with this or
16854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * lower priorities.
16954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
17054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see #setPriority
17154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
17254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static final int SYSTEM_LOW_PRIORITY = -1000;
17354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
17454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
17554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * The part of a match constant that describes the category of match
17654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * that occurred.  May be either {@link #MATCH_CATEGORY_EMPTY},
177df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * {@link #MATCH_CATEGORY_SCHEME}, {@link #MATCH_CATEGORY_SCHEME_SPECIFIC_PART},
178df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * {@link #MATCH_CATEGORY_HOST}, {@link #MATCH_CATEGORY_PORT},
17954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * {@link #MATCH_CATEGORY_PATH}, or {@link #MATCH_CATEGORY_TYPE}.  Higher
18054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * values indicate a better match.
18154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
18254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static final int MATCH_CATEGORY_MASK = 0xfff0000;
18354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
18454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
18554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * The part of a match constant that applies a quality adjustment to the
18654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * basic category of match.  The value {@link #MATCH_ADJUSTMENT_NORMAL}
18754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * is no adjustment; higher numbers than that improve the quality, while
18854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * lower numbers reduce it.
18954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
19054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static final int MATCH_ADJUSTMENT_MASK = 0x000ffff;
19154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
19254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
19354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Quality adjustment applied to the category of match that signifies
19454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * the default, base value; higher numbers improve the quality while
19554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * lower numbers reduce it.
19654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
19754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static final int MATCH_ADJUSTMENT_NORMAL = 0x8000;
19854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
19954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
20054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * The filter matched an intent that had no data specified.
20154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
20254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static final int MATCH_CATEGORY_EMPTY = 0x0100000;
20354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
20454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * The filter matched an intent with the same data URI scheme.
20554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
20654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static final int MATCH_CATEGORY_SCHEME = 0x0200000;
20754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
20854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * The filter matched an intent with the same data URI scheme and
20954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * authority host.
21054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
21154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static final int MATCH_CATEGORY_HOST = 0x0300000;
21254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
21354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * The filter matched an intent with the same data URI scheme and
21454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * authority host and port.
21554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
21654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static final int MATCH_CATEGORY_PORT = 0x0400000;
21754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
21854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * The filter matched an intent with the same data URI scheme,
21954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * authority, and path.
22054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
22154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static final int MATCH_CATEGORY_PATH = 0x0500000;
22254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
223df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * The filter matched an intent with the same data URI scheme and
224df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * scheme specific part.
225df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     */
226df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    public static final int MATCH_CATEGORY_SCHEME_SPECIFIC_PART = 0x0580000;
227df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    /**
22854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * The filter matched an intent with the same data MIME type.
22954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
23054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static final int MATCH_CATEGORY_TYPE = 0x0600000;
23154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
23254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
23354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * The filter didn't match due to different MIME types.
23454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
23554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static final int NO_MATCH_TYPE = -1;
23654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
23754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * The filter didn't match due to different data URIs.
23854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
23954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static final int NO_MATCH_DATA = -2;
24054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
24154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * The filter didn't match due to different actions.
24254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
24354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static final int NO_MATCH_ACTION = -3;
24454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
24554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * The filter didn't match because it required one or more categories
24654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * that were not in the Intent.
24754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
24854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static final int NO_MATCH_CATEGORY = -4;
24954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
25054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private int mPriority;
25154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private final ArrayList<String> mActions;
25254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private ArrayList<String> mCategories = null;
25354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private ArrayList<String> mDataSchemes = null;
254df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    private ArrayList<PatternMatcher> mDataSchemeSpecificParts = null;
25554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private ArrayList<AuthorityEntry> mDataAuthorities = null;
25654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private ArrayList<PatternMatcher> mDataPaths = null;
25754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private ArrayList<String> mDataTypes = null;
25854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private boolean mHasPartialTypes = false;
25954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
26054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    // These functions are the start of more optimized code for managing
26154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    // the string sets...  not yet implemented.
26254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
26354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private static int findStringInSet(String[] set, String string,
26454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            int[] lengths, int lenPos) {
26554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (set == null) return -1;
26654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        final int N = lengths[lenPos];
26754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        for (int i=0; i<N; i++) {
26854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (set[i].equals(string)) return i;
26954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
27054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return -1;
27154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
27254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
27354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private static String[] addStringToSet(String[] set, String string,
27454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            int[] lengths, int lenPos) {
27554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (findStringInSet(set, string, lengths, lenPos) >= 0) return set;
27654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (set == null) {
27754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            set = new String[2];
27854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            set[0] = string;
27954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            lengths[lenPos] = 1;
28054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return set;
28154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
28254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        final int N = lengths[lenPos];
28354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (N < set.length) {
28454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            set[N] = string;
28554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            lengths[lenPos] = N+1;
28654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return set;
28754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
28854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
28954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        String[] newSet = new String[(N*3)/2 + 2];
29054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        System.arraycopy(set, 0, newSet, 0, N);
29154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        set = newSet;
29254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        set[N] = string;
29354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        lengths[lenPos] = N+1;
29454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return set;
29554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
29654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
29754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private static String[] removeStringFromSet(String[] set, String string,
29854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            int[] lengths, int lenPos) {
29954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        int pos = findStringInSet(set, string, lengths, lenPos);
30054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (pos < 0) return set;
30154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        final int N = lengths[lenPos];
30254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (N > (set.length/4)) {
30354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            int copyLen = N-(pos+1);
30454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (copyLen > 0) {
30554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                System.arraycopy(set, pos+1, set, pos, copyLen);
30654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
30754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            set[N-1] = null;
30854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            lengths[lenPos] = N-1;
30954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return set;
31054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
31154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
31254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        String[] newSet = new String[set.length/3];
31354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (pos > 0) System.arraycopy(set, 0, newSet, 0, pos);
31454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if ((pos+1) < N) System.arraycopy(set, pos+1, newSet, pos, N-(pos+1));
31554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return newSet;
31654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
31754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
31854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
31954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * This exception is thrown when a given MIME type does not have a valid
32054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * syntax.
32154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
32254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static class MalformedMimeTypeException extends AndroidException {
32354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        public MalformedMimeTypeException() {
32454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
32554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
32654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        public MalformedMimeTypeException(String name) {
32754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            super(name);
32854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
32954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    };
33054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
33154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
33254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Create a new IntentFilter instance with a specified action and MIME
33354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * type, where you know the MIME type is correctly formatted.  This catches
33454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * the {@link MalformedMimeTypeException} exception that the constructor
33554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * can call and turns it into a runtime exception.
33654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
33754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param action The action to match, i.e. Intent.ACTION_VIEW.
33854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param dataType The type to match, i.e. "vnd.android.cursor.dir/person".
33954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
34054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @return A new IntentFilter for the given action and type.
34154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
34254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see #IntentFilter(String, String)
34354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
34454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static IntentFilter create(String action, String dataType) {
34554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        try {
34654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return new IntentFilter(action, dataType);
34754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        } catch (MalformedMimeTypeException e) {
34854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            throw new RuntimeException("Bad MIME type", e);
34954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
35054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
35154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
35254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
35354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * New empty IntentFilter.
35454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
35554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public IntentFilter() {
35654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        mPriority = 0;
35754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        mActions = new ArrayList<String>();
35854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
35954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
36054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
36154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * New IntentFilter that matches a single action with no data.  If
36254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * no data characteristics are subsequently specified, then the
36354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * filter will only match intents that contain no data.
36454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
36554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param action The action to match, i.e. Intent.ACTION_MAIN.
36654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
36754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public IntentFilter(String action) {
36854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        mPriority = 0;
36954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        mActions = new ArrayList<String>();
37054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        addAction(action);
37154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
37254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
37354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
37454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * New IntentFilter that matches a single action and data type.
37554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
376b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * <p><em>Note: MIME type matching in the Android framework is
377b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * case-sensitive, unlike formal RFC MIME types.  As a result,
378b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * you should always write your MIME types with lower case letters,
379b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * and any MIME types you receive from outside of Android should be
380b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * converted to lower case before supplying them here.</em></p>
381b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     *
38254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * <p>Throws {@link MalformedMimeTypeException} if the given MIME type is
38354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * not syntactically correct.
38454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
38554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param action The action to match, i.e. Intent.ACTION_VIEW.
38654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param dataType The type to match, i.e. "vnd.android.cursor.dir/person".
38754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
38854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
38954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public IntentFilter(String action, String dataType)
39054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        throws MalformedMimeTypeException {
39154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        mPriority = 0;
39254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        mActions = new ArrayList<String>();
39324847f35177fd970670aa1ffdfc6639bbd11d1f5Tom Gibara        addAction(action);
39454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        addDataType(dataType);
39554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
39654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
39754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
39854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * New IntentFilter containing a copy of an existing filter.
39954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
40054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param o The original filter to copy.
40154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
40254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public IntentFilter(IntentFilter o) {
40354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        mPriority = o.mPriority;
40454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        mActions = new ArrayList<String>(o.mActions);
40554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (o.mCategories != null) {
40654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mCategories = new ArrayList<String>(o.mCategories);
40754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
40854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (o.mDataTypes != null) {
40954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mDataTypes = new ArrayList<String>(o.mDataTypes);
41054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
41154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (o.mDataSchemes != null) {
41254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mDataSchemes = new ArrayList<String>(o.mDataSchemes);
41354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
414df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        if (o.mDataSchemeSpecificParts != null) {
415df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            mDataSchemeSpecificParts = new ArrayList<PatternMatcher>(o.mDataSchemeSpecificParts);
416df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        }
41754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (o.mDataAuthorities != null) {
41854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mDataAuthorities = new ArrayList<AuthorityEntry>(o.mDataAuthorities);
41954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
42054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (o.mDataPaths != null) {
42154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mDataPaths = new ArrayList<PatternMatcher>(o.mDataPaths);
42254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
42354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        mHasPartialTypes = o.mHasPartialTypes;
42454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
42554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
42654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
42754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Modify priority of this filter.  The default priority is 0. Positive
42854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * values will be before the default, lower values will be after it.
42954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Applications must use a value that is larger than
43054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * {@link #SYSTEM_LOW_PRIORITY} and smaller than
43154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * {@link #SYSTEM_HIGH_PRIORITY} .
43254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
43354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param priority The new priority value.
43454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
43554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see #getPriority
43654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see #SYSTEM_LOW_PRIORITY
43754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see #SYSTEM_HIGH_PRIORITY
43854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
43954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final void setPriority(int priority) {
44054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        mPriority = priority;
44154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
44254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
44354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
44454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return the priority of this filter.
44554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
44654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @return The priority of the filter.
44754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
44854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see #setPriority
44954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
45054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final int getPriority() {
45154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mPriority;
45254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
45354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
45454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
45554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Add a new Intent action to match against.  If any actions are included
45654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * in the filter, then an Intent's action must be one of those values for
45754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * it to match.  If no actions are included, the Intent action is ignored.
45854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
45954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param action Name of the action to match, i.e. Intent.ACTION_VIEW.
46054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
46154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final void addAction(String action) {
46254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (!mActions.contains(action)) {
46354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mActions.add(action.intern());
46454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
46554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
46654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
46754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
46854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return the number of actions in the filter.
46954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
47054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final int countActions() {
47154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mActions.size();
47254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
47354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
47454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
47554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return an action in the filter.
47654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
47754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final String getAction(int index) {
47854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mActions.get(index);
47954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
48054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
48154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
48254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Is the given action included in the filter?  Note that if the filter
48354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * does not include any actions, false will <em>always</em> be returned.
48454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
48554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param action The action to look for.
48654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
48754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @return True if the action is explicitly mentioned in the filter.
48854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
48954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final boolean hasAction(String action) {
4902c376fc46cd01b12e003a7bf83d82f527f6efaf1Jeff Brown        return action != null && mActions.contains(action);
49154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
49254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
49354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
49454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Match this filter against an Intent's action.  If the filter does not
49554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * specify any actions, the match will always fail.
49654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
49754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param action The desired action to look for.
49854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
4992c376fc46cd01b12e003a7bf83d82f527f6efaf1Jeff Brown     * @return True if the action is listed in the filter.
50054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
50154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final boolean matchAction(String action) {
5022c376fc46cd01b12e003a7bf83d82f527f6efaf1Jeff Brown        return hasAction(action);
50354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
50454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
50554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
50654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return an iterator over the filter's actions.  If there are no actions,
50754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * returns null.
50854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
50954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final Iterator<String> actionsIterator() {
51054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mActions != null ? mActions.iterator() : null;
51154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
51254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
51354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
51454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Add a new Intent data type to match against.  If any types are
51554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * included in the filter, then an Intent's data must be <em>either</em>
51654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * one of these types <em>or</em> a matching scheme.  If no data types
51754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * are included, then an Intent will only match if it specifies no data.
51854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
519b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * <p><em>Note: MIME type matching in the Android framework is
520b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * case-sensitive, unlike formal RFC MIME types.  As a result,
521b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * you should always write your MIME types with lower case letters,
522b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * and any MIME types you receive from outside of Android should be
523b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * converted to lower case before supplying them here.</em></p>
524b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     *
52554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * <p>Throws {@link MalformedMimeTypeException} if the given MIME type is
52654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * not syntactically correct.
52754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
52854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param type Name of the data type to match, i.e. "vnd.android.cursor.dir/person".
52954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
53054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see #matchData
53154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
53254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final void addDataType(String type)
53354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        throws MalformedMimeTypeException {
53454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        final int slashpos = type.indexOf('/');
53554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        final int typelen = type.length();
53654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (slashpos > 0 && typelen >= slashpos+2) {
53754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (mDataTypes == null) mDataTypes = new ArrayList<String>();
53854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (typelen == slashpos+2 && type.charAt(slashpos+1) == '*') {
53954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                String str = type.substring(0, slashpos);
54054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                if (!mDataTypes.contains(str)) {
54154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    mDataTypes.add(str.intern());
54254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                }
54354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                mHasPartialTypes = true;
54454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            } else {
54554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                if (!mDataTypes.contains(type)) {
54654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    mDataTypes.add(type.intern());
54754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                }
54854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
54954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return;
55054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
55154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
55254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        throw new MalformedMimeTypeException(type);
55354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
55454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
55554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
55654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Is the given data type included in the filter?  Note that if the filter
55754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * does not include any type, false will <em>always</em> be returned.
55854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
55954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param type The data type to look for.
56054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
56154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @return True if the type is explicitly mentioned in the filter.
56254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
56354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final boolean hasDataType(String type) {
56454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mDataTypes != null && findMimeType(type);
56554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
56654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
56754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
56854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return the number of data types in the filter.
56954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
57054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final int countDataTypes() {
57154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mDataTypes != null ? mDataTypes.size() : 0;
57254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
57354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
57454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
57554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return a data type in the filter.
57654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
57754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final String getDataType(int index) {
57854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mDataTypes.get(index);
57954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
58054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
58154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
58254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return an iterator over the filter's data types.
58354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
58454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final Iterator<String> typesIterator() {
58554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mDataTypes != null ? mDataTypes.iterator() : null;
58654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
58754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
58854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
58954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Add a new Intent data scheme to match against.  If any schemes are
59054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * included in the filter, then an Intent's data must be <em>either</em>
59154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * one of these schemes <em>or</em> a matching data type.  If no schemes
59254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * are included, then an Intent will match only if it includes no data.
59354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
594b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * <p><em>Note: scheme matching in the Android framework is
595b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * case-sensitive, unlike formal RFC schemes.  As a result,
596b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * you should always write your schemes with lower case letters,
597b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * and any schemes you receive from outside of Android should be
598b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * converted to lower case before supplying them here.</em></p>
599b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     *
60054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param scheme Name of the scheme to match, i.e. "http".
60154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
60254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see #matchData
60354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
60454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final void addDataScheme(String scheme) {
60554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mDataSchemes == null) mDataSchemes = new ArrayList<String>();
60654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (!mDataSchemes.contains(scheme)) {
60754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mDataSchemes.add(scheme.intern());
60854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
60954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
61054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
61154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
61254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return the number of data schemes in the filter.
61354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
61454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final int countDataSchemes() {
61554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mDataSchemes != null ? mDataSchemes.size() : 0;
61654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
61754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
61854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
61954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return a data scheme in the filter.
62054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
62154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final String getDataScheme(int index) {
62254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mDataSchemes.get(index);
62354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
62454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
62554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
62654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Is the given data scheme included in the filter?  Note that if the
62754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * filter does not include any scheme, false will <em>always</em> be
62854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * returned.
62954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
63054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param scheme The data scheme to look for.
63154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
63254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @return True if the scheme is explicitly mentioned in the filter.
63354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
63454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final boolean hasDataScheme(String scheme) {
63554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mDataSchemes != null && mDataSchemes.contains(scheme);
63654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
63754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
63854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
63954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return an iterator over the filter's data schemes.
64054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
64154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final Iterator<String> schemesIterator() {
64254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mDataSchemes != null ? mDataSchemes.iterator() : null;
64354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
64454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
64554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
64654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * This is an entry for a single authority in the Iterator returned by
64754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * {@link #authoritiesIterator()}.
64854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
64954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final static class AuthorityEntry {
65054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        private final String mOrigHost;
65154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        private final String mHost;
65254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        private final boolean mWild;
65354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        private final int mPort;
65454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
65554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        public AuthorityEntry(String host, String port) {
65654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mOrigHost = host;
65754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mWild = host.length() > 0 && host.charAt(0) == '*';
65854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mHost = mWild ? host.substring(1).intern() : host;
65954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mPort = port != null ? Integer.parseInt(port) : -1;
66054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
66154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
66254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        AuthorityEntry(Parcel src) {
66354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mOrigHost = src.readString();
66454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mHost = src.readString();
66554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mWild = src.readInt() != 0;
66654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mPort = src.readInt();
66754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
66854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
66954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        void writeToParcel(Parcel dest) {
67054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dest.writeString(mOrigHost);
67154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dest.writeString(mHost);
67254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dest.writeInt(mWild ? 1 : 0);
67354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dest.writeInt(mPort);
67454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
67554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
67654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        public String getHost() {
67754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return mOrigHost;
67854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
67954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
68054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        public int getPort() {
68154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return mPort;
68254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
68354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
684b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn        /**
685b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn         * Determine whether this AuthorityEntry matches the given data Uri.
686b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn         * <em>Note that this comparison is case-sensitive, unlike formal
687b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn         * RFC host names.  You thus should always normalize to lower-case.</em>
688b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn         *
689b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn         * @param data The Uri to match.
690b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn         * @return Returns either {@link IntentFilter#NO_MATCH_DATA},
691b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn         * {@link IntentFilter#MATCH_CATEGORY_PORT}, or
692b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn         * {@link IntentFilter#MATCH_CATEGORY_HOST}.
693b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn         */
69454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        public int match(Uri data) {
69554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            String host = data.getHost();
69654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (host == null) {
69754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                return NO_MATCH_DATA;
69854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
69943a17654cf4bfe7f1ec22bd8b7b32daccdf27c09Joe Onorato            if (false) Log.v("IntentFilter",
70054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    "Match host " + host + ": " + mHost);
70154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (mWild) {
70254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                if (host.length() < mHost.length()) {
70354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    return NO_MATCH_DATA;
70454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                }
70554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                host = host.substring(host.length()-mHost.length());
70654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
70754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (host.compareToIgnoreCase(mHost) != 0) {
70854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                return NO_MATCH_DATA;
70954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
71054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (mPort >= 0) {
71154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                if (mPort != data.getPort()) {
71254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    return NO_MATCH_DATA;
71354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                }
71454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                return MATCH_CATEGORY_PORT;
71554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
71654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return MATCH_CATEGORY_HOST;
71754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
71854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    };
71954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
72054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
721df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * Add a new Intent data "scheme specific part" to match against.  The filter must
722df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * include one or more schemes (via {@link #addDataScheme}) for the
723df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * scheme specific part to be considered.  If any scheme specific parts are
724df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * included in the filter, then an Intent's data must match one of
725df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * them.  If no scheme specific parts are included, then only the scheme must match.
726df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     *
727ebc15ef80ff1b4354be99a45d348537f094d6b59Dianne Hackborn     * <p>The "scheme specific part" that this matches against is the string returned
728ebc15ef80ff1b4354be99a45d348537f094d6b59Dianne Hackborn     * by {@link android.net.Uri#getSchemeSpecificPart() Uri.getSchemeSpecificPart}.
729ebc15ef80ff1b4354be99a45d348537f094d6b59Dianne Hackborn     * For Uris that contain a path, this kind of matching is not generally of interest,
730ebc15ef80ff1b4354be99a45d348537f094d6b59Dianne Hackborn     * since {@link #addDataAuthority(String, String)} and
731ebc15ef80ff1b4354be99a45d348537f094d6b59Dianne Hackborn     * {@link #addDataPath(String, int)} can provide a better mechanism for matching
732ebc15ef80ff1b4354be99a45d348537f094d6b59Dianne Hackborn     * them.  However, for Uris that do not contain a path, the authority and path
733ebc15ef80ff1b4354be99a45d348537f094d6b59Dianne Hackborn     * are empty, so this is the only way to match against the non-scheme part.</p>
734ebc15ef80ff1b4354be99a45d348537f094d6b59Dianne Hackborn     *
735df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * @param ssp Either a raw string that must exactly match the scheme specific part
736df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * path, or a simple pattern, depending on <var>type</var>.
737df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * @param type Determines how <var>ssp</var> will be compared to
738df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * determine a match: either {@link PatternMatcher#PATTERN_LITERAL},
739df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * {@link PatternMatcher#PATTERN_PREFIX}, or
740df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * {@link PatternMatcher#PATTERN_SIMPLE_GLOB}.
741df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     *
742df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * @see #matchData
743df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * @see #addDataScheme
744df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     */
745df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    public final void addDataSchemeSpecificPart(String ssp, int type) {
746b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn        addDataSchemeSpecificPart(new PatternMatcher(ssp, type));
747b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn    }
748b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn
749b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn    /** @hide */
750b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn    public final void addDataSchemeSpecificPart(PatternMatcher ssp) {
751439e9bc85d854cec5ca89e8947a17693e84cb4aeDianne Hackborn        if (mDataSchemeSpecificParts == null) {
752439e9bc85d854cec5ca89e8947a17693e84cb4aeDianne Hackborn            mDataSchemeSpecificParts = new ArrayList<PatternMatcher>();
753439e9bc85d854cec5ca89e8947a17693e84cb4aeDianne Hackborn        }
754b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn        mDataSchemeSpecificParts.add(ssp);
755df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    }
756df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn
757df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    /**
758df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * Return the number of data scheme specific parts in the filter.
759df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     */
760df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    public final int countDataSchemeSpecificParts() {
761df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        return mDataSchemeSpecificParts != null ? mDataSchemeSpecificParts.size() : 0;
762df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    }
763df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn
764df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    /**
765df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * Return a data scheme specific part in the filter.
766df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     */
767df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    public final PatternMatcher getDataSchemeSpecificPart(int index) {
768df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        return mDataSchemeSpecificParts.get(index);
769df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    }
770df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn
771df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    /**
772df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * Is the given data scheme specific part included in the filter?  Note that if the
773df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * filter does not include any scheme specific parts, false will <em>always</em> be
774df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * returned.
775df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     *
776df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * @param data The scheme specific part that is being looked for.
777df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     *
778df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * @return Returns true if the data string matches a scheme specific part listed in the
779df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     *         filter.
780df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     */
781df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    public final boolean hasDataSchemeSpecificPart(String data) {
782df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        if (mDataSchemeSpecificParts == null) {
783df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            return false;
784df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        }
785df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        final int numDataSchemeSpecificParts = mDataSchemeSpecificParts.size();
786df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        for (int i = 0; i < numDataSchemeSpecificParts; i++) {
787df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            final PatternMatcher pe = mDataSchemeSpecificParts.get(i);
788df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            if (pe.match(data)) {
789df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                return true;
790df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            }
791df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        }
792df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        return false;
793df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    }
794df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn
795df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    /**
796df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     * Return an iterator over the filter's data scheme specific parts.
797df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn     */
798df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    public final Iterator<PatternMatcher> schemeSpecificPartsIterator() {
799df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        return mDataSchemeSpecificParts != null ? mDataSchemeSpecificParts.iterator() : null;
800df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    }
801df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn
802df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn    /**
80354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Add a new Intent data authority to match against.  The filter must
80454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * include one or more schemes (via {@link #addDataScheme}) for the
80554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * authority to be considered.  If any authorities are
80654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * included in the filter, then an Intent's data must match one of
80754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * them.  If no authorities are included, then only the scheme must match.
80854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
809b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * <p><em>Note: host name in the Android framework is
810b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * case-sensitive, unlike formal RFC host names.  As a result,
811b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * you should always write your host names with lower case letters,
812b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * and any host names you receive from outside of Android should be
813b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * converted to lower case before supplying them here.</em></p>
814b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     *
81554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param host The host part of the authority to match.  May start with a
81654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *             single '*' to wildcard the front of the host name.
81754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param port Optional port part of the authority to match.  If null, any
81854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *             port is allowed.
81954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
82054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see #matchData
82154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see #addDataScheme
82254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
82354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final void addDataAuthority(String host, String port) {
824b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn        if (port != null) port = port.intern();
825b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn        addDataAuthority(new AuthorityEntry(host.intern(), port));
826b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn    }
827b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn
828b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn    /** @hide */
829b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn    public final void addDataAuthority(AuthorityEntry ent) {
83054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mDataAuthorities == null) mDataAuthorities =
83154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                new ArrayList<AuthorityEntry>();
832b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn        mDataAuthorities.add(ent);
83354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
83454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
83554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
83654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return the number of data authorities in the filter.
83754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
83854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final int countDataAuthorities() {
83954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mDataAuthorities != null ? mDataAuthorities.size() : 0;
84054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
84154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
84254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
84354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return a data authority in the filter.
84454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
84554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final AuthorityEntry getDataAuthority(int index) {
84654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mDataAuthorities.get(index);
84754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
84854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
84954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
85054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Is the given data authority included in the filter?  Note that if the
85154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * filter does not include any authorities, false will <em>always</em> be
85254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * returned.
85354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
85454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param data The data whose authority is being looked for.
85554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
85654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @return Returns true if the data string matches an authority listed in the
85754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *         filter.
85854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
85954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final boolean hasDataAuthority(Uri data) {
86054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return matchDataAuthority(data) >= 0;
86154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
86254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
86354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
86454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return an iterator over the filter's data authorities.
86554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
86654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final Iterator<AuthorityEntry> authoritiesIterator() {
86754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mDataAuthorities != null ? mDataAuthorities.iterator() : null;
86854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
86954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
87054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
87137051cdd8624c4821bb68169be427061c48ad837Gilles Debunne     * Add a new Intent data path to match against.  The filter must
87254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * include one or more schemes (via {@link #addDataScheme}) <em>and</em>
87354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * one or more authorities (via {@link #addDataAuthority}) for the
87454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * path to be considered.  If any paths are
87554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * included in the filter, then an Intent's data must match one of
87654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * them.  If no paths are included, then only the scheme/authority must
87754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * match.
87854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
87954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * <p>The path given here can either be a literal that must directly
88054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * match or match against a prefix, or it can be a simple globbing pattern.
88154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * If the latter, you can use '*' anywhere in the pattern to match zero
88254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * or more instances of the previous character, '.' as a wildcard to match
88354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * any character, and '\' to escape the next character.
88454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
88554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param path Either a raw string that must exactly match the file
88654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * path, or a simple pattern, depending on <var>type</var>.
88754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param type Determines how <var>path</var> will be compared to
88854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * determine a match: either {@link PatternMatcher#PATTERN_LITERAL},
88954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * {@link PatternMatcher#PATTERN_PREFIX}, or
89054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * {@link PatternMatcher#PATTERN_SIMPLE_GLOB}.
89154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
89254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see #matchData
89354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see #addDataScheme
89454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see #addDataAuthority
89554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
89654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final void addDataPath(String path, int type) {
897b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn        addDataPath(new PatternMatcher(path.intern(), type));
898b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn    }
899b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn
900b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn    /** @hide */
901b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn    public final void addDataPath(PatternMatcher path) {
90254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mDataPaths == null) mDataPaths = new ArrayList<PatternMatcher>();
903b09491f271c0a647632e5a99bfe280cbb7106195Dianne Hackborn        mDataPaths.add(path);
90454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
90554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
90654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
90754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return the number of data paths in the filter.
90854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
90954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final int countDataPaths() {
91054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mDataPaths != null ? mDataPaths.size() : 0;
91154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
91254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
91354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
91454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return a data path in the filter.
91554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
91654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final PatternMatcher getDataPath(int index) {
91754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mDataPaths.get(index);
91854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
91954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
92054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
92154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Is the given data path included in the filter?  Note that if the
92254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * filter does not include any paths, false will <em>always</em> be
92354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * returned.
92454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
92554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param data The data path to look for.  This is without the scheme
92654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *             prefix.
92754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
92854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @return True if the data string matches a path listed in the
92954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *         filter.
93054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
93154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final boolean hasDataPath(String data) {
93254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mDataPaths == null) {
93354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return false;
93454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
9352c376fc46cd01b12e003a7bf83d82f527f6efaf1Jeff Brown        final int numDataPaths = mDataPaths.size();
9362c376fc46cd01b12e003a7bf83d82f527f6efaf1Jeff Brown        for (int i = 0; i < numDataPaths; i++) {
9372c376fc46cd01b12e003a7bf83d82f527f6efaf1Jeff Brown            final PatternMatcher pe = mDataPaths.get(i);
93854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (pe.match(data)) {
93954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                return true;
94054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
94154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
94254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return false;
94354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
94454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
94554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
94654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return an iterator over the filter's data paths.
94754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
94854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final Iterator<PatternMatcher> pathsIterator() {
94954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mDataPaths != null ? mDataPaths.iterator() : null;
95054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
95154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
95254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
95354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Match this intent filter against the given Intent data.  This ignores
95454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * the data scheme -- unlike {@link #matchData}, the authority will match
95554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * regardless of whether there is a matching scheme.
95654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
95754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param data The data whose authority is being looked for.
95854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
95954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @return Returns either {@link #MATCH_CATEGORY_HOST},
96054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * {@link #MATCH_CATEGORY_PORT}, {@link #NO_MATCH_DATA}.
96154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
96254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final int matchDataAuthority(Uri data) {
96354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mDataAuthorities == null) {
96454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return NO_MATCH_DATA;
96554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
9662c376fc46cd01b12e003a7bf83d82f527f6efaf1Jeff Brown        final int numDataAuthorities = mDataAuthorities.size();
9672c376fc46cd01b12e003a7bf83d82f527f6efaf1Jeff Brown        for (int i = 0; i < numDataAuthorities; i++) {
9682c376fc46cd01b12e003a7bf83d82f527f6efaf1Jeff Brown            final AuthorityEntry ae = mDataAuthorities.get(i);
96954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            int match = ae.match(data);
97054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (match >= 0) {
97154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                return match;
97254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
97354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
97454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return NO_MATCH_DATA;
97554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
97654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
97754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
97854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Match this filter against an Intent's data (type, scheme and path). If
97954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * the filter does not specify any types and does not specify any
98054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * schemes/paths, the match will only succeed if the intent does not
9810ea920d8396e4c8596ddeaa5bd130fd012d9c4b9Dianne Hackborn     * also specify a type or data.  If the filter does not specify any schemes,
9820ea920d8396e4c8596ddeaa5bd130fd012d9c4b9Dianne Hackborn     * it will implicitly match intents with no scheme, or the schemes "content:"
9830ea920d8396e4c8596ddeaa5bd130fd012d9c4b9Dianne Hackborn     * or "file:" (basically performing a MIME-type only match).  If the filter
9840ea920d8396e4c8596ddeaa5bd130fd012d9c4b9Dianne Hackborn     * does not specify any MIME types, the Intent also must not specify a MIME
9850ea920d8396e4c8596ddeaa5bd130fd012d9c4b9Dianne Hackborn     * type.
98654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
987b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * <p>Be aware that to match against an authority, you must also specify a base
98854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * scheme the authority is in.  To match against a data path, both a scheme
98954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * and authority must be specified.  If the filter does not specify any
99054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * types or schemes that it matches against, it is considered to be empty
99154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * (any authority or data path given is ignored, as if it were empty as
99254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * well).
99354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
994b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * <p><em>Note: MIME type, Uri scheme, and host name matching in the
995b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * Android framework is case-sensitive, unlike the formal RFC definitions.
996b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * As a result, you should always write these elements with lower case letters,
997b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * and normalize any MIME types or Uris you receive from
998b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * outside of Android to ensure these elements are lower case before
999b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     * supplying them here.</em></p>
1000b3cddae4994128983b6bf7e808a7670f90cc30e4Dianne Hackborn     *
100154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param type The desired data type to look for, as returned by
100254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *             Intent.resolveType().
100354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param scheme The desired data scheme to look for, as returned by
100454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *               Intent.getScheme().
100554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param data The full data string to match against, as supplied in
100654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *             Intent.data.
100754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
100854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @return Returns either a valid match constant (a combination of
100954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * {@link #MATCH_CATEGORY_MASK} and {@link #MATCH_ADJUSTMENT_MASK}),
101054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * or one of the error codes {@link #NO_MATCH_TYPE} if the type didn't match
101154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * or {@link #NO_MATCH_DATA} if the scheme/path didn't match.
101254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
101354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see #match
101454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
101554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final int matchData(String type, String scheme, Uri data) {
101654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        final ArrayList<String> types = mDataTypes;
101754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        final ArrayList<String> schemes = mDataSchemes;
101854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
101954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        int match = MATCH_CATEGORY_EMPTY;
102054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
102154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (types == null && schemes == null) {
102254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return ((type == null && data == null)
102354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                ? (MATCH_CATEGORY_EMPTY+MATCH_ADJUSTMENT_NORMAL) : NO_MATCH_DATA);
102454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
102554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
102654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (schemes != null) {
102754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (schemes.contains(scheme != null ? scheme : "")) {
102854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                match = MATCH_CATEGORY_SCHEME;
102954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            } else {
103054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                return NO_MATCH_DATA;
103154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
103254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
1033df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            final ArrayList<PatternMatcher> schemeSpecificParts = mDataSchemeSpecificParts;
1034df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            if (schemeSpecificParts != null) {
1035df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                match = hasDataSchemeSpecificPart(data.getSchemeSpecificPart())
1036df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                        ? MATCH_CATEGORY_SCHEME_SPECIFIC_PART : NO_MATCH_DATA;
1037df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            }
1038df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            if (match != MATCH_CATEGORY_SCHEME_SPECIFIC_PART) {
1039df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                // If there isn't any matching ssp, we need to match an authority.
1040df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                final ArrayList<AuthorityEntry> authorities = mDataAuthorities;
1041df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                if (authorities != null) {
1042df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                    int authMatch = matchDataAuthority(data);
1043df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                    if (authMatch >= 0) {
1044df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                        final ArrayList<PatternMatcher> paths = mDataPaths;
1045df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                        if (paths == null) {
1046df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                            match = authMatch;
1047df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                        } else if (hasDataPath(data.getPath())) {
1048df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                            match = MATCH_CATEGORY_PATH;
1049df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                        } else {
1050df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                            return NO_MATCH_DATA;
1051df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                        }
105254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    } else {
105354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                        return NO_MATCH_DATA;
105454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    }
105554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                }
105654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
1057df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            // If neither an ssp nor an authority matched, we're done.
1058df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            if (match == NO_MATCH_DATA) {
1059df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                return NO_MATCH_DATA;
1060df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            }
106154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        } else {
106254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            // Special case: match either an Intent with no data URI,
106354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            // or with a scheme: URI.  This is to give a convenience for
106454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            // the common case where you want to deal with data in a
106554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            // content provider, which is done by type, and we don't want
106654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            // to force everyone to say they handle content: or file: URIs.
106754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (scheme != null && !"".equals(scheme)
106854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    && !"content".equals(scheme)
106954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    && !"file".equals(scheme)) {
107054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                return NO_MATCH_DATA;
107154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
107254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
107354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
107454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (types != null) {
107554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (findMimeType(type)) {
107654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                match = MATCH_CATEGORY_TYPE;
107754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            } else {
107854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                return NO_MATCH_TYPE;
107954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
108054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        } else {
108154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            // If no MIME types are specified, then we will only match against
108254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            // an Intent that does not have a MIME type.
108354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (type != null) {
108454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                return NO_MATCH_TYPE;
108554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
108654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
108754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
108854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return match + MATCH_ADJUSTMENT_NORMAL;
108954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
109054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
109154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
109254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Add a new Intent category to match against.  The semantics of
109354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * categories is the opposite of actions -- an Intent includes the
109454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * categories that it requires, all of which must be included in the
109554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * filter in order to match.  In other words, adding a category to the
109654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * filter has no impact on matching unless that category is specified in
109754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * the intent.
109854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
109954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param category Name of category to match, i.e. Intent.CATEGORY_EMBED.
110054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
110154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final void addCategory(String category) {
110254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mCategories == null) mCategories = new ArrayList<String>();
110354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (!mCategories.contains(category)) {
110454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mCategories.add(category.intern());
110554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
110654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
110754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
110854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
110954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return the number of categories in the filter.
111054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
111154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final int countCategories() {
111254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mCategories != null ? mCategories.size() : 0;
111354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
111454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
111554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
111654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return a category in the filter.
111754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
111854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final String getCategory(int index) {
111954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mCategories.get(index);
112054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
112154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
112254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
112354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Is the given category included in the filter?
112454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
112554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param category The category that the filter supports.
112654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
112754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @return True if the category is explicitly mentioned in the filter.
112854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
112954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final boolean hasCategory(String category) {
113054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mCategories != null && mCategories.contains(category);
113154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
113254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
113354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
113454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Return an iterator over the filter's categories.
1135d2d2925ff7ae9456c1c6c9147b1b9fd9a99ea607Kenny Root     *
1136d2d2925ff7ae9456c1c6c9147b1b9fd9a99ea607Kenny Root     * @return Iterator if this filter has categories or {@code null} if none.
113754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
113854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final Iterator<String> categoriesIterator() {
113954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return mCategories != null ? mCategories.iterator() : null;
114054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
114154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
114254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
114354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Match this filter against an Intent's categories.  Each category in
114454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * the Intent must be specified by the filter; if any are not in the
114554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * filter, the match fails.
114654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
114754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param categories The categories included in the intent, as returned by
114854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *                   Intent.getCategories().
114954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
115054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @return If all categories match (success), null; else the name of the
115154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *         first category that didn't match.
115254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
115354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final String matchCategories(Set<String> categories) {
115454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (categories == null) {
115554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return null;
115654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
115754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
115854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        Iterator<String> it = categories.iterator();
115954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
116054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mCategories == null) {
116154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return it.hasNext() ? it.next() : null;
116254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
116354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
116454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        while (it.hasNext()) {
116554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            final String category = it.next();
116654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (!mCategories.contains(category)) {
116754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                return category;
116854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
116954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
117054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
117154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return null;
117254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
117354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
117454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
117554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Test whether this filter matches the given <var>intent</var>.
117654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
117754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param intent The Intent to compare against.
117854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param resolve If true, the intent's type will be resolved by calling
117954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *                Intent.resolveType(); otherwise a simple match against
118054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *                Intent.type will be performed.
118154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param logTag Tag to use in debugging messages.
118254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
118354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @return Returns either a valid match constant (a combination of
118454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * {@link #MATCH_CATEGORY_MASK} and {@link #MATCH_ADJUSTMENT_MASK}),
118554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * or one of the error codes {@link #NO_MATCH_TYPE} if the type didn't match,
118654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * {@link #NO_MATCH_DATA} if the scheme/path didn't match,
118754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * {@link #NO_MATCH_ACTION if the action didn't match, or
118854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * {@link #NO_MATCH_CATEGORY} if one or more categories didn't match.
118954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
119054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @return How well the filter matches.  Negative if it doesn't match,
119154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *         zero or positive positive value if it does with a higher
119254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *         value representing a better match.
119354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
119454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see #match(String, String, String, android.net.Uri , Set, String)
119554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
119654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final int match(ContentResolver resolver, Intent intent,
119754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            boolean resolve, String logTag) {
119854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        String type = resolve ? intent.resolveType(resolver) : intent.getType();
119954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return match(intent.getAction(), type, intent.getScheme(),
120054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                     intent.getData(), intent.getCategories(), logTag);
120154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
120254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
120354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
120454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Test whether this filter matches the given intent data.  A match is
120554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * only successful if the actions and categories in the Intent match
120654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * against the filter, as described in {@link IntentFilter}; in that case,
120754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * the match result returned will be as per {@link #matchData}.
120854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
120954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param action The intent action to match against (Intent.getAction).
121054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param type The intent type to match against (Intent.resolveType()).
121154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param scheme The data scheme to match against (Intent.getScheme()).
121254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param data The data URI to match against (Intent.getData()).
121354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param categories The categories to match against
121454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *                   (Intent.getCategories()).
121554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @param logTag Tag to use in debugging messages.
121654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
121754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @return Returns either a valid match constant (a combination of
121854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * {@link #MATCH_CATEGORY_MASK} and {@link #MATCH_ADJUSTMENT_MASK}),
121954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * or one of the error codes {@link #NO_MATCH_TYPE} if the type didn't match,
122054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * {@link #NO_MATCH_DATA} if the scheme/path didn't match,
122154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * {@link #NO_MATCH_ACTION if the action didn't match, or
122254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * {@link #NO_MATCH_CATEGORY} if one or more categories didn't match.
122354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
122454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see #matchData
122554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see Intent#getAction
122654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see Intent#resolveType
122754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see Intent#getScheme
122854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see Intent#getData
122954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * @see Intent#getCategories
123054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
123154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final int match(String action, String type, String scheme,
123254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            Uri data, Set<String> categories, String logTag) {
1233239f77d20adcc0e2ce67a7907b3f6ca75b13fd00Jeff Brown        if (action != null && !matchAction(action)) {
123443a17654cf4bfe7f1ec22bd8b7b32daccdf27c09Joe Onorato            if (false) Log.v(
123554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                logTag, "No matching action " + action + " for " + this);
123654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return NO_MATCH_ACTION;
123754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
123854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
123954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        int dataMatch = matchData(type, scheme, data);
124054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (dataMatch < 0) {
124143a17654cf4bfe7f1ec22bd8b7b32daccdf27c09Joe Onorato            if (false) {
124254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                if (dataMatch == NO_MATCH_TYPE) {
124354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    Log.v(logTag, "No matching type " + type
124454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                          + " for " + this);
124554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                }
124654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                if (dataMatch == NO_MATCH_DATA) {
124754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    Log.v(logTag, "No matching scheme/path " + data
124854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                          + " for " + this);
124954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                }
125054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
125154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return dataMatch;
125254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
125354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
12542c376fc46cd01b12e003a7bf83d82f527f6efaf1Jeff Brown        String categoryMismatch = matchCategories(categories);
12552c376fc46cd01b12e003a7bf83d82f527f6efaf1Jeff Brown        if (categoryMismatch != null) {
125643a17654cf4bfe7f1ec22bd8b7b32daccdf27c09Joe Onorato            if (false) {
12572c376fc46cd01b12e003a7bf83d82f527f6efaf1Jeff Brown                Log.v(logTag, "No matching category " + categoryMismatch + " for " + this);
12582c376fc46cd01b12e003a7bf83d82f527f6efaf1Jeff Brown            }
125954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return NO_MATCH_CATEGORY;
126054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
126154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
126254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        // It would be nice to treat container activities as more
126354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        // important than ones that can be embedded, but this is not the way...
126454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (false) {
126554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (categories != null) {
126654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                dataMatch -= mCategories.size() - categories.size();
126754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
126854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
126954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
127054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return dataMatch;
127154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
127254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
127354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
127454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * Write the contents of the IntentFilter as an XML stream.
127554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
127654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public void writeToXml(XmlSerializer serializer) throws IOException {
127754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        int N = countActions();
127854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        for (int i=0; i<N; i++) {
127954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            serializer.startTag(null, ACTION_STR);
128054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            serializer.attribute(null, NAME_STR, mActions.get(i));
128154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            serializer.endTag(null, ACTION_STR);
128254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
128354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        N = countCategories();
128454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        for (int i=0; i<N; i++) {
128554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            serializer.startTag(null, CAT_STR);
128654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            serializer.attribute(null, NAME_STR, mCategories.get(i));
128754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            serializer.endTag(null, CAT_STR);
128854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
128954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        N = countDataTypes();
129054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        for (int i=0; i<N; i++) {
129154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            serializer.startTag(null, TYPE_STR);
129254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            String type = mDataTypes.get(i);
129354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (type.indexOf('/') < 0) type = type + "/*";
129454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            serializer.attribute(null, NAME_STR, type);
129554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            serializer.endTag(null, TYPE_STR);
129654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
129754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        N = countDataSchemes();
129854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        for (int i=0; i<N; i++) {
129954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            serializer.startTag(null, SCHEME_STR);
130054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            serializer.attribute(null, NAME_STR, mDataSchemes.get(i));
130154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            serializer.endTag(null, SCHEME_STR);
130254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
1303df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        N = countDataSchemeSpecificParts();
1304df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        for (int i=0; i<N; i++) {
1305df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            serializer.startTag(null, SSP_STR);
1306df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            PatternMatcher pe = mDataSchemeSpecificParts.get(i);
1307df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            switch (pe.getType()) {
1308df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                case PatternMatcher.PATTERN_LITERAL:
1309df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                    serializer.attribute(null, LITERAL_STR, pe.getPath());
1310df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                    break;
1311df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                case PatternMatcher.PATTERN_PREFIX:
1312df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                    serializer.attribute(null, PREFIX_STR, pe.getPath());
1313df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                    break;
1314df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                case PatternMatcher.PATTERN_SIMPLE_GLOB:
1315df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                    serializer.attribute(null, SGLOB_STR, pe.getPath());
1316df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                    break;
1317df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            }
1318df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            serializer.endTag(null, SSP_STR);
1319df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        }
132054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        N = countDataAuthorities();
132154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        for (int i=0; i<N; i++) {
132254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            serializer.startTag(null, AUTH_STR);
132354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            AuthorityEntry ae = mDataAuthorities.get(i);
132454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            serializer.attribute(null, HOST_STR, ae.getHost());
132554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (ae.getPort() >= 0) {
132654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                serializer.attribute(null, PORT_STR, Integer.toString(ae.getPort()));
132754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
132854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            serializer.endTag(null, AUTH_STR);
132954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
133054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        N = countDataPaths();
133154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        for (int i=0; i<N; i++) {
133254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            serializer.startTag(null, PATH_STR);
133354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            PatternMatcher pe = mDataPaths.get(i);
133454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            switch (pe.getType()) {
133554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                case PatternMatcher.PATTERN_LITERAL:
133654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    serializer.attribute(null, LITERAL_STR, pe.getPath());
133754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    break;
133854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                case PatternMatcher.PATTERN_PREFIX:
133954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    serializer.attribute(null, PREFIX_STR, pe.getPath());
134054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    break;
134154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                case PatternMatcher.PATTERN_SIMPLE_GLOB:
134254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    serializer.attribute(null, SGLOB_STR, pe.getPath());
134354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    break;
134454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
134554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            serializer.endTag(null, PATH_STR);
134654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
134754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
134854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
134954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public void readFromXml(XmlPullParser parser) throws XmlPullParserException,
135054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            IOException {
135154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        int outerDepth = parser.getDepth();
135254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        int type;
135354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        while ((type=parser.next()) != XmlPullParser.END_DOCUMENT
135454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project               && (type != XmlPullParser.END_TAG
135554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                       || parser.getDepth() > outerDepth)) {
135654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (type == XmlPullParser.END_TAG
135754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    || type == XmlPullParser.TEXT) {
135854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                continue;
135954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
136054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
136154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            String tagName = parser.getName();
136254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (tagName.equals(ACTION_STR)) {
136354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                String name = parser.getAttributeValue(null, NAME_STR);
136454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                if (name != null) {
136554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    addAction(name);
136654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                }
136754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            } else if (tagName.equals(CAT_STR)) {
136854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                String name = parser.getAttributeValue(null, NAME_STR);
136954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                if (name != null) {
137054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    addCategory(name);
137154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                }
137254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            } else if (tagName.equals(TYPE_STR)) {
137354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                String name = parser.getAttributeValue(null, NAME_STR);
137454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                if (name != null) {
137554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    try {
137654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                        addDataType(name);
137754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    } catch (MalformedMimeTypeException e) {
137854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    }
137954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                }
138054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            } else if (tagName.equals(SCHEME_STR)) {
138154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                String name = parser.getAttributeValue(null, NAME_STR);
138254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                if (name != null) {
138354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    addDataScheme(name);
138454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                }
1385df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            } else if (tagName.equals(SSP_STR)) {
1386df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                String ssp = parser.getAttributeValue(null, LITERAL_STR);
1387df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                if (ssp != null) {
1388df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                    addDataSchemeSpecificPart(ssp, PatternMatcher.PATTERN_LITERAL);
1389df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                } else if ((ssp=parser.getAttributeValue(null, PREFIX_STR)) != null) {
1390df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                    addDataSchemeSpecificPart(ssp, PatternMatcher.PATTERN_PREFIX);
1391df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                } else if ((ssp=parser.getAttributeValue(null, SGLOB_STR)) != null) {
1392df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                    addDataSchemeSpecificPart(ssp, PatternMatcher.PATTERN_SIMPLE_GLOB);
1393df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                }
139454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            } else if (tagName.equals(AUTH_STR)) {
139554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                String host = parser.getAttributeValue(null, HOST_STR);
139654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                String port = parser.getAttributeValue(null, PORT_STR);
139754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                if (host != null) {
139854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    addDataAuthority(host, port);
139954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                }
140054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            } else if (tagName.equals(PATH_STR)) {
140154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                String path = parser.getAttributeValue(null, LITERAL_STR);
140254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                if (path != null) {
140354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    addDataPath(path, PatternMatcher.PATTERN_LITERAL);
140454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                } else if ((path=parser.getAttributeValue(null, PREFIX_STR)) != null) {
140554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    addDataPath(path, PatternMatcher.PATTERN_PREFIX);
140654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                } else if ((path=parser.getAttributeValue(null, SGLOB_STR)) != null) {
140754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    addDataPath(path, PatternMatcher.PATTERN_SIMPLE_GLOB);
140854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                }
140954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            } else {
141054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                Log.w("IntentFilter", "Unknown tag parsing IntentFilter: " + tagName);
141154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
141254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            XmlUtils.skipCurrentTag(parser);
141354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
141454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
141554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
141654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public void dump(Printer du, String prefix) {
14171d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn        StringBuilder sb = new StringBuilder(256);
141854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mActions.size() > 0) {
141954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            Iterator<String> it = mActions.iterator();
142054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            while (it.hasNext()) {
14211d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                sb.setLength(0);
14221d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                sb.append(prefix); sb.append("Action: \"");
14231d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                        sb.append(it.next()); sb.append("\"");
14241d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                du.println(sb.toString());
142554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
142654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
142754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mCategories != null) {
142854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            Iterator<String> it = mCategories.iterator();
142954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            while (it.hasNext()) {
14301d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                sb.setLength(0);
14311d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                sb.append(prefix); sb.append("Category: \"");
14321d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                        sb.append(it.next()); sb.append("\"");
14331d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                du.println(sb.toString());
143454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
143554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
143654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mDataSchemes != null) {
143754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            Iterator<String> it = mDataSchemes.iterator();
143854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            while (it.hasNext()) {
14391d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                sb.setLength(0);
14401d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                sb.append(prefix); sb.append("Scheme: \"");
14411d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                        sb.append(it.next()); sb.append("\"");
14421d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                du.println(sb.toString());
144354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
144454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
1445df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        if (mDataSchemeSpecificParts != null) {
1446df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            Iterator<PatternMatcher> it = mDataSchemeSpecificParts.iterator();
1447df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            while (it.hasNext()) {
1448df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                PatternMatcher pe = it.next();
1449df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                sb.setLength(0);
1450df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                sb.append(prefix); sb.append("Ssp: \"");
1451df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                        sb.append(pe); sb.append("\"");
1452df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                du.println(sb.toString());
1453df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            }
1454df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        }
145554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mDataAuthorities != null) {
145654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            Iterator<AuthorityEntry> it = mDataAuthorities.iterator();
145754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            while (it.hasNext()) {
145854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                AuthorityEntry ae = it.next();
14591d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                sb.setLength(0);
14601d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                sb.append(prefix); sb.append("Authority: \"");
14611d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                        sb.append(ae.mHost); sb.append("\": ");
14621d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                        sb.append(ae.mPort);
14631d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                if (ae.mWild) sb.append(" WILD");
14641d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                du.println(sb.toString());
146554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
146654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
146754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mDataPaths != null) {
146854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            Iterator<PatternMatcher> it = mDataPaths.iterator();
146954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            while (it.hasNext()) {
147054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                PatternMatcher pe = it.next();
14711d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                sb.setLength(0);
14721d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                sb.append(prefix); sb.append("Path: \"");
14731d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                        sb.append(pe); sb.append("\"");
14741d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                du.println(sb.toString());
147554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
147654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
147754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mDataTypes != null) {
147854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            Iterator<String> it = mDataTypes.iterator();
147954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            while (it.hasNext()) {
14801d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                sb.setLength(0);
14811d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                sb.append(prefix); sb.append("Type: \"");
14821d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                        sb.append(it.next()); sb.append("\"");
14831d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                du.println(sb.toString());
148454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
148554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
14861d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn        if (mPriority != 0 || mHasPartialTypes) {
14871d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn            sb.setLength(0);
14881d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn            sb.append(prefix); sb.append("mPriority="); sb.append(mPriority);
14891d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn                    sb.append(", mHasPartialTypes="); sb.append(mHasPartialTypes);
14901d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn            du.println(sb.toString());
14911d442e0d990b581357f33f5463c7c5cb49b551e8Dianne Hackborn        }
149254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
149354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
149454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public static final Parcelable.Creator<IntentFilter> CREATOR
149554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            = new Parcelable.Creator<IntentFilter>() {
149654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        public IntentFilter createFromParcel(Parcel source) {
149754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return new IntentFilter(source);
149854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
149954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
150054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        public IntentFilter[] newArray(int size) {
150154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return new IntentFilter[size];
150254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
150354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    };
150454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
150554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final int describeContents() {
150654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return 0;
150754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
150854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
150954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public final void writeToParcel(Parcel dest, int flags) {
151054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        dest.writeStringList(mActions);
151154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mCategories != null) {
151254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dest.writeInt(1);
151354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dest.writeStringList(mCategories);
151454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        } else {
151554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dest.writeInt(0);
151654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
151754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mDataSchemes != null) {
151854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dest.writeInt(1);
151954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dest.writeStringList(mDataSchemes);
152054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        } else {
152154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dest.writeInt(0);
152254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
152354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mDataTypes != null) {
152454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dest.writeInt(1);
152554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dest.writeStringList(mDataTypes);
152654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        } else {
152754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dest.writeInt(0);
152854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
1529df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        if (mDataSchemeSpecificParts != null) {
1530df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            final int N = mDataSchemeSpecificParts.size();
1531df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            dest.writeInt(N);
1532df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            for (int i=0; i<N; i++) {
1533439e9bc85d854cec5ca89e8947a17693e84cb4aeDianne Hackborn                mDataSchemeSpecificParts.get(i).writeToParcel(dest, flags);
1534df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            }
1535df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        } else {
1536df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            dest.writeInt(0);
1537df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        }
153854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mDataAuthorities != null) {
153954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            final int N = mDataAuthorities.size();
154054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dest.writeInt(N);
154154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            for (int i=0; i<N; i++) {
154254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                mDataAuthorities.get(i).writeToParcel(dest);
154354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
154454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        } else {
154554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dest.writeInt(0);
154654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
154754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mDataPaths != null) {
154854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            final int N = mDataPaths.size();
154954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dest.writeInt(N);
155054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            for (int i=0; i<N; i++) {
1551439e9bc85d854cec5ca89e8947a17693e84cb4aeDianne Hackborn                mDataPaths.get(i).writeToParcel(dest, flags);
155254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
155354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        } else {
155454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dest.writeInt(0);
155554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
155654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        dest.writeInt(mPriority);
155754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        dest.writeInt(mHasPartialTypes ? 1 : 0);
155854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
155954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
156054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    /**
156154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * For debugging -- perform a check on the filter, return true if it passed
156254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * or false if it failed.
156354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     *
156454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     * {@hide}
156554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project     */
156654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    public boolean debugCheck() {
156754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return true;
156854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
156954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        // This code looks for intent filters that do not specify data.
157054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        /*
157154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mActions != null && mActions.size() == 1
157254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                && mActions.contains(Intent.ACTION_MAIN)) {
157354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return true;
157454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
157554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
157654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mDataTypes == null && mDataSchemes == null) {
157754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            Log.w("IntentFilter", "QUESTIONABLE INTENT FILTER:");
157854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            dump(Log.WARN, "IntentFilter", "  ");
157954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return false;
158054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
158154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
158254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return true;
158354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        */
158454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
158554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
158654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private IntentFilter(Parcel source) {
158754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        mActions = new ArrayList<String>();
158854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        source.readStringList(mActions);
158954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (source.readInt() != 0) {
159054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mCategories = new ArrayList<String>();
159154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            source.readStringList(mCategories);
159254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
159354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (source.readInt() != 0) {
159454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mDataSchemes = new ArrayList<String>();
159554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            source.readStringList(mDataSchemes);
159654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
159754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (source.readInt() != 0) {
159854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            mDataTypes = new ArrayList<String>();
159954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            source.readStringList(mDataTypes);
160054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
160154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        int N = source.readInt();
160254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (N > 0) {
1603df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            mDataSchemeSpecificParts = new ArrayList<PatternMatcher>(N);
1604df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            for (int i=0; i<N; i++) {
1605df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn                mDataSchemeSpecificParts.add(new PatternMatcher(source));
1606df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            }
1607df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        }
1608df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        N = source.readInt();
1609df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn        if (N > 0) {
1610df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            mDataAuthorities = new ArrayList<AuthorityEntry>(N);
161154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            for (int i=0; i<N; i++) {
161254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                mDataAuthorities.add(new AuthorityEntry(source));
161354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
161454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
161554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        N = source.readInt();
161654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (N > 0) {
1617df1c0bf7744d4abd3e2000fcfec01c119b857c75Dianne Hackborn            mDataPaths = new ArrayList<PatternMatcher>(N);
161854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            for (int i=0; i<N; i++) {
161954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                mDataPaths.add(new PatternMatcher(source));
162054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
162154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
162254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        mPriority = source.readInt();
162354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        mHasPartialTypes = source.readInt() > 0;
162454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
162554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
162654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    private final boolean findMimeType(String type) {
162754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        final ArrayList<String> t = mDataTypes;
162854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
162954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (type == null) {
163054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return false;
163154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
163254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
163354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (t.contains(type)) {
163454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return true;
163554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
163654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
163754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        // Deal with an Intent wanting to match every type in the IntentFilter.
163854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        final int typeLength = type.length();
163954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (typeLength == 3 && type.equals("*/*")) {
164054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return !t.isEmpty();
164154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
164254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
164354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        // Deal with this IntentFilter wanting to match every Intent type.
164454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (mHasPartialTypes && t.contains("*")) {
164554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            return true;
164654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
164754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
164854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        final int slashpos = type.indexOf('/');
164954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        if (slashpos > 0) {
165054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (mHasPartialTypes && t.contains(type.substring(0, slashpos))) {
165154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                return true;
165254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
165354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            if (typeLength == slashpos+2 && type.charAt(slashpos+1) == '*') {
165454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                // Need to look through all types for one that matches
165554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                // our base...
16562c376fc46cd01b12e003a7bf83d82f527f6efaf1Jeff Brown                final int numTypes = t.size();
16572c376fc46cd01b12e003a7bf83d82f527f6efaf1Jeff Brown                for (int i = 0; i < numTypes; i++) {
16582c376fc46cd01b12e003a7bf83d82f527f6efaf1Jeff Brown                    final String v = t.get(i);
165954b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    if (type.regionMatches(0, v, 0, slashpos+1)) {
166054b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                        return true;
166154b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                    }
166254b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project                }
166354b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project            }
166454b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        }
166554b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project
166654b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project        return false;
166754b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project    }
166854b6cfa9a9e5b861a9930af873580d6dc20f773The Android Open Source Project}
1669