Make conf_display work again (primary output resolution st/ld).
SVN revision: 69547
This commit is contained in:
parent
b1d31afdb8
commit
95f33ad549
|
@ -50,7 +50,6 @@ static E_Config_DD *_e_config_mime_icon_edd = NULL;
|
|||
static E_Config_DD *_e_config_syscon_action_edd = NULL;
|
||||
static E_Config_DD *_e_config_env_var_edd = NULL;
|
||||
static E_Config_DD *_e_config_randr_size_edd = NULL;
|
||||
static E_Config_DD *_e_config_randr_size_mm_edd = NULL;
|
||||
static E_Config_DD *_e_config_randr_edid_hash_edd = NULL;
|
||||
static E_Config_DD *_e_config_randr_serialized_setup_edd = NULL;
|
||||
static E_Config_DD *_e_config_randr_serialized_setup_11_edd = NULL;
|
||||
|
@ -520,18 +519,6 @@ e_config_init(void)
|
|||
#define D _e_config_randr_size_edd
|
||||
E_CONFIG_VAL(D, T, width, INT);
|
||||
E_CONFIG_VAL(D, T, height, INT);
|
||||
E_CONFIG_VAL(D, T, width, INT);
|
||||
E_CONFIG_VAL(D, T, height, INT);
|
||||
|
||||
_e_config_randr_size_mm_edd = E_CONFIG_DD_NEW("Ecore_X_Randr_Screen_Size_MM", Ecore_X_Randr_Screen_Size_MM);
|
||||
#undef T
|
||||
#undef D
|
||||
#define T Ecore_X_Randr_Screen_Size_MM
|
||||
#define D _e_config_randr_size_mm_edd
|
||||
E_CONFIG_VAL(D, T, width, INT);
|
||||
E_CONFIG_VAL(D, T, height, INT);
|
||||
E_CONFIG_VAL(D, T, width_mm, INT);
|
||||
E_CONFIG_VAL(D, T, height_mm, INT);
|
||||
|
||||
_e_config_randr_edid_hash_edd = E_CONFIG_DD_NEW("E_Randr_Edid_Hash", E_Randr_Edid_Hash);
|
||||
#undef T
|
||||
|
@ -545,7 +532,10 @@ e_config_init(void)
|
|||
#undef D
|
||||
#define T E_Randr_Serialized_Setup_11
|
||||
#define D _e_config_randr_serialized_setup_11_edd
|
||||
E_CONFIG_SUB(D, T, size, _e_config_randr_size_edd);
|
||||
E_CONFIG_VAL(D, T, size.width, INT);
|
||||
E_CONFIG_VAL(D, T, size.height, INT);
|
||||
E_CONFIG_VAL(D, T, size.width_mm, INT);
|
||||
E_CONFIG_VAL(D, T, size.height_mm, INT);
|
||||
E_CONFIG_VAL(D, T, orientation, INT);
|
||||
E_CONFIG_VAL(D, T, refresh_rate, SHORT);
|
||||
|
||||
|
|
|
@ -27,7 +27,6 @@ static Eina_Bool _init(void);
|
|||
static void _shutdown(void);
|
||||
static Eina_Bool _screen_info_refresh(void);
|
||||
static Eina_Bool _e_event_config_loaded_cb(void *data, int type, void *e);
|
||||
static void _try_restore_configuration(void);
|
||||
static void _event_listeners_add(void);
|
||||
static void _event_listeners_remove(void);
|
||||
|
||||
|
@ -60,13 +59,15 @@ _init(void)
|
|||
return EINA_FALSE;
|
||||
_event_listeners_add();
|
||||
|
||||
_try_restore_configuration();
|
||||
|
||||
if (e_randr_screen_info.randr_version >= ECORE_X_RANDR_1_2)
|
||||
if (e_config->randr_serialized_setup)
|
||||
{
|
||||
if ((e_config->randr_serialized_setup) &&
|
||||
(e_config->randr_serialized_setup->outputs_policies))
|
||||
_12_policies_restore();
|
||||
e_randr_try_restore_configuration();
|
||||
|
||||
if (e_randr_screen_info.randr_version >= ECORE_X_RANDR_1_2)
|
||||
{
|
||||
if (e_config->randr_serialized_setup->outputs_policies)
|
||||
_12_policies_restore();
|
||||
}
|
||||
}
|
||||
|
||||
return EINA_TRUE;
|
||||
|
@ -144,22 +145,6 @@ _event_listeners_add(void)
|
|||
}
|
||||
}
|
||||
|
||||
static void
|
||||
_try_restore_configuration(void)
|
||||
{
|
||||
if (e_config->randr_serialized_setup)
|
||||
{
|
||||
if (e_randr_screen_info.randr_version == ECORE_X_RANDR_1_1)
|
||||
{
|
||||
_11_try_restore_configuration();
|
||||
}
|
||||
else if (e_randr_screen_info.randr_version >= ECORE_X_RANDR_1_2)
|
||||
{
|
||||
_12_try_restore_configuration();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// "Free" helper functions
|
||||
static void
|
||||
_event_listeners_remove(void)
|
||||
|
|
|
@ -29,6 +29,7 @@ typedef enum _E_Randr_Configuration_Store_Modifier
|
|||
} E_Randr_Configuration_Store_Modifier;
|
||||
|
||||
EAPI void e_randr_store_configuration(E_Randr_Configuration_Store_Modifier modifier);
|
||||
EAPI void e_randr_11_store_configuration(E_Randr_Configuration_Store_Modifier modifier);
|
||||
|
||||
#else
|
||||
#ifndef E_RANDR_H
|
||||
|
@ -183,6 +184,8 @@ struct _E_Randr_Serialized_Setup
|
|||
EINTERN Eina_Bool e_randr_init(void);
|
||||
EAPI Eina_Bool e_randr_screen_info_refresh(void);
|
||||
EINTERN int e_randr_shutdown(void);
|
||||
EINTERN void e_randr_try_restore_configuration(void);
|
||||
EINTERN E_Randr_Serialized_Setup *e_randr_serialized_setup_new(void);
|
||||
EINTERN void e_randr_serialized_setup_free(E_Randr_Serialized_Setup *ss);
|
||||
EINTERN void e_randr_11_serialized_setup_free(E_Randr_Serialized_Setup_11 *ss_11);
|
||||
EINTERN void e_randr_12_serialized_setup_free(E_Randr_Serialized_Setup_12 *ss_12);
|
||||
|
|
|
@ -15,14 +15,30 @@ _serialized_setup_11_new(void)
|
|||
{
|
||||
E_Randr_Serialized_Setup_11 *ss;
|
||||
Ecore_X_Randr_Screen_Size_MM *size;
|
||||
Ecore_X_Randr_Orientation ori;
|
||||
Ecore_X_Randr_Refresh_Rate rate;
|
||||
|
||||
ss = malloc(sizeof(*ss));
|
||||
|
||||
if (!(size = (Ecore_X_Randr_Screen_Size_MM *)eina_list_data_get(eina_list_nth(e_randr_screen_info.rrvd_info.randr_info_11->sizes, e_randr_screen_info.rrvd_info.randr_info_11->csize_index)))) goto _serialized_setup_11_new_failed_free_ss;
|
||||
ss->size.width = size->width;
|
||||
ss->size.height = size->height;
|
||||
ss->refresh_rate = e_randr_screen_info.rrvd_info.randr_info_11->current_rate;
|
||||
ss->orientation = e_randr_screen_info.rrvd_info.randr_info_11->corientation;
|
||||
if (e_randr_screen_info.randr_version == ECORE_X_RANDR_1_1)
|
||||
{
|
||||
if (!(size = (Ecore_X_Randr_Screen_Size_MM *)eina_list_data_get(eina_list_nth(e_randr_screen_info.rrvd_info.randr_info_11->sizes, e_randr_screen_info.rrvd_info.randr_info_11->csize_index)))) goto _serialized_setup_11_new_failed_free_ss;
|
||||
rate = e_randr_screen_info.rrvd_info.randr_info_11->current_rate;
|
||||
ori = e_randr_screen_info.rrvd_info.randr_info_11->corientation;
|
||||
ss->size.width = size->width;
|
||||
ss->size.width_mm = size->width_mm;
|
||||
ss->size.height = size->height;
|
||||
ss->size.height_mm = size->height_mm;
|
||||
}
|
||||
else if (e_randr_screen_info.randr_version > ECORE_X_RANDR_1_1)
|
||||
{
|
||||
ecore_x_randr_screen_primary_output_current_size_get(e_randr_screen_info.root, &ss->size.width, &ss->size.height, &ss->size.width_mm, &ss->size.height_mm, NULL);
|
||||
rate = ecore_x_randr_screen_primary_output_current_refresh_rate_get(e_randr_screen_info.root);
|
||||
ori = ecore_x_randr_screen_primary_output_orientation_get(e_randr_screen_info.root);
|
||||
}
|
||||
|
||||
ss->refresh_rate = rate;
|
||||
ss->orientation = ori;
|
||||
|
||||
return ss;
|
||||
|
||||
|
@ -35,24 +51,31 @@ _serialized_setup_11_new_failed_free_ss:
|
|||
E_Randr_Serialized_Setup_11 *
|
||||
_serialized_setup_11_update(E_Randr_Serialized_Setup_11 *ss_11)
|
||||
{
|
||||
Ecore_X_Randr_Screen_Size_MM *size;
|
||||
|
||||
if (ss_11)
|
||||
{
|
||||
if (!(size = (Ecore_X_Randr_Screen_Size_MM *)eina_list_data_get(eina_list_nth(e_randr_screen_info.rrvd_info.randr_info_11->sizes, e_randr_screen_info.rrvd_info.randr_info_11->csize_index)))) return NULL;
|
||||
if (!memcpy(&ss_11->size, size, sizeof(Ecore_X_Randr_Screen_Size_MM)))
|
||||
goto _update_serialized_setup_11_failed_free_ss;
|
||||
ss_11->refresh_rate = e_randr_screen_info.rrvd_info.randr_info_11->current_rate;
|
||||
ss_11->orientation = e_randr_screen_info.rrvd_info.randr_info_11->corientation;
|
||||
}
|
||||
else
|
||||
ss_11 = _serialized_setup_11_new();
|
||||
e_randr_11_serialized_setup_free(ss_11);
|
||||
|
||||
ss_11 = _serialized_setup_11_new();
|
||||
|
||||
return ss_11;
|
||||
}
|
||||
|
||||
_update_serialized_setup_11_failed_free_ss:
|
||||
free(ss_11);
|
||||
return NULL;
|
||||
void
|
||||
_11_store_configuration(E_Randr_Configuration_Store_Modifier modifier __UNUSED__)
|
||||
{
|
||||
if (!e_config->randr_serialized_setup)
|
||||
e_config->randr_serialized_setup = e_randr_serialized_setup_new();
|
||||
|
||||
if (e_config->randr_serialized_setup->serialized_setup_11)
|
||||
e_config->randr_serialized_setup->serialized_setup_11 = _serialized_setup_11_update(e_config->randr_serialized_setup->serialized_setup_11);
|
||||
else
|
||||
e_config->randr_serialized_setup->serialized_setup_11 = _serialized_setup_11_new();
|
||||
}
|
||||
|
||||
|
||||
EAPI void e_randr_11_store_configuration(E_Randr_Configuration_Store_Modifier modifier __UNUSED__)
|
||||
{
|
||||
_11_store_configuration(modifier);
|
||||
e_config_save_queue();
|
||||
}
|
||||
|
||||
//Free helper functions
|
||||
|
@ -71,32 +94,42 @@ e_randr_11_serialized_setup_free(E_Randr_Serialized_Setup_11 *ss_11)
|
|||
Eina_Bool
|
||||
_11_try_restore_configuration(void)
|
||||
{
|
||||
Ecore_X_Randr_Screen_Size_MM *stored_size, *size;
|
||||
Ecore_X_Randr_Screen_Size_MM *stored_size, *size, *sizes;
|
||||
Eina_List *iter;
|
||||
int i = 0;
|
||||
int i = 0, nsizes;
|
||||
|
||||
#define SIZE_EQUAL(size) \
|
||||
((stored_size->width == (size).width) \
|
||||
&& (stored_size->height == (size).height) \
|
||||
&& (stored_size->width_mm == (size).width_mm) \
|
||||
&& (stored_size->height_mm == (size).height_mm))
|
||||
|
||||
if (!e_config->randr_serialized_setup->serialized_setup_11) return EINA_FALSE;
|
||||
stored_size = &e_config->randr_serialized_setup->serialized_setup_11->size;
|
||||
EINA_LIST_FOREACH(e_randr_screen_info.rrvd_info.randr_info_11->sizes, iter, size)
|
||||
if (e_randr_screen_info.randr_version == ECORE_X_RANDR_1_1)
|
||||
{
|
||||
if ((stored_size->width == size->width)
|
||||
&& (stored_size->height == size->height)
|
||||
&& (stored_size->width_mm == size->width_mm)
|
||||
&& (stored_size->height_mm == size->height_mm))
|
||||
EINA_LIST_FOREACH(e_randr_screen_info.rrvd_info.randr_info_11->sizes, iter, size)
|
||||
{
|
||||
return ecore_x_randr_screen_primary_output_size_set(e_randr_screen_info.root, i);
|
||||
if (SIZE_EQUAL(*size))
|
||||
{
|
||||
return ecore_x_randr_screen_primary_output_size_set(e_randr_screen_info.root, i);
|
||||
}
|
||||
i++;
|
||||
}
|
||||
i++;
|
||||
}
|
||||
else if (e_randr_screen_info.randr_version > ECORE_X_RANDR_1_1)
|
||||
{
|
||||
sizes = ecore_x_randr_screen_primary_output_sizes_get(e_randr_screen_info.root, &nsizes);
|
||||
for (i = 0; i < nsizes; i++)
|
||||
{
|
||||
if (SIZE_EQUAL(sizes[i]))
|
||||
{
|
||||
free(sizes);
|
||||
return ecore_x_randr_screen_primary_output_size_set(e_randr_screen_info.root, i);
|
||||
}
|
||||
}
|
||||
}
|
||||
#undef SIZE_EQUAL
|
||||
|
||||
return EINA_FALSE;
|
||||
}
|
||||
|
||||
void
|
||||
_11_store_configuration(E_Randr_Configuration_Store_Modifier modifier)
|
||||
{
|
||||
if (e_config->randr_serialized_setup->serialized_setup_11)
|
||||
e_config->randr_serialized_setup->serialized_setup_11 = _serialized_setup_11_update(e_config->randr_serialized_setup->serialized_setup_11);
|
||||
else
|
||||
e_config->randr_serialized_setup->serialized_setup_11 = _serialized_setup_11_new();
|
||||
}
|
||||
|
|
|
@ -18,6 +18,12 @@ _new_serialized_setup(void)
|
|||
return E_NEW(E_Randr_Serialized_Setup, 1);
|
||||
}
|
||||
|
||||
EINTERN E_Randr_Serialized_Setup *
|
||||
e_randr_serialized_setup_new(void)
|
||||
{
|
||||
return _new_serialized_setup();
|
||||
}
|
||||
|
||||
EAPI void
|
||||
e_randr_store_configuration(E_Randr_Configuration_Store_Modifier modifier)
|
||||
{
|
||||
|
@ -43,7 +49,8 @@ _try_restore_configuration(void)
|
|||
EINA_SAFETY_ON_NULL_RETURN_VAL(e_config, EINA_FALSE);
|
||||
EINA_SAFETY_ON_NULL_RETURN_VAL(e_config->randr_serialized_setup, EINA_FALSE);
|
||||
|
||||
if (e_randr_screen_info.randr_version == ECORE_X_RANDR_1_1)
|
||||
if ((e_randr_screen_info.randr_version == ECORE_X_RANDR_1_1) ||
|
||||
((e_randr_screen_info.randr_version >= ECORE_X_RANDR_1_1) && e_config->randr_serialized_setup->serialized_setup_11 && !e_config->randr_serialized_setup->serialized_setups_12)) // either be 1.1 or maybe we have stored a resolution using the old conf_display dialog (which uses randr 1.1)
|
||||
return _11_try_restore_configuration();
|
||||
else if (e_randr_screen_info.randr_version >= ECORE_X_RANDR_1_2)
|
||||
return _12_try_restore_configuration();
|
||||
|
@ -51,6 +58,11 @@ _try_restore_configuration(void)
|
|||
return EINA_FALSE;
|
||||
}
|
||||
|
||||
EINTERN void e_randr_try_restore_configuration(void)
|
||||
{
|
||||
return _try_restore_configuration();
|
||||
}
|
||||
|
||||
EINTERN void e_randr_serialized_setup_free(E_Randr_Serialized_Setup *ss)
|
||||
{
|
||||
E_Randr_Serialized_Setup_12 *serialized_setup_12 = NULL;
|
||||
|
|
|
@ -85,14 +85,11 @@ static void
|
|||
_surebox_dialog_cb_yes(void *data, E_Dialog *dia)
|
||||
{
|
||||
SureBox *sb;
|
||||
Ecore_X_Randr_Screen_Size c_size;
|
||||
E_Manager *man;
|
||||
|
||||
sb = data;
|
||||
man = e_manager_current_get();
|
||||
ecore_x_randr_screen_primary_output_current_size_get(man->root, &c_size.width, &c_size.height, NULL, NULL, NULL);
|
||||
|
||||
e_randr_store_configuration(E_RANDR_CONFIGURATION_STORE_ALL);
|
||||
if (sb->cfdata->restore)
|
||||
e_randr_11_store_configuration(E_RANDR_CONFIGURATION_STORE_ALL);
|
||||
|
||||
_fill_data(sb->cfdata);
|
||||
_load_resolutions(sb->cfdata);
|
||||
|
|
Loading…
Reference in New Issue