tizen 2.4 release
[framework/uifw/elementary.git] / src / lib / elm_widget_video.h
index 7f9dbef..df66548 100644 (file)
@@ -1,7 +1,13 @@
 #ifndef ELM_WIDGET_VIDEO_H
 #define ELM_WIDGET_VIDEO_H
 
-#include "elm_widget_layout.h"
+#include "Elementary.h"
+
+/* DO NOT USE THIS HEADER UNLESS YOU ARE PREPARED FOR BREAKING OF YOUR
+ * CODE. THIS IS ELEMENTARY'S INTERNAL WIDGET API (for now) AND IS NOT
+ * FINAL. CALL elm_widget_api_check(ELM_INTERNAL_API_VERSION) TO CHECK
+ * IT AT RUNTIME.
+ */
 
 /**
  * @internal
  */
 
 /**
- * @def ELM_VIDEO_CLASS
- *
- * Use this macro to cast whichever subclass of
- * #Elm_Video_Smart_Class into it, so to access its fields.
- *
- * @ingroup Widget
- */
-#define ELM_VIDEO_CLASS(x) ((Elm_Video_Smart_Class *)x)
-
-/**
- * @def ELM_VIDEO_DATA
- *
- * Use this macro to cast whichever subdata of
- * #Elm_Video_Smart_Data into it, so to access its fields.
- *
- * @ingroup Widget
- */
-#define ELM_VIDEO_DATA(x)  ((Elm_Video_Smart_Data *)x)
-
-/**
- * @def ELM_VIDEO_SMART_CLASS_VERSION
- *
- * Current version for Elementary video @b base smart class, a value
- * which goes to _Elm_Video_Smart_Class::version.
- *
- * @ingroup Widget
- */
-#define ELM_VIDEO_SMART_CLASS_VERSION 1
-
-/**
- * @def ELM_VIDEO_SMART_CLASS_INIT
- *
- * Initializer for a whole #Elm_Video_Smart_Class structure, with
- * @c NULL values on its specific fields.
- *
- * @param smart_class_init initializer to use for the "base" field
- * (#Evas_Smart_Class).
- *
- * @see EVAS_SMART_CLASS_INIT_NULL
- * @see EVAS_SMART_CLASS_INIT_NAME_VERSION
- * @see ELM_VIDEO_SMART_CLASS_INIT_NULL
- * @see ELM_VIDEO_SMART_CLASS_INIT_NAME_VERSION
- *
- * @ingroup Widget
- */
-#define ELM_VIDEO_SMART_CLASS_INIT(smart_class_init) \
-  {smart_class_init, ELM_VIDEO_SMART_CLASS_VERSION}
-
-/**
- * @def ELM_VIDEO_SMART_CLASS_INIT_NULL
- *
- * Initializer to zero out a whole #Elm_Video_Smart_Class structure.
- *
- * @see ELM_VIDEO_SMART_CLASS_INIT_NAME_VERSION
- * @see ELM_VIDEO_SMART_CLASS_INIT
- *
- * @ingroup Widget
- */
-#define ELM_VIDEO_SMART_CLASS_INIT_NULL \
-  ELM_VIDEO_SMART_CLASS_INIT(EVAS_SMART_CLASS_INIT_NULL)
-
-/**
- * @def ELM_VIDEO_SMART_CLASS_INIT_NAME_VERSION
- *
- * Initializer to zero out a whole #Elm_Video_Smart_Class structure and
- * set its name and version.
- *
- * This is similar to #ELM_VIDEO_SMART_CLASS_INIT_NULL, but it will
- * also set the version field of #Elm_Video_Smart_Class (base field)
- * to the latest #ELM_VIDEO_SMART_CLASS_VERSION and name it to the
- * specific value.
- *
- * It will keep a reference to the name field as a <c>"const char *"</c>,
- * i.e., the name must be available while the structure is
- * used (hint: static or global variable!) and must not be modified.
- *
- * @see ELM_VIDEO_SMART_CLASS_INIT_NULL
- * @see ELM_VIDEO_SMART_CLASS_INIT
- *
- * @ingroup Widget
- */
-#define ELM_VIDEO_SMART_CLASS_INIT_NAME_VERSION(name) \
-  ELM_VIDEO_SMART_CLASS_INIT                          \
-    (ELM_LAYOUT_SMART_CLASS_INIT_NAME_VERSION(name))
-
-/**
- * Elementary video base smart class. This inherits directly from
- * #Elm_Layout_Smart_Class and is meant to build widgets extending the
- * behavior of a video.
- *
- * All of the functions listed on @ref Video namespace will work for
- * objects deriving from #Elm_Video_Smart_Class.
- */
-typedef struct _Elm_Video_Smart_Class
-{
-   Elm_Layout_Smart_Class base;
-
-   int                    version;    /**< Version of this smart class definition */
-} Elm_Video_Smart_Class;
-
-/**
  * Base layout smart data extended with video instance data.
  */
-typedef struct _Elm_Video_Smart_Data Elm_Video_Smart_Data;
-struct _Elm_Video_Smart_Data
+typedef struct _Elm_Video_Data Elm_Video_Data;
+struct _Elm_Video_Data
 {
-   Elm_Layout_Smart_Data base;
-
    Evas_Object          *emotion;
    Ecore_Timer          *timer;
 
@@ -135,33 +38,29 @@ struct _Elm_Video_Smart_Data
  * @}
  */
 
-EAPI extern const char ELM_VIDEO_SMART_NAME[];
-EAPI const Elm_Video_Smart_Class *elm_video_smart_class_get(void);
-
 #define ELM_VIDEO_DATA_GET(o, sd) \
-  Elm_Video_Smart_Data * sd = evas_object_smart_data_get(o)
+  Elm_Video_Data * sd = eo_data_scope_get(o, ELM_VIDEO_CLASS)
 
 #define ELM_VIDEO_DATA_GET_OR_RETURN(o, ptr)         \
   ELM_VIDEO_DATA_GET(o, ptr);                        \
-  if (!ptr)                                          \
+  if (EINA_UNLIKELY(!ptr))                           \
     {                                                \
-       CRITICAL("No widget data for object %p (%s)", \
-                o, evas_object_type_get(o));         \
+       CRI("No widget data for object %p (%s)",      \
+           o, evas_object_type_get(o));              \
        return;                                       \
     }
 
 #define ELM_VIDEO_DATA_GET_OR_RETURN_VAL(o, ptr, val) \
   ELM_VIDEO_DATA_GET(o, ptr);                         \
-  if (!ptr)                                           \
+  if (EINA_UNLIKELY(!ptr))                            \
     {                                                 \
-       CRITICAL("No widget data for object %p (%s)",  \
-                o, evas_object_type_get(o));          \
+       CRI("No widget data for object %p (%s)",       \
+           o, evas_object_type_get(o));               \
        return val;                                    \
     }
 
-#define ELM_VIDEO_CHECK(obj)                                      \
-  if (!obj || !elm_widget_type_check((obj), ELM_VIDEO_SMART_NAME, \
-                                     __func__))                   \
+#define ELM_VIDEO_CHECK(obj)                              \
+  if (EINA_UNLIKELY(!eo_isa((obj), ELM_VIDEO_CLASS))) \
     return
 
 #endif