@learnpack/learnpack 2.1.39 → 2.1.40

Sign up to get free protection for your applications and to get access to all the features.
Files changed (196) hide show
  1. package/README.md +370 -35
  2. package/bin/run +17 -17
  3. package/bin/run.cmd +3 -3
  4. package/lib/commands/audit.d.ts +6 -6
  5. package/lib/commands/audit.js +342 -342
  6. package/lib/commands/clean.d.ts +8 -8
  7. package/lib/commands/clean.js +25 -25
  8. package/lib/commands/download.d.ts +13 -13
  9. package/lib/commands/download.js +55 -55
  10. package/lib/commands/init.d.ts +9 -9
  11. package/lib/commands/init.js +123 -123
  12. package/lib/commands/login.d.ts +14 -14
  13. package/lib/commands/login.js +37 -37
  14. package/lib/commands/logout.d.ts +14 -14
  15. package/lib/commands/logout.js +37 -37
  16. package/lib/commands/publish.d.ts +14 -14
  17. package/lib/commands/publish.js +82 -82
  18. package/lib/commands/start.d.ts +7 -7
  19. package/lib/commands/start.js +239 -208
  20. package/lib/commands/test.d.ts +6 -6
  21. package/lib/commands/test.js +62 -62
  22. package/lib/index.d.ts +1 -1
  23. package/lib/index.js +4 -4
  24. package/lib/managers/config/allowed_files.d.ts +5 -5
  25. package/lib/managers/config/allowed_files.js +30 -30
  26. package/lib/managers/config/defaults.d.ts +41 -41
  27. package/lib/managers/config/defaults.js +44 -44
  28. package/lib/managers/config/exercise.d.ts +36 -36
  29. package/lib/managers/config/exercise.js +236 -236
  30. package/lib/managers/config/index.d.ts +3 -3
  31. package/lib/managers/config/index.js +337 -337
  32. package/lib/managers/file.d.ts +14 -14
  33. package/lib/managers/file.js +153 -153
  34. package/lib/managers/gitpod.d.ts +3 -3
  35. package/lib/managers/gitpod.js +67 -67
  36. package/lib/managers/server/index.d.ts +6 -6
  37. package/lib/managers/server/index.js +58 -58
  38. package/lib/managers/server/routes.d.ts +4 -4
  39. package/lib/managers/server/routes.js +219 -219
  40. package/lib/managers/session.d.ts +3 -3
  41. package/lib/managers/session.js +125 -125
  42. package/lib/managers/socket.d.ts +3 -3
  43. package/lib/managers/socket.js +176 -176
  44. package/lib/managers/telemetry.d.ts +74 -74
  45. package/lib/managers/telemetry.js +206 -206
  46. package/lib/managers/test.js +84 -84
  47. package/lib/models/action.d.ts +2 -2
  48. package/lib/models/action.js +2 -2
  49. package/lib/models/audit.d.ts +15 -15
  50. package/lib/models/audit.js +2 -2
  51. package/lib/models/config-manager.d.ts +21 -21
  52. package/lib/models/config-manager.js +2 -2
  53. package/lib/models/config.d.ts +68 -67
  54. package/lib/models/config.js +2 -2
  55. package/lib/models/counter.d.ts +11 -11
  56. package/lib/models/counter.js +2 -2
  57. package/lib/models/errors.d.ts +15 -15
  58. package/lib/models/errors.js +2 -2
  59. package/lib/models/exercise-obj.d.ts +30 -30
  60. package/lib/models/exercise-obj.js +2 -2
  61. package/lib/models/file.d.ts +5 -5
  62. package/lib/models/file.js +2 -2
  63. package/lib/models/findings.d.ts +17 -17
  64. package/lib/models/findings.js +2 -2
  65. package/lib/models/flags.d.ts +10 -10
  66. package/lib/models/flags.js +2 -2
  67. package/lib/models/front-matter.d.ts +11 -11
  68. package/lib/models/front-matter.js +2 -2
  69. package/lib/models/gitpod-data.d.ts +16 -16
  70. package/lib/models/gitpod-data.js +2 -2
  71. package/lib/models/language.d.ts +4 -4
  72. package/lib/models/language.js +2 -2
  73. package/lib/models/package.d.ts +7 -7
  74. package/lib/models/package.js +2 -2
  75. package/lib/models/plugin-config.d.ts +16 -16
  76. package/lib/models/plugin-config.js +2 -2
  77. package/lib/models/session.d.ts +31 -31
  78. package/lib/models/session.js +2 -2
  79. package/lib/models/socket.d.ts +36 -32
  80. package/lib/models/socket.js +2 -2
  81. package/lib/models/status.d.ts +1 -1
  82. package/lib/models/status.js +2 -2
  83. package/lib/models/success-types.d.ts +1 -1
  84. package/lib/models/success-types.js +2 -2
  85. package/lib/plugin/command/compile.d.ts +6 -6
  86. package/lib/plugin/command/compile.js +18 -18
  87. package/lib/plugin/command/test.d.ts +6 -6
  88. package/lib/plugin/command/test.js +25 -25
  89. package/lib/plugin/index.d.ts +27 -27
  90. package/lib/plugin/index.js +7 -7
  91. package/lib/plugin/plugin.d.ts +8 -8
  92. package/lib/plugin/plugin.js +68 -68
  93. package/lib/plugin/utils.d.ts +16 -16
  94. package/lib/plugin/utils.js +58 -58
  95. package/lib/ui/download.d.ts +5 -5
  96. package/lib/ui/download.js +61 -61
  97. package/lib/utils/BaseCommand.d.ts +8 -8
  98. package/lib/utils/BaseCommand.js +41 -41
  99. package/lib/utils/SessionCommand.d.ts +10 -10
  100. package/lib/utils/SessionCommand.js +43 -43
  101. package/lib/utils/api.d.ts +14 -14
  102. package/lib/utils/api.js +255 -255
  103. package/lib/utils/audit.d.ts +16 -16
  104. package/lib/utils/audit.js +303 -303
  105. package/lib/utils/checkNotInstalled.d.ts +2 -0
  106. package/lib/utils/checkNotInstalled.js +36 -0
  107. package/lib/utils/console.d.ts +12 -12
  108. package/lib/utils/console.js +19 -19
  109. package/lib/utils/errors.d.ts +17 -17
  110. package/lib/utils/errors.js +100 -100
  111. package/lib/utils/exercisesQueue.d.ts +9 -9
  112. package/lib/utils/exercisesQueue.js +38 -38
  113. package/lib/utils/fileQueue.d.ts +40 -40
  114. package/lib/utils/fileQueue.js +168 -168
  115. package/lib/utils/misc.d.ts +1 -1
  116. package/lib/utils/misc.js +23 -23
  117. package/lib/utils/osOperations.d.ts +5 -5
  118. package/lib/utils/osOperations.js +72 -72
  119. package/lib/utils/validators.d.ts +5 -5
  120. package/lib/utils/validators.js +17 -17
  121. package/lib/utils/watcher.d.ts +2 -2
  122. package/lib/utils/watcher.js +25 -25
  123. package/oclif.manifest.json +1 -1
  124. package/package.json +139 -139
  125. package/src/commands/audit.ts +443 -443
  126. package/src/commands/clean.ts +29 -29
  127. package/src/commands/download.ts +61 -61
  128. package/src/commands/init.ts +170 -170
  129. package/src/commands/login.ts +42 -42
  130. package/src/commands/logout.ts +43 -43
  131. package/src/commands/publish.ts +107 -107
  132. package/src/commands/start.ts +53 -23
  133. package/src/commands/test.ts +85 -85
  134. package/src/index.ts +1 -1
  135. package/src/managers/config/allowed_files.ts +29 -29
  136. package/src/managers/config/defaults.ts +42 -42
  137. package/src/managers/config/exercise.ts +311 -311
  138. package/src/managers/config/index.ts +455 -455
  139. package/src/managers/file.ts +196 -196
  140. package/src/managers/gitpod.ts +84 -84
  141. package/src/managers/server/index.ts +78 -78
  142. package/src/managers/server/routes.ts +330 -330
  143. package/src/managers/session.ts +145 -145
  144. package/src/managers/socket.ts +250 -250
  145. package/src/managers/telemetry.ts +346 -346
  146. package/src/managers/test.ts +83 -83
  147. package/src/models/action.ts +10 -10
  148. package/src/models/audit.ts +16 -16
  149. package/src/models/config-manager.ts +23 -23
  150. package/src/models/config.ts +5 -3
  151. package/src/models/counter.ts +11 -11
  152. package/src/models/errors.ts +22 -22
  153. package/src/models/exercise-obj.ts +29 -29
  154. package/src/models/file.ts +5 -5
  155. package/src/models/findings.ts +18 -18
  156. package/src/models/flags.ts +10 -10
  157. package/src/models/front-matter.ts +11 -11
  158. package/src/models/gitpod-data.ts +19 -19
  159. package/src/models/language.ts +4 -4
  160. package/src/models/package.ts +7 -7
  161. package/src/models/plugin-config.ts +17 -17
  162. package/src/models/session.ts +34 -34
  163. package/src/models/socket.ts +5 -0
  164. package/src/models/status.ts +16 -16
  165. package/src/models/success-types.ts +1 -1
  166. package/src/plugin/command/compile.ts +17 -17
  167. package/src/plugin/command/test.ts +30 -30
  168. package/src/plugin/index.ts +6 -6
  169. package/src/plugin/plugin.ts +94 -94
  170. package/src/plugin/utils.ts +87 -87
  171. package/src/types/node-fetch.d.ts +1 -1
  172. package/src/ui/download.ts +71 -71
  173. package/src/utils/BaseCommand.ts +48 -48
  174. package/src/utils/SessionCommand.ts +43 -43
  175. package/src/utils/api.ts +303 -303
  176. package/src/utils/audit.ts +393 -393
  177. package/src/utils/checkNotInstalled.ts +46 -0
  178. package/src/utils/console.ts +24 -24
  179. package/src/utils/errors.ts +117 -117
  180. package/src/utils/exercisesQueue.ts +51 -51
  181. package/src/utils/fileQueue.ts +198 -198
  182. package/src/utils/misc.ts +23 -23
  183. package/src/utils/osOperations.ts +79 -79
  184. package/src/utils/templates/gitignore.txt +19 -19
  185. package/src/utils/templates/incremental/.learn/exercises/01-hello-world/README.es.md +24 -24
  186. package/src/utils/templates/incremental/.learn/exercises/01-hello-world/README.md +24 -24
  187. package/src/utils/templates/incremental/README.ejs +4 -4
  188. package/src/utils/templates/incremental/README.es.ejs +4 -4
  189. package/src/utils/templates/isolated/01-hello-world/README.es.md +26 -26
  190. package/src/utils/templates/isolated/01-hello-world/README.md +26 -26
  191. package/src/utils/templates/isolated/README.ejs +4 -4
  192. package/src/utils/templates/isolated/README.es.ejs +4 -4
  193. package/src/utils/templates/no-grading/README.ejs +4 -4
  194. package/src/utils/templates/no-grading/README.es.ejs +4 -4
  195. package/src/utils/validators.ts +18 -18
  196. package/src/utils/watcher.ts +27 -27
