forked from TrueCloudLab/rclone
fs: support multi-threads to head dst object
Signed-off-by: zhuc <zhucan.k8s@gmail.com>
This commit is contained in:
parent
d5181118cc
commit
a223b78872
1 changed files with 19 additions and 7 deletions
|
@ -382,6 +382,7 @@ func (m *March) processJob(job listDirJob) ([]listDirJob, error) {
|
||||||
srcList, dstList fs.DirEntries
|
srcList, dstList fs.DirEntries
|
||||||
srcListErr, dstListErr error
|
srcListErr, dstListErr error
|
||||||
wg sync.WaitGroup
|
wg sync.WaitGroup
|
||||||
|
mu sync.Mutex
|
||||||
)
|
)
|
||||||
|
|
||||||
// List the src and dst directories
|
// List the src and dst directories
|
||||||
|
@ -416,17 +417,28 @@ func (m *March) processJob(job listDirJob) ([]listDirJob, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// If NoTraverse is set, then try to find a matching object
|
// If NoTraverse is set, then try to find a matching object
|
||||||
// for each item in the srcList
|
// for each item in the srcList to head dst object
|
||||||
|
ci := fs.GetConfig(m.Ctx)
|
||||||
|
limiter := make(chan struct{}, ci.Checkers)
|
||||||
if m.NoTraverse && !m.NoCheckDest {
|
if m.NoTraverse && !m.NoCheckDest {
|
||||||
for _, src := range srcList {
|
for _, src := range srcList {
|
||||||
if srcObj, ok := src.(fs.Object); ok {
|
wg.Add(1)
|
||||||
leaf := path.Base(srcObj.Remote())
|
limiter <- struct{}{}
|
||||||
dstObj, err := m.Fdst.NewObject(m.Ctx, path.Join(job.dstRemote, leaf))
|
go func(limiter chan struct{}, src fs.DirEntry) {
|
||||||
if err == nil {
|
defer wg.Done()
|
||||||
dstList = append(dstList, dstObj)
|
if srcObj, ok := src.(fs.Object); ok {
|
||||||
|
leaf := path.Base(srcObj.Remote())
|
||||||
|
dstObj, err := m.Fdst.NewObject(m.Ctx, path.Join(job.dstRemote, leaf))
|
||||||
|
if err == nil {
|
||||||
|
mu.Lock()
|
||||||
|
dstList = append(dstList, dstObj)
|
||||||
|
mu.Unlock()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
<-limiter
|
||||||
|
}(limiter, src)
|
||||||
}
|
}
|
||||||
|
wg.Wait()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Work out what to do and do it
|
// Work out what to do and do it
|
||||||
|
|
Loading…
Reference in a new issue