2017-01-31 12:17:58 -08:00
|
|
|
/* EFL - EFL library
|
|
|
|
* Copyright (C) 2013 Cedric Bail
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library;
|
|
|
|
* if not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include "config.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "efl_suite.h"
|
|
|
|
|
|
|
|
#include <Efl.h>
|
|
|
|
#include <Ecore.h>
|
|
|
|
|
|
|
|
typedef struct _Test_Container_Item_Data {
|
|
|
|
unsigned int index;
|
|
|
|
} Test_Container_Item_Data;
|
|
|
|
|
|
|
|
const int base_int[7] = {10, 11, 12, 13, 14, 0, 16};
|
|
|
|
const char * const base_str[7] = {"A", "B", "C", "D", "E", "", "GH"};
|
|
|
|
|
2018-02-09 14:51:08 -08:00
|
|
|
static Eina_Value
|
|
|
|
_children_slice_future_then(void *data EINA_UNUSED,
|
|
|
|
const Eina_Value v, const Eina_Future *dead_future EINA_UNUSED)
|
2017-01-31 12:17:58 -08:00
|
|
|
{
|
2018-02-09 14:51:08 -08:00
|
|
|
unsigned int i, len;
|
|
|
|
Efl_Model *child = NULL;
|
2017-01-31 12:17:58 -08:00
|
|
|
|
2018-02-09 14:51:08 -08:00
|
|
|
fail_if(eina_value_type_get(&v) != EINA_VALUE_TYPE_ARRAY);
|
2017-01-31 12:17:58 -08:00
|
|
|
|
2018-02-09 14:51:08 -08:00
|
|
|
EINA_VALUE_ARRAY_FOREACH(&v, len, i, child)
|
2017-01-31 12:17:58 -08:00
|
|
|
{
|
2018-02-09 14:51:08 -08:00
|
|
|
Eina_Value *value_int = NULL;
|
|
|
|
Eina_Value *value_str = NULL;
|
|
|
|
const char *cmp_str = NULL;
|
|
|
|
int cmp_int = 0;
|
2017-01-31 12:17:58 -08:00
|
|
|
|
2018-02-09 14:51:08 -08:00
|
|
|
value_int = efl_model_property_get(child, "test_p_int");
|
|
|
|
value_str = efl_model_property_get(child, "test_p_str");
|
2017-01-31 12:17:58 -08:00
|
|
|
|
2018-02-09 14:51:08 -08:00
|
|
|
fail_if(eina_value_type_get(value_int) != EINA_VALUE_TYPE_INT);
|
|
|
|
fail_if(eina_value_type_get(value_str) != EINA_VALUE_TYPE_STRING);
|
2017-01-31 12:17:58 -08:00
|
|
|
|
2018-02-09 14:51:08 -08:00
|
|
|
eina_value_get(value_int, &cmp_int);
|
|
|
|
eina_value_get(value_str, &cmp_str);
|
2017-01-31 12:17:58 -08:00
|
|
|
|
2018-02-09 14:51:08 -08:00
|
|
|
if (cmp_int != base_int[i] ||
|
|
|
|
strcmp(cmp_str, base_str[i]) != 0)
|
|
|
|
{
|
|
|
|
abort();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fprintf(stderr, "len: %i\n", len);
|
2017-01-31 12:17:58 -08:00
|
|
|
|
2018-02-09 14:51:08 -08:00
|
|
|
fail_if(len != 7);
|
2017-01-31 12:17:58 -08:00
|
|
|
|
2018-02-09 14:51:08 -08:00
|
|
|
ecore_main_loop_quit();
|
2017-01-31 12:17:58 -08:00
|
|
|
|
2018-02-09 14:51:08 -08:00
|
|
|
return v;
|
2017-01-31 12:17:58 -08:00
|
|
|
}
|
|
|
|
|
efl_model : rename all efl_model based classes.
Summary:
As the result of discussion in T7458,
we need to rename all efl_model based classes with efl_XXX_Model sequence.
I've run few vote for this, see V42, V43
few classes are totally renamed as our consideration of misnaming.
| Efl.Model_Loop | Efl.Loop_Model |
| Efl.Model_Item | Efl.Generic_Model |
| Efl.Model_Container | Efl.Container_Model |
| Efl.Model_Container_Item | Efl.Container_Model_Item |
| Efl.Model_Composite | Efl.Composite_Model |
| Efl.Model_Composite_Boolean | Efl.Boolean_Model |
| Efl.Model_Composite_Boolean_Chlidren | Efl.Boolean_Model_Item |
| Efl.Model_Composite_Selection | Efl.Select_Model |
| Efl.Model_Composite_Selection_Chlidren | Efl.Select_Model_Item |
| Efl.Model_View | Efl.View_Model |
| Eio.Model | Efl.Io.Model |
| Efl.Ui.Model_State | Efl.Ui.State_Model |
| Efl.Ui.Model_Size | Efl.Ui.Size_Model |
| Efl.Ui.Model_Exact | Efl.Ui.Exact_Model |
| Efl.Ui.Model_Average | Efl.Ui.Average_Model |
| Efl.Ui.Model_Homogeneous | Efl.Ui.Homogeneous_Model |
I worried about Efl.Io.Model changes, cause it is widely used,
but as I tested, there is no issue found yet.
Eldbus.Model also may can changed Efl.Dbus.Model,
but I cannot found any class who using Efl.Dbus namespace,
so I left it future work.
Test Plan:
Run the Make Test,
it works well except Efl test about selection.
there are class inheritance problem exist in select_model,
I reported it and will fix it in another patch.
Reviewers: cedric, felipealmeida, woohyun, Hermet
Reviewed By: cedric
Subscribers: lauromoura
Tags: #efl, #do_not_merge
Differential Revision: https://phab.enlightenment.org/D7533
2019-01-30 20:35:34 -08:00
|
|
|
EFL_START_TEST(efl_test_container_model_values)
|
2017-01-31 12:17:58 -08:00
|
|
|
{
|
efl_model : rename all efl_model based classes.
Summary:
As the result of discussion in T7458,
we need to rename all efl_model based classes with efl_XXX_Model sequence.
I've run few vote for this, see V42, V43
few classes are totally renamed as our consideration of misnaming.
| Efl.Model_Loop | Efl.Loop_Model |
| Efl.Model_Item | Efl.Generic_Model |
| Efl.Model_Container | Efl.Container_Model |
| Efl.Model_Container_Item | Efl.Container_Model_Item |
| Efl.Model_Composite | Efl.Composite_Model |
| Efl.Model_Composite_Boolean | Efl.Boolean_Model |
| Efl.Model_Composite_Boolean_Chlidren | Efl.Boolean_Model_Item |
| Efl.Model_Composite_Selection | Efl.Select_Model |
| Efl.Model_Composite_Selection_Chlidren | Efl.Select_Model_Item |
| Efl.Model_View | Efl.View_Model |
| Eio.Model | Efl.Io.Model |
| Efl.Ui.Model_State | Efl.Ui.State_Model |
| Efl.Ui.Model_Size | Efl.Ui.Size_Model |
| Efl.Ui.Model_Exact | Efl.Ui.Exact_Model |
| Efl.Ui.Model_Average | Efl.Ui.Average_Model |
| Efl.Ui.Model_Homogeneous | Efl.Ui.Homogeneous_Model |
I worried about Efl.Io.Model changes, cause it is widely used,
but as I tested, there is no issue found yet.
Eldbus.Model also may can changed Efl.Dbus.Model,
but I cannot found any class who using Efl.Dbus namespace,
so I left it future work.
Test Plan:
Run the Make Test,
it works well except Efl test about selection.
there are class inheritance problem exist in select_model,
I reported it and will fix it in another patch.
Reviewers: cedric, felipealmeida, woohyun, Hermet
Reviewed By: cedric
Subscribers: lauromoura
Tags: #efl, #do_not_merge
Differential Revision: https://phab.enlightenment.org/D7533
2019-01-30 20:35:34 -08:00
|
|
|
Efl_Container_Model* model;
|
2018-02-09 14:51:08 -08:00
|
|
|
Eina_Future *future;
|
2017-01-31 12:17:58 -08:00
|
|
|
int **cmp_int;
|
|
|
|
const char **cmp_str;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
cmp_int = calloc(8, sizeof(int*));
|
|
|
|
cmp_str = calloc(8, sizeof(const char*));
|
|
|
|
for (i = 0; i < 7; ++i)
|
|
|
|
{
|
|
|
|
cmp_int[i] = calloc(1, sizeof(int));
|
|
|
|
*(cmp_int[i]) = base_int[i];
|
|
|
|
cmp_str[i] = strdup(base_str[i]);
|
|
|
|
}
|
|
|
|
|
2019-02-23 05:58:07 -08:00
|
|
|
model = efl_add(EFL_CONTAINER_MODEL_CLASS, efl_main_loop_get());
|
2017-01-31 12:17:58 -08:00
|
|
|
|
efl_model : rename all efl_model based classes.
Summary:
As the result of discussion in T7458,
we need to rename all efl_model based classes with efl_XXX_Model sequence.
I've run few vote for this, see V42, V43
few classes are totally renamed as our consideration of misnaming.
| Efl.Model_Loop | Efl.Loop_Model |
| Efl.Model_Item | Efl.Generic_Model |
| Efl.Model_Container | Efl.Container_Model |
| Efl.Model_Container_Item | Efl.Container_Model_Item |
| Efl.Model_Composite | Efl.Composite_Model |
| Efl.Model_Composite_Boolean | Efl.Boolean_Model |
| Efl.Model_Composite_Boolean_Chlidren | Efl.Boolean_Model_Item |
| Efl.Model_Composite_Selection | Efl.Select_Model |
| Efl.Model_Composite_Selection_Chlidren | Efl.Select_Model_Item |
| Efl.Model_View | Efl.View_Model |
| Eio.Model | Efl.Io.Model |
| Efl.Ui.Model_State | Efl.Ui.State_Model |
| Efl.Ui.Model_Size | Efl.Ui.Size_Model |
| Efl.Ui.Model_Exact | Efl.Ui.Exact_Model |
| Efl.Ui.Model_Average | Efl.Ui.Average_Model |
| Efl.Ui.Model_Homogeneous | Efl.Ui.Homogeneous_Model |
I worried about Efl.Io.Model changes, cause it is widely used,
but as I tested, there is no issue found yet.
Eldbus.Model also may can changed Efl.Dbus.Model,
but I cannot found any class who using Efl.Dbus namespace,
so I left it future work.
Test Plan:
Run the Make Test,
it works well except Efl test about selection.
there are class inheritance problem exist in select_model,
I reported it and will fix it in another patch.
Reviewers: cedric, felipealmeida, woohyun, Hermet
Reviewed By: cedric
Subscribers: lauromoura
Tags: #efl, #do_not_merge
Differential Revision: https://phab.enlightenment.org/D7533
2019-01-30 20:35:34 -08:00
|
|
|
efl_container_model_child_property_add(model, "test_p_int", EINA_VALUE_TYPE_INT,
|
2017-01-31 12:17:58 -08:00
|
|
|
eina_carray_iterator_new((void**)cmp_int));
|
|
|
|
|
efl_model : rename all efl_model based classes.
Summary:
As the result of discussion in T7458,
we need to rename all efl_model based classes with efl_XXX_Model sequence.
I've run few vote for this, see V42, V43
few classes are totally renamed as our consideration of misnaming.
| Efl.Model_Loop | Efl.Loop_Model |
| Efl.Model_Item | Efl.Generic_Model |
| Efl.Model_Container | Efl.Container_Model |
| Efl.Model_Container_Item | Efl.Container_Model_Item |
| Efl.Model_Composite | Efl.Composite_Model |
| Efl.Model_Composite_Boolean | Efl.Boolean_Model |
| Efl.Model_Composite_Boolean_Chlidren | Efl.Boolean_Model_Item |
| Efl.Model_Composite_Selection | Efl.Select_Model |
| Efl.Model_Composite_Selection_Chlidren | Efl.Select_Model_Item |
| Efl.Model_View | Efl.View_Model |
| Eio.Model | Efl.Io.Model |
| Efl.Ui.Model_State | Efl.Ui.State_Model |
| Efl.Ui.Model_Size | Efl.Ui.Size_Model |
| Efl.Ui.Model_Exact | Efl.Ui.Exact_Model |
| Efl.Ui.Model_Average | Efl.Ui.Average_Model |
| Efl.Ui.Model_Homogeneous | Efl.Ui.Homogeneous_Model |
I worried about Efl.Io.Model changes, cause it is widely used,
but as I tested, there is no issue found yet.
Eldbus.Model also may can changed Efl.Dbus.Model,
but I cannot found any class who using Efl.Dbus namespace,
so I left it future work.
Test Plan:
Run the Make Test,
it works well except Efl test about selection.
there are class inheritance problem exist in select_model,
I reported it and will fix it in another patch.
Reviewers: cedric, felipealmeida, woohyun, Hermet
Reviewed By: cedric
Subscribers: lauromoura
Tags: #efl, #do_not_merge
Differential Revision: https://phab.enlightenment.org/D7533
2019-01-30 20:35:34 -08:00
|
|
|
efl_container_model_child_property_add(model, "test_p_str", EINA_VALUE_TYPE_STRING,
|
2017-01-31 12:17:58 -08:00
|
|
|
eina_carray_iterator_new((void**)cmp_str));
|
|
|
|
|
|
|
|
for (i = 0; i < 7; ++i)
|
|
|
|
{
|
|
|
|
free(cmp_int[i]);
|
|
|
|
free((void*)cmp_str[i]);
|
|
|
|
}
|
|
|
|
free(cmp_int);
|
|
|
|
free(cmp_str);
|
|
|
|
|
2018-02-09 14:51:08 -08:00
|
|
|
future = efl_model_children_slice_get(model, 0, efl_model_children_count_get(model));
|
2017-01-31 12:17:58 -08:00
|
|
|
|
2018-11-07 06:52:41 -08:00
|
|
|
eina_future_then(future, _children_slice_future_then, NULL, NULL);
|
2017-01-31 12:17:58 -08:00
|
|
|
|
2018-02-09 14:51:08 -08:00
|
|
|
ecore_main_loop_begin();
|
2019-02-23 05:58:07 -08:00
|
|
|
|
|
|
|
efl_del(model);
|
2017-01-31 12:17:58 -08:00
|
|
|
}
|
2018-03-26 11:19:28 -07:00
|
|
|
EFL_END_TEST
|
2017-01-31 12:17:58 -08:00
|
|
|
|
|
|
|
|
|
|
|
void
|
efl_model : rename all efl_model based classes.
Summary:
As the result of discussion in T7458,
we need to rename all efl_model based classes with efl_XXX_Model sequence.
I've run few vote for this, see V42, V43
few classes are totally renamed as our consideration of misnaming.
| Efl.Model_Loop | Efl.Loop_Model |
| Efl.Model_Item | Efl.Generic_Model |
| Efl.Model_Container | Efl.Container_Model |
| Efl.Model_Container_Item | Efl.Container_Model_Item |
| Efl.Model_Composite | Efl.Composite_Model |
| Efl.Model_Composite_Boolean | Efl.Boolean_Model |
| Efl.Model_Composite_Boolean_Chlidren | Efl.Boolean_Model_Item |
| Efl.Model_Composite_Selection | Efl.Select_Model |
| Efl.Model_Composite_Selection_Chlidren | Efl.Select_Model_Item |
| Efl.Model_View | Efl.View_Model |
| Eio.Model | Efl.Io.Model |
| Efl.Ui.Model_State | Efl.Ui.State_Model |
| Efl.Ui.Model_Size | Efl.Ui.Size_Model |
| Efl.Ui.Model_Exact | Efl.Ui.Exact_Model |
| Efl.Ui.Model_Average | Efl.Ui.Average_Model |
| Efl.Ui.Model_Homogeneous | Efl.Ui.Homogeneous_Model |
I worried about Efl.Io.Model changes, cause it is widely used,
but as I tested, there is no issue found yet.
Eldbus.Model also may can changed Efl.Dbus.Model,
but I cannot found any class who using Efl.Dbus namespace,
so I left it future work.
Test Plan:
Run the Make Test,
it works well except Efl test about selection.
there are class inheritance problem exist in select_model,
I reported it and will fix it in another patch.
Reviewers: cedric, felipealmeida, woohyun, Hermet
Reviewed By: cedric
Subscribers: lauromoura
Tags: #efl, #do_not_merge
Differential Revision: https://phab.enlightenment.org/D7533
2019-01-30 20:35:34 -08:00
|
|
|
efl_test_case_container_model(TCase *tc)
|
2017-01-31 12:17:58 -08:00
|
|
|
{
|
efl_model : rename all efl_model based classes.
Summary:
As the result of discussion in T7458,
we need to rename all efl_model based classes with efl_XXX_Model sequence.
I've run few vote for this, see V42, V43
few classes are totally renamed as our consideration of misnaming.
| Efl.Model_Loop | Efl.Loop_Model |
| Efl.Model_Item | Efl.Generic_Model |
| Efl.Model_Container | Efl.Container_Model |
| Efl.Model_Container_Item | Efl.Container_Model_Item |
| Efl.Model_Composite | Efl.Composite_Model |
| Efl.Model_Composite_Boolean | Efl.Boolean_Model |
| Efl.Model_Composite_Boolean_Chlidren | Efl.Boolean_Model_Item |
| Efl.Model_Composite_Selection | Efl.Select_Model |
| Efl.Model_Composite_Selection_Chlidren | Efl.Select_Model_Item |
| Efl.Model_View | Efl.View_Model |
| Eio.Model | Efl.Io.Model |
| Efl.Ui.Model_State | Efl.Ui.State_Model |
| Efl.Ui.Model_Size | Efl.Ui.Size_Model |
| Efl.Ui.Model_Exact | Efl.Ui.Exact_Model |
| Efl.Ui.Model_Average | Efl.Ui.Average_Model |
| Efl.Ui.Model_Homogeneous | Efl.Ui.Homogeneous_Model |
I worried about Efl.Io.Model changes, cause it is widely used,
but as I tested, there is no issue found yet.
Eldbus.Model also may can changed Efl.Dbus.Model,
but I cannot found any class who using Efl.Dbus namespace,
so I left it future work.
Test Plan:
Run the Make Test,
it works well except Efl test about selection.
there are class inheritance problem exist in select_model,
I reported it and will fix it in another patch.
Reviewers: cedric, felipealmeida, woohyun, Hermet
Reviewed By: cedric
Subscribers: lauromoura
Tags: #efl, #do_not_merge
Differential Revision: https://phab.enlightenment.org/D7533
2019-01-30 20:35:34 -08:00
|
|
|
tcase_add_test(tc, efl_test_container_model_values);
|
2017-01-31 12:17:58 -08:00
|
|
|
}
|