516 lines
		
	
	
		
			20 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
			
		
		
	
	
			516 lines
		
	
	
		
			20 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
'use strict';
 | 
						||
Object.defineProperty(exports, "__esModule", { value: true });
 | 
						||
exports.LineBreaker = exports.inlineBreakOpportunities = exports.lineBreakAtIndex = exports.codePointsToCharacterClasses = exports.UnicodeTrie = exports.BREAK_ALLOWED = exports.BREAK_NOT_ALLOWED = exports.BREAK_MANDATORY = exports.classes = exports.LETTER_NUMBER_MODIFIER = void 0;
 | 
						||
var utrie_1 = require("utrie");
 | 
						||
var linebreak_trie_1 = require("./linebreak-trie");
 | 
						||
var Util_1 = require("./Util");
 | 
						||
exports.LETTER_NUMBER_MODIFIER = 50;
 | 
						||
// Non-tailorable Line Breaking Classes
 | 
						||
var BK = 1; //  Cause a line break (after)
 | 
						||
var CR = 2; //  Cause a line break (after), except between CR and LF
 | 
						||
var LF = 3; //  Cause a line break (after)
 | 
						||
var CM = 4; //  Prohibit a line break between the character and the preceding character
 | 
						||
var NL = 5; //  Cause a line break (after)
 | 
						||
var SG = 6; //  Do not occur in well-formed text
 | 
						||
var WJ = 7; //  Prohibit line breaks before and after
 | 
						||
var ZW = 8; //  Provide a break opportunity
 | 
						||
var GL = 9; //  Prohibit line breaks before and after
 | 
						||
var SP = 10; // Enable indirect line breaks
 | 
						||
var ZWJ = 11; // Prohibit line breaks within joiner sequences
 | 
						||
// Break Opportunities
 | 
						||
var B2 = 12; //  Provide a line break opportunity before and after the character
 | 
						||
var BA = 13; //  Generally provide a line break opportunity after the character
 | 
						||
var BB = 14; //  Generally provide a line break opportunity before the character
 | 
						||
var HY = 15; //  Provide a line break opportunity after the character, except in numeric context
 | 
						||
var CB = 16; //   Provide a line break opportunity contingent on additional information
 | 
						||
// Characters Prohibiting Certain Breaks
 | 
						||
var CL = 17; //  Prohibit line breaks before
 | 
						||
var CP = 18; //  Prohibit line breaks before
 | 
						||
var EX = 19; //  Prohibit line breaks before
 | 
						||
var IN = 20; //  Allow only indirect line breaks between pairs
 | 
						||
var NS = 21; //  Allow only indirect line breaks before
 | 
						||
var OP = 22; //  Prohibit line breaks after
 | 
						||
var QU = 23; //  Act like they are both opening and closing
 | 
						||
// Numeric Context
 | 
						||
var IS = 24; //  Prevent breaks after any and before numeric
 | 
						||
var NU = 25; //  Form numeric expressions for line breaking purposes
 | 
						||
var PO = 26; //  Do not break following a numeric expression
 | 
						||
var PR = 27; //  Do not break in front of a numeric expression
 | 
						||
var SY = 28; //  Prevent a break before; and allow a break after
 | 
						||
// Other Characters
 | 
						||
var AI = 29; //  Act like AL when the resolvedEAW is N; otherwise; act as ID
 | 
						||
var AL = 30; //  Are alphabetic characters or symbols that are used with alphabetic characters
 | 
						||
var CJ = 31; //  Treat as NS or ID for strict or normal breaking.
 | 
						||
var EB = 32; //  Do not break from following Emoji Modifier
 | 
						||
var EM = 33; //  Do not break from preceding Emoji Base
 | 
						||
var H2 = 34; //  Form Korean syllable blocks
 | 
						||
var H3 = 35; //  Form Korean syllable blocks
 | 
						||
var HL = 36; //  Do not break around a following hyphen; otherwise act as Alphabetic
 | 
						||
