diff --git a/cmd/run.go b/cmd/run.go index 22a9b614..2f4aad04 100644 --- a/cmd/run.go +++ b/cmd/run.go @@ -94,6 +94,11 @@ func (run) New(opts *lefthook.Options) *cobra.Command { "run only specified commands", ) + runCmd.Flags().StringSliceVar( + &runArgs.RunOnlyJobs, "jobs", nil, + "run only specified jobs", + ) + err := runCmd.Flags().MarkDeprecated("files", "use --file flag instead") if err != nil { log.Warn("Unexpected error:", err) diff --git a/internal/lefthook/run.go b/internal/lefthook/run.go index 2d41798c..3331de63 100644 --- a/internal/lefthook/run.go +++ b/internal/lefthook/run.go @@ -33,6 +33,7 @@ type RunArgs struct { SkipLFS bool Files []string RunOnlyCommands []string + RunOnlyJobs []string } func Run(opts *Options, args RunArgs, hookName string, gitArgs []string) error { @@ -170,6 +171,7 @@ func (l *Lefthook) Run(hookName string, args RunArgs, gitArgs []string) error { Files: args.Files, Force: args.Force, RunOnlyCommands: args.RunOnlyCommands, + RunOnlyJobs: args.RunOnlyJobs, SourceDirs: sourceDirs, }, ) diff --git a/internal/lefthook/runner/run_jobs.go b/internal/lefthook/runner/run_jobs.go index 827eeccb..97ee68d4 100644 --- a/internal/lefthook/runner/run_jobs.go +++ b/internal/lefthook/runner/run_jobs.go @@ -4,6 +4,7 @@ import ( "context" "errors" "path/filepath" + "slices" "strconv" "sync" "sync/atomic" @@ -81,6 +82,10 @@ func (r *Runner) runJob(ctx context.Context, domain *domain, id string, job *con } if len(job.Run) != 0 || len(job.Script) != 0 { + if len(r.RunOnlyJobs) != 0 && !slices.Contains(r.RunOnlyJobs, job.Name) { + return skipped(job.PrintableName(id)) + } + return r.runSingleJob(ctx, domain, id, job) } @@ -89,6 +94,16 @@ func (r *Runner) runJob(ctx context.Context, domain *domain, id string, job *con inheritedDomain.glob = first(job.Glob, domain.glob) inheritedDomain.root = first(job.Root, domain.root) groupName := first(job.Name, "["+id+"]") + + if len(r.RunOnlyJobs) != 0 && slices.Contains(r.RunOnlyJobs, job.Name) { + children := make([]string, len(job.Group.Jobs), 0) + for _, child := range job.Group.Jobs { + children = append(children, child.Name) + } + + r.RunOnlyJobs = append(r.RunOnlyJobs, children...) + } + return r.runGroup(ctx, groupName, &inheritedDomain, job.Group) } diff --git a/internal/lefthook/runner/runner.go b/internal/lefthook/runner/runner.go index db383a3d..d545fade 100644 --- a/internal/lefthook/runner/runner.go +++ b/internal/lefthook/runner/runner.go @@ -41,6 +41,7 @@ type Options struct { Force bool Files []string RunOnlyCommands []string + RunOnlyJobs []string SourceDirs []string }