|
"""The Context Switch (Big)."""
|
|
from .constants import get_category, get_name
|
|
from .context_utils import (ORIG_CTX_RETURN_TYPES, ORIG_CTX_RETURN_NAMES, merge_new_context,
|
|
get_orig_context_return_tuple, is_context_empty)
|
|
from .utils import FlexibleOptionalInputType
|
|
|
|
|
|
class RgthreeContextMerge:
|
|
"""The Context Merge node."""
|
|
|
|
NAME = get_name("Context Merge")
|
|
CATEGORY = get_category()
|
|
|
|
@classmethod
|
|
def INPUT_TYPES(cls):
|
|
return {
|
|
"required": {},
|
|
"optional": FlexibleOptionalInputType("RGTHREE_CONTEXT"),
|
|
}
|
|
|
|
RETURN_TYPES = ORIG_CTX_RETURN_TYPES
|
|
RETURN_NAMES = ORIG_CTX_RETURN_NAMES
|
|
FUNCTION = "merge"
|
|
|
|
def get_return_tuple(self, ctx):
|
|
"""Returns the context data. Separated so it can be overridden."""
|
|
return get_orig_context_return_tuple(ctx)
|
|
|
|
def merge(self, **kwargs):
|
|
"""Merges any non-null passed contexts; later ones overriding earlier."""
|
|
ctxs = [
|
|
value for key, value in kwargs.items()
|
|
if key.startswith('ctx_') and not is_context_empty(value)
|
|
]
|
|
ctx = merge_new_context(*ctxs)
|
|
|
|
return self.get_return_tuple(ctx)
|
|
|