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

A simple picocli/native-image ion-java CLI #988

Draft
wants to merge 132 commits into
base: ion-11-encoding
Choose a base branch
from

Conversation

jobarr-amzn
Copy link
Contributor

Issue #, if available:

Description of changes: Supports formatted transcription of input files or stdin to a destination file or stdout.

help showing subcommands

❯ jion help
Usage: jion [-hV] [-f=<format>] [-o=FILE] [FILE...] [COMMAND]
      [FILE...]
  -f, --format, --output-format=<format>
                      Output format, from the set (text | pretty | binary | none).
  -h, --help          Show this help message and exit.
  -o, --output=FILE   Output file
  -V, --version       Print version information and exit.
Commands:
  help          Display help information about the specified command.
  cat, process  concatenate FILE(s) in the requested Ion output format

help cat showing inherited options

❯ jion help cat
Usage: jion cat [-hV] [-f=<format>] [-o=FILE]
concatenate FILE(s) in the requested Ion output format
  -f, --format, --output-format=<format>
                      Output format, from the set (text | pretty | binary | none).
  -h, --help          Show this help message and exit.
  -o, --output=FILE   Output file
  -V, --version       Print version information and exit.

Rewriting Ion 1.1 with a macro invocation to Ion 1.0

❯ echo '$ion_1_1 (:make_string "hello" " " "world")' | jion cat -f binary | hexyl
┌────────┬─────────────────────────┬─────────────────────────┬────────┬────────┐
│00000000│ e0 01 00 ea 8b 68 65 6c ┊ 6c 6f 20 77 6f 72 6c 64 │ו⋄××hel┊lo world│
└────────┴─────────────────────────┴─────────────────────────┴────────┴────────┘

By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.

popematt and others added 30 commits September 8, 2024 18:10
tgregg and others added 2 commits October 30, 2024 13:37
* Use add/set_macros/symbols in ManagedWriter

* Apply suggestions from code review

Removing redundant checks

Co-authored-by: Matthew Pope <[email protected]>

* Remove obsoleted checks/comments

---------

Co-authored-by: Matthew Pope <[email protected]>
@jobarr-amzn jobarr-amzn requested a review from zslayton November 4, 2024 19:52
@jobarr-amzn
Copy link
Contributor Author

Ah oops, I built this locally with GraalVM CE 17 as described in the comments in build.gradle.kts.

Looks like it will need more refinement of the build script to fix the build in other contexts- I want to only build the native component when GRAALVM_HOME is set. I can fix this... should probably extract to a separate Gradle project anyway.

@jobarr-amzn jobarr-amzn removed the request for review from zslayton November 4, 2024 20:02
@jobarr-amzn jobarr-amzn marked this pull request as draft November 4, 2024 20:03
jobarr-amzn and others added 4 commits November 13, 2024 11:45
* Test TDL reference to pre-existing macros

* Support reference of pre-existing macros in TDL

- Adds a DEFAULT Encoding context
- Adds a MacroTable abstraction

* PR suggestions

* Comment asking for more modeling attention in MutableMacroTable
jobarr-amzn and others added 4 commits December 12, 2024 12:06
* Restack macros and symbols to meet spec changes

* Update ion-tests for symbol and macro restack

* Fix comment in src/test/java/com/amazon/ion/impl/bin/WriteBufferTest.java

Co-authored-by: Tyler Gregg <[email protected]>

---------

Co-authored-by: Tyler Gregg <[email protected]>
- Supports formatted transcription of input files or stdin to a
  destination file or stdout

# Conflicts:
#	ion-java-cli/src/main/java/com/amazon/tools/cli/OutputFormat.java
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants