diff options
| author | Alex Yatskov <alex@foosoft.net> | 2020-04-10 09:38:07 -0700 | 
|---|---|---|
| committer | Alex Yatskov <alex@foosoft.net> | 2020-04-10 09:38:07 -0700 | 
| commit | 3ed49205f2af076e3c5b4fe371d8a0a420845581 (patch) | |
| tree | ab0c0fd9638aaa6a842bc4f17e73754ca7d26bd9 /ext/bg/js/text-source-map.js | |
| parent | b77e2afe3a8ef9e96a53dd8ca97d8b913941244b (diff) | |
| parent | 281023095a9fb7f7aca1df8dc0e3f902e78dc16b (diff) | |
Merge branch 'master' into testing
Diffstat (limited to 'ext/bg/js/text-source-map.js')
| -rw-r--r-- | ext/bg/js/text-source-map.js | 115 | 
1 files changed, 115 insertions, 0 deletions
| diff --git a/ext/bg/js/text-source-map.js b/ext/bg/js/text-source-map.js new file mode 100644 index 00000000..24970978 --- /dev/null +++ b/ext/bg/js/text-source-map.js @@ -0,0 +1,115 @@ +/* + * Copyright (C) 2020  Alex Yatskov <alex@foosoft.net> + * Author: Alex Yatskov <alex@foosoft.net> + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program.  If not, see <https://www.gnu.org/licenses/>. + */ + +class TextSourceMap { +    constructor(source, mapping=null) { +        this._source = source; +        this._mapping = (Array.isArray(mapping) ? TextSourceMap._normalizeMapping(mapping) : null); +    } + +    get source() { +        return this._source; +    } + +    equals(other) { +        if (this === other) { +            return true; +        } + +        const source = this._source; +        if (!(other instanceof TextSourceMap && source === other._source)) { +            return false; +        } + +        let mapping = this._mapping; +        let otherMapping = other._mapping; +        if (mapping === null) { +            if (otherMapping === null) { +                return true; +            } +            mapping = TextSourceMap._createMapping(source); +        } else if (otherMapping === null) { +            otherMapping = TextSourceMap._createMapping(source); +        } + +        const mappingLength = mapping.length; +        if (mappingLength !== otherMapping.length) { +            return false; +        } + +        for (let i = 0; i < mappingLength; ++i) { +            if (mapping[i] !== otherMapping[i]) { +                return false; +            } +        } + +        return true; +    } + +    getSourceLength(finalLength) { +        const mapping = this._mapping; +        if (mapping === null) { +            return finalLength; +        } + +        let sourceLength = 0; +        for (let i = 0; i < finalLength; ++i) { +            sourceLength += mapping[i]; +        } +        return sourceLength; +    } + +    combine(index, count) { +        if (count <= 0) { return; } + +        if (this._mapping === null) { +            this._mapping = TextSourceMap._createMapping(this._source); +        } + +        let sum = this._mapping[index]; +        const parts = this._mapping.splice(index + 1, count); +        for (const part of parts) { +            sum += part; +        } +        this._mapping[index] = sum; +    } + +    insert(index, ...items) { +        if (this._mapping === null) { +            this._mapping = TextSourceMap._createMapping(this._source); +        } + +        this._mapping.splice(index, 0, ...items); +    } + +    static _createMapping(text) { +        return new Array(text.length).fill(1); +    } + +    static _normalizeMapping(mapping) { +        const result = []; +        for (const value of mapping) { +            result.push( +                (typeof value === 'number' && Number.isFinite(value)) ? +                Math.floor(value) : +                0 +            ); +        } +        return result; +    } +} |