change docstring formating
This commit is contained in:
@@ -7,17 +7,16 @@ import (
|
||||
"encoding/json"
|
||||
)
|
||||
|
||||
// A very simple datastructure, implementing the IDatastore interface. It uses
|
||||
// a simple text file to the data as json.
|
||||
type FileDatastore struct {
|
||||
/* A very simple datastructure, implementing the IDatastore interface. It
|
||||
* uses a simple text file to the data as json. */
|
||||
path string
|
||||
}
|
||||
|
||||
|
||||
// Creates a new FileDatastore object, creating the storage file in the
|
||||
// process.
|
||||
func NewFileDatastore(path string) (*FileDatastore, error) {
|
||||
/* Creates a new FileDatastore object, creating the storage file in the
|
||||
* process. */
|
||||
|
||||
fds := &FileDatastore{ path: path }
|
||||
|
||||
if _, err := fds.readMapObj(); err != nil {
|
||||
@@ -27,11 +26,10 @@ func NewFileDatastore(path string) (*FileDatastore, error) {
|
||||
return fds, nil
|
||||
}
|
||||
|
||||
// Read the contents of the storage file and convert to a map object. May throw
|
||||
// an error, if the file does not exit or the file content can not be
|
||||
// converted.
|
||||
func (fds *FileDatastore) readMapObj() (map[string]string, error) {
|
||||
/* Read the contents of the storage file and convert to a map object. May
|
||||
* throw an error, if the file does not exit or the file content can not be
|
||||
* converted. */
|
||||
|
||||
dat, err := os.ReadFile(fds.path)
|
||||
if err != nil { return nil, err }
|
||||
|
||||
@@ -42,11 +40,9 @@ func (fds *FileDatastore) readMapObj() (map[string]string, error) {
|
||||
return mapobj, nil
|
||||
}
|
||||
|
||||
// Write the map object to the storage file. Will overwrite the content of the
|
||||
// file. May throw an error, if the file cannot be created or written to.
|
||||
func (fds *FileDatastore) writeMapObj(m map[string]string) error {
|
||||
/* Write the map object to the storage file. Will overwrite the content of
|
||||
* the file. May throw an error, if the file cannot be created or written
|
||||
* to. */
|
||||
|
||||
file, err := os.Create(fds.path)
|
||||
if err != nil { return err }
|
||||
defer file.Close()
|
||||
@@ -57,13 +53,13 @@ func (fds *FileDatastore) writeMapObj(m map[string]string) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
|
||||
// --- implement IDatastore interface ---
|
||||
|
||||
// Sets the key value pair given, overwriting if the key already exists. May
|
||||
// through an error if the file cannot be opened or the contents cannot be
|
||||
// decoded correctly.
|
||||
func (fds *FileDatastore) Set(key string, val string) error {
|
||||
/* Sets the key value pair given, overwriting if the key already exists.
|
||||
* May through an error if the file cannot be opened or the contents cannot
|
||||
* be decoded correctly. */
|
||||
|
||||
m, err := fds.readMapObj()
|
||||
if err != nil { return err }
|
||||
|
||||
@@ -75,10 +71,9 @@ func (fds *FileDatastore) Set(key string, val string) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
// Check if for the given key a entry does exit. May through an error if the
|
||||
// file cannot be opened or the contents cannot be decoded correctly.
|
||||
func (fds *FileDatastore) KeyExists(key string) (bool, error) {
|
||||
/* Check if for the given key a entry does exit. May through an error if
|
||||
* the file cannot be opened or the contents cannot be decoded correctly. */
|
||||
|
||||
m, err := fds.readMapObj()
|
||||
if err != nil { return false, err }
|
||||
|
||||
@@ -87,11 +82,10 @@ func (fds *FileDatastore) KeyExists(key string) (bool, error) {
|
||||
return ok, nil
|
||||
}
|
||||
|
||||
// Gets the value for the given key. May through an error if the key does not
|
||||
// exit, the file cannot be opened or the contents cannot be decoded
|
||||
// correctly.
|
||||
func (fds *FileDatastore) Get(key string) (string, error) {
|
||||
/* Gets the value for the given key. May through an error if the key does
|
||||
* not exit, the file cannot be opened or the contents cannot be decoded
|
||||
* correctly. */
|
||||
|
||||
m, err := fds.readMapObj()
|
||||
if err != nil { return "", err }
|
||||
|
||||
@@ -101,19 +95,17 @@ func (fds *FileDatastore) Get(key string) (string, error) {
|
||||
return val, nil
|
||||
}
|
||||
|
||||
// Gets all the key value pairs from the file and returns them as a map object.
|
||||
// May through an error if the file cannot be opened or the contents cannot be
|
||||
// decoded correctly.
|
||||
func (fds *FileDatastore) GetAll() (map[string]string, error) {
|
||||
/* Gets all the key value pairs from the file and returns them as a map
|
||||
* object. May through an error if the file cannot be opened or the contents
|
||||
* cannot be decoded correctly. */
|
||||
|
||||
return fds.readMapObj()
|
||||
}
|
||||
|
||||
// Gets all the key the file and returns them as a map object. May through an
|
||||
// error if the file cannot be opened or the contents cannot be decoded
|
||||
// correctly.
|
||||
func (fds *FileDatastore) GetAllKeys() (map[string]bool, error) {
|
||||
/* Gets all the key the file and returns them as a map object. May through
|
||||
* an error if the file cannot be opened or the contents cannot be decoded
|
||||
* correctly. */
|
||||
|
||||
m, err := fds.readMapObj()
|
||||
if err != nil { return nil, err }
|
||||
|
||||
@@ -124,3 +116,18 @@ func (fds *FileDatastore) GetAllKeys() (map[string]bool, error) {
|
||||
|
||||
return out, nil
|
||||
}
|
||||
|
||||
// Deletes the entry with the given key. May through an error if the file
|
||||
// cannot be opened or the contents cannot be decoded or encoded correctly.
|
||||
func (fds *FileDatastore) Delete(key string) error {
|
||||
|
||||
m, err := fds.readMapObj()
|
||||
if err != nil { return err }
|
||||
|
||||
delete(m, key)
|
||||
|
||||
err = fds.writeMapObj(m)
|
||||
if err != nil { return err }
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user