Directories

Directories #

// Go possui várias funções úteis para trabalhar
// com diretórios em um sistema de arquivos.

package main

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

func check(e error) {
	if e != nil {
		panic(e)
	}
}

func main() {

	// Cria um novo sub-diretório no atual diretório.
	err := os.Mkdir("subdir", 0755)
	check(err)

	// Ao criar diretórios temporários, é uma boa prática
	// adicionar um `defer` para removê-los. `os.RemoveAll`
	// irá deletar uma árvore de diretórios por completo
	// (similar ao comando linux rm -rf).
	defer os.RemoveAll("subdir")

	// Função auxiliar para criar um novo arquivo vazio.
	createEmptyFile := func(name string) {
		d := []byte("")
		check(os.WriteFile(name, d, 0644))
	}

	createEmptyFile("subdir/file1")

	// É possível criar hierarquia de diretórios, inclusive
	// parentes com `MkdirAll`. Isto é similar ao comando de
	// linux `mkdir -p`.
	err = os.MkdirAll("subdir/parent/child", 0755)
	check(err)

	createEmptyFile("subdir/parent/file2")
	createEmptyFile("subdir/parent/file3")
	createEmptyFile("subdir/parent/child/file4")

	// `ReadDir` lista o conteúdo do diretório,
	// retornando uma slice de objetos do tipo
	// `os.DirEntry`.
	c, err := os.ReadDir("subdir/parent")
	check(err)

	fmt.Println("Listing subdir/parent")
	for _, entry := range c {
		fmt.Println(" ", entry.Name(), entry.IsDir())
	}

	// `Chdir` permite mudar o diretório de trabalho atual,
	// similar ao comando de linux `cd`.
	err = os.Chdir("subdir/parent/child")
	check(err)

	// Agora, será visto a lista de conteúdos de
	// `subdir/parent/child` quando listar o
	// diretório *atual* (".").
	c, err = os.ReadDir(".")
	check(err)

	fmt.Println("Listing subdir/parent/child")
	for _, entry := range c {
		fmt.Println(" ", entry.Name(), entry.IsDir())
	}

	// `cd` de volta ao ponto de início.
	err = os.Chdir("../../..")
	check(err)

	// É possível visitar um diretório *recursivamente*,
	// incluindo todos os seus sub-diretórios. `Walk`
	// aceita uma função callback para tratar todo arquivo
	// ou diretório visitado.
	fmt.Println("Visiting subdir")
	err = filepath.Walk("subdir", visit)
}

// `visit` é chamado recursivamente para cada arquivo
// e diretório encontrado por `filepath.Walk`.
func visit(p string, info os.FileInfo, err error) error {
	if err != nil {
		return err
	}
	fmt.Println(" ", p, info.IsDir())
	return nil
}
$ go run directories.go
Listing subdir/parent
  child true
  file2 false
  file3 false
Listing subdir/parent/child
  file4 false
Visiting subdir
  subdir true
  subdir/file1 false
  subdir/parent true
  subdir/parent/child true
  subdir/parent/child/file4 false
  subdir/parent/file2 false
  subdir/parent/file3 false