archive/tar
tar包
import "archive/tar"
- 概述
- 索引
- 示例
概述
Package tar 实现对 tar 档案的访问。它的目的是去涵盖大部分的变体(variations),其中包括 GNU 和 BSD tar生成的包。
参考:
http://www.freebsd.org/cgi/man.cgi?query=tar&sektion=5
http://www.gnu.org/software/tar/manual/html_node/Standard.html
http://pubs.opengroup.org/onlinepubs/9699919799/utilities/pax.html
示例
package main
import (
"archive/tar"
"bytes"
"fmt"
"io"
"log"
"os"
)
func main() {
// 创建一个缓冲区来写入我们的存档。
buf := new(bytes.Buffer)
// 创建一个新的tar存档。
tw := tar.NewWriter(buf)
// 将一些文件添加到存档中。
var files = []struct {
Name, Body string
}{
{"readme.txt", "This archive contains some text files."},
{"gopher.txt", "Gopher names:\nGeorge\nGeoffrey\nGonzo"},
{"todo.txt", "Get animal handling license."},
}
for _, file := range files {
hdr := &tar.Header{
Name: file.Name,
Mode: 0600,
Size: int64(len(file.Body)),
}
if err := tw.WriteHeader(hdr err != nil {
log.Fatalln(err)
}
if _, err := tw.Write([]byte(file.Body) err != nil {
log.Fatalln(err)
}
}
// 确保在Close时检查错误。
if err := tw.Close( err != nil {
log.Fatalln(err)
}
// 打开tar档案以供阅读。
r := bytes.NewReader(buf.Bytes())
tr := tar.NewReader(r)
// 迭代档案中的文件。
for {
hdr, err := tr.Next()
if err == io.EOF {
// tar归档结束
break
}
if err != nil {
log.Fatalln(err)
}
fmt.Printf("Contents of %s:\n", hdr.Name)
if _, err := io.Copy(os.Stdout, tr err != nil {
log.Fatalln(err)
}
fmt.Println()
}
}
索引
- Constants
- Variables
- type Header
func FileInfoHeader(fi os.FileInfo, link string) (*Header, error)
func (h *Header) FileInfo() os.FileInfo
- type Reader
func NewReader(r io.Reader) *Reader
func (tr *Reader) Next() (*Header, error)
func (tr *Reader) Read(b []byte) (int, error)
- type Writer
func NewWriter(w io.Writer) *Writer
func (tw *Writer) Close() error
func (tw *Writer) Flush() error
func (tw *Writer) Write(b []byte) (n int, err error)
func (tw *Writer) WriteHeader(hdr *Header) error
示例
包
Package files (包文件)
common.go format.go reader.go stat_atim.go stat_unix.go strconv.go writer.go
常量
标题类型标志。
const (
TypeReg = '0' // 普通文件
TypeRegA = '\x00' // 普通文件
TypeLink = '1' // 硬链接(hard link)
TypeSymlink = '2' // 符号链接
TypeChar = '3' // 字符设备节点
TypeBlock = '4' // 块设备节点
TypeDir = '5' // 目录
TypeFifo = '6' // fifo节点
TypeCont = '7' // 保留
TypeXHeader = 'x' // 扩展标题
TypeXGlobalHeader = 'g' // 全局扩展标题
TypeGNULongName = 'L' // 下一个文件名称很长
TypeGNULongLink = 'K' // 接下来将文件符号链接到一个带有长名字的文件
TypeGNUSparse = 'S' // 稀疏文件(sparse file)
)
变量
var (
ErrWriteTooLong = errors.New("archive/tar: write too long")
ErrFieldTooLong = errors.New("archive/tar: header field too long")
ErrWriteAfterClose = errors.New("archive/tar: write after close")
)
var (
ErrHeader = errors.New("archive/tar: invalid tar header")
)
type Header(查看源代码)
标题代表 tar 档案中的单个标题。有些字段可能不会被填充。
type Header struct {
Name string // 头文件条目的名称
Mode int64 // 许可和模式位
Uid int // 所有者的用户ID
Gid int // 所有者的组ID
Size int64 // 长度以字节为单位
ModTime time.Time // 修改时间
Typeflag byte // 标题条目的类型
Linkname string // 链接的目标名称
Uname string // 所有者的用户名
Gname string // 所有者的组名称
Devmajor int64 // 字符或块设备的主要数量
Devminor int64 // 少量的字符或块设备
AccessTime time.Time // 访问时间
ChangeTime time.Time // 状态更改时间
Xattrs map[string]string
}
func FileInfoHeader (查看源代码)
func FileInfoHeader(fi os.FileInfo, link string) (*Header, error)
FileInfoHeader 从 fi中 创建一个部分填充的 Header 。如果 fi 描述一个符号链接, FileInfoHeader 将链接记录为链接目标。如果 fi 描述一个目录,则会在该名称后附加一个斜杠。因为 os.FileInfo 的 Name 方法仅返回它描述的文件的基本名称,所以可能需要修改返回的头的 Name 字段以提供文件的完整路径名。
func (*Header) FileInfo(查看源代码)
func (h *Header) FileInfo() os.FileInfo
FileInfo 为 Header 返回一个 os.FileInfo。
type Reader(查看源代码)
Reader 提供对 tar 档案内容的顺序访问。tar 档案由一系列文件组成。Next 方法前进到存档中的下一个文件(包括第一个文件),然后可以将其视为一个 io.Reader 来访问该文件的数据。
type Reader struct {
// 包含已过滤或未导出的字段
}
func NewReader(查看源代码)
func NewReader(r io.Reader) *Reader
NewReader 从 r 中创建一个新的 Reader 阅读器。
func (*Reader) Next (查看源文档)
func (tr *Reader) Next() (*Header, error)
Next 阅读器前进到 tar 档案中的下一个条目。
在输入结束时返回 io.EOF 。
func (*Reader) Read(查看源代码)
func (tr *Reader) Read(b []byte) (int, error)
Read 阅读器读取 tar 档案中当前条目的读取内容。当它到达该条目的末尾时,它将返回0, io.EOF,直到Next 阅读器被调用到下一个条目。
无论 Header.Size 如何声明,在 TypeLink ,TypeSymLink,TypeChar, TypeBlock ,TypeDir 和 TypeFifo 等特殊类型上调用Read都会返回 0, io.EOF 。
type Writer(查看源代码)
Writer 提供 POSIX.1 格式的 tar 存档的顺序写入。tar 档案由一系列文件组成。调用 WriteHeader 然后开始一个新文件,然后调用 Write 来提供该文件的数据,最多共写入 hdr.Size 字节。
type Writer struct {
// 包含过滤或未导出的字段
}
func NewWriter (查看源代码)
func NewWriter(w io.Writer) *Writer
NewWriter 创建一个写入 w 的新 Writer。
func (*Writer) Close(查看源代码)
func (tw *Writer) Close() error
Close 关闭 tar 档案,将任何未写入的数据刷新到底层编写器(underlying writer)。
func (*Writer) Flush(查看源代码)
func (tw *Writer) Flush() error
刷新结束写入当前文件(可选)。
func (*Writer) Write(查看源代码)
func (tw *Writer) Write(b []byte) (n int, err error)
Write 写入 tar 档案 中的当前条目。如果在 WriteHeader 之后写入超过 hdr.Size 的字节,Writer 将返回错误 ErrWriteTooLong 。
func (*Writer) WriteHeader(查看源代码)
func (tw *Writer) WriteHeader(hdr *Header) error
WriteHeader 写入 hdr 并准备接受文件的内容。如果WriteHeader 不是第一个标题,则调用 Flush 。在 Close 之后调用将返回 ErrWriteAfterClose 。