2019-01-12 04:58:27 +00:00
/ *
Copyright 2018 The Kubernetes Authors .
Licensed under the Apache License , Version 2.0 ( the "License" ) ;
you may not use this file except in compliance with the License .
You may obtain a copy of the License at
http : //www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing , software
distributed under the License is distributed on an "AS IS" BASIS ,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND , either express or implied .
See the License for the specific language governing permissions and
limitations under the License .
* /
package genericclioptions
import (
"strings"
"github.com/spf13/cobra"
"github.com/spf13/pflag"
2019-04-07 17:07:55 +00:00
"k8s.io/cli-runtime/pkg/resource"
2019-01-12 04:58:27 +00:00
)
2021-03-18 22:40:29 +00:00
// FileNameFlags are flags for processing files.
2019-01-12 04:58:27 +00:00
// Usage of this struct by itself is discouraged.
// These flags are composed by ResourceBuilderFlags
// which should be used instead.
type FileNameFlags struct {
Usage string
Filenames * [ ] string
2019-08-30 18:33:25 +00:00
Kustomize * string
2019-01-12 04:58:27 +00:00
Recursive * bool
}
2021-03-18 22:40:29 +00:00
// ToOptions creates a new FileNameOptions struct and sets FilenameOptions based on FileNameflags
2019-01-12 04:58:27 +00:00
func ( o * FileNameFlags ) ToOptions ( ) resource . FilenameOptions {
options := resource . FilenameOptions { }
if o == nil {
return options
}
if o . Recursive != nil {
options . Recursive = * o . Recursive
}
if o . Filenames != nil {
options . Filenames = * o . Filenames
}
2019-08-30 18:33:25 +00:00
if o . Kustomize != nil {
options . Kustomize = * o . Kustomize
}
2019-01-12 04:58:27 +00:00
return options
}
2021-03-18 22:40:29 +00:00
// AddFlags binds file name flags to a given flagset
2019-01-12 04:58:27 +00:00
func ( o * FileNameFlags ) AddFlags ( flags * pflag . FlagSet ) {
if o == nil {
return
}
if o . Recursive != nil {
flags . BoolVarP ( o . Recursive , "recursive" , "R" , * o . Recursive , "Process the directory used in -f, --filename recursively. Useful when you want to manage related manifests organized within the same directory." )
}
if o . Filenames != nil {
flags . StringSliceVarP ( o . Filenames , "filename" , "f" , * o . Filenames , o . Usage )
annotations := make ( [ ] string , 0 , len ( resource . FileExtensions ) )
for _ , ext := range resource . FileExtensions {
annotations = append ( annotations , strings . TrimLeft ( ext , "." ) )
}
flags . SetAnnotation ( "filename" , cobra . BashCompFilenameExt , annotations )
}
2019-08-30 18:33:25 +00:00
if o . Kustomize != nil {
flags . StringVarP ( o . Kustomize , "kustomize" , "k" , * o . Kustomize ,
"Process a kustomization directory. This flag can't be used together with -f or -R." )
}
2019-01-12 04:58:27 +00:00
}