/* * Copyright © 2004 Christian Persch * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2, or (at your option) * any later version. * * This program 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * */ #include "config.h" #include "ephy-link.h" #include "ephy-embed-utils.h" #include "ephy-type-builtins.h" #include "ephy-signal-accumulator.h" #include "ephy-gui.h" #include "ephy-debug.h" enum { OPEN_LINK, LAST_SIGNAL }; static guint signals[LAST_SIGNAL]; static void ephy_link_base_init (gpointer g_class) { static gboolean initialised = FALSE; if (!initialised) { /** * EphyLink::open-link: * @address: the address of @link * @embed: #EphyEmbed associated with @link * @flags: flags for @link * * The ::open-link signal is emitted when @link is requested to * open it's associated @address. * * Returns: (transfer none): the #EphyEmbed where @address has * been handled. **/ signals[OPEN_LINK] = g_signal_new ("open-link", EPHY_TYPE_LINK, G_SIGNAL_RUN_LAST, G_STRUCT_OFFSET (EphyLinkIface, open_link), ephy_signal_accumulator_object, ephy_embed_get_type, g_cclosure_marshal_generic, GTK_TYPE_WIDGET /* Can't use an interface type here */, 3, G_TYPE_STRING, GTK_TYPE_WIDGET /* Can't use an interface type here */, EPHY_TYPE_LINK_FLAGS); initialised = TRUE; } } GType ephy_link_get_type (void) { static GType type = 0; if (G_UNLIKELY (type == 0)) { const GTypeInfo our_info = { sizeof (EphyLinkIface), ephy_link_base_init, NULL, }; type = g_type_register_static (G_TYPE_INTERFACE, "EphyLink", &our_info, (GTypeFlags)0); } return type; } /** * ephy_link_open: * @link: an #EphyLink object * @address: the address of @link * @embed: #EphyEmbed associated with @link * @flags: flags for @link * * Triggers @link open action. * * Returns: (transfer none): the #EphyEmbed where @link opened. */ EphyEmbed * ephy_link_open (EphyLink *link, const char *address, EphyEmbed *embed, EphyLinkFlags flags) { EphyEmbed *new_embed = NULL; LOG ("ephy_link_open address \"%s\" parent-embed %p flags %u", address, embed, flags); g_signal_emit (link, signals[OPEN_LINK], 0, address, embed, flags, &new_embed); return new_embed; } EphyLinkFlags ephy_link_flags_from_current_event (void) { GdkEventType type = GDK_NOTHING; guint state = 0, button = (guint) -1; EphyLinkFlags flags = 0; ephy_gui_get_current_event (&type, &state, &button); if (button == 2 && (type == GDK_BUTTON_PRESS || type == GDK_BUTTON_RELEASE)) { if (state == GDK_SHIFT_MASK) { flags = EPHY_LINK_NEW_WINDOW; } else if (state == 0 || state == GDK_CONTROL_MASK) { flags = EPHY_LINK_NEW_TAB | EPHY_LINK_NEW_TAB_APPEND_AFTER; } } else { if (state == (GDK_CONTROL_MASK | GDK_SHIFT_MASK)) { flags = EPHY_LINK_NEW_WINDOW; } else if (state == GDK_CONTROL_MASK) { flags = EPHY_LINK_NEW_TAB | EPHY_LINK_NEW_TAB_APPEND_AFTER; } } return flags; }