move wxLaunch* code in utilsx11.cpp as utilsunx.cpp is not compiled for wxCore
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@57937 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -942,7 +942,7 @@ void wxQsort(void *const pbase, size_t total_elems,
|
|||||||
// implemented in a port-specific utils source file:
|
// implemented in a port-specific utils source file:
|
||||||
bool wxDoLaunchDefaultBrowser(const wxString& url, const wxString& scheme, int flags);
|
bool wxDoLaunchDefaultBrowser(const wxString& url, const wxString& scheme, int flags);
|
||||||
|
|
||||||
#elif defined(__UNIX__) || defined(__WXCOCOA__) || \
|
#elif defined(__WXX11__) || defined(__WXGTK__) || defined(__WXMOTIF__) || defined(__WXCOCOA__) || \
|
||||||
(defined(__WXMAC__) && !defined(__WXOSX_IPHONE__))
|
(defined(__WXMAC__) && !defined(__WXOSX_IPHONE__))
|
||||||
|
|
||||||
// implemented in a port-specific utils source file:
|
// implemented in a port-specific utils source file:
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
// Name: src/unix/utilsunx.cpp
|
// Name: src/unix/utilsunx.cpp
|
||||||
// Purpose: generic Unix implementation of many wx functions
|
// Purpose: generic Unix implementation of many wx functions (for wxBase)
|
||||||
// Author: Vadim Zeitlin
|
// Author: Vadim Zeitlin
|
||||||
// Id: $Id$
|
// Id: $Id$
|
||||||
// Copyright: (c) 1998 Robert Roebling, Vadim Zeitlin
|
// Copyright: (c) 1998 Robert Roebling, Vadim Zeitlin
|
||||||
@@ -434,87 +434,6 @@ private:
|
|||||||
|
|
||||||
} // anonymous namespace
|
} // anonymous namespace
|
||||||
|
|
||||||
// these functions are in src/osx/carbon/utils.cpp for wxMac
|
|
||||||
#ifndef __WXMAC__
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// Launch document with default app
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
bool wxLaunchDefaultApplication(const wxString& document, int flags)
|
|
||||||
{
|
|
||||||
wxUnusedVar(flags);
|
|
||||||
|
|
||||||
// Our best best is to use xdg-open from freedesktop.org cross-desktop
|
|
||||||
// compatibility suite xdg-utils
|
|
||||||
// (see http://portland.freedesktop.org/wiki/) -- this is installed on
|
|
||||||
// most modern distributions and may be tweaked by them to handle
|
|
||||||
// distribution specifics.
|
|
||||||
wxString path, xdg_open;
|
|
||||||
if ( wxGetEnv("PATH", &path) &&
|
|
||||||
wxFindFileInPath(&xdg_open, path, "xdg-open") )
|
|
||||||
{
|
|
||||||
if ( wxExecute(xdg_open + " " + document) )
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// Launch default browser
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
bool wxDoLaunchDefaultBrowser(const wxString& url, int flags)
|
|
||||||
{
|
|
||||||
wxUnusedVar(flags);
|
|
||||||
|
|
||||||
// Our best best is to use xdg-open from freedesktop.org cross-desktop
|
|
||||||
// compatibility suite xdg-utils
|
|
||||||
// (see http://portland.freedesktop.org/wiki/) -- this is installed on
|
|
||||||
// most modern distributions and may be tweaked by them to handle
|
|
||||||
// distribution specifics. Only if that fails, try to find the right
|
|
||||||
// browser ourselves.
|
|
||||||
wxString path, xdg_open;
|
|
||||||
if ( wxGetEnv("PATH", &path) &&
|
|
||||||
wxFindFileInPath(&xdg_open, path, "xdg-open") )
|
|
||||||
{
|
|
||||||
if ( wxExecute(xdg_open + " " + url) )
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
wxString desktop = wxTheApp->GetTraits()->GetDesktopEnvironment();
|
|
||||||
|
|
||||||
// GNOME and KDE desktops have some applications which should be always installed
|
|
||||||
// together with their main parts, which give us the
|
|
||||||
if (desktop == wxT("GNOME"))
|
|
||||||
{
|
|
||||||
wxArrayString errors;
|
|
||||||
wxArrayString output;
|
|
||||||
|
|
||||||
// gconf will tell us the path of the application to use as browser
|
|
||||||
long res = wxExecute( wxT("gconftool-2 --get /desktop/gnome/applications/browser/exec"),
|
|
||||||
output, errors, wxEXEC_NODISABLE );
|
|
||||||
if (res >= 0 && errors.GetCount() == 0)
|
|
||||||
{
|
|
||||||
wxString cmd = output[0];
|
|
||||||
cmd << _T(' ') << url;
|
|
||||||
if (wxExecute(cmd))
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (desktop == wxT("KDE"))
|
|
||||||
{
|
|
||||||
// kfmclient directly opens the given URL
|
|
||||||
if (wxExecute(wxT("kfmclient openURL ") + url))
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif // __WXMAC__
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// wxExecute implementations
|
// wxExecute implementations
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
@@ -1,6 +1,6 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
// Name: src/unix/utilsx11.cpp
|
// Name: src/unix/utilsx11.cpp
|
||||||
// Purpose: Miscellaneous X11 functions
|
// Purpose: Miscellaneous X11 functions (for wxCore)
|
||||||
// Author: Mattia Barbon, Vaclav Slavik, Robert Roebling
|
// Author: Mattia Barbon, Vaclav Slavik, Robert Roebling
|
||||||
// Modified by:
|
// Modified by:
|
||||||
// Created: 25.03.02
|
// Created: 25.03.02
|
||||||
@@ -848,4 +848,80 @@ bool wxGetKeyState(wxKeyCode key)
|
|||||||
return key_vector[keyCode >> 3] & (1 << (keyCode & 7));
|
return key_vector[keyCode >> 3] & (1 << (keyCode & 7));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// Launch document with default app
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
bool wxLaunchDefaultApplication(const wxString& document, int flags)
|
||||||
|
{
|
||||||
|
wxUnusedVar(flags);
|
||||||
|
|
||||||
|
// Our best best is to use xdg-open from freedesktop.org cross-desktop
|
||||||
|
// compatibility suite xdg-utils
|
||||||
|
// (see http://portland.freedesktop.org/wiki/) -- this is installed on
|
||||||
|
// most modern distributions and may be tweaked by them to handle
|
||||||
|
// distribution specifics.
|
||||||
|
wxString path, xdg_open;
|
||||||
|
if ( wxGetEnv("PATH", &path) &&
|
||||||
|
wxFindFileInPath(&xdg_open, path, "xdg-open") )
|
||||||
|
{
|
||||||
|
if ( wxExecute(xdg_open + " " + document) )
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// Launch default browser
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
bool wxDoLaunchDefaultBrowser(const wxString& url, int flags)
|
||||||
|
{
|
||||||
|
wxUnusedVar(flags);
|
||||||
|
|
||||||
|
// Our best best is to use xdg-open from freedesktop.org cross-desktop
|
||||||
|
// compatibility suite xdg-utils
|
||||||
|
// (see http://portland.freedesktop.org/wiki/) -- this is installed on
|
||||||
|
// most modern distributions and may be tweaked by them to handle
|
||||||
|
// distribution specifics. Only if that fails, try to find the right
|
||||||
|
// browser ourselves.
|
||||||
|
wxString path, xdg_open;
|
||||||
|
if ( wxGetEnv("PATH", &path) &&
|
||||||
|
wxFindFileInPath(&xdg_open, path, "xdg-open") )
|
||||||
|
{
|
||||||
|
if ( wxExecute(xdg_open + " " + url) )
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxString desktop = wxTheApp->GetTraits()->GetDesktopEnvironment();
|
||||||
|
|
||||||
|
// GNOME and KDE desktops have some applications which should be always installed
|
||||||
|
// together with their main parts, which give us the
|
||||||
|
if (desktop == wxT("GNOME"))
|
||||||
|
{
|
||||||
|
wxArrayString errors;
|
||||||
|
wxArrayString output;
|
||||||
|
|
||||||
|
// gconf will tell us the path of the application to use as browser
|
||||||
|
long res = wxExecute( wxT("gconftool-2 --get /desktop/gnome/applications/browser/exec"),
|
||||||
|
output, errors, wxEXEC_NODISABLE );
|
||||||
|
if (res >= 0 && errors.GetCount() == 0)
|
||||||
|
{
|
||||||
|
wxString cmd = output[0];
|
||||||
|
cmd << _T(' ') << url;
|
||||||
|
if (wxExecute(cmd))
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (desktop == wxT("KDE"))
|
||||||
|
{
|
||||||
|
// kfmclient directly opens the given URL
|
||||||
|
if (wxExecute(wxT("kfmclient openURL ") + url))
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
#endif // __WXX11__ || __WXGTK__ || __WXMOTIF__
|
#endif // __WXX11__ || __WXGTK__ || __WXMOTIF__
|
||||||
|
Reference in New Issue
Block a user