forked from KolibriOS/kolibrios
WebView: convert & to & in URLs
git-svn-id: svn://kolibrios.org@5990 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
9223174c8e
commit
a96fb73670
@ -62,6 +62,7 @@ char attr[1200];
|
|||||||
char val[4096];
|
char val[4096];
|
||||||
char anchor[256]=0;
|
char anchor[256]=0;
|
||||||
|
|
||||||
|
#include "..\TWB\absolute_url.h"
|
||||||
#include "..\TWB\links.h"
|
#include "..\TWB\links.h"
|
||||||
#include "..\TWB\colors.h"
|
#include "..\TWB\colors.h"
|
||||||
#include "..\TWB\unicode_tags.h"
|
#include "..\TWB\unicode_tags.h"
|
||||||
@ -352,8 +353,7 @@ void TWebBrowser::SetStyle() {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (istag("br")) { NewLine(); return; }
|
if (istag("br")) { NewLine(); return; }
|
||||||
if (istag("tr")) { if (opened) { NewLine(); strcat(#line, "| "); } return; }
|
if (istag("tr")) { if (opened) NewLine(); return; }
|
||||||
if (istag("td")) || (istag("th")) { if (!opened) strcat(#line, " | "); return; }
|
|
||||||
if (istag("b")) || (istag("strong")) || (istag("big")) { style.b = opened; return; }
|
if (istag("b")) || (istag("strong")) || (istag("big")) { style.b = opened; return; }
|
||||||
if (istag("i")) || (istag("em")) || (istag("subtitle")) { style.i=opened; return; }
|
if (istag("i")) || (istag("em")) || (istag("subtitle")) { style.i=opened; return; }
|
||||||
if (istag("u")) || (istag("ins")) { style.u=opened; return;}
|
if (istag("u")) || (istag("ins")) { style.u=opened; return;}
|
||||||
|
70
programs/cmm/TWB/absolute_url.h
Normal file
70
programs/cmm/TWB/absolute_url.h
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
|
||||||
|
int UrlIsAbsolute(dword in)
|
||||||
|
{
|
||||||
|
if(!strncmp(in,"http:",5)) return true;
|
||||||
|
if(!strncmp(in,"https:",6)) return true;
|
||||||
|
if(!strncmp(in,"mailto:",7)) return true;
|
||||||
|
if(!strncmp(in,"ftp:",4)) return true;
|
||||||
|
if(!strncmp(in,"WebView:",8)) return true;
|
||||||
|
if(!strncmp(in,"/sys/",5)) return true;
|
||||||
|
if(!strncmp(in,"/hd/",4)) return true;
|
||||||
|
if(!strncmp(in,"/fd/",4)) return true;
|
||||||
|
if(!strncmp(in,"/rd/",4)) return true;
|
||||||
|
if(!strncmp(in,"/tmp/",5)) return true;
|
||||||
|
if(!strncmp(in,"/cd/",4)) return true;
|
||||||
|
if(!strncmp(in,"/bd/",4)) return true;
|
||||||
|
if(!strncmp(in,"/usbhd/",7)) return true;
|
||||||
|
if(!strncmp(in,"/kolibrios/",11)) return true;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
void GetAbsoluteURL(dword in_URL)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
dword orig_URL = in_URL;
|
||||||
|
char newurl[sizeof(URL)];
|
||||||
|
|
||||||
|
while (i=strstr(in_URL, "&"))
|
||||||
|
{
|
||||||
|
strcpy(i+1, i+5);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (UrlIsAbsolute(in_URL)) return;
|
||||||
|
|
||||||
|
IF (!strcmpn(in_URL,"./", 2)) in_URL+=2;
|
||||||
|
if (!http_transfer)
|
||||||
|
{
|
||||||
|
strcpy(#newurl, History.current());
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
strcpy(#newurl, History.items.get(History.active-2));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ESBYTE[in_URL] == '/') //remove everything after site domain name
|
||||||
|
{
|
||||||
|
i = strchr(#newurl+8, '/');
|
||||||
|
if (i) ESBYTE[i]=0;
|
||||||
|
in_URL+=1;
|
||||||
|
}
|
||||||
|
|
||||||
|
_CUT_ST_LEVEL_MARK:
|
||||||
|
|
||||||
|
if (newurl[strrchr(#newurl, '/')-2]<>'/')
|
||||||
|
{
|
||||||
|
newurl[strrchr(#newurl, '/')] = 0x00;
|
||||||
|
}
|
||||||
|
|
||||||
|
IF (!strncmp(in_URL,"../",3))
|
||||||
|
{
|
||||||
|
in_URL+=3;
|
||||||
|
newurl[strrchr(#newurl, '/')-1] = 0x00;
|
||||||
|
goto _CUT_ST_LEVEL_MARK;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (newurl[strlen(#newurl)-1]<>'/') strcat(#newurl, "/");
|
||||||
|
|
||||||
|
strcat(#newurl, in_URL);
|
||||||
|
strcpy(orig_URL, #newurl);
|
||||||
|
}
|
||||||
|
|
@ -44,7 +44,7 @@ void ImageCache::Images(int left1, top1, width1)
|
|||||||
if (isattr("src="))
|
if (isattr("src="))
|
||||||
{
|
{
|
||||||
strcpy(#img_path, #val);
|
strcpy(#img_path, #val);
|
||||||
PageLinks.GetAbsoluteURL(#img_path);
|
GetAbsoluteURL(#img_path);
|
||||||
cur_pic = GetImage(#img_path);
|
cur_pic = GetImage(#img_path);
|
||||||
}
|
}
|
||||||
if (isattr("alt="))
|
if (isattr("alt="))
|
||||||
|
@ -20,8 +20,6 @@ struct LinksArray {
|
|||||||
void AddText();
|
void AddText();
|
||||||
dword GetURL();
|
dword GetURL();
|
||||||
void Clear();
|
void Clear();
|
||||||
void GetAbsoluteURL();
|
|
||||||
int UrlAbsolute();
|
|
||||||
} PageLinks;
|
} PageLinks;
|
||||||
|
|
||||||
void LinksArray::AddLink(dword lpath, int link_x, link_y)
|
void LinksArray::AddLink(dword lpath, int link_x, link_y)
|
||||||
@ -98,68 +96,3 @@ void LinksArray::Hover(dword mx, my, link_col_in, link_col_a, bg_col)
|
|||||||
active = -1;
|
active = -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int LinksArray::UrlAbsolute(dword in_URL)
|
|
||||||
{
|
|
||||||
if(!strncmp(in_URL,"http:",5)) return 1;
|
|
||||||
if(!strncmp(in_URL,"https:",6)) return 1;
|
|
||||||
if(!strncmp(in_URL,"mailto:",7)) return 1;
|
|
||||||
if(!strncmp(in_URL,"ftp:",4)) return 1;
|
|
||||||
if(!strncmp(in_URL,"WebView:",8)) return 1;
|
|
||||||
if(!strncmp(in_URL,"/sys/",5)) return 1;
|
|
||||||
if(!strncmp(in_URL,"/hd/",4)) return 1;
|
|
||||||
if(!strncmp(in_URL,"/fd/",4)) return 1;
|
|
||||||
if(!strncmp(in_URL,"/rd/",4)) return 1;
|
|
||||||
if(!strncmp(in_URL,"/tmp/",5)) return 1;
|
|
||||||
if(!strncmp(in_URL,"/cd/",4)) return 1;
|
|
||||||
if(!strncmp(in_URL,"/bd/",4)) return 1;
|
|
||||||
if(!strncmp(in_URL,"/usbhd/",7)) return 1;
|
|
||||||
if(!strncmp(in_URL,"/kolibrios/",11)) return 1;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void LinksArray::GetAbsoluteURL(dword in_URL)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
dword orig_URL = in_URL;
|
|
||||||
char newurl[sizeof(URL)];
|
|
||||||
|
|
||||||
if (UrlAbsolute(in_URL)) return;
|
|
||||||
|
|
||||||
IF (!strcmpn(in_URL,"./", 2)) in_URL+=2;
|
|
||||||
if (!http_transfer)
|
|
||||||
{
|
|
||||||
strcpy(#newurl, History.current());
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
strcpy(#newurl, History.items.get(History.active-2));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ESBYTE[in_URL] == '/') //remove everything after site domain name
|
|
||||||
{
|
|
||||||
i = strchr(#newurl+8, '/');
|
|
||||||
if (i) ESBYTE[i]=0;
|
|
||||||
in_URL+=1;
|
|
||||||
}
|
|
||||||
|
|
||||||
_CUT_ST_LEVEL_MARK:
|
|
||||||
|
|
||||||
if (newurl[strrchr(#newurl, '/')-2]<>'/')
|
|
||||||
{
|
|
||||||
newurl[strrchr(#newurl, '/')] = 0x00;
|
|
||||||
}
|
|
||||||
|
|
||||||
IF (!strncmp(in_URL,"../",3))
|
|
||||||
{
|
|
||||||
in_URL+=3;
|
|
||||||
newurl[strrchr(#newurl, '/')-1] = 0x00;
|
|
||||||
goto _CUT_ST_LEVEL_MARK;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (newurl[strlen(#newurl)-1]<>'/') strcat(#newurl, "/");
|
|
||||||
|
|
||||||
strcat(#newurl, in_URL);
|
|
||||||
strcpy(orig_URL, #newurl);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
@ -29,14 +29,14 @@
|
|||||||
char homepage[] = FROM "html\\homepage.htm";
|
char homepage[] = FROM "html\\homepage.htm";
|
||||||
|
|
||||||
#ifdef LANG_RUS
|
#ifdef LANG_RUS
|
||||||
char version[]=" ’¥ªáâ®¢ë© ¡à 㧥à 1.40";
|
char version[]=" ’¥ªáâ®¢ë© ¡à 㧥à 1.41";
|
||||||
?define IMAGES_CACHE_CLEARED "Šíè ª à⨮ª ®ç¨é¥"
|
?define IMAGES_CACHE_CLEARED "Šíè ª à⨮ª ®ç¨é¥"
|
||||||
?define T_LAST_SLIDE "<EFBFBD>â® ¯®á«¥¤¨© á« ©¤"
|
?define T_LAST_SLIDE "<EFBFBD>â® ¯®á«¥¤¨© á« ©¤"
|
||||||
char loading[] = "‡ £à㧪 áâà ¨æë...<br>";
|
char loading[] = "‡ £à㧪 áâà ¨æë...<br>";
|
||||||
char page_not_found[] = FROM "html\page_not_found_ru.htm";
|
char page_not_found[] = FROM "html\page_not_found_ru.htm";
|
||||||
char accept_language[]= "Accept-Language: ru\n";
|
char accept_language[]= "Accept-Language: ru\n";
|
||||||
#else
|
#else
|
||||||
char version[]=" Text-based Browser 1.40";
|
char version[]=" Text-based Browser 1.41";
|
||||||
?define IMAGES_CACHE_CLEARED "Images cache cleared"
|
?define IMAGES_CACHE_CLEARED "Images cache cleared"
|
||||||
?define T_LAST_SLIDE "This slide is the last"
|
?define T_LAST_SLIDE "This slide is the last"
|
||||||
char loading[] = "Loading...<br>";
|
char loading[] = "Loading...<br>";
|
||||||
@ -217,7 +217,7 @@ void main()
|
|||||||
{
|
{
|
||||||
http_free stdcall (http_transfer);
|
http_free stdcall (http_transfer);
|
||||||
http_transfer=0;
|
http_transfer=0;
|
||||||
PageLinks.GetAbsoluteURL(#URL);
|
GetAbsoluteURL(#URL);
|
||||||
History.back();
|
History.back();
|
||||||
strcpy(#editURL, #URL);
|
strcpy(#editURL, #URL);
|
||||||
DrawEditBox();
|
DrawEditBox();
|
||||||
@ -518,7 +518,7 @@ void ClickLink()
|
|||||||
URL[strrchr(#URL, '#')-1] = 0x00;
|
URL[strrchr(#URL, '#')-1] = 0x00;
|
||||||
}
|
}
|
||||||
|
|
||||||
PageLinks.GetAbsoluteURL(#URL);
|
GetAbsoluteURL(#URL);
|
||||||
|
|
||||||
if (UrlExtIs(".png")==1) || (UrlExtIs(".gif")==1) || (UrlExtIs(".jpg")==1) || (UrlExtIs(".zip")==1) || (UrlExtIs(".kex")==1)
|
if (UrlExtIs(".png")==1) || (UrlExtIs(".gif")==1) || (UrlExtIs(".jpg")==1) || (UrlExtIs(".zip")==1) || (UrlExtIs(".kex")==1)
|
||||||
|| (UrlExtIs(".7z")==1) || (UrlExtIs("netcfg")==1)
|
|| (UrlExtIs(".7z")==1) || (UrlExtIs("netcfg")==1)
|
||||||
|
Loading…
Reference in New Issue
Block a user