1
0
Fork 0
mirror of https://github.com/vbatts/freezing-octo-hipster.git synced 2025-10-25 01:50:56 +00:00

dups: deduplication tool

This commit is contained in:
Vincent Batts 2015-05-21 11:14:05 -04:00
parent 5cbe83545d
commit 4619d4d8b7
2 changed files with 43 additions and 4 deletions

View file

@ -4,6 +4,39 @@ Random utilities of vbatts' being cleaned up, and published
# Commands # Commands
## dups
building a document of file checksum info, for a directory tree. Optionally
deduplicate the tree using hardlinks.
### Install
go get github.com/vbatts/freezing-octo-hipster/cmd/dups
### Usage
$ dups -h
Usage of dups:
-H=false: hardlink the duplicate files
-l="": load existing map from file
-q=false: less output
-s="hash-map.json": file to save map of file hashes to
By default it scans the paths provided, and creates a JSON document of the file paths and their checksum:
$ dups .
"/home/vbatts/src/vb/freezing-octo-hipster/.git/logs/refs/heads/master" is the same content as "/home/vbatts/src/vb/freezing-octo-hipster/.git/logs/HEAD"
"/home/vbatts/src/vb/freezing-octo-hipster/.git/refs/remotes/origin/master" is the same content as "/home/vbatts/src/vb/freezing-octo-hipster/.git/refs/heads/master"
"/home/vbatts/src/vb/freezing-octo-hipster/cmd/find-todos/main.go~" is the same content as "/home/vbatts/src/vb/freezing-octo-hipster/cmd/find-todos/main.go"
"/home/vbatts/src/vb/freezing-octo-hipster/cmd/slackware-sync/README.md~" is the same content as "/home/vbatts/src/vb/freezing-octo-hipster/cmd/slackware-sync/README.md"
"/home/vbatts/src/vb/freezing-octo-hipster/cmd/slackware-sync/main.go" is the same content as "/home/vbatts/src/vb/freezing-octo-hipster/cmd/slackware-sync/main.go~"
Savings of 0.005681mb
wrote "hash-map.json"
With the `-H` flag, as duplicate files are found (files with matching checksum)
are encountered, hardlink it to the duplicate file.
## next-note ## next-note
Simple date formating for notes Simple date formating for notes

View file

@ -3,11 +3,12 @@ package main
import ( import (
"flag" "flag"
"fmt" "fmt"
"github.com/BurntSushi/toml"
"net/url" "net/url"
"os" "os"
"os/exec" "os/exec"
"path" "path"
"github.com/BurntSushi/toml"
) )
func main() { func main() {
@ -19,6 +20,10 @@ func main() {
os.Exit(1) os.Exit(1)
} }
if len(*flSyncDir) > 0 {
config.SyncDir = *flSyncDir
}
_, err = EnsureDirExists(config.SyncDir) _, err = EnsureDirExists(config.SyncDir)
if err != nil { if err != nil {
fmt.Println(err) fmt.Println(err)
@ -82,6 +87,7 @@ type Mirror struct {
} }
var ( var (
flSyncDir = flag.String("dir", "", "directory to sync to (this flag overrides the url in the configuration file)")
flConfigFile = flag.String("c", path.Join(os.Getenv("HOME"), ".slackware-sync.toml"), "config file for the sync") flConfigFile = flag.String("c", path.Join(os.Getenv("HOME"), ".slackware-sync.toml"), "config file for the sync")
flQuiet = flag.Bool("q", false, "less output") flQuiet = flag.Bool("q", false, "less output")
) )