feat(build): allow create-class to drop classes into cwd #3193
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
create-class
creates class files in current working directoryThis PR introduces several new enhancements to the
create-class
script:-d
-d
is used:-s
npx neo-cc
(test w/npm i -g
for repository clones)Changes
The original implementation remains unchanged regarding functionality, some lines had to be shifted and re-arranged into conditional statements given the new option the script provides. It was also necessary to distinguish between - and further reuse - the original
cwd
- and__dirname
-variables, so the script can now be run outside of theneo
-folder.Features
-d
OptionThe
-d
options stands fordrop
and advises the script to run in a none-interactive environment. It will compute the namespace based on the current working directory up to the directory that is either used from the value found in the script'ssourceRootDirs
-array, or specified with the-s
-option.Example:
The user has an application in
/neo/apps/acme
and wants to create a new class foracme.view.masterDetail.TableView
.cd /neo/apps/acme/view/masterDetail npx neo-cc -c TableView -b component.Base -d
results in a file
TableView.mjs
created at/neo/apps/acme/view/masterDetail
with the following contents:Note, that
apps
is by default mentioned in thesourcesRootDir
of the script. The user can overwrite the directory where the sources (and therefore top-level namespaces reside) by using the -s option:Example:
The user has an application in
/neo/FOLDER/acme
and wants to create a new class foracme.view.masterDetail.TableView
.cd /neo/FOLDER/acme/view/masterDetail npx neo-cc -c TableView -b component.Base -d -s FOLDER
What kind of change does this PR introduce? (check at least one)
Does this PR introduce a breaking change? (check one)
If yes, please describe the impact and migration path for existing applications:
The PR fulfills these requirements:
dev
branch, not themaster
branchfix #xxx[,#xxx]
, where "xxx" is the issue number)If adding a new feature, the PR's description includes: