diff --git a/.gitignore b/.gitignore
index 49ffcee..8e8a868 100644
--- a/.gitignore
+++ b/.gitignore
@@ -3,3 +3,7 @@
/include
/build
*.tsbuildinfo
+
+# misc
+.DS_Store
+*.pem
\ No newline at end of file
diff --git a/package-lock.json b/package-lock.json
index e227cf5..fbfbd4c 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -9,7 +9,7 @@
"version": "0.1.1",
"license": "ISC",
"dependencies": {
- "@aethergames/mkscribe": "^0.1.0",
+ "@aethergames/mkscribe": "^0.3.0",
"@rbxts/services": "^1.5.1",
"@rbxts/testez": "^0.4.2-ts.0"
},
@@ -28,14 +28,14 @@
}
},
"node_modules/@aethergames/mkscribe": {
- "version": "0.1.0",
- "resolved": "https://registry.npmjs.org/@aethergames/mkscribe/-/mkscribe-0.1.0.tgz",
- "integrity": "sha512-jslOqvv/7a2XYGjihjhlCDtu7DQEvxfVbyj6Hz5jbWYJgisByFC6KxJrtpOC18ln+7DtRo7kF7m3bdovGsNH5g=="
+ "version": "0.3.0",
+ "resolved": "https://registry.npmjs.org/@aethergames/mkscribe/-/mkscribe-0.3.0.tgz",
+ "integrity": "sha512-aL18I6vXOwlKXZI8A/9syFvrRQdjsoweFw089AAtvnTYHOszPYAFUxVqwFVZgLCx4JLs+WcNnU9/aSDgGGsidA=="
},
"node_modules/@eslint/eslintrc": {
- "version": "1.4.1",
- "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.4.1.tgz",
- "integrity": "sha512-XXrH9Uarn0stsyldqDYq8r++mROmWRI1xKMXa640Bb//SY1+ECYX6VzT6Lcx5frD0V30XieqJ0oX9I2Xj5aoMA==",
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.0.0.tgz",
+ "integrity": "sha512-fluIaaV+GyV24CCu/ggiHdV+j4RNh85yQnAYS/G2mZODZgGmmlrgCydjUcV3YvxCm9x8nMAfThsqTni4KiXT4A==",
"dev": true,
"dependencies": {
"ajv": "^6.12.4",
@@ -55,6 +55,15 @@
"url": "https://opencollective.com/eslint"
}
},
+ "node_modules/@eslint/js": {
+ "version": "8.35.0",
+ "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.35.0.tgz",
+ "integrity": "sha512-JXdzbRiWclLVoD8sNUjR443VVlYqiYmDVT6rGUEIEHU5YJW0gaVZwV2xgM7D4arkvASqD0IlLUVjHiFuxaftRw==",
+ "dev": true,
+ "engines": {
+ "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
+ }
+ },
"node_modules/@humanwhocodes/config-array": {
"version": "0.11.8",
"resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.8.tgz",
@@ -152,9 +161,9 @@
"dev": true
},
"node_modules/@types/node": {
- "version": "16.18.12",
- "resolved": "https://registry.npmjs.org/@types/node/-/node-16.18.12.tgz",
- "integrity": "sha512-vzLe5NaNMjIE3mcddFVGlAXN1LEWueUsMsOJWaT6wWMJGyljHAWHznqfnKUQWGzu7TLPrGvWdNAsvQYW+C0xtw==",
+ "version": "16.18.14",
+ "resolved": "https://registry.npmjs.org/@types/node/-/node-16.18.14.tgz",
+ "integrity": "sha512-wvzClDGQXOCVNU4APPopC2KtMYukaF1MN/W3xAmslx22Z4/IF1/izDMekuyoUlwfnDHYCIZGaj7jMwnJKBTxKw==",
"dev": true
},
"node_modules/@types/semver": {
@@ -164,14 +173,14 @@
"dev": true
},
"node_modules/@typescript-eslint/eslint-plugin": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.53.0.tgz",
- "integrity": "sha512-alFpFWNucPLdUOySmXCJpzr6HKC3bu7XooShWM+3w/EL6J2HIoB2PFxpLnq4JauWVk6DiVeNKzQlFEaE+X9sGw==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.54.1.tgz",
+ "integrity": "sha512-a2RQAkosH3d3ZIV08s3DcL/mcGc2M/UC528VkPULFxR9VnVPT8pBu0IyBAJJmVsCmhVfwQX1v6q+QGnmSe1bew==",
"dev": true,
"dependencies": {
- "@typescript-eslint/scope-manager": "5.53.0",
- "@typescript-eslint/type-utils": "5.53.0",
- "@typescript-eslint/utils": "5.53.0",
+ "@typescript-eslint/scope-manager": "5.54.1",
+ "@typescript-eslint/type-utils": "5.54.1",
+ "@typescript-eslint/utils": "5.54.1",
"debug": "^4.3.4",
"grapheme-splitter": "^1.0.4",
"ignore": "^5.2.0",
@@ -198,12 +207,12 @@
}
},
"node_modules/@typescript-eslint/experimental-utils": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-5.53.0.tgz",
- "integrity": "sha512-4SklZEwRn0jqkhtW+pPZpbKFXprwGneBndRM0TGzJu/LWdb9QV2hBgFIVU9AREo02BzqFvyG/ypd+xAW5YGhXw==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-5.54.1.tgz",
+ "integrity": "sha512-oqSc2Gr4TL/2M0XRJ9abA1o3Wf1cFJTNqWq0kjdStIIvgMQGZ3TSaFFJ2Cvy3Fgqi9UfDZ8u5idbACssIIyHaw==",
"dev": true,
"dependencies": {
- "@typescript-eslint/utils": "5.53.0"
+ "@typescript-eslint/utils": "5.54.1"
},
"engines": {
"node": "^12.22.0 || ^14.17.0 || >=16.0.0"
@@ -217,14 +226,14 @@
}
},
"node_modules/@typescript-eslint/parser": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.53.0.tgz",
- "integrity": "sha512-MKBw9i0DLYlmdOb3Oq/526+al20AJZpANdT6Ct9ffxcV8nKCHz63t/S0IhlTFNsBIHJv+GY5SFJ0XfqVeydQrQ==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.54.1.tgz",
+ "integrity": "sha512-8zaIXJp/nG9Ff9vQNh7TI+C3nA6q6iIsGJ4B4L6MhZ7mHnTMR4YP5vp2xydmFXIy8rpyIVbNAG44871LMt6ujg==",
"dev": true,
"dependencies": {
- "@typescript-eslint/scope-manager": "5.53.0",
- "@typescript-eslint/types": "5.53.0",
- "@typescript-eslint/typescript-estree": "5.53.0",
+ "@typescript-eslint/scope-manager": "5.54.1",
+ "@typescript-eslint/types": "5.54.1",
+ "@typescript-eslint/typescript-estree": "5.54.1",
"debug": "^4.3.4"
},
"engines": {
@@ -244,13 +253,13 @@
}
},
"node_modules/@typescript-eslint/scope-manager": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.53.0.tgz",
- "integrity": "sha512-Opy3dqNsp/9kBBeCPhkCNR7fmdSQqA+47r21hr9a14Bx0xnkElEQmhoHga+VoaoQ6uDHjDKmQPIYcUcKJifS7w==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.54.1.tgz",
+ "integrity": "sha512-zWKuGliXxvuxyM71UA/EcPxaviw39dB2504LqAmFDjmkpO8qNLHcmzlh6pbHs1h/7YQ9bnsO8CCcYCSA8sykUg==",
"dev": true,
"dependencies": {
- "@typescript-eslint/types": "5.53.0",
- "@typescript-eslint/visitor-keys": "5.53.0"
+ "@typescript-eslint/types": "5.54.1",
+ "@typescript-eslint/visitor-keys": "5.54.1"
},
"engines": {
"node": "^12.22.0 || ^14.17.0 || >=16.0.0"
@@ -261,13 +270,13 @@
}
},
"node_modules/@typescript-eslint/type-utils": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-5.53.0.tgz",
- "integrity": "sha512-HO2hh0fmtqNLzTAme/KnND5uFNwbsdYhCZghK2SoxGp3Ifn2emv+hi0PBUjzzSh0dstUIFqOj3bp0AwQlK4OWw==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-5.54.1.tgz",
+ "integrity": "sha512-WREHsTz0GqVYLIbzIZYbmUUr95DKEKIXZNH57W3s+4bVnuF1TKe2jH8ZNH8rO1CeMY3U4j4UQeqPNkHMiGem3g==",
"dev": true,
"dependencies": {
- "@typescript-eslint/typescript-estree": "5.53.0",
- "@typescript-eslint/utils": "5.53.0",
+ "@typescript-eslint/typescript-estree": "5.54.1",
+ "@typescript-eslint/utils": "5.54.1",
"debug": "^4.3.4",
"tsutils": "^3.21.0"
},
@@ -288,9 +297,9 @@
}
},
"node_modules/@typescript-eslint/types": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.53.0.tgz",
- "integrity": "sha512-5kcDL9ZUIP756K6+QOAfPkigJmCPHcLN7Zjdz76lQWWDdzfOhZDTj1irs6gPBKiXx5/6O3L0+AvupAut3z7D2A==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.54.1.tgz",
+ "integrity": "sha512-G9+1vVazrfAfbtmCapJX8jRo2E4MDXxgm/IMOF4oGh3kq7XuK3JRkOg6y2Qu1VsTRmWETyTkWt1wxy7X7/yLkw==",
"dev": true,
"engines": {
"node": "^12.22.0 || ^14.17.0 || >=16.0.0"
@@ -301,13 +310,13 @@
}
},
"node_modules/@typescript-eslint/typescript-estree": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.53.0.tgz",
- "integrity": "sha512-eKmipH7QyScpHSkhbptBBYh9v8FxtngLquq292YTEQ1pxVs39yFBlLC1xeIZcPPz1RWGqb7YgERJRGkjw8ZV7w==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.54.1.tgz",
+ "integrity": "sha512-bjK5t+S6ffHnVwA0qRPTZrxKSaFYocwFIkZx5k7pvWfsB1I57pO/0M0Skatzzw1sCkjJ83AfGTL0oFIFiDX3bg==",
"dev": true,
"dependencies": {
- "@typescript-eslint/types": "5.53.0",
- "@typescript-eslint/visitor-keys": "5.53.0",
+ "@typescript-eslint/types": "5.54.1",
+ "@typescript-eslint/visitor-keys": "5.54.1",
"debug": "^4.3.4",
"globby": "^11.1.0",
"is-glob": "^4.0.3",
@@ -328,16 +337,16 @@
}
},
"node_modules/@typescript-eslint/utils": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.53.0.tgz",
- "integrity": "sha512-VUOOtPv27UNWLxFwQK/8+7kvxVC+hPHNsJjzlJyotlaHjLSIgOCKj9I0DBUjwOOA64qjBwx5afAPjksqOxMO0g==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.54.1.tgz",
+ "integrity": "sha512-IY5dyQM8XD1zfDe5X8jegX6r2EVU5o/WJnLu/znLPWCBF7KNGC+adacXnt5jEYS9JixDcoccI6CvE4RCjHMzCQ==",
"dev": true,
"dependencies": {
"@types/json-schema": "^7.0.9",
"@types/semver": "^7.3.12",
- "@typescript-eslint/scope-manager": "5.53.0",
- "@typescript-eslint/types": "5.53.0",
- "@typescript-eslint/typescript-estree": "5.53.0",
+ "@typescript-eslint/scope-manager": "5.54.1",
+ "@typescript-eslint/types": "5.54.1",
+ "@typescript-eslint/typescript-estree": "5.54.1",
"eslint-scope": "^5.1.1",
"eslint-utils": "^3.0.0",
"semver": "^7.3.7"
@@ -354,12 +363,12 @@
}
},
"node_modules/@typescript-eslint/visitor-keys": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.53.0.tgz",
- "integrity": "sha512-JqNLnX3leaHFZEN0gCh81sIvgrp/2GOACZNgO4+Tkf64u51kTpAyWFOY8XHx8XuXr3N2C9zgPPHtcpMg6z1g0w==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.54.1.tgz",
+ "integrity": "sha512-q8iSoHTgwCfgcRJ2l2x+xCbu8nBlRAlsQ33k24Adj8eoVBE0f8dUeI+bAa8F84Mv05UGbAx57g2zrRsYIooqQg==",
"dev": true,
"dependencies": {
- "@typescript-eslint/types": "5.53.0",
+ "@typescript-eslint/types": "5.54.1",
"eslint-visitor-keys": "^3.3.0"
},
"engines": {
@@ -597,12 +606,13 @@
}
},
"node_modules/eslint": {
- "version": "8.34.0",
- "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.34.0.tgz",
- "integrity": "sha512-1Z8iFsucw+7kSqXNZVslXS8Ioa4u2KM7GPwuKtkTFAqZ/cHMcEaR+1+Br0wLlot49cNxIiZk5wp8EAbPcYZxTg==",
+ "version": "8.35.0",
+ "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.35.0.tgz",
+ "integrity": "sha512-BxAf1fVL7w+JLRQhWl2pzGeSiGqbWumV4WNvc9Rhp6tiCtm4oHnyPBSEtMGZwrQgudFQ+otqzWoPB7x+hxoWsw==",
"dev": true,
"dependencies": {
- "@eslint/eslintrc": "^1.4.1",
+ "@eslint/eslintrc": "^2.0.0",
+ "@eslint/js": "8.35.0",
"@humanwhocodes/config-array": "^0.11.8",
"@humanwhocodes/module-importer": "^1.0.1",
"@nodelib/fs.walk": "^1.2.8",
@@ -616,7 +626,7 @@
"eslint-utils": "^3.0.0",
"eslint-visitor-keys": "^3.3.0",
"espree": "^9.4.0",
- "esquery": "^1.4.0",
+ "esquery": "^1.4.2",
"esutils": "^2.0.2",
"fast-deep-equal": "^3.1.3",
"file-entry-cache": "^6.0.1",
@@ -653,9 +663,9 @@
}
},
"node_modules/eslint-config-prettier": {
- "version": "8.6.0",
- "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-8.6.0.tgz",
- "integrity": "sha512-bAF0eLpLVqP5oEVUFKpMA+NnRFICwn9X8B5jrR9FcqnYBuPbqWEjTEspPWMj5ye6czoSLDweCzSo3Ko7gGrZaA==",
+ "version": "8.7.0",
+ "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-8.7.0.tgz",
+ "integrity": "sha512-HHVXLSlVUhMSmyW4ZzEuvjpwqamgmlfkutD53cYXLikh4pt/modINRcCIApJ84czDxM4GZInwUrromsDdTImTA==",
"dev": true,
"bin": {
"eslint-config-prettier": "bin/cli.js"
@@ -788,9 +798,9 @@
}
},
"node_modules/esquery": {
- "version": "1.4.2",
- "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.2.tgz",
- "integrity": "sha512-JVSoLdTlTDkmjFmab7H/9SL9qGSyjElT3myyKp7krqjVFQCDLmj1QFaCLRFBszBKI0XVZaiiXvuPIX3ZwHe1Ng==",
+ "version": "1.5.0",
+ "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz",
+ "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==",
"dev": true,
"dependencies": {
"estraverse": "^5.1.0"
@@ -1764,14 +1774,14 @@
},
"dependencies": {
"@aethergames/mkscribe": {
- "version": "0.1.0",
- "resolved": "https://registry.npmjs.org/@aethergames/mkscribe/-/mkscribe-0.1.0.tgz",
- "integrity": "sha512-jslOqvv/7a2XYGjihjhlCDtu7DQEvxfVbyj6Hz5jbWYJgisByFC6KxJrtpOC18ln+7DtRo7kF7m3bdovGsNH5g=="
+ "version": "0.3.0",
+ "resolved": "https://registry.npmjs.org/@aethergames/mkscribe/-/mkscribe-0.3.0.tgz",
+ "integrity": "sha512-aL18I6vXOwlKXZI8A/9syFvrRQdjsoweFw089AAtvnTYHOszPYAFUxVqwFVZgLCx4JLs+WcNnU9/aSDgGGsidA=="
},
"@eslint/eslintrc": {
- "version": "1.4.1",
- "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.4.1.tgz",
- "integrity": "sha512-XXrH9Uarn0stsyldqDYq8r++mROmWRI1xKMXa640Bb//SY1+ECYX6VzT6Lcx5frD0V30XieqJ0oX9I2Xj5aoMA==",
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.0.0.tgz",
+ "integrity": "sha512-fluIaaV+GyV24CCu/ggiHdV+j4RNh85yQnAYS/G2mZODZgGmmlrgCydjUcV3YvxCm9x8nMAfThsqTni4KiXT4A==",
"dev": true,
"requires": {
"ajv": "^6.12.4",
@@ -1785,6 +1795,12 @@
"strip-json-comments": "^3.1.1"
}
},
+ "@eslint/js": {
+ "version": "8.35.0",
+ "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.35.0.tgz",
+ "integrity": "sha512-JXdzbRiWclLVoD8sNUjR443VVlYqiYmDVT6rGUEIEHU5YJW0gaVZwV2xgM7D4arkvASqD0IlLUVjHiFuxaftRw==",
+ "dev": true
+ },
"@humanwhocodes/config-array": {
"version": "0.11.8",
"resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.8.tgz",
@@ -1863,9 +1879,9 @@
"dev": true
},
"@types/node": {
- "version": "16.18.12",
- "resolved": "https://registry.npmjs.org/@types/node/-/node-16.18.12.tgz",
- "integrity": "sha512-vzLe5NaNMjIE3mcddFVGlAXN1LEWueUsMsOJWaT6wWMJGyljHAWHznqfnKUQWGzu7TLPrGvWdNAsvQYW+C0xtw==",
+ "version": "16.18.14",
+ "resolved": "https://registry.npmjs.org/@types/node/-/node-16.18.14.tgz",
+ "integrity": "sha512-wvzClDGQXOCVNU4APPopC2KtMYukaF1MN/W3xAmslx22Z4/IF1/izDMekuyoUlwfnDHYCIZGaj7jMwnJKBTxKw==",
"dev": true
},
"@types/semver": {
@@ -1875,14 +1891,14 @@
"dev": true
},
"@typescript-eslint/eslint-plugin": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.53.0.tgz",
- "integrity": "sha512-alFpFWNucPLdUOySmXCJpzr6HKC3bu7XooShWM+3w/EL6J2HIoB2PFxpLnq4JauWVk6DiVeNKzQlFEaE+X9sGw==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.54.1.tgz",
+ "integrity": "sha512-a2RQAkosH3d3ZIV08s3DcL/mcGc2M/UC528VkPULFxR9VnVPT8pBu0IyBAJJmVsCmhVfwQX1v6q+QGnmSe1bew==",
"dev": true,
"requires": {
- "@typescript-eslint/scope-manager": "5.53.0",
- "@typescript-eslint/type-utils": "5.53.0",
- "@typescript-eslint/utils": "5.53.0",
+ "@typescript-eslint/scope-manager": "5.54.1",
+ "@typescript-eslint/type-utils": "5.54.1",
+ "@typescript-eslint/utils": "5.54.1",
"debug": "^4.3.4",
"grapheme-splitter": "^1.0.4",
"ignore": "^5.2.0",
@@ -1893,62 +1909,62 @@
}
},
"@typescript-eslint/experimental-utils": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-5.53.0.tgz",
- "integrity": "sha512-4SklZEwRn0jqkhtW+pPZpbKFXprwGneBndRM0TGzJu/LWdb9QV2hBgFIVU9AREo02BzqFvyG/ypd+xAW5YGhXw==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-5.54.1.tgz",
+ "integrity": "sha512-oqSc2Gr4TL/2M0XRJ9abA1o3Wf1cFJTNqWq0kjdStIIvgMQGZ3TSaFFJ2Cvy3Fgqi9UfDZ8u5idbACssIIyHaw==",
"dev": true,
"requires": {
- "@typescript-eslint/utils": "5.53.0"
+ "@typescript-eslint/utils": "5.54.1"
}
},
"@typescript-eslint/parser": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.53.0.tgz",
- "integrity": "sha512-MKBw9i0DLYlmdOb3Oq/526+al20AJZpANdT6Ct9ffxcV8nKCHz63t/S0IhlTFNsBIHJv+GY5SFJ0XfqVeydQrQ==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.54.1.tgz",
+ "integrity": "sha512-8zaIXJp/nG9Ff9vQNh7TI+C3nA6q6iIsGJ4B4L6MhZ7mHnTMR4YP5vp2xydmFXIy8rpyIVbNAG44871LMt6ujg==",
"dev": true,
"requires": {
- "@typescript-eslint/scope-manager": "5.53.0",
- "@typescript-eslint/types": "5.53.0",
- "@typescript-eslint/typescript-estree": "5.53.0",
+ "@typescript-eslint/scope-manager": "5.54.1",
+ "@typescript-eslint/types": "5.54.1",
+ "@typescript-eslint/typescript-estree": "5.54.1",
"debug": "^4.3.4"
}
},
"@typescript-eslint/scope-manager": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.53.0.tgz",
- "integrity": "sha512-Opy3dqNsp/9kBBeCPhkCNR7fmdSQqA+47r21hr9a14Bx0xnkElEQmhoHga+VoaoQ6uDHjDKmQPIYcUcKJifS7w==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.54.1.tgz",
+ "integrity": "sha512-zWKuGliXxvuxyM71UA/EcPxaviw39dB2504LqAmFDjmkpO8qNLHcmzlh6pbHs1h/7YQ9bnsO8CCcYCSA8sykUg==",
"dev": true,
"requires": {
- "@typescript-eslint/types": "5.53.0",
- "@typescript-eslint/visitor-keys": "5.53.0"
+ "@typescript-eslint/types": "5.54.1",
+ "@typescript-eslint/visitor-keys": "5.54.1"
}
},
"@typescript-eslint/type-utils": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-5.53.0.tgz",
- "integrity": "sha512-HO2hh0fmtqNLzTAme/KnND5uFNwbsdYhCZghK2SoxGp3Ifn2emv+hi0PBUjzzSh0dstUIFqOj3bp0AwQlK4OWw==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-5.54.1.tgz",
+ "integrity": "sha512-WREHsTz0GqVYLIbzIZYbmUUr95DKEKIXZNH57W3s+4bVnuF1TKe2jH8ZNH8rO1CeMY3U4j4UQeqPNkHMiGem3g==",
"dev": true,
"requires": {
- "@typescript-eslint/typescript-estree": "5.53.0",
- "@typescript-eslint/utils": "5.53.0",
+ "@typescript-eslint/typescript-estree": "5.54.1",
+ "@typescript-eslint/utils": "5.54.1",
"debug": "^4.3.4",
"tsutils": "^3.21.0"
}
},
"@typescript-eslint/types": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.53.0.tgz",
- "integrity": "sha512-5kcDL9ZUIP756K6+QOAfPkigJmCPHcLN7Zjdz76lQWWDdzfOhZDTj1irs6gPBKiXx5/6O3L0+AvupAut3z7D2A==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.54.1.tgz",
+ "integrity": "sha512-G9+1vVazrfAfbtmCapJX8jRo2E4MDXxgm/IMOF4oGh3kq7XuK3JRkOg6y2Qu1VsTRmWETyTkWt1wxy7X7/yLkw==",
"dev": true
},
"@typescript-eslint/typescript-estree": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.53.0.tgz",
- "integrity": "sha512-eKmipH7QyScpHSkhbptBBYh9v8FxtngLquq292YTEQ1pxVs39yFBlLC1xeIZcPPz1RWGqb7YgERJRGkjw8ZV7w==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.54.1.tgz",
+ "integrity": "sha512-bjK5t+S6ffHnVwA0qRPTZrxKSaFYocwFIkZx5k7pvWfsB1I57pO/0M0Skatzzw1sCkjJ83AfGTL0oFIFiDX3bg==",
"dev": true,
"requires": {
- "@typescript-eslint/types": "5.53.0",
- "@typescript-eslint/visitor-keys": "5.53.0",
+ "@typescript-eslint/types": "5.54.1",
+ "@typescript-eslint/visitor-keys": "5.54.1",
"debug": "^4.3.4",
"globby": "^11.1.0",
"is-glob": "^4.0.3",
@@ -1957,28 +1973,28 @@
}
},
"@typescript-eslint/utils": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.53.0.tgz",
- "integrity": "sha512-VUOOtPv27UNWLxFwQK/8+7kvxVC+hPHNsJjzlJyotlaHjLSIgOCKj9I0DBUjwOOA64qjBwx5afAPjksqOxMO0g==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.54.1.tgz",
+ "integrity": "sha512-IY5dyQM8XD1zfDe5X8jegX6r2EVU5o/WJnLu/znLPWCBF7KNGC+adacXnt5jEYS9JixDcoccI6CvE4RCjHMzCQ==",
"dev": true,
"requires": {
"@types/json-schema": "^7.0.9",
"@types/semver": "^7.3.12",
- "@typescript-eslint/scope-manager": "5.53.0",
- "@typescript-eslint/types": "5.53.0",
- "@typescript-eslint/typescript-estree": "5.53.0",
+ "@typescript-eslint/scope-manager": "5.54.1",
+ "@typescript-eslint/types": "5.54.1",
+ "@typescript-eslint/typescript-estree": "5.54.1",
"eslint-scope": "^5.1.1",
"eslint-utils": "^3.0.0",
"semver": "^7.3.7"
}
},
"@typescript-eslint/visitor-keys": {
- "version": "5.53.0",
- "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.53.0.tgz",
- "integrity": "sha512-JqNLnX3leaHFZEN0gCh81sIvgrp/2GOACZNgO4+Tkf64u51kTpAyWFOY8XHx8XuXr3N2C9zgPPHtcpMg6z1g0w==",
+ "version": "5.54.1",
+ "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.54.1.tgz",
+ "integrity": "sha512-q8iSoHTgwCfgcRJ2l2x+xCbu8nBlRAlsQ33k24Adj8eoVBE0f8dUeI+bAa8F84Mv05UGbAx57g2zrRsYIooqQg==",
"dev": true,
"requires": {
- "@typescript-eslint/types": "5.53.0",
+ "@typescript-eslint/types": "5.54.1",
"eslint-visitor-keys": "^3.3.0"
}
},
@@ -2147,12 +2163,13 @@
"dev": true
},
"eslint": {
- "version": "8.34.0",
- "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.34.0.tgz",
- "integrity": "sha512-1Z8iFsucw+7kSqXNZVslXS8Ioa4u2KM7GPwuKtkTFAqZ/cHMcEaR+1+Br0wLlot49cNxIiZk5wp8EAbPcYZxTg==",
+ "version": "8.35.0",
+ "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.35.0.tgz",
+ "integrity": "sha512-BxAf1fVL7w+JLRQhWl2pzGeSiGqbWumV4WNvc9Rhp6tiCtm4oHnyPBSEtMGZwrQgudFQ+otqzWoPB7x+hxoWsw==",
"dev": true,
"requires": {
- "@eslint/eslintrc": "^1.4.1",
+ "@eslint/eslintrc": "^2.0.0",
+ "@eslint/js": "8.35.0",
"@humanwhocodes/config-array": "^0.11.8",
"@humanwhocodes/module-importer": "^1.0.1",
"@nodelib/fs.walk": "^1.2.8",
@@ -2166,7 +2183,7 @@
"eslint-utils": "^3.0.0",
"eslint-visitor-keys": "^3.3.0",
"espree": "^9.4.0",
- "esquery": "^1.4.0",
+ "esquery": "^1.4.2",
"esutils": "^2.0.2",
"fast-deep-equal": "^3.1.3",
"file-entry-cache": "^6.0.1",
@@ -2212,9 +2229,9 @@
}
},
"eslint-config-prettier": {
- "version": "8.6.0",
- "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-8.6.0.tgz",
- "integrity": "sha512-bAF0eLpLVqP5oEVUFKpMA+NnRFICwn9X8B5jrR9FcqnYBuPbqWEjTEspPWMj5ye6czoSLDweCzSo3Ko7gGrZaA==",
+ "version": "8.7.0",
+ "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-8.7.0.tgz",
+ "integrity": "sha512-HHVXLSlVUhMSmyW4ZzEuvjpwqamgmlfkutD53cYXLikh4pt/modINRcCIApJ84czDxM4GZInwUrromsDdTImTA==",
"dev": true,
"requires": {}
},
@@ -2283,9 +2300,9 @@
}
},
"esquery": {
- "version": "1.4.2",
- "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.2.tgz",
- "integrity": "sha512-JVSoLdTlTDkmjFmab7H/9SL9qGSyjElT3myyKp7krqjVFQCDLmj1QFaCLRFBszBKI0XVZaiiXvuPIX3ZwHe1Ng==",
+ "version": "1.5.0",
+ "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz",
+ "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==",
"dev": true,
"requires": {
"estraverse": "^5.1.0"
diff --git a/package.json b/package.json
index 1b06fc1..c55a767 100644
--- a/package.json
+++ b/package.json
@@ -10,7 +10,7 @@
"test:watch": "rbxtsc -w --verbose --type game --rojo test.project.json",
"test:serve": "rojo serve ./test.project.json",
"test:rojo": "mkdir build & npm run test:build && rojo build -o ./build/test.rbxlx test.project.json",
- "test:run": "npm run prepublish && npm run test:serve",
+ "test:run": "npm run test:build && npm run test:serve",
"prepublish": "npm run build && mkdir build && npm pack --pack-destination=build",
"test": "npm run test:run"
},
@@ -43,7 +43,7 @@
"typescript": "^4.9.5"
},
"dependencies": {
- "@aethergames/mkscribe": "^0.1.0",
+ "@aethergames/mkscribe": "^0.3.0",
"@rbxts/services": "^1.5.1",
"@rbxts/testez": "^0.4.2-ts.0"
}
diff --git a/src/ast-interpreter/index.ts b/src/ast-interpreter/index.ts
deleted file mode 100644
index c62ecf5..0000000
--- a/src/ast-interpreter/index.ts
+++ /dev/null
@@ -1,78 +0,0 @@
-import { MkScribe } from "@aethergames/mkscribe";
-import { ScribeEnviroment } from "../types";
-import {
- DialogCallbackInput,
- PipeToCallbackInput,
- ScribeProgramProperties,
- ScribeRuntimeImplementation,
-} from "./types";
-import { TokenLiteral } from "@aethergames/mkscribe/out/mkscribe/scanner/types";
-import { ScribeVisitor, StatusInterpretationCode } from "./visitor";
-
-export class Runtime implements ScribeRuntimeImplementation {
- public dialogCallback!: (input: DialogCallbackInput) => void;
- public pipeTo!: (config: PipeToCallbackInput) => void;
-
- private interpreter!: ScribeVisitor;
-
- constructor(private readonly source: string, private readonly env: ScribeEnviroment) {}
-
- public start(): StatusInterpretationCode {
- this.interpreter = new ScribeVisitor(
- MkScribe.build(this.source),
- {
- dialog: this.dialogCallback,
- storeChange: this.pipeTo,
- },
- this.env,
- );
-
- return this.interpreter.interpret();
- }
-
- public getObjective(objective: string): TokenLiteral {
- return this.interpreter.records.objectives[objective];
- }
-
- public getProperty(property: string): TokenLiteral {
- return this.interpreter.programProperties[property];
- }
-
- public getProperties(): ScribeProgramProperties {
- return this.interpreter.programProperties;
- }
-
- public incrementStore(valueTo: string, increment: number): void {
- let head = this.interpreter.refs[valueTo];
-
- while (head !== undefined) {
- const { ref } = head;
-
- if (typeOf(this.interpreter.records.stores[ref][0]) === "number") {
- (this.interpreter.records.stores[ref][0] as number) += increment;
- } else {
- warn(`[Interpreter:incrementValue]: ${ref} isn't of type number, it can't be incremented.`);
- }
-
- head = head._next;
- }
- }
-
- public setStore(valueTo: string, value: unknown): void {
- let head = this.interpreter.refs[valueTo];
-
- while (head !== undefined) {
- this.interpreter.records.stores[head.ref][0] = value as TokenLiteral;
-
- head = head._next;
- }
- }
-
- public setCurrentObjective(objective: string): void {}
-
- public play(scene: string): void {}
-
- public interact(id: string): void {
- return this.interpreter.records.interactions[id].accept(this.interpreter);
- }
-}
diff --git a/src/index.spec.ts b/src/index.spec.ts
index fb89f3b..e36834d 100644
--- a/src/index.spec.ts
+++ b/src/index.spec.ts
@@ -1 +1,39 @@
-export = (): void => {}
\ No newline at end of file
+///
+
+import { Scribe } from "."
+
+export = (): void => {
+ describe("creating a new ScribeRuntime", () => {
+ const ScribeRuntime = Scribe.load(`
+ actor BEATRIZ "beatriz_id"
+
+ default objective hello "My objective!"
+
+ echo $test
+
+ interact BEATRIZ {
+ echo "Interacted with Beatriz!"
+ }
+
+ `, {
+ test: "Hello, world!"
+ })
+
+ it("should not throw when instantiating a new ScribeRuntime.", () => {
+ expect(() => Scribe.load("", {})).never.to.throw()
+ })
+
+ it("should not throw when retrieving an objective.", () => {
+ expect(() => {
+ ScribeRuntime.getCurrentObjective()
+ ScribeRuntime.getObjective("hello")
+ }).never.to.throw()
+ })
+
+ it("should interact correctly with the actor", () => {
+ expect(() => {
+ ScribeRuntime.interact("beatriz_id")
+ }).never.to.throw()
+ })
+ })
+}
\ No newline at end of file
diff --git a/src/index.ts b/src/index.ts
index 15dc78c..209d4cd 100644
--- a/src/index.ts
+++ b/src/index.ts
@@ -1,13 +1,8 @@
-import { Runtime } from "./ast-interpreter";
-import { ExecutionType, ModuleSource, ScribeEnviroment, StringSource, StringValueSource } from "./types";
-import { ScribeVM } from "./vm";
+import { Runtime } from "./runtime";
+import { ModuleSource, ScribeEnviroment, StringSource, StringValueSource } from "./types";
export namespace Scribe {
- export function load(
- file: string | StringValue | ModuleScript,
- env: ScribeEnviroment,
- executionType: T,
- ): T extends "ast-interpreter" ? Runtime : ScribeVM {
+ export function load(file: string | StringValue | ModuleScript, env: ScribeEnviroment): Runtime {
const toRetrieveFrom = typeOf(file);
let source!: string;
@@ -29,6 +24,6 @@ export namespace Scribe {
}
}
- return (executionType === "ast-interpreter" ? new Runtime(source, env) : new ScribeVM(source, env)) as never;
+ return new Runtime(source, env);
}
}
diff --git a/src/runtime/index.ts b/src/runtime/index.ts
new file mode 100644
index 0000000..5d0563f
--- /dev/null
+++ b/src/runtime/index.ts
@@ -0,0 +1,158 @@
+import { MkScribe } from "@aethergames/mkscribe";
+import { ScribeEnviroment } from "../types";
+import {
+ DialogCallbackInput,
+ InteractionJob,
+ Objective,
+ ObjectiveChangeCallbackInput,
+ PipeToCallbackInput,
+ ScribeProgramProperties,
+ ScribeRuntimeImplementation,
+} from "./types";
+import { TokenLiteral } from "@aethergames/mkscribe/out/mkscribe/scanner/types";
+import { ScribeVisitor, StatusInterpretationCode } from "./visitor";
+import { RunService } from "@rbxts/services";
+
+export class Runtime implements ScribeRuntimeImplementation {
+ public dialogCallback!: (input: DialogCallbackInput) => void;
+ public objectiveChangeCallback!: (input: ObjectiveChangeCallbackInput) => void;
+ public pipeTo!: (config: PipeToCallbackInput) => void;
+
+ private interpreter!: ScribeVisitor;
+
+ private interactions: Map = new Map();
+ private interactionsCooldown = 1 / 60;
+
+ constructor(private readonly source: string, private readonly env: ScribeEnviroment) {}
+
+ public start(): StatusInterpretationCode {
+ this.interpreter = new ScribeVisitor(
+ MkScribe.build(this.source),
+ {
+ onDialog: this.dialogCallback,
+ onStoreChange: this.pipeTo,
+ onObjectiveChange: this.objectiveChangeCallback,
+ },
+ this.env,
+ );
+
+ return this.interpreter.interpret();
+ }
+
+ public getObjective(objective: string): Objective | undefined {
+ return this.interpreter.records.objectives[objective];
+ }
+
+ public getCurrentObjective(): Objective | undefined {
+ const current = this.interpreter.records.objectives.current;
+
+ if (current !== undefined) {
+ return this.interpreter.records.objectives[current];
+ }
+ }
+
+ public getProperty(property: string): TokenLiteral {
+ return this.interpreter.programProperties[property];
+ }
+
+ public getProperties(): ScribeProgramProperties {
+ return this.interpreter.programProperties;
+ }
+
+ public incrementStore(valueTo: string, increment: number): void {
+ let head = this.interpreter.refs[valueTo];
+
+ while (head !== undefined) {
+ const { ref } = head;
+
+ if (typeOf(this.interpreter.records.stores[ref][0]) === "number") {
+ (this.interpreter.records.stores[ref][0] as number) += increment;
+ } else {
+ warn(`[Interpreter:incrementValue]: ${ref} isn't of type number, it can't be incremented.`);
+ }
+
+ head = head._next;
+ }
+ }
+
+ public setStore(valueTo: string, value: unknown): void {
+ let head = this.interpreter.refs[valueTo];
+
+ while (head !== undefined) {
+ this.interpreter.records.stores[head.ref][0] = value as TokenLiteral;
+
+ head = head._next;
+ }
+ }
+
+ public setCurrentObjective(objective: string): void {
+ this.interpreter.records.objectives.current = objective;
+ }
+
+ public play(id: string): void {
+ const scene = this.interpreter.records.scenes[id];
+
+ if (scene !== undefined) {
+ this.interpreter.resolve(this.interpreter.records.scenes[id]);
+ } else {
+ throw `Scene specified [${id}] isn't defined on the Scribe's program.`;
+ }
+ }
+
+ public async interact(id: string): Promise {
+ if (this.interactions.has(id) === false) {
+ this.interactions.set(id, {
+ cleanup: undefined,
+ lastInteraction: 0,
+ queue: new Array(),
+ });
+ }
+
+ // eslint-disable-next-line prefer-const
+ let { cleanup, lastInteraction, queue } = this.interactions.get(id)!;
+
+ if (cleanup !== undefined) {
+ cleanup.Disconnect();
+ }
+
+ const interaction = this.interpreter.records.interactions[id];
+ if (os.clock() - lastInteraction > this.interactionsCooldown && queue.size() === 0) {
+ lastInteraction = os.clock();
+
+ return this.interpreter.resolve(interaction);
+ } else {
+ queue.push(interaction);
+
+ // eslint-disable-next-line no-constant-condition
+ while (true) {
+ if (os.clock() - lastInteraction > this.interactionsCooldown && queue[1] === interaction) {
+ this.clean(id);
+
+ return this.interpreter.resolve(interaction);
+ } else {
+ task.wait();
+ }
+ }
+ }
+ }
+
+ private clean(id: string): void {
+ const interactionJob = this.interactions.get(id);
+
+ if (interactionJob !== undefined) {
+ const { cleanup, lastInteraction, queue } = interactionJob;
+
+ if (cleanup !== undefined) {
+ interactionJob.cleanup = RunService.PostSimulation.Connect(() => {
+ if (os.clock() - lastInteraction > this.interactionsCooldown && queue.size() === 0) {
+ if (this.interactions.has(id)) {
+ this.interactions.delete(id);
+ }
+
+ cleanup.Disconnect();
+ }
+ });
+ }
+ }
+ }
+}
diff --git a/src/ast-interpreter/types.d.ts b/src/runtime/types.d.ts
similarity index 81%
rename from src/ast-interpreter/types.d.ts
rename to src/runtime/types.d.ts
index 55c8608..f6ffaaf 100644
--- a/src/ast-interpreter/types.d.ts
+++ b/src/runtime/types.d.ts
@@ -2,7 +2,20 @@ import { Statement } from "@aethergames/mkscribe";
import { TokenLiteral } from "@aethergames/mkscribe/out/mkscribe/scanner/types";
import { StatusInterpretationCode } from "./visitor";
-declare type ScribeProperties = "title" | "description";
+export declare type InteractionJob = {
+ cleanup: RBXScriptConnection | undefined;
+ lastInteraction: number;
+ queue: Array;
+};
+
+export declare type ScribeProperties = "title" | "description";
+
+export declare type Objective = {
+ id: number;
+ name: string;
+ desc: string;
+ active: boolean;
+};
export declare type ScribeProgramProperties = Record;
@@ -23,6 +36,11 @@ export declare type DialogCallbackInput = {
step: (id?: number) => void;
};
+export declare type ObjectiveChangeCallbackInput = {
+ id: string;
+ description: string;
+};
+
export declare type PipeToCallbackInput = {
identifier: string;
data: unknown;
@@ -52,6 +70,13 @@ export interface ScribeRuntimeImplementation {
*/
start(): StatusInterpretationCode;
+ getObjective(objective: string): Objective | undefined;
+
+ /**
+ *
+ */
+ getCurrentObjective(): Objective | undefined;
+
/**
* Retrieve's a property's value.
*
diff --git a/src/ast-interpreter/utils/index.ts b/src/runtime/utils/index.ts
similarity index 100%
rename from src/ast-interpreter/utils/index.ts
rename to src/runtime/utils/index.ts
diff --git a/src/ast-interpreter/utils/types.d.ts b/src/runtime/utils/types.d.ts
similarity index 100%
rename from src/ast-interpreter/utils/types.d.ts
rename to src/runtime/utils/types.d.ts
diff --git a/src/ast-interpreter/visitor/index.ts b/src/runtime/visitor/index.ts
similarity index 91%
rename from src/ast-interpreter/visitor/index.ts
rename to src/runtime/visitor/index.ts
index bf4ebe3..f968b9b 100644
--- a/src/ast-interpreter/visitor/index.ts
+++ b/src/runtime/visitor/index.ts
@@ -31,7 +31,13 @@ import {
} from "@aethergames/mkscribe/out/mkscribe/ast/types";
import { TokenLiteral } from "@aethergames/mkscribe/out/mkscribe/scanner/types";
import { ScribeEnviroment } from "../../types";
-import { DialogCallbackInput, OptionStructure, PipeToCallbackInput } from "../types";
+import {
+ DialogCallbackInput,
+ Objective,
+ ObjectiveChangeCallbackInput,
+ OptionStructure,
+ PipeToCallbackInput,
+} from "../types";
import { EventListener } from "../utils";
import { Interpreter, RefNode } from "./types";
@@ -46,12 +52,14 @@ export class ScribeVisitor implements Interpreter {
public refs: Record;
public records: {
+ objectivesCurrentId: 0;
+
actors: Record;
stores: Record]>;
objectives: {
- current?: TokenLiteral;
- } & { [x: string]: TokenLiteral };
+ current?: string;
+ } & { [x: string]: Objective };
scenes: Record;
interactions: Record;
@@ -68,8 +76,9 @@ export class ScribeVisitor implements Interpreter {
constructor(
private readonly ast: Array,
private readonly callbacks: {
- dialog: (input: DialogCallbackInput) => void;
- storeChange: (config: PipeToCallbackInput) => void;
+ onDialog: (input: DialogCallbackInput) => void;
+ onStoreChange: (config: PipeToCallbackInput) => void;
+ onObjectiveChange: (input: ObjectiveChangeCallbackInput) => void;
},
private env: ScribeEnviroment,
) {
@@ -77,6 +86,8 @@ export class ScribeVisitor implements Interpreter {
this.refs = {};
this.records = {
+ objectivesCurrentId: 0,
+
actors: {},
stores: {},
objectives: {},
@@ -267,7 +278,7 @@ export class ScribeVisitor implements Interpreter {
}
}
- public visitEnviromentAccessor(expr: EnvironmentAccessor): TokenLiteral {
+ public visitEnvironmentAccessor(expr: EnvironmentAccessor): TokenLiteral {
const lexeme = expr.name.literal as string;
return this.env[lexeme.sub(2, lexeme.size())] as TokenLiteral;
}
@@ -305,6 +316,10 @@ export class ScribeVisitor implements Interpreter {
if (identifier in this.records.objectives) {
this.records.objectives.current = identifier;
+ this.callbacks.onObjectiveChange({
+ id: identifier,
+ description: this.records.objectives[identifier].desc,
+ });
} else {
this.resolve(this.records.scenes[identifier]);
}
@@ -337,13 +352,18 @@ export class ScribeVisitor implements Interpreter {
const objective = stmt.name.lexeme as string;
const objectiveDesc = this.evaluate(stmt.value);
- this.records.objectives[objective] = objectiveDesc;
-
if (isDefault && this.records.objectives.current === undefined) {
this.records.objectives.current = objective;
- } else {
+ } else if (isDefault && this.records.objectives.current !== undefined) {
throw `Another objective is already a default one, make sure to not override or have multiple default objectives. ${stmt.name.start}:${stmt.name.end}`;
}
+
+ this.records.objectives[objective] = {
+ id: ++this.records.objectivesCurrentId,
+ name: objective,
+ desc: objectiveDesc as string,
+ active: objective === this.records.objectives.current!,
+ };
}
public visitStoreStatement(stmt: StoreStatement): void {
@@ -386,7 +406,7 @@ export class ScribeVisitor implements Interpreter {
}
this.records.stores[ref][0] = refValue;
- this.callbacks.storeChange?.({ identifier: ref, data: refValue, metadata: metadata as never });
+ this.callbacks.onStoreChange?.({ identifier: ref, data: refValue, metadata: metadata as never });
this.tracker.event.notify(ref);
}
@@ -414,7 +434,7 @@ export class ScribeVisitor implements Interpreter {
}
task.spawn(() => {
- this.callbacks.dialog?.({
+ this.callbacks.onDialog?.({
characterIdentifier,
text,
metadata,
@@ -514,8 +534,9 @@ export class ScribeVisitor implements Interpreter {
public visitInteractStatement(stmt: InteractStatement): void {
const ref = stmt.identifier.lexeme as string;
const refValue = stmt.body;
+ const actor = this.records.actors[ref];
- this.records.interactions[ref] = refValue;
+ this.records.interactions[actor as string] = refValue;
}
public visitEchoStatement(stmt: EchoStatement): void {
diff --git a/src/ast-interpreter/visitor/types.d.ts b/src/runtime/visitor/types.d.ts
similarity index 100%
rename from src/ast-interpreter/visitor/types.d.ts
rename to src/runtime/visitor/types.d.ts
diff --git a/src/vm/chunk/index.ts b/src/vm/chunk/index.ts
deleted file mode 100644
index f486c1b..0000000
--- a/src/vm/chunk/index.ts
+++ /dev/null
@@ -1,49 +0,0 @@
-import { FREE_ARRAY } from "../memory";
-import { int, uint8 } from "../types";
-import { buildValueArray, freeValueArray, writeValueArray } from "../value";
-import { Value } from "../value/types";
-import { Chunk } from "./types";
-
-/**
- * Used to create a Chunk.
- *
- * @param chunk a Chunk
- */
-export function buildChunk(): Chunk {
- return {
- code: table.create(8),
- constants: buildValueArray(),
- };
-}
-
-/**
- * Used to free a Chunk's memory.
- *
- * @param chunk a Chunk
- */
-export function freeChunk(chunk: Chunk): void {
- FREE_ARRAY(chunk.code);
- freeValueArray(chunk.constants);
-}
-
-/**
- * Used to write/insert data to a Chunk's code.
- *
- * @param chunk a Chunk
- * @param byte a byte of data
- */
-export function writeChunk(chunk: Chunk, byte: uint8): void {
- chunk.code.push(byte);
-}
-
-/**
- * Used to store/add constants to the ValueArray.
- *
- * @param chunk a Chunk
- * @param value a valid Value type
- */
-export function addConstant(chunk: Chunk, value: Value): int {
- writeValueArray(chunk.constants, value);
-
- return chunk.constants.values.size() - 1;
-}
diff --git a/src/vm/chunk/types.d.ts b/src/vm/chunk/types.d.ts
deleted file mode 100644
index fa04add..0000000
--- a/src/vm/chunk/types.d.ts
+++ /dev/null
@@ -1,7 +0,0 @@
-import { uint8_t } from "../types";
-import { ValueArray } from "../value/types";
-
-export declare interface Chunk {
- code: uint8_t;
- constants: ValueArray;
-}
diff --git a/src/vm/debug/index.ts b/src/vm/debug/index.ts
deleted file mode 100644
index 4810b10..0000000
--- a/src/vm/debug/index.ts
+++ /dev/null
@@ -1,35 +0,0 @@
-import { Chunk } from "../chunk/types";
-import { OpCode } from "../op_codes";
-import { int, uint8 } from "../types";
-
-function formatInstruction(name: string, offset: int): int {
- print(`| ${"%04d".format(offset)} ${name}\n`);
-
- return offset + 1;
-}
-
-function disasembleInstruction(chunk: Chunk, offset: int): int {
- const instruction: uint8 = chunk.code[offset];
-
- switch (instruction) {
- case OpCode.OP_RETURN: {
- return formatInstruction("OP_RETURN", offset);
- }
-
- case OpCode.OP_ADD: {
- return formatInstruction("OP_ADD", offset);
- }
-
- default: {
- return offset + 1;
- }
- }
-}
-
-export function disassembleChunk(chunk: Chunk, name: string): void {
- print(`Disassembling ${name}\n`);
-
- for (let offset = 0; offset < chunk.code.size(); ) {
- offset = disasembleInstruction(chunk, offset);
- }
-}
diff --git a/src/vm/debug/types.d.ts b/src/vm/debug/types.d.ts
deleted file mode 100644
index ca4eb38..0000000
--- a/src/vm/debug/types.d.ts
+++ /dev/null
@@ -1,5 +0,0 @@
-import { Chunk } from "../chunk/types";
-import { int } from "../types";
-
-declare function disassembleChunk(chunk: Chunk, name: string): void;
-declare function disasembleInstruction(chunk: Chunk, offset: int): void;
diff --git a/src/vm/index.ts b/src/vm/index.ts
deleted file mode 100644
index ae26440..0000000
--- a/src/vm/index.ts
+++ /dev/null
@@ -1,57 +0,0 @@
-import { ScribeEnviroment } from "../types";
-import { Chunk } from "./chunk/types";
-import { OpCode } from "./op_codes";
-import { uint8 } from "./types";
-import { Value } from "./value/types";
-
-enum InterpreterStatusCode {
- SUCCESS,
- ERROR,
- RUNTIME_ERROR,
-}
-
-export class ScribeVM {
- private chunk!: Chunk;
- private ip: uint8 = 0;
-
- // public status_code: InterpreterStatusCode;
-
- constructor(private readonly source: string, env: ScribeEnviroment) {
- // this.status_code = this.interpret();
- }
-
- public interpret(chunk: Chunk): InterpreterStatusCode {
- this.chunk = chunk;
-
- for (;;) {
- let instruction: uint8;
-
- switch ((instruction = this.read_byte())) {
- case OpCode.OP_CONSTANT: {
- const constant: Value = this.read_constant();
-
- break;
- }
-
- case OpCode.OP_RETURN: {
- return InterpreterStatusCode.SUCCESS;
- }
- }
- }
- }
-
- private freeze(): void {}
-
- private cache(): void {}
-
- private read_byte(): uint8 {
- const byte = this.chunk.code[this.ip];
- this.ip++;
-
- return byte;
- }
-
- private read_constant(): Value {
- return this.chunk.constants.values[this.ip];
- }
-}
diff --git a/src/vm/memory/index.ts b/src/vm/memory/index.ts
deleted file mode 100644
index 5883494..0000000
--- a/src/vm/memory/index.ts
+++ /dev/null
@@ -1,9 +0,0 @@
-import { ScribeVM } from "..";
-
-export function FREE_ARRAY(array: object): void {
- return table.clear(array);
-}
-
-export function FREE_VM(vm: ScribeVM): void {
- return table.clear(vm);
-}
diff --git a/src/vm/op_codes/index.ts b/src/vm/op_codes/index.ts
deleted file mode 100644
index dcacc44..0000000
--- a/src/vm/op_codes/index.ts
+++ /dev/null
@@ -1,9 +0,0 @@
-/**
- * The OPCodes for ScribeVM.
- */
-export enum OpCode {
- OP_CONSTANT,
- OP_ADD,
- OP_SUB,
- OP_RETURN,
-}
diff --git a/src/vm/types.d.ts b/src/vm/types.d.ts
deleted file mode 100644
index f5ea597..0000000
--- a/src/vm/types.d.ts
+++ /dev/null
@@ -1,4 +0,0 @@
-export declare type int = number;
-export declare type uint8 = number;
-
-export declare type uint8_t = Array;
diff --git a/src/vm/value/index.ts b/src/vm/value/index.ts
deleted file mode 100644
index 73e666f..0000000
--- a/src/vm/value/index.ts
+++ /dev/null
@@ -1,32 +0,0 @@
-import { FREE_ARRAY } from "../memory";
-import { Value, ValueArray } from "./types";
-
-/**
- * Used to create a Chunk.
- *
- * @param chunk a Chunk
- */
-export function buildValueArray(): ValueArray {
- return {
- values: table.create(8),
- };
-}
-
-/**
- * Used to free a Chunk's memory.
- *
- * @param value_array a Chunk
- */
-export function freeValueArray(value_array: ValueArray): void {
- FREE_ARRAY(value_array.values);
-}
-
-/**
- * Used to write/insert data to a Chunk's code.
- *
- * @param value_array a Chunk
- * @param byte a byte of data
- */
-export function writeValueArray(value_array: ValueArray, byte: Value): void {
- value_array.values.push(byte);
-}
diff --git a/src/vm/value/types.d.ts b/src/vm/value/types.d.ts
deleted file mode 100644
index b779f98..0000000
--- a/src/vm/value/types.d.ts
+++ /dev/null
@@ -1,5 +0,0 @@
-export declare type Value = number;
-
-export declare interface ValueArray {
- values: Array;
-}
diff --git a/test.project.json b/test.project.json
index 2849b4b..2c84ac2 100644
--- a/test.project.json
+++ b/test.project.json
@@ -1,5 +1,5 @@
{
- "name": "rbxts.scribe-as-game",
+ "name": "rbxts-scribe-as-game",
"globIgnorePaths": ["**/package.json", "**/tsconfig.json"],
"tree": {
diff --git a/testez-companion.toml b/testez-companion.toml
new file mode 100644
index 0000000..ec9b156
--- /dev/null
+++ b/testez-companion.toml
@@ -0,0 +1,2 @@
+# These are the locations of your .spec files (descendants are searched too)
+roots = ["ServerScriptService/Package"]