2014-11-24 10:58:57 +01:00
|
|
|
// Copyright (C) 2014 The Syncthing Authors.
|
|
|
|
//
|
2015-03-07 21:36:35 +01:00
|
|
|
// This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
// License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
2017-02-09 07:52:18 +01:00
|
|
|
// You can obtain one at https://mozilla.org/MPL/2.0/.
|
2014-11-24 10:58:57 +01:00
|
|
|
|
|
|
|
package versioner
|
|
|
|
|
|
|
|
import (
|
|
|
|
"path/filepath"
|
|
|
|
"regexp"
|
2018-01-01 14:39:23 +00:00
|
|
|
"strings"
|
2014-11-24 10:58:57 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
// Inserts ~tag just before the extension of the filename.
|
2018-01-01 14:39:23 +00:00
|
|
|
func TagFilename(name, tag string) string {
|
2014-11-24 10:58:57 +01:00
|
|
|
dir, file := filepath.Dir(name), filepath.Base(name)
|
|
|
|
ext := filepath.Ext(file)
|
|
|
|
withoutExt := file[:len(file)-len(ext)]
|
|
|
|
return filepath.Join(dir, withoutExt+"~"+tag+ext)
|
|
|
|
}
|
|
|
|
|
2014-11-25 22:32:18 +00:00
|
|
|
var tagExp = regexp.MustCompile(`.*~([^~.]+)(?:\.[^.]+)?$`)
|
2014-11-24 10:58:57 +01:00
|
|
|
|
|
|
|
// Returns the tag from a filename, whether at the end or middle.
|
2018-01-01 14:39:23 +00:00
|
|
|
func ExtractTag(path string) string {
|
2014-11-24 10:58:57 +01:00
|
|
|
match := tagExp.FindStringSubmatch(path)
|
2015-04-28 18:34:55 +03:00
|
|
|
// match is []string{"whole match", "submatch"} when successful
|
2014-11-24 10:58:57 +01:00
|
|
|
|
|
|
|
if len(match) != 2 {
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
return match[1]
|
|
|
|
}
|
2018-01-01 14:39:23 +00:00
|
|
|
|
|
|
|
func UntagFilename(path string) (string, string) {
|
|
|
|
ext := filepath.Ext(path)
|
|
|
|
versionTag := ExtractTag(path)
|
|
|
|
|
|
|
|
// Files tagged with old style tags cannot be untagged.
|
|
|
|
if versionTag == "" || strings.HasSuffix(ext, versionTag) {
|
|
|
|
return "", ""
|
|
|
|
}
|
|
|
|
|
|
|
|
withoutExt := path[:len(path)-len(ext)-len(versionTag)-1]
|
|
|
|
name := withoutExt + ext
|
|
|
|
return name, versionTag
|
|
|
|
}
|