agola/internal/util/path.go

76 lines
2.1 KiB
Go
Raw Permalink Normal View History

2019-02-21 14:54:50 +00:00
// Copyright 2019 Sorint.lab
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied
// See the License for the specific language governing permissions and
// limitations under the License.
package util
2019-03-28 15:02:11 +00:00
import (
"path"
"strings"
2019-03-28 15:02:11 +00:00
)
2019-02-21 14:54:50 +00:00
// PathHierarchy return a slice of paths from the base path (root included as . or / ).
// I.E. for a path like "path/to/file" it'll return a slice of these elements:
// ".", "path", "path/to", "path/to/file"
2019-03-28 15:02:11 +00:00
// for a path like "/path/to/file" it'll return a slice of these elements:
// "/", "/path", "/path/to", "/path/to/file"
2019-02-21 14:54:50 +00:00
func PathHierarchy(p string) []string {
paths := []string{}
for {
paths = append([]string{p}, paths...)
prevp := p
p = path.Dir(p)
if p == prevp {
break
}
}
return paths
}
2019-03-28 15:02:11 +00:00
// PathList return a slice of paths from the base path (root exluded as . or / ).
// I.E. for a path like "path/to/file" or "/path/to/file" it'll return a slice of these elements:
// "path", "to", "file"
func PathList(p string) []string {
paths := []string{}
for {
paths = append([]string{path.Base(p)}, paths...)
p = path.Dir(p)
if p == "." || p == "/" {
break
}
}
return paths
}
// IsParentPath returns if the provided parent is parent of p
// parent and p paths must use slash "/" separators and must be absolute paths
func IsParentPath(parent, p string) bool {
// add ending / to avoid names with common prefix, like:
// /path/to
// /path/t
if !strings.HasSuffix(parent, "/") {
parent = parent + "/"
}
return strings.Contains(p, parent)
}
// IsParentPath returns if the provided parent the same path as p or a parent of p
// parent and p paths must use slash "/" separators
func IsSameOrParentPath(parent, p string) bool {
if parent == p {
return true
}
return IsParentPath(parent, p)
}