/*
Copyright (C) 2010 ProFUSION embedded systems
Copyright (C) 2010 Samsung Electronics
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 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
Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA.
*/
#include "config.h"
#include "ewk_window_features.h"
#include "WindowFeatures.h"
#include "ewk_private.h"
#include <Eina.h>
/**
* \struct _Ewk_Window_Features
* @brief Contains the window features data.
*/
struct _Ewk_Window_Features {
unsigned int __ref;
WebCore::WindowFeatures* core;
};
/**
* Decreases the referece count of an Ewk_Window_Features, possibly freeing it.
*
* When the reference count of the object reaches 0, the one is freed.
*
* @param window_features the object to decrease reference count
*/
EAPI void ewk_window_features_unref(Ewk_Window_Features* window_features)
{
EINA_SAFETY_ON_NULL_RETURN(window_features);
EINA_SAFETY_ON_FALSE_RETURN(window_features->__ref > 0);
if (--window_features->__ref)
return;
delete window_features->core;
window_features->core = 0;
free(window_features);
}
/**
* Increases the reference count of an Ewk_Window_Features.
*
* @param window_features the object to increase reference count
*/
EAPI void ewk_window_features_ref(Ewk_Window_Features* window_features)
{
EINA_SAFETY_ON_NULL_RETURN(window_features);
window_features->__ref++;
}
/**
* Gets boolean properties of an Ewk_Window_Features.
*
* Properties are returned in the respective pointers. Passing @c 0 to any of
* these pointers will make that property to not be returned.
*
* @param window_features the object to get boolean properties
* @param toolbar_visible the pointer to store if toolbar is visible
* @param statusbar_visible the pointer to store if statusbar is visible
* @param scrollbars_visible the pointer to store if scrollbars is visible
* @param menubar_visible the pointer to store if menubar is visible
* @param locationbar_visible the pointer to store if locationbar is visible
* @param fullscreen the pointer to store if fullscreen is enabled
*
* @see ewk_window_features_int_property_get
*/
EAPI void ewk_window_features_bool_property_get(Ewk_Window_Features* window_features, Eina_Bool* toolbar_visible, Eina_Bool* statusbar_visible, Eina_Bool* scrollbars_visible, Eina_Bool* menubar_visible, Eina_Bool* locationbar_visible, Eina_Bool* fullscreen)
{
EINA_SAFETY_ON_NULL_RETURN(window_features);
EINA_SAFETY_ON_NULL_RETURN(window_features->core);
if (toolbar_visible)
*toolbar_visible = window_features->core->toolBarVisible;
if (statusbar_visible)
*statusbar_visible = window_features->core->statusBarVisible;
if (scrollbars_visible)
*scrollbars_visible = window_features->core->scrollbarsVisible;
if (menubar_visible)
*menubar_visible = window_features->core->menuBarVisible;
if (locationbar_visible)
*locationbar_visible = window_features->core->locationBarVisible;
if (fullscreen)
*fullscreen = window_features->core->fullscreen;
}
/**
* Gets int properties of an Ewk_Window_Features.
*
* Properties are returned in the respective pointers. Passing @c 0 to any of
* these pointers will make that property to not be returned.
*
* Make sure to check if the value returned is less than 0 before using it, since in
* that case it means that property was not set in winwdow_features object.
*
* @param window_features the window's features
* @param x the pointer to store x position
* @param y the pointer to store y position
* @param w the pointer to store width
* @param h the pointer to store height
*
* @see ewk_window_features_bool_property_get
*/
EAPI void ewk_window_features_int_property_get(Ewk_Window_Features* window_features, int* x, int* y, int* w, int* h)
{
EINA_SAFETY_ON_NULL_RETURN(window_features);
EINA_SAFETY_ON_NULL_RETURN(window_features->core);
if (x)
*x = window_features->core->xSet ? static_cast<int>(window_features->core->x) : -1;
if (y)
*y = window_features->core->ySet ? static_cast<int>(window_features->core->y) : -1;
if (w)
*w = window_features->core->widthSet ? static_cast<int>(window_features->core->width) : -1;
if (h)
*h = window_features->core->heightSet ? static_cast<int>(window_features->core->height) : -1;
}
/* internal methods ****************************************************/
/**
* @internal
*
* Creates a new Ewk_Window_Features object.
*
* @param core if not @c 0 a new WebCore::WindowFeatures is allocated copying core features and
* it is embedded inside the Ewk_Window_Features whose ref count is initialized, if core is @c 0 a new one is created with the default features.
* @returns a new allocated the Ewk_Window_Features object
*/
Ewk_Window_Features* ewk_window_features_new_from_core(const WebCore::WindowFeatures* core)
{
Ewk_Window_Features* window_features = static_cast<Ewk_Window_Features*>(malloc(sizeof(*window_features)));
if (core)
window_features->core = new WebCore::WindowFeatures(*core);
else
window_features->core = new WebCore::WindowFeatures();
window_features->__ref = 1;
return window_features;
}