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

[Feat] Add JSON output to r.colors.out #3537

Closed
petrasovaa opened this issue Mar 27, 2024 · 3 comments · Fixed by #4555
Closed

[Feat] Add JSON output to r.colors.out #3537

petrasovaa opened this issue Mar 27, 2024 · 3 comments · Fixed by #4555
Labels
enhancement New feature or request gsoc Reserved for Google Summer of Code student(s)

Comments

@petrasovaa
Copy link
Contributor

Add JSON output for easy parsing of r.colors.out output.

Describe the solution you'd like
Adding option format, it would be something like format=plain for the current output format and format=json for the JSON output. There is a newly added parson library to GRASS (#3028), so it should be used here.

See also discussion in #3019.

A test should be included.
A possible JSON layout could be:

[
  {
    "value": 0,
    "red": 255,
    "green": 0,
    "blue": 0
  },
  {
    "value": 1,
    "red": 0,
    "green": 255,
    "blue": 0
  },
  {
    "value": 2,
    "red": 0,
    "green": 0,
    "blue": 255
  }
]
@petrasovaa petrasovaa added enhancement New feature or request gsoc Reserved for Google Summer of Code student(s) labels Mar 27, 2024
@cwhite911
Copy link
Contributor

It might be nice to have the output in a usable formats.

[
 {
    "value": 0,
    "hex": "#FF0000",
    "rgb": "rgb(255, 0, 0)",
    "rgb": "rgb(255, 0, 0, 0)",
    "hsl":  "hsl(0, 100, 50)"
  }
]

@NishantBansal2003
Copy link
Contributor

Hey, I was trying to look up this issue. Can you help me out a little? I want to know how I can test any changes I make to check their output.

[
 {
    "value": 0,
    "hex": "#FF0000",
    "rgb": "rgb(255, 0, 0)",
    "rgb": "rgb(255, 0, 0, 0)",
    "hsl":  "hsl(0, 100, 50)"
  }
]

Also, if you could provide a specific test that generates this output, I can use it to test my changes. Additionally, can you tell me how to test the changes overall, including some commands for integration tests?

@petrasovaa
Copy link
Contributor Author

Thanks for looking into this! I suggest to review r.colors.out documentation. You can try to write a simple test with pytest, see notes and look up some existing examples, e.g. in r.mask.status or v.dissolve. Similarly to r.mask.status example, you would create a small temporary raster and run r.colors.out on that one.

For the JSON support, look at some examples a GSoC student did this year to keep it consistent.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request gsoc Reserved for Google Summer of Code student(s)
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants