bridge reconnect nodegroup on clean

0.5.1

- feat: reconnect existing sockets inside nodegroups with clean nodes > re-order
main
Pullusb 2021-10-01 12:42:21 +02:00
parent 2aa4ecc00e
commit 65c7142786
4 changed files with 32 additions and 2 deletions

View File

@ -14,6 +14,10 @@ Activate / deactivate layer opaticty according to prefix
Activate / deactivate all masks using MA layers Activate / deactivate all masks using MA layers
--> -->
0.5.1
- feat: reconnect existing sockets inside nodegroups with clean nodes > re-order
0.5.0 0.5.0
- feat: add a render operator that render all scene - feat: add a render operator that render all scene

View File

@ -137,6 +137,8 @@ class GPEXP_OT_clean_compo_tree(bpy.types.Operator):
# Clear input that do not exists # Clear input that do not exists
fn.clean_nodegroup_inputs(n, skip_existing_pass=True) fn.clean_nodegroup_inputs(n, skip_existing_pass=True)
fn.bridge_reconnect_nodegroup(n)
if self.fo_clear_disconnected: if self.fo_clear_disconnected:
for fo in nodes: for fo in nodes:
if fo.type != 'OUTPUT_FILE': if fo.type != 'OUTPUT_FILE':
@ -144,7 +146,6 @@ class GPEXP_OT_clean_compo_tree(bpy.types.Operator):
fn.clear_disconnected(fo) fn.clear_disconnected(fo)
return {"FINISHED"} return {"FINISHED"}

View File

@ -2,7 +2,7 @@ bl_info = {
"name": "GP Render", "name": "GP Render",
"description": "Organise export of gp layers through compositor output", "description": "Organise export of gp layers through compositor output",
"author": "Samuel Bernou", "author": "Samuel Bernou",
"version": (0, 5, 0), "version": (0, 5, 1),
"blender": (2, 93, 0), "blender": (2, 93, 0),
"location": "View3D", "location": "View3D",
"warning": "", "warning": "",

25
fn.py
View File

@ -447,6 +447,31 @@ def clean_nodegroup_inputs(ng, skip_existing_pass=True):
# clear_nodegroup_content_if_disconnected(ngroup) # clear_nodegroup_content_if_disconnected(ngroup)
def bridge_reconnect_nodegroup(ng, socket_name=None):
'''
Reconnect group_in and group out that have been disconnected
:socket: only use this specific socket type
'''
ngroup = ng.node_tree
ng_in = ngroup.nodes.get('Group Input')
ng_out = ngroup.nodes.get('Group Output')
for sockin in ng_in.outputs:
if socket_name and sockin.name != socket_name:
continue
if not sockin.name: # last empty output is listed
continue
sockout = ng_out.inputs.get(sockin.name)
if not sockout:
continue
if len(sockin.links) and connect_to_group_output(sockin.links[0].to_node):
continue
## need reconnect
aa = create_aa_nodegroup(ngroup)
ngroup.links.new(sockin, aa.inputs[0])
ngroup.links.new(aa.outputs[0], sockout)
print(f'{ng.name}: Bridged {sockin.name}')
def random_color(alpha=False): def random_color(alpha=False):
import random import random
if alpha: if alpha: