--- xfce4-settings-4.6.5/xfce4-settings-helper/accessibility.c.xkbtimeout 2010-05-21 11:05:32.000000000 -0600 +++ xfce4-settings-4.6.5/xfce4-settings-helper/accessibility.c 2011-03-29 11:18:56.000000000 -0600 @@ -192,6 +192,13 @@ /* we always change this, so add it to the mask */ SET_FLAG (mask, XkbControlsEnabledMask); + /* if setting sticky keys, we set expiration too */ + if (HAS_FLAG (mask, XkbStickyKeysMask) || + HAS_FLAG (mask, XkbSlowKeysMask) || + HAS_FLAG (mask, XkbBounceKeysMask) || + HAS_FLAG (mask, XkbMouseKeysMask)) + SET_FLAG (mask, XkbAccessXTimeoutMask); + /* add the mouse keys values mask if needed */ if (HAS_FLAG (mask, XkbMouseKeysMask)) SET_FLAG (mask, XkbMouseKeysAccelMask); @@ -205,6 +212,8 @@ if (xfconf_channel_get_bool (helper->channel, "/StickyKeys", FALSE)) { SET_FLAG (xkb->ctrls->enabled_ctrls, XkbStickyKeysMask); + UNSET_FLAG (xkb->ctrls->axt_ctrls_mask, XkbStickyKeysMask); + UNSET_FLAG (xkb->ctrls->axt_ctrls_values, XkbStickyKeysMask); if (xfconf_channel_get_bool (helper->channel, "/StickyKeys/LatchToLock", FALSE)) SET_FLAG (xkb->ctrls->ax_options, XkbAX_LatchToLockMask); @@ -219,6 +228,8 @@ else { UNSET_FLAG (xkb->ctrls->enabled_ctrls, XkbStickyKeysMask); + SET_FLAG (xkb->ctrls->axt_ctrls_mask, XkbStickyKeysMask); + UNSET_FLAG (xkb->ctrls->axt_ctrls_values, XkbStickyKeysMask); } } @@ -228,13 +239,17 @@ if (xfconf_channel_get_bool (helper->channel, "/SlowKeys", FALSE)) { SET_FLAG (xkb->ctrls->enabled_ctrls, XkbSlowKeysMask); - + UNSET_FLAG (xkb->ctrls->axt_ctrls_mask, XkbSlowKeysMask); + UNSET_FLAG (xkb->ctrls->axt_ctrls_values, XkbSlowKeysMask); + delay = xfconf_channel_get_int (helper->channel, "/SlowKeys/Delay", 100); xkb->ctrls->slow_keys_delay = CLAMP (delay, 1, G_MAXUSHORT); } else { UNSET_FLAG (xkb->ctrls->enabled_ctrls, XkbSlowKeysMask); + SET_FLAG (xkb->ctrls->axt_ctrls_mask, XkbSlowKeysMask); + UNSET_FLAG (xkb->ctrls->axt_ctrls_values, XkbSlowKeysMask); } } @@ -244,13 +259,17 @@ if (xfconf_channel_get_bool (helper->channel, "/BounceKeys", FALSE)) { SET_FLAG (xkb->ctrls->enabled_ctrls, XkbBounceKeysMask); - + UNSET_FLAG (xkb->ctrls->axt_ctrls_mask, XkbBounceKeysMask); + UNSET_FLAG (xkb->ctrls->axt_ctrls_values, XkbBounceKeysMask); + delay = xfconf_channel_get_int (helper->channel, "/BounceKeys/Delay", 100); xkb->ctrls->debounce_delay = CLAMP (delay, 1, G_MAXUSHORT); } else { UNSET_FLAG (xkb->ctrls->enabled_ctrls, XkbBounceKeysMask); + SET_FLAG (xkb->ctrls->axt_ctrls_mask, XkbBounceKeysMask); + UNSET_FLAG (xkb->ctrls->axt_ctrls_values, XkbBounceKeysMask); } } @@ -260,7 +279,9 @@ if (xfconf_channel_get_bool (helper->channel, "/MouseKeys", FALSE)) { SET_FLAG (xkb->ctrls->enabled_ctrls, XkbMouseKeysMask); - + UNSET_FLAG (xkb->ctrls->axt_ctrls_mask, XkbMouseKeysMask); + UNSET_FLAG (xkb->ctrls->axt_ctrls_values, XkbMouseKeysMask); + /* get values */ delay = xfconf_channel_get_int (helper->channel, "/MouseKeys/Delay", 160); interval = xfconf_channel_get_int (helper->channel, "/MouseKeys/Interval", 20); @@ -288,6 +309,8 @@ else { UNSET_FLAG (xkb->ctrls->enabled_ctrls, XkbMouseKeysMask); + SET_FLAG (xkb->ctrls->axt_ctrls_mask, XkbMouseKeysMask); + UNSET_FLAG (xkb->ctrls->axt_ctrls_values, XkbMouseKeysMask); UNSET_FLAG (mask, XkbMouseKeysAccelMask); } }