| @@ 2918-2924 (lines=7) @@ | ||
| 2915 | if (0 === (0x80 & $in)) { |
|
| 2916 | // US-ASCII, pass straight through. |
|
| 2917 | $mBytes = 1; |
|
| 2918 | } elseif (0xC0 === (0xE0 & $in)) { |
|
| 2919 | // First octet of 2 octet sequence. |
|
| 2920 | $mUcs4 = $in; |
|
| 2921 | $mUcs4 = ($mUcs4 & 0x1F) << 6; |
|
| 2922 | $mState = 1; |
|
| 2923 | $mBytes = 2; |
|
| 2924 | } elseif (0xE0 === (0xF0 & $in)) { |
|
| 2925 | // First octet of 3 octet sequence. |
|
| 2926 | $mUcs4 = $in; |
|
| 2927 | $mUcs4 = ($mUcs4 & 0x0F) << 12; |
|
| @@ 2930-2936 (lines=7) @@ | ||
| 2927 | $mUcs4 = ($mUcs4 & 0x0F) << 12; |
|
| 2928 | $mState = 2; |
|
| 2929 | $mBytes = 3; |
|
| 2930 | } elseif (0xF0 === (0xF8 & $in)) { |
|
| 2931 | // First octet of 4 octet sequence. |
|
| 2932 | $mUcs4 = $in; |
|
| 2933 | $mUcs4 = ($mUcs4 & 0x07) << 18; |
|
| 2934 | $mState = 3; |
|
| 2935 | $mBytes = 4; |
|
| 2936 | } elseif (0xF8 === (0xFC & $in)) { |
|
| 2937 | /* First octet of 5 octet sequence. |
|
| 2938 | * |
|
| 2939 | * This is illegal because the encoded codepoint must be either |
|
| @@ 2949-2955 (lines=7) @@ | ||
| 2946 | $mUcs4 = ($mUcs4 & 0x03) << 24; |
|
| 2947 | $mState = 4; |
|
| 2948 | $mBytes = 5; |
|
| 2949 | } elseif (0xFC === (0xFE & $in)) { |
|
| 2950 | // First octet of 6 octet sequence, see comments for 5 octet sequence. |
|
| 2951 | $mUcs4 = $in; |
|
| 2952 | $mUcs4 = ($mUcs4 & 1) << 30; |
|
| 2953 | $mState = 5; |
|
| 2954 | $mBytes = 6; |
|
| 2955 | } else { |
|
| 2956 | /* Current octet is neither in the US-ASCII range nor a legal first |
|
| 2957 | * octet of a multi-octet sequence. |
|
| 2958 | */ |
|