Actually invert the init flag

This commit is contained in:
2024-07-20 19:51:33 +02:00
parent e9b6788af6
commit 7090618dbd

80
main.go
View File

@@ -66,11 +66,13 @@ func main() {
} }
var name string var name string
var private, forceInit bool var private, noinit, forceInit bool
flag.StringVar(&name, "name", "", "Name of the repository") flag.StringVar(&name, "name", "", "Name of the repository")
flag.StringVar(&name, "n", "", "Name of the repository (shorthand)") flag.StringVar(&name, "n", "", "Name of the repository (shorthand)")
flag.BoolVar(&private, "private", false, "Make the repository private") flag.BoolVar(&private, "private", false, "Make the repository private")
flag.BoolVar(&private, "p", false, "Make the repository private (shorthand)") flag.BoolVar(&private, "p", false, "Make the repository private (shorthand)")
flag.BoolVar(&noinit, "noinit", false, "Do not add remote to the new repo")
flag.BoolVar(&noinit, "ni", false, "Do not add remote to the new repo (shorthand)")
flag.BoolVar(&forceInit, "f", false, "Force assignment of the remote (deletes existing origin)") flag.BoolVar(&forceInit, "f", false, "Force assignment of the remote (deletes existing origin)")
flag.Parse() flag.Parse()
@@ -108,49 +110,51 @@ func main() {
clipboard.Write(clipboard.FmtText, []byte(repo.CloneURL)) clipboard.Write(clipboard.FmtText, []byte(repo.CloneURL))
} }
cwd, err := os.Getwd() if !noinit {
if err != nil { cwd, err := os.Getwd()
Error.Fatalf("Error getting current working directory: %v", err) if err != nil {
os.Exit(1) Error.Fatalf("Error getting current working directory: %v", err)
} os.Exit(1)
cwd = path.Clean(cwd) }
cwd = path.Clean(cwd)
var localRepo *git.Repository var localRepo *git.Repository
_, err = os.Stat(path.Join(cwd, ".git")) _, err = os.Stat(path.Join(cwd, ".git"))
if err == nil { if err == nil {
localRepo, err = git.PlainOpen(cwd) localRepo, err = git.PlainOpen(cwd)
if err != nil {
Error.Fatalf("Error opening git repository: %v", err)
os.Exit(1)
}
} else {
localRepo, err = git.PlainInit(cwd, false)
if err != nil {
Error.Fatalf("Error initializing git repository: %v", err)
os.Exit(1)
}
}
_, err = localRepo.Remote("origin")
if err == nil {
if forceInit {
err = localRepo.DeleteRemote("origin")
if err != nil { if err != nil {
Error.Fatalf("Error deleting remote from local repository: %v", err) Error.Fatalf("Error opening git repository: %v", err)
os.Exit(1) os.Exit(1)
} }
} else { } else {
Error.Fatalf("Remote origin already exists in local repository") localRepo, err = git.PlainInit(cwd, false)
if err != nil {
Error.Fatalf("Error initializing git repository: %v", err)
os.Exit(1)
}
}
_, err = localRepo.Remote("origin")
if err == nil {
if forceInit {
err = localRepo.DeleteRemote("origin")
if err != nil {
Error.Fatalf("Error deleting remote from local repository: %v", err)
os.Exit(1)
}
} else {
Error.Fatalf("Remote origin already exists in local repository")
os.Exit(1)
}
}
_, err = localRepo.CreateRemote(&config.RemoteConfig{
Name: "origin",
URLs: []string{repo.CloneURL},
})
if err != nil {
Error.Fatalf("Error adding remote to local repository: %v", err)
os.Exit(1) os.Exit(1)
} }
log.Printf("Remote added to local repository")
} }
_, err = localRepo.CreateRemote(&config.RemoteConfig{
Name: "origin",
URLs: []string{repo.CloneURL},
})
if err != nil {
Error.Fatalf("Error adding remote to local repository: %v", err)
os.Exit(1)
}
log.Printf("Remote added to local repository")
} }