Skip to content

Conversation

wagoodman
Copy link
Contributor

@wagoodman wagoodman commented May 18, 2023

This PR replaces what common patterns have already been established and hoisted into clio and bubbly. See DEVELOPING.md additions made in this PR for more details on the package layout.

At a high-level, here are the changes:

  • Removes the application object, eventloop, logger UI, config loading, version command, flag binding with viper, and profiling concerns (replaced by clio)
  • Removes bubbletea components (replaced by bubbly)

High level focuses of this PR:

  • lean into stronger separation of concerns and make it more difficult to accidentally misuse elements in the wrong package (e.g. by pushing internal packages lower in the API when possible)
  • focus on CLI-lib and core-lib divisions and usage
  • foster re-use of common patterns across applications when warranted

Detailed changes:

  • removed CLI interaction from the core lib (load.P12 -> loadP12Interactively) as this is a CLI concern.
  • splits the UI (an internal concern) and the handling of UI events into bubbletea models (a CLI lib concern). This allows for shared UI interactions for lib users of quill in the same way that grype uses syft UI elements in the grype UI. (see cmd/quill/cli/ui/handler.go and cmd/quill/internal/ui/ui.go)
  • version extracted from the build derived from ldflags is a main package-only concern, thus, this information is injected downstream from main instead of pulling from a package in static-fashion (see cmd/quill/main.go). Why? because this can only be valid when the build is controlled since specific ldflags are required.
  • replaced the log redactor with the common go-logger log redactor
  • the event child packages have been combined into the event package. Why? This separation seemed weak, where the original reason was to separate the definitions of events from the capabilities, however, this does not apply to these monitor/parser objects.

wagoodman added 7 commits May 17, 2023 17:24
Signed-off-by: Alex Goodman <[email protected]>
Signed-off-by: Alex Goodman <[email protected]>
Signed-off-by: Alex Goodman <[email protected]>
Signed-off-by: Alex Goodman <[email protected]>
@wagoodman wagoodman requested a review from a team May 31, 2023 20:49
@wagoodman wagoodman marked this pull request as ready for review May 31, 2023 20:49
Signed-off-by: Alex Goodman <[email protected]>
@wagoodman wagoodman merged commit f41308e into main Jun 30, 2023
@wagoodman wagoodman deleted the port-to-clio branch June 30, 2023 20:09
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