Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

#992: added design doc for script options #477

Merged
merged 26 commits into from
Jan 20, 2025
Merged
Changes from 2 commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
d2c2f6e
#991: Added Design Doc and Requirements Doc for Script Options parser
tomuben Oct 24, 2024
9385004
Updated design document
tomuben Oct 24, 2024
6c4c049
Updated design document
tomuben Nov 14, 2024
b9a7904
Updated design document
tomuben Nov 15, 2024
2b1e472
Updated design document
tomuben Nov 15, 2024
9671883
Updated design document & requirements document
tomuben Nov 15, 2024
93dca60
Added a GH workflow to run
tomuben Nov 15, 2024
9e35421
Fixed oft.yaml
tomuben Nov 15, 2024
3911606
Fixed oft.yaml
tomuben Nov 15, 2024
d0fee61
Fixed oft.yaml
tomuben Nov 15, 2024
a2fcff1
Fixed oft.yaml
tomuben Nov 15, 2024
7910608
Fixed oft.yaml
tomuben Nov 15, 2024
24caddc
Fixed oft.yaml
tomuben Nov 15, 2024
14425fa
Removed `Needs: req` in script_options_design.md
tomuben Nov 15, 2024
6800239
Fixed findings from OFT
tomuben Nov 15, 2024
1f08f8d
Fixed findings from OFT
tomuben Nov 15, 2024
207e27f
Fixed findings from review
tomuben Nov 22, 2024
af0d8ee
Merge branch 'master' into doc/992_add_design_doc_for_script_options
tomuben Dec 4, 2024
e80f66f
Merge remote-tracking branch 'origin/master' into doc/992_add_design_…
tomuben Jan 8, 2025
10072ee
Apply suggestions from code review
tomuben Jan 8, 2025
72dab60
Renamed design decision `Java %scriptclass Option Handling in Design`…
tomuben Jan 8, 2025
73184e1
Merge remote-tracking branch 'origin/doc/992_add_design_doc_for_scrip…
tomuben Jan 8, 2025
c1061af
Findings from review
tomuben Jan 8, 2025
edfc01d
Fixes from review
tomuben Jan 20, 2025
3976379
Merge remote-tracking branch 'origin/master' into doc/992_add_design_…
tomuben Jan 20, 2025
0eabe59
Update exaudfclient/docs/script_options_design.md
tomuben Jan 20, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 4 additions & 4 deletions exaudfclient/docs/script_options_design.md
Original file line number Diff line number Diff line change
Expand Up @@ -178,11 +178,11 @@ The following diagram shows how the scripts are collected in the recursive algor

### Parser Implementation V1

The legacy parser (V1) parser searches for one specific script option. The parser starts from the beginning of the script code. If found, the parser immediately removes the script option from the script code and returns the option value. It validates the
The legacy parser (V1) parser searches for one specific script option. The parser starts from the beginning of the script code. If found, the parser immediately removes the script option from the script code and returns the option value.

### Parser Implementation V2

The parser provides an interface to parse the UDF script for all options at once. All found script options need to be collected in an associative container. Internally. the parses uses [ctpg](https://github.com/peter-winter/ctpg) to parse the UDF script code line-by-line.
The parser provides an interface to parse the UDF script for all options at once. All found script options need to be collected in an associative container. Internally, the parses uses [ctpg](https://github.com/peter-winter/ctpg) to parse the UDF script code line-by-line.

## Cross-cutting Concerns

Expand Down Expand Up @@ -366,8 +366,8 @@ Tags: V2
### Java %jar Option Collection
`dsn~java-jar-option-collection~1`

Implement an algorithm in class `ConverterV2` to split the given Jar option value by colon (':') and then collect the found Jar options in a list.

Implement an algorithm in class `ConverterV2` which parses the given Jar option value in expected format `<file1>:<file2>:...:<filen>`. The algorithm shall splut by colon (':') and then collect the found Jar options in a list.
tomuben marked this conversation as resolved.
Show resolved Hide resolved
Compare [OpenJdk implementation](https://github.com/AdoptOpenJDK/openjdk-jdk11/blob/19fb8f93c59dfd791f62d41f332db9e306bc1422/src/java.base/share/classes/jdk/internal/loader/URLClassPath.java#L174) of parsing the classpath.

Covers:
- `req~java-jar-option-handling-v2~1`
Expand Down
Loading