drivers

package module
v0.0.0-...-05cc1f7 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 30, 2024 License: BSD-3-Clause Imports: 7 Imported by: 0

README

doc_drivers

WIP. Utility that generates drivers for hackborn/doc

Use

This utility converts a collection of domain classes into a driver for hackborn/doc, allowing use of the doc package to store and load data to a database backend. For instructions on how to use the resulting driver see that project; this one is concerned with generating the driver.

Types

The goal of any driver is for all types to be transparently written to and read from the database. In practice, the default string, int and float types are handled natively, but more advanced types, like slices and maps, may need to be translated to a format the underlying database can handle. Ideally as a user you are left unware of this detail, but see the format tag below for details about manually forcing a translation.

Tags

Translation to a database can be customized through the use of doc field tags. By default, every field in a struct has a corresponding field in the database with the same name, but this can be modified.

There are multiple keywords supported, all of which allow setting parameters in a () block.

Multiple keywords are separated with a ,.

Unexported fields are a special case, setting rules for the table.

Empty Tag

If there is no tag, the struct field name is used as the database field name. Note that some drivers might modify it for convention (for example, the SQLITE driver will lowercase the name).

Id string

The database field name will be Id or id, depending on the driver.

Tag Keyword: Name

The name keyword allows directly setting the database name for a field.

  1. Use a "name" property to directly set a databse name.
Id string `doc:"name(id)"`

The database field name will be id.

  1. Unexported fields with no tag are ignored.
id string

The struct name field will have no corresponding database field.

  1. Unexported fields with a tag are treated as table tags.
_table string `doc:"name(company)"`

The database table for the struct will be named company.

Tag Keyword: Key
  1. Database keys are specified by using the key keyword.
Id int `doc:"key"`

The database will have a key of Id or id.

  1. Multiple keys can be specified for a compound database key.
Pri int `doc:"key"`
Sec int `doc:"key"`

The database will have a compound key of Pri, Sec or pri, sec.

  1. Groups of keys can be created by providing key names.
Id int `doc:"key"`
Name string `doc:"key(group1)"`
Date int `doc:"key(group1)"`

The database will have keys of id and name, date.

  1. Keys within a key group can be ordered by supplying a number after the name.
Name string `doc:"key(group1, 1)"`
Date int `doc:"key(group1, 0)"`

The database will have a key of date, name.

  1. Key rules vary depending on the underlying storage model and level of support in the driver. Currently the only special rule is that the "primary" key is the first key group name, alphabetically. The easiest way to specify a primary key is to leave the key name blank.

Additionally, how multiple keys are handled depends on the underlying database driver. See driver docs for specifics.

Tag Keyword: Format

A tag of format will allow specification of a serialization format for the field. This is used to support Go types that are not supported by the underlying database. There is currently a single serialization format, JSON.

Order []int64 `doc:"format(json)"`

This will allow the int slice to be written to and read from the database. In theory, you should never have to use the format tag: Unhandled types are automatically serialzed.

Tag Keyword: -

A tag of - will omit the field from the database.

Name string `doc:"-"`

The struct Name field will have no corresponding database field.

Developing Drivers

The cmd/driverutil application is a tool used to help develop new drivers. Running the app displays a list of commands involved in generating the driver. See readmes for a specific driver (in backends/) for details.

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func MakeDriver

func MakeDriver(settings MakeDriverSettings) error

MakeDriver generates a new driver with the supplied settings.

Types

type MakeDriverSettings

type MakeDriverSettings struct {
	// The desired storage format for the driver. Currently supported:
	// "sqlite"
	Format string

	// LoadGlob is a glob to a folder containing
	// domain classes that will be used to generate the driver.
	LoadGlob string

	// LoadSeparator is an optional separator string used
	// to split the LoadGlob if you want to provide multiple
	// globs.
	// Example:
	// LoadSeparator=";"
	// LoadGlob="/path/to/1;/path/to/2" will be evaulated
	// as two separate paths and the results combined.
	LoadSeparator string

	// SavePath is a filepath to a folder where the new
	// driver will be saved.
	SavePath string

	// Pkg is the name of the package to use for the new driver.
	Pkg string

	// Prefix is the prefix name to use for the driver types.
	Prefix string

	// Flags is a list of per-driver named flags.
	Flags []string
}

Directories

Path Synopsis
backends
cmd

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL