.
This commit is contained in:
		
							
								
								
									
										86
									
								
								qwen/nodejs/node_modules/text-table/index.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								qwen/nodejs/node_modules/text-table/index.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,86 @@
 | 
			
		||||
module.exports = function (rows_, opts) {
 | 
			
		||||
    if (!opts) opts = {};
 | 
			
		||||
    var hsep = opts.hsep === undefined ? '  ' : opts.hsep;
 | 
			
		||||
    var align = opts.align || [];
 | 
			
		||||
    var stringLength = opts.stringLength
 | 
			
		||||
        || function (s) { return String(s).length; }
 | 
			
		||||
    ;
 | 
			
		||||
    
 | 
			
		||||
    var dotsizes = reduce(rows_, function (acc, row) {
 | 
			
		||||
        forEach(row, function (c, ix) {
 | 
			
		||||
            var n = dotindex(c);
 | 
			
		||||
            if (!acc[ix] || n > acc[ix]) acc[ix] = n;
 | 
			
		||||
        });
 | 
			
		||||
        return acc;
 | 
			
		||||
    }, []);
 | 
			
		||||
    
 | 
			
		||||
    var rows = map(rows_, function (row) {
 | 
			
		||||
        return map(row, function (c_, ix) {
 | 
			
		||||
            var c = String(c_);
 | 
			
		||||
            if (align[ix] === '.') {
 | 
			
		||||
                var index = dotindex(c);
 | 
			
		||||
                var size = dotsizes[ix] + (/\./.test(c) ? 1 : 2)
 | 
			
		||||
                    - (stringLength(c) - index)
 | 
			
		||||
                ;
 | 
			
		||||
                return c + Array(size).join(' ');
 | 
			
		||||
            }
 | 
			
		||||
            else return c;
 | 
			
		||||
        });
 | 
			
		||||
    });
 | 
			
		||||
    
 | 
			
		||||
    var sizes = reduce(rows, function (acc, row) {
 | 
			
		||||
        forEach(row, function (c, ix) {
 | 
			
		||||
            var n = stringLength(c);
 | 
			
		||||
            if (!acc[ix] || n > acc[ix]) acc[ix] = n;
 | 
			
		||||
        });
 | 
			
		||||
        return acc;
 | 
			
		||||
    }, []);
 | 
			
		||||
    
 | 
			
		||||
    return map(rows, function (row) {
 | 
			
		||||
        return map(row, function (c, ix) {
 | 
			
		||||
            var n = (sizes[ix] - stringLength(c)) || 0;
 | 
			
		||||
            var s = Array(Math.max(n + 1, 1)).join(' ');
 | 
			
		||||
            if (align[ix] === 'r' || align[ix] === '.') {
 | 
			
		||||
                return s + c;
 | 
			
		||||
            }
 | 
			
		||||
            if (align[ix] === 'c') {
 | 
			
		||||
                return Array(Math.ceil(n / 2 + 1)).join(' ')
 | 
			
		||||
                    + c + Array(Math.floor(n / 2 + 1)).join(' ')
 | 
			
		||||
                ;
 | 
			
		||||
            }
 | 
			
		||||
            
 | 
			
		||||
            return c + s;
 | 
			
		||||
        }).join(hsep).replace(/\s+$/, '');
 | 
			
		||||
    }).join('\n');
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
function dotindex (c) {
 | 
			
		||||
    var m = /\.[^.]*$/.exec(c);
 | 
			
		||||
    return m ? m.index + 1 : c.length;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function reduce (xs, f, init) {
 | 
			
		||||
    if (xs.reduce) return xs.reduce(f, init);
 | 
			
		||||
    var i = 0;
 | 
			
		||||
    var acc = arguments.length >= 3 ? init : xs[i++];
 | 
			
		||||
    for (; i < xs.length; i++) {
 | 
			
		||||
        f(acc, xs[i], i);
 | 
			
		||||
    }
 | 
			
		||||
    return acc;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function forEach (xs, f) {
 | 
			
		||||
    if (xs.forEach) return xs.forEach(f);
 | 
			
		||||
    for (var i = 0; i < xs.length; i++) {
 | 
			
		||||
        f.call(xs, xs[i], i);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function map (xs, f) {
 | 
			
		||||
    if (xs.map) return xs.map(f);
 | 
			
		||||
    var res = [];
 | 
			
		||||
    for (var i = 0; i < xs.length; i++) {
 | 
			
		||||
        res.push(f.call(xs, xs[i], i));
 | 
			
		||||
    }
 | 
			
		||||
    return res;
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user