indexpack

package
v0.0.2 Latest Latest
Warning

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

Go to latest
Published: Jun 5, 2015 License: Apache-2.0 Imports: 19 Imported by: 0

Documentation

Overview

Package indexpack provides an interface to a collection of compilation units stored in an "index pack" directory structure. The index pack format is defined in kythe-index-pack.txt.

Example usage, writing:

pack, err := indexpack.Create(ctx, "path/to/some/directory")
if err != nil {
  log.Exit(err)
}
for _, cu := range fetchUnits() {
  if _, err := pack.WriteUnit(ctx, "kythe", cu); err != nil {
    log.Error(err)
    continue
  }
  for _, input := range cu.RequiredInput {
    data, err := readFile(input)
    if err != nil {
      log.Error(err)
      continue
    }
    if err := pack.WriteFile(ctx, data); err != nil {
      log.Error(err)
    }
  }
}

Example usage, reading:

pack, err := indexpack.Open(ctx, "some/dir/path", indexpack.UnitType((*cpb.CompilationUnit)(nil)))
if err != nil {
  log.Exit(err)
}

// The value passed to the callback will have the concrete type of
// the third parameter to Open (or Create).
err := pack.ReadUnits(ctx, "kythe", func(cu interface{}) error {
  for _, input := range cu.(*cpb.CompilationUnit).RequiredInput {
    bits, err := pack.ReadFile(ctx, input.Digest)
    if err != nil {
      return err
    }
    processData(bits)
  }
  return doSomethingUseful(cu)
})
if err != nil {
  log.Exit(err)
}

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Archive

type Archive struct {
	// contains filtered or unexported fields
}

Archive represents an index pack directory.

func Create

func Create(ctx context.Context, path string, opts ...Option) (*Archive, error)

Create creates a new empty index pack at the specified path. It is an error if the path already exists.

If unitType != nil, the interface value passed to the callback of ReadUnits will be a pointer to its type.

func CreateOrOpen

func CreateOrOpen(ctx context.Context, path string, opts ...Option) (*Archive, error)

CreateOrOpen opens an existing index pack with the given parameters, if one exists; or if not, then attempts to create one.

func Open

func Open(ctx context.Context, path string, opts ...Option) (*Archive, error)

Open returns a handle for an existing valid index pack at the specified path. It is an error if path does not exist, or does not have the correct format.

If unitType != nil, the interface value passed to the callback of ReadUnits will be a pointer to its type.

func OpenZip

func OpenZip(ctx context.Context, r io.ReadSeeker, opts ...Option) (*Archive, error)

OpenZip returns a read-only *Archive tied to the ZIP file at r, which is expected to contain the recursive contents of an indexpack directory and its subdirectories. Operations that write to the pack will return errors.

func (*Archive) Fetcher

func (a *Archive) Fetcher(ctx context.Context) analysis.Fetcher

Fetcher returns an analysis.Fetcher that reads file contents from a.

func (*Archive) FileExists

func (a *Archive) FileExists(ctx context.Context, digest string) (bool, error)

FileExists determines whether a file with the given digest exists.

func (*Archive) ReadFile

func (a *Archive) ReadFile(ctx context.Context, digest string) ([]byte, error)

ReadFile reads and returns the file contents corresponding to the given hex-encoded SHA-256 digest.

func (*Archive) ReadUnit

func (a *Archive) ReadUnit(ctx context.Context, formatKey, digest string, f func(interface{}) error) error

ReadUnit calls f with the compilation unit stored in the units subdirectory with the given formatKey and digest. The concrete type of the value passed to f will be the same as the concrete type of the unitType argument that was passed to Open or Create.

If f returns a non-nil error, it is returned.

func (*Archive) ReadUnits

func (a *Archive) ReadUnits(ctx context.Context, formatKey string, f func(interface{}) error) error

ReadUnits calls f with each of the compilation units stored in the units subdirectory of the index pack whose format key equals formatKey. The concrete type of the value passed to f will be the same as the concrete type of the unitType argument that was passed to Open or Create.

If f returns a non-nil error, no further compilations are read and the error is propagated back to the caller of ReadUnits.

func (*Archive) Root

func (a *Archive) Root() string

Root returns the root path of the archive.

func (*Archive) WriteFile

func (a *Archive) WriteFile(ctx context.Context, data []byte) (string, error)

WriteFile writes the specified file contents to the files/ subdirectory of the index pack. Returns the resulting filename, whether or not there is an error in writing the file.

func (*Archive) WriteUnit

func (a *Archive) WriteUnit(ctx context.Context, formatKey string, cu interface{}) (string, error)

WriteUnit writes the specified compilation unit to the units/ subdirectory of the index pack, using the specified format key. Returns the resulting filename, whether or not there is an error in writing the file, as long as marshaling succeeded.

type Option

type Option func(*Archive) error

An Option is a configurable setting for an Archive.

func FS

func FS(fs VFS) Option

FS returns an Option that sets the filesystem interface used to implement the index pack.

func UnitType

func UnitType(t interface{}) Option

UnitType returns an Option that sets the concrete type used to unmarshal compilation units in the ReadUnits method. If t != nil, the interface value passed to the callback will be a pointer to the type of t.

type VFS

type VFS interface {
	// Stat returns file status information for path, as os.Stat.
	Stat(ctx context.Context, path string) (os.FileInfo, error)

	// MkdirAll recursively creates the specified directory path with the given
	// permissions, as os.MkdirAll.
	MkdirAll(ctx context.Context, path string, mode os.FileMode) error

	// Open opens an existing file for reading, as os.Open.
	Open(ctx context.Context, path string) (io.ReadCloser, error)

	// Create creates a new file for writing, as os.Create.
	Create(ctx context.Context, path string) (io.WriteCloser, error)

	// Rename renames oldPath to newPath, as os.Rename, overwriting newPath if
	// it exists.
	Rename(ctx context.Context, oldPath, newPath string) error

	// Remove deletes the file specified by path, as os.Remove.
	Remove(ctx context.Context, path string) error

	// Glob returns all the paths matching the specified glob pattern, as
	// filepath.Glob.
	Glob(ctx context.Context, glob string) ([]string, error)
}

VFS is the interface consumed by the Archive to manipulate the filesystem for index pack operations.

Directories

Path Synopsis
Package google implements an indexpack VFS backed by Google cloud storage.
Package google implements an indexpack VFS backed by Google cloud storage.

Jump to

Keyboard shortcuts

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