1 | "use strict";
|
2 | Object.defineProperty(exports, "__esModule", { value: true });
|
3 | exports.inspectAny = void 0;
|
4 | const js_lib_1 = require("@naturalcycles/js-lib");
|
5 | const util_1 = require("util");
|
6 |
|
7 |
|
8 |
|
9 |
|
10 |
|
11 |
|
12 |
|
13 |
|
14 |
|
15 |
|
16 |
|
17 |
|
18 |
|
19 |
|
20 |
|
21 | function inspectAny(obj, opt = {}) {
|
22 | let s;
|
23 | if (obj instanceof Error) {
|
24 |
|
25 | s = (!opt.noErrorStack && obj.stack) || [obj?.name, obj.message].filter(Boolean).join(': ');
|
26 | if (obj instanceof js_lib_1.AppError) {
|
27 | s = [s, Object.keys(obj.data).length > 0 && inspectAny(obj.data, opt)]
|
28 | .filter(Boolean)
|
29 | .join('\n');
|
30 | }
|
31 | else if (typeof obj.code === 'string') {
|
32 | s = obj.code + '\n' + s;
|
33 | }
|
34 | }
|
35 | else if (js_lib_1._isErrorObject(obj)) {
|
36 | s = [obj.message, Object.keys(obj.data).length > 0 && inspectAny(obj.data, opt)]
|
37 | .filter(Boolean)
|
38 | .join('\n');
|
39 | }
|
40 | else if (typeof obj === 'string') {
|
41 | s = obj.trim() || 'empty_string';
|
42 | }
|
43 | else {
|
44 | s = util_1.inspect(obj, {
|
45 | breakLength: 80,
|
46 | depth: 6,
|
47 | ...opt,
|
48 | });
|
49 | }
|
50 |
|
51 |
|
52 | if (opt.maxLen && s.length > opt.maxLen) {
|
53 | s = s.slice(0, opt.maxLen) + `... ${Math.ceil(s.length / 1024)} KB message truncated`;
|
54 | }
|
55 | return s;
|
56 | }
|
57 | exports.inspectAny = inspectAny;
|