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 ¶
- type Archive
- func Create(ctx context.Context, path string, opts ...Option) (*Archive, error)
- func CreateOrOpen(ctx context.Context, path string, opts ...Option) (*Archive, error)
- func Open(ctx context.Context, path string, opts ...Option) (*Archive, error)
- func OpenZip(ctx context.Context, r io.ReadSeeker, opts ...Option) (*Archive, error)
- func (a *Archive) Fetcher(ctx context.Context) analysis.Fetcher
- func (a *Archive) FileExists(ctx context.Context, digest string) (bool, error)
- func (a *Archive) ReadFile(ctx context.Context, digest string) ([]byte, error)
- func (a *Archive) ReadUnit(ctx context.Context, formatKey, digest string, f func(interface{}) error) error
- func (a *Archive) ReadUnits(ctx context.Context, formatKey string, f func(interface{}) error) error
- func (a *Archive) Root() string
- func (a *Archive) WriteFile(ctx context.Context, data []byte) (string, error)
- func (a *Archive) WriteUnit(ctx context.Context, formatKey string, cu interface{}) (string, error)
- type Option
- type VFS
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 ¶
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 ¶
CreateOrOpen opens an existing index pack with the given parameters, if one exists; or if not, then attempts to create one.
func Open ¶
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 ¶
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) FileExists ¶
FileExists determines whether a file with the given digest exists.
func (*Archive) ReadFile ¶
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 ¶
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) WriteFile ¶
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.
type Option ¶
An Option is a configurable setting for an Archive.
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.