Class DelegatingReadOnlyMacroManager
java.lang.Object
com.atlassian.confluence.macro.xhtml.DelegatingReadOnlyMacroManager
- All Implemented Interfaces:
MacroManager
A Macro Manager which looks for named macros in an ordered manner through a list of delegate MacroManager's it maintains.
This MacroManager is read only and therefore the registerMacro(String, Macro)
and
unregisterMacro(String)
calls are not supported.
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptiongetMacroByName
(String macroName) Gives theMacro
registered with the given name, or null if there is none registered with the manager.io.atlassian.util.concurrent.LazyReference
<Macro> newLazyMacroReference
(com.atlassian.plugin.ModuleDescriptor<?> moduleDescriptor) Macros are lazy loaded to avoid plugin module ordering problems like CONF-13386.void
registerMacro
(String name, Macro macro) Registers a new macro with the given name.void
unregisterMacro
(String name) Unregisters the macro with the given name.
-
Constructor Details
-
DelegatingReadOnlyMacroManager
-
-
Method Details
-
getMacroByName
Description copied from interface:MacroManager
Gives theMacro
registered with the given name, or null if there is none registered with the manager.- Specified by:
getMacroByName
in interfaceMacroManager
- Parameters:
macroName
- The macro to get.- Returns:
- The Macro, or null if there is none registered.
-
registerMacro
Description copied from interface:MacroManager
Registers a new macro with the given name. If a macro already exists with that name, it is replaced by the new macro.- Specified by:
registerMacro
in interfaceMacroManager
- Parameters:
name
- the name to register the macro under. For example, 'code'.macro
- the macro to register- Throws:
UnsupportedOperationException
-
unregisterMacro
Description copied from interface:MacroManager
Unregisters the macro with the given name. Does nothing if no such macro is registered.- Specified by:
unregisterMacro
in interfaceMacroManager
- Parameters:
name
- the name of the macro to unregister. For example, 'code'.- Throws:
UnsupportedOperationException
-
newLazyMacroReference
public io.atlassian.util.concurrent.LazyReference<Macro> newLazyMacroReference(com.atlassian.plugin.ModuleDescriptor<?> moduleDescriptor) Description copied from interface:MacroManager
Macros are lazy loaded to avoid plugin module ordering problems like CONF-13386.- Specified by:
newLazyMacroReference
in interfaceMacroManager
- Parameters:
moduleDescriptor
- describes the macro we are creating a lazy reference to.- Returns:
- a LazyReference to a macro as described by the supplied ModuleDescriptor
-