Tom Hacohen
a77f090256
Eo2: Make internal function static + improved debug output.
2014-04-10 04:20:21 +01:00
Tom Hacohen
1fbcb6ef98
Eo: Removed redundant code.
2014-04-10 04:20:21 +01:00
Tom Hacohen
8c025ee4d9
Eo: Renamed eo files from eo2* to eo*.
2014-04-10 04:20:21 +01:00
Tom Hacohen
3a0d62ffcf
Ecore audio tests: Updated to Eo2.
2014-04-10 04:20:21 +01:00
Tom Hacohen
96fe5bd941
More adjustments for eo2 calls.
2014-04-10 04:20:21 +01:00
Tom Hacohen
d36ca8f949
Eo: Reintroduce the events now that eo1 is gone.
2014-04-10 04:20:21 +01:00
Tom Hacohen
92cc33c46f
Eo: EO_BASE_CLASS->EO_CLASS.
2014-04-10 04:20:21 +01:00
Tom Hacohen
374af9b9ca
Eo: eo_base's data_*->key_data_*.
2014-04-10 04:20:21 +01:00
Tom Hacohen
1866909ba1
Eo: Changed eo_prefix for base class to 'eo'.
...
This is better than eo_base, as it's super common.
2014-04-10 04:20:21 +01:00
Tom Hacohen
35525a53e0
Adjust eo_do calls to work with the eo2 api.
2014-04-10 04:20:21 +01:00
Tom Hacohen
c32bb4fe95
Eo2: Updated naming Eo2->Eo.
2014-04-10 04:20:21 +01:00
Tom Hacohen
80faa56ed3
Eo2: Removed more Eo1 code.
2014-04-10 04:20:21 +01:00
Tom Hacohen
3c46e7dab8
Eo2: Removed a lot of Eo1 code.
2014-04-10 04:20:21 +01:00
Tom Hacohen
9d332da1f8
Eo2: Adjust to composite object changes.
2014-04-10 04:20:21 +01:00
Tom Hacohen
2b34ab4cf7
Eolian: Generate Eo2.
2014-04-10 04:20:21 +01:00
Jérémy Zurcher
d39d705087
eo2: call stack is now thread safe
...
create/destroy tls key (_eo2_call_stack_key) at eo_init()/eo_shutdown().
use _eo2_call_stack_get() to allocate the stack when required.
register _eo2_call_stack_free() as eina_tls_cb_new() delete callback.
2014-04-10 04:20:21 +01:00
Jérémy Zurcher
4b9c37501c
eo2: add tests for thread safe call stack
...
Summary:
2 threads run 'eo2_do(o, a(), b());'
- A goes first, creates an object, enters 'eo2_do(o, a(), b());'
in a() call, it blocks, releases B and waits for it.
- B when released, creates an object, enters 'eo2_do(o, a(), b());'
in a() call, it joins and releases A, then blocks.
- A returns from a(); and enters b() using current call stack frame,
which is the one pushed by B! then pop the frame and releases B.
- B does as above using the stack pushed by A!
2014-04-10 04:20:21 +01:00
Jérémy Zurcher
64aa007caf
eo2: update class creation tests, follow new error policy
...
see previous commit
2014-04-10 04:20:21 +01:00
Jérémy Zurcher
f812b38a66
eo2: do not allow ill formed class creation
...
eo_class_new() returns NULL on error in _eo2_class_funcs_set().
it covers: NULL API func, API redefined, dich func override,
overriding non-existing fct.
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
70fe1398fd
eo2: if _eo2_class_funcs_set() fails eo_class_new() returns NULL
...
call to _eo2_class_funcs_set() is moved out of _eo_class_constructor()
into eo_class_new().
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
2fb5a54610
eo2: add tests for method call error msgs
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
d23b9ffd23
eo2: tests: extract mgs checks into eo_error_msgs.c|h
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
a0d761cfa9
eo2: _eo2_call_resolve() fails if op is EO_NOOP
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
5dc95bb50c
eo2: add test cases for class construction errors
...
it covers: NULL API func, overriding non-existing fct,
API redefined, dich func override.
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
9d2eeb7a8b
eo2: improve _eo2_class_funcs_set() errors support
...
as op descs are sorted, we can't output fct indexes in error msgs, but
as they are sorted using api_fct as key, we can detect multiple usage of
the same api_fct which leads to an unpredictable call to whatever is
returned by _eo2_api_op_id_get()->_eo2_api_desc_get().
it is still possible to instanciate an object of a not well defined class.
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
a9c325c124
eo2: normalize ERR msgs
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
c506ce2e1f
eo2: fix err msg in _dich_func_set()
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
82af591b83
eo2: improve _eo_op_id_name_get() to support eo1/2
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
19245b48f8
eo2: add _eo2_op_id_desc_get()
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
e41f2804b4
eo2: improve err msg in _eo2_api_op_id_get() and _eo2_call_resolve()
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
914dde776f
eo2: fix uninitialized vars in tests
...
because of conditional execution of eo2_do() fct calls
these vars could end up not initialized.
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
63c271dc5e
eo2: fix indentation
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
d3cd7cd63c
eo2: do not try to unref classes in eo2_do_end()
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
56ae6cf32e
eo2: remove memset() in _eo2_do_end() as all stack fields are set in _eo2_do_start()
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
adb5b8776d
eo2: no need to resolve eo_id when we reuse previous stack frame
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
d497459f93
eo2: add tests for call stack grow and shrink
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
ae536bdd84
eo2: call stack grows and shrinks
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
5f311223ad
eo2: rename Eo_Abstract_Class->Eo2_Abstract_Class
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
1834e3ff12
eo2: remove dead code
2014-04-10 04:20:20 +01:00
Jérémy Zurcher
117aa6f2a7
eo2: add TODO-eo2
...
merry XMas eo2 !!
you've been fully rebased,
without the eo2test directory,
luckily without any mistake !?
2014-04-10 04:20:20 +01:00
Tom Hacohen
055dd3c521
eo2: change the order of EO2_OP_FUNC* to put EAPI first.
...
This looks cleaner and more aligned. Also, it makes more sense as the
internal function is bound to the EAPI and not the other way around.
2014-04-10 04:20:20 +01:00
Tom Hacohen
0dc70153e5
eo2: optimize eo2_do_super func relove a bit.
...
no need to call dich_func_get twice, just reuse the value previously
fetched.
2014-04-10 04:20:20 +01:00
Tom Hacohen
08aca96bc3
eo2: get rid of eo2_stack_depth_get.
...
This is super internal, no reason why it should be exposed.
We should just implement automatic stack growth.
2014-04-10 04:20:20 +01:00
Tom Hacohen
76dc0d99a6
eo2: formatting.
2014-04-10 04:20:19 +01:00
Tom Hacohen
2fe10219c0
eo2: prefixed internal functions with _.
...
This is done to prevent code completion from picking them up.
2014-04-10 04:20:19 +01:00
Tom Hacohen
ebae305a9e
eo2: fixed validity checks for eo2_do_super.
...
The class should be checked to be valid and non-null.
This fixes the issues with eo_suite.
2014-04-10 04:20:19 +01:00
Tom Hacohen
1890fdf27f
eo2: fixed eo2_do call order.
...
This fixes the mixin test and general calling order.
"Next class" can only be known per op. That's why super should be
restricted to only one op.
2014-04-10 04:20:19 +01:00
Tom Hacohen
7c3f7e9b5b
eo2: eo2_do_super should only have one func.
...
This is a limitation that must be respected as eo2_do_super, unlike
eo2_do can end up with having different next class because of mixins.
2014-04-10 04:20:19 +01:00
Tom Hacohen
a62d150c96
eo2: share code between eo2_do and eo2_do_super.
2014-04-10 04:20:19 +01:00
Tom Hacohen
d9ceddf63a
eo2: fixed formatting.
2014-04-10 04:20:19 +01:00