Class BuildTrigger.DescriptorImpl
- java.lang.Object
-
- hudson.model.Descriptor<T>
-
- hudson.tasks.BuildStepDescriptor<Publisher>
-
- hudson.tasks.BuildTrigger.DescriptorImpl
-
- Enclosing class:
- BuildTrigger
@Extension @Symbol("downstream") public static class BuildTrigger.DescriptorImpl extends BuildStepDescriptor<Publisher>
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static class
BuildTrigger.DescriptorImpl.ItemListenerImpl
-
Nested classes/interfaces inherited from class hudson.model.Descriptor
Descriptor.FormException, Descriptor.PropertyType, Descriptor.Self
-
-
Field Summary
-
Fields inherited from class hudson.model.Descriptor
clazz
-
-
Constructor Summary
Constructors Constructor Description DescriptorImpl()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description AutoCompletionCandidates
doAutoCompleteChildProjects(String value, Item self, ItemGroup container)
FormValidation
doCheck(AbstractProject project, String value)
Form validation method.String
getDisplayName()
Human readable name of this kind of configurable object.String
getHelpFile()
Returns the resource path to the help screen HTML, if any.boolean
isApplicable(Class<? extends AbstractProject> jobType)
Returns true if this task is applicable to the given project.BuildTrigger
newInstance(org.kohsuke.stapler.StaplerRequest req, net.sf.json.JSONObject formData)
Creates a configured instance from the submitted form.boolean
showEvenIfUnstableOption(Class<? extends AbstractProject<?,?>> jobType)
-
Methods inherited from class hudson.tasks.BuildStepDescriptor
filter
-
Methods inherited from class hudson.model.Descriptor
addHelpFileRedirect, bindJSON, calcAutoCompleteSettings, calcFillSettings, configure, configure, doHelp, find, find, findByDescribableClassName, findById, getCategory, getCheckMethod, getCheckUrl, getConfigFile, getConfigPage, getCurrentDescriptorByNameUrl, getDescriptorFullUrl, getDescriptorUrl, getGlobalConfigPage, getGlobalPropertyType, getHelpFile, getHelpFile, getId, getJsonSafeClassName, getKlass, getPlugin, getPossibleViewNames, getPropertyType, getPropertyType, getPropertyTypeOrDie, getRequiredGlobalConfigPagePermission, getT, getViewPage, isInstance, isSubTypeOf, load, newInstance, newInstancesFromHeteroList, newInstancesFromHeteroList, save, self, toArray, toList, toMap
-
-
-
-
Method Detail
-
getDisplayName
@NonNull public String getDisplayName()
Description copied from class:Descriptor
Human readable name of this kind of configurable object. Should be overridden for most descriptors, if the display name is visible somehow. As a fallback it usesClass.getSimpleName()
onDescriptor.clazz
, so for exampleMyThing
fromsome.pkg.MyThing.DescriptorImpl
. Historically some implementations returned null as a way of hiding the descriptor from the UI, but this is generally managed by an explicit method such asisEnabled
orisApplicable
.- Overrides:
getDisplayName
in classDescriptor<Publisher>
-
getHelpFile
public String getHelpFile()
Description copied from class:Descriptor
Returns the resource path to the help screen HTML, if any.Starting 1.282, this method uses "convention over configuration" — you should just put the "help.html" (and its localized versions, if any) in the same directory you put your Jelly view files, and this method will automatically does the right thing.
This value is relative to the context root of Hudson, so normally the values are something like
"/plugin/emma/help.html"
to refer to static resource files in a plugin, or"/publisher/EmmaPublisher/abc"
to refer to Jelly scriptabc.jelly
or a methodEmmaPublisher.doAbc()
.- Overrides:
getHelpFile
in classDescriptor<Publisher>
- Returns:
- null to indicate that there's no help.
-
newInstance
public BuildTrigger newInstance(org.kohsuke.stapler.StaplerRequest req, net.sf.json.JSONObject formData) throws Descriptor.FormException
Description copied from class:Descriptor
Creates a configured instance from the submitted form.Hudson only invokes this method when the user wants an instance of
T
. So there's no need to check that in the implementation.The default implementation of this method uses
Descriptor.bindJSON(org.kohsuke.stapler.StaplerRequest, java.lang.Class<T>, net.sf.json.JSONObject)
which performs the databinding on the constructor ofDescriptor.clazz
.For some types of
Describable
, such asListViewColumn
, this method can be invoked with null request object for historical reason. Such design is considered broken, but due to the compatibility reasons we cannot fix it. Because of this, the default implementation gracefully handles null request, but the contract of the method still is "request is always non-null." Extension points that need to define the "default instance" semantics should define a descriptor subtype and add the no-arg newInstance method.- Overrides:
newInstance
in classDescriptor<Publisher>
- Parameters:
req
- Always non-null (see note above.) This object includes represents the entire submission.formData
- The JSON object that captures the configuration data for thisDescriptor
. See the developer documentation. Always non-null.- Throws:
Descriptor.FormException
- Signals a problem in the submitted form.
-
isApplicable
public boolean isApplicable(Class<? extends AbstractProject> jobType)
Description copied from class:BuildStepDescriptor
Returns true if this task is applicable to the given project.- Specified by:
isApplicable
in classBuildStepDescriptor<Publisher>
- Returns:
- true to allow user to configure this post-promotion task for the given project.
- See Also:
AbstractProject.AbstractProjectDescriptor.isApplicable(Descriptor)
-
showEvenIfUnstableOption
public boolean showEvenIfUnstableOption(@CheckForNull Class<? extends AbstractProject<?,?>> jobType)
-
doCheck
public FormValidation doCheck(@AncestorInPath AbstractProject project, @QueryParameter String value)
Form validation method.
-
doAutoCompleteChildProjects
public AutoCompletionCandidates doAutoCompleteChildProjects(@QueryParameter String value, @AncestorInPath Item self, @AncestorInPath ItemGroup container)
-
-