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

LDoc: Allow additional fields in enum objects #134

Open
jakubg1 opened this issue Nov 24, 2024 · 1 comment
Open

LDoc: Allow additional fields in enum objects #134

jakubg1 opened this issue Nov 24, 2024 · 1 comment
Assignees
Labels
A: Documentation Issue with documentation. D: Feature Request A feature that may be implemented in a future version. R: WIP The resolution is in progress.

Comments

@jakubg1
Copy link
Owner

jakubg1 commented Nov 24, 2024

Right now, to add a field to an enum object that is applicable to any of the types, you have to clone it in all of the choices. Make it possible to add such fields by assigning them a name.

Example:

- (object) {type: Type of the Collectible Generator Entry.} - A collectible generator entry.
    - "collectible" - Evaluates to a single collectible.
        - name (string) - A collectible ID to be evaluated to.
        - conditions* (array) - A list of conditions. All of them must be satisfied. In other case, this entry will not generate any collectibles and return an empty list.
            - (%boolean) - A single condition.
    - "collectibleGenerator" - Evaluates to another collectible generator result.
        - generator (CollectibleGenerator) - Path to another Collectible Generator which will be evaluated.
        - conditions* (array) - A list of conditions. All of them must be satisfied. In other case, this entry will not generate any collectibles and return an empty list.
            - (%boolean) - A single condition.
    - "combine" - Evaluates a list of given entries and returns a list of all collectibles generated.
        - entries (array) - A list of collectible entries to be evaluated.
            - (#) - A single collectible generator entry.
        - conditions* (array) - A list of conditions. All of them must be satisfied. In other case, this entry will not generate any collectibles and return an empty list.
            - (%boolean) - A single condition.
    - "repeat" - Evaluates a given entry a number of times and returns a list of all collectibles generated.
        - entry (#) - A collectible entry to be evaluated.
        - count (%integer) [>=2] - How many times the entry should be evaluated.
        - conditions* (array) - A list of conditions. All of them must be satisfied. In other case, this entry will not generate any collectibles and return an empty list.
            - (%boolean) - A single condition.
    - "randomPick" - Evaluates all the choices, discards empty ones, and selects one of the remaining results at random.
        - pool (array) - A list of choices to be picked from.
            - (object) - A single choice.
                - entry (#) - A collectible generator entry to be evaluated.
                - weight* (number) [>0] - The bigger this number is, the more likely this option is to be chosen. Defaults to 1.
        - conditions* (array) - A list of conditions. All of them must be satisfied. In other case, this entry will not generate any collectibles and return an empty list.
            - (%boolean) - A single condition.

would turn into

- (object) {type: Type of the Collectible Generator Entry.} - A collectible generator entry.
    - "collectible" - Evaluates to a single collectible.
        - name (string) - A collectible ID to be evaluated to.
    - "collectibleGenerator" - Evaluates to another collectible generator result.
        - generator (CollectibleGenerator) - Path to another Collectible Generator which will be evaluated.
            - (%boolean) - A single condition.
    - "combine" - Evaluates a list of given entries and returns a list of all collectibles generated.
        - entries (array) - A list of collectible entries to be evaluated.
            - (#) - A single collectible generator entry.
            - (%boolean) - A single condition.
    - "repeat" - Evaluates a given entry a number of times and returns a list of all collectibles generated.
        - entry (#) - A collectible entry to be evaluated.
        - count (%integer) [>=2] - How many times the entry should be evaluated.
            - (%boolean) - A single condition.
    - "randomPick" - Evaluates all the choices, discards empty ones, and selects one of the remaining results at random.
        - pool (array) - A list of choices to be picked from.
            - (object) - A single choice.
                - entry (#) - A collectible generator entry to be evaluated.
                - weight* (number) [>0] - The bigger this number is, the more likely this option is to be chosen. Defaults to 1.
    - conditions* (array) - A list of conditions. All of them must be satisfied. In other case, this entry will not generate any collectibles and return an empty list.
        - (%boolean) - A single condition.
@jakubg1 jakubg1 added D: Feature Request A feature that may be implemented in a future version. A: Documentation Issue with documentation. labels Nov 24, 2024
@jakubg1 jakubg1 added this to the Beta 5.0.0 release milestone Nov 24, 2024
@jakubg1
Copy link
Owner Author

jakubg1 commented Nov 25, 2024

Partially implemented in 9b2196e (works for Config Classes, but doesn't work for schemas yet).

@jakubg1 jakubg1 self-assigned this Nov 25, 2024
@jakubg1 jakubg1 added the R: WIP The resolution is in progress. label Nov 25, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A: Documentation Issue with documentation. D: Feature Request A feature that may be implemented in a future version. R: WIP The resolution is in progress.
Projects
None yet
Development

No branches or pull requests

1 participant