diff options
Diffstat (limited to 'pkg/config')
| -rw-r--r-- | pkg/config/config.go | 49 | 
1 files changed, 49 insertions, 0 deletions
| diff --git a/pkg/config/config.go b/pkg/config/config.go index 1ad5108..60a3444 100644 --- a/pkg/config/config.go +++ b/pkg/config/config.go @@ -4,6 +4,7 @@ import (  	"errors"  	"fmt"  	"io" +	"log/slog"  	"os"  	"path"  	"path/filepath" @@ -19,6 +20,16 @@ var (  	ErrInvalidProperty = errors.New("Invalid property")  ) +type OrderBy int + +const ( +	Unordered OrderBy = iota +	AlphabeticalAsc +	AlphabeticalDesc +	LastCommitAsc +	LastCommitDesc +) +  type (  	// scan represents piece of the scan from the configuration file. @@ -36,6 +47,7 @@ type (  		Passphrase      string  		SyntaxHighlight string  		AESKey          string +		OrderBy         string  		Repositories    []*GitRepositoryConfiguration  	} @@ -58,6 +70,7 @@ type (  		passphrase      []byte  		aesKey          []byte  		syntaxHighlight string +		orderBy         OrderBy  		repositories    []*GitRepositoryConfiguration  	}  ) @@ -80,6 +93,7 @@ func LoadConfigurationRepository(configPath string) (*ConfigurationRepository, e  		repositories:    config.Repositories,  		rootReadme:      config.RootReadme,  		syntaxHighlight: config.SyntaxHighlight, +		orderBy:         parseOrderBy(config.OrderBy),  	}  	for _, scan := range config.Scans { @@ -99,6 +113,10 @@ func (c *ConfigurationRepository) GetRootReadme() string {  	return c.rootReadme  } +func (c *ConfigurationRepository) GetOrderBy() OrderBy { +	return c.orderBy +} +  func (c *ConfigurationRepository) GetSyntaxHighlight() string {  	return c.syntaxHighlight  } @@ -211,6 +229,11 @@ func parse(r io.Reader) (*configuration, error) {  		return nil, err  	} +	err = setOrderby(block, &config.OrderBy) +	if err != nil { +		return nil, err +	} +  	err = setRepositories(block, &config.Repositories)  	if err != nil {  		return nil, err @@ -316,6 +339,11 @@ func setSyntaxHighlight(block scfg.Block, listenAddr *string) error {  	return setString(scanDir, listenAddr)  } +func setOrderby(block scfg.Block, orderBy *string) error { +	scanDir := block.Get("order-by") +	return setString(scanDir, orderBy) +} +  func setListenAddr(block scfg.Block, listenAddr *string) error {  	scanDir := block.Get("listen-addr")  	return setString(scanDir, listenAddr) @@ -363,3 +391,24 @@ func setString(dir *scfg.Directive, field *string) error {  	}  	return nil  } + +func parseOrderBy(s string) OrderBy { +	switch s { +	case "": +		return LastCommitAsc +	case "unordered": +		return Unordered +	case "alphabetical-asc": +		return AlphabeticalAsc +	case "alphabetical-desc": +		return AlphabeticalDesc +	case "lastcommit-asc": +		return LastCommitAsc +	case "lastcommit-desc": +		return LastCommitDesc +	default: +		slog.Warn("Invalid order-by using default unordered") +		return LastCommitAsc + +	} +} | 
