func lockCommand(cmd *cobra.Command, args []string) { setLockRemoteFor(config.Config) if len(args) == 0 { Print("Usage: git lfs lock <path>") return } latest, err := git.CurrentRemoteRef() if err != nil { Error(err.Error()) Exit("Unable to determine lastest remote ref for branch.") } path, err := lockPath(args[0]) if err != nil { Exit(err.Error()) } s, resp := API.Locks.Lock(&api.LockRequest{ Path: path, Committer: api.CurrentCommitter(), LatestRemoteCommit: latest.Sha, }) if _, err := API.Do(s); err != nil { Error(err.Error()) Exit("Error communicating with LFS API.") } if len(resp.Err) > 0 { Error(resp.Err) Exit("Server unable to create lock.") } Print("\n'%s' was locked (%s)", args[0], resp.Lock.Id) }
func statusCommand(cmd *cobra.Command, args []string) { requireInRepo() ref, err := git.CurrentRef() if err != nil { Panic(err, "Could not get the current ref") } stagedPointers, err := lfs.ScanIndex() if err != nil { Panic(err, "Could not scan staging for Git LFS objects") } if porcelain { for _, p := range stagedPointers { switch p.Status { case "R", "C": Print("%s %s -> %s %d", p.Status, p.SrcName, p.Name, p.Size) case "M": Print(" %s %s %d", p.Status, p.Name, p.Size) default: Print("%s %s %d", p.Status, p.Name, p.Size) } } return } Print("On branch %s", ref.Name) remoteRef, err := git.CurrentRemoteRef() if err == nil { pointers, err := lfs.ScanRefs(ref.Sha, "^"+remoteRef.Sha, nil) if err != nil { Panic(err, "Could not scan for Git LFS objects") } Print("Git LFS objects to be pushed to %s:\n", remoteRef.Name) for _, p := range pointers { Print("\t%s (%s)", p.Name, humanizeBytes(p.Size)) } } Print("\nGit LFS objects to be committed:\n") for _, p := range stagedPointers { switch p.Status { case "R", "C": Print("\t%s -> %s (%s)", p.SrcName, p.Name, humanizeBytes(p.Size)) case "M": default: Print("\t%s (%s)", p.Name, humanizeBytes(p.Size)) } } Print("\nGit LFS objects not staged for commit:\n") for _, p := range stagedPointers { if p.Status == "M" { Print("\t%s", p.Name) } } Print("") }