File Paths

File Paths #

// O pacote `filepath` fornece funções para parsear
// e construir *file paths*, ou caminhos de arquivos,
// de uma maneira flexível que pode ser utilizado
// em vários sistemas operacionais; `dir/file` no
// Linux vs. `dir\file` no Windows, por exemplo.
package main

import (
	"fmt"
	"path/filepath"
	"strings"
)

func main() {

	// `Join` deve ser usado para construir caminhos
	// de forma flexível. Pode receber qualquer número
	// de argumentos e constrói um caminho com hierarquia
	// a partir deles.
	p := filepath.Join("dir1", "dir2", "filename")
	fmt.Println("p:", p)

	// Sempre deve ser utilizado o `Join` ao invés de
	// concatenar `/` ou `\` manualmente. Em adição
	// a a tornar flexível e utilizável em mais de um
	// sistema operacional, `Join` também irá normalizar
	// os caminhos, removendo separadores superfluos e
	// mudanças de diretório.
	fmt.Println(filepath.Join("dir1//", "filename"))
	fmt.Println(filepath.Join("dir1/../dir1", "filename"))

	// `Dir` e `Base` podem se rusados para dividir o caminho
	// para o diretório e para o arquivo. Alternativamente,
	// `Split` retornará ambos em uma mesma chamada.
	fmt.Println("Dir(p):", filepath.Dir(p))
	fmt.Println("Base(p):", filepath.Base(p))

	// É possível checar se um caminho é absoluto.
	fmt.Println(filepath.IsAbs("dir/file"))
	fmt.Println(filepath.IsAbs("/dir/file"))

	filename := "config.json"

	// Alguns nomes de arquivos tem extenção seguida
	// de um ponto. É possível separar a extensão do
	// resto do nome com `Ext`.
	ext := filepath.Ext(filename)
	fmt.Println(ext)

	// Para encontrar nomes de arquivos com extensão
	// usa-se `strings.TrimSuffix`.
	fmt.Println(strings.TrimSuffix(filename, ext))

	// `Rel` encontra o caminho relativo entre *base* e
	// *alvo*, ou *target*. Retorna erro se o alvo não
	// pode ser acessar a partir de base.
	rel, err := filepath.Rel("a/b", "a/b/t/file")
	if err != nil {
		panic(err)
	}
	fmt.Println(rel)

	rel, err = filepath.Rel("a/b", "a/c/t/file")
	if err != nil {
		panic(err)
	}
	fmt.Println(rel)
}
$ go run file-paths.go
p: dir1/dir2/filename
dir1/filename
dir1/filename
Dir(p): dir1/dir2
Base(p): filename
false
true
.json
config
t/file
../c/t/file