Files
dolt/go/datas/dataset.go
2017-05-25 11:51:20 -07:00

108 lines
2.9 KiB
Go

// Copyright 2016 Attic Labs, Inc. All rights reserved.
// Licensed under the Apache License, version 2.0:
// http://www.apache.org/licenses/LICENSE-2.0
package datas
import (
"regexp"
"github.com/attic-labs/noms/go/d"
"github.com/attic-labs/noms/go/types"
)
// DatasetRe is a regexp that matches a legal Dataset name anywhere within the
// target string.
var DatasetRe = regexp.MustCompile(`[a-zA-Z0-9\-_/]+`)
// DatasetFullRe is a regexp that matches a only a target string that is
// entirely legal Dataset name.
var DatasetFullRe = regexp.MustCompile("^" + DatasetRe.String() + "$")
// Dataset is a named Commit within a Database.
type Dataset struct {
db Database
id string
head types.Value
}
func newDataset(db Database, id string, head types.Value) Dataset {
d.PanicIfFalse(head == nil || IsCommit(head))
return Dataset{db, id, head}
}
// Database returns the Database object in which this Dataset is stored.
// WARNING: This method is under consideration for deprecation.
func (ds Dataset) Database() Database {
return ds.db
}
// ID returns the name of this Dataset.
func (ds Dataset) ID() string {
return ds.id
}
// MaybeHead returns the current Head Commit of this Dataset, which contains
// the current root of the Dataset's value tree, if available. If not, it
// returns a new Commit and 'false'.
func (ds Dataset) MaybeHead() (types.Struct, bool) {
if ds.head == nil {
return types.Struct{}, false
}
return ds.head.(types.Struct), true
}
// Head returns the current head Commit, which contains the current root of
// the Dataset's value tree.
func (ds Dataset) Head() types.Struct {
c, ok := ds.MaybeHead()
if !ok {
d.Panic("Dataset \"%s\" does not exist", ds.id)
}
return c
}
// MaybeHeadRef returns the Ref of the current Head Commit of this Dataset,
// which contains the current root of the Dataset's value tree, if available.
// If not, it returns an empty Ref and 'false'.
func (ds Dataset) MaybeHeadRef() (types.Ref, bool) {
if ds.head == nil {
return types.Ref{}, false
}
return types.NewRef(ds.head), true
}
// HasHead() returns 'true' if this dataset has a Head Commit, false otherwise.
func (ds Dataset) HasHead() bool {
return ds.head != nil
}
// HeadRef returns the Ref of the current head Commit, which contains the
// current root of the Dataset's value tree.
func (ds Dataset) HeadRef() types.Ref {
r, ok := ds.MaybeHeadRef()
if !ok {
d.Panic("Dataset \"%s\" does not exist", ds.id)
}
return r
}
// MaybeHeadValue returns the Value field of the current head Commit, if
// available. If not it returns nil and 'false'.
func (ds Dataset) MaybeHeadValue() (types.Value, bool) {
if c, ok := ds.MaybeHead(); ok {
return c.Get(ValueField), true
}
return nil, false
}
// HeadValue returns the Value field of the current head Commit.
func (ds Dataset) HeadValue() types.Value {
c := ds.Head()
return c.Get(ValueField)
}
func IsValidDatasetName(name string) bool {
return DatasetFullRe.MatchString(name)
}