All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.ibm.as400.access.BidiFlagSet Maven / Gradle / Ivy

The newest version!
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename:  BidiFlagSet.java
//
// The source code contained herein is licensed under the IBM Public License
// Version 1.0, which has been approved by the Open Source Initiative.
// Copyright (C) 1997-2006 International Business Machines Corporation and
// others.  All rights reserved.
//
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;

import java.util.StringTokenizer;

/**
 *  This class represents a BidiFlagSet object defining the text attributes
 *  to be used during a Bidi layout transformation process and the
 *  available values for each flag.
 *  

* Bidi text can be stored in different formats, which are characterized * by 5 Bidi attributes, whose values may be stored in 5 Bidi flags. * These 5 flags constitute a BidiFlagSet. *

* A BidiFlagSet object contains a value for each of the 5 Bidi flags * which represent the Bidi attributes. The 5 attributes are: *

    *
  • type of text (Implicit or Visual) *
  • orientation (LTR, RTL, Contextual LTR, Contextual RTL) *
  • symmetric swapping (Yes or No) *
  • numeral shapes (Nominal, National, Contextual or Any) *
  • text shapes (Nominal, Shaped, Initial, Middle, Final or Isolated) *
*

Multi-threading considerations: Different threads may use * the same BidiFlagSet instance if they all mean it to represent * identical values of the Bidi attributes. For different values of the * Bidi attributes, distinct instances of this class must be used. * */ public class BidiFlagSet { /** * Mask to apply on a BidiFlagSet value to isolate the * type-of-text flag */ static final int TYPE_MASK = 0x03000000; /** * Value identifying Implicit type of text */ static final int ITYPE_IMPLICIT = 0x01000000; /** * Value identifying Visual type of text */ static final int ITYPE_VISUAL = 0x03000000; /** * Mask to apply on a BidiFlagSet value to isolate the * orientation flag */ static final int ORIENTATION_MASK = 0x00700000; /** * Value identifying LTR orientation */ static final int IORIENTATION_LTR = 0x00100000; /** * Value identifying RTL orientation */ static final int IORIENTATION_RTL = 0x00300000; /** * Value identifying Contextual orientation with default to LTR */ static final int IORIENTATION_CONTEXT_LTR = 0x00500000; /** * Value identifying Contextual orientation with default to RTL */ static final int IORIENTATION_CONTEXT_RTL = 0x00700000; /** * Mask to apply on a BidiFlagSet value to isolate the * symmetric swapping flag */ static final int SWAP_MASK = 0x00030000; /** * Value identifying that symmetric swapping has been applied */ static final int ISWAP_YES = 0x00010000; /** * Value identifying that symmetric swapping has not been applied */ static final int ISWAP_NO = 0x00030000; /** * Mask to apply on a BidiFlagSet value to isolate the * numeral shapes flag */ static final int NUMERALS_MASK = 0x00000700; /** * Value identifying that numeral shapes are Nominal */ static final int INUMERALS_NOMINAL = 0x00000100; /** * Value identifying that numeral shapes are National */ static final int INUMERALS_NATIONAL = 0x00000300; /** * Value identifying that numeral shapes are Contextual (Nominal or National * depending on context) */ static final int INUMERALS_CONTEXTUAL = 0x00000500; /** * Value identifying that numeral shapes can be Nominal or National */ static final int INUMERALS_ANY = 0x00000700; /** * Mask to apply on a BidiFlagSet value to isolate the * text shapes flag */ static final int TEXT_MASK = 0x0000000F; /** * Value identifying that the text is stored in Nominal characters */ static final int ITEXT_NOMINAL = 0x00000001; /** * Value identifying that the text is stored in Shaped characters */ static final int ITEXT_SHAPED = 0x00000003; /** * Value identifying that the text must be displayed in Initial characters */ static final int ITEXT_INITIAL = 0x00000005; /** * Value identifying that the text must be displayed in Middle characters */ static final int ITEXT_MIDDLE = 0x00000007; /** * Value identifying that the text must be displayed in Final characters */ static final int ITEXT_FINAL = 0x00000009; /** * Value identifying that the text must be displayed in Isolated characters */ static final int ITEXT_ISOLATED = 0x0000000B; // This is the default value for uninitialized BidiFlagSet. static final int DEFAULT = ITYPE_IMPLICIT | IORIENTATION_LTR | ISWAP_YES | INUMERALS_NOMINAL | ITEXT_NOMINAL; // This is the only field in this class. int value; /** * Constructs a BidiFlagSet with the default value. * The default is: *

 *      Type: implicit  Orientation: LTR    Swapping: YES
 *      Numeral Shapes: Nominal     Text Shapes: Nominal
 *  
*/ public BidiFlagSet() { this.value = DEFAULT; } /** * Constructs a BidiFlagSet based on an existing BidiFlagSet. * @param model The BidiFlagSet which is copied. */ public BidiFlagSet(BidiFlagSet model) { this.value = model.value; } /** * Constructs a BidiFlagSet from one BidiFlag. The other Bidi * flags are set to their default. *

Example: *

 *  BidiFlagset bdfs = new BidiFlagSet(ORIENTATION_RTL);
 *  
* * @param flag The BidiFlag which is explicitly specified. */ public BidiFlagSet(BidiFlag flag) { this.value = flag.value | DEFAULT; } /** * Constructs a BidiFlagSet from two BidiFlags. The other Bidi * flags are set to their default. * If there is a contradiction or a duplication between the arguments, * then an IllegalArgumentException is thrown. *

Example: *

 *  BidiFlagset bdfs = new BidiFlagSet(ORIENTATION_RTL, TYPE_VISUAL);
 *  
* * @param flag1 The first BidiFlag which is explicitly specified. * @param flag2 The second BidiFlag which is explicitly specified. * * @exception IllegalArgumentException If the arguments conflict or are duplicates. */ public BidiFlagSet(BidiFlag flag1, BidiFlag flag2) { this.value = flag1.value; if ((this.value & flag2.value) != 0) throw new IllegalArgumentException(); this.value |= flag2.value | DEFAULT; } /** * Constructs a BidiFlagSet from three BidiFlags. The other Bidi * flags are set to their default. * If there is a contradiction or a duplication between the arguments, * then an IllegalArgumentException is thrown. *

Example: *

 *  BidiFlagset bdfs = new BidiFlagSet(ORIENTATION_RTL, TYPE_VISUAL, SWAP_YES);
 *  
* * * @param flag1 The first BidiFlag which is explicitly specified. * @param flag2 The second BidiFlag which is explicitly specified. * @param flag3 The third BidiFlag which is explicitly specified. * * @exception IllegalArgumentException If the arguments conflict or are duplicates. */ public BidiFlagSet(BidiFlag flag1, BidiFlag flag2, BidiFlag flag3) { this.value = flag1.value; if ((this.value & flag2.value) != 0) throw new IllegalArgumentException(); this.value |= flag2.value; if ((this.value & flag3.value) != 0) throw new IllegalArgumentException(); this.value |= flag3.value | DEFAULT; } /** * Constructs a BidiFlagSet from four BidiFlags. The other Bidi * flag is set to its default. * If there is a contradiction or a duplication between the arguments, * then an IllegalArgumentException is thrown. * * @param flag1 The first BidiFlag which is explicitly specified. * @param flag2 The second BidiFlag which is explicitly specified. * @param flag3 The third BidiFlag which is explicitly specified. * @param flag4 The fourth BidiFlag which is explicitly specified. * * @exception IllegalArgumentException If the arguments conflict or are duplicates. */ public BidiFlagSet(BidiFlag flag1, BidiFlag flag2, BidiFlag flag3, BidiFlag flag4) { this.value = flag1.value; if ((this.value & flag2.value) != 0) throw new IllegalArgumentException(); this.value |= flag2.value; if ((this.value & flag3.value) != 0) throw new IllegalArgumentException(); this.value |= flag3.value; if ((this.value & flag4.value) != 0) throw new IllegalArgumentException(); this.value |= flag4.value | DEFAULT; } /** * Constructs a BidiFlagSet from five BidiFlags. * If there is a contradiction or a duplication between the arguments, * then an IllegalArgumentException is thrown. * * @param flag1 The first BidiFlag which is explicitly specified. * @param flag2 The second BidiFlag which is explicitly specified. * @param flag3 The third BidiFlag which is explicitly specified. * @param flag4 The fourth BidiFlag which is explicitly specified. * @param flag5 The fifth BidiFlag which is explicitly specified. * * @exception IllegalArgumentException If the arguments conflict or duplicate */ public BidiFlagSet(BidiFlag flag1, BidiFlag flag2, BidiFlag flag3, BidiFlag flag4, BidiFlag flag5) { this.value = flag1.value; if ((this.value & flag2.value) != 0) throw new IllegalArgumentException(); this.value |= flag2.value; if ((this.value & flag3.value) != 0) throw new IllegalArgumentException(); this.value |= flag3.value; if ((this.value & flag4.value) != 0) throw new IllegalArgumentException(); this.value |= flag4.value; if ((this.value & flag5.value) != 0) throw new IllegalArgumentException(); this.value |= flag5.value; } /** * Constructs a BidiFlagSet from a char array. * The content of the array must follow the specification for the "S" and * "U" parts of the BIDI environment variable, as follows: *
    *
  • character 1: type of text = I (Implicit) or V (Visual) *
  • character 2: orientation = L (LTR), R (RTL), C (Contextual LTR) or D (Contextual RTL) *
  • character 3: swapping = Y (Swapping ON) or N (Swapping OFF) *
  • character 4: text shaping = N (Nominal), S (Shaped), I (Initial), M (Middle), F (Final), B (Isolated) *
  • character 5: numeral shaping = N (Nominal), H (National), C (Contextual), A (Any) *
  • character 6: bidi algorithm = U (Unicode), R (Roundtrip) *
  • character 7: Lamalef mode = G (Grow), S(Shrink), N (Near), B (Begin), E (End), W (groW with space), A (Auto) *
  • character 8: SeenTail mode = O (One cell), N (Near), B (Begin), E (End), A (Auto) *
  • character 9: Yeh Hamza mode = O (One cell), N (Near), B (Begin), E (End), A (Auto) *
  • character 10: Tashkeel mode = Z (Zero width), W (with Width), B (Begin), E (End), A (Auto) *
*

Only characters 1 to 5 are used to build the BidiFlagSet. *

* @param chars A character array. */ public BidiFlagSet(char[] chars) { int newValue = DEFAULT; int len = chars.length; while (len > 0) { if ('V' == chars[0]) newValue = (newValue & (~TYPE_MASK)) | ITYPE_VISUAL; else if ('I' == chars[0]) newValue = (newValue & (~TYPE_MASK)) | ITYPE_IMPLICIT; if (len <= 1) break; if ('L' == chars[1]) newValue = (newValue & (~ORIENTATION_MASK)) | IORIENTATION_LTR; else if ('R' == chars[1]) newValue = (newValue & (~ORIENTATION_MASK)) | IORIENTATION_RTL; else if ('C' == chars[1]) newValue = (newValue & (~ORIENTATION_MASK)) | IORIENTATION_CONTEXT_LTR; else if ('D' == chars[1]) newValue = (newValue & (~ORIENTATION_MASK)) | IORIENTATION_CONTEXT_RTL; if (len <= 2) break; if ('Y' == chars[2]) newValue = (newValue & (~SWAP_MASK)) | ISWAP_YES; else if ('N' == chars[2]) newValue = (newValue & (~SWAP_MASK)) | ISWAP_NO; if (len <= 3) break; if ('N' == chars[3]) newValue = (newValue & (~TEXT_MASK)) | ITEXT_NOMINAL; else if ('S' == chars[3]) newValue = (newValue & (~TEXT_MASK)) | ITEXT_SHAPED; else if ('I' == chars[3]) newValue = (newValue & (~TEXT_MASK)) | ITEXT_INITIAL; else if ('M' == chars[3]) newValue = (newValue & (~TEXT_MASK)) | ITEXT_MIDDLE; else if ('F' == chars[3]) newValue = (newValue & (~TEXT_MASK)) | ITEXT_FINAL; else if ('B' == chars[3]) newValue = (newValue & (~TEXT_MASK)) | ITEXT_ISOLATED; if (len <= 4) break; if ('N' == chars[4]) newValue = (newValue & (~NUMERALS_MASK)) | INUMERALS_NOMINAL; else if ('H' == chars[4]) newValue = (newValue & (~NUMERALS_MASK)) | INUMERALS_NATIONAL; else if ('C' == chars[4]) newValue = (newValue & (~NUMERALS_MASK)) | INUMERALS_CONTEXTUAL; else if ('A' == chars[4]) newValue = (newValue & (~NUMERALS_MASK)) | INUMERALS_ANY; break; } this.value = newValue; } /** * Constructs a BidiFlagSet from a string. * The content of the string must follow the syntax of the modifiers * specified in X/Open standard "Portable Layout Services". *

The string contains sequences in the form "keyword=value" * separated by commas. *

* This format is compatible with the result of the toString method. * This format is useful when readibility is more important than efficiency. *

* The supported keywords are: typeoftext, orientation, context, swapping, * numerals and shaping. *

* The following keywords are ignored but do not cause a syntax error: @ls, * implicitalg, checkmode, shapcharset. *

Example: *

 *  typeoftext=implicit, orientation=rtl, swap=yes, shaping=nominal, numerals=nominal
 *  
*

* @param str A string in the format "flag=value [,...]". * @exception IllegalArgumentException If the syntax of the data is invalid. * @see #toString */ public BidiFlagSet(String str) throws IllegalArgumentException { int n = parseBidiFlagSet(str); if (n < 0) throw new IllegalArgumentException(); this.value = n; } /** * Compares two BidiFlagSets. * Two BidiFlagSets are considered equal if they represent the same values * for the 5 Bidi flags. * @param obj The BidiFlagSet to compare to this. * @return true if the BidiFlagSets are equal, false otherwise. */ public boolean equals(Object obj) { if (obj == null) return false; if (obj instanceof BidiFlagSet) { BidiFlagSet other = (BidiFlagSet) obj; return this.value == other.value; } else { return false; } } /** * Returns the numeral shapes flag from a BidiFlagSet. * @return The value of the numeral shapes flag. *

The expected value is one of NUMERALS_NOMINAL, NUMERALS_NATIONAL, * NUMERALS_CONTEXTUAL, NUMERALS_ANY. *
It can be tested as in the following example: *

 *  if (getNumerals(myFlags) == NUMERALS_NATIONAL) . . .
 *  
*/ public BidiFlag getNumerals() { switch(this.value & NUMERALS_MASK) { case INUMERALS_NOMINAL: return BidiFlag.NUMERALS_NOMINAL; case INUMERALS_NATIONAL: return BidiFlag.NUMERALS_NATIONAL; case INUMERALS_CONTEXTUAL: return BidiFlag.NUMERALS_CONTEXTUAL; case INUMERALS_ANY: return BidiFlag.NUMERALS_ANY; } return BidiFlag.NUMERALS_NOMINAL; } /** * Returns the orientation flag from a BidiFlagSet. * @return The value of the orientation flag. *

The expected value is one of ORIENTATION_LTR, ORIENTATION_RTL, * ORIENTATION_CONTEXT_LTR, ORIENTATION_CONTEXT_RTL. *
It can be tested as in the following example: *

 *  if (getOrientation(myFlags) == ORIENTATION_RTL) . . .
 *  
*/ public BidiFlag getOrientation() { switch(this.value & ORIENTATION_MASK) { case IORIENTATION_LTR: return BidiFlag.ORIENTATION_LTR; case IORIENTATION_RTL: return BidiFlag.ORIENTATION_RTL; case IORIENTATION_CONTEXT_LTR: return BidiFlag.ORIENTATION_CONTEXT_LTR; case IORIENTATION_CONTEXT_RTL: return BidiFlag.ORIENTATION_CONTEXT_RTL; } return BidiFlag.ORIENTATION_LTR; } /** * Returns the symmetric swapping flag from a BidiFlagSet. * @return The value of the symmetric swapping flag. *

The expected value is one of SWAP_YES, SWAP_NO. *
It can be tested as in the following example: *

 *  if (getSwap(myFlags) == SWAP_YES) . . .
 *  
*/ public BidiFlag getSwap() { switch(this.value & SWAP_MASK) { case ISWAP_YES: return BidiFlag.SWAP_YES; case ISWAP_NO: return BidiFlag.SWAP_NO; } return BidiFlag.SWAP_YES; } /** * Returns the text shapes flag from a BidiFlagSet. * @return The value of the text shapes flag. *

The expected value is one of TEXT_NOMINAL, TEXT_SHAPED, * TEXT_INITIAL, TEXT_MIDDLE, TEXT_FINAL, TEXT_ISOLATED. *
It can be tested as in the following example: *

 *  if (getText(myFlags) == TEXT_MIDDLE) . . .
 *  
*/ public BidiFlag getText() { switch(this.value & TEXT_MASK) { case ITEXT_NOMINAL: return BidiFlag.TEXT_NOMINAL; case ITEXT_SHAPED: return BidiFlag.TEXT_SHAPED; case ITEXT_INITIAL: return BidiFlag.TEXT_INITIAL; case ITEXT_MIDDLE: return BidiFlag.TEXT_MIDDLE; case ITEXT_FINAL: return BidiFlag.TEXT_FINAL; case ITEXT_ISOLATED: return BidiFlag.TEXT_ISOLATED; } return BidiFlag.TEXT_NOMINAL; } /** * Returns the type-of-text flag from a BidiFlagSet. * @return The value of the type-of-text flag. *

The expected value is one of TYPE_IMPLICIT, TYPE_VISUAL. *
It can be tested as in the following example: *

 *  if (getType(myFlags) == TYPE_VISUAL) . . .
 *  
*/ public BidiFlag getType() { switch(this.value & TYPE_MASK) { case ITYPE_IMPLICIT: return BidiFlag.TYPE_IMPLICIT; case ITYPE_VISUAL: return BidiFlag.TYPE_VISUAL; } return BidiFlag.TYPE_IMPLICIT; } /** * Returns a hashcode for a BidiFlagSet. * The hashcode of a BidiFlagSet is the same as the hashcode of its * value. * @return A hashcode value. */ public int hashCode() { return this.value; } /** * Computes the value of a BidiFlagSet specified as text. * The text must follow the syntax of modifiers detailed in X/Open * "Portable Layout Services". * This format is compatible with the result of the toString method. * This format is useful when readibility is more important than efficiency. *

* The supported keywords are: typeoftext, orientation, context, swapping, * numerals and shaping. *

* The following keywords are ignored but do not cause a syntax error: @ls, * implicitalg, checkmode, shapcharset. * @param str a string in the format "flag=value [,...]" * @return The value of the BidiFlagSet object if str is correct; * if the syntax is invalid, the return value is a negative number * whose absolute value is the ordinal (starting from 1) of the first * invalid word token (disregarding punctuation). * @see #toString */ private static int parseBidiFlagSet(String str) { int newValue = 0; int counter = 0; String token, keyword = ""; StringTokenizer stok = new StringTokenizer(str, "\t ,="); while (stok.hasMoreElements()) { token = stok.nextToken(); counter--; if (token.equals("@ls")) continue; if (token.equals("implicitalg") || token.equals("checkmode") || token.equals("shapcharset") ) { keyword = "allowed"; continue; } if (token.equals("typeoftext") || token.equals("orientation") || token.equals("context") || token.equals("swapping") || token.equals("numerals") || token.equals("shaping") ) { keyword = token; continue; } if (token.equals("visual")) { if (!keyword.equals("typeoftext")) return counter; newValue = (newValue & (~TYPE_MASK)) | ITYPE_VISUAL; continue; } if (token.equals("implicit")) { if (!keyword.equals("typeoftext")) return counter; newValue = (newValue & (~TYPE_MASK)) | ITYPE_IMPLICIT; continue; } if (token.equals("ltr")) { if (keyword.equals("orientation")) { newValue = (newValue & (~ORIENTATION_MASK)) | IORIENTATION_LTR; continue; } if (keyword.equals("context")) { if ((newValue & ORIENTATION_MASK) != IORIENTATION_LTR && (newValue & ORIENTATION_MASK) != IORIENTATION_RTL) newValue = (newValue & (~ORIENTATION_MASK)) | IORIENTATION_CONTEXT_LTR; continue; } return counter; } if (token.equals("rtl")) { if (keyword.equals("orientation")) { newValue = (newValue & (~ORIENTATION_MASK)) | IORIENTATION_RTL; continue; } if (keyword.equals("context")) { if ((newValue & ORIENTATION_MASK) != IORIENTATION_LTR && (newValue & ORIENTATION_MASK) != IORIENTATION_RTL) newValue = (newValue & (~ORIENTATION_MASK)) | IORIENTATION_CONTEXT_RTL; continue; } return counter; } if (token.equals("contextual")) { if (keyword.equals("orientation")) { if ((newValue & ORIENTATION_MASK) == IORIENTATION_CONTEXT_RTL) continue; newValue = ((newValue & (~ORIENTATION_MASK)) | IORIENTATION_CONTEXT_LTR); continue; } if (keyword.equals("numerals")) { newValue = (newValue & (~NUMERALS_MASK)) | INUMERALS_CONTEXTUAL; continue; } return counter; } if (token.equals("yes")) { if (!keyword.equals("swapping")) return counter; newValue = (newValue & (~SWAP_MASK)) | ISWAP_YES; continue; } if (token.equals("no")) { if (!keyword.equals("swapping")) return counter; newValue = (newValue & (~SWAP_MASK)) | ISWAP_NO; continue; } if (token.equals("nominal")) { if (keyword.equals("numerals")) { newValue = (newValue & (~NUMERALS_MASK)) | INUMERALS_NOMINAL; continue; } if (keyword.equals("shaping")) { newValue = (newValue & (~TEXT_MASK)) | ITEXT_NOMINAL; continue; } return counter; } if (token.equals("national")) { if (!keyword.equals("numerals")) return counter; newValue = (newValue & (~NUMERALS_MASK)) | INUMERALS_NATIONAL; continue; } if (token.equals("any")) { if (!keyword.equals("numerals")) return counter; newValue = (newValue & (~NUMERALS_MASK)) | INUMERALS_ANY; continue; } if (token.equals("shaped")) { if (!keyword.equals("shaping")) return counter; newValue = (newValue & (~TEXT_MASK)) | ITEXT_SHAPED; continue; } if (token.equals("shform1")) { if (!keyword.equals("shaping")) return counter; newValue = (newValue & (~TEXT_MASK)) | ITEXT_INITIAL; continue; } if (token.equals("shform2")) { if (!keyword.equals("shaping")) return counter; newValue = (newValue & (~TEXT_MASK)) | ITEXT_MIDDLE; continue; } if (token.equals("shform3")) { if (!keyword.equals("shaping")) return counter; newValue = (newValue & (~TEXT_MASK)) | ITEXT_FINAL; continue; } if (token.equals("shform4")) { if (!keyword.equals("shaping")) return counter; newValue = (newValue & (~TEXT_MASK)) | ITEXT_ISOLATED; continue; } if (keyword.equals("allowed")) continue; return counter; } return newValue | DEFAULT; } /** * Sets all bidi flags based on another BidiFlagSet. * @param model The BidiFlagSet which is copied. */ public void setAllFlags(BidiFlagSet model) { this.value = model.value; } /** * Sets all bidi flags from a string. * The content of the string must follow the syntax of modifiers * specified in X/Open standard "Portable Layout Services". *

The string contains sequences of the form "keyword=value" * separated by commas. *

* This format is compatible with the result of the toString method. * This format is useful when readibility is more important than efficiency. *

* The supported keywords are: typeoftext, orientation, context, swapping, * numerals and shaping. *

* The following keywords are ignored but do not cause a syntax error: @ls, * implicitalg, checkmode, shapcharset. *

Example: *

 *  typeoftext=visual, orientation=ltr, swap=no, shaping=shaped, numerals=contextual
 *  
*

* @param str A string in the format "flag=value [,...]". * @exception IllegalArgumentException If the syntax of the data is invalid. * @see #toString */ public void setAllFlags(String str) throws IllegalArgumentException { int n = parseBidiFlagSet(str); if (n < 0) throw new IllegalArgumentException(); this.value = n; } /** * Sets all the Bidi flags in 2 BidiFlagSets based on a string. * The content of the string must follow the syntax of modifiers * specified in X/Open standard "Portable Layout Services". * This may be used to specify in one operation the Bidi flags of the source * and the destination of a transformation. *

The string contains sequences of the form "keyword=value" or * "keyword=value1:value2", with a separating comma. * Each keyword is followed by one or two values. In the first case, * this value applies to both source and destination. In the second case, * the two values are separated by a colon; the first value applies to * the source and the second value to the destination. *

* The supported keywords are: typeoftext, orientation, context, swapping, * numerals and shaping. *

* The following keywords are ignored but do not cause a syntax error: @ls, * implicitalg, checkmode, shapcharset. *

Example: the source flags are "implicit, ltr, swapping on"; the * target flags are "visual, ltr, no swapping". The string will be: *

 *  typeoftext=implicit:visual, orientation=ltr, swapping=yes:no
 *  
* @param flags1 The first BidiFlagSet to be set. * @param flags2 The second BidiFlagSet to be set. * @param str A string in the format "flag=value [,...]". * * @exception IllegalArgumentException If the syntax of the data is invalid. */ public static void set2AllFlags(BidiFlagSet flags1, BidiFlagSet flags2, String str) throws IllegalArgumentException { int capacity = str.length(); StringBuffer sb1 = new StringBuffer(capacity); StringBuffer sb2 = new StringBuffer(capacity); StringTokenizer stok = new StringTokenizer(str, "\t ,=:", true); String token; int sb2Length = 0; boolean colon = false; while (stok.hasMoreElements()) { token = stok.nextToken(); if (token.equals(" ") || token.equals("\t")) { sb1.append(token); sb2.append(token); continue; } if (token.equals(",") || token.equals("=")) { colon = false; sb1.append(token); sb2.append(token); continue; } if (token.equals(":")) { colon = true; sb2.setLength(sb2Length); continue; } if (!colon) sb1.append(token); sb2Length = sb2.length(); sb2.append(token); colon = false; } flags1.setAllFlags(sb1.toString()); flags2.setAllFlags(sb2.toString()); } /** * Sets a new value for one of the Bidi flags in a set without changing * the other Bidi flags. *

The new value must be one of the pre-defined values for BidiFlag. * * @param newFlag The new value requested for one of the flags. */ public void setOneFlag(BidiFlag newFlag) { this.value = (this.value & (~newFlag.mask)) | newFlag.value; } /** * Creates a string that represents the various Bidi flags grouped in * a BidiFlagSet. This may be useful for instance for debugging. *

* The format is compatible with the syntax of modifiers in X/Open standard * "Portable Layout Services". *

* For each flag, an expression of the form "keyword=value" is added * to the string. Adjacent expressions are separated by a comma and a * space. *

The keywords and their respective sets of values are: *

 *  KEYWORD         VALUES
 *  -----------     ---------------
 *  typeoftext      implicit visual
 *  orientation     ltr rtl contextual
 *  context         ltr rtl
 *  swapping        yes no
 *  numerals        nominal national contextual any
 *  shaping         nominal shaped shform1 shform2 shform3 shform4
 *  
* @return A human readable form of the flag values. */ public String toString() { return BidiFlagSet.toString(this.value); } /** * Class method parallel to the instance method with the same name. * @param value The value of a BidiFlagSet. * @return A human readable form of the flag values. */ static String toString(int value) { final String[] typeStrings = {"implicit", "visual"}; final String[] orientationStrings = {"ltr", "rtl", "contextual, context=ltr", "contextual, context=rtl"}; final String[] swapStrings = {"yes", "no"}; final String[] numeralsStrings = {"nominal", "national", "contextual", "any"}; final String[] textStrings = {"nominal", "shaped", "shform1", "shform2", "shform3", "shform4", "invalid", "invalid"}; return "typeoftext=" + typeStrings[(value & TYPE_MASK)>>25] + ", " + "orientation=" + orientationStrings[(value & ORIENTATION_MASK)>>21] + ", " + "swapping=" + swapStrings[(value & SWAP_MASK)>>17] + ", " + "numerals=" + numeralsStrings[(value & NUMERALS_MASK)>>9] + ", " + "shaping=" + textStrings[(value & TEXT_MASK)>>1]; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy