From d72304457677623368d4198011693ed1ffa9712d Mon Sep 17 00:00:00 2001 From: Diego Hernan Borghetti Date: Thu, 27 Mar 2008 12:55:48 -0300 Subject: [PATCH] Fix for bug #8746: the fake user button for datablocks was not a toggle button, while it should be. Author: Brecht Van Lommel SVN revision: 14255 Date: 2008-03-26 17:17:50 -0300 (Wed, 26 Mar 2008) --- source/blender/blenkernel/BKE_brush.h | 2 +- source/blender/blenkernel/intern/brush.c | 23 +++++++++++++---------- source/blender/src/buttons_editing.c | 2 +- source/blender/src/header_image.c | 2 +- source/blender/src/headerbuttons.c | 12 +++++------- 5 files changed, 21 insertions(+), 20 deletions(-) diff --git a/source/blender/blenkernel/BKE_brush.h b/source/blender/blenkernel/BKE_brush.h index e9fb81f..1f8b98b 100644 --- a/source/blender/blenkernel/BKE_brush.h +++ b/source/blender/blenkernel/BKE_brush.h @@ -48,7 +48,7 @@ void free_brush(struct Brush *brush); int brush_set_nr(struct Brush **current_brush, int nr); int brush_delete(struct Brush **current_brush); void brush_check_exists(struct Brush **brush); -void brush_toggle_fake_user(struct Brush *brush); +void brush_toggled_fake_user(struct Brush *brush); int brush_texture_set_nr(struct Brush *brush, int nr); int brush_texture_delete(struct Brush *brush); int brush_clone_image_set_nr(struct Brush *brush, int nr); diff --git a/source/blender/blenkernel/intern/brush.c b/source/blender/blenkernel/intern/brush.c index cf895e1..d1a4d42 100644 --- a/source/blender/blenkernel/intern/brush.c +++ b/source/blender/blenkernel/intern/brush.c @@ -73,7 +73,8 @@ Brush *add_brush(char *name) brush->clone.alpha= 0.5; /* enable fake user by default */ - brush_toggle_fake_user(brush); + brush->id.flag |= LIB_FAKEUSER; + brush_toggled_fake_user(brush); return brush; } @@ -95,8 +96,10 @@ Brush *copy_brush(Brush *brush) } /* enable fake user by default */ - if (!(brushn->id.flag & LIB_FAKEUSER)) - brush_toggle_fake_user(brushn); + if (!(brushn->id.flag & LIB_FAKEUSER)) { + brushn->id.flag |= LIB_FAKEUSER; + brush_toggled_fake_user(brushn); + } return brushn; } @@ -148,8 +151,10 @@ void make_local_brush(Brush *brush) new_id(0, (ID *)brush, 0); /* enable fake user by default */ - if (!(brush->id.flag & LIB_FAKEUSER)) - brush_toggle_fake_user(brush); + if (!(brush->id.flag & LIB_FAKEUSER)) { + brush->id.flag |= LIB_FAKEUSER; + brush_toggled_fake_user(brush); + } } else if(local && lib) { brushn= copy_brush(brush); @@ -203,16 +208,14 @@ int brush_delete(Brush **current_brush) return 0; } -void brush_toggle_fake_user(Brush *brush) +void brush_toggled_fake_user(Brush *brush) { ID *id= (ID*)brush; if(id) { if(id->flag & LIB_FAKEUSER) { - id->flag -= LIB_FAKEUSER; - id->us--; - } else { - id->flag |= LIB_FAKEUSER; id_us_plus(id); + } else { + id->us--; } } } diff --git a/source/blender/src/buttons_editing.c b/source/blender/src/buttons_editing.c index e1bd482..cf73e38 100644 --- a/source/blender/src/buttons_editing.c +++ b/source/blender/src/buttons_editing.c @@ -5122,7 +5122,7 @@ void do_fpaintbuts(unsigned short event) } break; case B_BRUSHKEEPDATA: - brush_toggle_fake_user(settings->imapaint.brush); + brush_toggled_fake_user(settings->imapaint.brush); allqueue(REDRAWBUTSEDIT, 0); allqueue(REDRAWIMAGE, 0); break; diff --git a/source/blender/src/header_image.c b/source/blender/src/header_image.c index c6b3fd2..9672adc 100644 --- a/source/blender/src/header_image.c +++ b/source/blender/src/header_image.c @@ -306,7 +306,7 @@ void do_image_buttons(unsigned short event) } break; case B_KEEPDATA: - brush_toggle_fake_user(settings->imapaint.brush); + brush_toggled_fake_user(settings->imapaint.brush); allqueue(REDRAWIMAGE, 0); allqueue(REDRAWBUTSEDIT, 0); break; diff --git a/source/blender/src/headerbuttons.c b/source/blender/src/headerbuttons.c index 7206142..b771be7 100644 --- a/source/blender/src/headerbuttons.c +++ b/source/blender/src/headerbuttons.c @@ -386,7 +386,7 @@ int std_libbuttons(uiBlock *block, short xco, short yco, } if(keepbut) { - uiDefBut(block, BUT, keepbut, "F", xco,yco,XIC,YIC, 0, 0, 0, 0, 0, "Saves this datablock even if it has no users"); + uiDefButBitS(block, TOG, LIB_FAKEUSER, keepbut, "F", xco,yco,XIC,YIC, &id->flag, 0, 0, 0, 0, "Saves this datablock even if it has no users"); xco+= XIC; } } @@ -1559,13 +1559,11 @@ void do_global_buttons(unsigned short event) id = ((SpaceNode *)curarea->spacedata.first)->id; } /* similar for other spacetypes ? */ if (id) { - if( id->flag & LIB_FAKEUSER) { - id->flag -= LIB_FAKEUSER; - id->us--; - } else { - id->flag |= LIB_FAKEUSER; + /* flag was already toggled, just need to update user count */ + if(id->flag & LIB_FAKEUSER) id->us++; - } + else + id->us--; } allqueue(REDRAWHEADERS, 0); -- 2.11.4.GIT