Merge branch 'blender2.7'
This commit is contained in:
commit
c5f13ecbc0
|
@ -9,7 +9,7 @@ if "%BUILD_ARCH%"=="x64" (
|
|||
)
|
||||
|
||||
if "%WITH_CLANG%"=="1" (
|
||||
set CLANG_CMAKE_ARGS=-T"LLVM-vs2017"
|
||||
set CLANG_CMAKE_ARGS=-T"llvm"
|
||||
if "%WITH_ASAN%"=="1" (
|
||||
set ASAN_CMAKE_ARGS=-DWITH_COMPILER_ASAN=On
|
||||
)
|
||||
|
|
|
@ -22,50 +22,39 @@ import math
|
|||
from bpy.app.handlers import persistent
|
||||
|
||||
|
||||
def foreach_notree_node(nodetree, callback, traversed):
|
||||
if nodetree in traversed:
|
||||
return
|
||||
traversed.add(nodetree)
|
||||
def foreach_cycles_nodetree_group(nodetree, traversed):
|
||||
for node in nodetree.nodes:
|
||||
callback(node)
|
||||
if node.bl_idname == 'ShaderNodeGroup':
|
||||
foreach_notree_node(node.node_tree, callback, traversed)
|
||||
group = node.node_tree
|
||||
if group and group not in traversed:
|
||||
traversed.add(group)
|
||||
yield group, group.library
|
||||
yield from foreach_cycles_nodetree_group(group, traversed)
|
||||
|
||||
|
||||
def foreach_cycles_node(callback):
|
||||
def foreach_cycles_nodetree():
|
||||
traversed = set()
|
||||
|
||||
for material in bpy.data.materials:
|
||||
if material.node_tree:
|
||||
foreach_notree_node(
|
||||
material.node_tree,
|
||||
callback,
|
||||
traversed,
|
||||
)
|
||||
nodetree = material.node_tree
|
||||
if nodetree:
|
||||
yield nodetree, material.library
|
||||
yield from foreach_cycles_nodetree_group(nodetree, traversed)
|
||||
|
||||
for world in bpy.data.worlds:
|
||||
if world.node_tree:
|
||||
foreach_notree_node(
|
||||
world.node_tree,
|
||||
callback,
|
||||
traversed,
|
||||
)
|
||||
nodetree = world.node_tree
|
||||
if nodetree:
|
||||
yield nodetree, world.library
|
||||
foreach_cycles_nodetree_group(nodetree, traversed)
|
||||
|
||||
for light in bpy.data.lights:
|
||||
if light.node_tree:
|
||||
foreach_notree_node(
|
||||
light.node_tree,
|
||||
callback,
|
||||
traversed,
|
||||
)
|
||||
nodetree = light.node_tree
|
||||
if nodetree:
|
||||
yield nodetree, light.library
|
||||
foreach_cycles_nodetree_group(nodetree, traversed)
|
||||
|
||||
|
||||
def displacement_node_insert(material, nodetree, traversed):
|
||||
if nodetree in traversed:
|
||||
return
|
||||
traversed.add(nodetree)
|
||||
|
||||
for node in nodetree.nodes:
|
||||
if node.bl_idname == 'ShaderNodeGroup':
|
||||
displacement_node_insert(material, node.node_tree, traversed)
|
||||
|
||||
def displacement_node_insert(nodetree):
|
||||
# Gather links to replace
|
||||
displacement_links = []
|
||||
for link in nodetree.links:
|
||||
|
@ -95,13 +84,6 @@ def displacement_node_insert(material, nodetree, traversed):
|
|||
nodetree.links.new(node.outputs['Displacement'], to_socket)
|
||||
|
||||
|
||||
def displacement_nodes_insert():
|
||||
traversed = set()
|
||||
for material in bpy.data.materials:
|
||||
if material.node_tree:
|
||||
displacement_node_insert(material, material.node_tree, traversed)
|
||||
|
||||
|
||||
def displacement_principled_nodes(node):
|
||||
if node.bl_idname == 'ShaderNodeDisplacement':
|
||||
if node.space != 'WORLD':
|
||||
|
@ -111,11 +93,7 @@ def displacement_principled_nodes(node):
|
|||
node.subsurface_method = 'BURLEY'
|
||||
|
||||
|
||||
def square_roughness_node_insert(material, nodetree, traversed):
|
||||
if nodetree in traversed:
|
||||
return
|
||||
traversed.add(nodetree)
|
||||
|
||||
def square_roughness_node_insert(nodetree):
|
||||
roughness_node_types = {
|
||||
'ShaderNodeBsdfAnisotropic',
|
||||
'ShaderNodeBsdfGlass',
|
||||
|
@ -124,9 +102,7 @@ def square_roughness_node_insert(material, nodetree, traversed):
|
|||
|
||||
# Update default values
|
||||
for node in nodetree.nodes:
|
||||
if node.bl_idname == 'ShaderNodeGroup':
|
||||
square_roughness_node_insert(material, node.node_tree, traversed)
|
||||
elif node.bl_idname in roughness_node_types:
|
||||
if node.bl_idname in roughness_node_types:
|
||||
roughness_input = node.inputs['Roughness']
|
||||
roughness_input.default_value = math.sqrt(max(roughness_input.default_value, 0.0))
|
||||
|
||||
|
@ -156,13 +132,6 @@ def square_roughness_node_insert(material, nodetree, traversed):
|
|||
nodetree.links.new(node.outputs['Value'], to_socket)
|
||||
|
||||
|
||||
def square_roughness_nodes_insert():
|
||||
traversed = set()
|
||||
for material in bpy.data.materials:
|
||||
if material.node_tree:
|
||||
square_roughness_node_insert(material, material.node_tree, traversed)
|
||||
|
||||
|
||||
def mapping_node_order_flip(node):
|
||||
"""
|
||||
Flip euler order of mapping shader node
|
||||
|
@ -244,18 +213,12 @@ def custom_bake_remap(scene):
|
|||
scene.render.bake.use_pass_indirect = False
|
||||
|
||||
|
||||
def ambient_occlusion_node_relink(material, nodetree, traversed):
|
||||
if nodetree in traversed:
|
||||
return
|
||||
traversed.add(nodetree)
|
||||
|
||||
def ambient_occlusion_node_relink(nodetree):
|
||||
for node in nodetree.nodes:
|
||||
if node.bl_idname == 'ShaderNodeAmbientOcclusion':
|
||||
node.samples = 1
|
||||
node.only_local = False
|
||||
node.inputs['Distance'].default_value = 0.0
|
||||
elif node.bl_idname == 'ShaderNodeGroup':
|
||||
ambient_occlusion_node_relink(material, node.node_tree, traversed)
|
||||
|
||||
# Gather links to replace
|
||||
ao_links = []
|
||||
|
@ -272,13 +235,6 @@ def ambient_occlusion_node_relink(material, nodetree, traversed):
|
|||
nodetree.links.new(from_node.outputs['Color'], to_socket)
|
||||
|
||||
|
||||
def ambient_occlusion_nodes_relink():
|
||||
traversed = set()
|
||||
for material in bpy.data.materials:
|
||||
if material.node_tree:
|
||||
ambient_occlusion_node_relink(material, material.node_tree, traversed)
|
||||
|
||||
|
||||
@persistent
|
||||
def do_versions(self):
|
||||
if bpy.context.preferences.version <= (2, 78, 1):
|
||||
|
@ -304,168 +260,199 @@ def do_versions(self):
|
|||
if not bpy.data.is_saved:
|
||||
return
|
||||
|
||||
# Clamp Direct/Indirect separation in 270
|
||||
if bpy.data.version <= (2, 70, 0):
|
||||
for scene in bpy.data.scenes:
|
||||
cscene = scene.cycles
|
||||
sample_clamp = cscene.get("sample_clamp", False)
|
||||
if (sample_clamp and
|
||||
not cscene.is_property_set("sample_clamp_direct") and
|
||||
not cscene.is_property_set("sample_clamp_indirect")):
|
||||
# Map of versions used by libraries.
|
||||
library_versions = {}
|
||||
library_versions[bpy.data.version] = [None]
|
||||
for library in bpy.data.libraries:
|
||||
library_versions.setdefault(library.version, []).append(library)
|
||||
|
||||
cscene.sample_clamp_direct = sample_clamp
|
||||
cscene.sample_clamp_indirect = sample_clamp
|
||||
# Do versioning per library, since they might have different versions.
|
||||
max_need_versioning = (2, 79, 6)
|
||||
for version, libraries in library_versions.items():
|
||||
if version > max_need_versioning:
|
||||
continue
|
||||
|
||||
# Change of Volume Bounces in 271
|
||||
if bpy.data.version <= (2, 71, 0):
|
||||
# Scenes
|
||||
for scene in bpy.data.scenes:
|
||||
cscene = scene.cycles
|
||||
if not cscene.is_property_set("volume_bounces"):
|
||||
cscene.volume_bounces = 1
|
||||
if scene.library not in libraries:
|
||||
continue
|
||||
|
||||
# Caustics Reflective/Refractive separation in 272
|
||||
if bpy.data.version <= (2, 72, 0):
|
||||
for scene in bpy.data.scenes:
|
||||
cscene = scene.cycles
|
||||
if (cscene.get("no_caustics", False) and
|
||||
not cscene.is_property_set("caustics_reflective") and
|
||||
# Clamp Direct/Indirect separation in 270
|
||||
if version <= (2, 70, 0):
|
||||
cscene = scene.cycles
|
||||
sample_clamp = cscene.get("sample_clamp", False)
|
||||
if (sample_clamp and
|
||||
not cscene.is_property_set("sample_clamp_direct") and
|
||||
not cscene.is_property_set("sample_clamp_indirect")):
|
||||
cscene.sample_clamp_direct = sample_clamp
|
||||
cscene.sample_clamp_indirect = sample_clamp
|
||||
|
||||
# Change of Volume Bounces in 271
|
||||
if version <= (2, 71, 0):
|
||||
cscene = scene.cycles
|
||||
if not cscene.is_property_set("volume_bounces"):
|
||||
cscene.volume_bounces = 1
|
||||
|
||||
# Caustics Reflective/Refractive separation in 272
|
||||
if version <= (2, 72, 0):
|
||||
cscene = scene.cycles
|
||||
if (cscene.get("no_caustics", False) and
|
||||
not cscene.is_property_set("caustics_reflective") and
|
||||
not cscene.is_property_set("caustics_refractive")):
|
||||
cscene.caustics_reflective = False
|
||||
cscene.caustics_refractive = False
|
||||
|
||||
cscene.caustics_reflective = False
|
||||
cscene.caustics_refractive = False
|
||||
# Baking types changed
|
||||
if version <= (2, 76, 6):
|
||||
custom_bake_remap(scene)
|
||||
|
||||
# Euler order was ZYX in previous versions.
|
||||
if bpy.data.version <= (2, 73, 4):
|
||||
foreach_cycles_node(mapping_node_order_flip)
|
||||
# Several default changes for 2.77
|
||||
if version <= (2, 76, 8):
|
||||
cscene = scene.cycles
|
||||
|
||||
if bpy.data.version <= (2, 76, 5):
|
||||
foreach_cycles_node(vector_curve_node_remap)
|
||||
# Samples
|
||||
if not cscene.is_property_set("samples"):
|
||||
cscene.samples = 10
|
||||
|
||||
# Baking types changed
|
||||
if bpy.data.version <= (2, 76, 6):
|
||||
for scene in bpy.data.scenes:
|
||||
custom_bake_remap(scene)
|
||||
# Preview Samples
|
||||
if not cscene.is_property_set("preview_samples"):
|
||||
cscene.preview_samples = 10
|
||||
|
||||
# Several default changes for 2.77
|
||||
if bpy.data.version <= (2, 76, 8):
|
||||
for scene in bpy.data.scenes:
|
||||
cscene = scene.cycles
|
||||
# Filter
|
||||
if not cscene.is_property_set("filter_type"):
|
||||
cscene.pixel_filter_type = 'GAUSSIAN'
|
||||
|
||||
# Samples
|
||||
if not cscene.is_property_set("samples"):
|
||||
cscene.samples = 10
|
||||
# Tile Order
|
||||
if not cscene.is_property_set("tile_order"):
|
||||
cscene.tile_order = 'CENTER'
|
||||
|
||||
# Preview Samples
|
||||
if not cscene.is_property_set("preview_samples"):
|
||||
cscene.preview_samples = 10
|
||||
if version <= (2, 76, 10):
|
||||
cscene = scene.cycles
|
||||
if cscene.is_property_set("filter_type"):
|
||||
if not cscene.is_property_set("pixel_filter_type"):
|
||||
cscene.pixel_filter_type = cscene.filter_type
|
||||
if cscene.filter_type == 'BLACKMAN_HARRIS':
|
||||
cscene.filter_type = 'GAUSSIAN'
|
||||
|
||||
# Filter
|
||||
if not cscene.is_property_set("filter_type"):
|
||||
cscene.pixel_filter_type = 'GAUSSIAN'
|
||||
if version <= (2, 78, 2):
|
||||
cscene = scene.cycles
|
||||
if not cscene.is_property_set("light_sampling_threshold"):
|
||||
cscene.light_sampling_threshold = 0.0
|
||||
|
||||
# Tile Order
|
||||
if not cscene.is_property_set("tile_order"):
|
||||
cscene.tile_order = 'CENTER'
|
||||
if version <= (2, 79, 0):
|
||||
cscene = scene.cycles
|
||||
# Default changes
|
||||
if not cscene.is_property_set("aa_samples"):
|
||||
cscene.aa_samples = 4
|
||||
if not cscene.is_property_set("preview_aa_samples"):
|
||||
cscene.preview_aa_samples = 4
|
||||
if not cscene.is_property_set("blur_glossy"):
|
||||
cscene.blur_glossy = 0.0
|
||||
if not cscene.is_property_set("sample_clamp_indirect"):
|
||||
cscene.sample_clamp_indirect = 0.0
|
||||
|
||||
# Lamps
|
||||
for light in bpy.data.lights:
|
||||
clight = light.cycles
|
||||
if light.library not in libraries:
|
||||
continue
|
||||
|
||||
# MIS
|
||||
if not clight.is_property_set("use_multiple_importance_sampling"):
|
||||
clight.use_multiple_importance_sampling = False
|
||||
if version <= (2, 76, 5):
|
||||
clight = light.cycles
|
||||
|
||||
for mat in bpy.data.materials:
|
||||
cmat = mat.cycles
|
||||
# MIS
|
||||
if not clight.is_property_set("use_multiple_importance_sampling"):
|
||||
clight.use_multiple_importance_sampling = False
|
||||
|
||||
# Volume Sampling
|
||||
if not cmat.is_property_set("volume_sampling"):
|
||||
cmat.volume_sampling = 'DISTANCE'
|
||||
|
||||
if bpy.data.version <= (2, 76, 9):
|
||||
# Worlds
|
||||
for world in bpy.data.worlds:
|
||||
cworld = world.cycles
|
||||
if world.library not in libraries:
|
||||
continue
|
||||
|
||||
# World MIS Samples
|
||||
if not cworld.is_property_set("samples"):
|
||||
cworld.samples = 4
|
||||
if version <= (2, 76, 9):
|
||||
cworld = world.cycles
|
||||
|
||||
# World MIS Resolution
|
||||
if not cworld.is_property_set("sample_map_resolution"):
|
||||
cworld.sample_map_resolution = 256
|
||||
# World MIS Samples
|
||||
if not cworld.is_property_set("samples"):
|
||||
cworld.samples = 4
|
||||
|
||||
if bpy.data.version <= (2, 76, 10):
|
||||
for scene in bpy.data.scenes:
|
||||
cscene = scene.cycles
|
||||
if cscene.is_property_set("filter_type"):
|
||||
if not cscene.is_property_set("pixel_filter_type"):
|
||||
cscene.pixel_filter_type = cscene.filter_type
|
||||
if cscene.filter_type == 'BLACKMAN_HARRIS':
|
||||
cscene.filter_type = 'GAUSSIAN'
|
||||
# World MIS Resolution
|
||||
if not cworld.is_property_set("sample_map_resolution"):
|
||||
cworld.sample_map_resolution = 256
|
||||
|
||||
if bpy.data.version <= (2, 78, 2):
|
||||
for scene in bpy.data.scenes:
|
||||
cscene = scene.cycles
|
||||
if not cscene.is_property_set("light_sampling_threshold"):
|
||||
cscene.light_sampling_threshold = 0.0
|
||||
if version <= (2, 79, 4) or \
|
||||
(version >= (2, 80, 0) and version <= (2, 80, 18)):
|
||||
cworld = world.cycles
|
||||
# World MIS
|
||||
if not cworld.is_property_set("sampling_method"):
|
||||
if cworld.get("sample_as_light", True):
|
||||
cworld.sampling_method = 'MANUAL'
|
||||
else:
|
||||
cworld.sampling_method = 'NONE'
|
||||
|
||||
if bpy.data.version <= (2, 79, 0):
|
||||
for scene in bpy.data.scenes:
|
||||
cscene = scene.cycles
|
||||
# Default changes
|
||||
if not cscene.is_property_set("aa_samples"):
|
||||
cscene.aa_samples = 4
|
||||
if not cscene.is_property_set("preview_aa_samples"):
|
||||
cscene.preview_aa_samples = 4
|
||||
if not cscene.is_property_set("blur_glossy"):
|
||||
cscene.blur_glossy = 0.0
|
||||
if not cscene.is_property_set("sample_clamp_indirect"):
|
||||
cscene.sample_clamp_indirect = 0.0
|
||||
|
||||
if bpy.data.version <= (2, 79, 1) or \
|
||||
(bpy.data.version >= (2, 80, 0) and bpy.data.version <= (2, 80, 3)):
|
||||
displacement_nodes_insert()
|
||||
|
||||
if bpy.data.version <= (2, 79, 2):
|
||||
# Materials
|
||||
for mat in bpy.data.materials:
|
||||
cmat = mat.cycles
|
||||
if not cmat.is_property_set("displacement_method"):
|
||||
cmat.displacement_method = 'BUMP'
|
||||
if mat.library not in libraries:
|
||||
continue
|
||||
|
||||
foreach_cycles_node(displacement_principled_nodes)
|
||||
if version <= (2, 76, 5):
|
||||
cmat = mat.cycles
|
||||
# Volume Sampling
|
||||
if not cmat.is_property_set("volume_sampling"):
|
||||
cmat.volume_sampling = 'DISTANCE'
|
||||
|
||||
if bpy.data.version <= (2, 79, 3) or \
|
||||
(bpy.data.version >= (2, 80, 0) and bpy.data.version <= (2, 80, 4)):
|
||||
# Switch to squared roughness convention
|
||||
square_roughness_nodes_insert()
|
||||
if version <= (2, 79, 2):
|
||||
cmat = mat.cycles
|
||||
if not cmat.is_property_set("displacement_method"):
|
||||
cmat.displacement_method = 'BUMP'
|
||||
|
||||
if bpy.data.version <= (2, 80, 15):
|
||||
# Copy cycles hair settings to internal settings
|
||||
# Change default to bump again.
|
||||
if version <= (2, 79, 6) or \
|
||||
(version >= (2, 80, 0) and version <= (2, 80, 41)):
|
||||
cmat = mat.cycles
|
||||
if not cmat.is_property_set("displacement_method"):
|
||||
cmat.displacement_method = 'DISPLACEMENT'
|
||||
|
||||
# Nodes
|
||||
for nodetree, library in foreach_cycles_nodetree():
|
||||
if library not in libraries:
|
||||
continue
|
||||
|
||||
# Euler order was ZYX in previous versions.
|
||||
if version <= (2, 73, 4):
|
||||
for node in nodetree.nodes:
|
||||
mapping_node_order_flip(node)
|
||||
|
||||
if version <= (2, 76, 5):
|
||||
for node in nodetree.nodes:
|
||||
vector_curve_node_remap(node)
|
||||
|
||||
if version <= (2, 79, 1) or \
|
||||
(version >= (2, 80, 0) and version <= (2, 80, 3)):
|
||||
displacement_node_insert(nodetree)
|
||||
|
||||
if version <= (2, 79, 2):
|
||||
for node in nodetree.nodes:
|
||||
displacement_principled_nodes(node)
|
||||
|
||||
if version <= (2, 79, 3) or \
|
||||
(version >= (2, 80, 0) and version <= (2, 80, 4)):
|
||||
# Switch to squared roughness convention
|
||||
square_roughness_node_insert(nodetree)
|
||||
|
||||
if version <= (2, 79, 4):
|
||||
ambient_occlusion_node_relink(nodetree)
|
||||
|
||||
# Particles
|
||||
for part in bpy.data.particles:
|
||||
cpart = part.get("cycles", None)
|
||||
if cpart:
|
||||
part.shape = cpart.get("shape", 0.0)
|
||||
part.root_radius = cpart.get("root_width", 1.0)
|
||||
part.tip_radius = cpart.get("tip_width", 0.0)
|
||||
part.radius_scale = cpart.get("radius_scale", 0.01)
|
||||
part.use_close_tip = cpart.get("use_closetip", True)
|
||||
if part.library not in libraries:
|
||||
continue
|
||||
|
||||
if bpy.data.version <= (2, 79, 4) or \
|
||||
(bpy.data.version >= (2, 80, 0) and bpy.data.version <= (2, 80, 18)):
|
||||
for world in bpy.data.worlds:
|
||||
cworld = world.cycles
|
||||
# World MIS
|
||||
if not cworld.is_property_set("sampling_method"):
|
||||
if cworld.get("sample_as_light", True):
|
||||
cworld.sampling_method = 'MANUAL'
|
||||
else:
|
||||
cworld.sampling_method = 'NONE'
|
||||
|
||||
ambient_occlusion_nodes_relink()
|
||||
|
||||
if bpy.data.version <= (2, 79, 6) or \
|
||||
(bpy.data.version >= (2, 80, 0) and bpy.data.version <= (2, 80, 41)):
|
||||
# Change default to bump again.
|
||||
for mat in bpy.data.materials:
|
||||
cmat = mat.cycles
|
||||
if not cmat.is_property_set("displacement_method"):
|
||||
cmat.displacement_method = 'DISPLACEMENT'
|
||||
# Copy cycles hair settings to internal settings
|
||||
if version <= (2, 80, 15):
|
||||
cpart = part.get("cycles", None)
|
||||
if cpart:
|
||||
part.shape = cpart.get("shape", 0.0)
|
||||
part.root_radius = cpart.get("root_width", 1.0)
|
||||
part.tip_radius = cpart.get("tip_width", 0.0)
|
||||
part.radius_scale = cpart.get("radius_scale", 0.01)
|
||||
part.use_close_tip = cpart.get("use_closetip", True)
|
||||
|
|
|
@ -28,6 +28,7 @@
|
|||
|
||||
/* for backtrace and gethostname/GetComputerName */
|
||||
#if defined(WIN32)
|
||||
# include <intrin.h>
|
||||
# include <windows.h>
|
||||
# include <dbghelp.h>
|
||||
#else
|
||||
|
|
|
@ -848,6 +848,14 @@ static IDProperty *rna_IDPropertyWrapPtr_idprops(PointerRNA *ptr, bool UNUSED(cr
|
|||
return ptr->data;
|
||||
}
|
||||
|
||||
static void rna_Library_version_get(PointerRNA *ptr, int *value)
|
||||
{
|
||||
Library *lib = (Library *)ptr->data;
|
||||
value[0] = lib->versionfile / 100;
|
||||
value[1] = lib->versionfile % 100;
|
||||
value[2] = lib->subversionfile;
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
static void rna_def_ID_properties(BlenderRNA *brna)
|
||||
|
@ -1316,6 +1324,12 @@ static void rna_def_library(BlenderRNA *brna)
|
|||
RNA_def_property_pointer_sdna(prop, NULL, "packedfile");
|
||||
RNA_def_property_ui_text(prop, "Packed File", "");
|
||||
|
||||
prop = RNA_def_int_vector(srna, "version", 3, NULL, 0, INT_MAX,
|
||||
"Version", "Version of Blender the library .blend was saved with", 0, INT_MAX);
|
||||
RNA_def_property_int_funcs(prop, "rna_Library_version_get", NULL, NULL);
|
||||
RNA_def_property_clear_flag(prop, PROP_EDITABLE);
|
||||
RNA_def_property_flag(prop, PROP_THICK_WRAP);
|
||||
|
||||
func = RNA_def_function(srna, "reload", "WM_lib_reload");
|
||||
RNA_def_function_flag(func, FUNC_USE_REPORTS | FUNC_USE_CONTEXT);
|
||||
RNA_def_function_ui_description(func, "Reload this library and all its linked data-blocks");
|
||||
|
|
Loading…
Reference in New Issue