-
-
Notifications
You must be signed in to change notification settings - Fork 81
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
WIP: Refactor crates #640
WIP: Refactor crates #640
Conversation
0aa59f7
to
0b9d07a
Compare
32b22f2
to
3a6cf03
Compare
3a6cf03
to
81261fc
Compare
Hey just chipping in my opinion on the questions posed above.
I could try to do this and you could update where I misunderstood how things work. Give me a chance to test my understanding in a way that I can get feedback on.
I actually think that's a pretty good name for it. Makes it clear what it is and has trippy in the name to make it easier to discover. It would also help with deciding what code should go where. Anything related to UI would not belong in there based on that name in my opinion.
I don't know the difference between this question and the previous one. But wouldn't it being separate be a prerequisite for it having a separate name? One thing to consider is that if we want to support feature flags and we keep both of them in the same crate then the binary can only use the default-features. Actually the binary would have to use exactly the default features, to the best of my checking. No default features can be left out and no other features can be used in the binary. My basis for this was the checking we did when we were writing cargo-leet. We ended up having to set the default features to match what the binary needed because that was the only option we could find without using a separate crate. I also plan to publish this to crates.io so we can test options on that project as it is still pre-1.0, and that's the point of that project. It was created and is designed to provide opportunity to experiment and learn.
Does this mean separate create for capabilities? If yes then I guess that could be a good idea but I'm not sure it's worth it. Might be better to use feature flags (especially with the improved support that just got added to the comiler)
IMO it should stay with the executable whereever that ends up (which I don't think should move to avoid causing problems for anyone). |
Hi @c-git
Always welcome!
Sure; the "library" portion of trippy lives in the
At a high level I think of trippy as consisting of two things; a library for performing tracing (so The backend, whilst part of the tool, is independent of the front end and is responsible for collecting / aggregating the data from the library for each round of tracing, calculating stats and so forth, which the frontend can then consume directly. The bulk of the work happens in I don't think it makes sense for the backend to be bundled with the tool, as it could be useful in other contexts (such as a service for monitoring and alerting!) and it doesn't belong in the library either as it is not strictly needed for tracing (the reports do not currently use it, for example). Therefore it may make sense for this to live in a standalone crate which depends only on the
The motivation here is to remove the need for the frontend crate to have to include any platform specific code or crates. Currently the only place trippy needs platform specific code, other than the tracing library network code (i.e. It's not a big deal and i'm undecided on whether this separation makes sense (or indeed whether it makes sense to split trippy up as per this pr at all).
Yes, I think that's probably right. I think it may be possible to remove this entirely by tweaking |
Ok I follow, I'll start with the clap change you recommended then I'll try to document just the current lib stuff and we'll go from there. I think the more you can make parts reusable the better as I already know one person who would reuse them (me... ). I still haven't had a chance to test out open telemetry but I'm not opposed to that option. |
Closing this as I don't think it is the right approach and even if we do this in the future this PR is very stale and would need to be redone. |
trippy-core
?)trippy-backend
crate?package.metadata.generate-rpm
live?