1 package com.github.mygreen.supercsv.annotation; 2 3 4 /** 5 * 正規表現をコンパイルする際のフラグを表現するための列挙型。 6 * <p>アノテーションの正規表現の属性として指定するために使用する。</p> 7 * 8 * @since 2.0 9 * @author T.TSUCHIE 10 * 11 */ 12 public enum PatternFlag { 13 14 /** 15 * Unixライン・モードを有効にします。 16 * <p>このモードでは、「{@literal \n}」行末記号以外は、{@literal .、^、および$}の動作で認識されません。</p> 17 * 18 * @see java.util.regex.Pattern#UNIX_LINES 19 */ 20 UNIX_LINES( java.util.regex.Pattern.UNIX_LINES ), 21 22 /** 23 * 大文字と小文字を区別しないマッチングを有効にします。 24 * <p>デフォルトの大文字と小文字を区別しないマッチングでは、US-ASCII文字セットの文字だけがマッチします。 25 * Unicodeに準拠した大文字と小文字を区別しないマッチングを有効にするには、 26 * {@link #UNIX_LINES}フラグをこのフラグと組み合わせて指定します。 27 * </p> 28 * 29 * @see java.util.regex.Pattern#CASE_INSENSITIVE 30 */ 31 CASE_INSENSITIVE( java.util.regex.Pattern.CASE_INSENSITIVE ), 32 33 /** 34 * パターン内で空白とコメントを使用できるようにします。 35 * <p>このモードでは、空白は無視され、#で始まる埋込みコメントは行末まで無視されます。</p> 36 * 37 * @see java.util.regex.Pattern#COMMENTS 38 */ 39 COMMENTS( java.util.regex.Pattern.COMMENTS ), 40 41 /** 42 * 複数行モードを有効にします。 43 * <p>複数行モードでは、表現{@literal ^と$}は、それぞれ行末記号または入力シーケンスの末尾の直後または直前にマッチします。 44 * デフォルトでは、これらの表現は入力シーケンス全体の先頭と末尾にだけマッチします。 45 * </p> 46 * 47 * @see java.util.regex.Pattern#MULTILINE 48 */ 49 MULTILINE( java.util.regex.Pattern.MULTILINE ), 50 51 /** 52 * DOTALLモードを有効にします。 53 * <p>DOTALLモードでは、表現.は行末記号を含む任意の文字にマッチします。 54 * デフォルトでは、この表現は行末記号にマッチしません。 55 * </p> 56 * 57 * @see java.util.regex.Pattern#DOTALL 58 */ 59 DOTALL( java.util.regex.Pattern.DOTALL ), 60 61 /** 62 * Unicodeに準拠した大文字と小文字を区別しないマッチングを有効にします。 63 * <p>このフラグと{@link #CASE_INSENSITIVE}フラグを同時に指定した場合は、 64 * Unicode標準に準拠した大文字と小文字を区別しないマッチングが行われます。 65 * デフォルトの大文字と小文字を区別しないマッチングでは、US-ASCII文字セットの文字だけがマッチします。 66 * </p> 67 * 68 * @see java.util.regex.Pattern#UNICODE_CASE 69 */ 70 UNICODE_CASE( java.util.regex.Pattern.UNICODE_CASE ), 71 72 /** 73 * 正規等価を有効にします。 74 * <p>このフラグを指定したときは、2つの文字の完全な正規分解がマッチした場合に限り、それらの文字がマッチするとみなされます。 75 * たとえば、このフラグを指定すると、表現「{@literal a\u030A}」は文字列「{@literal \u00E5}」にマッチします。 76 * デフォルトのマッチングでは、正規等価が考慮されません。 77 * </p> 78 * 79 * @see java.util.regex.Pattern#CANON_EQ 80 */ 81 CANON_EQ( java.util.regex.Pattern.CANON_EQ ); 82 83 //JDK flag value 84 private final int value; 85 86 private PatternFlag(int value) { 87 this.value = value; 88 } 89 90 /** 91 * @return {@link java.util.regex.Pattern}に対応するフラグの値を返す。 92 */ 93 public int getValue() { 94 return value; 95 } 96 97 }