oclang 1.2.2 → 1.3.2
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.
- package/.gitattributes +7 -0
- package/BUG_REGISTRY.md +6 -1
- package/CHANGELOG.md +20 -3
- package/README.md +2 -0
- package/dist/cli/ocat/index.js +0 -0
- package/dist/cli/ocm/commands/run.js +0 -5
- package/dist/cli/ocm/index.js +0 -0
- package/dist/core/ast/astBuilder.js +20 -144
- package/dist/core/ast/statements/_base.js +1 -0
- package/dist/core/ast/statements/function.js +53 -0
- package/dist/core/ast/statements/import.js +16 -0
- package/dist/core/ast/statements/io.js +45 -0
- package/dist/core/ast/statements/vars.js +37 -0
- package/dist/core/ast/types/base/statement.js +1 -0
- package/dist/core/ast/types/statements/importStatement.js +1 -0
- package/dist/core/ast/types/statements/index.js +5 -4
- package/dist/core/index.js +7 -5
- package/dist/core/lexer/tokens/keywords.js +2 -1
- package/dist/core/parser/parser.js +42 -15
- package/dist/core/runner/funcs/_base.js +1 -0
- package/dist/core/runner/funcs/functions.js +28 -0
- package/dist/core/runner/funcs/io.js +29 -0
- package/dist/core/runner/funcs/modules.js +11 -0
- package/dist/core/runner/funcs/variables.js +42 -0
- package/dist/core/runner/runner.js +16 -101
- package/dist/core/services/log.service.js +7 -7
- package/dist/shared/context/globalContext.js +7 -1
- package/dist/shared/manager/baseManager.js +5 -3
- package/dist/shared/manager/warn/coreWarnings.js +2 -2
- package/package.json +30 -30
- package/src/cli/ocm/commands/run.ts +0 -5
- package/src/core/ast/astBuilder.ts +21 -152
- package/src/core/ast/statements/_base.ts +3 -0
- package/src/core/ast/statements/function.ts +60 -0
- package/src/core/ast/statements/import.ts +22 -0
- package/src/core/ast/statements/io.ts +50 -0
- package/src/core/ast/statements/vars.ts +46 -0
- package/src/core/ast/types/base/statement.ts +2 -1
- package/src/core/ast/types/statements/callStatement.ts +1 -2
- package/src/core/ast/types/statements/functionStatement.ts +2 -2
- package/src/core/ast/types/statements/importStatement.ts +6 -0
- package/src/core/ast/types/statements/index.ts +12 -9
- package/src/core/ast/types/statements/printStatement.ts +2 -2
- package/src/core/ast/types/statements/variableStatement.ts +2 -2
- package/src/core/context/coreContext.ts +3 -3
- package/src/core/index.ts +8 -5
- package/src/core/lexer/tokens/keywords.ts +3 -1
- package/src/core/parser/parser.ts +49 -15
- package/src/core/runner/funcs/_base.ts +3 -0
- package/src/core/runner/funcs/functions.ts +46 -0
- package/src/core/runner/funcs/io.ts +38 -0
- package/src/core/runner/funcs/modules.ts +17 -0
- package/src/core/runner/funcs/variables.ts +57 -0
- package/src/core/runner/runner.ts +27 -121
- package/src/core/services/log.service.ts +24 -16
- package/src/shared/context/globalContext.ts +12 -1
- package/src/shared/manager/baseManager.ts +5 -3
- package/src/shared/manager/warn/coreWarnings.ts +2 -2
- package/src/shared/models/func.ts +1 -1
- package/tsconfig.json +3 -3
|
@@ -10,7 +10,7 @@ export interface Log {
|
|
|
10
10
|
level: LogLevel;
|
|
11
11
|
}
|
|
12
12
|
|
|
13
|
-
export interface LoggerConfig {
|
|
13
|
+
export interface LoggerConfig {
|
|
14
14
|
interceptors: {
|
|
15
15
|
onLog: (message: string) => string;
|
|
16
16
|
level: LogLevel;
|
|
@@ -26,52 +26,60 @@ export class LoggerService {
|
|
|
26
26
|
this.config = config;
|
|
27
27
|
}
|
|
28
28
|
|
|
29
|
-
log
|
|
29
|
+
log(message: string, level: LogLevel = LogLevel.Info, printMsg: string = message) {
|
|
30
30
|
this.logs.push({ message, level });
|
|
31
|
-
this.config.interceptors.forEach(interceptor => {
|
|
31
|
+
this.config.interceptors.forEach((interceptor) => {
|
|
32
32
|
if (interceptor.level === level) {
|
|
33
33
|
message = interceptor.onLog(message);
|
|
34
34
|
}
|
|
35
35
|
});
|
|
36
|
-
|
|
37
|
-
console.log(message);
|
|
38
|
-
}
|
|
36
|
+
console.log(printMsg);
|
|
39
37
|
}
|
|
40
38
|
|
|
41
|
-
debug
|
|
39
|
+
debug(message: string) {
|
|
42
40
|
this.log(message, LogLevel.Debug);
|
|
43
41
|
}
|
|
44
42
|
|
|
45
|
-
info
|
|
43
|
+
info(message: string) {
|
|
46
44
|
this.log(message, LogLevel.Info);
|
|
47
45
|
}
|
|
48
46
|
|
|
49
|
-
warning
|
|
47
|
+
warning(message: string) {
|
|
50
48
|
this.log(message, LogLevel.Warning);
|
|
51
49
|
}
|
|
52
50
|
|
|
53
|
-
error
|
|
51
|
+
error(message: string) {
|
|
54
52
|
this.log(message, LogLevel.Error);
|
|
55
53
|
}
|
|
56
54
|
|
|
57
|
-
getLogs
|
|
55
|
+
getLogs() {
|
|
58
56
|
return this.logs;
|
|
59
57
|
}
|
|
60
58
|
|
|
61
|
-
pushInterceptor
|
|
59
|
+
pushInterceptor(interceptor: {
|
|
60
|
+
onLog: (message: string) => string;
|
|
61
|
+
level: LogLevel;
|
|
62
|
+
}) {
|
|
62
63
|
this.config.interceptors.push(interceptor);
|
|
63
64
|
}
|
|
64
65
|
|
|
65
|
-
removeInterceptor
|
|
66
|
-
|
|
66
|
+
removeInterceptor(interceptor: {
|
|
67
|
+
onLog: (message: string) => string;
|
|
68
|
+
level: LogLevel;
|
|
69
|
+
}) {
|
|
70
|
+
this.config.interceptors = this.config.interceptors.filter(
|
|
71
|
+
(i) => i !== interceptor,
|
|
72
|
+
);
|
|
67
73
|
}
|
|
68
74
|
|
|
69
75
|
toString() {
|
|
70
|
-
return this.logs
|
|
76
|
+
return this.logs
|
|
77
|
+
.map((log) => `[${log.level}] ${log.message}`)
|
|
78
|
+
.join("\n");
|
|
71
79
|
}
|
|
72
80
|
}
|
|
73
81
|
|
|
74
82
|
export const defaultLoggerConfig: LoggerConfig = {
|
|
75
83
|
interceptors: [],
|
|
76
84
|
logs: [LogLevel.Debug, LogLevel.Info],
|
|
77
|
-
};
|
|
85
|
+
};
|
|
@@ -1,8 +1,19 @@
|
|
|
1
|
+
import type { LoggerService } from "../../core/services/log.service.js";
|
|
2
|
+
|
|
1
3
|
export interface Context {
|
|
2
4
|
[key: string]: any;
|
|
5
|
+
services: Map<string, any>;
|
|
3
6
|
}
|
|
4
7
|
|
|
5
|
-
let globalContext: Context = {};
|
|
8
|
+
let globalContext: Context = { services: new Map() };
|
|
9
|
+
|
|
10
|
+
export function pushService(service: any, name: string) {
|
|
11
|
+
globalContext.services.set(name, service);
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export function getService(name: string) {
|
|
15
|
+
return globalContext.services.get(name);
|
|
16
|
+
}
|
|
6
17
|
|
|
7
18
|
export function get(key: string) {
|
|
8
19
|
return globalContext[key];
|
|
@@ -7,12 +7,14 @@ export class OcatManager {
|
|
|
7
7
|
public message: string;
|
|
8
8
|
public color: ChalkInstance;
|
|
9
9
|
public level: LogLevel;
|
|
10
|
+
public printFn: (message: string) => void;
|
|
10
11
|
|
|
11
12
|
constructor(name: string, color: ChalkInstance, level: LogLevel) {
|
|
12
13
|
this.name = name;
|
|
13
14
|
this.message = "";
|
|
14
15
|
this.color = color;
|
|
15
16
|
this.level = level;
|
|
17
|
+
this.printFn = console.log;
|
|
16
18
|
}
|
|
17
19
|
|
|
18
20
|
toString(line: number | undefined = undefined): string {
|
|
@@ -31,9 +33,9 @@ export class OcatManager {
|
|
|
31
33
|
}
|
|
32
34
|
|
|
33
35
|
throw(line: number | undefined = undefined): never {
|
|
34
|
-
|
|
35
|
-
const
|
|
36
|
-
log
|
|
36
|
+
const log = ctx.get("services")?.log;
|
|
37
|
+
const message = this.build(line);
|
|
38
|
+
log?.log(message, this.level, this.toString(line));
|
|
37
39
|
process.exit(1);
|
|
38
40
|
}
|
|
39
41
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import chalk from "chalk";
|
|
2
|
-
import { OcatManager } from "../baseManager";
|
|
3
|
-
import { LogLevel } from "../../../core/services/log.service";
|
|
2
|
+
import { OcatManager } from "../baseManager.js";
|
|
3
|
+
import { LogLevel } from "../../../core/services/log.service.js";
|
|
4
4
|
|
|
5
5
|
export class OcatWarning extends OcatManager {
|
|
6
6
|
constructor(name: string) {
|
package/tsconfig.json
CHANGED
|
@@ -3,13 +3,13 @@
|
|
|
3
3
|
// Enable latest features
|
|
4
4
|
"lib": ["ESNext", "DOM"],
|
|
5
5
|
"target": "ESNext",
|
|
6
|
-
|
|
6
|
+
|
|
7
|
+
"module": "nodenext",
|
|
8
|
+
"moduleResolution": "nodenext",
|
|
7
9
|
"moduleDetection": "force",
|
|
8
10
|
"jsx": "react-jsx",
|
|
9
11
|
"allowJs": true,
|
|
10
12
|
|
|
11
|
-
// Bundler mode
|
|
12
|
-
"moduleResolution": "bundler",
|
|
13
13
|
"verbatimModuleSyntax": true,
|
|
14
14
|
|
|
15
15
|
// Best practices
|