updatePendingPackages updates the lockfile entries for each package, using the right strategy per package kind. Flake refs warn-and-continue on failure (see #1180 / #1840); versioned nixpkgs packages abort the update on failure. Unversioned non-flake entries are left alone.
(pkgs []*devpkg.Package)
| 124 | // failure (see #1180 / #1840); versioned nixpkgs packages abort the update on |
| 125 | // failure. Unversioned non-flake entries are left alone. |
| 126 | func (d *Devbox) updatePendingPackages(pkgs []*devpkg.Package) error { |
| 127 | for _, pkg := range pkgs { |
| 128 | if pkgtype.IsFlake(pkg.Raw) { |
| 129 | if err := d.updateDevboxPackage(pkg); err != nil { |
| 130 | ux.Fwarningf(d.stderr, "Failed to update %s: %s\n", pkg.Raw, err) |
| 131 | } |
| 132 | continue |
| 133 | } |
| 134 | if _, _, isVersioned := searcher.ParseVersionedPackage(pkg.Raw); isVersioned { |
| 135 | if err := d.updateDevboxPackage(pkg); err != nil { |
| 136 | return err |
| 137 | } |
| 138 | } |
| 139 | } |
| 140 | return nil |
| 141 | } |
| 142 | |
| 143 | func (d *Devbox) updateDevboxPackage(pkg *devpkg.Package) error { |
| 144 | // refresh=true so flake refs bypass nix's own metadata cache and re-query |
no test coverage detected