@dxos/log 0.8.4-main.fd6878d → 0.8.4-main.fdfb99ef29

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (94) hide show
  1. package/dist/lib/browser/chunk-IEP6GGEX.mjs +23 -0
  2. package/dist/lib/browser/chunk-IEP6GGEX.mjs.map +7 -0
  3. package/dist/lib/browser/chunk-V7FYKT4H.mjs +311 -0
  4. package/dist/lib/browser/chunk-V7FYKT4H.mjs.map +7 -0
  5. package/dist/lib/browser/index.mjs +347 -198
  6. package/dist/lib/browser/index.mjs.map +4 -4
  7. package/dist/lib/browser/meta.json +1 -1
  8. package/dist/lib/browser/platform/browser/index.mjs +26 -0
  9. package/dist/lib/browser/platform/browser/index.mjs.map +7 -0
  10. package/dist/lib/browser/platform/node/index.mjs +21 -0
  11. package/dist/lib/browser/platform/node/index.mjs.map +7 -0
  12. package/dist/lib/browser/processors/console-processor.mjs +102 -0
  13. package/dist/lib/browser/processors/console-processor.mjs.map +7 -0
  14. package/dist/lib/browser/processors/console-stub.mjs +9 -0
  15. package/dist/lib/browser/processors/console-stub.mjs.map +7 -0
  16. package/dist/lib/node-esm/chunk-2SZHAWBN.mjs +24 -0
  17. package/dist/lib/node-esm/chunk-2SZHAWBN.mjs.map +7 -0
  18. package/dist/lib/node-esm/chunk-5TBDXMQF.mjs +313 -0
  19. package/dist/lib/node-esm/chunk-5TBDXMQF.mjs.map +7 -0
  20. package/dist/lib/node-esm/index.mjs +349 -287
  21. package/dist/lib/node-esm/index.mjs.map +4 -4
  22. package/dist/lib/node-esm/meta.json +1 -1
  23. package/dist/lib/node-esm/platform/browser/index.mjs +27 -0
  24. package/dist/lib/node-esm/platform/browser/index.mjs.map +7 -0
  25. package/dist/lib/node-esm/platform/node/index.mjs +22 -0
  26. package/dist/lib/node-esm/platform/node/index.mjs.map +7 -0
  27. package/dist/lib/node-esm/processors/console-processor.mjs +103 -0
  28. package/dist/lib/node-esm/processors/console-processor.mjs.map +7 -0
  29. package/dist/lib/node-esm/processors/console-stub.mjs +10 -0
  30. package/dist/lib/node-esm/processors/console-stub.mjs.map +7 -0
  31. package/dist/types/src/config.d.ts +2 -3
  32. package/dist/types/src/config.d.ts.map +1 -1
  33. package/dist/types/src/context.d.ts +78 -2
  34. package/dist/types/src/context.d.ts.map +1 -1
  35. package/dist/types/src/dbg.d.ts +23 -0
  36. package/dist/types/src/dbg.d.ts.map +1 -0
  37. package/dist/types/src/decorators.d.ts +1 -1
  38. package/dist/types/src/decorators.d.ts.map +1 -1
  39. package/dist/types/src/environment.d.ts +24 -0
  40. package/dist/types/src/environment.d.ts.map +1 -0
  41. package/dist/types/src/environment.test.d.ts +2 -0
  42. package/dist/types/src/environment.test.d.ts.map +1 -0
  43. package/dist/types/src/experimental/ownership.d.ts.map +1 -1
  44. package/dist/types/src/index.d.ts +7 -3
  45. package/dist/types/src/index.d.ts.map +1 -1
  46. package/dist/types/src/jsonl.d.ts +53 -0
  47. package/dist/types/src/jsonl.d.ts.map +1 -0
  48. package/dist/types/src/jsonl.test.d.ts +2 -0
  49. package/dist/types/src/jsonl.test.d.ts.map +1 -0
  50. package/dist/types/src/log-buffer.d.ts +20 -0
  51. package/dist/types/src/log-buffer.d.ts.map +1 -0
  52. package/dist/types/src/log-buffer.test.d.ts +2 -0
  53. package/dist/types/src/log-buffer.test.d.ts.map +1 -0
  54. package/dist/types/src/log.d.ts +55 -18
  55. package/dist/types/src/log.d.ts.map +1 -1
  56. package/dist/types/src/meta.d.ts +20 -1
  57. package/dist/types/src/meta.d.ts.map +1 -1
  58. package/dist/types/src/options.d.ts +1 -6
  59. package/dist/types/src/options.d.ts.map +1 -1
  60. package/dist/types/src/platform/browser/index.d.ts.map +1 -1
  61. package/dist/types/src/platform/index.d.ts +1 -1
  62. package/dist/types/src/platform/index.d.ts.map +1 -1
  63. package/dist/types/src/platform/node/index.d.ts.map +1 -1
  64. package/dist/types/src/processors/browser-processor.d.ts.map +1 -1
  65. package/dist/types/src/processors/common.d.ts.map +1 -1
  66. package/dist/types/src/processors/console-processor.d.ts.map +1 -1
  67. package/dist/types/src/processors/file-processor.d.ts.map +1 -1
  68. package/dist/types/src/processors/index.d.ts +3 -3
  69. package/dist/types/src/processors/index.d.ts.map +1 -1
  70. package/dist/types/src/scope.d.ts.map +1 -1
  71. package/dist/types/tsconfig.tsbuildinfo +1 -1
  72. package/package.json +30 -15
  73. package/src/config.ts +3 -2
  74. package/src/context.ts +278 -7
  75. package/src/dbg.ts +34 -0
  76. package/src/decorators.ts +4 -5
  77. package/src/environment.test.ts +222 -0
  78. package/src/environment.ts +129 -0
  79. package/src/experimental/classes.test.ts +0 -1
  80. package/src/index.ts +7 -4
  81. package/src/jsonl.test.ts +121 -0
  82. package/src/jsonl.ts +104 -0
  83. package/src/log-buffer.test.ts +158 -0
  84. package/src/log-buffer.ts +89 -0
  85. package/src/log.test.ts +48 -19
  86. package/src/log.ts +146 -58
  87. package/src/meta.ts +29 -1
  88. package/src/options.ts +26 -10
  89. package/src/platform/index.ts +1 -1
  90. package/src/platform/node/index.ts +1 -2
  91. package/src/processors/browser-processor.ts +28 -27
  92. package/src/processors/console-processor.ts +5 -13
  93. package/src/processors/file-processor.ts +9 -9
  94. package/src/processors/index.ts +3 -3
