// -*- Mode: C++; indent-tabs-mode: nil; c-basic-offset: 2 -*- /* Copyright (C) 2007 The gtkmm Development Team * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include #include #include #include #include #include #include //#include #include _DEFS(giomm,gio) _PINCLUDE(glibmm/private/interface_p.h) _PINCLUDE(glibmm/private/object_p.h) #ifndef DOXYGEN_SHOULD_SKIP_THIS typedef struct _GAppInfoIface GAppInfoIface; #endif /* DOXYGEN_SHOULD_SKIP_THIS */ namespace Gio { _WRAP_ENUM(AppInfoCreateFlags, GAppInfoCreateFlags, NO_GTYPE) class File; /** Application information, to describe applications installed on the system, * and launch them. * See also AppLaunchContext. * * @newin{2,16} */ class AppInfo : public Glib::Interface { _CLASS_INTERFACE(AppInfo, GAppInfo, G_APP_INFO, GAppInfoIface) public: static Glib::RefPtr create_from_commandline(const std::string& commandline, const std::string& application_name, AppInfoCreateFlags flags); //_IGNORE(g_app_info_dup) _IGNORE(g_app_info_equal) // Note that the implementation of equal() is virtual via equal_vfunc(). _WRAP_METHOD(bool equal(const Glib::RefPtr& other) const, g_app_info_equal) _WRAP_METHOD(std::string get_id() const, g_app_info_get_id) _WRAP_METHOD(std::string get_name() const, g_app_info_get_name) _WRAP_METHOD(std::string get_display_name() const, g_app_info_get_display_name) _WRAP_METHOD(std::string get_description() const, g_app_info_get_description) _WRAP_METHOD(std::string get_executable() const, g_app_info_get_executable) _WRAP_METHOD(std::string get_commandline() const, g_app_info_get_commandline) _WRAP_METHOD(Glib::RefPtr get_icon(), g_app_info_get_icon, refreturn) _WRAP_METHOD(const Glib::RefPtr get_icon() const, g_app_info_get_icon, refreturn, constversion) #m4 _CONVERSION(`const std::vector< Glib::RefPtr >&',`GList*',`Glib::ListHandler >::vector_to_list($3).data ()') /** Launches the application. This passes the @a file to the launched application * as an argument, using the optional @a launch_context to get information * about the details of the launcher (like what screen it is on). * On error, an exception will be thrown accordingly. * * Note that even if the launch is successful the application launched * can fail to start if it runs into problems during startup. There is * no way to detect this. * * Some URIs can be changed when passed through a GFile (for instance * unsupported uris with strange formats like mailto:), so if you have * a textual uri you want to pass in as argument, consider using * launch_uris() instead. * * On UNIX, this function sets the GIO_LAUNCHED_DESKTOP_FILE * environment variable with the path of the launched desktop file and * GIO_LAUNCHED_DESKTOP_FILE_PID to the process * id of the launched process. This can be used to ignore * GIO_LAUNCHED_DESKTOP_FILE, should it be inherited * by further processes. The DISPLAY and * DESKTOP_STARTUP_ID environment variables are also * set, based on information provided in @a launch_context. * @param files A List of File objects. * @param launch_context An AppLaunchContext. * @return true on successful launch, false otherwise. * * @newin{3,2} */ bool launch(const Glib::RefPtr& file, const Glib::RefPtr& launch_context); /** Launches the application. This passes the @a file to the launched application * as an arguments. * On error, an exception will be thrown accordingly. * * Note that even if the launch is successful the application launched * can fail to start if it runs into problems during startup. There is * no way to detect this. * * Some URIs can be changed when passed through a GFile (for instance * unsupported uris with strange formats like mailto:), so if you have * a textual uri you want to pass in as argument, consider using * launch_uris() instead. * * On UNIX, this function sets the GIO_LAUNCHED_DESKTOP_FILE * environment variable with the path of the launched desktop file and * GIO_LAUNCHED_DESKTOP_FILE_PID to the process * id of the launched process. This can be used to ignore * GIO_LAUNCHED_DESKTOP_FILE, should it be inherited * by further processes. The DISPLAY and * DESKTOP_STARTUP_ID environment variables are also * set, based on information provided in @a launch_context. * @param files A File object. * @return true on successful launch, false otherwise. * * @newin{3,2} */ bool launch(const Glib::RefPtr& file); _WRAP_METHOD(bool launch(const std::vector< Glib::RefPtr >& files, const Glib::RefPtr& launch_context{?}), g_app_info_launch, errthrow) _WRAP_METHOD(bool supports_uris() const, g_app_info_supports_uris) _WRAP_METHOD(bool supports_files() const, g_app_info_supports_files) #m4 _CONVERSION(`const Glib::ListHandle&',`GList*',`$3.data()') _WRAP_METHOD(bool launch_uris(const Glib::ListHandle& uris, GAppLaunchContext* launch_context), g_app_info_launch_uris, errthrow, deprecated "Use the method that takes an AppLaunchContext") //TODO: I think we use Glib::ustring elsewhere for URIs: _WRAP_METHOD(bool launch_uris(const Glib::ListHandle& uris, const Glib::RefPtr& launch_context{?}), g_app_info_launch_uris, errthrow) /** Launches the application. This passes the @a uri to the launched application * as an arguments, using the optional @a launch_context to get information * about the details of the launcher (like what screen it is on). * On error, an exception will be thrown accordingly. * * Note that even if the launch is successful the application launched * can fail to start if it runs into problems during startup. There is * no way to detect this. * @param uris A URIs to launch. * @param launch_context An AppLaunchContext. * @return true on successful launch, false otherwise. * * @newin{3,2} */ bool launch_uri(const std::string& uris, const Glib::RefPtr& launch_context); /** A launch_uri() convenience overload. * * @newin{3,2} */ bool launch_uri(const std::string& uris); _WRAP_METHOD(bool should_show() const, g_app_info_should_show) // FIXME: use better terminology than delete/do_delete _WRAP_METHOD(bool can_delete() const, g_app_info_can_delete) _WRAP_METHOD(bool do_delete(), g_app_info_delete) _WRAP_METHOD(bool set_as_default_for_type(const std::string& content_type), g_app_info_set_as_default_for_type, errthrow) _WRAP_METHOD(bool set_as_default_for_extension(const std::string& extension), g_app_info_set_as_default_for_extension, errthrow) _WRAP_METHOD(bool add_supports_type(const std::string& content_type), g_app_info_add_supports_type, errthrow) _WRAP_METHOD(bool can_remove_supports_type() const, g_app_info_can_remove_supports_type) _WRAP_METHOD(bool remove_supports_type(const std::string& content_type), g_app_info_remove_supports_type, errthrow) #m4 _CONVERSION(`const char**', `Glib::StringArrayHandle', `Glib::StringArrayHandle($3, Glib::OWNERSHIP_NONE)') _WRAP_METHOD(Glib::StringArrayHandle get_supported_types() const, g_app_info_get_supported_types) _WRAP_METHOD(bool set_as_last_used_for_type(const std::string& content_type), g_app_info_set_as_last_used_for_type, errthrow) #m4 _CONVERSION(`GList*',`Glib::ListHandle >',`Glib::ListHandle >($3, Glib::OWNERSHIP_SHALLOW)') _WRAP_METHOD(static Glib::ListHandle > get_all(), g_app_info_get_all) _WRAP_METHOD(static Glib::ListHandle > get_all_for_type(const std::string& content_type), g_app_info_get_all_for_type) _WRAP_METHOD(static Glib::RefPtr get_default_for_type(const std::string& content_type, bool must_support_uris = true), g_app_info_get_default_for_type) _WRAP_METHOD(static Glib::RefPtr get_default_for_uri_scheme(const std::string& uri_scheme), g_app_info_get_default_for_uri_scheme) _WRAP_METHOD(static void reset_type_associations(const std::string& content_type), g_app_info_reset_type_associations) _WRAP_METHOD(static bool launch_default_for_uri(const std::string& uri, const Glib::RefPtr& context), g_app_info_launch_default_for_uri, errthrow) // same as above but without optional AppLaunchContext static bool launch_default_for_uri(const std::string& uri); protected: //_WRAP_VFUNC(Glib::RefPtr dup(), "dup") //_WRAP_VFUNC(bool equal(const Glib::RefPtr& appinfo2), "equal") //_WRAP_VFUNC(std::string get_id() const, "get_id") //_WRAP_VFUNC(std::string get_name() const, "get_name") //_WRAP_VFUNC(std::string get_description() const, "get_description") //_WRAP_VFUNC(std::string get_executable() const, "get_executable") //_WRAP_VFUNC(Glib::RefPtr get_icon() const, "get_icon") //#m4 _CONVERSION(`const Glib::ListHandle&',`GList*',`$3.data()') //#m4 _CONVERSION(`GList*',`const Glib::ListHandle&',`Glib::ListHandle($3, Glib::OWNERSHIP_NONE)') //_WRAP_VFUNC(bool launch(const std::vector& filenames, const Glib::RefPtr& launch_context, GError** error), "launch") //_WRAP_VFUNC(bool supports_uris() const, "supports_uris") //_WRAP_VFUNC(bool supports_files() const, "supports_files") //_WRAP_VFUNC(bool launch_uris(const Glib::ListHandle& uris, const Glib::RefPtr& launch_context, GError** error), "launch_uris") //_WRAP_VFUNC(bool should_show() const, "should_show") //_WRAP_VFUNC(bool set_as_default_for_type(const std::string& content_type, GError** error), "set_as_default_for_type") //_WRAP_VFUNC(bool set_as_default_for_extension(const std::string& extension, GError** error), "set_as_default_for_extension") //_WRAP_VFUNC(bool add_supports_type(const std::string& content_type, GError** error), "add_supports_type") //_WRAP_VFUNC(bool can_remove_supports_type() const, "can_remove_supports_type") //_WRAP_VFUNC(bool remove_supports_type(const std::string& content_type, GError** error), "remove_supports_type") }; } // namespace Gio