本文整理汇总了Golang中github.com/google/stenographer/indexfile.IndexFile类的典型用法代码示例。如果您正苦于以下问题:Golang IndexFile类的具体用法?Golang IndexFile怎么用?Golang IndexFile使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了IndexFile类的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Golang代码示例。
示例1: log
func log(q Query, i *indexfile.IndexFile, bp *base.Positions, err *error) func() {
start := time.Now()
if q.base() {
indexBaseLookupsStarted.Increment()
} else {
indexSetLookupsStarted.Increment()
}
return func() {
duration := time.Since(start)
if q.base() {
indexBaseLookupsFinished.Increment()
indexBaseLookupNanos.IncrementBy(duration.Nanoseconds())
} else {
indexSetLookupsFinished.Increment()
indexSetLookupNanos.IncrementBy(duration.Nanoseconds())
}
v(3, "Query %q in %q took %v, found %d %v", q, i.Name(), duration, len(*bp), *err)
}
}
开发者ID:nizq,项目名称:stenographer,代码行数:19,代码来源:query.go
示例2: LookupIn
func (a timeQuery) LookupIn(ctx context.Context, index *indexfile.IndexFile) (bp base.Positions, err error) {
defer log(a, index, &bp, &err)()
last := filepath.Base(index.Name())
intval, err := strconv.ParseInt(last, 10, 64)
if err != nil {
return nil, fmt.Errorf("could not parse basename %q: %v", last, err)
}
t := time.Unix(0, intval*1000) // converts micros -> nanos
// Note, we add a minute when doing 'before' queries and subtract a minute
// when doing 'after' queries, to make sure we actually get the time
// specified.
if !a[0].IsZero() && t.Before(a[0].Add(time.Minute)) {
v(2, "time query skipping %q", index.Name())
return base.NoPositions, nil
}
if !a[1].IsZero() && t.After(a[1].Add(-time.Minute)) {
v(2, "time query skipping %q", index.Name())
return base.NoPositions, nil
}
v(2, "time query using %q", index.Name())
return base.AllPositions, nil
}
开发者ID:nizq,项目名称:stenographer,代码行数:22,代码来源:query.go
注:本文中的github.com/google/stenographer/indexfile.IndexFile类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。 |
请发表评论