blob: e7292e93d0910fcb9dc774512469ab31ba0f14d0 (
plain) (
tree)
|
|
package config
// New creates a new config instance.
func New() *Config {
return &Config{}
}
type Config struct {
Comment *Comment
Sections Sections
Includes Includes
}
type Includes []*Include
// A reference to a included configuration.
type Include struct {
Path string
Config *Config
}
type Comment string
const (
NoSubsection = ""
)
func (c *Config) Section(name string) *Section {
for i := len(c.Sections) - 1; i >= 0; i-- {
s := c.Sections[i]
if s.IsName(name) {
return s
}
}
s := &Section{Name: name}
c.Sections = append(c.Sections, s)
return s
}
// AddOption is a convenience method to add an option to a given
// section and subsection.
//
// Use the NoSubsection constant for the subsection argument
// if no subsection is wanted.
func (s *Config) AddOption(section string, subsection string, key string, value string) *Config {
if subsection == "" {
s.Section(section).AddOption(key, value)
} else {
s.Section(section).Subsection(subsection).AddOption(key, value)
}
return s
}
// SetOption is a convenience method to set an option to a given
// section and subsection.
//
// Use the NoSubsection constant for the subsection argument
// if no subsection is wanted.
func (s *Config) SetOption(section string, subsection string, key string, value string) *Config {
if subsection == "" {
s.Section(section).SetOption(key, value)
} else {
s.Section(section).Subsection(subsection).SetOption(key, value)
}
return s
}
func (c *Config) RemoveSection(name string) *Config {
result := Sections{}
for _, s := range c.Sections {
if !s.IsName(name) {
result = append(result, s)
}
}
c.Sections = result
return c
}
func (c *Config) RemoveSubsection(section string, subsection string) *Config {
for _, s := range c.Sections {
if s.IsName(section) {
result := Subsections{}
for _, ss := range s.Subsections {
if !ss.IsName(subsection) {
result = append(result, ss)
}
}
s.Subsections = result
}
}
return c
}
|