ELM_POLICY_EXIT, /**< defines elm_exit() behaviour. @see Elm_Policy_Exit.
* @since 1.8
*/
+ ELM_POLICY_THROTTLE, /**< defines how throttling should work @see Elm_Policy_Throttle
+ * @since 1.8
+ */
ELM_POLICY_LAST
} Elm_Policy; /**< Elementary policy identifiers/groups enumeration. @see elm_policy_set() */
* the main loop */
} Elm_Policy_Exit;
+/**
+ * Possible values for the #ELM_POLICY_THROTTLE policy.
+ * @since 1.8
+ */
+typedef enum
+{
+ ELM_POLICY_THROTTLE_CONFIG = 0, /**< do whatever elementary config is configured to do */
+ ELM_POLICY_THROTTLE_HIDDEN_ALWAYS, /**< always throttle when all windows are no longer visible */
+ ELM_POLICY_THROTTLE_NEVER /**< never throttle when windows are all hidden, regardless of config settings */
+} Elm_Policy_Throttle;
+
typedef enum
{
ELM_OBJECT_SELECT_MODE_DEFAULT = 0, /**< default select mode */
}
}
}
- if (_elm_config->auto_throttle)
+ if (((_elm_config->auto_throttle) &&
+ (elm_policy_get(ELM_POLICY_THROTTLE) != ELM_POLICY_THROTTLE_NEVER)) ||
+ (elm_policy_get(ELM_POLICY_THROTTLE) == ELM_POLICY_THROTTLE_HIDDEN_ALWAYS))
{
if (_elm_win_count == 0)
{