Stephane Lussier

Implemented PathIsURLA and modified ShellExecute16 to be able to load URL
This commit is contained in:
Alexandre Julliard 2000-02-20 18:43:44 +00:00
parent b070313c80
commit 3712c46511
2 changed files with 152 additions and 8 deletions

View File

@ -27,6 +27,7 @@
#include "winreg.h" #include "winreg.h"
#include "syslevel.h" #include "syslevel.h"
#include "imagelist.h" #include "imagelist.h"
#include "tchar.h"
DEFAULT_DEBUG_CHANNEL(shell) DEFAULT_DEBUG_CHANNEL(shell)
DECLARE_DEBUG_CHANNEL(exec) DECLARE_DEBUG_CHANNEL(exec)
@ -334,7 +335,7 @@ HINSTANCE SHELL_FindExecutable( LPCSTR lpFile,
HINSTANCE retval=31; /* default - 'No association was found' */ HINSTANCE retval=31; /* default - 'No association was found' */
char *tok; /* token pointer */ char *tok; /* token pointer */
int i; /* random counter */ int i; /* random counter */
char xlpFile[256]; /* result of SearchPath */ char xlpFile[256] = ""; /* result of SearchPath */
TRACE("%s\n", (lpFile != NULL?lpFile:"-") ); TRACE("%s\n", (lpFile != NULL?lpFile:"-") );
@ -408,7 +409,7 @@ HINSTANCE SHELL_FindExecutable( LPCSTR lpFile,
&filetypelen ) == ERROR_SUCCESS ) &filetypelen ) == ERROR_SUCCESS )
{ {
filetype[filetypelen]='\0'; filetype[filetypelen]='\0';
TRACE("File type: %s\n", filetype); TRACE("File type: %s\n", filetype);
/* Looking for ...buffer\shell\lpOperation\command */ /* Looking for ...buffer\shell\lpOperation\command */
strcat( filetype, "\\shell\\" ); strcat( filetype, "\\shell\\" );
@ -418,6 +419,24 @@ HINSTANCE SHELL_FindExecutable( LPCSTR lpFile,
if (RegQueryValue16( HKEY_CLASSES_ROOT, filetype, command, if (RegQueryValue16( HKEY_CLASSES_ROOT, filetype, command,
&commandlen ) == ERROR_SUCCESS ) &commandlen ) == ERROR_SUCCESS )
{ {
LPSTR tmp;
char param[256];
LONG paramlen = 256;
/* Get the parameters needed by the application
from the associated ddeexec key */
tmp = strstr(filetype,"command");
tmp[0] = '\0';
strcat(filetype,"ddeexec");
if(RegQueryValue16( HKEY_CLASSES_ROOT, filetype, param,&paramlen ) == ERROR_SUCCESS)
{
strcat(command," ");
strcat(command,param);
commandlen += paramlen;
}
/* Is there a replace() function anywhere? */ /* Is there a replace() function anywhere? */
command[commandlen]='\0'; command[commandlen]='\0';
strcpy( lpResult, command ); strcpy( lpResult, command );
@ -473,7 +492,7 @@ HINSTANCE16 WINAPI ShellExecute16( HWND16 hWnd, LPCSTR lpOperation,
LPCSTR lpDirectory, INT16 iShowCmd ) LPCSTR lpDirectory, INT16 iShowCmd )
{ HINSTANCE16 retval=31; { HINSTANCE16 retval=31;
char old_dir[1024]; char old_dir[1024];
char cmd[256]; char cmd[1024] = "";
TRACE("(%04x,'%s','%s','%s','%s',%x)\n", TRACE("(%04x,'%s','%s','%s','%s',%x)\n",
hWnd, lpOperation ? lpOperation:"<null>", lpFile ? lpFile:"<null>", hWnd, lpOperation ? lpOperation:"<null>", lpFile ? lpFile:"<null>",
@ -489,20 +508,108 @@ HINSTANCE16 WINAPI ShellExecute16( HWND16 hWnd, LPCSTR lpOperation,
SetCurrentDirectoryA( lpDirectory ); SetCurrentDirectoryA( lpDirectory );
} }
retval = SHELL_FindExecutable( lpFile, lpOperation, cmd ); /* First try to execute lpFile with lpParameters directly */
strcpy(cmd,lpFile);
strcat(cmd,lpParameters ? lpParameters : "");
if (retval > 32) /* Found */ SYSLEVEL_ReleaseWin16Lock();
retval = WinExec( cmd, iShowCmd );
SYSLEVEL_RestoreWin16Lock();
/* Unable to execute lpFile directly
Check if we can match an application to lpFile */
if(retval < 31)
{ {
cmd[0] = '\0';
retval = SHELL_FindExecutable( lpFile, lpOperation, cmd );
if (retval > 32) /* Found */
{
if (lpParameters) if (lpParameters)
{ {
strcat(cmd," "); strcat(cmd," ");
strcat(cmd,lpParameters); strcat(cmd,lpParameters);
} }
TRACE("starting %s\n",cmd);
SYSLEVEL_ReleaseWin16Lock(); SYSLEVEL_ReleaseWin16Lock();
retval = WinExec( cmd, iShowCmd ); retval = WinExec( cmd, iShowCmd );
SYSLEVEL_RestoreWin16Lock(); SYSLEVEL_RestoreWin16Lock();
}
else if(PathIsURLA((LPSTR)lpFile)) /* File not found, check for URL */
{
char lpstrProtocol[256];
LONG cmdlen = 512;
LPSTR lpstrRes;
INT iSize;
lpstrRes = strchr(lpFile,':');
iSize = lpstrRes - lpFile;
/* Looking for ...protocol\shell\lpOperation\command */
strncpy(lpstrProtocol,lpFile,iSize);
lpstrProtocol[iSize]='\0';
strcat( lpstrProtocol, "\\shell\\" );
strcat( lpstrProtocol, lpOperation );
strcat( lpstrProtocol, "\\command" );
/* Remove File Protocol from lpFile */
/* In the case file://path/file */
if(!_strnicmp(lpFile,"file",iSize))
{
lpFile += iSize;
while(*lpFile == ':') lpFile++;
}
/* Get the application for the protocol and execute it */
if (RegQueryValue16( HKEY_CLASSES_ROOT, lpstrProtocol, cmd,
&cmdlen ) == ERROR_SUCCESS )
{
LPSTR tok;
LPSTR tmp;
char param[256] = "";
LONG paramlen = 256;
/* Get the parameters needed by the application
from the associated ddeexec key */
tmp = strstr(lpstrProtocol,"command");
tmp[0] = '\0';
strcat(lpstrProtocol,"ddeexec");
if(RegQueryValue16( HKEY_CLASSES_ROOT, lpstrProtocol, param,&paramlen ) == ERROR_SUCCESS)
{
strcat(cmd," ");
strcat(cmd,param);
cmdlen += paramlen;
}
/* Is there a replace() function anywhere? */
cmd[cmdlen]='\0';
tok=strstr( cmd, "%1" );
if (tok != NULL)
{
tok[0]='\0'; /* truncate string at the percent */
strcat( cmd, lpFile ); /* what if no dir in xlpFile? */
tok=strstr( cmd, "%1" );
if ((tok!=NULL) && (strlen(tok)>2))
{
strcat( cmd, &tok[2] );
}
}
SYSLEVEL_ReleaseWin16Lock();
retval = WinExec( cmd, iShowCmd );
SYSLEVEL_RestoreWin16Lock();
}
}
/* Check if file specified is in the form www.??????.*** */
else if(!_strnicmp(lpFile,"www",3))
{
/* if so, append lpFile http:// and call ShellExecute */
char lpstrTmpFile[256] = "http://" ;
strcat(lpstrTmpFile,lpFile);
retval = ShellExecuteA(hWnd,lpOperation,lpstrTmpFile,NULL,NULL,0);
}
} }
if (lpDirectory) if (lpDirectory)
SetCurrentDirectoryA( old_dir ); SetCurrentDirectoryA( old_dir );

View File

@ -11,13 +11,18 @@
#include "winversion.h" #include "winversion.h"
#include "winreg.h" #include "winreg.h"
#include "crtdll.h" #include "crtdll.h"
#include "tchar.h"
#include "shlobj.h" #include "shlobj.h"
#include "shell32_main.h" #include "shell32_main.h"
#include "windef.h" #include "windef.h"
#include "options.h"
DEFAULT_DEBUG_CHANNEL(shell) DEFAULT_DEBUG_CHANNEL(shell)
/* Supported protocols for PathIsURL */
LPSTR SupportedProtocol[] = {"http","https","ftp","gopher","file","mailto",""};
/************************************************************************* /*************************************************************************
* PathIsRoot [SHELL32.29] * PathIsRoot [SHELL32.29]
*/ */
@ -1041,6 +1046,38 @@ LPWSTR WINAPI PathRemoveBackslashW( LPWSTR lpPath )
/* SHGetValue: Gets a value from the registry */ /* SHGetValue: Gets a value from the registry */
BOOL WINAPI PathIsURLA(LPCSTR lpstrPath)
{
LPSTR lpstrRes;
char lpstrFileType[10] = "";
int iSize;
int i = 0;
/* sanity check */
if(!lpstrPath)
return FALSE;
/* get protocol */
/* protocol://location */
if(!(lpstrRes = strchr(lpstrPath,':')))
{
return FALSE;
}
iSize = lpstrRes - lpstrPath;
if(iSize > sizeof(lpstrFileType))
return FALSE;
strncpy(lpstrFileType,lpstrPath,iSize);
while(strlen(SupportedProtocol[i]))
{
if(!_stricmp(lpstrFileType,SupportedProtocol[i++]))
return TRUE;
}
return FALSE;
}
DWORD WINAPI SHGetValueA( DWORD WINAPI SHGetValueA(
HKEY hkey, HKEY hkey,
LPCSTR pSubKey, LPCSTR pSubKey,