summaryrefslogtreecommitdiffstats
path: root/Tools/EWebLauncher/main.c
diff options
context:
space:
mode:
Diffstat (limited to 'Tools/EWebLauncher/main.c')
-rw-r--r--Tools/EWebLauncher/main.c1050
1 files changed, 0 insertions, 1050 deletions
diff --git a/Tools/EWebLauncher/main.c b/Tools/EWebLauncher/main.c
deleted file mode 100644
index b9b5b5297..000000000
--- a/Tools/EWebLauncher/main.c
+++ /dev/null
@@ -1,1050 +0,0 @@
-/*
- * Copyright (C) 2008 INdT - Instituto Nokia de Tecnologia
- * Copyright (C) 2009, 2010 ProFUSION embedded systems
- * Copyright (C) 2009, 2010, 2011 Samsung Electronics
- * Copyright (C) 2012 Intel Corporation
- *
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- *
- * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY
- * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
- * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR
- * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
- * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
- * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
- * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
- * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-
-#include "EWebKit.h"
-
-#include "url_bar.h"
-#include "url_utils.h"
-#include <Ecore.h>
-#include <Ecore_Evas.h>
-#include <Ecore_File.h>
-#include <Ecore_Getopt.h>
-#include <Ecore_X.h>
-#include <Edje.h>
-#include <Evas.h>
-#include <ctype.h>
-#include <inttypes.h>
-#include <limits.h>
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-#include <sys/stat.h>
-#include <sys/types.h>
-#include <unistd.h>
-
-#define DEFAULT_WIDTH 800
-#define DEFAULT_HEIGHT 600
-#define DEFAULT_ZOOM_INIT 1.0
-
-#define info(format, args...) \
- do { \
- if (verbose) \
- printf(format"\n", ##args); \
- } while (0)
-
-#define MIN_ZOOM_LEVEL 0
-#define DEFAULT_ZOOM_LEVEL 5
-#define MAX_ZOOM_LEVEL 13
-
-static int currentZoomLevel = DEFAULT_ZOOM_LEVEL;
-static float currentZoom = 1.0;
-
-// the zoom values are chosen to be like in Mozilla Firefox 3
-static int zoomLevels[] = {30, 50, 67, 80, 90,
- 100,
- 110, 120, 133, 150, 170, 200, 240, 300};
-
-static int verbose = 0;
-
-static Eina_List *windows = NULL;
-
-static char *themePath = NULL;
-
-static const char *backingStores[] = {
- "tiled",
- "single",
- NULL
-};
-
-typedef struct _Window_Properties {
- Eina_Bool toolbarsVisible:1;
- Eina_Bool statusbarVisible:1;
- Eina_Bool scrollbarsVisible:1;
- Eina_Bool menubarVisible:1;
-} Window_Properties;
-
-Window_Properties windowProperties = { /* Pretend we have them and they are initially visible */
- EINA_TRUE,
- EINA_TRUE,
- EINA_TRUE,
- EINA_TRUE
-};
-
-static const Ecore_Getopt options = {
- "EWebLauncher",
- "%prog [options] [url]",
- "0.0.1",
- "(C)2008 INdT (The Nokia Technology Institute)\n"
- "(C)2009, 2010 ProFUSION embedded systems\n"
- "(C)2009, 2010, 2011 Samsung Electronics\n"
- "(C)2012 Intel Corporation\n",
- "GPL",
- "Test Web Browser using the Enlightenment Foundation Libraries of WebKit",
- EINA_TRUE, {
- ECORE_GETOPT_STORE_STR
- ('e', "engine", "ecore-evas engine to use."),
- ECORE_GETOPT_CALLBACK_NOARGS
- ('E', "list-engines", "list ecore-evas engines.",
- ecore_getopt_callback_ecore_evas_list_engines, NULL),
- ECORE_GETOPT_CHOICE
- ('b', "backing-store", "choose backing store to use.", backingStores),
- ECORE_GETOPT_STORE_DOUBLE
- ('r', "device-pixel-ratio", "Ratio between the CSS units and device pixels."),
- ECORE_GETOPT_STORE_DEF_BOOL
- ('c', "encoding-detector", "enable/disable encoding detector", 0),
- ECORE_GETOPT_STORE_DEF_BOOL
- ('f', "flattening", "frame flattening.", 0),
- ECORE_GETOPT_STORE_DEF_BOOL
- ('F', "fullscreen", "fullscreen mode.", 0),
- ECORE_GETOPT_CALLBACK_ARGS
- ('g', "geometry", "geometry to use in x:y:w:h form.", "X:Y:W:H",
- ecore_getopt_callback_geometry_parse, NULL),
- ECORE_GETOPT_STORE_STR
- ('t', "theme", "path to read the theme file from."),
- ECORE_GETOPT_STORE_DEF_BOOL
- ('T', "tiled-backing-store", "enable/disable WebCore's tiled backingstore(ewk_view_single only)", 0),
- ECORE_GETOPT_STORE_STR
- ('U', "user-agent", "custom user agent string to use."),
- ECORE_GETOPT_COUNT
- ('v', "verbose", "be more verbose."),
- ECORE_GETOPT_VERSION
- ('V', "version"),
- ECORE_GETOPT_COPYRIGHT
- ('R', "copyright"),
- ECORE_GETOPT_LICENSE
- ('L', "license"),
- ECORE_GETOPT_HELP
- ('h', "help"),
- ECORE_GETOPT_SENTINEL
- }
-};
-
-typedef struct _User_Arguments {
- char *engine;
- Eina_Bool quitOption;
- char *backingStore;
- float device_pixel_ratio;
- Eina_Bool enableEncodingDetector;
- Eina_Bool enableTiledBackingStore;
- Eina_Bool isFlattening;
- Eina_Bool isFullscreen;
- Eina_Rectangle geometry;
- char *theme;
- char *userAgent;
- char *databasePath;
-} User_Arguments;
-
-typedef struct _ELauncher {
- Ecore_Evas *ee;
- Evas *evas;
- Evas_Object *browser;
- Url_Bar *url_bar;
- User_Arguments *userArgs;
-} ELauncher;
-
-static void windowDestroy(Ecore_Evas *ee);
-static void closeWindow(Ecore_Evas *ee);
-static int browserCreate(const char *url, User_Arguments *userArgs);
-static int webInspectorCreate(ELauncher *appBrowser);
-static ELauncher *windowCreate(User_Arguments *userArgs);
-
-static ELauncher *
-find_app_from_ee(Ecore_Evas *ee)
-{
- Eina_List *l;
- void *data;
-
- EINA_LIST_FOREACH(windows, l, data)
- {
- ELauncher *app = (ELauncher *) data;
- if (app->ee == ee)
- return app;
- }
- return NULL;
-}
-
-static void
-print_history(Eina_List *list)
-{
- Eina_List *l;
- void *d;
-
- if (!verbose)
- return;
-
- printf("Session history contains:\n");
-
- EINA_LIST_FOREACH(list, l, d) {
- Ewk_History_Item *item = (Ewk_History_Item*)d;
- cairo_surface_t *cs = ewk_history_item_icon_surface_get(item);
- char buf[PATH_MAX];
- int s = snprintf(buf, sizeof(buf), "/tmp/favicon-%s.png", ewk_history_item_uri_original_get(item));
- for (s--; s >= (int)sizeof("/tmp/favicon-"); s--) {
- if (!isalnum(buf[s]) && buf[s] != '.')
- buf[s] = '_';
- }
- cs = ewk_history_item_icon_surface_get(item);
-
- if (cs && cairo_surface_status(cs) == CAIRO_STATUS_SUCCESS)
- cairo_surface_write_to_png(cs, buf);
- else
- buf[0] = '\0';
-
- printf("* '%s' title='%s' icon='%s'\n",
- ewk_history_item_uri_original_get(item),
- ewk_history_item_title_get(item), buf);
- }
-}
-
-static int
-nearest_zoom_level_get(float factor)
-{
- int i, intFactor = (int)(factor * 100.0);
- for (i = 0; zoomLevels[i] <= intFactor; i++) { }
- printf("factor=%f, intFactor=%d, zoomLevels[%d]=%d, zoomLevels[%d]=%d\n",
- factor, intFactor, i-1, zoomLevels[i-1], i, zoomLevels[i]);
- if (intFactor - zoomLevels[i-1] < zoomLevels[i] - intFactor)
- return i - 1;
- return i;
-}
-
-static Eina_Bool
-zoom_level_set(Evas_Object *webview, int level)
-{
- float factor = ((float) zoomLevels[level]) / 100.0;
- Evas_Coord ox, oy, mx, my, cx, cy;
- evas_pointer_canvas_xy_get(evas_object_evas_get(webview), &mx, &my);
- evas_object_geometry_get(webview, &ox, &oy, NULL, NULL);
- cx = mx - ox;
- cy = my - oy;
- return ewk_view_zoom_animated_set(webview, factor, 0.5, cx, cy);
-}
-
-static void
-on_browser_ecore_evas_resize(Ecore_Evas *ee)
-{
- ELauncher *app;
- Evas_Object *webview;
- int w, h;
-
- ecore_evas_geometry_get(ee, NULL, NULL, &w, &h);
-
- /* Resize URL bar */
- app = find_app_from_ee(ee);
- url_bar_width_set(app->url_bar, w);
-
- webview = evas_object_name_find(ecore_evas_get(ee), "browser");
- evas_object_move(webview, 0, URL_BAR_HEIGHT);
- evas_object_resize(webview, w, h - URL_BAR_HEIGHT);
-}
-
-static void
-on_inspector_ecore_evas_resize(Ecore_Evas *ee)
-{
- Evas_Object *webview;
- int w, h;
-
- ecore_evas_geometry_get(ee, NULL, NULL, &w, &h);
-
- webview = evas_object_name_find(ecore_evas_get(ee), "inspector");
- evas_object_move(webview, 0, 0);
- evas_object_resize(webview, w, h);
-}
-
-static void
-title_set(Ecore_Evas *ee, const Ewk_Text_With_Direction *title, int progress)
-{
- const char *appname = "EFL Test Launcher";
- const char *separator = " - ";
- char label[4096];
- int size;
-
- if (!title || !title->string || !strcmp(title->string, "")) {
- ecore_evas_title_set(ee, appname);
- return;
- }
-
- if (progress < 100)
- size = snprintf(label, sizeof(label), "%s (%d%%)%s%s", title->string, progress, separator, appname);
- else
- size = snprintf(label, sizeof(label), "%s %s%s", title->string, separator, appname);
-
- if (size >= (int)sizeof(label))
- return;
-
- ecore_evas_title_set(ee, label);
-}
-
-static void
-on_title_changed(void *user_data, Evas_Object *webview, void *event_info)
-{
- ELauncher *app = (ELauncher *)user_data;
- const Ewk_Text_With_Direction *title = (const Ewk_Text_With_Direction *)event_info;
-
- title_set(app->ee, title, 100);
-}
-
-static void
-on_progress(void *user_data, Evas_Object *webview, void *event_info)
-{
- ELauncher *app = (ELauncher *)user_data;
- double *progress = (double *)event_info;
-
- title_set(app->ee, ewk_view_title_get(app->browser), *progress * 100);
-}
-
-static void
-on_load_finished(void *user_data, Evas_Object *webview, void *event_info)
-{
- const Ewk_Frame_Load_Error *err = (const Ewk_Frame_Load_Error *)event_info;
-
- if (!err)
- info("Succeeded loading page.");
- else if (err->is_cancellation)
- info("Load was cancelled.");
- else
- info("Failed loading page: %d %s \"%s\", url=%s",
- err->code, err->domain, err->description, err->failing_url);
-
- currentZoom = ewk_view_zoom_get(webview);
- currentZoomLevel = nearest_zoom_level_get(currentZoom);
- info("WebCore Zoom=%f, currentZoomLevel=%d", currentZoom, currentZoomLevel);
-}
-
-static void
-on_load_error(void *user_data, Evas_Object *webview, void *event_info)
-{
- const Ewk_Frame_Load_Error *err = (const Ewk_Frame_Load_Error *)event_info;
- char message[1024];
- snprintf(message, 1024, "<html><body><div style=\"color:#ff0000\">ERROR!</div><br><div>Code: %d<br>Domain: %s<br>Description: %s<br>URL: %s</div></body</html>",
- err->code, err->domain, err->description, err->failing_url);
- ewk_frame_contents_set(err->frame, message, 0, "text/html", "UTF-8", err->failing_url);
-}
-
-static void
-on_toolbars_visible_set(void* user_data, Evas_Object* webview, void* event_info)
-{
- Eina_Bool *visible = (Eina_Bool *)event_info;
- if (*visible) {
- info("Toolbars visible changed: show");
- windowProperties.toolbarsVisible = EINA_TRUE;
- } else {
- info("Toolbars visible changed: hide");
- windowProperties.toolbarsVisible = EINA_FALSE;
- }
-}
-
-static void
-on_toolbars_visible_get(void* user_data, Evas_Object* webview, void* event_info)
-{
- Eina_Bool *visible = (Eina_Bool *)event_info;
- *visible = windowProperties.toolbarsVisible;
-}
-
-static void
-on_statusbar_visible_set(void* user_data, Evas_Object* webview, void* event_info)
-{
- Eina_Bool *visible = (Eina_Bool *)event_info;
- if (*visible) {
- info("Statusbar visible changed: show");
- windowProperties.statusbarVisible = EINA_TRUE;
- } else {
- info("Statusbar visible changed: hide");
- windowProperties.statusbarVisible = EINA_FALSE;
- }
-}
-
-static void
-on_statusbar_visible_get(void* user_data, Evas_Object* webview, void* event_info)
-{
- Eina_Bool *visible = (Eina_Bool *)event_info;
- *visible = windowProperties.statusbarVisible;
-}
-
-static void
-on_scrollbars_visible_set(void* user_data, Evas_Object* webview, void* event_info)
-{
- Eina_Bool *visible = (Eina_Bool *)event_info;
- if (*visible) {
- info("Scrollbars visible changed: show");
- windowProperties.scrollbarsVisible = EINA_TRUE;
- } else {
- info("Scrollbars visible changed: hide");
- windowProperties.scrollbarsVisible = EINA_FALSE;
- }
-}
-
-static void
-on_scrollbars_visible_get(void* user_data, Evas_Object* webview, void* event_info)
-{
- Eina_Bool *visible = (Eina_Bool *)event_info;
- *visible = windowProperties.scrollbarsVisible;
-}
-
-static void
-on_menubar_visible_set(void* user_data, Evas_Object* webview, void* event_info)
-{
- Eina_Bool *visible = (Eina_Bool *)event_info;
- if (*visible) {
- info("Menubar visible changed: show");
- windowProperties.menubarVisible = EINA_TRUE;
- } else {
- info("Menubar visible changed: hide");
- windowProperties.menubarVisible = EINA_FALSE;
- }
-}
-
-static void
-on_menubar_visible_get(void* user_data, Evas_Object* webview, void* event_info)
-{
- Eina_Bool *visible = (Eina_Bool *)event_info;
- *visible = windowProperties.menubarVisible;
-}
-
-static void
-on_tooltip_text_set(void* user_data, Evas_Object* webview, void* event_info)
-{
- const char *text = (const char *)event_info;
- info("Tooltip is set: %s", text);
-}
-
-static void
-on_tooltip_text_unset(void* user_data, Evas_Object* webview, void* event_info)
-{
- info("Tooltip is unset");
-}
-
-static void
-on_inputmethod_changed(void* user_data, Evas_Object* webview, void* event_info)
-{
- Eina_Bool active = (Eina_Bool)(long)event_info;
- unsigned int imh;
- info("Keyboard changed: %d", active);
-
- if (!active)
- return;
-
- imh = ewk_view_imh_get(webview);
- info(" Keyboard flags: %#.2x", imh);
-
-}
-
-static void
-on_url_changed(void* user_data, Evas_Object* webview, void* event_info)
-{
- ELauncher *app = (ELauncher *)user_data;
- url_bar_url_set(app->url_bar, ewk_view_uri_get(app->browser));
-}
-
-static void
-on_mouse_down(void* data, Evas* e, Evas_Object* webview, void* event_info)
-{
- Evas_Event_Mouse_Down *ev = (Evas_Event_Mouse_Down *)event_info;
-
- if (ev->button == 1)
- evas_object_focus_set(webview, EINA_TRUE);
- else if (ev->button == 2)
- evas_object_focus_set(webview, !evas_object_focus_get(webview));
-}
-
-static void
-on_focus_out(void *data, Evas *e, Evas_Object *obj, void *event_info)
-{
- info("the webview lost keyboard focus");
-}
-
-static void
-on_focus_in(void *data, Evas *e, Evas_Object *obj, void *event_info)
-{
- info("the webview gained keyboard focus");
-}
-
-static void
-on_key_down(void *data, Evas *e, Evas_Object *obj, void *event_info)
-{
- Evas_Event_Key_Down *ev = (Evas_Event_Key_Down*) event_info;
- ELauncher *app = data;
- static const char *encodings[] = {
- "ISO-8859-1",
- "UTF-8",
- NULL
- };
- static int currentEncoding = -1;
- const Evas_Modifier *mod = evas_key_modifier_get(e);
- Eina_Bool ctrlPressed = evas_key_modifier_is_set(mod, "Control");
- Eina_Bool altPressed = evas_key_modifier_is_set(mod, "Alt");
-
- if (!strcmp(ev->key, "Escape")) {
- closeWindow(app->ee);
- } else if (!strcmp(ev->key, "Left") && altPressed) {
- info("Back (Alt+Left) was pressed");
- if (ewk_view_back_possible(obj)) {
- Ewk_History *history = ewk_view_history_get(obj);
- Eina_List *list = ewk_history_back_list_get(history);
- print_history(list);
- ewk_history_item_list_free(list);
- ewk_view_back(obj);
- } else
- info("Back ignored: No back history");
- } else if (!strcmp(ev->key, "Right") && altPressed) {
- info("Forward (Alt+Right) was pressed");
- if (ewk_view_forward_possible(obj)) {
- Ewk_History *history = ewk_view_history_get(obj);
- Eina_List *list = ewk_history_forward_list_get(history);
- print_history(list);
- ewk_history_item_list_free(list);
- ewk_view_forward(obj);
- } else
- info("Forward ignored: No forward history");
- } else if (!strcmp(ev->key, "F3")) {
- currentEncoding++;
- currentEncoding %= (sizeof(encodings) / sizeof(encodings[0]));
- info("Set encoding (F3) pressed. New encoding to %s", encodings[currentEncoding]);
- ewk_view_setting_encoding_custom_set(obj, encodings[currentEncoding]);
- } else if (!strcmp(ev->key, "F4")) {
- Evas_Object *frame = ewk_view_frame_main_get(obj);
- Evas_Coord x, y;
- Ewk_Hit_Test *ht;
-
- evas_pointer_canvas_xy_get(evas_object_evas_get(obj), &x, &y);
- ht = ewk_frame_hit_test_new(frame, x, y);
- if (!ht)
- printf("No hit test returned for point %d,%d\n", x, y);
- else {
- printf("Hit test for point %d,%d\n"
- " pos=%3d,%3d\n"
- " bounding_box=%d,%d + %dx%d\n"
- " title='%s'\n"
- " alternate_text='%s'\n"
- " frame=%p (%s)\n"
- " link {\n"
- " text='%s'\n"
- " url='%s'\n"
- " title='%s'\n"
- " target frame=%p (%s)\n"
- " }\n"
- "context:\n"
- "%s"
- "%s"
- "%s"
- "%s"
- "%s\n",
- x, y,
- ht->x, ht->y,
- ht->bounding_box.x, ht->bounding_box.y, ht->bounding_box.w, ht->bounding_box.h,
- ht->title.string,
- ht->alternate_text,
- ht->frame, evas_object_name_get(ht->frame),
- ht->link.text,
- ht->link.url,
- ht->link.title,
- ht->link.target_frame, evas_object_name_get(ht->link.target_frame),
- ht->context & EWK_HIT_TEST_RESULT_CONTEXT_LINK ? " LINK\n" : "",
- ht->context & EWK_HIT_TEST_RESULT_CONTEXT_IMAGE ? " IMAGE\n" : "",
- ht->context & EWK_HIT_TEST_RESULT_CONTEXT_MEDIA ? " MEDIA\n" : "",
- ht->context & EWK_HIT_TEST_RESULT_CONTEXT_SELECTION ? " SELECTION\n" : "",
- ht->context & EWK_HIT_TEST_RESULT_CONTEXT_EDITABLE ? " EDITABLE" : "");
- ewk_frame_hit_test_free(ht);
- }
-
- } else if (!strcmp(ev->key, "F5")) {
- info("Reload (F5) was pressed, reloading.");
- ewk_view_reload(obj);
- } else if (!strcmp(ev->key, "F6")) {
- info("Stop (F6) was pressed, stop loading.");
- ewk_view_stop(obj);
- } else if (!strcmp(ev->key, "F12")) {
- Eina_Bool status = ewk_view_setting_spatial_navigation_get(obj);
- ewk_view_setting_spatial_navigation_set(obj, !status);
- info("Command::keyboard navigation toggle");
- } else if ((!strcmp(ev->key, "minus") || !strcmp(ev->key, "KP_Subtract")) && ctrlPressed) {
- if (currentZoomLevel > MIN_ZOOM_LEVEL && zoom_level_set(obj, currentZoomLevel - 1))
- currentZoomLevel--;
- info("Zoom out (Ctrl + '-') was pressed, zoom level became %.2f", zoomLevels[currentZoomLevel] / 100.0);
- } else if ((!strcmp(ev->key, "equal") || !strcmp(ev->key, "KP_Add")) && ctrlPressed) {
- if (currentZoomLevel < MAX_ZOOM_LEVEL && zoom_level_set(obj, currentZoomLevel + 1))
- currentZoomLevel++;
- info("Zoom in (Ctrl + '+') was pressed, zoom level became %.2f", zoomLevels[currentZoomLevel] / 100.0);
- } else if (!strcmp(ev->key, "0") && ctrlPressed) {
- if (zoom_level_set(obj, DEFAULT_ZOOM_LEVEL))
- currentZoomLevel = DEFAULT_ZOOM_LEVEL;
- info("Zoom to default (Ctrl + '0') was pressed, zoom level became %.2f", zoomLevels[currentZoomLevel] / 100.0);
- } else if (!strcmp(ev->key, "n") && ctrlPressed) {
- info("Create new window (Ctrl+n) was pressed.");
- browserCreate("http://www.google.com", app->userArgs);
- } else if (!strcmp(ev->key, "g") && ctrlPressed ) {
- Evas_Coord x, y, w, h;
- Evas_Object *frame = ewk_view_frame_main_get(obj);
- float zoom = zoomLevels[currentZoomLevel] / 100.0;
-
- ewk_frame_visible_content_geometry_get(frame, EINA_FALSE, &x, &y, &w, &h);
- x -= w;
- y -= h;
- w *= 4;
- h *= 4;
- info("Pre-render %d,%d + %dx%d", x, y, w, h);
- ewk_view_pre_render_region(obj, x, y, w, h, zoom);
- } else if (!strcmp(ev->key, "r") && ctrlPressed) {
- info("Pre-render 1 extra column/row with current zoom");
- ewk_view_pre_render_relative_radius(obj, 1);
- } else if (!strcmp(ev->key, "p") && ctrlPressed) {
- info("Pre-rendering start");
- ewk_view_pre_render_start(obj);
- } else if (!strcmp(ev->key, "d") && ctrlPressed) {
- info("Render suspended");
- ewk_view_disable_render(obj);
- } else if (!strcmp(ev->key, "e") && ctrlPressed) {
- info("Render resumed");
- ewk_view_enable_render(obj);
- } else if (!strcmp(ev->key, "s") && ctrlPressed) {
- Evas_Object *frame = ewk_view_frame_main_get(obj);
- Ewk_Security_Origin *origin = ewk_frame_security_origin_get(frame);
- printf("Security origin information:\n"
- " protocol=%s\n"
- " host=%s\n"
- " port=%d\n"
- " web database quota=%" PRIu64 "\n",
- ewk_security_origin_protocol_get(origin),
- ewk_security_origin_host_get(origin),
- ewk_security_origin_port_get(origin),
- ewk_security_origin_web_database_quota_get(origin));
-
- Eina_List *databaseList = ewk_security_origin_web_database_get_all(origin);
- Eina_List *listIterator = 0;
- Ewk_Web_Database *database;
- EINA_LIST_FOREACH(databaseList, listIterator, database)
- printf("Database information:\n"
- " name=%s\n"
- " display name=%s\n"
- " filename=%s\n"
- " expected size=%" PRIu64 "\n"
- " size=%" PRIu64 "\n",
- ewk_web_database_name_get(database),
- ewk_web_database_display_name_get(database),
- ewk_web_database_filename_get(database),
- ewk_web_database_expected_size_get(database),
- ewk_web_database_size_get(database));
-
- ewk_security_origin_free(origin);
- ewk_web_database_list_free(databaseList);
- } else if (!strcmp(ev->key, "i") && ctrlPressed) {
- Evas_Object *inspector_view = ewk_view_inspector_view_get(obj);
- if (inspector_view) {
- info("Web Inspector close");
- ewk_view_inspector_close(obj);
- } else {
- info("Web Inspector show");
- ewk_view_inspector_show(obj);
- }
- }
-}
-
-static void
-on_browser_del(void *data, Evas *evas, Evas_Object *browser, void *event)
-{
- ELauncher *app = (ELauncher*) data;
-
- evas_object_event_callback_del(app->browser, EVAS_CALLBACK_KEY_DOWN, on_key_down);
- evas_object_event_callback_del(app->browser, EVAS_CALLBACK_MOUSE_DOWN, on_mouse_down);
- evas_object_event_callback_del(app->browser, EVAS_CALLBACK_FOCUS_IN, on_focus_in);
- evas_object_event_callback_del(app->browser, EVAS_CALLBACK_FOCUS_OUT, on_focus_out);
- evas_object_event_callback_del(app->browser, EVAS_CALLBACK_DEL, on_browser_del);
-}
-
-static void
-on_inspector_view_create(void *user_data, Evas_Object *webview, void *event_info)
-{
- ELauncher *app_browser = (ELauncher *)user_data;
-
- webInspectorCreate(app_browser);
-}
-
-static void
-on_inspector_view_close(void *user_data, Evas_Object *webview, void *event_info)
-{
- Eina_List *l;
- void *app;
- ELauncher *app_browser = (ELauncher *)user_data;
- Evas_Object *inspector_view = (Evas_Object *)event_info;
-
- ewk_view_inspector_view_set(app_browser->browser, NULL);
-
- EINA_LIST_FOREACH(windows, l, app)
- if (((ELauncher *)app)->browser == inspector_view)
- break;
-
- windows = eina_list_remove(windows, app);
- windowDestroy(((ELauncher *)app)->ee);
- free(app);
-}
-
-static void
-on_inspector_view_destroyed(Ecore_Evas *ee)
-{
- ELauncher *app;
-
- app = find_app_from_ee(ee);
- evas_object_smart_callback_call(app->browser, "inspector,view,destroy", NULL);
-}
-
-static int
-quit(Eina_Bool success, const char *msg)
-{
- edje_shutdown();
- ecore_evas_shutdown();
- ecore_file_shutdown();
-
- if (msg)
- fputs(msg, (success) ? stdout : stderr);
-
- if (themePath) {
- free(themePath);
- themePath = NULL;
- }
-
- if (!success)
- return EXIT_FAILURE;
-
- return EXIT_SUCCESS;
-}
-
-static int
-browserCreate(const char *url, User_Arguments *userArgs)
-{
- ELauncher *appBrowser = windowCreate(userArgs);
- if (!appBrowser)
- return quit(EINA_FALSE, "ERROR: could not create a browser window\n");
-
- ecore_evas_title_set(appBrowser->ee, "EFL Test Launcher");
- ecore_evas_callback_resize_set(appBrowser->ee, on_browser_ecore_evas_resize);
- ecore_evas_callback_delete_request_set(appBrowser->ee, closeWindow);
-
- evas_object_name_set(appBrowser->browser, "browser");
-
- evas_object_smart_callback_add(appBrowser->browser, "inputmethod,changed", on_inputmethod_changed, appBrowser);
- evas_object_smart_callback_add(appBrowser->browser, "inspector,view,close", on_inspector_view_close, appBrowser);
- evas_object_smart_callback_add(appBrowser->browser, "inspector,view,create", on_inspector_view_create, appBrowser);
- evas_object_smart_callback_add(appBrowser->browser, "load,error", on_load_error, appBrowser);
- evas_object_smart_callback_add(appBrowser->browser, "load,finished", on_load_finished, appBrowser);
- evas_object_smart_callback_add(appBrowser->browser, "load,progress", on_progress, appBrowser);
- evas_object_smart_callback_add(appBrowser->browser, "menubar,visible,get", on_menubar_visible_get, appBrowser);
- evas_object_smart_callback_add(appBrowser->browser, "menubar,visible,set", on_menubar_visible_set, appBrowser);
- evas_object_smart_callback_add(appBrowser->browser, "scrollbars,visible,get", on_scrollbars_visible_get, appBrowser);
- evas_object_smart_callback_add(appBrowser->browser, "scrollbars,visible,set", on_scrollbars_visible_set, appBrowser);
- evas_object_smart_callback_add(appBrowser->browser, "statusbar,visible,get", on_statusbar_visible_get, appBrowser);
- evas_object_smart_callback_add(appBrowser->browser, "statusbar,visible,set", on_statusbar_visible_set, appBrowser);
- evas_object_smart_callback_add(appBrowser->browser, "title,changed", on_title_changed, appBrowser);
- evas_object_smart_callback_add(appBrowser->browser, "toolbars,visible,get", on_toolbars_visible_get, appBrowser);
- evas_object_smart_callback_add(appBrowser->browser, "toolbars,visible,set", on_toolbars_visible_set, appBrowser);
- evas_object_smart_callback_add(appBrowser->browser, "tooltip,text,set", on_tooltip_text_set, appBrowser);
- evas_object_smart_callback_add(appBrowser->browser, "tooltip,text,unset", on_tooltip_text_unset, appBrowser);
- evas_object_smart_callback_add(appBrowser->browser, "uri,changed", on_url_changed, appBrowser);
-
- evas_object_event_callback_add(appBrowser->browser, EVAS_CALLBACK_DEL, on_browser_del, appBrowser);
- evas_object_event_callback_add(appBrowser->browser, EVAS_CALLBACK_FOCUS_IN, on_focus_in, appBrowser);
- evas_object_event_callback_add(appBrowser->browser, EVAS_CALLBACK_FOCUS_OUT, on_focus_out, appBrowser);
- evas_object_event_callback_add(appBrowser->browser, EVAS_CALLBACK_KEY_DOWN, on_key_down, appBrowser);
- evas_object_event_callback_add(appBrowser->browser, EVAS_CALLBACK_MOUSE_DOWN, on_mouse_down, appBrowser);
-
- ewk_view_setting_enable_developer_extras_set(appBrowser->browser, EINA_TRUE);
-
- appBrowser->url_bar = url_bar_add(appBrowser->browser, DEFAULT_WIDTH);
-
- evas_object_move(appBrowser->browser, 0, URL_BAR_HEIGHT);
- evas_object_resize(appBrowser->browser, userArgs->geometry.w, userArgs->geometry.h - URL_BAR_HEIGHT);
-
- ewk_view_uri_set(appBrowser->browser, url);
-
- evas_object_show(appBrowser->browser);
- ecore_evas_show(appBrowser->ee);
-
- evas_object_focus_set(appBrowser->browser, EINA_TRUE);
-
- return 1;
-}
-
-static int
-webInspectorCreate(ELauncher *appBrowser)
-{
- ELauncher *appInspector = windowCreate(appBrowser->userArgs);
- if (!appInspector)
- return quit(EINA_FALSE, "ERROR: could not create an inspector window\n");
-
- ecore_evas_title_set(appInspector->ee, "Web Inspector");
- ecore_evas_callback_resize_set(appInspector->ee, on_inspector_ecore_evas_resize);
- ecore_evas_callback_delete_request_set(appInspector->ee, on_inspector_view_destroyed);
-
- evas_object_name_set(appInspector->browser, "inspector");
-
- evas_object_move(appInspector->browser, 0, 0);
- evas_object_resize(appInspector->browser, appInspector->userArgs->geometry.w, appInspector->userArgs->geometry.h);
-
- evas_object_show(appInspector->browser);
- ecore_evas_show(appInspector->ee);
-
- evas_object_focus_set(appInspector->browser, EINA_TRUE);
-
- ewk_view_inspector_view_set(appBrowser->browser, appInspector->browser);
-
- return 1;
-}
-
-static ELauncher *
-windowCreate(User_Arguments *userArgs)
-{
- ELauncher *app = (ELauncher *)malloc(sizeof(ELauncher));
- if (!app) {
- quit(EINA_FALSE, "ERROR: could not create an ELauncher\n");
- return NULL;
- }
-
-#if defined(WTF_USE_ACCELERATED_COMPOSITING) && defined(HAVE_ECORE_X)
- if (userArgs->engine)
-#endif
- app->ee = ecore_evas_new(userArgs->engine, 0, 0, userArgs->geometry.w, userArgs->geometry.h, NULL);
-#if defined(WTF_USE_ACCELERATED_COMPOSITING) && defined(HAVE_ECORE_X)
- else {
- const char* engine = "opengl_x11";
- app->ee = ecore_evas_new(engine, 0, 0, userArgs->geometry.w, userArgs->geometry.h, NULL);
- }
-#endif
- if (!app->ee) {
- quit(EINA_FALSE, "ERROR: could not construct evas-ecore\n");
- return NULL;
- }
-
- if (userArgs->isFullscreen)
- ecore_evas_fullscreen_set(app->ee, EINA_TRUE);
-
- app->evas = ecore_evas_get(app->ee);
- if (!app->evas) {
- quit(EINA_FALSE, "ERROR: could not get evas from evas-ecore\n");
- return NULL;
- }
-
- if (userArgs->backingStore && !strcasecmp(userArgs->backingStore, "tiled")) {
- app->browser = ewk_view_tiled_add(app->evas);
- info("backing store: tiled");
- } else {
- app->browser = ewk_view_single_add(app->evas);
- info("backing store: single");
-
- ewk_view_setting_tiled_backing_store_enabled_set(app->browser, userArgs->enableTiledBackingStore);
- }
-
- ewk_view_theme_set(app->browser, themePath);
- if (userArgs->userAgent)
- ewk_view_setting_user_agent_set(app->browser, userArgs->userAgent);
-
- ewk_view_setting_local_storage_database_path_set(app->browser, userArgs->databasePath);
- ewk_view_setting_enable_frame_flattening_set(app->browser, userArgs->isFlattening);
- ewk_view_setting_encoding_detector_set(app->browser, userArgs->enableEncodingDetector);
- ewk_view_device_pixel_ratio_set(app->browser, userArgs->device_pixel_ratio);
-
- app->userArgs = userArgs;
- app->url_bar = NULL;
-
- windows = eina_list_append(windows, app);
-
- return app;
-}
-
-static void
-windowDestroy(Ecore_Evas *ee)
-{
- ecore_evas_free(ee);
- if (!eina_list_count(windows))
- ecore_main_loop_quit();
-}
-
-static void
-closeWindow(Ecore_Evas *ee)
-{
- ELauncher *app;
-
- app = find_app_from_ee(ee);
- ewk_view_inspector_close(app->browser);
-
- windows = eina_list_remove(windows, app);
- url_bar_del(app->url_bar);
- windowDestroy(ee);
- free(app);
-}
-
-static Eina_Bool
-main_signal_exit(void *data, int ev_type, void *ev)
-{
- ELauncher *app;
- while (windows) {
- app = (ELauncher*) eina_list_data_get(windows);
- ewk_view_inspector_close(app->browser);
-
- ecore_evas_free(app->ee);
- windows = eina_list_remove(windows, app);
- }
- if (!eina_list_count(windows))
- ecore_main_loop_quit();
- return EINA_TRUE;
-}
-
-static char *
-findThemePath(const char *theme)
-{
- const char *default_theme = TEST_THEME_DIR "/default.edj";
- char *rpath;
- struct stat st;
-
- if (!theme)
- theme = default_theme;
-
- rpath = ecore_file_realpath(theme);
-
- if (!strlen(rpath) || stat(rpath, &st)) {
- free(rpath);
- return NULL;
- }
-
- return rpath;
-}
-
-int
-parseUserArguments(int argc, char *argv[], User_Arguments *userArgs)
-{
- int args;
-
- userArgs->engine = NULL;
- userArgs->quitOption = EINA_FALSE;
- userArgs->backingStore = (char *)backingStores[1];
- userArgs->device_pixel_ratio = 1.0;
- userArgs->enableEncodingDetector = EINA_FALSE;
- userArgs->enableTiledBackingStore = EINA_FALSE;
- userArgs->isFlattening = EINA_FALSE;
- userArgs->isFullscreen = EINA_FALSE;
- userArgs->geometry.x = 0;
- userArgs->geometry.y = 0;
- userArgs->geometry.w = 0;
- userArgs->geometry.h = 0;
- userArgs->theme = NULL;
- userArgs->userAgent = NULL;
-
- Ecore_Getopt_Value values[] = {
- ECORE_GETOPT_VALUE_STR(userArgs->engine),
- ECORE_GETOPT_VALUE_BOOL(userArgs->quitOption),
- ECORE_GETOPT_VALUE_STR(userArgs->backingStore),
- ECORE_GETOPT_VALUE_DOUBLE(userArgs->device_pixel_ratio),
- ECORE_GETOPT_VALUE_BOOL(userArgs->enableEncodingDetector),
- ECORE_GETOPT_VALUE_BOOL(userArgs->isFlattening),
- ECORE_GETOPT_VALUE_BOOL(userArgs->isFullscreen),
- ECORE_GETOPT_VALUE_PTR_CAST(userArgs->geometry),
- ECORE_GETOPT_VALUE_STR(userArgs->theme),
- ECORE_GETOPT_VALUE_BOOL(userArgs->enableTiledBackingStore),
- ECORE_GETOPT_VALUE_STR(userArgs->userAgent),
- ECORE_GETOPT_VALUE_INT(verbose),
- ECORE_GETOPT_VALUE_BOOL(userArgs->quitOption),
- ECORE_GETOPT_VALUE_BOOL(userArgs->quitOption),
- ECORE_GETOPT_VALUE_BOOL(userArgs->quitOption),
- ECORE_GETOPT_VALUE_BOOL(userArgs->quitOption),
- ECORE_GETOPT_VALUE_NONE
- };
-
- ecore_app_args_set(argc, (const char**) argv);
- args = ecore_getopt_parse(&options, values, argc, argv);
-
- themePath = findThemePath(userArgs->theme);
-
- if ((userArgs->geometry.w <= 0) || (userArgs->geometry.h <= 0)) {
- userArgs->geometry.w = DEFAULT_WIDTH;
- userArgs->geometry.h = DEFAULT_HEIGHT;
- }
-
- return args;
-}
-
-int
-main(int argc, char *argv[])
-{
- const char *default_url = "http://www.google.com/";
- const char *tmp;
- const char *proxyUri;
- char path[PATH_MAX];
- int args;
-
- User_Arguments userArgs;
-
- if (!ewk_init())
- return EXIT_FAILURE;
-
- if (!ecore_file_init()) {
- ewk_shutdown();
- return EXIT_FAILURE;
- }
-
- args = parseUserArguments(argc, argv, &userArgs);
- if (args < 0)
- return quit(EINA_FALSE, "ERROR: could not parse options.\n");
-
- if (userArgs.quitOption)
- return quit(EINA_TRUE, NULL);
-
- if (!themePath)
- return quit(EINA_FALSE, "ERROR: could not find theme.\n");
-
- tmp = getenv("TMPDIR");
- if (!tmp)
- tmp = "/tmp";
- snprintf(path, sizeof(path), "%s/.ewebkit-%u", tmp, getuid());
- if (!ecore_file_mkpath(path))
- return quit(EINA_FALSE, "ERROR: could not create settings database directory.\n");
-
- userArgs.databasePath = path;
-
- ewk_settings_icon_database_path_set(path);
- ewk_settings_web_database_path_set(path);
-
- proxyUri = getenv("http_proxy");
- if (proxyUri)
- ewk_network_proxy_uri_set(proxyUri);
-
- if (args < argc) {
- char *url = url_from_user_input(argv[args]);
- browserCreate(url, &userArgs);
- free(url);
- } else
- browserCreate(default_url, &userArgs);
-
- ecore_event_handler_add(ECORE_EVENT_SIGNAL_EXIT, main_signal_exit, &windows);
-
- ecore_main_loop_begin();
-
- ecore_file_shutdown();
- ewk_shutdown();
-
- return quit(EINA_TRUE, NULL);
-}