package/src/options.ts CHANGED
@@ -12,32 +12,48 @@ import { BROWSER_PROCESSOR, CONSOLE_PROCESSOR, DEBUG_PROCESSOR } from './process
12
12
  /**
13
13
  * Processor variants.
14
14
  */
15
- export const processors: { [index: string]: LogProcessor } = {
15
+ export const processors: Record<string, LogProcessor> = {
16
16
  [LogProcessorType.CONSOLE]: CONSOLE_PROCESSOR,
17
17
  [LogProcessorType.BROWSER]: BROWSER_PROCESSOR,
18
18
  [LogProcessorType.DEBUG]: DEBUG_PROCESSOR,
19
19
  };
20
20
 
21
- const IS_BROWSER = typeof window !== 'undefined' || typeof navigator !== 'undefined';
21
+ const browser =
22
+ (typeof window !== 'undefined' || typeof navigator !== 'undefined') &&
23
+ !(typeof process !== 'undefined' && process?.env?.VITEST);
22
24
 
23
- export const DEFAULT_PROCESSORS = [IS_BROWSER ? BROWSER_PROCESSOR : CONSOLE_PROCESSOR];
25
+ export const DEFAULT_PROCESSORS = [browser ? BROWSER_PROCESSOR : CONSOLE_PROCESSOR];
24
26
 
27
+ const parseLogLevel = (level: string, defValue = LogLevel.WARN) => levels[level.toLowerCase()] ?? defValue;
28
+
29
+ /**
30
+ * @internal
31
+ */
25
32
  export const parseFilter = (filter: string | string[] | LogLevel): LogFilter[] => {
26
33
  if (typeof filter === 'number') {
27
34
  return [{ level: filter }];
28
35
  }
29
36
 
30
- const parseLogLevel = (level: string, defValue = LogLevel.WARN) => levels[level.toLowerCase()] ?? defValue;
31
-
32
37
  const lines = typeof filter === 'string' ? filter.split(/,\s*/) : filter;
33
38
  return lines.map((filter) => {
34
39
  const [pattern, level] = filter.split(':');
35
- return level ? { level: parseLogLevel(level), pattern } : { level: parseLogLevel(pattern) };
40
+ return level
41
+ ? {
42
+ level: parseLogLevel(level),
43
+ pattern,
44
+ }
45
+ : {
46
+ level: parseLogLevel(pattern),
47
+ };
36
48
  });
37
49
  };
38
50
 
39
- export const getConfig = (options?: LogOptions): LogConfig => {
40
- const nodeOptions: LogOptions | undefined =
51
+ /**
52
+ * @internal
53
+ */
54
+ export const createConfig = (options?: LogOptions): LogConfig => {
55
+ // Node only.
56
+ const envOptions: LogOptions | undefined =
41
57
  'process' in globalThis
42
58
  ? {
43
59
  file: process!.env.LOG_CONFIG,
@@ -46,12 +62,12 @@ export const getConfig = (options?: LogOptions): LogConfig => {
46
62
  }
47
63
  : undefined;
48
64
 
49
- const mergedOptions: LogOptions = defaultsDeep({}, loadOptions(nodeOptions?.file), nodeOptions, options);
65
+ const mergedOptions: LogOptions = defaultsDeep({}, loadOptions(envOptions?.file), envOptions, options);
50
66
  return {
51
67
  options: mergedOptions,
52
68
  filters: parseFilter(mergedOptions.filter ?? LogLevel.INFO),
53
69
  captureFilters: parseFilter(mergedOptions.captureFilter ?? LogLevel.WARN),
54
- processors: mergedOptions.processor ? [processors[mergedOptions.processor]] : DEFAULT_PROCESSORS,
70
+ processors: mergedOptions.processor ? [processors[mergedOptions.processor]] : [...DEFAULT_PROCESSORS],
55
71
  prefix: mergedOptions.prefix,
56
72
  };
57
73
  };
@@ -2,4 +2,4 @@
2
2
  // Copyright 2022 DXOS.org
3
3
  //
4
4
 
5
- export * from './node';
5
+ export * from '#platform';
@@ -2,9 +2,8 @@
2
2
  // Copyright 2022 DXOS.org
3
3
  //
4
4
 
5
- import fs from 'node:fs';
6
-
7
5
  import yaml from 'js-yaml';
6
+ import fs from 'node:fs';
8
7
 
9
8
  import { type LogOptions } from '../../config';
10
9
 
@@ -2,23 +2,11 @@
2
2
  // Copyright 2022 DXOS.org
3
3
  //
4
4
 
5
- import { getDebugName, safariCheck } from '@dxos/util';
5
+ import { safariCheck } from '@dxos/util';
6
6
 
7
7
  import { LogLevel } from '../config';
8
8
  import { type LogProcessor, getContextFromEntry, shouldLog } from '../context';
9
9
 
10
- const getRelativeFilename = (filename: string) => {
11
- // TODO(burdon): Hack uses "packages" as an anchor (pre-parse NX?)
12
- // Including `packages/` part of the path so that excluded paths (e.g. from dist) are clickable in vscode.
13
- const match = filename.match(/.+\/(packages\/.+\/.+)/);
14
- if (match) {
15
- const [, filePath] = match;
16
- return filePath;
17
- }
18
-
19
- return filename;
20
- };
21
-
22
10
  type Config = {
23
11
  useTestProcessor: boolean;
24
12
  printFileLinks: boolean;
@@ -47,23 +35,26 @@ const APP_BROWSER_PROCESSOR: LogProcessor = (config, entry) => {
47
35
  // const LOG_BROWSER_CSS = ['color:gray; font-size:10px; padding-bottom: 4px', 'color:#B97852; font-size:14px;'];
48
36
  const LOG_BROWSER_CSS: string[] = [];
49
37
 
38
+ const { filename, line: lineNumber, context: scopeDebugName } = entry.computedMeta;
39
+
50
40
  let link = '';
51
- if (entry.meta) {
52
- const filename = getRelativeFilename(entry.meta.F);
41
+ if (filename !== undefined && lineNumber !== undefined) {
53
42
  const filepath = `${LOG_BROWSER_PREFIX.replace(/\/$/, '')}/${filename}`;
54
43
  // TODO(burdon): Line numbers not working for app link, even with colons.
55
44
  // https://stackoverflow.com/a/54459820/2804332
56
- link = `${filepath}#L${entry.meta.L}`;
45
+ link = `${filepath}#L${lineNumber}`;
57
46
  }
58
47
 
59
48
  let args = [];
60
49
 
61
- if (entry.meta?.S) {
62
- const scope = entry.meta?.S;
63
- const scopeName = scope.name || getDebugName(scope);
64
- const processPrefix = entry.meta.S?.hostSessionId ? '[worker] ' : '';
65
- // TODO(dmaretskyi): Those can be made clickable with a custom formatter.
66
- args.push(`%c${processPrefix}${scopeName}`, 'color:#C026D3;font-weight:bold');
50
+ const scope = entry.meta?.S;
51
+ if (scope) {
52
+ const scopeName = scope.name || scopeDebugName;
53
+ if (scopeName) {
54
+ const processPrefix = scope.hostSessionId ? '[worker] ' : '';
55
+ // TODO(dmaretskyi): Those can be made clickable with a custom formatter.
56
+ args.push(`%c${processPrefix}${scopeName}`, 'color:#C026D3;font-weight:bold');
57
+ }
67
58
  }
68
59
 
69
60
  if (entry.message) {
@@ -73,7 +64,9 @@ const APP_BROWSER_PROCESSOR: LogProcessor = (config, entry) => {
73
64
  const context = getContextFromEntry(entry);
74
65
  if (context) {
75
66
  if (Object.keys(context).length === 1 && 'error' in context) {
76
- args.push(context.error);
67
+ args.push(unwrapEffectError(context.error));
68
+ } else if (Object.keys(context).length === 1 && 'err' in context) {
69
+ args.push(unwrapEffectError(context.err));
77
70
  } else {
78
71
  args.push(context);
79
72
  }
@@ -112,10 +105,8 @@ const TEST_BROWSER_PROCESSOR: LogProcessor = (config, entry) => {
112
105
  return;
113
106
  }
114
107
 
115
- let path = '';
116
- if (entry.meta) {
117
- path = `${getRelativeFilename(entry.meta.F)}:${entry.meta.L}`;
118
- }
108
+ const { filename, line: lineNumber } = entry.computedMeta;
109
+ const path = filename !== undefined && lineNumber !== undefined ? `${filename}:${lineNumber}` : '';
119
110
 
120
111
  let args = [];
121
112
 
@@ -146,3 +137,13 @@ const TEST_BROWSER_PROCESSOR: LogProcessor = (config, entry) => {
146
137
  };
147
138
 
148
139
  export const BROWSER_PROCESSOR: LogProcessor = CONFIG.useTestProcessor ? TEST_BROWSER_PROCESSOR : APP_BROWSER_PROCESSOR;
140
+
141
+ // effect-specific
142
+ const originalSymbol = Symbol.for('effect/OriginalAnnotation');
143
+
144
+ const unwrapEffectError = (error: any) => {
145
+ if (typeof error === 'object' && error !== null && originalSymbol in error) {
146
+ return error[originalSymbol];
147
+ }
148
+ return error;
149
+ };
@@ -2,17 +2,14 @@
2
2
  // Copyright 2022 DXOS.org
3
3
  //
4
4
 
5
- import { inspect } from 'node:util';
6
-
7
5
  import chalk from 'chalk';
6
+ import { inspect } from 'node:util';
8
7
 
9
8
  import { getPrototypeSpecificInstanceId, pickBy } from '@dxos/util';
10
9
 
11
10
  import { type LogConfig, LogLevel, shortLevelName } from '../config';
12
11
  import { type LogProcessor, getContextFromEntry, shouldLog } from '../context';
13
12
 
14
- import { getRelativeFilename } from './common';
15
-
16
13
  const LEVEL_COLORS: Record<LogLevel, typeof chalk.ForegroundColor> = {
17
14
  [LogLevel.TRACE]: 'gray',
18
15
  [LogLevel.DEBUG]: 'gray',
@@ -95,22 +92,17 @@ export const CONSOLE_PROCESSOR: LogProcessor = (config, entry) => {
95
92
  return;
96
93
  }
97
94
 
95
+ const { filename, line: lineNumber } = entry.computedMeta;
98
96
  const parts: FormatParts = {
99
97
  level,
100
98
  message,
101
99
  error,
102
- path: undefined,
103
- line: undefined,
104
- scope: undefined,
100
+ path: filename,
101
+ line: lineNumber,
102
+ scope: meta?.S,
105
103
  context: undefined,
106
104
  };
107
105
 
108
- if (meta) {
109
- parts.path = getRelativeFilename(meta.F);
110
- parts.line = meta.L;
111
- parts.scope = meta.S;
112
- }
113
-
114
106
  const context = getContextFromEntry(entry);
115
107
  if (context) {
116
108
  // Remove undefined fields.
@@ -5,15 +5,12 @@
5
5
  import { appendFileSync, mkdirSync, openSync } from 'node:fs';
6
6
  import { dirname } from 'node:path';
7
7
 
8
- import { jsonlogify } from '@dxos/util';
9
-
10
8
  import { type LogFilter, LogLevel } from '../config';
11
- import { type LogProcessor, getContextFromEntry, shouldLog } from '../context';
12
-
13
- import { getRelativeFilename } from './common';
9
+ import { type LogProcessor, shouldLog } from '../context';
14
10
 
15
11
  // Amount of time to retry writing after encountering EAGAIN before giving up.
16
12
  const EAGAIN_MAX_DURATION = 1000;
13
+
17
14
  /**
18
15
  * Create a file processor.
19
16
  * @param path - Path to log file to create or append to, or existing open file descriptor e.g. stdout.
@@ -38,6 +35,7 @@ export const createFileProcessor = ({
38
35
  if (!shouldLog(entry, filters)) {
39
36
  return;
40
37
  }
38
+
41
39
  if (typeof pathOrFd === 'number') {
42
40
  fd = pathOrFd;
43
41
  } else {
@@ -48,10 +46,12 @@ export const createFileProcessor = ({
48
46
  }
49
47
 
50
48
  const record = {
51
- ...entry,
52
- timestamp: Date.now(),
53
- ...(entry.meta ? { meta: { file: getRelativeFilename(entry.meta.F), line: entry.meta.L } } : {}),
54
- context: jsonlogify(getContextFromEntry(entry)),
49
+ level: entry.level,
50
+ message: entry.message,
51
+ timestamp: entry.timestamp,
52
+ meta: entry.computedMeta,
53
+ context: entry.computedContext,
54
+ error: entry.computedError,
55
55
  };
56
56
  let retryTS: number = 0;
57
57
 
@@ -2,8 +2,8 @@
2
2
  // Copyright 2022 DXOS.org
3
3
  //
4
4
 
5
- export * from './console-processor';
6
- export * from './debug-processor';
7
5
  export * from './browser-processor';
8
- export * from './file-processor';
9
6
  export * from './common';
7
+ export * from '#console-processor';
8
+ export * from './debug-processor';
9
+ export * from './file-processor';