mirror of
https://github.com/mudler/luet.git
synced 2025-09-03 00:06:36 +00:00
Add support for parsing version with build
This commit is contained in:
21
cmd/build.go
21
cmd/build.go
@@ -15,18 +15,17 @@
|
|||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
"github.com/mudler/luet/pkg/compiler"
|
"github.com/mudler/luet/pkg/compiler"
|
||||||
"github.com/mudler/luet/pkg/compiler/backend"
|
"github.com/mudler/luet/pkg/compiler/backend"
|
||||||
. "github.com/mudler/luet/pkg/config"
|
. "github.com/mudler/luet/pkg/config"
|
||||||
|
helpers "github.com/mudler/luet/pkg/helpers"
|
||||||
. "github.com/mudler/luet/pkg/logger"
|
. "github.com/mudler/luet/pkg/logger"
|
||||||
pkg "github.com/mudler/luet/pkg/package"
|
pkg "github.com/mudler/luet/pkg/package"
|
||||||
tree "github.com/mudler/luet/pkg/tree"
|
tree "github.com/mudler/luet/pkg/tree"
|
||||||
|
|
||||||
_gentoo "github.com/Sabayon/pkgs-checker/pkg/gentoo"
|
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
"github.com/spf13/viper"
|
"github.com/spf13/viper"
|
||||||
)
|
)
|
||||||
@@ -137,26 +136,12 @@ var buildCmd = &cobra.Command{
|
|||||||
luetCompiler.SetCompressionType(compiler.CompressionImplementation(compressionType))
|
luetCompiler.SetCompressionType(compiler.CompressionImplementation(compressionType))
|
||||||
if !all {
|
if !all {
|
||||||
for _, a := range args {
|
for _, a := range args {
|
||||||
gp, err := _gentoo.ParsePackageStr(a)
|
|
||||||
|
pack, err := helpers.ParsePackageStr(a)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
Fatal("Invalid package string ", a, ": ", err.Error())
|
Fatal("Invalid package string ", a, ": ", err.Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
if gp.Version == "" {
|
|
||||||
gp.Version = "0"
|
|
||||||
gp.Condition = _gentoo.PkgCondGreaterEqual
|
|
||||||
}
|
|
||||||
|
|
||||||
pack := &pkg.DefaultPackage{
|
|
||||||
Name: gp.Name,
|
|
||||||
Version: fmt.Sprintf("%s%s%s",
|
|
||||||
pkg.PkgSelectorConditionFromInt(gp.Condition.Int()).String(),
|
|
||||||
gp.Version,
|
|
||||||
gp.VersionSuffix,
|
|
||||||
),
|
|
||||||
Category: gp.Category,
|
|
||||||
Uri: make([]string, 0),
|
|
||||||
}
|
|
||||||
spec, err := luetCompiler.FromPackage(pack)
|
spec, err := luetCompiler.FromPackage(pack)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
Fatal("Error: " + err.Error())
|
Fatal("Error: " + err.Error())
|
||||||
|
@@ -15,17 +15,16 @@
|
|||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
|
||||||
installer "github.com/mudler/luet/pkg/installer"
|
installer "github.com/mudler/luet/pkg/installer"
|
||||||
|
|
||||||
. "github.com/mudler/luet/pkg/config"
|
. "github.com/mudler/luet/pkg/config"
|
||||||
|
helpers "github.com/mudler/luet/pkg/helpers"
|
||||||
. "github.com/mudler/luet/pkg/logger"
|
. "github.com/mudler/luet/pkg/logger"
|
||||||
pkg "github.com/mudler/luet/pkg/package"
|
pkg "github.com/mudler/luet/pkg/package"
|
||||||
|
|
||||||
_gentoo "github.com/Sabayon/pkgs-checker/pkg/gentoo"
|
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -50,26 +49,10 @@ var installCmd = &cobra.Command{
|
|||||||
var systemDB pkg.PackageDatabase
|
var systemDB pkg.PackageDatabase
|
||||||
|
|
||||||
for _, a := range args {
|
for _, a := range args {
|
||||||
gp, err := _gentoo.ParsePackageStr(a)
|
pack, err := helpers.ParsePackageStr(a)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
Fatal("Invalid package string ", a, ": ", err.Error())
|
Fatal("Invalid package string ", a, ": ", err.Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
if gp.Version == "" {
|
|
||||||
gp.Version = "0"
|
|
||||||
gp.Condition = _gentoo.PkgCondGreaterEqual
|
|
||||||
}
|
|
||||||
|
|
||||||
pack := &pkg.DefaultPackage{
|
|
||||||
Name: gp.Name,
|
|
||||||
Version: fmt.Sprintf("%s%s%s",
|
|
||||||
pkg.PkgSelectorConditionFromInt(gp.Condition.Int()).String(),
|
|
||||||
gp.Version,
|
|
||||||
gp.VersionSuffix,
|
|
||||||
),
|
|
||||||
Category: gp.Category,
|
|
||||||
Uri: make([]string, 0),
|
|
||||||
}
|
|
||||||
toInstall = append(toInstall, pack)
|
toInstall = append(toInstall, pack)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -15,16 +15,15 @@
|
|||||||
package cmd
|
package cmd
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
|
||||||
. "github.com/mudler/luet/pkg/config"
|
. "github.com/mudler/luet/pkg/config"
|
||||||
|
helpers "github.com/mudler/luet/pkg/helpers"
|
||||||
installer "github.com/mudler/luet/pkg/installer"
|
installer "github.com/mudler/luet/pkg/installer"
|
||||||
. "github.com/mudler/luet/pkg/logger"
|
. "github.com/mudler/luet/pkg/logger"
|
||||||
pkg "github.com/mudler/luet/pkg/package"
|
pkg "github.com/mudler/luet/pkg/package"
|
||||||
|
|
||||||
_gentoo "github.com/Sabayon/pkgs-checker/pkg/gentoo"
|
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -46,24 +45,11 @@ var uninstallCmd = &cobra.Command{
|
|||||||
var systemDB pkg.PackageDatabase
|
var systemDB pkg.PackageDatabase
|
||||||
|
|
||||||
for _, a := range args {
|
for _, a := range args {
|
||||||
gp, err := _gentoo.ParsePackageStr(a)
|
|
||||||
|
pack, err := helpers.ParsePackageStr(a)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
Fatal("Invalid package string ", a, ": ", err.Error())
|
Fatal("Invalid package string ", a, ": ", err.Error())
|
||||||
}
|
}
|
||||||
if gp.Version == "" {
|
|
||||||
gp.Version = "0"
|
|
||||||
gp.Condition = _gentoo.PkgCondGreaterEqual
|
|
||||||
}
|
|
||||||
pack := &pkg.DefaultPackage{
|
|
||||||
Name: gp.Name,
|
|
||||||
Version: fmt.Sprintf("%s%s%s",
|
|
||||||
pkg.PkgSelectorConditionFromInt(gp.Condition.Int()).String(),
|
|
||||||
gp.Version,
|
|
||||||
gp.VersionSuffix,
|
|
||||||
),
|
|
||||||
Category: gp.Category,
|
|
||||||
Uri: make([]string, 0),
|
|
||||||
}
|
|
||||||
|
|
||||||
stype := LuetCfg.Viper.GetString("solver.type")
|
stype := LuetCfg.Viper.GetString("solver.type")
|
||||||
discount := LuetCfg.Viper.GetFloat64("solver.discount")
|
discount := LuetCfg.Viper.GetFloat64("solver.discount")
|
||||||
|
60
pkg/helpers/cli.go
Normal file
60
pkg/helpers/cli.go
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
// Copyright © 2020 Ettore Di Giacinto <mudler@gentoo.org>
|
||||||
|
// Daniele Rondina <geaaru@sabayonlinux.org>
|
||||||
|
//
|
||||||
|
// This program is free software; you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License as published by
|
||||||
|
// the Free Software Foundation; either version 2 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// This program is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU General Public License along
|
||||||
|
// with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
package helpers
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
_gentoo "github.com/Sabayon/pkgs-checker/pkg/gentoo"
|
||||||
|
pkg "github.com/mudler/luet/pkg/package"
|
||||||
|
)
|
||||||
|
|
||||||
|
func ParsePackageStr(p string) (*pkg.DefaultPackage, error) {
|
||||||
|
gp, err := _gentoo.ParsePackageStr(p)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if gp.Version == "" {
|
||||||
|
gp.Version = "0"
|
||||||
|
gp.Condition = _gentoo.PkgCondGreaterEqual
|
||||||
|
}
|
||||||
|
|
||||||
|
pkgVersion := ""
|
||||||
|
if gp.VersionBuild != "" {
|
||||||
|
pkgVersion = fmt.Sprintf("%s%s%s+%s",
|
||||||
|
pkg.PkgSelectorConditionFromInt(gp.Condition.Int()).String(),
|
||||||
|
gp.Version,
|
||||||
|
gp.VersionSuffix,
|
||||||
|
gp.VersionBuild,
|
||||||
|
)
|
||||||
|
} else {
|
||||||
|
pkgVersion = fmt.Sprintf("%s%s%s",
|
||||||
|
pkg.PkgSelectorConditionFromInt(gp.Condition.Int()).String(),
|
||||||
|
gp.Version,
|
||||||
|
gp.VersionSuffix,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
pack := &pkg.DefaultPackage{
|
||||||
|
Name: gp.Name,
|
||||||
|
Category: gp.Category,
|
||||||
|
Version: pkgVersion,
|
||||||
|
Uri: make([]string, 0),
|
||||||
|
}
|
||||||
|
|
||||||
|
return pack, nil
|
||||||
|
}
|
Reference in New Issue
Block a user