Gaffer 1.4 release
(Redirected from Gaffer 1.4 release summary)
This page contains a collated and ordered list of changelog entries for all Gaffer 1.4.x.x releases up to and including Gaffer 1.4.15.2.
Features
- Arnold : Added support for Arnold 7.3. Note that a minimum of 7.3.1.0 is required, meaning that 7.3.0.0 is not supported.
- Cycles :
- Updated to version 4.0.2.
- Added support for CUDA and Optix devices (GCC 11 and Windows builds only).
 
- ContactSheet : Added new node for creating contact sheets from multiple input images.
- 3Delight :
- Added interactive Viewer renderer.
- Added “3Delight Cloud” renderer, for rendering using the 3Delight cloud.
 
- DeepSlice : Added a new node for clipping out part of an image based on depth.
- Dispatcher : Dispatchers are now TaskNodes, allowing them to be nested in a task graph. Possibilities include :
- Using a LocalDispatcher and a Wedge to launch multiple TractorDispatcher jobs.
- Using a nested LocalDispatcher to perform a group of tasks on a single blade within a TractorDispatcher job.
 
- GraphEditor : Added X shortcut for removing connections between nodules. Hold X then left click to remove all connections under the cursor. Hold X then left drag to draw a line, all connections that intersect with the line will be removed once the drag is ended (#788).
- ImageInspector : Added a new panel for inspecting image format, metadata and channel statistics.
- LightPosition Tool :
- Added a variation on the shadow placement tool to place highlights. Lights are positioned such that they will create a specular highlight at the target point.
- Added Diffusemode for placing lights along the normal of the target position.
 
- MeshTessellate : Added a new node for increasing the polycount of subdivision meshes.
- MeshTessellate/MeshType : Added support for special-purpose subdiv options: interpolateBoundary, faceVaryingLinearInterpolation, triangleSubdivisionRule.
- RenderPassEditor :
- Added typecolumn for configuring specific passes to render with a predefined type. We provide default configurations of a number of render pass types, these can be modified to suit specific workflows via the RenderPassShader node or by registering new types and processors via the RenderPassTypeAdaptor in a startup file.
- The default render pass type configurations include :
- A “shadow” type for catching shadows cast by casterlocations oncatcherlocations.
- A “reflection” type for catching reflections cast by casterlocations oncatcherlocations. The roughness of the reflective material can be configured per catcher location by creating auser:renderPass:reflectionCatcher:roughnessfloat attribute.
- A “reflectionAlpha” type for catching reflection mattes cast by casterlocations oncatcherlocations. The colour of the matte can be configured per caster location by creating auser:renderPass:reflectionCaster:colorColor3f attribute.
 
- A “shadow” type for catching shadows cast by 
 
- Added 
- RenderPassShader : Added new node for overriding a shader used by a render pass type.
- SelectionTool : Added select mode plug. When set to anything except Standardusing the SelectionTool causes the actual scene location selected to potentially be modified from the originally selected location. Selection modifiers work identically for deselection. Currently, two selectors are implemented :- USD Kind : When selecting, the first ancestor location with a usd:kindattribute matching the chosen list of USD Kind will ultimately be selected. USD’s Kind Registry includesAssembly,Component,Group,ModelandSubComponentby default and can be extended via USD startup scripts.
- Shader Assignment : When selecting, the first ancestor location with a renderable and direct (not inherited) shader attribute will ultimately be selected. This can be used to select either surface or displacement shaders.
 
- USD Kind : When selecting, the first ancestor location with a 
- ShaderTweaks : Added support for creating ShaderTweakProxy nodes that allow making input connections to the original network.
- Viewer : Added support for Cycles GPU rendering via a new Device option in the Cycles viewer settings.
Improvements
- Annotations :
- Added support for {plug}value substitutions in node annotations.
- Added Ctrl + Enter keyboard shortcut to annotation dialogue. This applies the annotation and closes the dialogue.
 
- Added support for 
- Arnold :
- OSL shaders with connections from multiple outputs are no longer duplicated on export to Arnold.
- Gaffer’s native OpenColorIO config is now automatically translated to Arnold. Use an ArnoldColorManager node to override this behaviour.
- Added support for Int64Data and UInt64Data custom attributes, allowing USD’s instanceIdto be used as a custom attribute in the Instancer node. Warnings are emitted if values are out of range for Arnold’s 32 bit ints.
- If it exists, an ai:volumeattribute is preferred over anai:surfaceattribute when resolving shaders for volumes.
 
- ArnoldAttributes : Added syntax highlighting and auto-complete for set expressions on the shadowGroupplug.
- ArnoldShader :
- Added parameter tooltips based on helpmetadata provided by Arnold.
- Added a UI layout for the new openpbr_surfaceshader.
- Moved Arnold 7.3.3.0’s new standard_volume.scatter_diffusionparameters to a “Scatter Diffusion” section of the UI.
- Moved the toonshader’s*_tonemap_hue_saturationparameters to appropriate sections in the UI.
- The following parameters are now visible in the GraphEditor :
- The aov_inputparameter of theaov_write_intshader.
- The data_inputparameter of thecolor_jittershader.
- The input_intandseedparameters of therandomshader.
- The indexparameters of theswitch_rgbaandswitch_shadershaders.
- The defaultparameter of theuser_data_intshader.
 
- The 
- The following parameters can now be made visible in the GraphEditor :
- The flake_layersparameter of thecar_paintshader.
- The data_seed,proc_seed,obj_seed, andface_seedparameters of thecolor_jittershader.
 
- The 
 
- Added parameter tooltips based on 
- Arnold light_decay:- Increased the size of the triangle indicators for the decay ranges.
- The decay range indicators are now scaled by the light’s gl:visualiser:scaleattribute.
- The decay range is now ignored when framing a light in the Viewer.
 
- AttributeTweaks, CameraTweaks, ShaderTweaks, OptionTweaks, PrimitiveVariableTweaks :
- Added support for a {source}token which is substituted with the original value when tweaking a string inReplacemode.
- Added tooltips documenting the tweak modes.
 
- Added support for a 
- AttributeQuery, PrimitiveVariableQuery, ContextQuery, OptionQuery, ShaderQuery : Added support for querying arrays of length 1 as their equivalent scalar types.
- Backdrop : Improved drawing order for nested backdrops :
- Larger backdrops are automatically drawn behind smaller ones, so that nested backdrops will always appear on top.
- Added a depthplug to assign a manual drawing depth for the rare cases where the automatic depth is unwanted.
 
- BackgroundTask : Added reporting of tasks attempting to wait for themselves.
- Cache : Increased default computation cache size to 8Gb. Call Gaffer.ValuePlug.setCacheMemoryLimit()from a startup file to override this.
- Catalogue :
- Added imageNamesoutput plug, containing the names of all images in the Catalogue. Among other things this can be used to drive a Wedge or ContactSheet node and a CatalogueSelect.
- Added a handle for controlling the relative sizes of the listing and image property widgets.
 
- Added 
- CodeWidget :
- Added highlighting of braces and operators.
- Added Ctrl+L shortcut for selecting all text on the current line.
 
- Collect : Added the ability to collect StringVectorData inputs.
- ColorChooser :
- Added channel names to identify sliders.
- Setting the saturation to zero no longer resets the hue and setting the value to zero no longer resets the hue and saturation.
 
- CropWindowTool : Added Alt+Cfor toggling both the crop window tool and the relevant crop windowenabledplug.
- Cryptomatte : Renamed __manifestSceneplug tomanifestSceneso it is no longer considered to be private.
- Cycles :
- Updated the UI of Cycles shaders and lights for ease of use and to match Blender conventions.
- Hide certain parameters based on UI selections.
- Renamed and reordered parameters and created sections to match Blender.
- Changed all the Cycles items in the Gaffer tab menu to title case.
- Changed default value for principled_bsdf.specular_ior_levelto0.5, matching Blender.
- Added support for uv.tangentanduv.tangent_signprimitive variables to assist in rendering with normal maps (#5269).
 
- CyclesOptions : Improved device selection UI.
- 3Delight :
- Added NSI screen static sampling pattern option (dl:staticsamplingpattern).
- Added support for layerNameparameter in output definitions.
- Added support for filterparameter in output definitions.
- Added camera overscan support.
- Added support for reading dl:anduser:attributes from shaders.
- Added importanceSampleFilterplug to DelightOptions, providing denoiser-compatible output.
- Added support for external procedurals.
- Matched DelightOptions default values for oversamplingandshadingSamplesto 3Delight’s own default values.
- NSI scene description export format is now based on file extension - .nsifor binary and.nsiafor ASCII.
- Added support for multipart EXR renders by using the same file name parameter on multiple outputs.
- Added support for scalarformat, colorprofile, filterwidth and arbitrary custom NSI outputlayer and outputdriver attributes.
- Updated the default output presets to include scalarformat, colorprofile, filter and filterwidth output parameters.
 
- Added NSI screen static sampling pattern option (
- Dispatcher : Reduced internal overhead of dispatch()call, with one benchmark showing around a 3x speedup.
- EditScope :
- Added a summary of edits in the NodeEditor, with the ability to select the affected objects and quickly navigate to the processor nodes.
- Added summaries of set membership edits in the NodeEditor.
- Filtered the EditScope menu to show only nodes that are active in the relevant context.
 
- EditScopePlugValueWidget : Width can now be configured via <layoutName>:widthmetadata. This enables customisation of the Edit Scope menu width by registering metadata in a startup file, such asGaffer.Metadata.registerValue( GafferSceneUI.RenderPassEditor.Settings, "editScope", "layout:width", 450 )to double the standard width of the Edit Scope menu in the Render Pass Editor.- When viewing the output of a Box, the menu now displays the Edit Scopes contained within.
- Added support for dropping an Edit Scope node onto the widget to set it as the current Edit Scope.
- Added support for middle-dragging from the widget to access the current Edit Scope node.
- Added icon representing the Edit Scope node colour.
 
- File Browser : The “Type” column can now be sorted. This sorts directories separately from files, which are sorted by their extension.
- GraphComponent : Node and Plug names may now start with a numeric digit.
- GraphEditor :
- The source node for any location can be located by dragging the location into the GraphEditor from the Viewer or HierarchyView.
- Removed all renderer-specific Render and InteractiveRender nodes from the node menu. These nodes still exist for backwards compatibility with old scenes, but the generic Render and InteractiveRender nodes should now be used instead.
- Improved logic used to connect a newly created node to the selected nodes.
- Improved pointer used to indicate when dropping a location would find the source node.
 
- Group : Added setsplug, to control what sets the group belongs to.
- HierarchyView, LightEditor, RenderPassEditor, SetEditor : Reduced potential UI stalls when first showing a scene.
- ImageReader :
- Added fileValid = Falsemetadata to images from missing frames, whenmissingFrameModeisBlackorHold.
- Improved multithreading of EXR reads. This can result in a performance improvement of around 4X for large images.
- Added OIIO config that disables OIIO threading by default. This simplifies our threading model, and has no impact on performance for our main use cases. If read performance of Gaffer compositing using non-EXR formats, such as Tiff, is important to you, you may want to add your own config to turn OIIO threading back on.
 
- Added 
- ImageStats : Added areaSourceplug, allowing area to be driven by the input display window or data window.
- LightEditor :
- Added support for Arnold light blockers and barndoor, gobo and decay light filters.
- Values of inherited attributes are now displayed in the Light Editor. These are presented as dimmed “fallback” values. Values are inherited from an ancestor of the inspected location or from attributes created in the scene globals.
- Default values are now displayed as dimmed “fallback” values for attributes that don’t exist in the scene.
- When a fallback value is displayed, the cell’s tooltip includes a description of the source of the value.
- Mute and solo columns now accurately reflect the presence of the light:muteattribute (for the Mute column) and membership in thesoloLightsset (for the Solo column) for all scene locations, not just for lights.
- Added the ability to register columns for editing any parameter in a light’s shader network. The parameter to edit is registered in the form shaderName.parameterNamewhen callingGafferSceneUI.LightEditor.registerParameter.
- Added columns for Arnold-specific parameters on USD lights.
 
- LightEditor, RenderPassEditor : Fallback values shown in the history window are displayed with the same dimmed text colour used for fallback values in editor columns.
- LightPositionTool :
- The tool is now only visible for members of the __lightsset, instead of all objects.
- Changed the pointer to notEditablewhen using keyboard combinations that do not apply to the current tool mode.
 
- The tool is now only visible for members of the 
- LocalDispatcher :
- Added a new dockable LocalJobs editor, to replace the floating window previously accessible via the “Execute/Local Jobs” menu item.
- Task output is now shown in the UI.
- Jobs are no longer removed from the UI as soon as they complete.
- Incomplete jobs are now killed automatically when the application is closed, after prompting to confirm that shutdown should go ahead.
 
- NodeEditor :
- Improved image channel selectors :
- Added “Custom” option, to allow strings to be entered manually.
- Added right-click context menu.
 
- Improved performance when showing a node with many colour plugs. Showing the Arnold standard_surfaceshader is now almost 2x faster.
 
- Improved image channel selectors :
- NodeEditor, NameWidget : Invalid characters are automatically converted to _when renaming a node or plug, and:is no longer treated as invalid.
- NodeEditor, UIEditor, PythonEditor : Added popup hint for the Ctrl+Return shortcut.
- NumericWidget : Added the ability to use Ctrl + scroll wheel to adjust values in the same manner as Up and Down (#6009).
- OpenColorIO : When a script-level OpenColorIO variable contains a Gaffer ${contextVariable}reference, its evaluation is now deferred to the point of use. This allows it to pick up overrides introduced by nodes such as ContextVariables and Wedge.
- OptionTweaks : Tweak valueplugs can now access metadata registered globally tooption:{tweakName}, where{tweakName}is the value of the tweak’snameplug.
- ParameterInspector : Added the ability to inspect parameters on any shader in a light or shader’s shader network.
- PathFilterUI : Added the ability to drag and drop scene paths onto Box and Reference nodes. Doing so will create a new PathFilter with the selected paths if none is connected, or update an existing connected PathFilter.
- Premultiply : Added useDeepVisibilityplug, which weights samples according to their visibility based on the opacity of samples in front.
- PythonCommand : Added standard popup menu to commandwidget in NodeEditor.
- RenderPassEditor :
- Added preset menu for choosing a render pass type from the list of available registered types. An “auto” type is included in the list when an auto type function has been registered.
- Added “Camera Inclusions” and “Camera Exclusions” columns, providing control over the camera visibility of scene locations in each render pass.
- Added “Matte Inclusions” and “Matte Exclusions” columns, providing control over the scene locations used as holdout mattes in each render pass.
- The currently active render pass can now be unset by double clicking on its green dot in the “Active” column.
- Added “Select Affected Objects” popup menu item.
 
- RenderPassEditor, LightEditor : Improved update performance for certain graph configurations, by optimising SceneAlgo::history()(#5199).
- Resize :
- Added support for deep images.
- Added “Nearest” filter.
 
- SceneInspector :
- Added support for dragging inspector labels, such as those containing the names of attributes, options, output parameters, parameters, primitive variables, and sets.
- Set names beginning with “__” such as “__lights” or “__cameras” are now displayed as-is, rather than being transformed to “Lights” or “Cameras”.
 
- SceneReader : ModelAPI extentsHintsare now considered when loading the bounding box for a location in Gaffer. This can significantly reduce the time taken to load bounds for large USD assemblies. If necessary, this behaviour can be disabled by setting theIECOREUSD_USE_MODELAPI_BOUNDSenvironment variable with a value of0.
- ScenePlug, ImagePlug : Child plugs are now serialisable. Among other things, this enables them to be driven by expressions (#3986).
- ScriptWindow : Added “Save” option to dialogue shown when closing a window containing unsaved changes.
- SetEditor : Added support for dragging a set name onto a node in the Graph Editor to create or modify a connected SetFilternode. Holding Shift while dragging will add to the set expression. Holding Control will remove from the set expression. Only set expressions with a simple list of sets are supported. Expressions with boolean or hierarchy operators are not supported.
- SetExpressions : Set Expressions containing only whitespace characters are now treated as empty rather than producing an error.
- SetFilter, StandardAttributes, StandardOptions : Added syntax highlighting and auto-complete for set expressions.
- ShaderTweaks : Added support for wildcards in the shader name, in order to tweak multiple shaders at once.
- ShaderTweaks, ShaderQuery : Improved performance of parameter selection dialogue. For some particularly large shader networks, speedups are greater than 100x.
- Shuffle :
- Reimplemented to match ShuffleAttributes and ShufflePrimitiveVariables.
- Any number of shuffles can be added using the UI.
- Wildcards can be used to match multiple source channels, and expressions can be used to map them to destination channels.
- Source channels can optionally be deleted after shuffling.
- Overwriting of destination channels can optionally be avoided.
 
- Added missingSourceModeplug to determine behaviour when a source channel doesn’t exist.
 
- Reimplemented to match ShuffleAttributes and ShufflePrimitiveVariables.
- Spreadsheet : Added support for metadata to be automatically forwarded from plugs downstream of a column’s outplug to the column’s default row.
- Switch :
- Added deleteContextVariablesplug.
- Added connectedInputsoutput plug.
 
- Added 
- TaskList, FrameMask : Reimplemented in C++ for improved performance.
- Toolbars : Changed hotkey behavior to toggle any tool on and off. Exclusive tools such as the Translate and Crop Window tools activate the first tool (currently Selection Tool) when they are toggled off.
- TweakPlug : ListAppend,ListPrependandListRemovemodes are now supported for string values. In this case, the string is treated as a space-separated list.
- UI Editor :
- Added the ability to edit the scale of node icons.
- Improved layout of Box node plug creator visibility toggles.
- Added code examples to button code placeholder text.
 
- USD :
- Added automatic render-time translation of UsdPreviewSurface shaders to Cycles.
- Added automatic render-time translation of UsdPreviewSurface shaders to 3Delight.
 
- USDLight :
- Added Arnold-specific extension parameters.
- Added parameter tooltips.
 
- Viewer : Added diagnostic shading mode for visualising the values of the usd:purposeattribute as colours :- White : Default
- Green : Render
- Blue : Proxy
- Red : Guide
 
- Wireframe :
- Improved performance ~3x.
- Improved cancellation responsiveness.
 
Fixes
- AnnotationsGadget : Fixed potential hang in annotationText()Python binding.
- Arnold :
- Fixed rendering of shaders imported from HtoA via USD.
- Fixed USD export of shaders to use outputs:outinstead ofoutputs:DEFAULT_OUTPUT.
- Fixed rendering of oslshaders using thecodeparameter.
- Fixed bug preventing UI metadata for Imagers from being loaded for Arnold 7.3.
- Fixed rendering of ai:volumeshaders loaded from USD (#5830).
- Renamed Arnold/Globals/Imager menu option to Arnold/Globals/Imagers so that the actual ArnoldImager node menu option wasn’t overwritten.
- Fixed rendering of VDB volumes without file_mem_bytesmetadata.
 
- ArrayPlug :
- Fixed error when resize()removed plugs with input connections.
- Fixed error when resize()was used on an output plug.
 
- Fixed error when 
- BackgroundTask : Fixed potential deadlock caused by destroying a BackgroundTask from Python while it was still running.
- Catalogue :
- Fixed undo for image reordering via drag & drop.
- Fixed bugs caused by reordering images using GraphComponent::reorderChildren().
- Fixed bug which allowed locked Catalogues to be edited.
- Fixed NodeEditor update when the first image is added or the last image is removed.
 
- CodeWidget :
- Fixed bug that could prevent changes from being committed while the completion menu was visible.
- Fixed errors handling highlights which spanned more than one line, such as triple-quoted strings in the PythonEditor.
- Removed unwanted \nprefix in lines passed toCompleters.
- Prevented spurious emission of editingFinishedSignal()when showing the completions menu.
- Prevented the completion menu from popping up inappropriately when the highlighter was changed.
 
- Collect : Fixed display of results collected from TypedObjectPlug inputs.
- ColorChooser : Fixed emission of colorChangedSignal()while the widget was in an inconsistent internal state.
- ColorChooserPlugValueWidget : Fixed bug that allowed the editing of locked plugs and nodes.
- ColorToVector : Fixed parameter types.
- Constraint : The targetbrowser now shows locations from thetargetSceneif it has an input connection. Before it always showed locations from the main input.
- CreateViews : Fixed loading of files saved from Gaffer 1.5+.
- Cryptomatte :
- Fixed errors when the input image didn’t contain the main RGBAchannels.
- Fixed inaccurate hash.
 
- Fixed errors when the input image didn’t contain the main 
- Cycles :
- Fixed hangs and crashes when using non-default session modes such as SVM shading.
- Fixed failure to render background light in batch renders (#5234).
- Fixed failure to update when reverting a background shader to previous values.
- Fixed bug preventing a background light from being added to a light group.
- Fixed rendering to the Catalogue using the batch Render node (#5905). Note that rendering a mixture of Catalogue and file outputs is still not supported, and in this case any file outputs will be ignored.
 
- DeepState : Fixed handling of NaNvalues and samples whereZBackis less thanZ.
- 3Delight :
- Fixed failure to change sampling pattern per frame.
- Fixed Resolution Multiplier support.
- Fixed UI visibility of angleparameter for distant lights, which was previously hidden.
- Fixed export of Varyingprimitive variables on meshes (#5781).
- Fixed loading of surface shaders such as dlStandardso that they can be connected to the inputs of shaders such asdlLayeredMaterial.
 
- Dispatcher : The job directory is no longer created when dispatch is cancelled by a slot connected to preDispatchSignal().
- Expression : setExpression()now respects configs that provide backwards compatibility for old plug names.
- FlatImageProcessor : Fixed bug that could cause an input to be evaluated with an invalid image:viewName.
- File Browser : Windows only : Fixed bug in HiddenFilePathFilterthat caused sequences to be treated as though they are hidden files (#5810).
- FormatPlug : Fixed potential hang in acquireDefaultFormatPlug()Python binding.
- FramingConstraint : Fixed crash caused by attempts to constrain objects that were not cameras.
- Gadget : Fixed access to DragDropEvent.sourceWidgetandDragDropEvent.destinationWidgetfrom Python slots connected to a Gadget’s DragDropSignals.
- GraphGadget : Fixed unwanted highlighting of nodes when custom drag & drop handlers were active.
- GafferTest, GafferImageTest : Fixed import of these modules if the Gaffermodule had not been imported previously.
- HierarchyView, LightEditor, PrimitiveInspector, SceneInspector : Fixed bug which allowed scenes from private plugs to be displayed.
- ImageGadget : Fixed loading of non-8-bit images. Among other things, this fixes the display of 16 bit node icons in the GraphEditor.
- ImageInspector : Fixed broken UI caused by double-clicking in the Image tab.
- ImageReader :
- Fixed crash caused by invalid OpenEXR multiViewattributes.
- Fixed array metadata loading bugs, including the loading of ICCProfilemetadata.
 
- Fixed crash caused by invalid OpenEXR 
- ImageStats :
- Fixed output of infinite values, which were previously being clamped.
- Results for min/max now correctly reflect zero values outside the data window.
 
- InteractiveRender :
- Fixed crash triggered by a render adaptor depending on its rendererinput to adapt the scene globals.
- Removed unintentional ability for render adaptors to change the renderer being used.
 
- Fixed crash triggered by a render adaptor depending on its 
- LazyMethod : Fixed errors caused by running idle callbacks without a valid Qt Widget.
- LightEditor : Fixed regression (introduced in 1.4.8.0) causing the mute and solo icons to not show up for groups.
- LightEditor, RenderPassEditor : Added missing icon representing use of the CreateIfMissingtweak mode in the history window.
- LightPositionTool :
- Fixed bug that caused the target/pivot positions to be lost when placing a light with Z scale not equal to 1.0.
- Fixed bug that allowed a non-light object to be moved by clicking or dragging the target or pivot.
 
- Linux : Fixed crashes at startup on platforms - including RHEL 9.4 - with a more recent glibc(#5856).
- LocalDispatcher :
- Fixed delays and zombie processes caused by shutting down Gaffer while background jobs were running. Background jobs are now killed before Gaffer exits instead.
- Stopped failed jobs jumping to the end of the Local Jobs UI.
- Fixed message log update.
- Fixed Job.statistics()errors on Windows, ensuring that apidis always returned when available.
 
- Loop : Fixed handling of empty indexVariable. This now disables the Loop instead of creating an unnamed context variable.
- MultiLineTextWidget :
- Fixed rendering of disabled widgets, which now show faded text.
- Fixed behaviour of editingFinishedSignal()to match TextWidget : it is now also emitted when the text is activated (seeactivatedSignal()).
 
- MultiLineStringMetadataWidget : The Ctrl+Return shortcut now updates the metadata value immediately.
- NameSwitch : Fixed NodeEditor tab order, so that the Settings tab precedes the Advanced tab.
- NameWidget : Fixed bug which allowed plugs on locked nodes to be renamed.
- NodeAlgo : Fixed presets inheritance for promoted plugs with multiple outputs.
- NodeEditor : Fixed broken layouts caused by computation errors in plugs used by section summaries.
- NodeMenu, NodeEditor : userDefaultmetadata is now evaluated in the script context, so it can depend on script variables.
- OpenColorIO : Fixed the display transform used to show colours in popups.
- OptionQuery : Fixed bug which allowed the scene:pathcontext variable to leak into the context used to evaluate the globals.
- PathFilter : Fixed bug allowing dropping paths onto read-only PathFilternodes in the graph.
- PlugAlgo :
- Updated canSetValueFromData(),setValueFromData()andgetValueAsData()with support for missing types.
- Fixed promotion of CompoundDataPlugs with non-dynamic children, such as the Camera.renderSettingOverridesplug.
 
- Updated 
- PlugPopup : Fixed error when displaying a popup with no PlugValueWidget.
- Premultiply : Fixed handling of non-existent alpha channel.
- PrimitiveInspector : Fixed bug which claimed “Location does not exist” for objects without any primitive variables.
- PythonCommand : Fixed loading of files saved from Gaffer 1.5+.
- ResamplePrimitiveVariables : Fixed handling of periodic curves.
- SceneReader :
- Fixed crash reading facevarying normals skinned with UsdSkel.
- Fixed loading of facevarying normals skinned with UsdSkel.
- Stopped loading USD lightLinksandshadowLinkscollections as sets.
- USD asset paths on Windows now use /as the path separator, instead of\. SetIECOREUSD_FORCE_ASSET_PATH_FORWARD_SLASH=0to keep the previous behaviour.
- Fixed loading of animated ModelAPI extents from USD.
 
- SceneAlgo : Fixed exception handling for Python render adaptors. Previously an exception during adaptor construction caused a SystemError.
- SceneWriter :
- Fixed crash when writing to a USD file that is already open elsewhere.
- Fixed handling of ‘:’ characters in set names when writing to USD. These were previously converted to ’_’ but are now preserved.
- Fixed writing of locations with names that are not valid USD identifiers.
- Fixed handling of shader parameters not supported in USD, such as texture inputs to OpenGLShader.
- Fixed import of treatAsPointandtreatAsLineparameters on UsdLux lights.
 
- SceneInspector : Fixed “Show History” menu items.
- SceneReader :
- Fixed duplicate loading of arnold:*attributes on lights. These are now omitted, since they are converted to parameters on the light shader itself.
- Fixed error loading USD Volumes with empty fields. These will now issue a warning and load as empty locations.
 
- Fixed duplicate loading of 
- SceneReader, SceneWriter : Fixed handling of Arnold-specific parameters on UsdLux lights.
- Shader : Fixed “Revert to Defaults” menu item in NodeEditor (#1862).
- ShaderTweaks : Fixed potential crash if a ShaderTweakProxy was used to accidentally create a cyclic connection.
- ShaderView : Fixed crash caused by a SceneCreator returning None.
- ShowURL : Fixed opening of “file://” URLs on Windows (#5861).
- Slider : Fixed bug where two undo steps were needed to get back to the original value when dragging.
- Spreadsheet : Fixed “Sets”, “Operators” and “Select Affected Objects” popup menu items, which were broken in 1.4.5.0.
- TaskNode / GafferCortex : Fixed missing GIL releases that caused hang at ImageEngine.
- TransformTool : Fixed alignment of green “value changed” icon for orientationplugs.
- TweakPlug : Fixed incorrect results and potential crashes in list modes.
- UI : Fixed hangs caused by garbage collection of removed Editors. One common example involved viewing a Catalogue in the NodeEditor after removing the ImageInspector (#5877).
- UIEditor : The Ctrl+Return shortcut now updates the button code immediately.
- USD : Fixed Unsupported value type "StringData" for parameter "input"warning when convertingUsdTransform2dshaders with noinconnections to Arnold.
- ValuePlug : Fixed the plug passed to Monitor::forceMonitoring(). PreviouslyProcess::destinationPlug()was being passed instead ofProcess::plug().
- VectorDataWidget :
- Fixed bug allowing dropping paths onto read-only widgets.
- Fixed bug causing paths to display as “…” after the last visible “/” when the widget wasn’t wide enough to show the entire path.
 
- Viewer :
- Fixed handling of Gaffer ${contextVariable}references in OpenColorIO variable values. The Viewer now updates the Display Transform appropriately when the value of the context variable changes.
- Fixed Cycles shader balls.
- Fixed selection overlay glitches with an Arnold skydome_lightand an empty selection.
- Fixed drawing of custom mesh light texture visualisers (#6002).
 
- Fixed handling of Gaffer 
- Viewer, ImageGadget :
- Fixed partial image updates when an unrelated InteractiveRender was running (#6043).
- Fixed “colour tearing”, where updates to some image channels became visible before updates to others.
- Fixed unnecessary texture updates when specific image tiles don’t change.
 
- ViewportGadget : Fixed selection issues with Intel GPUs (#901, #2788).
- Widget :
- Fixed bug that prevented Gadgets from receiving drops from another application.
- Fixed errors when dragging from another application onto widgets that didn’t expect it.
 
- WidgetAlgo : Fixed issue preventing grab()from capturing popup menus on Windows.
- Windows :
- Removed “Error(s) running Gaffer” shutdown message. It was misleading when errors originated in the renderer rather than Gaffer itself.
- Fixed conflicts with other software installations on PATH. ThePXR_USD_WINDOWS_DLL_PATHenvironment variable is now set to an empty string if it is not already set, preventing USD from adding all entries fromPATHto Python’s DLL search paths.
 
API
- ArnoldShaderUI : Added support for gaffer.nodeGadget.colorRGB metadata in.mtdfiles, to specify per-shader colouring of nodes in the GraphEditor.
- AnnotationsGadget : Added annotationText()method.
- Box2fVectorDataPlug : Added new plug type for storing arrays of Box2f.
- BoxPlug : Added Python bindings for ValueType,PointTypeandChildTypetype aliases.
- Catalogue : Deprecated image:indexmetadata.
- Color3fPlug : Added setValue( V3f() )overload.
- ContactSheetCore : Added a new node to do provide the basis for networks that create contact sheets from multiple input images.
- ContextAlgo : Deprecated. Use ScriptNodeAlgo instead.
- ContextTracker : Added a new class that determines what contexts nodes are evaluated in relative to the focus node. This allows UI components to provide improved context-sensitive feedback to the user.
- DeepPixelAccessor : Added utility class for accessing deep samples while abstracting away the underlying tile storage.
- DocumentationAlgo : Added table and strikethrough support to markdownToHTML().
- Editor : Added Settingsclass, which should be used to store settings for subclasses. See LightEditor and ImageInspector for examples.
- EditScopeUI : Added an API for customising the EditScope’s NodeEditor with summaries for each processor :
- ProcessorWidget provides a base class for custom widgets, and a factory mechanism for registering them against processors.
- SimpleProcessorWidget provides a base class for widgets with a simple summary label and optional action links.
 
- ExtensionAlgo : Added exportNode()andexportNodeUI()functions.
- GafferTractor : Added tractorAPI()method used for accessing thetractor.api.authormodule.
- GafferTractorTest : Added tractorAPI()method which returns a mock API if Tractor is not available. This allows the GafferTractor module to be tested without Tractor being installed.
- HierarchyView : Added sceneListing()method, to allow the context menu to be customised.
- IconPathColumn :
- Added constructor which allows the full header CellData to be specified.
- Added prefix()andproperty()accessors.
 
- Image : Added createSwatch()static method.
- ImageGadget : Removed textureLoader()method.
- ImageTestCase : in assertImageEqualfunction, maxDifference may now be a tuple, to specify an asymmetric range.
- Label : Added textSelectableconstructor argument.
- LabelPlugValueWidget : Added optional labelPlugValueWidget:showValueChangedIndicatormetadata entry. If a plug has this entry set toFalse, the icon next to the label that indicates the value has changed will not be shown. Defaults toTrueif the value is not set.
- LightEditor :
- Added deregisterColumn()method for removing columns.
- Added registerShaderParameter()method for registering parameters for shader attributes that are not the same as therendererKey.
- Added columnNameparameter toregisterParameter()method, matching the behaviour ofRenderPassEditor.registerOption().
 
- Added 
- LocalDispatcher :
- Added Job.status()andJob.statusChangedSignal()methods.
- Added Job.messages()andJob.messagesChangedSignal()methods.
- Added Job.frameRange(),Job.environmentCommand()andJob.startTime()methods.
- Added Job.cpuUsage()andJob.memoryUsage()methods.
- Added JobPool.addJob()andJobPool.removeJob()methods.
 
- Added 
- Loop :
- Added previousIteration()method.
- Added nextIterationContext()method.
 
- Added 
- Menu : Menu items with “checkBox” enabled now draw their checked indicator in place of their “icon” when both are defined.
- MetadataWidget : Added NumericMetadataWidgetclass.
- MultiLineTextWidget : Added setSelection()andgetSelection()methods.
- ParallelAlgo : Added canCallOnUIThread()function.
- Pointer : Added fileName()method.
- PathColumn :
- Added CellData::sortValuemember, to provide additional control over sorting in the PathListingWidget.
- Added missing Python binding for headerData()method.
 
- Added 
- PathListingWidget : Added columnContextMenuSignal(), allowing multiple clients to collaborate on the creation of a column-specific context menu.
- ParallelAlgoTest : Added UIThreadCallHandler.receive()method.
- PlugAlgo : setValueFromData()andcanSetValueFromData()now support conversion of arrays of length 1 to their equivalent scalar types.
- PlugLayout : Added support for activators in Boxes and extension nodes by allowing layout:activator:activatorNamemetadata to contain a Python string to be executed. Execution is performed in an environment where aparentvariable refers to node or plug represented by the layout, and from which plug values can be obtained.
- PopupWindow : Added parentargument topopup()method. This allows popup windows to inherit the display transform from the main UI.
- RenderPassEditor : Added deregisterColumn()method.
- RenderPassWedge : Render adaptors may now be used to delete and/or disable render passes, by passing client = "RenderPassWedge"toSceneAlgo.registerRenderAdaptor().
- RenderPassTypeAdaptor :
- Added registration methods for defining render pass types and processors.
- Added registerAutoTypeFunction()method to define a function used to automatically derive the render pass type from the render pass name when therenderPass:typeoption value is “auto”.
- Added autoTypeFunction()method.
 
- SceneAlgo : Added mechanism for scoping render adaptors to specific clients and/or renderers.
- ScenePathPlugValueWidget : The scenePathPlugValueWidget:scenemetadata now accepts a space-separated list of plugs, taking the first plug which has an input connection.
- ScriptNodeAlgo : Added new namespace with functions for managing shared UI state for GafferSceneUI.
- SelectionTool : Added static registerSelectMode()method for registering a Python or C++ function that will modify a selected scene path location. Users can choose which mode is active when selecting.
- SetExpressionPlugValueWidget : Added new editor for set expressions, with syntax highlighting and auto-complete.
- ShaderPlug : Added parameterSource()method returning theValuePlugresponsible for generating a parameter in a shader network.
- ShaderUI : Added support for nodeGadget:colormetadata registered against{shaderType}:{shaderName}, to specify per-shader colouring of nodes in the GraphEditor.
- ShufflesPlug :
- Added ignoreMissingSourceargument toshuffle().
- Added shuffleWithExtraSources()method.
 
- Added 
- ShufflePlugValueWidget : Widgets for the sourceanddestinationplugs can now be customised using standardplugValueWidget:typemetadata.
- StandardPathColumn :
- Added constructor which allows the full header CellData to be specified.
- Added missing Python binding for property()method.
 
- TextWidget : Added selectedText()convenience method.
- TextWidget, MultilineTextWidget :
- Added setPlaceholderText()andgetPlaceholderText()methods.
- Added placeholderTextconstructor argument.
 
- Added 
- TractorDispatcher : The preSpoolSignal()now provides an additionaltaskDataargument to slots, which maps from Tractor tasks to information about the Gaffer tasks they will execute.
- TypedObjectPlug : Added Python bindings for the default values of the defaultValueconstructor argument.
- USDShader : Added support for loading from the UsdSchemaRegistry as well as from the SdrRegistry. This is now used when loading UsdLuxLights.
- VisibleSet : Added Python constructor with keyword arguments for expansions,inclusionsandexclusions.
- Widget : Added a 0.5 pixel offset to ButtonEvent.lineobjects passed to mouse event signals such asbuttonPressSignal()anddragMoveSignal()
- Window : Added preCloseSignal(), which allows connected slots to prevent a window from being closed.
Documentation
- Windows : Documentation is now included in Windows release packages.
- Updated with generic Render and InteractiveRender nodes in place of deprecated renderer-specific nodes.
Breaking Changes
- Arnold : Removed support for Arnold 7.1.
- Backdrop : Changed default drawing order. Use the new depthplug to override the order if necessary.
- Cycles : Updated to version 4.0.2.
- CyclesAttributes : Removed the cycles:dupliGeneratedandcycles:dupliUVattributes.
- CyclesOptions :
- Changed hairShapedefault value to “ribbon”, to match Cycles’ and Blender’s own defaults.
- Removed useFrameAsSeedplug. The frame is now automatically used as the seed ifseedis not set.
- Removed all texture cache options. These had never been exposed in the UI because this never became an official Cycles feature.
- Removed cryptomatteAccurate. This feature is no longer present in Cycles.
- Removed cycles:integrator:sampling_patternoption. This is intended only for debugging, but is still available via a CustomOptions node.
 
- Changed 
- 3Delight :
- Changed default layer names for outputs.
- Changed NSI scene description export with .nsifile extension from ASCII to binary (.nsiais used for ASCII now).
 
- DelightOptions : Changed default values for oversamplingandshadingSamplesplugs.
- Dispatcher :
- Removed createMatching()method.
- Removed non-const TaskBatch accessors frames()andpreTasks().
- Made TaskBatchconstructors private.
- The job directory is no longer available in slots connected to preDispatchSignal().
- Removed nodesarguments from dispatch signals. Use thedispatcher["tasks"]plug instead.
- Removed scriptandcontextarguments fromframeRange()method. The current frame and full frame range are now queried from the current context.
 
- Removed 
- DispatcherUI :
- Removed appendMenuDefinitions(),appendNodeContextMenuDefinitions(),executeSelected()andrepeatPrevious()functions.
- Removed DispatcherWindowclass.
 
- Removed 
- Enums : Replaced IECore.Enumtypes with standard Python types from theenummodule.
- ImageProcessor : Internal connections to the outplug are no longer serialised.
- ImageStatsUI : Removed postCreate().
- InteractiveRenderTest : Subclasses must now return the shader output plug from creation methods such as _createConstantShader().
- LocalDispatcher :
- Removed JobPool.jobFailedSignal().
- Removed JobPool.failedJobs()method. Failed jobs now remain in place in the mainjobs()container.
- Removed Job.failed()andJob.killed()methods. UseJob.status()instead.
- Removed Job.execute()method. This should not have been public.
- Removed Job.messageHandler()method. UseJob.messages()instead.
- Removed Job.description()method.
- Removed Job.statistics()method. UseJob.memoryUsage()andJob.cpuUsage()instead.
- JobPool no longer derives from RunTimeTyped.
 
- Removed 
- LocalDispatcherUI : Removed appendMenuDefinitions()function.
- OpenColorIOContext : Removed configEnabledPlug(),configValuePlug(),workingSpaceEnabledPlug()andworkingSpaceValuePlug()methods. Use the OptionalValuePlug child accessors instead.
- OSLShader : Output parameters are now loaded onto the outplug for all types (surface,displacementetc), not justshader.
- Pointer :
- Removed Pointer( const ImagePrimitive * )constructor.
- Removed image()method.
 
- Removed 
- Preferences : Removed cacheplug.
- Process : Removed non-const variant of the handleException()method.
- Render : Changed render:includedPurposesdefault to"default", "render".
- SceneProcessor : Subclasses no longer serialise internal connections to the outplug.
- Shuffle :
- Removed ChannelPlug type. Use Gaffer.ShufflePluginstead.
- Renamed channelsplug toshufflesplug, matching nodes such as ShuffleAttributes and ShufflePrimitiveVariables.
 
- Removed ChannelPlug type. Use 
- ShuffleUI : Removed nodeMenuCreateCommand().
- StandardLightVisualiser : Added attributeNameargument tosurfaceTexture()virtual method.
- StringPlug : Removed deprecated precomputedHashargument fromgetValue()method.
- TaskNode :
- The Taskconstructor no longer takes a copy of the context, so the context must not be modified after being passed.
- Removed Task( taskNode, context )constructor. UseTask( taskNode["task"], context )instead.
 
- The 
- USD : Removed Embree Hydra delegate.
- ValuePlug : Removed deprecated getObjectValue()overload.
- Windows launch script : Removed the hardcoded /debugexeswitch used whenGAFFER_DEBUGis enabled, making it possible to use debuggers other than Visual Studio. Debug switches can be added to theGAFFER_DEBUGGERenvironment variable instead.
Build
- Cortex : Updated to version 10.5.9.5.
- Cycles : Updated to version 4.0.2.
- Embree : Updated to version 4.3.0.
- Imath : Updated to version 3.1.9.
- MaterialX : Updated to version 1.38.8.
- LibWebP : Added version 1.3.2.
- OpenEXR : Updated to version 3.1.13.
- OpenImageIO : Updated to version 2.5.8.0.
- OpenPGL : Updated to version 0.5.0.
- OpenShadingLanguage : Updated to version 1.12.14.0.
- OpenSubdiv : Updated to version 3.5.1.
- OpenSSL : Removed.
- OpenVDB : Updated to version 10.1.0.
- PsUtil : Added version 5.9.6.
- PySide : Updated to version 5.15.12.
- Python : Updated to version 3.10.13.
- Qt :
- Updated to version 5.15.12.
- Removed QtPurchasing library.
- Removed QtNetworkAuth library.
 
- USD :
- Updated to version 23.11.
- Added sdrOsl, for inclusion of OSL shaders in the Sdr Registry.
- Fixed issue where gafferwrapper may not exist when callingusdGenSchemafrom a clean build.
 
- MacOS : Fixed issue where Python.frameworkmay not be found when building with a prebuilt dependencies package.