本文整理匯總了Golang中os.File.Seek方法的典型用法代碼示例。如果您正苦於以下問題:Golang File.Seek方法的具體用法?Golang File.Seek怎麽用?Golang File.Seek使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類os.File
的用法示例。
在下文中一共展示了File.Seek方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: getTarFileBytes
func getTarFileBytes(file *os.File, path string) ([]byte, error) {
_, err := file.Seek(0, 0)
if err != nil {
fmt.Errorf("error seeking file: %v", err)
}
var fileBytes []byte
fileWalker := func(t *tarball.TarFile) error {
if filepath.Clean(t.Name()) == path {
fileBytes, err = ioutil.ReadAll(t.TarStream)
if err != nil {
return err
}
}
return nil
}
tr := tar.NewReader(file)
if err := tarball.Walk(*tr, fileWalker); err != nil {
return nil, err
}
if fileBytes == nil {
return nil, fmt.Errorf("file %q not found", path)
}
return fileBytes, nil
}
示例2: Zip
func (zipper ApplicationZipper) Zip(dirOrZipFilePath string, targetFile *os.File) error {
if zipper.IsZipFile(dirOrZipFilePath) {
zipFile, err := os.Open(dirOrZipFilePath)
if err != nil {
return err
}
defer zipFile.Close()
_, err = io.Copy(targetFile, zipFile)
if err != nil {
return err
}
} else {
err := writeZipFile(dirOrZipFilePath, targetFile)
if err != nil {
return err
}
}
_, err := targetFile.Seek(0, os.SEEK_SET)
if err != nil {
return err
}
return nil
}
示例3: newFileEncoder
// newFileEncoder creates a new encoder with current file offset for the page writer.
func newFileEncoder(f *os.File, prevCrc uint32) (*encoder, error) {
offset, err := f.Seek(0, os.SEEK_CUR)
if err != nil {
return nil, err
}
return newEncoder(f, prevCrc, int(offset)), nil
}
示例4: initFileOffset
func (h *Harvester) initFileOffset(file *os.File) error {
offset, err := file.Seek(0, os.SEEK_CUR)
if h.getOffset() > 0 {
// continue from last known offset
logp.Debug("harvester",
"harvest: %q position:%d (offset snapshot:%d)", h.Path, h.getOffset(), offset)
_, err = file.Seek(h.getOffset(), os.SEEK_SET)
} else if h.Config.TailFiles {
// tail file if file is new and tail_files config is set
logp.Debug("harvester",
"harvest: (tailing) %q (offset snapshot:%d)", h.Path, offset)
offset, err = file.Seek(0, os.SEEK_END)
h.SetOffset(offset)
} else {
// get offset from file in case of encoding factory was
// required to read some data.
logp.Debug("harvester", "harvest: %q (offset snapshot:%d)", h.Path, offset)
h.SetOffset(offset)
}
return err
}
示例5: dataLookup
func (wndb *WordNetDb) dataLookup(fh *os.File, offset int64) ([]byte, error) {
_, err := fh.Seek(offset, os.SEEK_SET)
if err != nil {
return nil, err
}
buffer := make([]byte, BUFFSIZE) // initial size of the buffer is 3kb
line := make([]byte, 0, BUFFSIZE)
prevLen := 0
for {
prevLen = len(line)
n, err := fh.Read(buffer) // we read the next 3kb (or less)
if err != nil && err != io.EOF {
return nil, err
}
line = append(line, buffer[:]...)
until := bytes.IndexByte(buffer, '\n')
if until > 0 { // We have a full line
return line[:prevLen+until], nil
}
if err == io.EOF || n < BUFFSIZE {
return line, nil
}
}
return nil, ERR_MSG(UNREACHABLE_CODE)
}
示例6: RewindFile
func RewindFile(fileHandle *os.File) {
_, rewindErr := fileHandle.Seek(0, 0)
if rewindErr != nil {
log.Fatalln("Unable to rewind file")
}
}
示例7: NewDraw
func NewDraw(fp *os.File, labels []string) *Draw {
w, h := termbox.Size()
tab := INPROCESS
inproc, arch, err := ReadCSV(fp)
if err != nil {
panic(err)
}
fp.Seek(0, 0)
data := &Data{Labels: &LabelList{}}
data.InProcess = inproc
data.Archive = arch
*data.Labels = labels
view := mode.NewView(w, h)
view.Reset()
drawer := &mode.NormalDraw{
View: *view,
Tab: tab,
}
drawer.SetLister(data.InProcess)
return &Draw{
Drawer: drawer,
data: data,
tab: tab,
file: fp,
}
}
示例8: uploadToS3
func (r *Runner) uploadToS3(file *os.File, b *Build, boundary string) string {
name := fmt.Sprintf("%s-build-%s-%s.txt", b.ID, b.Commit, time.Now().Format("2006-01-02-15-04-05"))
url := fmt.Sprintf("https://s3.amazonaws.com/%s/%s", logBucket, name)
if _, err := file.Seek(0, os.SEEK_SET); err != nil {
log.Printf("failed to seek log file: %s\n", err)
return ""
}
stat, err := file.Stat()
if err != nil {
log.Printf("failed to get log file size: %s\n", err)
return ""
}
log.Printf("uploading build log to S3: %s\n", url)
if err := s3attempts.Run(func() error {
contentType := "multipart/mixed; boundary=" + boundary
acl := "public-read"
_, err := r.s3.PutObject(&s3.PutObjectRequest{
Key: &name,
Body: file,
Bucket: &logBucket,
ACL: &acl,
ContentType: &contentType,
ContentLength: typeconv.Int64Ptr(stat.Size()),
})
return err
}); err != nil {
log.Printf("failed to upload build output to S3: %s\n", err)
}
return url
}
示例9: dataLookup
func dataLookup(fh *os.File, offset int64) []byte {
_, err := fh.Seek(offset, os.SEEK_SET)
if err != nil {
log.Fatal(err)
}
buffer := make([]byte, BUFFSIZE) // initial size of the buffer is 3kb
line := make([]byte, 0, BUFFSIZE)
prevLen := 0
for {
prevLen = len(line)
n, err := fh.Read(buffer) // we read the next 3kb (or less)
if err != nil && err != io.EOF {
log.Fatal(err)
}
line = append(line, buffer[:]...)
until := bytes.IndexByte(buffer, '\n')
if until > 0 { // We have a full line
return line[:prevLen+until]
}
if err == io.EOF || n < BUFFSIZE {
return line
}
}
log.Fatal("We can't be here")
return nil
}
示例10: MakePrimitiveBlockReader
func MakePrimitiveBlockReader(file *os.File) <-chan blockData {
retval := make(chan blockData)
go func() {
file.Seek(0, os.SEEK_SET)
for {
filePosition, err := file.Seek(0, os.SEEK_CUR)
blobHeader, err := ReadNextBlobHeader(file)
if err == io.EOF {
break
} else if err != nil {
println("Blob header read error:", err.Error())
os.Exit(2)
}
blobBytes, err := readBlock(file, *blobHeader.Datasize)
if err != nil {
println("Blob read error:", err.Error())
os.Exit(3)
}
retval <- blockData{blobHeader, blobBytes, filePosition}
}
close(retval)
}()
return retval
}
示例11: NewSlowLogParser
func NewSlowLogParser(file *os.File, stopChan <-chan bool, opt Options) *SlowLogParser {
// Seek to the offset, if any.
// @todo error if start off > file size
if opt.StartOffset > 0 {
// @todo handle error
file.Seek(int64(opt.StartOffset), os.SEEK_SET)
}
if opt.Debug {
l.SetFlags(l.Ltime | l.Lmicroseconds)
fmt.Println()
l.Println("parsing " + file.Name())
}
p := &SlowLogParser{
stopChan: stopChan,
opt: opt,
file: file,
EventChan: make(chan *log.Event),
inHeader: false,
inQuery: false,
headerLines: 0,
queryLines: 0,
bytesRead: opt.StartOffset,
lineOffset: 0,
event: log.NewEvent(),
}
return p
}
示例12: WriteLobbyInfo
func WriteLobbyInfo(file *os.File, lobby *models.Lobby) {
if !config.Constants.ChatLogsEnabled {
return
}
file.Seek(0, os.SEEK_SET)
//TODO: write lobby info to file
}
示例13: GetProperty
// returns string property prop
func (proc *SProcess) GetProperty(prop string) string {
var (
file *os.File
err error
)
// file exists
if proc.files[prop] != nil {
file = proc.files[prop]
file.Seek(0, 0)
// doesn't exist; create
} else {
file, err = os.Create("/system/process/" + strconv.Itoa(proc.pid) + "/" + prop)
file.Chmod(0755)
}
// read up to 1024 bytes
b := make([]byte, 1024)
_, err = file.Read(b)
// an error occured, and it was not an EOF
if err != nil && err != io.EOF {
return "(undefined)"
}
// file was more than 1M
if err != io.EOF {
return "(maxed out)"
}
return string(b)
}
示例14: FindAndReplaceFd
func FindAndReplaceFd(fd *os.File, oldPattern, newPattern string) error {
fbuf, err := ioutil.ReadAll(fd)
if err != nil {
return err
}
fd.Seek(0, -1)
fd.Truncate(0)
expr, err := regexp.Compile(oldPattern)
if err != nil {
return err
}
buffer := bytes.NewBuffer(fbuf)
for {
line, err := buffer.ReadString('\n')
if err != nil {
if err == io.EOF {
break
}
return err
}
if expr.MatchString(line) {
line = expr.ReplaceAllString(line, newPattern)
}
if _, err := fd.WriteString(line); err != nil {
return err
}
}
return nil
}
示例15: mergeCoverprofile
func mergeCoverprofile(file *os.File, out io.Writer) error {
_, err := file.Seek(0, 0)
if err != nil {
return err
}
rd := bufio.NewReader(file)
_, err = rd.ReadString('\n')
if err == io.EOF {
return nil
}
if err != nil {
return err
}
_, err = io.Copy(out, rd)
if err != nil {
return err
}
err = file.Close()
if err != nil {
return err
}
return err
}