mirror of
https://github.com/rclone/rclone.git
synced 2025-01-15 10:49:13 +01:00
drive: add support for multipart document extensions
This commit is contained in:
parent
70b30d5ca4
commit
80b25daac7
@ -477,7 +477,7 @@ func (f *Fs) list(dirIDs []string, title string, directoriesOnly bool, filesOnly
|
|||||||
_ = parentsQuery.WriteByte(')')
|
_ = parentsQuery.WriteByte(')')
|
||||||
query = append(query, parentsQuery.String())
|
query = append(query, parentsQuery.String())
|
||||||
}
|
}
|
||||||
stem := ""
|
var stems []string
|
||||||
if title != "" {
|
if title != "" {
|
||||||
// Escaping the backslash isn't documented but seems to work
|
// Escaping the backslash isn't documented but seems to work
|
||||||
searchTitle := strings.Replace(title, `\`, `\\`, -1)
|
searchTitle := strings.Replace(title, `\`, `\\`, -1)
|
||||||
@ -485,17 +485,22 @@ func (f *Fs) list(dirIDs []string, title string, directoriesOnly bool, filesOnly
|
|||||||
// Convert / to / for search
|
// Convert / to / for search
|
||||||
searchTitle = strings.Replace(searchTitle, "/", "/", -1)
|
searchTitle = strings.Replace(searchTitle, "/", "/", -1)
|
||||||
|
|
||||||
handleGdocs := !directoriesOnly && !f.opt.SkipGdocs
|
var titleQuery bytes.Buffer
|
||||||
// if the search title contains an extension and the extension is in the export extensions add a search
|
_, _ = fmt.Fprintf(&titleQuery, "(name='%s'", searchTitle)
|
||||||
|
if !directoriesOnly && !f.opt.SkipGdocs {
|
||||||
|
// If the search title has an extension that is in the export extensions add a search
|
||||||
// for the filename without the extension.
|
// for the filename without the extension.
|
||||||
// assume that export extensions don't contain escape sequences and only have one part (not .tar.gz)
|
// Assume that export extensions don't contain escape sequences.
|
||||||
if ext := path.Ext(searchTitle); handleGdocs && len(ext) > 0 && containsString(f.exportExtensions, ext) {
|
for _, ext := range f.exportExtensions {
|
||||||
stem = title[:len(title)-len(ext)]
|
if strings.HasSuffix(searchTitle, ext) {
|
||||||
query = append(query, fmt.Sprintf("(name='%s' or name='%s')", searchTitle, searchTitle[:len(searchTitle)-len(ext)]))
|
stems = append(stems, title[:len(title)-len(ext)])
|
||||||
} else {
|
_, _ = fmt.Fprintf(&titleQuery, " or name='%s'", searchTitle[:len(searchTitle)-len(ext)])
|
||||||
query = append(query, fmt.Sprintf("name='%s'", searchTitle))
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
_ = titleQuery.WriteByte(')')
|
||||||
|
query = append(query, titleQuery.String())
|
||||||
|
}
|
||||||
if directoriesOnly {
|
if directoriesOnly {
|
||||||
query = append(query, fmt.Sprintf("mimeType='%s'", driveFolderType))
|
query = append(query, fmt.Sprintf("mimeType='%s'", driveFolderType))
|
||||||
}
|
}
|
||||||
@ -546,7 +551,14 @@ OUTER:
|
|||||||
// the `=` operator is case insensitive.
|
// the `=` operator is case insensitive.
|
||||||
|
|
||||||
if title != "" && title != item.Name {
|
if title != "" && title != item.Name {
|
||||||
if stem == "" || stem != item.Name {
|
found := false
|
||||||
|
for _, stem := range stems {
|
||||||
|
if stem == item.Name {
|
||||||
|
found = true
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if !found {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
_, exportName, _, _ := f.findExportFormat(item)
|
_, exportName, _, _ := f.findExportFormat(item)
|
||||||
|
Loading…
Reference in New Issue
Block a user