@@ -1,168 +1,168 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const console_1 = require("../utils/console");
4
- const fs = require("fs");
5
- // import em from "events"
6
- const XXH = require("xxhashjs");
7
- // possible events to dispatch
8
- const events = {
9
- START_EXERCISE: "start_exercise",
10
- INIT: "initializing",
11
- RUNNING: "configuration_loaded",
12
- END: "connection_ended",
13
- RESET_EXERCISE: "reset_exercise",
14
- OPEN_FILES: "open_files",
15
- OPEN_WINDOW: "open_window",
16
- INSTRUCTIONS_CLOSED: "instructions_closed",
17
- };
18
- let options = {
19
- path: null,
20
- create: false,
21
- };
22
- let lastHash = null;
23
- let watcher = null; // subscribe to file and listen to changes
24
- let actions = null; // action queue
25
- const loadDispatcher = (opts) => {
26
- actions = [{ name: "initializing", time: now() }];
27
- console_1.default.debug(`Loading from ${opts.path}`);
28
- let exists = fs.existsSync(opts.path);
29
- if (opts.create) {
30
- if (exists)
31
- actions.push({ name: "reset", time: now() });
32
- fs.writeFileSync(opts.path, JSON.stringify(actions), { flag: "w" });
33
- exists = true;
34
- }
35
- if (!exists)
36
- throw new Error(`Invalid queue path, missing file at: ${opts.path}`);
37
- let incomingActions = [];
38
- try {
39
- const content = fs.readFileSync(opts.path, "utf-8");
40
- incomingActions = JSON.parse(content);
41
- if (!Array.isArray(incomingActions))
42
- incomingActions = [];
43
- }
44
- catch (_a) {
45
- incomingActions = [];
46
- console_1.default.debug("Error loading VSCode Actions file");
47
- }
48
- console_1.default.debug("Actions load ", incomingActions);
49
- return incomingActions;
50
- };
51
- // eslint-disable-next-line
52
- const enqueue = (name, data = undefined) => {
53
- if (!Object.values(events).includes(name)) {
54
- console_1.default.debug(`Invalid event ${name}`);
55
- throw new Error(`Invalid action ${name}`);
56
- }
57
- if (!actions)
58
- actions = [];
59
- actions.push({ name, time: now(), data: data });
60
- console_1.default.debug(`EMIT -> ${name}:Exporting changes to ${options.path}`);
61
- return fs.writeFileSync(options.path || "", JSON.stringify(actions));
62
- };
63
- const now = () => {
64
- const hrTime = process.hrtime();
65
- // eslint-disable-next-line
66
- const htTime0 = hrTime[0] * 1000000;
67
- return (htTime0 + hrTime[1]) / 1000;
68
- };
69
- const loadFile = (filePath) => {
70
- if (!fs.existsSync(filePath))
71
- throw new Error(`No queue.json file to load on ${filePath}`);
72
- const content = fs.readFileSync(filePath, "utf8");
73
- const newHash = XXH.h32(content, 43981).toString(16);
74
- const isUpdated = lastHash !== newHash;
75
- lastHash = newHash;
76
- const incomingActions = JSON.parse(content);
77
- return { isUpdated, incomingActions };
78
- };
79
- const dequeue = () => {
80
- // first time dequeue loads
81
- if (!actions)
82
- actions = [];
83
- const { isUpdated, incomingActions } = loadFile(options.path || "");
84
- if (!isUpdated) {
85
- /**
86
- * make sure no tasks are executed from the queue by matching both
87
- * queues (the incoming with current one)
88
- */
89
- actions = incomingActions;
90
- console_1.default.debug(`No new actions to process: ${actions.length}/${incomingActions.length}`);
91
- return null;
92
- }
93
- // do i need to reset actions to zero?
94
- if (actions.length > 0 && actions[0].time !== incomingActions[0].time) {
95
- actions = [];
96
- }
97
- const action = incomingActions[incomingActions.length - 1];
98
- console_1.default.debug("Dequeing action ", action);
99
- actions.push(action);
100
- return action;
101
- };
102
- const pull = (callback) => {
103
- console_1.default.debug("Pulling actions");
104
- let incoming = dequeue();
105
- while (incoming) {
106
- callback(incoming);
107
- incoming = dequeue();
108
- }
109
- };
110
- const reset = (callback) => {
111
- console_1.default.debug("Queue reseted");
112
- actions = [];
113
- if (fs.existsSync(options.path || "")) {
114
- fs.writeFileSync(options.path || "", "[]");
115
- callback();
116
- }
117
- };
118
- const onPull = (callback) => {
119
- // eslint-disable-next-line
120
- const chokidar = require("chokidar");
121
- console_1.default.debug("Starting to listen...");
122
- try {
123
- loadFile(options.path || "");
124
- }
125
- catch (_a) {
126
- console_1.default.debug("No previoues queue file, waiting for it to be created...");
127
- }
128
- if (!watcher) {
129
- console_1.default.debug(`Watching ${options.path}`);
130
- watcher = chokidar.watch(`${options.path}`, {
131
- persistent: true,
132
- });
133
- }
134
- else
135
- console_1.default.debug("Already watching queue path");
136
- watcher.on("add", () => pull(callback)).on("change", () => pull(callback));
137
- return true;
138
- };
139
- const onReset = (callback) => {
140
- // eslint-disable-next-line
141
- const chokidar = require("chokidar");
142
- if (!watcher) {
143
- console_1.default.debug(`Watching ${options.path}`);
144
- watcher = chokidar.watch(`${options.path}`, {
145
- persistent: true,
146
- });
147
- }
148
- watcher.on("unlink", () => reset(callback));
149
- return true;
150
- };
151
- exports.default = {
152
- events,
153
- dispatcher: (opts = {}) => {
154
- if (!actions) {
155
- options = Object.assign(Object.assign({}, options), opts);
156
- console_1.default.debug("Initializing queue dispatcher", options);
157
- actions = loadDispatcher(options);
158
- }
159
- return { enqueue, events };
160
- },
161
- listener: (opts = {}) => {
162
- if (!actions) {
163
- options = Object.assign(Object.assign({}, options), opts);
164
- console_1.default.debug("Initializing queue listener", options);
165
- }
166
- return { onPull, onReset, events };
167
- },
168
- };
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const console_1 = require("../utils/console");
4
+ const fs = require("fs");
5
+ // import em from "events"
6
+ const XXH = require("xxhashjs");
7
+ // possible events to dispatch
8
+ const events = {
9
+ START_EXERCISE: "start_exercise",
10
+ INIT: "initializing",
11
+ RUNNING: "configuration_loaded",
12
+ END: "connection_ended",
13
+ RESET_EXERCISE: "reset_exercise",
14
+ OPEN_FILES: "open_files",
15
+ OPEN_WINDOW: "open_window",
16
+ INSTRUCTIONS_CLOSED: "instructions_closed",
17
+ };
18
+ let options = {
19
+ path: null,
20
+ create: false,
21
+ };
22
+ let lastHash = null;
23
+ let watcher = null; // subscribe to file and listen to changes
24
+ let actions = null; // action queue
25
+ const loadDispatcher = (opts) => {
26
+ actions = [{ name: "initializing", time: now() }];
27
+ console_1.default.debug(`Loading from ${opts.path}`);
28
+ let exists = fs.existsSync(opts.path);
29
+ if (opts.create) {
30
+ if (exists)
31
+ actions.push({ name: "reset", time: now() });
32
+ fs.writeFileSync(opts.path, JSON.stringify(actions), { flag: "w" });
33
+ exists = true;
34
+ }
35
+ if (!exists)
36
+ throw new Error(`Invalid queue path, missing file at: ${opts.path}`);
37
+ let incomingActions = [];
38
+ try {
39
+ const content = fs.readFileSync(opts.path, "utf-8");
40
+ incomingActions = JSON.parse(content);
41
+ if (!Array.isArray(incomingActions))
42
+ incomingActions = [];
43
+ }
44
+ catch (_a) {
45
+ incomingActions = [];
46
+ console_1.default.debug("Error loading VSCode Actions file");
47
+ }
48
+ console_1.default.debug("Actions load ", incomingActions);
49
+ return incomingActions;
50
+ };
51
+ // eslint-disable-next-line
52
+ const enqueue = (name, data = undefined) => {
53
+ if (!Object.values(events).includes(name)) {
54
+ console_1.default.debug(`Invalid event ${name}`);
55
+ throw new Error(`Invalid action ${name}`);
56
+ }
57
+ if (!actions)
58
+ actions = [];
59
+ actions.push({ name, time: now(), data: data });
60
+ console_1.default.debug(`EMIT -> ${name}:Exporting changes to ${options.path}`);
61
+ return fs.writeFileSync(options.path || "", JSON.stringify(actions));
62
+ };
63
+ const now = () => {
64
+ const hrTime = process.hrtime();
65
+ // eslint-disable-next-line
66
+ const htTime0 = hrTime[0] * 1000000;
67
+ return (htTime0 + hrTime[1]) / 1000;
68
+ };
69
+ const loadFile = (filePath) => {
70
+ if (!fs.existsSync(filePath))
71
+ throw new Error(`No queue.json file to load on ${filePath}`);
72
+ const content = fs.readFileSync(filePath, "utf8");
73
+ const newHash = XXH.h32(content, 43981).toString(16);
74
+ const isUpdated = lastHash !== newHash;
75
+ lastHash = newHash;
76
+ const incomingActions = JSON.parse(content);
77
+ return { isUpdated, incomingActions };
78
+ };
79
+ const dequeue = () => {
80
+ // first time dequeue loads
81
+ if (!actions)
82
+ actions = [];
83
+ const { isUpdated, incomingActions } = loadFile(options.path || "");
84
+ if (!isUpdated) {
85
+ /**
86
+ * make sure no tasks are executed from the queue by matching both
87
+ * queues (the incoming with current one)
88
+ */
89
+ actions = incomingActions;
90
+ console_1.default.debug(`No new actions to process: ${actions.length}/${incomingActions.length}`);
91
+ return null;
92
+ }
93
+ // do i need to reset actions to zero?
94
+ if (actions.length > 0 && actions[0].time !== incomingActions[0].time) {
95
+ actions = [];
96
+ }
97
+ const action = incomingActions[incomingActions.length - 1];
98
+ console_1.default.debug("Dequeing action ", action);
99
+ actions.push(action);
100
+ return action;
101
+ };
102
+ const pull = (callback) => {
103
+ console_1.default.debug("Pulling actions");
104
+ let incoming = dequeue();
105
+ while (incoming) {
106
+ callback(incoming);
107
+ incoming = dequeue();
108
+ }
109
+ };
110
+ const reset = (callback) => {
111
+ console_1.default.debug("Queue reseted");
112
+ actions = [];
113
+ if (fs.existsSync(options.path || "")) {
114
+ fs.writeFileSync(options.path || "", "[]");
115
+ callback();
116
+ }
117
+ };
118
+ const onPull = (callback) => {
119
+ // eslint-disable-next-line
120
+ const chokidar = require("chokidar");
121
+ console_1.default.debug("Starting to listen...");
122
+ try {
123
+ loadFile(options.path || "");
124
+ }
125
+ catch (_a) {
126
+ console_1.default.debug("No previoues queue file, waiting for it to be created...");
127
+ }
128
+ if (!watcher) {
129
+ console_1.default.debug(`Watching ${options.path}`);
130
+ watcher = chokidar.watch(`${options.path}`, {
131
+ persistent: true,
132
+ });
133
+ }
134
+ else
135
+ console_1.default.debug("Already watching queue path");
136
+ watcher.on("add", () => pull(callback)).on("change", () => pull(callback));
137
+ return true;
138
+ };
139
+ const onReset = (callback) => {
140
+ // eslint-disable-next-line
141
+ const chokidar = require("chokidar");
142
+ if (!watcher) {
143
+ console_1.default.debug(`Watching ${options.path}`);
144
+ watcher = chokidar.watch(`${options.path}`, {
145
+ persistent: true,
146
+ });
147
+ }
148
+ watcher.on("unlink", () => reset(callback));
149
+ return true;
150
+ };
151
+ exports.default = {
152
+ events,
153
+ dispatcher: (opts = {}) => {
154
+ if (!actions) {
155
+ options = Object.assign(Object.assign({}, options), opts);
156
+ console_1.default.debug("Initializing queue dispatcher", options);
157
+ actions = loadDispatcher(options);
158
+ }
159
+ return { enqueue, events };
160
+ },
161
+ listener: (opts = {}) => {
162
+ if (!actions) {
163
+ options = Object.assign(Object.assign({}, options), opts);
164
+ console_1.default.debug("Initializing queue listener", options);
165
+ }
166
+ return { onPull, onReset, events };
167
+ },
168
+ };
@@ -1 +1 @@
1
- export declare const prioritizeHTMLFile: (entryFiles: string[]) => string[];
1
+ export declare const prioritizeHTMLFile: (entryFiles: string[]) => string[];
package/lib/utils/misc.js CHANGED
@@ -1,23 +1,23 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.prioritizeHTMLFile = void 0;
4
- exports.prioritizeHTMLFile = (entryFiles) => {
5
- let files = [];
6
- // Find the html file and put it as latest in the files array
7
- // in order to keep the html file opened in vscode plugin
8
- const index = entryFiles.findIndex(file => {
9
- return /.*\.html$/.test(file);
10
- });
11
- if (index !== -1) {
12
- for (const [i, entryFile] of entryFiles.entries()) {
13
- if (i !== index) {
14
- files.push(entryFile);
15
- }
16
- }
17
- files.push(entryFiles[index]);
18
- }
19
- else {
20
- files = entryFiles;
21
- }
22
- return files;
23
- };
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.prioritizeHTMLFile = void 0;
4
+ exports.prioritizeHTMLFile = (entryFiles) => {
5
+ let files = [];
6
+ // Find the html file and put it as latest in the files array
7
+ // in order to keep the html file opened in vscode plugin
8
+ const index = entryFiles.findIndex(file => {
9
+ return /.*\.html$/.test(file);
10
+ });
11
+ if (index !== -1) {
12
+ for (const [i, entryFile] of entryFiles.entries()) {
13
+ if (i !== index) {
14
+ files.push(entryFile);
15
+ }
16
+ }
17
+ files.push(entryFiles[index]);
18
+ }
19
+ else {
20
+ files = entryFiles;
21
+ }
22
+ return files;
23
+ };
@@ -1,5 +1,5 @@
1
- declare const eventManager: {
2
- enqueue: (event: string, data: any) => void;
3
- checkXDGInstalled: () => Promise<boolean>;
4
- };
5
- export { eventManager };
1
+ declare const eventManager: {
2
+ enqueue: (event: string, data: any) => void;
3
+ checkXDGInstalled: () => Promise<boolean>;
4
+ };
5
+ export { eventManager };
@@ -1,72 +1,72 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.eventManager = void 0;
4
- const child_process_1 = require("child_process");
5
- const os = require("os");
6
- const path = require("path");
7
- const cli_ux_1 = require("cli-ux");
8
- const checkXDGInstalled = () => {
9
- return new Promise((resolve, reject) => {
10
- child_process_1.exec("which xdg-open", (error, stdout, stderr) => {
11
- if (error) {
12
- resolve(false);
13
- }
14
- if (stdout) {
15
- resolve(true);
16
- }
17
- else {
18
- resolve(false);
19
- }
20
- });
21
- });
22
- };
23
- const openFile = (filePath) => {
24
- const fullPath = path.join(process.cwd(), filePath);
25
- let command;
26
- switch (os.platform()) {
27
- case "darwin": // macOS
28
- command = `open ${fullPath}`;
29
- break;
30
- case "win32": // Windows
31
- command = `start ${fullPath}`;
32
- break;
33
- case "linux": // Linux
34
- command = `xdg-open ${fullPath}`;
35
- break;
36
- default:
37
- throw new Error("Unsupported OS");
38
- }
39
- child_process_1.exec(command, (error, stdout, stderr) => {
40
- if (error) {
41
- console.error(`exec error: ${error}`);
42
- }
43
- });
44
- };
45
- const eventManager = {
46
- enqueue: (event, data) => {
47
- if (event === "start_exercise") {
48
- const exercise = data;
49
- const filesToOpen = exercise.files
50
- .filter((file) => !file.hidden)
51
- .map((file) => {
52
- return file.path.replace("\\", "/");
53
- });
54
- for (const file of filesToOpen) {
55
- openFile(file);
56
- }
57
- }
58
- if (event === "open_files") {
59
- const files = data;
60
- for (const file of files) {
61
- const correctedPath = file.replace("\\", "/");
62
- openFile(correctedPath);
63
- }
64
- }
65
- if (event === "open_window") {
66
- const url = data.url;
67
- cli_ux_1.default.open(url);
68
- }
69
- },
70
- checkXDGInstalled,
71
- };
72
- exports.eventManager = eventManager;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.eventManager = void 0;
4
+ const child_process_1 = require("child_process");
5
+ const os = require("os");
6
+ const path = require("path");
7
+ const cli_ux_1 = require("cli-ux");
8
+ const checkXDGInstalled = () => {
9
+ return new Promise((resolve, reject) => {
10
+ child_process_1.exec("which xdg-open", (error, stdout, stderr) => {
11
+ if (error) {
12
+ resolve(false);
13
+ }
14
+ if (stdout) {
15
+ resolve(true);
16
+ }
17
+ else {
18
+ resolve(false);
19
+ }
20
+ });
21
+ });
22
+ };
23
+ const openFile = (filePath) => {
24
+ const fullPath = path.join(process.cwd(), filePath);
25
+ let command;
26
+ switch (os.platform()) {
27
+ case "darwin": // macOS
28
+ command = `open ${fullPath}`;
29
+ break;
30
+ case "win32": // Windows
31
+ command = `start ${fullPath}`;
32
+ break;
33
+ case "linux": // Linux
34
+ command = `xdg-open ${fullPath}`;
35
+ break;
36
+ default:
37
+ throw new Error("Unsupported OS");
38
+ }
39
+ child_process_1.exec(command, (error, stdout, stderr) => {
40
+ if (error) {
41
+ console.error(`exec error: ${error}`);
42
+ }
43
+ });
44
+ };
45
+ const eventManager = {
46
+ enqueue: (event, data) => {
47
+ if (event === "start_exercise") {
48
+ const exercise = data;
49
+ const filesToOpen = exercise.files
50
+ .filter((file) => !file.hidden)
51
+ .map((file) => {
52
+ return file.path.replace("\\", "/");
53
+ });
54
+ for (const file of filesToOpen) {
55
+ openFile(file);
56
+ }
57
+ }
58
+ if (event === "open_files") {
59
+ const files = data;
60
+ for (const file of files) {
61
+ const correctedPath = file.replace("\\", "/");
62
+ openFile(correctedPath);
63
+ }
64
+ }
65
+ if (event === "open_window") {
66
+ const url = data.url;
67
+ cli_ux_1.default.open(url);
68
+ }
69
+ },
70
+ checkXDGInstalled,
71
+ };
72
+ exports.eventManager = eventManager;
@@ -1,5 +1,5 @@
1
- export declare function validURL(str: string): boolean;
2
- declare const _default: {
3
- validURL: typeof validURL;
4
- };
5
- export default _default;
1
+ export declare function validURL(str: string): boolean;
2
+ declare const _default: {
3
+ validURL: typeof validURL;
4
+ };
5
+ export default _default;
@@ -1,17 +1,17 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.validURL = void 0;
4
- function validURL(str) {
5
- if (!str.includes('github.com')) {
6
- return false;
7
- }
8
- const pattern = new RegExp('^(https?:\\/\\/)?' + // protocol
9
- '((([a-z\\d]([a-z\\d-]*[a-z\\d])*)\\.)+[a-z]{2,}|' + // domain name
10
- '((\\d{1,3}\\.){3}\\d{1,3}))' + // OR ip (v4) address
11
- '(\\:\\d+)?(\\/[-a-z\\d%_.~+]*)*' + // port and path
12
- '(\\?[;&a-z\\d%_.~+=-]*)?' + // query string
13
- '(\\#[-a-z\\d_]*)?$', 'i'); // fragment locator
14
- return !!pattern.test(str);
15
- }
16
- exports.validURL = validURL;
17
- exports.default = { validURL };
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.validURL = void 0;
4
+ function validURL(str) {
5
+ if (!str.includes('github.com')) {
6
+ return false;
7
+ }
8
+ const pattern = new RegExp('^(https?:\\/\\/)?' + // protocol
9
+ '((([a-z\\d]([a-z\\d-]*[a-z\\d])*)\\.)+[a-z]{2,}|' + // domain name
10
+ '((\\d{1,3}\\.){3}\\d{1,3}))' + // OR ip (v4) address
11
+ '(\\:\\d+)?(\\/[-a-z\\d%_.~+]*)*' + // port and path
12
+ '(\\?[;&a-z\\d%_.~+=-]*)?' + // query string
13
+ '(\\#[-a-z\\d_]*)?$', 'i'); // fragment locator
14
+ return !!pattern.test(str);
15
+ }
16
+ exports.validURL = validURL;
17
+ exports.default = { validURL };
@@ -1,2 +1,2 @@
1
- declare const _default: (path: string, reloadSocket: (filename: string) => void) => Promise<unknown>;
2
- export default _default;
1
+ declare const _default: (path: string, reloadSocket: (filename: string) => void) => Promise<unknown>;
2
+ export default _default;
@@ -1,25 +1,25 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const chokidar = require("chokidar");
4
- const console_1 = require("./console");
5
- const debounce = require("debounce");
6
- exports.default = (path, reloadSocket) => new Promise((resolve /* , reject */) => {
7
- console_1.default.debug("PATH:", path);
8
- const watcher = chokidar.watch(path, {
9
- // TODO: This watcher is not ready yet
10
- // ignored: /^(?=.*(\.\w+)$)(?!.*\.md$).*$/gm,
11
- ignored: /\.pyc$/,
12
- ignoreInitial: true,
13
- });
14
- const onChange = (eventname, _filename) => {
15
- // Console.info(`Event ${eventname} detected. in file: ${_filename}`)
16
- resolve(_filename);
17
- reloadSocket(_filename);
18
- };
19
- watcher.on("all", debounce(onChange, 500, true));
20
- // watcher.on('all', onChange)
21
- process.on("SIGINT", function () {
22
- watcher.close();
23
- process.exit();
24
- });
25
- });
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const chokidar = require("chokidar");
4
+ const console_1 = require("./console");
5
+ const debounce = require("debounce");
6
+ exports.default = (path, reloadSocket) => new Promise((resolve /* , reject */) => {
7
+ console_1.default.debug("PATH:", path);
8
+ const watcher = chokidar.watch(path, {
9
+ // TODO: This watcher is not ready yet
10
+ // ignored: /^(?=.*(\.\w+)$)(?!.*\.md$).*$/gm,
11
+ ignored: /\.pyc$/,
12
+ ignoreInitial: true,
13
+ });
14
+ const onChange = (eventname, _filename) => {
15
+ // Console.info(`Event ${eventname} detected. in file: ${_filename}`)
16
+ resolve(_filename);
17
+ reloadSocket(_filename);
18
+ };
19
+ watcher.on("all", debounce(onChange, 500, true));
20
+ // watcher.on('all', onChange)
21
+ process.on("SIGINT", function () {
22
+ watcher.close();
23
+ process.exit();
24
+ });
25
+ });