var ID = 37; //  Break before or after; except in some numeric context
 | 
						||
var JL = 38; //  Form Korean syllable blocks
 | 
						||
var JV = 39; //  Form Korean syllable blocks
 | 
						||
var JT = 40; //  Form Korean syllable blocks
 | 
						||
var RI = 41; //  Keep pairs together. For pairs; break before and after other classes
 | 
						||
var SA = 42; //  Provide a line break opportunity contingent on additional, language-specific context analysis
 | 
						||
var XX = 43; //  Have as yet unknown line breaking behavior or unassigned code positions
 | 
						||
var ea_OP = [0x2329, 0xff08];
 | 
						||
exports.classes = {
 | 
						||
    BK: BK,
 | 
						||
    CR: CR,
 | 
						||
    LF: LF,
 | 
						||
    CM: CM,
 | 
						||
    NL: NL,
 | 
						||
    SG: SG,
 | 
						||
    WJ: WJ,
 | 
						||
    ZW: ZW,
 | 
						||
    GL: GL,
 | 
						||
    SP: SP,
 | 
						||
    ZWJ: ZWJ,
 | 
						||
    B2: B2,
 | 
						||
    BA: BA,
 | 
						||
    BB: BB,
 | 
						||
    HY: HY,
 | 
						||
    CB: CB,
 | 
						||
    CL: CL,
 | 
						||
    CP: CP,
 | 
						||
    EX: EX,
 | 
						||
    IN: IN,
 | 
						||
    NS: NS,
 | 
						||
    OP: OP,
 | 
						||
    QU: QU,
 | 
						||
    IS: IS,
 | 
						||
    NU: NU,
 | 
						||
    PO: PO,
 | 
						||
    PR: PR,
 | 
						||
    SY: SY,
 | 
						||
    AI: AI,
 | 
						||
    AL: AL,
 | 
						||
    CJ: CJ,
 | 
						||
    EB: EB,
 | 
						||
    EM: EM,
 | 
						||
    H2: H2,
 | 
						||
    H3: H3,
 | 
						||
    HL: HL,
 | 
						||
    ID: ID,
 | 
						||
    JL: JL,
 | 
						||
    JV: JV,
 | 
						||
    JT: JT,
 | 
						||
    RI: RI,
 | 
						||
    SA: SA,
 | 
						||
    XX: XX,
 | 
						||
};
 | 
						||
exports.BREAK_MANDATORY = '!';
 | 
						||
exports.BREAK_NOT_ALLOWED = '×';
 | 
						||
exports.BREAK_ALLOWED = '÷';
 | 
						||
exports.UnicodeTrie = utrie_1.createTrieFromBase64(linebreak_trie_1.base64, linebreak_trie_1.byteLength);
 | 
						||
var ALPHABETICS = [AL, HL];
 | 
						||
var HARD_LINE_BREAKS = [BK, CR, LF, NL];
 | 
						||
var SPACE = [SP, ZW];
 | 
						||
var PREFIX_POSTFIX = [PR, PO];
 | 
						||
var LINE_BREAKS = HARD_LINE_BREAKS.concat(SPACE);
 | 
						||
var KOREAN_SYLLABLE_BLOCK = [JL, JV, JT, H2, H3];
 | 
						||
var HYPHEN = [HY, BA];
 | 
						||
