From f1d7ff49c6671ec1ce5bea0e4c62f45186abc46c Mon Sep 17 00:00:00 2001 From: Daniel Salazar Date: Mon, 11 Apr 2022 19:23:56 -0500 Subject: [PATCH] feat(back): #829 multiple directories - Support multiple directories for extendingMakesDir - Update doc --- README.md | 48 +++++++++++++++---------------- makes.nix | 2 +- src/evaluator/modules/default.nix | 18 ++++++++---- 3 files changed, 37 insertions(+), 31 deletions(-) diff --git a/README.md b/README.md index b12b9221..700039a0 100644 --- a/README.md +++ b/README.md @@ -250,7 +250,7 @@ Real life projects that run entirely on [Makes][MAKES]: - [makePythonPypiEnvironmentSources](#makepythonpypienvironmentsources) - [makeSopsEncryptedFile](#makesopsencryptedfile) - [Framework Configuration](#framework-configuration) - - [extendingMakesDir](#extendingmakesdir) + - [extendingMakesDirs](#extendingmakesdirs) - [inputs](#inputs) - [Database](#database) - [dynamoDb](#dynamodb) @@ -808,23 +808,23 @@ Example usage with [direnv][DIRENV] on remote projects: ```bash -$ cat /path/to/some/folder/.envrc +$ cat /path/to/some/dir/.envrc source "$(m github:fluidattacks/makes@main /dev/example)/template" -# Now every time you enter /path/to/some/folder +# Now every time you enter /path/to/some/dir # the shell will automatically load the environment -$ cd /path/to/some/folder +$ cd /path/to/some/dir - direnv: loading /path/to/some/folder/.envrc + direnv: loading /path/to/some/dir/.envrc direnv: export ~PATH -/path/to/some/folder $ hello +/path/to/some/dir $ hello Hello, world! -# If you exit the folder, the development environment is unloaded -/path/to/some/folder $ cd .. +# If you exit the directory, the development environment is unloaded +/path/to/some/dir $ cd .. direnv: unloading @@ -839,24 +839,24 @@ Example usage with [direnv][DIRENV] on a local project: ```bash -$ cat /path/to/some/folder/.envrc +$ cat /path/to/some/dir/.envrc cd /path/to/my/project source "$(m . /dev/example)/template" -# Now every time you enter /path/to/some/folder +# Now every time you enter /path/to/some/dir # the shell will automatically load the environment -$ cd /path/to/some/folder +$ cd /path/to/some/dir - direnv: loading /path/to/some/folder/.envrc + direnv: loading /path/to/some/dir/.envrc direnv: export ~PATH -/path/to/some/folder $ hello +/path/to/some/dir $ hello Hello, world! -# If you exit the folder, the development environment is unloaded -/path/to/some/folder $ cd .. +# If you exit the directory, the development environment is unloaded +/path/to/some/dir $ cd .. direnv: unloading @@ -1441,7 +1441,7 @@ Types: - python (`enum [ "3.7" "3.8" "3.9" ]`): Python interpreter version that your package/module is designed for. - src (`str`): - Path to the file or folder that contains the tests code. + Path to the file or directory that contains the tests code. - searchPaths (`asIn makeSearchPaths`): Optional. Arguments here will be passed as-is to `makeSearchPaths`. Defaults to `makeSearchPaths`'s defaults. @@ -1455,7 +1455,7 @@ Types: The final test structure looks like this: ```bash - /tmp/some-random-unique-folder + /tmp/some-random-unique-dir ├── __project__ # The entire source code of your project │  ├── ... │  └── path/to/src @@ -1467,7 +1467,7 @@ Types: And we will run [pytest][PYTEST] like this: - `$ pytest /tmp/some-random-unique-folder/__project__/path/to/src` + `$ pytest /tmp/some-random-unique-dir/__project__/path/to/src` Defaults to `{ }`. @@ -2481,14 +2481,14 @@ m github:fluidattacks/makes@22.04 /utils/makeSopsEncryptedFile \ ## Framework Configuration -### extendingMakesDir +### extendingMakesDirs -Path to the magic folder where Makes extensions will be loaded from. +Paths to magic directories where Makes extensions will be loaded from. Types: -- extendingMakesDir (`str`): Optional. - Defaults to `"/makes"`. +- extendingMakesDirs (`listOf str`): Optional. + Defaults to `["/makes"]`. ### inputs @@ -3472,7 +3472,7 @@ Types: you can omit this parameter and execute Makes, Makes will tell you the correct SHA256 on failure. - stripRoot (`bool`): Optional. - Most archives have a symbolic top-level folder + Most archives have a symbolic top-level directory that is discarded during unpack phase. If this is not the case you can set this flag to `false`. Defaults to `true`. @@ -3750,7 +3750,7 @@ $ m . /example :warning: This function is only available on Linux at the moment. -Cook the `node_modules` folder +Cook the `node_modules` directory for the given [NPM][NPM] project. Types: diff --git a/makes.nix b/makes.nix index 54fc6f7e..925c3bd0 100644 --- a/makes.nix +++ b/makes.nix @@ -60,7 +60,7 @@ VAR_NAME = "test"; }; }; - extendingMakesDir = "/makes"; + extendingMakesDirs = ["/makes"]; formatBash = { enable = true; targets = ["/"]; diff --git a/src/evaluator/modules/default.nix b/src/evaluator/modules/default.nix index 95388f70..b7fdf08c 100644 --- a/src/evaluator/modules/default.nix +++ b/src/evaluator/modules/default.nix @@ -64,9 +64,9 @@ type = lib.types.str; default = ""; }; - extendingMakesDir = lib.mkOption { - default = "/makes"; - type = lib.types.str; + extendingMakesDirs = lib.mkOption { + default = ["/makes"]; + type = lib.types.listOf lib.types.str; }; config = lib.mkOption { @@ -104,9 +104,15 @@ (builtins.readDir path))); in ( - attrsOptional - (builtins.pathExists (projectSrc + config.extendingMakesDir)) - (attrsFromPath (projectPath config.extendingMakesDir) []) + builtins.foldl' + lib.mergeAttrs + {} + (builtins.map + (dir: + attrsOptional + (builtins.pathExists (projectSrc + dir)) + (attrsFromPath (projectPath dir) [])) + config.extendingMakesDirs) ) // { __all__ =