保誠-保戶業務員媒合平台
HelenHuang
2022-06-09 23b60dc1975db38c280d8a123aff97544d1673e0
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/*
    MIT License http://www.opensource.org/licenses/mit-license.php
    Author Tobias Koppers @sokra
*/
"use strict";
 
var SourceNode = require("source-map").SourceNode;
var SourceMapConsumer = require("source-map").SourceMapConsumer;
var SourceListMap = require("source-list-map").SourceListMap;
var Source = require("./Source");
 
var SPLIT_REGEX = /(?!$)[^\n\r;{}]*[\n\r;{}]*/g;
 
function _splitCode(code) {
    return code.match(SPLIT_REGEX) || [];
}
 
class OriginalSource extends Source {
    constructor(value, name) {
        super();
        this._value = value;
        this._name = name;
    }
 
    source() {
        return this._value;
    }
 
    node(options) {
        options = options || {};
        var sourceMap = this._sourceMap;
        var value = this._value;
        var name = this._name;
        var lines = value.split("\n");
        var node = new SourceNode(null, null, null,
            lines.map(function(line, idx) {
                var pos = 0;
                if(options.columns === false) {
                    var content = line + (idx != lines.length - 1 ? "\n" : "");
                    return new SourceNode(idx + 1, 0, name, content);
                }
                return new SourceNode(null, null, null,
                    _splitCode(line + (idx != lines.length - 1 ? "\n" : "")).map(function(item) {
                        if(/^\s*$/.test(item)) {
                            pos += item.length;
                            return item;
                        }
                        var res = new SourceNode(idx + 1, pos, name, item);
                        pos += item.length;
                        return res;
                    })
                );
            })
        );
        node.setSourceContent(name, value);
        return node;
    }
 
    listMap(options) {
        return new SourceListMap(this._value, this._name, this._value)
    }
 
    updateHash(hash) {
        hash.update(this._value);
    }
}
 
require("./SourceAndMapMixin")(OriginalSource.prototype);
 
module.exports = OriginalSource;