var codePointsToCharacterClasses = function (codePoints, lineBreak) {
 | 
						||
    if (lineBreak === void 0) { lineBreak = 'strict'; }
 | 
						||
    var types = [];
 | 
						||
    var indices = [];
 | 
						||
    var categories = [];
 | 
						||
    codePoints.forEach(function (codePoint, index) {
 | 
						||
        var classType = exports.UnicodeTrie.get(codePoint);
 | 
						||
        if (classType > exports.LETTER_NUMBER_MODIFIER) {
 | 
						||
            categories.push(true);
 | 
						||
            classType -= exports.LETTER_NUMBER_MODIFIER;
 | 
						||
        }
 | 
						||
        else {
 | 
						||
            categories.push(false);
 | 
						||
        }
 | 
						||
        if (['normal', 'auto', 'loose'].indexOf(lineBreak) !== -1) {
 | 
						||
            // U+2010, – U+2013, 〜 U+301C, ゠ U+30A0
 | 
						||
            if ([0x2010, 0x2013, 0x301c, 0x30a0].indexOf(codePoint) !== -1) {
 | 
						||
                indices.push(index);
 | 
						||
                return types.push(CB);
 | 
						||
            }
 | 
						||
        }
 | 
						||
        if (classType === CM || classType === ZWJ) {
 | 
						||
            // LB10 Treat any remaining combining mark or ZWJ as AL.
 | 
						||
            if (index === 0) {
 | 
						||
                indices.push(index);
 | 
						||
                return types.push(AL);
 | 
						||
            }
 | 
						||
            // LB9 Do not break a combining character sequence; treat it as if it has the line breaking class of
 | 
						||
            // the base character in all of the following rules. Treat ZWJ as if it were CM.
 | 
						||
            var prev = types[index - 1];
 | 
						||
            if (LINE_BREAKS.indexOf(prev) === -1) {
 | 
						||
                indices.push(indices[index - 1]);
 | 
						||
                return types.push(prev);
 | 
						||
            }
 | 
						||
            indices.push(index);
 | 
						||
            return types.push(AL);
 | 
						||
        }
 | 
						||
        indices.push(index);
 | 
						||
        if (classType === CJ) {
 | 
						||
            return types.push(lineBreak === 'strict' ? NS : ID);
 | 
						||
        }
 | 
						||
        if (classType === SA) {
 | 
						||
            return types.push(AL);
 | 
						||
        }
 | 
						||
        if (classType === AI) {
 | 
						||
            return types.push(AL);
 | 
						||
        }
 | 
						||
        // For supplementary characters, a useful default is to treat characters in the range 10000..1FFFD as AL
 | 
						||
        // and characters in the ranges 20000..2FFFD and 30000..3FFFD as ID, until the implementation can be revised
 | 
						||
        // to take into account the actual line breaking properties for these characters.
 | 
						||
        if (classType === XX) {
 | 
						||
            if ((codePoint >= 0x20000 && codePoint <= 0x2fffd) || (codePoint >= 0x30000 && codePoint <= 0x3fffd)) {
 | 
						||
                return types.push(ID);
 | 
						||
            }
 | 
						||
            else {
 | 
						||
                return types.push(AL);
 | 
						||
            }
 | 
						||
        }
 | 
						||
        types.push(classType);
 | 
						||
    });
 | 
						||
    return [indices, types, categories];
 | 
						||
};
 | 
						||
exports.codePointsToCharacterClasses = codePointsToCharacterClasses;
 | 
						||
var isAdjacentWithSpaceIgnored = function (a, b, currentIndex, classTypes) {
 | 
						||
    var current = classTypes[currentIndex];
 | 
						||
    if (Array.isArray(a) ? a.indexOf(current) !== -1 : a === current) {
 | 
						||
        var i = currentIndex;
 | 
						||
        while (i <= classTypes.length) {
 | 
						||
            i++;
 | 
						||
            var next = classTypes[i];
 | 
						||
            if (next === b) {
 | 
						||
                return true;
 | 
						||
            }
 | 
						||
            if (next !== SP) {
 | 
						||
                break;
 | 
						||
            }
 | 
						||
        }
 | 
						||
    }
 | 
						||
    if (current === SP) {
 | 
						||
        var i = currentIndex;
 | 
						||
        while (i > 0) {
 | 
						||
            i--;
 | 
						||
            var prev = classTypes[i];
 | 
						||
            if (Array.isArray(a) ? a.indexOf(prev) !== -1 : a === prev) {
 | 
						||
                var n = currentIndex;
 | 
						||
                while (n <= classTypes.length) {
 | 
						||
                    n++;
 | 
						||
                    var next = classTypes[n];
 | 
						||
                    if (next === b) {
 | 
						||
                        return true;
 | 
						||
                    }
 | 
						||
                    if (next !== SP) {
 | 
						||
                        break;
 | 
						||
                    }
 | 
						||
                }
 | 
						||
            }
 | 
						||
            if (prev !== SP) {
 | 
						||
                break;
 | 
						||
            }
 | 
						||
        }
 | 
						||
    }
 | 
						||
    return false;
 | 
						||
};
 | 
						||
