@learnpack/learnpack 2.1.39 → 2.1.41
Sign up to get free protection for your applications and to get access to all the features.
- package/README.md +370 -35
- package/bin/run +17 -17
- package/bin/run.cmd +3 -3
- package/lib/commands/audit.d.ts +6 -6
- package/lib/commands/audit.js +342 -342
- package/lib/commands/clean.d.ts +8 -8
- package/lib/commands/clean.js +25 -25
- package/lib/commands/download.d.ts +13 -13
- package/lib/commands/download.js +55 -55
- package/lib/commands/init.d.ts +9 -9
- package/lib/commands/init.js +123 -123
- package/lib/commands/login.d.ts +14 -14
- package/lib/commands/login.js +37 -37
- package/lib/commands/logout.d.ts +14 -14
- package/lib/commands/logout.js +37 -37
- package/lib/commands/publish.d.ts +14 -14
- package/lib/commands/publish.js +82 -82
- package/lib/commands/start.d.ts +7 -7
- package/lib/commands/start.js +239 -208
- package/lib/commands/test.d.ts +6 -6
- package/lib/commands/test.js +62 -62
- package/lib/index.d.ts +1 -1
- package/lib/index.js +4 -4
- package/lib/managers/config/allowed_files.d.ts +5 -5
- package/lib/managers/config/allowed_files.js +30 -30
- package/lib/managers/config/defaults.d.ts +41 -41
- package/lib/managers/config/defaults.js +44 -44
- package/lib/managers/config/exercise.d.ts +36 -36
- package/lib/managers/config/exercise.js +236 -236
- package/lib/managers/config/index.d.ts +3 -3
- package/lib/managers/config/index.js +337 -337
- package/lib/managers/file.d.ts +14 -14
- package/lib/managers/file.js +153 -153
- package/lib/managers/gitpod.d.ts +3 -3
- package/lib/managers/gitpod.js +67 -67
- package/lib/managers/server/index.d.ts +6 -6
- package/lib/managers/server/index.js +58 -58
- package/lib/managers/server/routes.d.ts +4 -4
- package/lib/managers/server/routes.js +219 -219
- package/lib/managers/session.d.ts +3 -3
- package/lib/managers/session.js +125 -125
- package/lib/managers/socket.d.ts +3 -3
- package/lib/managers/socket.js +176 -176
- package/lib/managers/telemetry.d.ts +74 -74
- package/lib/managers/telemetry.js +206 -206
- package/lib/managers/test.js +84 -84
- package/lib/models/action.d.ts +2 -2
- package/lib/models/action.js +2 -2
- package/lib/models/audit.d.ts +15 -15
- package/lib/models/audit.js +2 -2
- package/lib/models/config-manager.d.ts +21 -21
- package/lib/models/config-manager.js +2 -2
- package/lib/models/config.d.ts +68 -67
- package/lib/models/config.js +2 -2
- package/lib/models/counter.d.ts +11 -11
- package/lib/models/counter.js +2 -2
- package/lib/models/errors.d.ts +15 -15
- package/lib/models/errors.js +2 -2
- package/lib/models/exercise-obj.d.ts +30 -30
- package/lib/models/exercise-obj.js +2 -2
- package/lib/models/file.d.ts +5 -5
- package/lib/models/file.js +2 -2
- package/lib/models/findings.d.ts +17 -17
- package/lib/models/findings.js +2 -2
- package/lib/models/flags.d.ts +10 -10
- package/lib/models/flags.js +2 -2
- package/lib/models/front-matter.d.ts +11 -11
- package/lib/models/front-matter.js +2 -2
- package/lib/models/gitpod-data.d.ts +16 -16
- package/lib/models/gitpod-data.js +2 -2
- package/lib/models/language.d.ts +4 -4
- package/lib/models/language.js +2 -2
- package/lib/models/package.d.ts +7 -7
- package/lib/models/package.js +2 -2
- package/lib/models/plugin-config.d.ts +16 -16
- package/lib/models/plugin-config.js +2 -2
- package/lib/models/session.d.ts +31 -31
- package/lib/models/session.js +2 -2
- package/lib/models/socket.d.ts +36 -32
- package/lib/models/socket.js +2 -2
- package/lib/models/status.d.ts +1 -1
- package/lib/models/status.js +2 -2
- package/lib/models/success-types.d.ts +1 -1
- package/lib/models/success-types.js +2 -2
- package/lib/plugin/command/compile.d.ts +6 -6
- package/lib/plugin/command/compile.js +18 -18
- package/lib/plugin/command/test.d.ts +6 -6
- package/lib/plugin/command/test.js +25 -25
- package/lib/plugin/index.d.ts +27 -27
- package/lib/plugin/index.js +7 -7
- package/lib/plugin/plugin.d.ts +8 -8
- package/lib/plugin/plugin.js +68 -68
- package/lib/plugin/utils.d.ts +16 -16
- package/lib/plugin/utils.js +58 -58
- package/lib/ui/download.d.ts +5 -5
- package/lib/ui/download.js +61 -61
- package/lib/utils/BaseCommand.d.ts +8 -8
- package/lib/utils/BaseCommand.js +41 -41
- package/lib/utils/SessionCommand.d.ts +10 -10
- package/lib/utils/SessionCommand.js +43 -43
- package/lib/utils/api.d.ts +14 -14
- package/lib/utils/api.js +255 -255
- package/lib/utils/audit.d.ts +16 -16
- package/lib/utils/audit.js +303 -303
- package/lib/utils/checkNotInstalled.d.ts +2 -0
- package/lib/utils/checkNotInstalled.js +36 -0
- package/lib/utils/console.d.ts +12 -12
- package/lib/utils/console.js +19 -19
- package/lib/utils/errors.d.ts +17 -17
- package/lib/utils/errors.js +100 -100
- package/lib/utils/exercisesQueue.d.ts +9 -9
- package/lib/utils/exercisesQueue.js +38 -38
- package/lib/utils/fileQueue.d.ts +40 -40
- package/lib/utils/fileQueue.js +168 -168
- package/lib/utils/misc.d.ts +1 -1
- package/lib/utils/misc.js +23 -23
- package/lib/utils/osOperations.d.ts +5 -5
- package/lib/utils/osOperations.js +72 -72
- package/lib/utils/validators.d.ts +5 -5
- package/lib/utils/validators.js +17 -17
- package/lib/utils/watcher.d.ts +2 -2
- package/lib/utils/watcher.js +25 -25
- package/oclif.manifest.json +1 -1
- package/package.json +139 -139
- package/src/commands/audit.ts +443 -443
- package/src/commands/clean.ts +29 -29
- package/src/commands/download.ts +61 -61
- package/src/commands/init.ts +170 -170
- package/src/commands/login.ts +42 -42
- package/src/commands/logout.ts +43 -43
- package/src/commands/publish.ts +107 -107
- package/src/commands/start.ts +53 -23
- package/src/commands/test.ts +85 -85
- package/src/index.ts +1 -1
- package/src/managers/config/allowed_files.ts +29 -29
- package/src/managers/config/defaults.ts +42 -42
- package/src/managers/config/exercise.ts +311 -311
- package/src/managers/config/index.ts +455 -455
- package/src/managers/file.ts +196 -196
- package/src/managers/gitpod.ts +84 -84
- package/src/managers/server/index.ts +78 -78
- package/src/managers/server/routes.ts +330 -330
- package/src/managers/session.ts +145 -145
- package/src/managers/socket.ts +250 -250
- package/src/managers/telemetry.ts +346 -346
- package/src/managers/test.ts +83 -83
- package/src/models/action.ts +10 -10
- package/src/models/audit.ts +16 -16
- package/src/models/config-manager.ts +23 -23
- package/src/models/config.ts +5 -3
- package/src/models/counter.ts +11 -11
- package/src/models/errors.ts +22 -22
- package/src/models/exercise-obj.ts +29 -29
- package/src/models/file.ts +5 -5
- package/src/models/findings.ts +18 -18
- package/src/models/flags.ts +10 -10
- package/src/models/front-matter.ts +11 -11
- package/src/models/gitpod-data.ts +19 -19
- package/src/models/language.ts +4 -4
- package/src/models/package.ts +7 -7
- package/src/models/plugin-config.ts +17 -17
- package/src/models/session.ts +34 -34
- package/src/models/socket.ts +5 -0
- package/src/models/status.ts +16 -16
- package/src/models/success-types.ts +1 -1
- package/src/plugin/command/compile.ts +17 -17
- package/src/plugin/command/test.ts +30 -30
- package/src/plugin/index.ts +6 -6
- package/src/plugin/plugin.ts +94 -94
- package/src/plugin/utils.ts +87 -87
- package/src/types/node-fetch.d.ts +1 -1
- package/src/ui/download.ts +71 -71
- package/src/utils/BaseCommand.ts +48 -48
- package/src/utils/SessionCommand.ts +43 -43
- package/src/utils/api.ts +303 -303
- package/src/utils/audit.ts +393 -393
- package/src/utils/checkNotInstalled.ts +46 -0
- package/src/utils/console.ts +24 -24
- package/src/utils/errors.ts +117 -117
- package/src/utils/exercisesQueue.ts +51 -51
- package/src/utils/fileQueue.ts +198 -198
- package/src/utils/misc.ts +23 -23
- package/src/utils/osOperations.ts +79 -79
- package/src/utils/templates/gitignore.txt +19 -19
- package/src/utils/templates/incremental/.learn/exercises/01-hello-world/README.es.md +24 -24
- package/src/utils/templates/incremental/.learn/exercises/01-hello-world/README.md +24 -24
- package/src/utils/templates/incremental/README.ejs +4 -4
- package/src/utils/templates/incremental/README.es.ejs +4 -4
- package/src/utils/templates/isolated/01-hello-world/README.es.md +26 -26
- package/src/utils/templates/isolated/01-hello-world/README.md +26 -26
- package/src/utils/templates/isolated/README.ejs +4 -4
- package/src/utils/templates/isolated/README.es.ejs +4 -4
- package/src/utils/templates/no-grading/README.ejs +4 -4
- package/src/utils/templates/no-grading/README.es.ejs +4 -4
- package/src/utils/validators.ts +18 -18
- package/src/utils/watcher.ts +27 -27
@@ -1,24 +1,24 @@
|
|
1
|
-
# `01` Hello World
|
2
|
-
|
3
|
-
Puedes tener un archivo README el cual será como una página de un libro, sin archivos de código.
|
4
|
-
|
5
|
-
También puedes agregar un archivo `README.[lenguaje].md` para traducciones, por ejemplo `README.es.md` para español.
|
6
|
-
|
7
|
-
## Inserta videos
|
8
|
-
|
9
|
-
Si quieres incluir algún video introductorio para cada ejercicio, agrega la propiedad `intro` en el inicio del README.md para ese ejercicio en particular:
|
10
|
-
|
11
|
-
```markdown
|
12
|
-
---
|
13
|
-
intro: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
14
|
-
---
|
15
|
-
```
|
16
|
-
|
17
|
-
Tambien puedes agregar un video explicando la solución para cada ejercicio agregando la propiedad `tutorial` al inicio del markdown del README.md correspondiente:
|
18
|
-
|
19
|
-
```markdown
|
20
|
-
---
|
21
|
-
intro: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
22
|
-
tutorial: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
23
|
-
---
|
24
|
-
```
|
1
|
+
# `01` Hello World
|
2
|
+
|
3
|
+
Puedes tener un archivo README el cual será como una página de un libro, sin archivos de código.
|
4
|
+
|
5
|
+
También puedes agregar un archivo `README.[lenguaje].md` para traducciones, por ejemplo `README.es.md` para español.
|
6
|
+
|
7
|
+
## Inserta videos
|
8
|
+
|
9
|
+
Si quieres incluir algún video introductorio para cada ejercicio, agrega la propiedad `intro` en el inicio del README.md para ese ejercicio en particular:
|
10
|
+
|
11
|
+
```markdown
|
12
|
+
---
|
13
|
+
intro: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
14
|
+
---
|
15
|
+
```
|
16
|
+
|
17
|
+
Tambien puedes agregar un video explicando la solución para cada ejercicio agregando la propiedad `tutorial` al inicio del markdown del README.md correspondiente:
|
18
|
+
|
19
|
+
```markdown
|
20
|
+
---
|
21
|
+
intro: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
22
|
+
tutorial: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
23
|
+
---
|
24
|
+
```
|
@@ -1,24 +1,24 @@
|
|
1
|
-
# `01` Hello World
|
2
|
-
|
3
|
-
You can have just a README file and it will be like a page in a book, no code files.
|
4
|
-
|
5
|
-
You can also add a `README.[lang].md` file for translations, for example: `README.es.md` for spanish.
|
6
|
-
|
7
|
-
## Video compatibility
|
8
|
-
|
9
|
-
If you want to include some video introduction for each exercise, add a `intro` property in the markdown frontmatter of the README.md for that particular exercise:
|
10
|
-
|
11
|
-
```markdown
|
12
|
-
---
|
13
|
-
intro: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
14
|
-
---
|
15
|
-
```
|
16
|
-
|
17
|
-
You can also add a video solution for each exercise by adding a `tutorial` property on the markdown frontmatter of it's README.md:
|
18
|
-
|
19
|
-
```markdown
|
20
|
-
---
|
21
|
-
intro: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
22
|
-
tutorial: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
23
|
-
---
|
24
|
-
```
|
1
|
+
# `01` Hello World
|
2
|
+
|
3
|
+
You can have just a README file and it will be like a page in a book, no code files.
|
4
|
+
|
5
|
+
You can also add a `README.[lang].md` file for translations, for example: `README.es.md` for spanish.
|
6
|
+
|
7
|
+
## Video compatibility
|
8
|
+
|
9
|
+
If you want to include some video introduction for each exercise, add a `intro` property in the markdown frontmatter of the README.md for that particular exercise:
|
10
|
+
|
11
|
+
```markdown
|
12
|
+
---
|
13
|
+
intro: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
14
|
+
---
|
15
|
+
```
|
16
|
+
|
17
|
+
You can also add a video solution for each exercise by adding a `tutorial` property on the markdown frontmatter of it's README.md:
|
18
|
+
|
19
|
+
```markdown
|
20
|
+
---
|
21
|
+
intro: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
22
|
+
tutorial: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
23
|
+
---
|
24
|
+
```
|
@@ -1,5 +1,5 @@
|
|
1
|
-
# Welcome to <%= it.title %>
|
2
|
-
|
3
|
-
You have initialized the exercises with grading=`incremental`; meaning that your students will complete one single tutorial with clear and autograded steps from beginning to end.
|
4
|
-
|
1
|
+
# Welcome to <%= it.title %>
|
2
|
+
|
3
|
+
You have initialized the exercises with grading=`incremental`; meaning that your students will complete one single tutorial with clear and autograded steps from beginning to end.
|
4
|
+
|
5
5
|
Type `$ learnpack start` in your terminal to start the exercises.
|
@@ -1,5 +1,5 @@
|
|
1
|
-
# Bienvenido a <%= it.title %>
|
2
|
-
|
3
|
-
Has inicializado los ejercicios con grading=`incremental`; esto signigica que tus estudiantes completarán un solo tutorial con pasos claros e incrementales, desde el comienzo hasta el final.
|
4
|
-
|
1
|
+
# Bienvenido a <%= it.title %>
|
2
|
+
|
3
|
+
Has inicializado los ejercicios con grading=`incremental`; esto signigica que tus estudiantes completarán un solo tutorial con pasos claros e incrementales, desde el comienzo hasta el final.
|
4
|
+
|
5
5
|
Ejecuta `$ learnpack start` en la terminal para comenzar con los ejercicios.
|
@@ -1,26 +1,26 @@
|
|
1
|
-
# `01` Primer Ejercicio
|
2
|
-
|
3
|
-
Hemos creado este primer ejercicio como ejemplo. Lo puedes ubicar en la carpeta `./01-hello-world`.
|
4
|
-
|
5
|
-
1. Cada ejercicio debe estar ubicado en carpetas separadas y debe tener un archivo README.md con las instrucciones del ejercicio escrito en markdown.
|
6
|
-
2. Puedes tener un archivo README el cual será como una página de un libro, sin archivos de código.
|
7
|
-
3. También puedes agregar un archivo `README.[lenguaje].md` para traducciones, por ejemplo `README.es.md` para español.
|
8
|
-
|
9
|
-
## Inserta videos
|
10
|
-
|
11
|
-
Si quieres incluir algún video introductorio para cada ejercicio, agrega la propiedad `intro` en el inicio del README.md para ese ejercicio en particular:
|
12
|
-
|
13
|
-
```markdown
|
14
|
-
---
|
15
|
-
intro: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
16
|
-
---
|
17
|
-
```
|
18
|
-
|
19
|
-
Tambien puedes agregar un video explicando la solución para cada ejercicio agregando la propiedad `tutorial` al inicio del markdown del README.md correspondiente:
|
20
|
-
|
21
|
-
```markdown
|
22
|
-
---
|
23
|
-
intro: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
24
|
-
tutorial: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
25
|
-
---
|
26
|
-
```
|
1
|
+
# `01` Primer Ejercicio
|
2
|
+
|
3
|
+
Hemos creado este primer ejercicio como ejemplo. Lo puedes ubicar en la carpeta `./01-hello-world`.
|
4
|
+
|
5
|
+
1. Cada ejercicio debe estar ubicado en carpetas separadas y debe tener un archivo README.md con las instrucciones del ejercicio escrito en markdown.
|
6
|
+
2. Puedes tener un archivo README el cual será como una página de un libro, sin archivos de código.
|
7
|
+
3. También puedes agregar un archivo `README.[lenguaje].md` para traducciones, por ejemplo `README.es.md` para español.
|
8
|
+
|
9
|
+
## Inserta videos
|
10
|
+
|
11
|
+
Si quieres incluir algún video introductorio para cada ejercicio, agrega la propiedad `intro` en el inicio del README.md para ese ejercicio en particular:
|
12
|
+
|
13
|
+
```markdown
|
14
|
+
---
|
15
|
+
intro: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
16
|
+
---
|
17
|
+
```
|
18
|
+
|
19
|
+
Tambien puedes agregar un video explicando la solución para cada ejercicio agregando la propiedad `tutorial` al inicio del markdown del README.md correspondiente:
|
20
|
+
|
21
|
+
```markdown
|
22
|
+
---
|
23
|
+
intro: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
24
|
+
tutorial: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
25
|
+
---
|
26
|
+
```
|
@@ -1,26 +1,26 @@
|
|
1
|
-
# `01` First Exercise
|
2
|
-
|
3
|
-
We created this first exercise as an example, you can find it located in the folder `./01-hello-world`.
|
4
|
-
|
5
|
-
1. Every exercise must be located on a separate folder and it must have a README.md file inside with the exercise instructions written in markdown.
|
6
|
-
2. You can have just a README file and it will be like a page in a book, no code files.
|
7
|
-
3. You can also add a `README.[lang].md` file for translations, for example: `README.es.md` for spanish.
|
8
|
-
|
9
|
-
## Video compatibility
|
10
|
-
|
11
|
-
If you want to include some video introduction for each exercise, add a `intro` property in the markdown frontmatter of the README.md for that particular exercise:
|
12
|
-
|
13
|
-
```markdown
|
14
|
-
---
|
15
|
-
intro: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
16
|
-
---
|
17
|
-
```
|
18
|
-
|
19
|
-
You can also add a video solution for each exercise by adding a `tutorial` property on the markdown frontmatter of it's README.md:
|
20
|
-
|
21
|
-
```markdown
|
22
|
-
---
|
23
|
-
intro: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
24
|
-
tutorial: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
25
|
-
---
|
26
|
-
```
|
1
|
+
# `01` First Exercise
|
2
|
+
|
3
|
+
We created this first exercise as an example, you can find it located in the folder `./01-hello-world`.
|
4
|
+
|
5
|
+
1. Every exercise must be located on a separate folder and it must have a README.md file inside with the exercise instructions written in markdown.
|
6
|
+
2. You can have just a README file and it will be like a page in a book, no code files.
|
7
|
+
3. You can also add a `README.[lang].md` file for translations, for example: `README.es.md` for spanish.
|
8
|
+
|
9
|
+
## Video compatibility
|
10
|
+
|
11
|
+
If you want to include some video introduction for each exercise, add a `intro` property in the markdown frontmatter of the README.md for that particular exercise:
|
12
|
+
|
13
|
+
```markdown
|
14
|
+
---
|
15
|
+
intro: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
16
|
+
---
|
17
|
+
```
|
18
|
+
|
19
|
+
You can also add a video solution for each exercise by adding a `tutorial` property on the markdown frontmatter of it's README.md:
|
20
|
+
|
21
|
+
```markdown
|
22
|
+
---
|
23
|
+
intro: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
24
|
+
tutorial: "https://www.youtube.com/watch?v=YkgkThdzX-8"
|
25
|
+
---
|
26
|
+
```
|
@@ -1,5 +1,5 @@
|
|
1
|
-
# Welcome to <%= it.title %>
|
2
|
-
|
3
|
-
You have initialized the exercises with grading=`incremental`; meaning that your students will complete one single tutorial with clear and autograded steps from beginning to end.
|
4
|
-
|
1
|
+
# Welcome to <%= it.title %>
|
2
|
+
|
3
|
+
You have initialized the exercises with grading=`incremental`; meaning that your students will complete one single tutorial with clear and autograded steps from beginning to end.
|
4
|
+
|
5
5
|
Type `$ learnpack start` in your terminal to start the exercises.
|
@@ -1,5 +1,5 @@
|
|
1
|
-
# Bienvenido a <%= it.title %>
|
2
|
-
|
3
|
-
Has inicializado los ejercicios con grading=`incremental`; esto signigica que tus estudiantes completarán un solo tutorial con pasos claros e incrementales, desde el comienzo hasta el final.
|
4
|
-
|
1
|
+
# Bienvenido a <%= it.title %>
|
2
|
+
|
3
|
+
Has inicializado los ejercicios con grading=`incremental`; esto signigica que tus estudiantes completarán un solo tutorial con pasos claros e incrementales, desde el comienzo hasta el final.
|
4
|
+
|
5
5
|
Ejecuta `$ learnpack start` en la terminal para comenzar con los ejercicios.
|
@@ -1,5 +1,5 @@
|
|
1
|
-
# Welcome to <%= it.title %>
|
2
|
-
|
3
|
-
You have initialized the exercises without grading, meaning that your students will completed exercises without the need of coding.
|
4
|
-
|
1
|
+
# Welcome to <%= it.title %>
|
2
|
+
|
3
|
+
You have initialized the exercises without grading, meaning that your students will completed exercises without the need of coding.
|
4
|
+
|
5
5
|
Type `$ learnpack start` in your terminal to start the exercises.
|
@@ -1,5 +1,5 @@
|
|
1
|
-
# Bienvenido a <%= it.title %>
|
2
|
-
|
3
|
-
Has inicializado los ejercicios sin grading; lo que signigica que tus estudiantes completarán los ejercicios sin necesidad de codificar.
|
4
|
-
|
1
|
+
# Bienvenido a <%= it.title %>
|
2
|
+
|
3
|
+
Has inicializado los ejercicios sin grading; lo que signigica que tus estudiantes completarán los ejercicios sin necesidad de codificar.
|
4
|
+
|
5
5
|
Ejecuta `$ learnpack start` en la terminal para comenzar con los ejercicios.
|
package/src/utils/validators.ts
CHANGED
@@ -1,18 +1,18 @@
|
|
1
|
-
export function validURL(str: string) {
|
2
|
-
if (!str.includes('github.com')) {
|
3
|
-
return false
|
4
|
-
}
|
5
|
-
|
6
|
-
const pattern = new RegExp(
|
7
|
-
'^(https?:\\/\\/)?' + // protocol
|
8
|
-
'((([a-z\\d]([a-z\\d-]*[a-z\\d])*)\\.)+[a-z]{2,}|' + // domain name
|
9
|
-
'((\\d{1,3}\\.){3}\\d{1,3}))' + // OR ip (v4) address
|
10
|
-
'(\\:\\d+)?(\\/[-a-z\\d%_.~+]*)*' + // port and path
|
11
|
-
'(\\?[;&a-z\\d%_.~+=-]*)?' + // query string
|
12
|
-
'(\\#[-a-z\\d_]*)?$',
|
13
|
-
'i',
|
14
|
-
) // fragment locator
|
15
|
-
return !!pattern.test(str)
|
16
|
-
}
|
17
|
-
|
18
|
-
export default {validURL}
|
1
|
+
export function validURL(str: string) {
|
2
|
+
if (!str.includes('github.com')) {
|
3
|
+
return false
|
4
|
+
}
|
5
|
+
|
6
|
+
const pattern = new RegExp(
|
7
|
+
'^(https?:\\/\\/)?' + // protocol
|
8
|
+
'((([a-z\\d]([a-z\\d-]*[a-z\\d])*)\\.)+[a-z]{2,}|' + // domain name
|
9
|
+
'((\\d{1,3}\\.){3}\\d{1,3}))' + // OR ip (v4) address
|
10
|
+
'(\\:\\d+)?(\\/[-a-z\\d%_.~+]*)*' + // port and path
|
11
|
+
'(\\?[;&a-z\\d%_.~+=-]*)?' + // query string
|
12
|
+
'(\\#[-a-z\\d_]*)?$',
|
13
|
+
'i',
|
14
|
+
) // fragment locator
|
15
|
+
return !!pattern.test(str)
|
16
|
+
}
|
17
|
+
|
18
|
+
export default {validURL}
|
package/src/utils/watcher.ts
CHANGED
@@ -1,27 +1,27 @@
|
|
1
|
-
import * as chokidar from "chokidar"
|
2
|
-
import Console from "./console"
|
3
|
-
import * as debounce from "debounce"
|
4
|
-
import { IConfigManager } from "../models/config-manager"
|
5
|
-
|
6
|
-
export default (path: string, reloadSocket: (filename: string) => void) =>
|
7
|
-
new Promise((resolve /* , reject */) => {
|
8
|
-
Console.debug("PATH:", path)
|
9
|
-
const watcher = chokidar.watch(path, {
|
10
|
-
// TODO: This watcher is not ready yet
|
11
|
-
// ignored: /^(?=.*(\.\w+)$)(?!.*\.md$).*$/gm,
|
12
|
-
ignored: /\.pyc$/,
|
13
|
-
ignoreInitial: true,
|
14
|
-
})
|
15
|
-
const onChange = (eventname: string, _filename: string) => {
|
16
|
-
// Console.info(`Event ${eventname} detected. in file: ${_filename}`)
|
17
|
-
resolve(_filename)
|
18
|
-
reloadSocket(_filename)
|
19
|
-
}
|
20
|
-
|
21
|
-
watcher.on("all", debounce(onChange, 500, true))
|
22
|
-
// watcher.on('all', onChange)
|
23
|
-
process.on("SIGINT", function () {
|
24
|
-
watcher.close()
|
25
|
-
process.exit()
|
26
|
-
})
|
27
|
-
})
|
1
|
+
import * as chokidar from "chokidar"
|
2
|
+
import Console from "./console"
|
3
|
+
import * as debounce from "debounce"
|
4
|
+
import { IConfigManager } from "../models/config-manager"
|
5
|
+
|
6
|
+
export default (path: string, reloadSocket: (filename: string) => void) =>
|
7
|
+
new Promise((resolve /* , reject */) => {
|
8
|
+
Console.debug("PATH:", path)
|
9
|
+
const watcher = chokidar.watch(path, {
|
10
|
+
// TODO: This watcher is not ready yet
|
11
|
+
// ignored: /^(?=.*(\.\w+)$)(?!.*\.md$).*$/gm,
|
12
|
+
ignored: /\.pyc$/,
|
13
|
+
ignoreInitial: true,
|
14
|
+
})
|
15
|
+
const onChange = (eventname: string, _filename: string) => {
|
16
|
+
// Console.info(`Event ${eventname} detected. in file: ${_filename}`)
|
17
|
+
resolve(_filename)
|
18
|
+
reloadSocket(_filename)
|
19
|
+
}
|
20
|
+
|
21
|
+
watcher.on("all", debounce(onChange, 500, true))
|
22
|
+
// watcher.on('all', onChange)
|
23
|
+
process.on("SIGINT", function () {
|
24
|
+
watcher.close()
|
25
|
+
process.exit()
|
26
|
+
})
|
27
|
+
})
|