docs: embed defaults in app
Alan Pearce alan@alanpearce.eu
Thu, 09 May 2024 18:18:59 +0200
3 files changed, 45 insertions(+), 45 deletions(-)
M config.toml → config.toml
@@ -1,38 +1,9 @@ [sources.nixos] - name = "NixOS" enable = true - type = "channel" channel = "nixos-unstable" - import-path = "nixos/release.nix" - attribute = "options" - output-path = "share/doc/nixos/options.json" - [sources.repo] - type = "github" - owner = "NixOS" - repo = "nixpkgs" [sources.darwin] - name = "darwin" enable = true - type = "channel" - channel = "darwin" - import-path = "release.nix" - attribute = "options" - output-path = "share/doc/darwin/options.json" - [sources.repo] - type = "github" - owner = "LnL7" - repo = "nix-darwin" [sources.home-manager] - name = "home-manager" enable = true - type = "channel" - channel = "home-manager" - import-path = "default.nix" - attribute = "docs.json" - output-path = "share/doc/home-manager/options.json" - [sources.repo] - type = "github" - owner = "nix-community" - repo = "home-manager"
M import/main.go → import/main.go
@@ -11,7 +11,6 @@ "path" "searchix/internal/config" "searchix/internal/importer" "searchix/internal/search" - "slices" "strings" "time" ) @@ -27,11 +26,7 @@ if err != nil { log.Fatal(err) } - enabledSources := slices.DeleteFunc(cfg.Sources, func(s importer.Source) bool { - return !s.Enable - }) - - if len(enabledSources) == 0 { + if len(cfg.Sources) == 0 { slog.Info("No sources enabled") return @@ -47,8 +42,8 @@ defer cancel() var imp importer.Importer var hadErrors bool - for _, source := range enabledSources { - logger := slog.With("name", source.Name, "importer", source.Type.String()) + for name, source := range cfg.Sources { + logger := slog.With("name", name, "importer", source.Type.String()) logger.Debug("starting importer") switch source.Type {
M internal/config/config.go → internal/config/config.go
@@ -7,6 +7,7 @@ "net/url" "os" "searchix/internal/file" "searchix/internal/importer" + "time" "github.com/pelletier/go-toml/v2" "github.com/pkg/errors" @@ -42,18 +43,51 @@ Headers: map[string]string{ "x-content-type-options": "nosniff", }, Sources: map[string]importer.Source{ - "nixos": importer.Source{ - Name: "NixOS", - Enable: true, - Type: importer.Channel, - Channel: "nixos-unstable", - ImportPath: "nixos/release.nix", - Attribute: "options", - OutputPath: "share/doc/nixos/options.json", + "nixos": { + Name: "NixOS", + Enable: true, + Type: importer.Channel, + Channel: "nixpkgs", + ImportPath: "nixos/release.nix", + Attribute: "options", + OutputPath: "share/doc/nixos/options.json", + FetchTimeout: 5 * time.Minute, + ImportTimeout: 15 * time.Minute, Repo: importer.Repository{ Type: "github", Owner: "NixOS", Repo: "nixpkgs", + }, + }, + "darwin": { + Name: "darwin", + Enable: false, + Type: importer.Channel, + Channel: "nix-darwin", + ImportPath: "release.nix", + Attribute: "options", + OutputPath: "share/doc/darwin/options.json", + FetchTimeout: 5 * time.Minute, + ImportTimeout: 15 * time.Minute, + Repo: importer.Repository{ + Type: "github", + Owner: "LnL7", + Repo: "nix-darwin", + }, + }, + "home-manager": { + Name: "home-manager", + Enable: false, + Type: importer.Channel, + ImportPath: "default.nix", + Attribute: "docs.json", + OutputPath: "share/doc/home-manager/options.json", + FetchTimeout: 5 * time.Minute, + ImportTimeout: 15 * time.Minute, + Repo: importer.Repository{ + Type: "github", + Owner: "nix-community", + Repo: "home-manager", }, }, },