130 lines
4.4 KiB
Java
130 lines
4.4 KiB
Java
![]() |
/* GENERATED SOURCE. DO NOT MODIFY. */
|
||
|
/*
|
||
|
* Copyright (C) 2011 The Libphonenumber Authors
|
||
|
*
|
||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||
|
* you may not use this file except in compliance with the License.
|
||
|
* You may obtain a copy of the License at
|
||
|
*
|
||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||
|
*
|
||
|
* Unless required by applicable law or agreed to in writing, software
|
||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
|
* See the License for the specific language governing permissions and
|
||
|
* limitations under the License.
|
||
|
*/
|
||
|
|
||
|
package com.android.i18n.phonenumbers;
|
||
|
|
||
|
import com.android.i18n.phonenumbers.Phonenumber.PhoneNumber;
|
||
|
|
||
|
import java.util.Arrays;
|
||
|
|
||
|
/**
|
||
|
* The immutable match of a phone number within a piece of text. Matches may be found using
|
||
|
* {@link PhoneNumberUtil#findNumbers}.
|
||
|
*
|
||
|
* <p>A match consists of the {@linkplain #number() phone number} as well as the
|
||
|
* {@linkplain #start() start} and {@linkplain #end() end} offsets of the corresponding subsequence
|
||
|
* of the searched text. Use {@link #rawString()} to obtain a copy of the matched subsequence.
|
||
|
*
|
||
|
* <p>The following annotated example clarifies the relationship between the searched text, the
|
||
|
* match offsets, and the parsed number:
|
||
|
|
||
|
* <pre>
|
||
|
* CharSequence text = "Call me at +1 425 882-8080 for details.";
|
||
|
* String country = "US";
|
||
|
* PhoneNumberUtil util = PhoneNumberUtil.getInstance();
|
||
|
*
|
||
|
* // Find the first phone number match:
|
||
|
* PhoneNumberMatch m = util.findNumbers(text, country).iterator().next();
|
||
|
*
|
||
|
* // rawString() contains the phone number as it appears in the text.
|
||
|
* "+1 425 882-8080".equals(m.rawString());
|
||
|
*
|
||
|
* // start() and end() define the range of the matched subsequence.
|
||
|
* CharSequence subsequence = text.subSequence(m.start(), m.end());
|
||
|
* "+1 425 882-8080".contentEquals(subsequence);
|
||
|
*
|
||
|
* // number() returns the the same result as PhoneNumberUtil.{@link PhoneNumberUtil#parse parse()}
|
||
|
* // invoked on rawString().
|
||
|
* util.parse(m.rawString(), country).equals(m.number());
|
||
|
* </pre>
|
||
|
* @hide This class is not part of the Android public SDK API
|
||
|
*/
|
||
|
public final class PhoneNumberMatch {
|
||
|
/** The start index into the text. */
|
||
|
private final int start;
|
||
|
/** The raw substring matched. */
|
||
|
private final String rawString;
|
||
|
/** The matched phone number. */
|
||
|
private final PhoneNumber number;
|
||
|
|
||
|
/**
|
||
|
* Creates a new match.
|
||
|
*
|
||
|
* @param start the start index into the target text
|
||
|
* @param rawString the matched substring of the target text
|
||
|
* @param number the matched phone number
|
||
|
*/
|
||
|
PhoneNumberMatch(int start, String rawString, PhoneNumber number) {
|
||
|
if (start < 0) {
|
||
|
throw new IllegalArgumentException("Start index must be >= 0.");
|
||
|
}
|
||
|
if (rawString == null || number == null) {
|
||
|
throw new NullPointerException();
|
||
|
}
|
||
|
this.start = start;
|
||
|
this.rawString = rawString;
|
||
|
this.number = number;
|
||
|
}
|
||
|
|
||
|
/** Returns the phone number matched by the receiver. */
|
||
|
@android.compat.annotation.UnsupportedAppUsage(maxTargetSdk = 30, trackingBug = 170729553)
|
||
|
public PhoneNumber number() {
|
||
|
return number;
|
||
|
}
|
||
|
|
||
|
/** Returns the start index of the matched phone number within the searched text. */
|
||
|
@android.compat.annotation.UnsupportedAppUsage(maxTargetSdk = 30, trackingBug = 170729553)
|
||
|
public int start() {
|
||
|
return start;
|
||
|
}
|
||
|
|
||
|
/** Returns the exclusive end index of the matched phone number within the searched text. */
|
||
|
@android.compat.annotation.UnsupportedAppUsage(maxTargetSdk = 30, trackingBug = 170729553)
|
||
|
public int end() {
|
||
|
return start + rawString.length();
|
||
|
}
|
||
|
|
||
|
/** Returns the raw string matched as a phone number in the searched text. */
|
||
|
@android.compat.annotation.UnsupportedAppUsage(maxTargetSdk = 30, trackingBug = 170729553)
|
||
|
public String rawString() {
|
||
|
return rawString;
|
||
|
}
|
||
|
|
||
|
@Override
|
||
|
public int hashCode() {
|
||
|
return Arrays.hashCode(new Object[]{start, rawString, number});
|
||
|
}
|
||
|
|
||
|
@Override
|
||
|
public boolean equals(Object obj) {
|
||
|
if (this == obj) {
|
||
|
return true;
|
||
|
}
|
||
|
if (!(obj instanceof PhoneNumberMatch)) {
|
||
|
return false;
|
||
|
}
|
||
|
PhoneNumberMatch other = (PhoneNumberMatch) obj;
|
||
|
return rawString.equals(other.rawString) && (start == other.start)
|
||
|
&& number.equals(other.number);
|
||
|
}
|
||
|
|
||
|
@Override
|
||
|
public String toString() {
|
||
|
return "PhoneNumberMatch [" + start() + "," + end() + ") " + rawString;
|
||
|
}
|
||
|
}
|