-
Notifications
You must be signed in to change notification settings - Fork 58
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
Dependency on libyaml not documented #224
Comments
Hello! The README file says it here: https://github.com/tlsa/libcyaml/blob/main/README.md?plain=1#L40 Maybe I can make it clearer. |
Maybe it's worth to add a small section before or under If it works for you, I can reuse the list of deps from my project ( https://github.com/danielealbano/cachegrand/blob/main/docs/build-from-source.md ), clean it up and add it to the section |
@tlsa, it would seem I can't read. Oops. Now I do think you can make it clearer. Listing the libyaml dependency as a "feature" probably contributed to my missing it: I'm currently taking over a project that uses LibCYAML, and until the thing build I had no interest in your features. We could also argue that dependencies aren't features. If libyaml is your only significant dependency (besides a C compiler), you could perhaps lead with something like "LibCYAML is a C library for reading and writing structured YAML documents. It is written in ISO C11, based on libyaml, and licensed under the ISC licence." Or something similar under the "overview" section. @danielealbano, a clear list of dependencies under a dedicated section (if we have many dependencies) or under the Building section (if we have few dependencies) would work wonders. |
When I was writing that, the reason I considered it a feature is that it gives people the assurance that under the hood it's the canonical implementation of the YAML spec. When you get to the edge cases there are about as many different behaviors as there are implementations. See this overview of the situation with JSON parsers, and YAML is a far more complex standard. |
Sounds like a pretty core selling point, then. It definitely belongs to your elevator pitch. If not in the very first sentence like I've shown, at least in the overview. That way people know right away you're building on a strong foundation. (And grumpy users like me will stop bitching about not finding dependencies. 😄) |
Hi,
When I first tried to build libcyaml, I got a compile error about
yaml.h
being missing. Digging to the source code I noticed that the error was normal, because I did not have libyaml installed on my system.The dependency itself is okay, but the README makes no mention of libyaml, and I don't see an INSTALL file either. Perhaps you should mention that you're building on top of libyaml? From the look of it libcyaml is an overley of top of libyaml that adds schema capabilities. You may also have other advantages over libyaml (I don't know, I just got in), that may be worth mentioning explicitly.
Explicitly documenting the dependence and the additional features of libcyaml over libyaml would help newcomers decide which is best for them. Me for instance just have one small configuration file, so I probably won't ever need the schemas. But I could consider sticking with libcyaml if its API is clearly easier to use.
The text was updated successfully, but these errors were encountered: