Files
test/source/blender/blenloader/intern/versioning_userdef.cc
Pablo Vazquez 4340d5fff9 Merge branch 'blender-v5.0-release'
# Conflicts:
#	source/blender/blenkernel/BKE_blender_version.h
#	source/blender/blenloader/intern/versioning_userdef.cc
2025-10-17 18:53:10 +02:00

1766 lines
62 KiB
C++

/* SPDX-FileCopyrightText: 2023 Blender Authors
*
* SPDX-License-Identifier: GPL-2.0-or-later */
/** \file
* \ingroup blenloader
*
* Version patch user preferences.
*/
#define DNA_DEPRECATED_ALLOW
#include <cstring>
#include <fmt/format.h>
#include "BLI_listbase.h"
#include "BLI_map.hh"
#include "BLI_math_rotation.h"
#include "BLI_math_vector.h"
#include "BLI_string.h"
#include "BLI_string_utf8.h"
#include "BLI_string_utils.hh"
#include "BLI_utildefines.h"
#include "DNA_anim_types.h"
#include "DNA_curve_types.h"
#include "DNA_scene_types.h"
#include "DNA_space_types.h"
#include "DNA_userdef_types.h"
#include "DNA_windowmanager_types.h"
#include "BKE_addon.h"
#include "BKE_blender_version.h"
#include "BKE_colorband.hh"
#include "BKE_idprop.hh"
#include "BKE_keyconfig.h"
#include "BKE_main.hh"
#include "BKE_preferences.h"
#include "BLO_readfile.hh"
#include "BLO_userdef_default.h"
#include "BLT_translation.hh"
#include "DNA_brush_enums.h"
#include "GPU_platform.hh"
#include "MEM_guardedalloc.h"
#include "readfile.hh" /* Own include. */
#include "WM_keymap.hh"
#include "WM_types.hh"
#include "wm_event_types.hh"
/* Don't use translation strings in versioning!
* These depend on the preferences already being read.
* If this is important we can set the translations as part of versioning preferences,
* however that should only be done if there are important use-cases. */
#if 0
# include "BLT_translation.hh"
#else
# define N_(msgid) msgid
#endif
/* For versioning we only ever want to manipulate preferences passed in. */
#define U BLI_STATIC_ASSERT(false, "Global 'U' not allowed, only use arguments passed in!")
static void do_versions_theme(const UserDef *userdef, bTheme *btheme)
{
#define USER_VERSION_ATLEAST(ver, subver) MAIN_VERSION_FILE_ATLEAST(userdef, ver, subver)
#define FROM_DEFAULT_V4_UCHAR(member) copy_v4_v4_uchar(btheme->member, U_theme_default.member)
if (!USER_VERSION_ATLEAST(300, 41)) {
MEMCPY_STRUCT_AFTER(btheme, &U_theme_default, name);
}
/* Again reset the theme, but only if stored with an early 3.1 alpha version. Some changes were
* done in the release branch and then merged into the 3.1 branch (master). So the previous reset
* wouldn't work for people who saved their preferences with a 3.1 build meanwhile. But we still
* don't want to reset theme changes stored in the eventual 3.0 release once opened in a 3.1
* build. */
if (userdef->versionfile > 300 && !USER_VERSION_ATLEAST(301, 1)) {
MEMCPY_STRUCT_AFTER(btheme, &U_theme_default, name);
}
if (!USER_VERSION_ATLEAST(301, 2)) {
FROM_DEFAULT_V4_UCHAR(space_sequencer.mask);
}
if (!USER_VERSION_ATLEAST(302, 8)) {
btheme->space_node.grid_levels = U_theme_default.space_node.grid_levels;
}
if (!USER_VERSION_ATLEAST(306, 3)) {
FROM_DEFAULT_V4_UCHAR(space_view3d.face_retopology);
}
if (!USER_VERSION_ATLEAST(306, 8)) {
FROM_DEFAULT_V4_UCHAR(space_node.node_zone_simulation);
FROM_DEFAULT_V4_UCHAR(space_action.simulated_frames);
}
if (!USER_VERSION_ATLEAST(400, 12)) {
FROM_DEFAULT_V4_UCHAR(space_node.node_zone_repeat);
}
if (!USER_VERSION_ATLEAST(400, 24)) {
FROM_DEFAULT_V4_UCHAR(tui.wcol_list_item.inner_sel);
FROM_DEFAULT_V4_UCHAR(space_sequencer.transition);
}
if (!USER_VERSION_ATLEAST(400, 27)) {
FROM_DEFAULT_V4_UCHAR(space_sequencer.keyborder);
FROM_DEFAULT_V4_UCHAR(space_sequencer.keyborder_select);
FROM_DEFAULT_V4_UCHAR(space_sequencer.transition);
}
if (!USER_VERSION_ATLEAST(400, 35)) {
FROM_DEFAULT_V4_UCHAR(tui.wcol_list_item.item);
}
if (!USER_VERSION_ATLEAST(401, 4)) {
FROM_DEFAULT_V4_UCHAR(space_view3d.edge_select);
FROM_DEFAULT_V4_UCHAR(space_view3d.edge_mode_select);
FROM_DEFAULT_V4_UCHAR(space_view3d.face_select);
FROM_DEFAULT_V4_UCHAR(space_view3d.face_mode_select);
}
if (!USER_VERSION_ATLEAST(402, 13)) {
FROM_DEFAULT_V4_UCHAR(space_text.hilite);
FROM_DEFAULT_V4_UCHAR(space_console.console_cursor);
}
if (!USER_VERSION_ATLEAST(402, 16)) {
BLI_uniquename(
&userdef->themes, btheme, "Theme", '.', offsetof(bTheme, name), sizeof(btheme->name));
}
if (!USER_VERSION_ATLEAST(402, 47)) {
FROM_DEFAULT_V4_UCHAR(space_view3d.time_gp_keyframe);
}
if (!USER_VERSION_ATLEAST(402, 62)) {
FROM_DEFAULT_V4_UCHAR(space_sequencer.audio);
FROM_DEFAULT_V4_UCHAR(space_sequencer.color_strip);
FROM_DEFAULT_V4_UCHAR(space_sequencer.effect);
FROM_DEFAULT_V4_UCHAR(space_sequencer.image);
FROM_DEFAULT_V4_UCHAR(space_sequencer.mask);
FROM_DEFAULT_V4_UCHAR(space_sequencer.meta);
FROM_DEFAULT_V4_UCHAR(space_sequencer.movie);
FROM_DEFAULT_V4_UCHAR(space_sequencer.movieclip);
FROM_DEFAULT_V4_UCHAR(space_sequencer.scene);
FROM_DEFAULT_V4_UCHAR(space_sequencer.text_strip);
FROM_DEFAULT_V4_UCHAR(space_sequencer.transition);
}
if (!USER_VERSION_ATLEAST(403, 5)) {
FROM_DEFAULT_V4_UCHAR(space_view3d.before_current_frame);
FROM_DEFAULT_V4_UCHAR(space_view3d.after_current_frame);
FROM_DEFAULT_V4_UCHAR(space_sequencer.before_current_frame);
FROM_DEFAULT_V4_UCHAR(space_sequencer.after_current_frame);
}
if (!USER_VERSION_ATLEAST(403, 18)) {
FROM_DEFAULT_V4_UCHAR(tui.icon_autokey);
}
if (!USER_VERSION_ATLEAST(403, 25)) {
FROM_DEFAULT_V4_UCHAR(space_node.node_zone_foreach_geometry_element);
}
if (!USER_VERSION_ATLEAST(403, 27)) {
FROM_DEFAULT_V4_UCHAR(tui.editor_border);
FROM_DEFAULT_V4_UCHAR(tui.editor_outline);
FROM_DEFAULT_V4_UCHAR(tui.editor_outline_active);
}
if (!USER_VERSION_ATLEAST(404, 7)) {
if (btheme->space_view3d.face_front[0] == 0 && btheme->space_view3d.face_front[1] == 0 &&
btheme->space_view3d.face_front[2] == 0xFF && btheme->space_view3d.face_front[3] == 0xB3)
{
/* Use new default value only if currently set to the old default value. */
FROM_DEFAULT_V4_UCHAR(space_view3d.face_front);
}
}
if (!USER_VERSION_ATLEAST(404, 12)) {
FROM_DEFAULT_V4_UCHAR(space_sequencer.text_strip_cursor);
FROM_DEFAULT_V4_UCHAR(space_sequencer.selected_text);
}
if (!USER_VERSION_ATLEAST(405, 3)) {
FROM_DEFAULT_V4_UCHAR(tui.wcol_state.error);
FROM_DEFAULT_V4_UCHAR(tui.wcol_state.warning);
FROM_DEFAULT_V4_UCHAR(tui.wcol_state.info);
FROM_DEFAULT_V4_UCHAR(tui.wcol_state.success);
}
if (!USER_VERSION_ATLEAST(405, 14)) {
FROM_DEFAULT_V4_UCHAR(space_node.node_zone_closure);
}
if (!USER_VERSION_ATLEAST(500, 6)) {
/* Match the selected/unselected outline colors. */
copy_v4_v4_uchar(btheme->tui.wcol_box.outline_sel, U_theme_default.tui.wcol_box.outline);
copy_v4_v4_uchar(btheme->tui.wcol_list_item.outline_sel,
U_theme_default.tui.wcol_list_item.outline);
copy_v4_v4_uchar(btheme->tui.wcol_menu.outline_sel, U_theme_default.tui.wcol_menu.outline);
copy_v4_v4_uchar(btheme->tui.wcol_menu_back.outline_sel,
U_theme_default.tui.wcol_menu_back.outline);
copy_v4_v4_uchar(btheme->tui.wcol_menu_item.outline_sel,
U_theme_default.tui.wcol_menu_item.outline);
copy_v4_v4_uchar(btheme->tui.wcol_num.outline_sel, U_theme_default.tui.wcol_num.outline);
copy_v4_v4_uchar(btheme->tui.wcol_numslider.outline_sel,
U_theme_default.tui.wcol_numslider.outline);
copy_v4_v4_uchar(btheme->tui.wcol_option.outline_sel, U_theme_default.tui.wcol_option.outline);
copy_v4_v4_uchar(btheme->tui.wcol_pie_menu.outline_sel,
U_theme_default.tui.wcol_pie_menu.outline);
copy_v4_v4_uchar(btheme->tui.wcol_progress.outline_sel,
U_theme_default.tui.wcol_progress.outline);
copy_v4_v4_uchar(btheme->tui.wcol_pulldown.outline_sel,
U_theme_default.tui.wcol_pulldown.outline);
copy_v4_v4_uchar(btheme->tui.wcol_radio.outline_sel, U_theme_default.tui.wcol_radio.outline);
copy_v4_v4_uchar(btheme->tui.wcol_regular.outline_sel,
U_theme_default.tui.wcol_regular.outline);
copy_v4_v4_uchar(btheme->tui.wcol_scroll.outline_sel, U_theme_default.tui.wcol_scroll.outline);
copy_v4_v4_uchar(btheme->tui.wcol_tab.outline_sel, U_theme_default.tui.wcol_tab.outline);
copy_v4_v4_uchar(btheme->tui.wcol_text.outline_sel, U_theme_default.tui.wcol_text.outline);
copy_v4_v4_uchar(btheme->tui.wcol_toggle.outline_sel, U_theme_default.tui.wcol_toggle.outline);
copy_v4_v4_uchar(btheme->tui.wcol_tool.outline_sel, U_theme_default.tui.wcol_tool.outline);
copy_v4_v4_uchar(btheme->tui.wcol_toolbar_item.outline_sel,
U_theme_default.tui.wcol_toolbar_item.outline);
copy_v4_v4_uchar(btheme->tui.wcol_tooltip.outline_sel,
U_theme_default.tui.wcol_tooltip.outline);
}
if (!USER_VERSION_ATLEAST(500, 9)) {
FROM_DEFAULT_V4_UCHAR(tui.panel_header);
FROM_DEFAULT_V4_UCHAR(tui.panel_back);
FROM_DEFAULT_V4_UCHAR(tui.panel_sub_back);
}
if (!USER_VERSION_ATLEAST(500, 12)) {
FROM_DEFAULT_V4_UCHAR(space_node.syntaxs);
FROM_DEFAULT_V4_UCHAR(space_node.syntaxb);
FROM_DEFAULT_V4_UCHAR(space_node.syntaxn);
FROM_DEFAULT_V4_UCHAR(space_node.syntaxv);
FROM_DEFAULT_V4_UCHAR(space_node.syntaxc);
FROM_DEFAULT_V4_UCHAR(space_node.syntaxd);
FROM_DEFAULT_V4_UCHAR(space_node.nodeclass_attribute);
FROM_DEFAULT_V4_UCHAR(space_node.nodeclass_filter);
FROM_DEFAULT_V4_UCHAR(space_node.nodeclass_geometry);
FROM_DEFAULT_V4_UCHAR(space_node.nodeclass_output);
FROM_DEFAULT_V4_UCHAR(space_node.nodeclass_script);
FROM_DEFAULT_V4_UCHAR(space_node.nodeclass_shader);
FROM_DEFAULT_V4_UCHAR(space_node.nodeclass_texture);
FROM_DEFAULT_V4_UCHAR(space_node.nodeclass_vector);
}
if (!USER_VERSION_ATLEAST(500, 19)) {
btheme->tui.menu_shadow_fac = U_theme_default.tui.menu_shadow_fac;
btheme->tui.menu_shadow_width = U_theme_default.tui.menu_shadow_width;
}
if (!USER_VERSION_ATLEAST(500, 24)) {
FROM_DEFAULT_V4_UCHAR(tui.panel_title);
FROM_DEFAULT_V4_UCHAR(tui.panel_text);
}
if (!USER_VERSION_ATLEAST(500, 29)) {
FROM_DEFAULT_V4_UCHAR(space_node.console_output);
}
if (!USER_VERSION_ATLEAST(405, 45)) {
FROM_DEFAULT_V4_UCHAR(space_node.node_zone_closure);
FROM_DEFAULT_V4_UCHAR(space_node.node_zone_repeat);
}
if (!USER_VERSION_ATLEAST(500, 47)) {
if (btheme->tui.panel_title[3] == 0) {
btheme->tui.panel_title[3] = 255;
}
if (btheme->tui.panel_text[3] == 0) {
btheme->tui.panel_text[3] = 255;
}
}
if (!USER_VERSION_ATLEAST(500, 50)) {
FROM_DEFAULT_V4_UCHAR(common.anim.preview_range);
}
if (!USER_VERSION_ATLEAST(500, 52)) {
FROM_DEFAULT_V4_UCHAR(tui.waxis);
}
if (!USER_VERSION_ATLEAST(405, 55)) {
FROM_DEFAULT_V4_UCHAR(space_node.node_zone_closure);
FROM_DEFAULT_V4_UCHAR(space_node.node_zone_repeat);
}
if (!USER_VERSION_ATLEAST(500, 56)) {
FROM_DEFAULT_V4_UCHAR(common.anim.playhead);
FROM_DEFAULT_V4_UCHAR(common.anim.channel_group);
FROM_DEFAULT_V4_UCHAR(common.anim.channel_group_active);
}
if (!USER_VERSION_ATLEAST(500, 60)) {
FROM_DEFAULT_V4_UCHAR(common.curves.handle_free);
FROM_DEFAULT_V4_UCHAR(common.curves.handle_auto);
FROM_DEFAULT_V4_UCHAR(common.curves.handle_vect);
FROM_DEFAULT_V4_UCHAR(common.curves.handle_align);
FROM_DEFAULT_V4_UCHAR(common.curves.handle_auto_clamped);
FROM_DEFAULT_V4_UCHAR(common.curves.handle_sel_free);
FROM_DEFAULT_V4_UCHAR(common.curves.handle_sel_auto);
FROM_DEFAULT_V4_UCHAR(common.curves.handle_sel_vect);
FROM_DEFAULT_V4_UCHAR(common.curves.handle_sel_align);
FROM_DEFAULT_V4_UCHAR(common.curves.handle_sel_auto_clamped);
FROM_DEFAULT_V4_UCHAR(common.curves.handle_vertex);
FROM_DEFAULT_V4_UCHAR(common.curves.handle_vertex_select);
btheme->common.curves.handle_vertex_size = U_theme_default.common.curves.handle_vertex_size;
}
if (!USER_VERSION_ATLEAST(500, 69)) {
FROM_DEFAULT_V4_UCHAR(common.anim.keyframe);
FROM_DEFAULT_V4_UCHAR(common.anim.keyframe_extreme);
FROM_DEFAULT_V4_UCHAR(common.anim.keyframe_breakdown);
FROM_DEFAULT_V4_UCHAR(common.anim.keyframe_jitter);
FROM_DEFAULT_V4_UCHAR(common.anim.keyframe_moving_hold);
FROM_DEFAULT_V4_UCHAR(common.anim.keyframe_generated);
FROM_DEFAULT_V4_UCHAR(common.anim.keyframe_selected);
FROM_DEFAULT_V4_UCHAR(common.anim.keyframe_extreme_selected);
FROM_DEFAULT_V4_UCHAR(common.anim.keyframe_breakdown_selected);
FROM_DEFAULT_V4_UCHAR(common.anim.keyframe_jitter_selected);
FROM_DEFAULT_V4_UCHAR(common.anim.keyframe_moving_hold_selected);
FROM_DEFAULT_V4_UCHAR(common.anim.keyframe_generated_selected);
FROM_DEFAULT_V4_UCHAR(common.anim.long_key);
FROM_DEFAULT_V4_UCHAR(common.anim.long_key_selected);
}
if (!USER_VERSION_ATLEAST(500, 74)) {
FROM_DEFAULT_V4_UCHAR(tui.panel_active);
}
if (!USER_VERSION_ATLEAST(500, 78)) {
FROM_DEFAULT_V4_UCHAR(regions.channels.back);
FROM_DEFAULT_V4_UCHAR(regions.channels.text);
FROM_DEFAULT_V4_UCHAR(regions.channels.text_selected);
FROM_DEFAULT_V4_UCHAR(regions.asset_shelf.back);
FROM_DEFAULT_V4_UCHAR(regions.asset_shelf.header_back);
FROM_DEFAULT_V4_UCHAR(regions.sidebars.back);
FROM_DEFAULT_V4_UCHAR(regions.sidebars.tab_back);
}
if (!USER_VERSION_ATLEAST(500, 79)) {
FROM_DEFAULT_V4_UCHAR(common.anim.channels);
FROM_DEFAULT_V4_UCHAR(common.anim.channels_sub);
FROM_DEFAULT_V4_UCHAR(common.anim.channel);
FROM_DEFAULT_V4_UCHAR(common.anim.channel_selected);
}
if (!USER_VERSION_ATLEAST(500, 80)) {
FROM_DEFAULT_V4_UCHAR(regions.scrubbing.back);
FROM_DEFAULT_V4_UCHAR(regions.scrubbing.text);
FROM_DEFAULT_V4_UCHAR(regions.scrubbing.time_marker);
FROM_DEFAULT_V4_UCHAR(regions.scrubbing.time_marker_selected);
}
if (!USER_VERSION_ATLEAST(500, 91)) {
FROM_DEFAULT_V4_UCHAR(space_view3d.bevel);
FROM_DEFAULT_V4_UCHAR(space_view3d.seam);
FROM_DEFAULT_V4_UCHAR(space_view3d.sharp);
FROM_DEFAULT_V4_UCHAR(space_view3d.crease);
FROM_DEFAULT_V4_UCHAR(space_view3d.freestyle);
}
if (!USER_VERSION_ATLEAST(500, 93)) {
FROM_DEFAULT_V4_UCHAR(tui.wcol_curve.text);
FROM_DEFAULT_V4_UCHAR(tui.wcol_curve.text_sel);
FROM_DEFAULT_V4_UCHAR(tui.wcol_curve.item);
FROM_DEFAULT_V4_UCHAR(tui.wcol_curve.inner);
FROM_DEFAULT_V4_UCHAR(tui.wcol_curve.inner_sel);
FROM_DEFAULT_V4_UCHAR(tui.wcol_curve.outline);
FROM_DEFAULT_V4_UCHAR(tui.wcol_curve.outline_sel);
btheme->tui.wcol_curve.roundness = U_theme_default.tui.wcol_curve.roundness;
}
if (!USER_VERSION_ATLEAST(500, 104)) {
FROM_DEFAULT_V4_UCHAR(common.anim.scene_strip_range);
}
/* Reset the theme due to compatibility breaking changes in 5.0. */
if (!USER_VERSION_ATLEAST(500, 111)) {
MEMCPY_STRUCT_AFTER(btheme, &U_theme_default, name);
/* Update text styles to match. */
LISTBASE_FOREACH (uiStyle *, style, &userdef->uistyles) {
style->paneltitle.points = 11.0f;
style->paneltitle.shadow = 3;
style->paneltitle.shadowalpha = 0.5f;
style->paneltitle.shadowcolor = 0.0f;
style->widget.points = 11.0f;
style->widget.shadow = 1;
style->widget.shadowalpha = 0.5f;
style->widget.shadowcolor = 0.0f;
style->tooltip.shadow = 1;
style->tooltip.points = 11.0f;
style->tooltip.shadowalpha = 0.5f;
style->tooltip.shadowcolor = 0.0f;
}
}
if (!USER_VERSION_ATLEAST(501, 3)) {
FROM_DEFAULT_V4_UCHAR(space_action.anim_interpolation_other);
FROM_DEFAULT_V4_UCHAR(space_action.anim_interpolation_constant);
FROM_DEFAULT_V4_UCHAR(space_action.anim_interpolation_linear);
}
/**
* Always bump subversion in BKE_blender_version.h when adding versioning
* code here, and wrap it inside a USER_VERSION_ATLEAST check.
*
* \note Keep this message at the bottom of the function.
*/
#undef FROM_DEFAULT_V4_UCHAR
#undef USER_VERSION_ATLEAST
}
/** #UserDef.flag */
#define USER_LMOUSESELECT (1 << 14) /* deprecated */
static void do_version_select_mouse(const UserDef *userdef, wmKeyMapItem *kmi)
{
/* Remove select/action mouse from user defined keymaps. */
enum {
ACTIONMOUSE = 0x0005,
SELECTMOUSE = 0x0006,
EVT_TWEAK_A = 0x5005,
EVT_TWEAK_S = 0x5006,
};
const bool left = (userdef->flag & USER_LMOUSESELECT) != 0;
switch (kmi->type) {
case SELECTMOUSE:
kmi->type = (left) ? LEFTMOUSE : RIGHTMOUSE;
break;
case ACTIONMOUSE:
kmi->type = (left) ? RIGHTMOUSE : LEFTMOUSE;
break;
case EVT_TWEAK_S:
kmi->type = (left) ? LEFTMOUSE : RIGHTMOUSE;
kmi->val = KM_PRESS_DRAG;
break;
case EVT_TWEAK_A:
kmi->type = (left) ? RIGHTMOUSE : LEFTMOUSE;
kmi->val = KM_PRESS_DRAG;
break;
default:
break;
}
}
static void do_version_keyframe_jump(wmKeyMapItem *kmi)
{
if (STREQ(kmi->idname, "GRAPH_OT_keyframe_jump")) {
STRNCPY(kmi->idname, "SCREEN_OT_keyframe_jump");
}
}
static bool keymap_item_has_invalid_wm_context_data_path(wmKeyMapItem *kmi, void * /*user_data*/)
{
if (STRPREFIX(kmi->idname, "WM_OT_context_") && kmi->properties) {
IDProperty *idprop = IDP_GetPropertyFromGroup(kmi->properties, "data_path");
if (idprop && (idprop->type == IDP_STRING) &&
STRPREFIX(static_cast<const char *>(idprop->data.pointer), "(null)"))
{
return true;
}
}
return false;
}
/** Tweak event types have been removed, replace with click-drag. */
static bool keymap_item_update_tweak_event(wmKeyMapItem *kmi, void * /*user_data*/)
{
/* Tweak events for L M R mouse-buttons. */
enum {
EVT_TWEAK_L = 0x5002,
EVT_TWEAK_M = 0x5003,
EVT_TWEAK_R = 0x5004,
};
switch (kmi->type) {
case EVT_TWEAK_L:
kmi->type = LEFTMOUSE;
break;
case EVT_TWEAK_M:
kmi->type = MIDDLEMOUSE;
break;
case EVT_TWEAK_R:
kmi->type = RIGHTMOUSE;
break;
default:
kmi->direction = KM_ANY;
return false;
}
if (kmi->val >= KM_DIRECTION_N && kmi->val <= KM_DIRECTION_NW) {
kmi->direction = kmi->val;
}
else {
kmi->direction = KM_ANY;
}
kmi->val = KM_PRESS_DRAG;
return false;
}
static void keymap_update_brushes_handle_add_item(
const blender::StringRef asset_prefix,
const blender::StringRef tool_property,
const blender::Map<blender::StringRef, blender::StringRefNull> &tool_tool_map,
const blender::Map<blender::StringRef, blender::StringRef> &tool_asset_map,
const blender::Map<int, blender::StringRef> &id_asset_map,
wmKeyMapItem *kmi)
{
std::optional<blender::StringRef> asset_id = {};
std::optional<blender::StringRefNull> tool_id = {};
if (STREQ(kmi->idname, "WM_OT_tool_set_by_id")) {
IDProperty *idprop = IDP_GetPropertyFromGroup(kmi->properties, "name");
if (idprop && (idprop->type == IDP_STRING)) {
const blender::StringRef prop_val = IDP_string_get(idprop);
if (!prop_val.startswith("builtin_brush.")) {
return;
}
if (tool_asset_map.contains(prop_val)) {
asset_id = tool_asset_map.lookup(prop_val);
}
else if (tool_tool_map.contains(prop_val)) {
tool_id = tool_tool_map.lookup(prop_val);
}
}
}
else if (STREQ(kmi->idname, "PAINT_OT_brush_select")) {
IDProperty *idprop = IDP_GetPropertyFromGroup(kmi->properties, tool_property);
if (idprop && (idprop->type == IDP_INT)) {
const int prop_val = IDP_int_get(idprop);
if (id_asset_map.contains(prop_val)) {
asset_id = id_asset_map.lookup(prop_val);
}
}
}
if (asset_id) {
const std::string full_path = fmt::format("{}{}", asset_prefix, *asset_id);
WM_keymap_item_properties_reset(kmi, nullptr);
STRNCPY(kmi->idname, "BRUSH_OT_asset_activate");
IDP_AddToGroup(
kmi->properties,
blender::bke::idprop::create("asset_library_type", ASSET_LIBRARY_ESSENTIALS).release());
IDP_AddToGroup(kmi->properties,
blender::bke::idprop::create("relative_asset_identifier", full_path).release());
}
else if (tool_id) {
WM_keymap_item_properties_reset(kmi, nullptr);
IDP_AddToGroup(kmi->properties, blender::bke::idprop::create("name", *tool_id).release());
}
}
static void keymap_update_brushes_handle_remove_item(
const blender::StringRef asset_prefix,
const blender::StringRef tool_property,
const blender::Map<int, blender::StringRef> &id_asset_map,
wmKeyMapItem *kmi)
{
std::optional<blender::StringRef> asset_id = {};
/* Only the paint.brush_select operator is stored in the default keymap & applicable to be
* updated if the user removed it in a previous version. */
if (STREQ(kmi->idname, "PAINT_OT_brush_select")) {
IDProperty *idprop = IDP_GetPropertyFromGroup(kmi->properties, tool_property);
if (idprop && (idprop->type == IDP_INT)) {
const int prop_val = IDP_int_get(idprop);
if (id_asset_map.contains(prop_val)) {
asset_id = id_asset_map.lookup(prop_val);
}
}
}
if (asset_id) {
const std::string full_path = fmt::format("{}{}", asset_prefix, *asset_id);
WM_keymap_item_properties_reset(kmi, nullptr);
STRNCPY(kmi->idname, "BRUSH_OT_asset_activate");
IDP_AddToGroup(
kmi->properties,
blender::bke::idprop::create("asset_library_type", ASSET_LIBRARY_ESSENTIALS).release());
IDP_AddToGroup(kmi->properties,
blender::bke::idprop::create("relative_asset_identifier", full_path).release());
}
}
static void keymap_update_brushes(
wmKeyMap *keymap,
const blender::StringRef asset_prefix,
const blender::StringRef tool_property,
const blender::Map<blender::StringRef, blender::StringRefNull> &tool_tool_map,
const blender::Map<blender::StringRef, blender::StringRef> &tool_asset_map,
const blender::Map<int, blender::StringRef> &id_asset_map)
{
LISTBASE_FOREACH (wmKeyMapDiffItem *, kmid, &keymap->diff_items) {
if (kmid->add_item) {
keymap_update_brushes_handle_add_item(asset_prefix,
tool_property,
tool_tool_map,
tool_asset_map,
id_asset_map,
kmid->add_item);
}
if (kmid->remove_item) {
keymap_update_brushes_handle_remove_item(
asset_prefix, tool_property, id_asset_map, kmid->remove_item);
}
}
}
static void keymap_update_mesh_sculpt_brushes(wmKeyMap *keymap)
{
constexpr blender::StringRef asset_prefix =
"brushes/essentials_brushes-mesh_sculpt.blend/Brush/";
constexpr blender::StringRef tool_property = "sculpt_tool";
const auto tool_asset_map = []() {
blender::Map<blender::StringRef, blender::StringRef> map;
map.add_new("builtin_brush.Draw Sharp", "Draw Sharp");
map.add_new("builtin_brush.Clay", "Clay");
map.add_new("builtin_brush.Clay Strips", "Clay Strips");
map.add_new("builtin_brush.Clay Thumb", "Clay Thumb");
map.add_new("builtin_brush.Layer", "Layer");
map.add_new("builtin_brush.Inflate", "Inflate/Deflate");
map.add_new("builtin_brush.Blob", "Blob");
map.add_new("builtin_brush.Crease", "Crease Polish");
map.add_new("builtin_brush.Smooth", "Smooth");
map.add_new("builtin_brush.Flatten", "Flatten/Contrast");
map.add_new("builtin_brush.Fill", "Fill/Deepen");
map.add_new("builtin_brush.Scrape", "Scrape/Fill");
map.add_new("builtin_brush.Multi-plane Scrape", "Scrape Multiplane");
map.add_new("builtin_brush.Pinch", "Pinch/Magnify");
map.add_new("builtin_brush.Grab", "Grab");
map.add_new("builtin_brush.Elastic Deform", "Elastic Grab");
map.add_new("builtin_brush.Snake Hook", "Snake Hook");
map.add_new("builtin_brush.Thumb", "Thumb");
map.add_new("builtin_brush.Pose", "Pose");
map.add_new("builtin_brush.Nudge", "Nudge");
map.add_new("builtin_brush.Rotate", "Twist");
map.add_new("builtin_brush.Slide Relax", "Relax Slide");
map.add_new("builtin_brush.Boundary", "Boundary");
map.add_new("builtin_brush.Cloth", "Drag Cloth");
map.add_new("builtin_brush.Simplify", "Density");
map.add_new("builtin_brush.Multires Displacement Eraser", "Erase Multires Displacement");
map.add_new("builtin_brush.Multires Displacement Smear", "Smear Multires Displacement");
map.add_new("builtin_brush.Smear", "Smear");
return map;
}();
const auto tool_tool_map = []() {
blender::Map<blender::StringRef, blender::StringRefNull> map;
map.add_new("builtin_brush.Draw", "builtin.brush");
map.add_new("builtin_brush.Paint", "builtin_brush.paint");
map.add_new("builtin_brush.Mask", "builtin_brush.mask");
map.add_new("builtin_brush.Draw Face Sets", "builtin_brush.draw_face_sets");
return map;
}();
const auto id_asset_map = []() {
blender::Map<int, blender::StringRef> map;
map.add_new(SCULPT_BRUSH_TYPE_DRAW, "Draw");
map.add_new(SCULPT_BRUSH_TYPE_DRAW_SHARP, "Draw Sharp");
map.add_new(SCULPT_BRUSH_TYPE_CLAY, "Clay");
map.add_new(SCULPT_BRUSH_TYPE_CLAY_STRIPS, "Clay Strips");
map.add_new(SCULPT_BRUSH_TYPE_CLAY_THUMB, "Clay Thumb");
map.add_new(SCULPT_BRUSH_TYPE_LAYER, "Layer");
map.add_new(SCULPT_BRUSH_TYPE_INFLATE, "Inflate/Deflate");
map.add_new(SCULPT_BRUSH_TYPE_BLOB, "Blob");
map.add_new(SCULPT_BRUSH_TYPE_CREASE, "Crease Polish");
map.add_new(SCULPT_BRUSH_TYPE_SMOOTH, "Smooth");
map.add_new(SCULPT_BRUSH_TYPE_FLATTEN, "Flatten/Contrast");
map.add_new(SCULPT_BRUSH_TYPE_FILL, "Fill/Deepen");
map.add_new(SCULPT_BRUSH_TYPE_SCRAPE, "Scrape/Fill");
map.add_new(SCULPT_BRUSH_TYPE_MULTIPLANE_SCRAPE, "Scrape Multiplane");
map.add_new(SCULPT_BRUSH_TYPE_PINCH, "Pinch/Magnify");
map.add_new(SCULPT_BRUSH_TYPE_GRAB, "Grab");
map.add_new(SCULPT_BRUSH_TYPE_ELASTIC_DEFORM, "Elastic Grab");
map.add_new(SCULPT_BRUSH_TYPE_SNAKE_HOOK, "Snake Hook");
map.add_new(SCULPT_BRUSH_TYPE_THUMB, "Thumb");
map.add_new(SCULPT_BRUSH_TYPE_POSE, "Pose");
map.add_new(SCULPT_BRUSH_TYPE_NUDGE, "Nudge");
map.add_new(SCULPT_BRUSH_TYPE_ROTATE, "Twist");
map.add_new(SCULPT_BRUSH_TYPE_SLIDE_RELAX, "Relax Slide");
map.add_new(SCULPT_BRUSH_TYPE_BOUNDARY, "Boundary");
map.add_new(SCULPT_BRUSH_TYPE_CLOTH, "Drag Cloth");
map.add_new(SCULPT_BRUSH_TYPE_SIMPLIFY, "Density");
map.add_new(SCULPT_BRUSH_TYPE_MASK, "Mask");
map.add_new(SCULPT_BRUSH_TYPE_DRAW_FACE_SETS, "Face Set Paint");
map.add_new(SCULPT_BRUSH_TYPE_DISPLACEMENT_ERASER, "Erase Multires Displacement");
map.add_new(SCULPT_BRUSH_TYPE_DISPLACEMENT_SMEAR, "Smear Multires Displacement");
map.add_new(SCULPT_BRUSH_TYPE_PAINT, "Paint Hard");
map.add_new(SCULPT_BRUSH_TYPE_SMEAR, "Smear");
return map;
}();
keymap_update_brushes(
keymap, asset_prefix, tool_property, tool_tool_map, tool_asset_map, id_asset_map);
}
static void keymap_update_mesh_vertex_paint_brushes(wmKeyMap *keymap)
{
constexpr blender::StringRef asset_prefix =
"brushes/essentials_brushes-mesh_vertex.blend/Brush/";
constexpr blender::StringRef tool_property = "vertex_tool";
const auto tool_tool_map = []() {
blender::Map<blender::StringRef, blender::StringRefNull> map;
map.add_new("builtin_brush.Draw", "builtin.brush");
map.add_new("builtin_brush.Blur", "builtin_brush.blur");
map.add_new("builtin_brush.Average", "builtin_brush.average");
map.add_new("builtin_brush.Smear", "builtin_brush.smear");
return map;
}();
const auto id_asset_map = []() {
blender::Map<int, blender::StringRef> map;
map.add_new(VPAINT_BRUSH_TYPE_DRAW, "Paint Hard");
map.add_new(VPAINT_BRUSH_TYPE_BLUR, "Blur");
map.add_new(VPAINT_BRUSH_TYPE_AVERAGE, "Average");
map.add_new(VPAINT_BRUSH_TYPE_SMEAR, "Smear");
return map;
}();
keymap_update_brushes(keymap, asset_prefix, tool_property, tool_tool_map, {}, id_asset_map);
}
static void keymap_update_mesh_weight_paint_brushes(wmKeyMap *keymap)
{
constexpr blender::StringRef asset_prefix =
"brushes/essentials_brushes-mesh_weight.blend/Brush/";
constexpr blender::StringRef tool_property = "weight_tool";
const auto tool_tool_map = []() {
blender::Map<blender::StringRef, blender::StringRefNull> map;
map.add_new("builtin_brush.Draw", "builtin.brush");
map.add_new("builtin_brush.Blur", "builtin_brush.blur");
map.add_new("builtin_brush.Average", "builtin_brush.average");
map.add_new("builtin_brush.Smear", "builtin_brush.smear");
return map;
}();
const auto asset_id_map = []() {
blender::Map<int, blender::StringRef> map;
map.add_new(WPAINT_BRUSH_TYPE_DRAW, "Paint");
map.add_new(WPAINT_BRUSH_TYPE_BLUR, "Blur");
map.add_new(WPAINT_BRUSH_TYPE_AVERAGE, "Average");
map.add_new(WPAINT_BRUSH_TYPE_SMEAR, "Smear");
return map;
}();
keymap_update_brushes(keymap, asset_prefix, tool_property, tool_tool_map, {}, asset_id_map);
}
static void keymap_update_mesh_texture_paint_brushes(wmKeyMap *keymap)
{
constexpr blender::StringRef asset_prefix =
"brushes/essentials_brushes-mesh_texture.blend/Brush/";
constexpr blender::StringRef tool_property = "image_tool";
const auto tool_tool_map = []() {
blender::Map<blender::StringRef, blender::StringRefNull> map;
map.add_new("builtin_brush.Draw", "builtin.brush");
map.add_new("builtin_brush.Soften", "builtin_brush.soften");
map.add_new("builtin_brush.Smear", "builtin_brush.smear");
map.add_new("builtin_brush.Clone", "builtin_brush.clone");
map.add_new("builtin_brush.Fill", "builtin_brush.fill");
map.add_new("builtin_brush.Mask", "builtin_brush.mask");
return map;
}();
const auto id_asset_map = []() {
blender::Map<int, blender::StringRef> map;
map.add_new(IMAGE_PAINT_BRUSH_TYPE_DRAW, "Paint Hard");
map.add_new(IMAGE_PAINT_BRUSH_TYPE_SOFTEN, "Blur");
map.add_new(IMAGE_PAINT_BRUSH_TYPE_SMEAR, "Smear");
map.add_new(IMAGE_PAINT_BRUSH_TYPE_CLONE, "Clone");
map.add_new(IMAGE_PAINT_BRUSH_TYPE_FILL, "Fill");
map.add_new(IMAGE_PAINT_BRUSH_TYPE_MASK, "Mask");
return map;
}();
keymap_update_brushes(keymap, asset_prefix, tool_property, tool_tool_map, {}, id_asset_map);
}
void blo_do_versions_userdef(UserDef *userdef)
{
/* #UserDef & #Main happen to have the same struct member. */
#define USER_VERSION_ATLEAST(ver, subver) MAIN_VERSION_FILE_ATLEAST(userdef, ver, subver)
/* the UserDef struct is not corrected with do_versions() .... ugh! */
if (userdef->menuthreshold1 == 0) {
userdef->menuthreshold1 = 5;
userdef->menuthreshold2 = 2;
}
if (userdef->mixbufsize == 0) {
userdef->mixbufsize = 2048;
}
if (userdef->autokey_mode == 0) {
/* 'add/replace' but not on */
userdef->autokey_mode = 2;
}
if (userdef->savetime <= 0) {
userdef->savetime = 1;
// XXX error(STRINGIFY(BLENDER_STARTUP_FILE)" is buggy, please consider removing it.\n");
}
if (userdef->gizmo_size == 0) {
userdef->gizmo_size = 75;
userdef->gizmo_flag |= USER_GIZMO_DRAW;
}
if (userdef->pad_rot_angle == 0.0f) {
userdef->pad_rot_angle = 15.0f;
}
/* If the userdef was created on a different platform, it may have an
* unsupported GPU backend selected. If so, pick a supported default. */
#ifdef __APPLE__
if (userdef->gpu_backend == GPU_BACKEND_OPENGL || userdef->gpu_backend == GPU_BACKEND_VULKAN) {
userdef->gpu_backend = GPU_BACKEND_METAL;
}
#else
if (userdef->gpu_backend == GPU_BACKEND_METAL) {
userdef->gpu_backend = GPU_BACKEND_OPENGL;
}
#endif
/* graph editor - unselected F-Curve visibility */
if (userdef->fcu_inactive_alpha == 0) {
userdef->fcu_inactive_alpha = 0.25f;
}
if (!USER_VERSION_ATLEAST(192, 0)) {
STRNCPY(userdef->sounddir, "/");
}
/* patch to set Dupli Armature */
if (!USER_VERSION_ATLEAST(220, 0)) {
userdef->dupflag |= USER_DUP_ARM;
}
/* added seam, normal color, undo */
if (!USER_VERSION_ATLEAST(235, 0)) {
userdef->uiflag |= USER_GLOBALUNDO;
if (userdef->undosteps == 0) {
userdef->undosteps = 32;
}
}
if (!USER_VERSION_ATLEAST(236, 0)) {
/* illegal combo... */
if (userdef->flag & USER_LMOUSESELECT) {
userdef->flag &= ~USER_TWOBUTTONMOUSE;
}
}
if (!USER_VERSION_ATLEAST(240, 0)) {
userdef->uiflag |= USER_PLAINMENUS;
}
if (!USER_VERSION_ATLEAST(242, 0)) {
/* set defaults for 3D View rotating axis indicator */
/* since size can't be set to 0, this indicates it's not saved in startup.blend */
if (userdef->rvisize == 0) {
userdef->rvisize = 15;
userdef->rvibright = 8;
userdef->uiflag |= USER_SHOW_GIZMO_NAVIGATE;
}
}
if (!USER_VERSION_ATLEAST(244, 0)) {
/* set default number of recently-used files (if not set) */
if (userdef->recent_files == 0) {
userdef->recent_files = 10;
}
}
if (!USER_VERSION_ATLEAST(245, 3)) {
if (userdef->coba_weight.tot == 0) {
BKE_colorband_init(&userdef->coba_weight, true);
}
}
if (!USER_VERSION_ATLEAST(245, 3)) {
userdef->flag |= USER_ADD_VIEWALIGNED | USER_ADD_EDITMODE;
}
if (!USER_VERSION_ATLEAST(250, 0)) {
/* adjust grease-pencil distances */
userdef->gp_manhattandist = 1;
userdef->gp_euclideandist = 2;
/* adjust default interpolation for new IPO-curves */
userdef->ipo_new = BEZT_IPO_BEZ;
}
if (!USER_VERSION_ATLEAST(250, 3)) {
/* new audio system */
if (userdef->audiochannels == 0) {
userdef->audiochannels = 2;
}
if (userdef->audioformat == 0) {
userdef->audioformat = 0x24;
}
if (userdef->audiorate == 0) {
userdef->audiorate = 48000;
}
}
if (!USER_VERSION_ATLEAST(250, 8)) {
LISTBASE_FOREACH (wmKeyMap *, km, &userdef->user_keymaps) {
if (STREQ(km->idname, "Armature_Sketch")) {
STRNCPY(km->idname, "Armature Sketch");
}
else if (STREQ(km->idname, "View3D")) {
STRNCPY(km->idname, "3D View");
}
else if (STREQ(km->idname, "View3D Generic")) {
STRNCPY(km->idname, "3D View Generic");
}
else if (STREQ(km->idname, "EditMesh")) {
STRNCPY(km->idname, "Mesh");
}
else if (STREQ(km->idname, "UVEdit")) {
STRNCPY(km->idname, "UV Editor");
}
else if (STREQ(km->idname, "Animation_Channels")) {
STRNCPY(km->idname, "Animation Channels");
}
else if (STREQ(km->idname, "GraphEdit Keys")) {
STRNCPY(km->idname, "Graph Editor");
}
else if (STREQ(km->idname, "GraphEdit Generic")) {
STRNCPY(km->idname, "Graph Editor Generic");
}
else if (STREQ(km->idname, "Action_Keys")) {
STRNCPY(km->idname, "Dopesheet");
}
else if (STREQ(km->idname, "NLA Data")) {
STRNCPY(km->idname, "NLA Editor");
}
else if (STREQ(km->idname, "Node Generic")) {
STRNCPY(km->idname, "Node Editor");
}
else if (STREQ(km->idname, "Logic Generic")) {
STRNCPY(km->idname, "Logic Editor");
}
else if (STREQ(km->idname, "File")) {
STRNCPY(km->idname, "File Browser");
}
else if (STREQ(km->idname, "FileMain")) {
STRNCPY(km->idname, "File Browser Main");
}
else if (STREQ(km->idname, "FileButtons")) {
STRNCPY(km->idname, "File Browser Buttons");
}
else if (STREQ(km->idname, "Buttons Generic")) {
STRNCPY(km->idname, "Property Editor");
}
}
}
if (!USER_VERSION_ATLEAST(252, 3)) {
if (userdef->flag & USER_LMOUSESELECT) {
userdef->flag &= ~USER_TWOBUTTONMOUSE;
}
}
if (!USER_VERSION_ATLEAST(252, 4)) {
/* default new handle type is auto handles */
userdef->keyhandles_new = HD_AUTO;
}
if (!USER_VERSION_ATLEAST(257, 0)) {
/* Clear #AUTOKEY_FLAG_ONLYKEYINGSET flag from user-preferences,
* so that it doesn't linger around from old configurations like a ghost. */
userdef->keying_flag &= ~AUTOKEY_FLAG_ONLYKEYINGSET;
}
if (!USER_VERSION_ATLEAST(260, 3)) {
/* if new keyframes handle default is stuff "auto", make it "auto-clamped" instead
* was changed in 260 as part of GSoC11, but version patch was wrong
*/
if (userdef->keyhandles_new == HD_AUTO) {
userdef->keyhandles_new = HD_AUTO_ANIM;
}
}
if (!USER_VERSION_ATLEAST(267, 0)) {
/* GL Texture Garbage Collection */
if (userdef->textimeout == 0) {
userdef->texcollectrate = 60;
userdef->textimeout = 120;
}
if (userdef->memcachelimit <= 0) {
userdef->memcachelimit = 32;
}
if (userdef->dbl_click_time == 0) {
userdef->dbl_click_time = 350;
}
if (userdef->v2d_min_gridsize == 0) {
userdef->v2d_min_gridsize = 35;
}
if (userdef->widget_unit == 0) {
userdef->widget_unit = 20;
}
if (userdef->anisotropic_filter <= 0) {
userdef->anisotropic_filter = 1;
}
if (userdef->ndof_translation_sensitivity == 0.0f) {
userdef->ndof_translation_sensitivity = 1.0f;
userdef->ndof_flag = (NDOF_LOCK_HORIZON | NDOF_SHOULD_PAN | NDOF_SHOULD_ZOOM |
NDOF_SHOULD_ROTATE);
}
if (userdef->ndof_rotation_sensitivity == 0.0f) {
userdef->ndof_rotation_sensitivity = userdef->ndof_translation_sensitivity;
if (!(userdef->flag & USER_TRACKBALL)) {
userdef->ndof_flag |= NDOF_TURNTABLE;
}
}
}
if (!USER_VERSION_ATLEAST(269, 4)) {
userdef->walk_navigation.mouse_speed = 1.0f;
userdef->walk_navigation.walk_speed = 2.5f; /* m/s */
userdef->walk_navigation.walk_speed_factor = 5.0f;
userdef->walk_navigation.view_height = 1.6f; /* m */
userdef->walk_navigation.jump_height = 0.4f; /* m */
userdef->walk_navigation.teleport_time = 0.2f; /* s */
}
if (!USER_VERSION_ATLEAST(271, 5)) {
userdef->pie_menu_radius = 100;
userdef->pie_menu_threshold = 12;
userdef->pie_animation_timeout = 6;
}
if (!USER_VERSION_ATLEAST(275, 2)) {
userdef->ndof_deadzone = 0.0;
}
if (!USER_VERSION_ATLEAST(275, 4)) {
userdef->node_margin = 80;
}
if (!USER_VERSION_ATLEAST(278, 6)) {
/* Clear preference flags for re-use. */
userdef->flag &= ~(USER_FLAG_NUMINPUT_ADVANCED | (1 << 2) | USER_MENU_CLOSE_LEAVE |
USER_FLAG_UNUSED_6 | USER_FLAG_UNUSED_7 | USER_INTERNET_ALLOW |
USER_DEVELOPER_UI);
userdef->uiflag &= ~USER_HEADER_BOTTOM;
userdef->transopts &= ~(USER_TR_UNUSED_3 | USER_TR_UNUSED_4 | USER_TR_UNUSED_6 |
USER_TR_UNUSED_7);
userdef->uiflag |= USER_LOCK_CURSOR_ADJUST;
}
if (!USER_VERSION_ATLEAST(280, 20)) {
userdef->gpu_viewport_quality = 0.6f;
/* Reset theme, old themes will not be compatible with minor version updates from now on. */
LISTBASE_FOREACH (bTheme *, btheme, &userdef->themes) {
MEMCPY_STRUCT_AFTER(btheme, &U_theme_default, name);
}
/* Annotations - new layer color
* Replace anything that used to be set if it looks like was left
* on the old default (i.e. black), which most users used
*/
if ((userdef->gpencil_new_layer_col[3] < 0.1f) || (userdef->gpencil_new_layer_col[0] < 0.1f)) {
/* - New color matches the annotation pencil icon
* - Non-full alpha looks better!
*/
ARRAY_SET_ITEMS(userdef->gpencil_new_layer_col, 0.38f, 0.61f, 0.78f, 0.9f);
}
}
if (!USER_VERSION_ATLEAST(280, 31)) {
/* Remove select/action mouse from user defined keymaps. */
LISTBASE_FOREACH (wmKeyMap *, keymap, &userdef->user_keymaps) {
LISTBASE_FOREACH (wmKeyMapDiffItem *, kmdi, &keymap->diff_items) {
if (kmdi->remove_item) {
do_version_select_mouse(userdef, kmdi->remove_item);
}
if (kmdi->add_item) {
do_version_select_mouse(userdef, kmdi->add_item);
}
}
LISTBASE_FOREACH (wmKeyMapItem *, kmi, &keymap->items) {
do_version_select_mouse(userdef, kmi);
}
}
}
if (!USER_VERSION_ATLEAST(280, 33)) {
/* Enable GLTF addon by default. */
BKE_addon_ensure(&userdef->addons, "io_scene_gltf2");
userdef->pressure_threshold_max = 1.0f;
}
if (!USER_VERSION_ATLEAST(280, 35)) {
/* Preserve RMB select setting after moving to Python and changing default value. */
if (USER_VERSION_ATLEAST(280, 32) || !(userdef->flag & USER_LMOUSESELECT)) {
BKE_keyconfig_pref_set_select_mouse(userdef, 1, false);
}
userdef->flag &= ~USER_LMOUSESELECT;
}
if (!USER_VERSION_ATLEAST(280, 38)) {
copy_v4_fl4(userdef->light_param[0].vec, -0.580952, 0.228571, 0.781185, 0.0);
copy_v4_fl4(userdef->light_param[0].col, 0.900000, 0.900000, 0.900000, 1.000000);
copy_v4_fl4(userdef->light_param[0].spec, 0.318547, 0.318547, 0.318547, 1.000000);
userdef->light_param[0].flag = 1;
userdef->light_param[0].smooth = 0.1;
copy_v4_fl4(userdef->light_param[1].vec, 0.788218, 0.593482, -0.162765, 0.0);
copy_v4_fl4(userdef->light_param[1].col, 0.267115, 0.269928, 0.358840, 1.000000);
copy_v4_fl4(userdef->light_param[1].spec, 0.090838, 0.090838, 0.090838, 1.000000);
userdef->light_param[1].flag = 1;
userdef->light_param[1].smooth = 0.25;
copy_v4_fl4(userdef->light_param[2].vec, 0.696472, -0.696472, -0.172785, 0.0);
copy_v4_fl4(userdef->light_param[2].col, 0.293216, 0.304662, 0.401968, 1.000000);
copy_v4_fl4(userdef->light_param[2].spec, 0.069399, 0.020331, 0.020331, 1.000000);
userdef->light_param[2].flag = 1;
userdef->light_param[2].smooth = 0.4;
copy_v4_fl4(userdef->light_param[3].vec, 0.021053, -0.989474, 0.143173, 0.0);
copy_v4_fl4(userdef->light_param[3].col, 0.0, 0.0, 0.0, 1.0);
copy_v4_fl4(userdef->light_param[3].spec, 0.072234, 0.082253, 0.162642, 1.000000);
userdef->light_param[3].flag = 1;
userdef->light_param[3].smooth = 0.7;
copy_v3_fl3(userdef->light_ambient, 0.025000, 0.025000, 0.025000);
userdef->flag &= ~USER_FLAG_UNUSED_4;
userdef->uiflag &= ~(USER_HEADER_FROM_PREF | USER_REGISTER_ALL_USERS);
}
if (!USER_VERSION_ATLEAST(280, 41)) {
if (userdef->pie_tap_timeout == 0) {
userdef->pie_tap_timeout = 20;
}
}
if (!USER_VERSION_ATLEAST(280, 44)) {
userdef->uiflag &= ~USER_NO_MULTITOUCH_GESTURES;
userdef->uiflag2 &= ~USER_ALWAYS_SHOW_NUMBER_ARROWS;
userdef->gp_settings &= ~GP_PAINT_UNUSED_0;
}
if (!USER_VERSION_ATLEAST(280, 50)) {
/* 3ds is no longer enabled by default and not ported yet. */
BKE_addon_remove_safe(&userdef->addons, "io_scene_3ds");
}
if (!USER_VERSION_ATLEAST(280, 51)) {
userdef->move_threshold = 2;
}
if (!USER_VERSION_ATLEAST(280, 58)) {
if (userdef->image_draw_method != IMAGE_DRAW_METHOD_GLSL) {
userdef->image_draw_method = IMAGE_DRAW_METHOD_AUTO;
}
}
/* Patch to set dupli light-probes and grease-pencil. */
if (!USER_VERSION_ATLEAST(280, 58)) {
userdef->dupflag |= USER_DUP_LIGHTPROBE;
userdef->dupflag |= USER_DUP_GPENCIL;
}
if (!USER_VERSION_ATLEAST(280, 60)) {
const float GPU_VIEWPORT_QUALITY_FXAA = 0.10f;
const float GPU_VIEWPORT_QUALITY_TAA8 = 0.25f;
const float GPU_VIEWPORT_QUALITY_TAA16 = 0.6f;
const float GPU_VIEWPORT_QUALITY_TAA32 = 0.8f;
if (userdef->gpu_viewport_quality <= GPU_VIEWPORT_QUALITY_FXAA) {
userdef->viewport_aa = SCE_DISPLAY_AA_OFF;
}
else if (userdef->gpu_viewport_quality <= GPU_VIEWPORT_QUALITY_TAA8) {
userdef->viewport_aa = SCE_DISPLAY_AA_FXAA;
}
else if (userdef->gpu_viewport_quality <= GPU_VIEWPORT_QUALITY_TAA16) {
userdef->viewport_aa = SCE_DISPLAY_AA_SAMPLES_8;
}
else if (userdef->gpu_viewport_quality <= GPU_VIEWPORT_QUALITY_TAA32) {
userdef->viewport_aa = SCE_DISPLAY_AA_SAMPLES_16;
}
else {
userdef->viewport_aa = SCE_DISPLAY_AA_SAMPLES_32;
}
}
if (!USER_VERSION_ATLEAST(280, 62)) {
if (userdef->vbotimeout == 0) {
userdef->vbocollectrate = 60;
userdef->vbotimeout = 120;
}
if (userdef->lookdev_sphere_size == 0) {
userdef->lookdev_sphere_size = 150;
}
userdef->pref_flag |= USER_PREF_FLAG_SAVE;
}
if (!USER_VERSION_ATLEAST(280, 73)) {
userdef->drag_threshold = 30;
userdef->drag_threshold_mouse = 3;
userdef->drag_threshold_tablet = 10;
}
if (!USER_VERSION_ATLEAST(281, 9)) {
/* X3D is no longer enabled by default. */
BKE_addon_remove_safe(&userdef->addons, "io_scene_x3d");
}
if (!USER_VERSION_ATLEAST(281, 12)) {
userdef->render_display_type = USER_RENDER_DISPLAY_WINDOW;
userdef->filebrowser_display_type = USER_TEMP_SPACE_DISPLAY_WINDOW;
}
if (!USER_VERSION_ATLEAST(281, 13)) {
userdef->auto_smoothing_new = FCURVE_SMOOTH_CONT_ACCEL;
if (userdef->file_space_data.display_type == FILE_DEFAULTDISPLAY) {
memcpy(
&userdef->file_space_data, &U_default.file_space_data, sizeof(userdef->file_space_data));
}
}
if (!USER_VERSION_ATLEAST(281, 16)) {
wmKeyConfigFilterItemParams params{};
params.check_item = true;
params.check_diff_item_add = true;
BKE_keyconfig_pref_filter_items(
userdef, &params, keymap_item_has_invalid_wm_context_data_path, nullptr);
}
if (!USER_VERSION_ATLEAST(282, 1)) {
userdef->file_space_data.filter_id = U_default.file_space_data.filter_id;
}
if (!USER_VERSION_ATLEAST(282, 4)) {
if (userdef->view_rotate_sensitivity_turntable == 0.0f) {
userdef->view_rotate_sensitivity_turntable = DEG2RADF(0.4f);
userdef->view_rotate_sensitivity_trackball = 1.0f;
}
if (userdef->scrollback == 0) {
userdef->scrollback = U_default.scrollback;
}
/* Enable Overlay Engine Smooth Wire by default */
userdef->gpu_flag |= USER_GPU_FLAG_OVERLAY_SMOOTH_WIRE;
}
if (!USER_VERSION_ATLEAST(283, 13)) {
/* If Translations is off then language should default to English. */
if ((userdef->transopts & USER_DOTRANSLATE_DEPRECATED) == 0) {
userdef->language = ULANGUAGE_ENGLISH;
}
/* Clear this deprecated flag. */
userdef->transopts &= ~USER_DOTRANSLATE_DEPRECATED;
}
if (!USER_VERSION_ATLEAST(290, 7)) {
userdef->statusbar_flag = STATUSBAR_SHOW_VERSION;
}
if (!USER_VERSION_ATLEAST(291, 1)) {
if (userdef->collection_instance_empty_size == 0) {
userdef->collection_instance_empty_size = 1.0f;
}
}
if (!USER_VERSION_ATLEAST(292, 3)) {
if (userdef->pixelsize == 0.0f) {
userdef->pixelsize = 1.0f;
}
/* Clear old userdef flag for "Camera Parent Lock". */
userdef->uiflag &= ~USER_AREA_CORNER_HANDLE;
}
if (!USER_VERSION_ATLEAST(292, 9)) {
if (BLI_listbase_is_empty(&userdef->asset_libraries)) {
BKE_preferences_asset_library_default_add(userdef);
}
}
if (!USER_VERSION_ATLEAST(293, 1)) {
/* This rename was made after 2.93.0, harmless to run when it's not needed. */
const char *replace_table[][2] = {
{"blender", "Blender"},
{"blender_27x", "Blender_27x"},
{"industry_compatible", "Industry_Compatible"},
};
const int replace_table_len = ARRAY_SIZE(replace_table);
BLI_string_replace_table_exact(
userdef->keyconfigstr, sizeof(userdef->keyconfigstr), replace_table, replace_table_len);
LISTBASE_FOREACH (wmKeyConfigPref *, kpt, &userdef->user_keyconfig_prefs) {
BLI_string_replace_table_exact(
kpt->idname, sizeof(kpt->idname), replace_table, replace_table_len);
}
}
if (!USER_VERSION_ATLEAST(293, 12)) {
if (userdef->gizmo_size_navigate_v3d == 0) {
userdef->gizmo_size_navigate_v3d = 80;
}
userdef->sequencer_proxy_setup = USER_SEQ_PROXY_SETUP_AUTOMATIC;
}
if (!USER_VERSION_ATLEAST(293, 13)) {
BKE_addon_ensure(&userdef->addons, "pose_library");
}
if (!USER_VERSION_ATLEAST(300, 21)) {
/* Deprecated userdef->flag USER_SAVE_PREVIEWS */
userdef->file_preview_type = (userdef->flag & USER_FLAG_UNUSED_5) ? USER_FILE_PREVIEW_AUTO :
USER_FILE_PREVIEW_NONE;
/* Clear for reuse. */
userdef->flag &= ~USER_FLAG_UNUSED_5;
}
if (!USER_VERSION_ATLEAST(300, 38)) {
/* Patch to set Dupli Lattice/Camera/Speaker. */
userdef->dupflag |= USER_DUP_LATTICE;
userdef->dupflag |= USER_DUP_CAMERA;
userdef->dupflag |= USER_DUP_SPEAKER;
}
if (!USER_VERSION_ATLEAST(300, 40)) {
/* Rename the default asset library from "Default" to "User Library". This isn't bullet proof
* since it doesn't handle translations and ignores user changes. But this was an alpha build
* (experimental) feature and the name is just for display in the UI anyway. So it doesn't have
* to work perfectly at all. */
LISTBASE_FOREACH (bUserAssetLibrary *, asset_library, &userdef->asset_libraries) {
/* Ignores translations, since that would depend on the current preferences (global `U`). */
if (STREQ(asset_library->name, "Default")) {
BKE_preferences_asset_library_name_set(
userdef, asset_library, BKE_PREFS_ASSET_LIBRARY_DEFAULT_NAME);
}
}
}
if (!USER_VERSION_ATLEAST(300, 40)) {
LISTBASE_FOREACH (uiStyle *, style, &userdef->uistyles) {
const int default_title_points = 11; /* UI_DEFAULT_TITLE_POINTS */
style->paneltitle.points = default_title_points;
style->grouplabel.points = default_title_points;
}
}
if (!USER_VERSION_ATLEAST(300, 43)) {
userdef->ndof_flag |= NDOF_CAMERA_PAN_ZOOM;
}
if (!USER_VERSION_ATLEAST(302, 5)) {
const wmKeyConfigFilterItemParams params = WM_KEY_CONFIG_FILTER_ITEM_ALL;
BKE_keyconfig_pref_filter_items(userdef, &params, keymap_item_update_tweak_event, nullptr);
}
if (!USER_VERSION_ATLEAST(302, 11)) {
userdef->dupflag |= USER_DUP_CURVES | USER_DUP_POINTCLOUD;
}
/* Set GPU backend to OpenGL. */
if (!USER_VERSION_ATLEAST(305, 5)) {
#ifdef __APPLE__
userdef->gpu_backend = GPU_BACKEND_METAL;
#else
userdef->gpu_backend = GPU_BACKEND_OPENGL;
#endif
}
if (!USER_VERSION_ATLEAST(305, 10)) {
LISTBASE_FOREACH (bUserAssetLibrary *, asset_library, &userdef->asset_libraries) {
asset_library->import_method = ASSET_IMPORT_APPEND_REUSE;
}
}
if (!USER_VERSION_ATLEAST(306, 2)) {
userdef->animation_flag |= USER_ANIM_HIGH_QUALITY_DRAWING;
}
if (!USER_VERSION_ATLEAST(306, 4)) {
/* Increase the number of recently-used files if using the old default value. */
if (userdef->recent_files == 10) {
userdef->recent_files = 20;
}
}
if (!USER_VERSION_ATLEAST(306, 5)) {
if (userdef->pythondir_legacy[0]) {
bUserScriptDirectory *script_dir = MEM_callocN<bUserScriptDirectory>(
"Versioning user script path");
STRNCPY(script_dir->dir_path, userdef->pythondir_legacy);
STRNCPY_UTF8(script_dir->name, DATA_("Untitled"));
BLI_addhead(&userdef->script_directories, script_dir);
}
}
if (!USER_VERSION_ATLEAST(306, 6)) {
LISTBASE_FOREACH (bUserAssetLibrary *, asset_library, &userdef->asset_libraries) {
asset_library->flag |= ASSET_LIBRARY_RELATIVE_PATH;
}
}
if (!USER_VERSION_ATLEAST(400, 4)) {
/* obj and ply python addons were removed. */
BKE_addon_remove_safe(&userdef->addons, "io_mesh_ply");
BKE_addon_remove_safe(&userdef->addons, "io_scene_obj");
}
if (!USER_VERSION_ATLEAST(400, 15)) {
userdef->node_preview_res = 120;
}
if (!USER_VERSION_ATLEAST(400, 18)) {
userdef->playback_fps_samples = 8;
}
if (!USER_VERSION_ATLEAST(400, 19)) {
userdef->uiflag |= USER_NODE_AUTO_OFFSET;
}
if (!USER_VERSION_ATLEAST(400, 24)) {
/* Clear deprecated USER_MENUFIXEDORDER user flag for reuse. */
userdef->uiflag &= ~(1 << 23);
}
if (!USER_VERSION_ATLEAST(400, 26)) {
userdef->animation_flag |= USER_ANIM_SHOW_CHANNEL_GROUP_COLORS;
}
if (!USER_VERSION_ATLEAST(400, 32)) {
userdef->text_render |= USER_TEXT_RENDER_SUBPIXELAA;
}
if (!USER_VERSION_ATLEAST(401, 3)) {
LISTBASE_FOREACH (uiStyle *, style, &userdef->uistyles) {
style->paneltitle.character_weight = 400;
style->grouplabel.character_weight = 400;
style->widget.character_weight = 400;
}
}
if (!USER_VERSION_ATLEAST(401, 9)) {
userdef->key_insert_channels = (USER_ANIM_KEY_CHANNEL_LOCATION |
USER_ANIM_KEY_CHANNEL_ROTATION | USER_ANIM_KEY_CHANNEL_SCALE |
USER_ANIM_KEY_CHANNEL_CUSTOM_PROPERTIES);
}
if (!USER_VERSION_ATLEAST(401, 13)) {
if (userdef->keying_flag & AUTOKEY_FLAG_INSERTNEEDED) {
userdef->keying_flag |= MANUALKEY_FLAG_INSERTNEEDED;
}
userdef->keying_flag |= AUTOKEY_FLAG_INSERTNEEDED;
}
if (!USER_VERSION_ATLEAST(401, 21)) {
LISTBASE_FOREACH (wmKeyMap *, km, &userdef->user_keymaps) {
if (STREQ(km->idname, "NLA Channels")) {
STRNCPY(km->idname, "NLA Tracks");
}
}
}
if (!USER_VERSION_ATLEAST(402, 36)) {
/* Reset repositories. */
while (!BLI_listbase_is_empty(&userdef->extension_repos)) {
BKE_preferences_extension_repo_remove(
userdef, static_cast<bUserExtensionRepo *>(userdef->extension_repos.first));
}
BKE_preferences_extension_repo_add_default_remote(userdef);
BKE_preferences_extension_repo_add_default_user(userdef);
}
if (!USER_VERSION_ATLEAST(402, 42)) {
/* 80 was the old default. */
if (userdef->node_margin == 80) {
userdef->node_margin = 40;
}
}
if (!USER_VERSION_ATLEAST(402, 56)) {
BKE_preferences_extension_repo_add_default_system(userdef);
}
if (!USER_VERSION_ATLEAST(402, 58)) {
/* Remove add-ons which are no longer bundled by default
* and have no upgrade path to extensions in the UI. */
const char *addon_modules[] = {
"depsgraph_debug",
"io_coat3D",
"io_import_images_as_planes",
"io_mesh_stl",
"io_scene_x3d",
};
for (int i = 0; i < ARRAY_SIZE(addon_modules); i++) {
BKE_addon_remove_safe(&userdef->addons, addon_modules[i]);
}
}
if (!USER_VERSION_ATLEAST(402, 59)) {
userdef->network_timeout = 10;
userdef->network_connection_limit = 5;
}
if (!USER_VERSION_ATLEAST(402, 63)) {
userdef->statusbar_flag |= STATUSBAR_SHOW_EXTENSIONS_UPDATES;
}
if (!USER_VERSION_ATLEAST(402, 65)) {
/* Bone Selection Sets is no longer an add-on, but core functionality. */
BKE_addon_remove_safe(&userdef->addons, "bone_selection_sets");
}
if (!USER_VERSION_ATLEAST(403, 3)) {
BKE_preferences_asset_shelf_settings_ensure_catalog_path_enabled(
userdef, "VIEW3D_AST_brush_sculpt", "Brushes/Mesh Sculpt/Cloth");
BKE_preferences_asset_shelf_settings_ensure_catalog_path_enabled(
userdef, "VIEW3D_AST_brush_sculpt", "Brushes/Mesh Sculpt/General");
BKE_preferences_asset_shelf_settings_ensure_catalog_path_enabled(
userdef, "VIEW3D_AST_brush_sculpt", "Brushes/Mesh Sculpt/Paint");
}
if (!USER_VERSION_ATLEAST(403, 12)) {
LISTBASE_FOREACH (uiStyle *, style, &userdef->uistyles) {
style->tooltip.points = 11.0f; /* UI_DEFAULT_TOOLTIP_POINTS */
style->tooltip.character_weight = 400;
style->tooltip.shadow = 0;
style->tooltip.shady = -1;
style->tooltip.shadowalpha = 0.5f;
style->tooltip.shadowcolor = 0.0f;
}
}
if (!USER_VERSION_ATLEAST(403, 19)) {
userdef->sequencer_editor_flag |= USER_SEQ_ED_CONNECT_STRIPS_BY_DEFAULT;
}
if (!USER_VERSION_ATLEAST(404, 3)) {
userdef->uiflag &= ~USER_FILTER_BRUSHES_BY_TOOL;
BKE_preferences_asset_shelf_settings_ensure_catalog_path_enabled(
userdef, "VIEW3D_AST_brush_gpencil_paint", "Brushes/Grease Pencil Draw/Draw");
BKE_preferences_asset_shelf_settings_ensure_catalog_path_enabled(
userdef, "VIEW3D_AST_brush_gpencil_paint", "Brushes/Grease Pencil Draw/Erase");
BKE_preferences_asset_shelf_settings_ensure_catalog_path_enabled(
userdef, "VIEW3D_AST_brush_gpencil_paint", "Brushes/Grease Pencil Draw/Utilities");
BKE_preferences_asset_shelf_settings_ensure_catalog_path_enabled(
userdef, "VIEW3D_AST_brush_gpencil_sculpt", "Brushes/Grease Pencil Sculpt/Contrast");
BKE_preferences_asset_shelf_settings_ensure_catalog_path_enabled(
userdef, "VIEW3D_AST_brush_gpencil_sculpt", "Brushes/Grease Pencil Sculpt/Transform");
BKE_preferences_asset_shelf_settings_ensure_catalog_path_enabled(
userdef, "VIEW3D_AST_brush_gpencil_sculpt", "Brushes/Grease Pencil Sculpt/Utilities");
}
if (!USER_VERSION_ATLEAST(404, 9)) {
LISTBASE_FOREACH (wmKeyMap *, keymap, &userdef->user_keymaps) {
if (STREQ("Sculpt", keymap->idname)) {
keymap_update_mesh_sculpt_brushes(keymap);
}
else if (STREQ("Vertex Paint", keymap->idname)) {
keymap_update_mesh_vertex_paint_brushes(keymap);
}
else if (STREQ("Weight Paint", keymap->idname)) {
keymap_update_mesh_weight_paint_brushes(keymap);
}
else if (STREQ("Image Paint", keymap->idname)) {
keymap_update_mesh_texture_paint_brushes(keymap);
}
}
}
if (!USER_VERSION_ATLEAST(404, 28)) {
userdef->ndof_flag |= NDOF_SHOW_GUIDE_ORBIT_CENTER | NDOF_ORBIT_CENTER_AUTO;
}
if (userdef->border_width == 0) {
userdef->border_width = 2;
}
if (!USER_VERSION_ATLEAST(405, 10)) {
static const blender::Map<std::string, std::string> keymap_renames = {
{"SequencerCommon", "Video Sequence Editor"},
{"SequencerPreview", "Preview"},
{"Sequencer Tool: Cursor", "Preview Tool: Cursor"},
{"Sequencer Tool: Sample", "Preview Tool: Sample"},
{"Sequencer Tool: Move", "Preview Tool: Move"},
{"Sequencer Tool: Rotate", "Preview Tool: Rotate"},
{"Sequencer Tool: Scale", "Preview Tool: Scale"},
{"Sequencer Timeline Tool: Select Box", "Sequencer Tool: Select Box"},
{"Sequencer Timeline Tool: Select Box (fallback)",
"Sequencer Tool: Select Box (fallback)"},
{"Sequencer Preview Tool: Tweak", "Preview Tool: Tweak"},
{"Sequencer Preview Tool: Tweak (fallback)", "Preview Tool: Tweak (fallback)"},
{"Sequencer Preview Tool: Select Box", "Preview Tool: Select Box"},
{"Sequencer Preview Tool: Select Box (fallback)", "Preview Tool: Select Box (fallback)"},
};
LISTBASE_FOREACH (wmKeyMap *, keymap, &userdef->user_keymaps) {
std::string old_name(keymap->idname);
if (const std::string *new_name = keymap_renames.lookup_ptr(old_name)) {
STRNCPY(keymap->idname, new_name->c_str());
}
}
}
if (!USER_VERSION_ATLEAST(405, 11)) {
const wmKeyConfigFilterItemParams params = WM_KEY_CONFIG_FILTER_ITEM_ALL;
BKE_keyconfig_pref_filter_items(
userdef,
&params,
[](wmKeyMapItem *kmi, void * /*user_data*/) -> bool {
if (kmi->shift == KM_ANY && kmi->ctrl == KM_ANY && kmi->alt == KM_ANY &&
kmi->oskey == KM_ANY)
{
kmi->hyper = KM_ANY;
}
return false;
},
nullptr);
}
if (!USER_VERSION_ATLEAST(405, 50)) {
LISTBASE_FOREACH (wmKeyMap *, keymap, &userdef->user_keymaps) {
LISTBASE_FOREACH (wmKeyMapDiffItem *, kmdi, &keymap->diff_items) {
if (kmdi->remove_item) {
do_version_keyframe_jump(kmdi->remove_item);
}
if (kmdi->add_item) {
do_version_keyframe_jump(kmdi->add_item);
}
}
LISTBASE_FOREACH (wmKeyMapItem *, kmi, &keymap->items) {
do_version_keyframe_jump(kmi);
}
}
}
if (!USER_VERSION_ATLEAST(405, 86)) {
if (userdef->gpu_shader_workers > 0) {
userdef->shader_compilation_method = USER_SHADER_COMPILE_SUBPROCESS;
}
}
if (!USER_VERSION_ATLEAST(500, 11)) {
userdef->gpu_flag &= ~USER_GPU_FLAG_UNUSED_0;
}
if (!USER_VERSION_ATLEAST(500, 59)) {
userdef->preferences_display_type = USER_TEMP_SPACE_DISPLAY_WINDOW;
}
if (!USER_VERSION_ATLEAST(500, 76)) {
if (userdef->stored_bounds.file.xmin == userdef->stored_bounds.file.xmax) {
memcpy(&userdef->stored_bounds, &U_default.stored_bounds, sizeof(userdef->stored_bounds));
}
}
if (!USER_VERSION_ATLEAST(500, 90)) {
BKE_preferences_asset_shelf_settings_ensure_catalog_path_enabled(
userdef, "IMAGE_AST_brush_paint", "Brushes/Mesh Texture Paint/Basic");
BKE_preferences_asset_shelf_settings_ensure_catalog_path_enabled(
userdef, "IMAGE_AST_brush_paint", "Brushes/Mesh Texture Paint/Erase");
BKE_preferences_asset_shelf_settings_ensure_catalog_path_enabled(
userdef, "IMAGE_AST_brush_paint", "Brushes/Mesh Texture Paint/Pixel Art");
BKE_preferences_asset_shelf_settings_ensure_catalog_path_enabled(
userdef, "IMAGE_AST_brush_paint", "Brushes/Mesh Texture Paint/Utilities");
BKE_preferences_asset_shelf_settings_ensure_catalog_path_enabled(
userdef, "VIEW3D_AST_brush_texture_paint", "Brushes/Mesh Texture Paint/Basic");
BKE_preferences_asset_shelf_settings_ensure_catalog_path_enabled(
userdef, "VIEW3D_AST_brush_texture_paint", "Brushes/Mesh Texture Paint/Erase");
BKE_preferences_asset_shelf_settings_ensure_catalog_path_enabled(
userdef, "VIEW3D_AST_brush_texture_paint", "Brushes/Mesh Texture Paint/Pixel Art");
BKE_preferences_asset_shelf_settings_ensure_catalog_path_enabled(
userdef, "VIEW3D_AST_brush_texture_paint", "Brushes/Mesh Texture Paint/Utilities");
}
if (!USER_VERSION_ATLEAST(500, 94)) {
/* Force-reset file compression to ON, see #135735. */
userdef->flag |= USER_FILECOMPRESS;
}
if (!USER_VERSION_ATLEAST(500, 96)) {
/* Increase the number of recently-used files if using the old default value. */
if (userdef->recent_files == 20) {
userdef->recent_files = 200;
}
}
if (!USER_VERSION_ATLEAST(500, 99)) {
userdef->xr_navigation.vignette_intensity = 50.0f;
userdef->xr_navigation.turn_amount = DEG2RAD(30);
userdef->xr_navigation.turn_speed = DEG2RAD(60);
userdef->xr_navigation.flag = USER_XR_NAV_SNAP_TURN;
}
if (!USER_VERSION_ATLEAST(500, 101)) {
/* The Copy Global Transform add-on was moved into Blender itself, and thus
* is no longer an add-on. */
BKE_addon_remove_safe(&userdef->addons, "copy_global_transform");
}
/**
* Always bump subversion in BKE_blender_version.h when adding versioning
* code here, and wrap it inside a USER_VERSION_ATLEAST check.
*
* \note Keep this message at the bottom of the function.
*/
LISTBASE_FOREACH (bTheme *, btheme, &userdef->themes) {
do_versions_theme(userdef, btheme);
}
#undef USER_VERSION_ATLEAST
}
void BLO_sanitize_experimental_features_userpref_blend(UserDef *userdef)
{
/* User preference experimental settings are only supported in alpha builds.
* This prevents users corrupting data and relying on API that may change.
*
* If user preferences are saved this will be stored in disk as expected.
* This only starts to take effect when there is a release branch (on beta).
*
* At that time master already has its version bumped so its user preferences
* are not touched by these settings. */
#ifdef WITH_EXPERIMENTAL_FEATURES
if (BKE_blender_version_is_alpha()) {
return;
}
#endif
MEMSET_STRUCT_AFTER(&userdef->experimental, 0, SANITIZE_AFTER_HERE);
}
#undef USER_LMOUSESELECT