| /* |
| * Copyright 2010 Google Inc. |
| * |
| * 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.google.gwt.i18n.shared; |
| |
| import com.google.gwt.i18n.client.HasDirection.Direction; |
| |
| /** |
| * Direction estimator that uses the "any RTL" heuristic. |
| */ |
| public class AnyRtlDirectionEstimator extends DirectionEstimator { |
| |
| /** |
| * An instance of AnyRtlDirectionEstimator, to be returned by {@link #get}. |
| */ |
| private static final AnyRtlDirectionEstimator instance = |
| new AnyRtlDirectionEstimator(); |
| |
| /** |
| * Get an instance of AnyRtlDirectionEstimator. |
| * |
| * @return An instance of AnyRtlDirectionEstimator. |
| */ |
| public static AnyRtlDirectionEstimator get() { |
| return instance; |
| } |
| |
| /** |
| * Estimates the direction of a given string using the "any RTL" heuristic: |
| * the return value is RTL if the string contains at least one RTL character. |
| * Otherwise, it is LTR. |
| * |
| * @param str Input string. |
| * @return Direction The estimated direction of {@code str}. |
| */ |
| @Override |
| public Direction estimateDirection(String str) { |
| return BidiUtils.get().hasAnyRtl(str) ? Direction.RTL : Direction.LTR; |
| } |
| } |