var previousNonSpaceClassType = function (currentIndex, classTypes) {
 | 
						||
    var i = currentIndex;
 | 
						||
    while (i >= 0) {
 | 
						||
        var type = classTypes[i];
 | 
						||
        if (type === SP) {
 | 
						||
            i--;
 | 
						||
        }
 | 
						||
        else {
 | 
						||
            return type;
 | 
						||
        }
 | 
						||
    }
 | 
						||
    return 0;
 | 
						||
};
 | 
						||
var _lineBreakAtIndex = function (codePoints, classTypes, indicies, index, forbiddenBreaks) {
 | 
						||
    if (indicies[index] === 0) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    var currentIndex = index - 1;
 | 
						||
    if (Array.isArray(forbiddenBreaks) && forbiddenBreaks[currentIndex] === true) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    var beforeIndex = currentIndex - 1;
 | 
						||
    var afterIndex = currentIndex + 1;
 | 
						||
    var current = classTypes[currentIndex];
 | 
						||
    // LB4 Always break after hard line breaks.
 | 
						||
    // LB5 Treat CR followed by LF, as well as CR, LF, and NL as hard line breaks.
 | 
						||
    var before = beforeIndex >= 0 ? classTypes[beforeIndex] : 0;
 | 
						||
    var next = classTypes[afterIndex];
 | 
						||
    if (current === CR && next === LF) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    if (HARD_LINE_BREAKS.indexOf(current) !== -1) {
 | 
						||
        return exports.BREAK_MANDATORY;
 | 
						||
    }
 | 
						||
    // LB6 Do not break before hard line breaks.
 | 
						||
    if (HARD_LINE_BREAKS.indexOf(next) !== -1) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB7 Do not break before spaces or zero width space.
 | 
						||
    if (SPACE.indexOf(next) !== -1) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB8 Break before any character following a zero-width space, even if one or more spaces intervene.
 | 
						||
    if (previousNonSpaceClassType(currentIndex, classTypes) === ZW) {
 | 
						||
        return exports.BREAK_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB8a Do not break after a zero width joiner.
 | 
						||
    if (exports.UnicodeTrie.get(codePoints[currentIndex]) === ZWJ) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // zwj emojis
 | 
						||
    if ((current === EB || current === EM) && exports.UnicodeTrie.get(codePoints[afterIndex]) === ZWJ) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB11 Do not break before or after Word joiner and related characters.
 | 
						||
    if (current === WJ || next === WJ) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB12 Do not break after NBSP and related characters.
 | 
						||
    if (current === GL) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB12a Do not break before NBSP and related characters, except after spaces and hyphens.
 | 
						||
    if ([SP, BA, HY].indexOf(current) === -1 && next === GL) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB13 Do not break before ‘]’ or ‘!’ or ‘;’ or ‘/’, even after spaces.
 | 
						||
    if ([CL, CP, EX, IS, SY].indexOf(next) !== -1) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB14 Do not break after ‘[’, even after spaces.
 | 
						||
    if (previousNonSpaceClassType(currentIndex, classTypes) === OP) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB15 Do not break within ‘”[’, even with intervening spaces.
 | 
						||
    if (isAdjacentWithSpaceIgnored(QU, OP, currentIndex, classTypes)) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB16 Do not break between closing punctuation and a nonstarter (lb=NS), even with intervening spaces.
 | 
						||
    if (isAdjacentWithSpaceIgnored([CL, CP], NS, currentIndex, classTypes)) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB17 Do not break within ‘——’, even with intervening spaces.
 | 
						||
    if (isAdjacentWithSpaceIgnored(B2, B2, currentIndex, classTypes)) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB18 Break after spaces.
 | 
						||
    if (current === SP) {
 | 
						||
        return exports.BREAK_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB19 Do not break before or after quotation marks, such as ‘ ” ’.
 | 
						||
    if (current === QU || next === QU) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB20 Break before and after unresolved CB.
 | 
						||
    if (next === CB || current === CB) {
 | 
						||
        return exports.BREAK_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB21 Do not break before hyphen-minus, other hyphens, fixed-width spaces, small kana, and other non-starters, or after acute accents.
 | 
						||
    if ([BA, HY, NS].indexOf(next) !== -1 || current === BB) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB21a Don't break after Hebrew + Hyphen.
 | 
						||
    if (before === HL && HYPHEN.indexOf(current) !== -1) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB21b Don’t break between Solidus and Hebrew letters.
 | 
						||
    if (current === SY && next === HL) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB22 Do not break before ellipsis.
 | 
						||
    if (next === IN) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB23 Do not break between digits and letters.
 | 
						||
    if ((ALPHABETICS.indexOf(next) !== -1 && current === NU) || (ALPHABETICS.indexOf(current) !== -1 && next === NU)) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB23a Do not break between numeric prefixes and ideographs, or between ideographs and numeric postfixes.
 | 
						||
    if ((current === PR && [ID, EB, EM].indexOf(next) !== -1) ||
 | 
						||
        ([ID, EB, EM].indexOf(current) !== -1 && next === PO)) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB24 Do not break between numeric prefix/postfix and letters, or between letters and prefix/postfix.
 | 
						||
    if ((ALPHABETICS.indexOf(current) !== -1 && PREFIX_POSTFIX.indexOf(next) !== -1) ||
 | 
						||
        (PREFIX_POSTFIX.indexOf(current) !== -1 && ALPHABETICS.indexOf(next) !== -1)) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB25 Do not break between the following pairs of classes relevant to numbers:
 | 
						||
    if (
 | 
						||
    // (PR | PO) × ( OP | HY )? NU
 | 
						||
    ([PR, PO].indexOf(current) !== -1 &&
 | 
						||
        (next === NU || ([OP, HY].indexOf(next) !== -1 && classTypes[afterIndex + 1] === NU))) ||
 | 
						||
        // ( OP | HY ) × NU
 | 
						||
        ([OP, HY].indexOf(current) !== -1 && next === NU) ||
 | 
						||
        // NU ×	(NU | SY | IS)
 | 
						||
        (current === NU && [NU, SY, IS].indexOf(next) !== -1)) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // NU (NU | SY | IS)* × (NU | SY | IS | CL | CP)
 | 
						||
    if ([NU, SY, IS, CL, CP].indexOf(next) !== -1) {
 | 
						||
        var prevIndex = currentIndex;
 | 
						||
        while (prevIndex >= 0) {
 | 
						||
            var type = classTypes[prevIndex];
 | 
						||
            if (type === NU) {
 | 
						||
                return exports.BREAK_NOT_ALLOWED;
 | 
						||
            }
 | 
						||
            else if ([SY, IS].indexOf(type) !== -1) {
 | 
						||
                prevIndex--;
 | 
						||
            }
 | 
						||
            else {
 | 
						||
                break;
 | 
						||
            }
 | 
						||
        }
 | 
						||
    }
 | 
						||
    // NU (NU | SY | IS)* (CL | CP)? × (PO | PR))
 | 
						||
    if ([PR, PO].indexOf(next) !== -1) {
 | 
						||
        var prevIndex = [CL, CP].indexOf(current) !== -1 ? beforeIndex : currentIndex;
 | 
						||
        while (prevIndex >= 0) {
 | 
						||
            var type = classTypes[prevIndex];
 | 
						||
            if (type === NU) {
 | 
						||
                return exports.BREAK_NOT_ALLOWED;
 | 
						||
            }
 | 
						||
            else if ([SY, IS].indexOf(type) !== -1) {
 | 
						||
                prevIndex--;
 | 
						||
            }
 | 
						||
            else {
 | 
						||
                break;
 | 
						||
            }
 | 
						||
        }
 | 
						||
    }
 | 
						||
    // LB26 Do not break a Korean syllable.
 | 
						||
    if ((JL === current && [JL, JV, H2, H3].indexOf(next) !== -1) ||
 | 
						||
        ([JV, H2].indexOf(current) !== -1 && [JV, JT].indexOf(next) !== -1) ||
 | 
						||
        ([JT, H3].indexOf(current) !== -1 && next === JT)) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB27 Treat a Korean Syllable Block the same as ID.
 | 
						||
    if ((KOREAN_SYLLABLE_BLOCK.indexOf(current) !== -1 && [IN, PO].indexOf(next) !== -1) ||
 | 
						||
        (KOREAN_SYLLABLE_BLOCK.indexOf(next) !== -1 && current === PR)) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB28 Do not break between alphabetics (“at”).
 | 
						||
    if (ALPHABETICS.indexOf(current) !== -1 && ALPHABETICS.indexOf(next) !== -1) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB29 Do not break between numeric punctuation and alphabetics (“e.g.”).
 | 
						||
    if (current === IS && ALPHABETICS.indexOf(next) !== -1) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB30 Do not break between letters, numbers, or ordinary symbols and opening or closing parentheses.
 | 
						||
    if ((ALPHABETICS.concat(NU).indexOf(current) !== -1 &&
 | 
						||
        next === OP &&
 | 
						||
        ea_OP.indexOf(codePoints[afterIndex]) === -1) ||
 | 
						||
        (ALPHABETICS.concat(NU).indexOf(next) !== -1 && current === CP)) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB30a Break between two regional indicator symbols if and only if there are an even number of regional
 | 
						||
    // indicators preceding the position of the break.
 | 
						||
    if (current === RI && next === RI) {
 | 
						||
        var i = indicies[currentIndex];
 | 
						||
        var count = 1;
 | 
						||
        while (i > 0) {
 | 
						||
            i--;
 | 
						||
            if (classTypes[i] === RI) {
 | 
						||
                count++;
 | 
						||
            }
 | 
						||
            else {
 | 
						||
                break;
 | 
						||
            }
 | 
						||
        }
 | 
						||
        if (count % 2 !== 0) {
 | 
						||
            return exports.BREAK_NOT_ALLOWED;
 | 
						||
        }
 | 
						||
    }
 | 
						||
    // LB30b Do not break between an emoji base and an emoji modifier.
 | 
						||
    if (current === EB && next === EM) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    return exports.BREAK_ALLOWED;
 | 
						||
};
 | 
						||
var lineBreakAtIndex = function (codePoints, index) {
 | 
						||
    // LB2 Never break at the start of text.
 | 
						||
    if (index === 0) {
 | 
						||
        return exports.BREAK_NOT_ALLOWED;
 | 
						||
    }
 | 
						||
    // LB3 Always break at the end of text.
 | 
						||
    if (index >= codePoints.length) {
 | 
						||
        return exports.BREAK_MANDATORY;
 | 
						||
    }
 | 
						||
    var _a = exports.codePointsToCharacterClasses(codePoints), indices = _a[0], classTypes = _a[1];
 | 
						||
    return _lineBreakAtIndex(codePoints, classTypes, indices, index);
 | 
						||
};
 | 
						||
exports.lineBreakAtIndex = lineBreakAtIndex;
 | 
						||
var cssFormattedClasses = function (codePoints, options) {
 | 
						||
    if (!options) {
 | 
						||
        options = { lineBreak: 'normal', wordBreak: 'normal' };
 | 
						||
    }
 | 
						||
    var _a = exports.codePointsToCharacterClasses(codePoints, options.lineBreak), indicies = _a[0], classTypes = _a[1], isLetterNumber = _a[2];
 | 
						||
    if (options.wordBreak === 'break-all' || options.wordBreak === 'break-word') {
 | 
						||
        classTypes = classTypes.map(function (type) { return ([NU, AL, SA].indexOf(type) !== -1 ? ID : type); });
 | 
						||
    }
 | 
						||
    var forbiddenBreakpoints = options.wordBreak === 'keep-all'
 | 
						||
        ? isLetterNumber.map(function (letterNumber, i) {
 | 
						||
            return letterNumber && codePoints[i] >= 0x4e00 && codePoints[i] <= 0x9fff;
 | 
						||
        })
 | 
						||
        : undefined;
 | 
						||
    return [indicies, classTypes, forbiddenBreakpoints];
 | 
						||
};
 | 
						||
var inlineBreakOpportunities = function (str, options) {
 | 
						||
    var codePoints = Util_1.toCodePoints(str);
 | 
						||
    var output = exports.BREAK_NOT_ALLOWED;
 | 
						||
    var _a = cssFormattedClasses(codePoints, options), indicies = _a[0], classTypes = _a[1], forbiddenBreakpoints = _a[2];
 | 
						||
    codePoints.forEach(function (codePoint, i) {
 | 
						||
        output +=
 | 
						||
            Util_1.fromCodePoint(codePoint) +
 | 
						||
                (i >= codePoints.length - 1
 | 
						||
                    ? exports.BREAK_MANDATORY
 | 
						||
                    : _lineBreakAtIndex(codePoints, classTypes, indicies, i + 1, forbiddenBreakpoints));
 | 
						||
    });
 | 
						||
    return output;
 | 
						||
};
 | 
						||
exports.inlineBreakOpportunities = inlineBreakOpportunities;
 | 
						||
var Break = /** @class */ (function () {
 | 
						||
    function Break(codePoints, lineBreak, start, end) {
 | 
						||
        this.codePoints = codePoints;
 | 
						||
        this.required = lineBreak === exports.BREAK_MANDATORY;
 | 
						||
        this.start = start;
 | 
						||
        this.end = end;
 | 
						||
    }
 | 
						||
    Break.prototype.slice = function () {
 | 
						||
        return Util_1.fromCodePoint.apply(void 0, this.codePoints.slice(this.start, this.end));
 | 
						||
    };
 | 
						||
    return Break;
 | 
						||
}());
 | 
						||
var LineBreaker = function (str, options) {
 | 
						||
    var codePoints = Util_1.toCodePoints(str);
 | 
						||
    var _a = cssFormattedClasses(codePoints, options), indicies = _a[0], classTypes = _a[1], forbiddenBreakpoints = _a[2];
 | 
						||
    var length = codePoints.length;
 | 
						||
    var lastEnd = 0;
 | 
						||
    var nextIndex = 0;
 | 
						||
    return {
 | 
						||
        next: function () {
 | 
						||
            if (nextIndex >= length) {
 | 
						||
                return { done: true, value: null };
 | 
						||
            }
 | 
						||
            var lineBreak = exports.BREAK_NOT_ALLOWED;
 | 
						||
            while (nextIndex < length &&
 | 
						||
                (lineBreak = _lineBreakAtIndex(codePoints, classTypes, indicies, ++nextIndex, forbiddenBreakpoints)) ===
 | 
						||
                    exports.BREAK_NOT_ALLOWED) { }
 | 
						||
            if (lineBreak !== exports.BREAK_NOT_ALLOWED || nextIndex === length) {
 | 
						||
                var value = new Break(codePoints, lineBreak, lastEnd, nextIndex);
 | 
						||
                lastEnd = nextIndex;
 | 
						||
                return { value: value, done: false };
 | 
						||
            }
 | 
						||
            return { done: true, value: null };
 | 
						||
        },
 | 
						||
    };
 | 
						||
};
 | 
						||
exports.LineBreaker = LineBreaker;
 | 
						||
//# sourceMappingURL=LineBreak.js.map
 |