19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/*
29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Copyright (C) 2006 The Android Open Source Project
39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Licensed under the Apache License, Version 2.0 (the "License");
59066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * you may not use this file except in compliance with the License.
69066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * You may obtain a copy of the License at
79066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0
99066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * Unless required by applicable law or agreed to in writing, software
119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * distributed under the License is distributed on an "AS IS" BASIS,
129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * See the License for the specific language governing permissions and
149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * limitations under the License.
159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpackage android.text;
189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/**
209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * This is the class for text whose content is immutable but to which
219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * markup objects can be attached and detached.
229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * For mutable text, see {@link SpannableStringBuilder}.
239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic class SpannableString
259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectextends SpannableStringInternal
269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectimplements CharSequence, GetChars, Spannable
279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project{
283483bc7d648ad96916eb68203103dc9668dd0be7Seigo Nonaka    /**
293483bc7d648ad96916eb68203103dc9668dd0be7Seigo Nonaka     * @param source source object to copy from
303483bc7d648ad96916eb68203103dc9668dd0be7Seigo Nonaka     * @param ignoreNoCopySpan whether to copy NoCopySpans in the {@code source}
313483bc7d648ad96916eb68203103dc9668dd0be7Seigo Nonaka     * @hide
323483bc7d648ad96916eb68203103dc9668dd0be7Seigo Nonaka     */
333483bc7d648ad96916eb68203103dc9668dd0be7Seigo Nonaka    public SpannableString(CharSequence source, boolean ignoreNoCopySpan) {
343483bc7d648ad96916eb68203103dc9668dd0be7Seigo Nonaka        super(source, 0, source.length(), ignoreNoCopySpan);
353483bc7d648ad96916eb68203103dc9668dd0be7Seigo Nonaka    }
363483bc7d648ad96916eb68203103dc9668dd0be7Seigo Nonaka
373483bc7d648ad96916eb68203103dc9668dd0be7Seigo Nonaka    /**
383483bc7d648ad96916eb68203103dc9668dd0be7Seigo Nonaka     * For the backward compatibility reasons, this constructor copies all spans including {@link
393483bc7d648ad96916eb68203103dc9668dd0be7Seigo Nonaka     * android.text.NoCopySpan}.
403483bc7d648ad96916eb68203103dc9668dd0be7Seigo Nonaka     * @param source source text
413483bc7d648ad96916eb68203103dc9668dd0be7Seigo Nonaka     */
429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public SpannableString(CharSequence source) {
433483bc7d648ad96916eb68203103dc9668dd0be7Seigo Nonaka        this(source, false /* ignoreNoCopySpan */);  // preserve existing NoCopySpan behavior
449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private SpannableString(CharSequence source, int start, int end) {
473483bc7d648ad96916eb68203103dc9668dd0be7Seigo Nonaka        // preserve existing NoCopySpan behavior
483483bc7d648ad96916eb68203103dc9668dd0be7Seigo Nonaka        super(source, start, end, false /* ignoreNoCopySpan */);
499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static SpannableString valueOf(CharSequence source) {
529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (source instanceof SpannableString) {
539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return (SpannableString) source;
549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        } else {
559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return new SpannableString(source);
569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void setSpan(Object what, int start, int end, int flags) {
609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        super.setSpan(what, start, end, flags);
619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public void removeSpan(Object what) {
649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        super.removeSpan(what);
659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public final CharSequence subSequence(int start, int end) {
689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return new SpannableString(this, start, end);
699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project}
71