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

There are no obvious links to the runtime downloads #20

Open
Carnildo opened this issue Mar 23, 2023 · 1 comment
Open

There are no obvious links to the runtime downloads #20

Carnildo opened this issue Mar 23, 2023 · 1 comment

Comments

@Carnildo
Copy link

Using Kaitai Struct in a program requires additional downloads beyond what's available from clicking the "download" link, but this is not made clear, and there are no obvious links to them.

Steps to reproduce:

  1. Click the "download" link.
  2. Download and install the "universal .zip" package or the "Linux .deb" package (or, presumably, the Windows MSI installer).
  3. Use the Kaitai Struct compiler to generate code.

Expected result:

You now have everything you need to use Kaitai Struct in your program.

Actual result:

You still need to download the appropriate runtime. If there are any download links for the runtimes on the site, I've been unable to find them.

@generalmimon
Copy link
Member

Yes, you're right. Our website/documentation is generally not very good at communicating this to the users. I've added some instructions in this regard to the individual format pages at formats.kaitai.io (see kaitai-io/kaitai_struct#571), but that was only for the most popular languages. And it obviously deserves more attention on the homepage too.

but this is not made clear, and there are no obvious links to them.

Technically, it's mentioned in https://kaitai.io/#using-ks-in-your-project:

Using KS in your project

Typically, using formats described in KS in your project involves the following steps:

  • Describe the format — i.e. create a .ksy file
  • Use a visualizer to debug the format and ensure that it parses data properly
  • Compile the .ksy file into a target language source file and include that file into your project
  • Add the KS runtime library for your particular language into your project (don’t worry, it’s small and it’s there mostly to ensure readability of generated code)
  • Use the generated class(es) to parse your binary file or stream and access its components

and the links to individual runtime library repos is in https://kaitai.io/#download under Licensing:

but I agree this is not very clear or sufficient, and it's not an excuse. I'm aware that this is an issue. At least the homepage deserves a bit of rework to address it.

Most users appear to ultimately figure out that they need the runtime library as well, but I'm not entirely sure how they do that, because it's indeed not very well documented.

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

No branches or pull requests

2 participants