WTB: small structure improvements

git-svn-id: svn://kolibrios.org@4540 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
Kirill Lipatov (Leency) 2014-01-27 20:16:33 +00:00
parent da432de99f
commit 862f49c057
4 changed files with 55 additions and 53 deletions

View File

@ -1,8 +1,8 @@
#include "..\TWB\links.h" #include "..\TWB\links.h"
dword buf; dword bufpointer;
dword filesize; dword bufsize;
#define URL param #define URL param
@ -10,12 +10,10 @@ scroll_bar scroll_wv = { 18,200,398, 44,18,0,115,15,0,0xeeeeee,0xD2CED0,0x555555
char header[2048]; char header[2048];
int downloader_id;
char download_path[]="/rd/1/.download"; char download_path[]="/rd/1/.download";
struct TWebBrowser { struct TWebBrowser {
llist list; //need #include "..\lib\list_box.h" llist list;
DrawBufer DrawBuf; DrawBufer DrawBuf;
void GetNewUrl(); void GetNewUrl();
void ReadHtml(); void ReadHtml();
@ -151,20 +149,20 @@ void TWebBrowser::ReadHtml(byte encoding)
else else
file_size stdcall (#URL); file_size stdcall (#URL);
filesize = EBX; bufsize = EBX;
if (!filesize) return; if (!bufsize) return;
mem_Free(buf); mem_Free(bufpointer);
buf = mem_Alloc(filesize); bufpointer = mem_Alloc(bufsize);
if (!strncmp(#URL,"http:",5)) if (!strncmp(#URL,"http:",5))
ReadFile(0, filesize, buf, #download_path); ReadFile(0, bufsize, bufpointer, #download_path);
else else
ReadFile(0, filesize, buf, #URL); ReadFile(0, bufsize, bufpointer, #URL);
cur_encoding = encoding; cur_encoding = encoding;
if (encoding==_WIN) wintodos(buf); if (encoding==_WIN) wintodos(bufpointer);
if (encoding==_UTF) utf8rutodos(buf); if (encoding==_UTF) utf8rutodos(bufpointer);
if (encoding==_KOI) koitodos(buf); if (encoding==_KOI) koitodos(bufpointer);
} }
@ -197,7 +195,7 @@ void TWebBrowser::ParseHTML(dword bufpos){
if (!strcmp(#URL + strlen(#URL) - 4, ".mht")) ignor_text = 1; if (!strcmp(#URL + strlen(#URL) - 4, ".mht")) ignor_text = 1;
} }
for ( ; bufstart+filesize > bufpos; bufpos++;) for ( ; bufstart+bufsize > bufpos; bufpos++;)
{ {
bukva = ESBYTE[bufpos]; bukva = ESBYTE[bufpos];
if (ignor_text) && (bukva!='<') continue; if (ignor_text) && (bukva!='<') continue;
@ -255,7 +253,7 @@ void TWebBrowser::ParseHTML(dword bufpos){
do do
{ {
bufpos++; bufpos++;
if (bufstart + filesize <= bufpos) break 2; if (bufstart + bufsize <= bufpos) break 2;
} }
while (ESBYTE[bufpos] <>'-'); while (ESBYTE[bufpos] <>'-');
@ -263,7 +261,7 @@ void TWebBrowser::ParseHTML(dword bufpos){
if (ESBYTE[bufpos] <>'-') goto HH_; if (ESBYTE[bufpos] <>'-') goto HH_;
} }
} }
while (ESBYTE[bufpos] !='>') && (bufpos < bufstart + filesize) //ïîëó÷àåì òåã è åãî ïàğàìåòğû while (ESBYTE[bufpos] !='>') && (bufpos < bufstart + bufsize) //ïîëó÷àåì òåã è åãî ïàğàìåòğû
{ {
bukva = ESBYTE[bufpos]; bukva = ESBYTE[bufpos];
if (bukva == '\9') || (bukva == '\x0a') || (bukva == '\x0d') bukva = ' '; if (bukva == '\9') || (bukva == '\x0a') || (bukva == '\x0d') bukva = ' ';

View File

@ -43,9 +43,8 @@ void ImageCache::Images(int left1, top1, width1)
do{ do{
if (!strcmp(#parametr,"src=")) //íàäî îáúåäèíèòü ñ GetNewUrl() if (!strcmp(#parametr,"src=")) //íàäî îáúåäèíèòü ñ GetNewUrl()
{ {
if (downloader_id) strcpy(#img_path, #history_list[history_current-1].Item); //if (downloader_id) strcpy(#img_path, #history_list[history_current-1].Item); else
else strcpy(#img_path, BrowserHistory.CurrentUrl()); //äîńňŕ¸ě ŕäđĺń ňĺęóůĺé ńňđŕíčöű strcpy(#img_path, BrowserHistory.CurrentUrl());
if (strcmpn(#img_path, "http:", 5)!=0) || (strcmpn(#options, "http:", 5)!=0) if (strcmpn(#img_path, "http:", 5)!=0) || (strcmpn(#options, "http:", 5)!=0)
{ {
//get path: absolute or relative //get path: absolute or relative

View File

@ -58,6 +58,8 @@ int action_buf;
dword http_transfer = 0; dword http_transfer = 0;
dword http_buffer; dword http_buffer;
int downloader_id;
#include "..\TWB\TWB.c" #include "..\TWB\TWB.c"
#include "menu_rmb.h" #include "menu_rmb.h"
@ -80,6 +82,7 @@ void main()
if (load_dll2(boxlib, #box_lib_init,0)!=0) {notify("System Error: library doesn't exists /rd/1/lib/box_lib.obj"); ExitProcess();} if (load_dll2(boxlib, #box_lib_init,0)!=0) {notify("System Error: library doesn't exists /rd/1/lib/box_lib.obj"); ExitProcess();}
if (load_dll2(libio, #libio_init,1)!=0) notify("Error: library doesn't exists - libio"); if (load_dll2(libio, #libio_init,1)!=0) notify("Error: library doesn't exists - libio");
if (load_dll2(libimg, #libimg_init,1)!=0) notify("Error: library doesn't exists - libimg"); if (load_dll2(libimg, #libimg_init,1)!=0) notify("Error: library doesn't exists - libimg");
if (load_dll2(libHTTP, #http_lib_init,1)!=0) notify("Error: library doesn't exists - http");
if (!URL) strcpy(#URL, "/sys/index.htm"); if (!URL) strcpy(#URL, "/sys/index.htm");
Form.width=WIN_W; Form.width=WIN_W;
@ -101,7 +104,7 @@ void main()
m.get(); m.get();
PageLinks.Hover(m.x, m.y, link_color_inactive, link_color_active, bg_color); PageLinks.Hover(m.x, m.y, link_color_inactive, link_color_active, bg_color);
if (m.y>WB1.list.y) && (m.y<Form.height) && (filesize) if (m.y>WB1.list.y) && (m.y<Form.height) && (bufsize)
{ {
if (m.pkm) if (m.pkm)
{ {
@ -118,7 +121,7 @@ void main()
if (m.vert) if (m.vert)
{ {
if (WB1.list.MouseScroll(m.vert)) WB1.ParseHTML(buf); if (WB1.list.MouseScroll(m.vert)) WB1.ParseHTML(bufpointer);
} }
if (!m.lkm) scroll_used=0; if (!m.lkm) scroll_used=0;
@ -136,7 +139,7 @@ void main()
btn=WB1.list.first; btn=WB1.list.first;
WB1.list.first = m.y -half_scroll_size -WB1.list.y * WB1.list.count / WB1.list.h; WB1.list.first = m.y -half_scroll_size -WB1.list.y * WB1.list.count / WB1.list.h;
if (WB1.list.visible+WB1.list.first>WB1.list.count) WB1.list.first=WB1.list.count-WB1.list.visible; if (WB1.list.visible+WB1.list.first>WB1.list.count) WB1.list.first=WB1.list.count-WB1.list.visible;
if (btn<>WB1.list.first) WB1.ParseHTML(buf); if (btn<>WB1.list.first) WB1.ParseHTML(bufpointer);
} }
break; break;
@ -167,28 +170,29 @@ void main()
if (action_buf) { Scan(action_buf); action_buf=0;} if (action_buf) { Scan(action_buf); action_buf=0;}
Draw_Window(); Draw_Window();
break; break;
case evNetwork: case evNetwork:
return; return;
//open page http_get stdcall (#search_path, 0);
http_get stdcall (#URL, 0);
http_transfer = EAX; http_transfer = EAX;
IF (http_transfer < 0) notify("Error from HTTP lib"); IF (http_transfer < 0) notify("Error from HTTP lib");
//
if (http_transfer != 0) { if (http_transfer > 0) {
http_process stdcall (http_transfer); http_process stdcall (http_transfer);
$push EAX $push EAX
ESI = http_transfer; ESI = http_transfer;
if (!ESI.http_msg.content_received) break; bufpointer = ESI.http_msg.content_ptr;
buf = ESI.http_msg.content_ptr; debug(bufpointer);
debug(buf); //bufsize = ESI.http_msg.content_received;
filesize = ESI.http_msg.content_received; bufsize = strlen(bufpointer)-2;
debugi(filesize); debugi(bufsize);
WB1.ParseHTML(buf); WB1.ParseHTML(bufpointer);
$pop EAX $pop EAX
if (EAX == 0) { if (EAX == 0) {
http_free stdcall (http_transfer); http_free stdcall (http_transfer);
http_transfer=0; http_transfer=0;
} }
pause(10);
} }
default: default:
if (downloader_id<>0) if (downloader_id<>0)
@ -256,28 +260,28 @@ void Scan(int id)
{ {
case 011: //Ctrk+K case 011: //Ctrk+K
WB1.ReadHtml(_KOI); WB1.ReadHtml(_KOI);
WB1.ParseHTML(buf); WB1.ParseHTML(bufpointer);
return; return;
case 021: //Ctrl+U case 021: //Ctrl+U
WB1.ReadHtml(_UTF); WB1.ReadHtml(_UTF);
WB1.ParseHTML(buf); WB1.ParseHTML(bufpointer);
return; return;
case 004: //Ctrl+D case 004: //Ctrl+D
WB1.ReadHtml(_DOS); WB1.ReadHtml(_DOS);
WB1.ParseHTML(buf); WB1.ParseHTML(bufpointer);
return; return;
case 005: //Win encoding case 005: //Win encoding
WB1.ReadHtml(_WIN); WB1.ReadHtml(_WIN);
WB1.ParseHTML(buf); WB1.ParseHTML(bufpointer);
return; return;
case 009: //free img cache case 009: //free img cache
ImgCache.Free(); ImgCache.Free();
notify(IMAGES_CACHE_CLEARED); notify(IMAGES_CACHE_CLEARED);
WB1.ParseHTML(buf); WB1.ParseHTML(bufpointer);
return; return;
case BACK: case BACK:
@ -293,7 +297,7 @@ void Scan(int id)
else RunProgram("/rd/1/tinypad", #download_path); else RunProgram("/rd/1/tinypad", #download_path);
return; return;
case 054: //F5 case 054: //F5
IF(address_box.flags & 0b10) WB1.ParseHTML(buf); IF(address_box.flags & 0b10) WB1.ParseHTML(bufpointer);
return; return;
case REFRESH: case REFRESH:
@ -334,7 +338,7 @@ void Scan(int id)
IF(WB1.list.first == WB1.list.count - WB1.list.visible) return; IF(WB1.list.first == WB1.list.count - WB1.list.visible) return;
WB1.list.first += WB1.list.visible + 2; WB1.list.first += WB1.list.visible + 2;
IF(WB1.list.visible + WB1.list.first > WB1.list.count) WB1.list.first = WB1.list.count - WB1.list.visible; IF(WB1.list.visible + WB1.list.first > WB1.list.count) WB1.list.first = WB1.list.count - WB1.list.visible;
WB1.ParseHTML(buf); WB1.ParseHTML(bufpointer);
return; return;
case 184: //PgUp case 184: //PgUp
@ -342,30 +346,30 @@ void Scan(int id)
IF(WB1.list.first == 0) return; IF(WB1.list.first == 0) return;
WB1.list.first -= WB1.list.visible - 2; WB1.list.first -= WB1.list.visible - 2;
IF(WB1.list.first < 0) WB1.list.first = 0; IF(WB1.list.first < 0) WB1.list.first = 0;
WB1.ParseHTML(buf); WB1.ParseHTML(bufpointer);
return; return;
case 178: case 178:
case BTN_UP: //ìîòàåì ââåðõ case BTN_UP: //ìîòàåì ââåðõ
if (WB1.list.first <= 0) return; if (WB1.list.first <= 0) return;
WB1.list.first--; WB1.list.first--;
WB1.ParseHTML(buf); WB1.ParseHTML(bufpointer);
return; return;
case 177: case 177:
case BTN_DOWN: //ìîòàåì âíèç case BTN_DOWN: //ìîòàåì âíèç
if (WB1.list.visible + WB1.list.first >= WB1.list.count) return; if (WB1.list.visible + WB1.list.first >= WB1.list.count) return;
WB1.list.first++; WB1.list.first++;
WB1.ParseHTML(buf); WB1.ParseHTML(bufpointer);
return; return;
case 180: //home case 180: //home
if (WB1.list.KeyHome()) WB1.ParseHTML(buf); if (WB1.list.KeyHome()) WB1.ParseHTML(bufpointer);
return; return;
case 181: //end case 181: //end
if (WB1.list.count < WB1.list.visible) return; if (WB1.list.count < WB1.list.visible) return;
if (WB1.list.KeyEnd()) WB1.ParseHTML(buf); if (WB1.list.KeyEnd()) WB1.ParseHTML(bufpointer);
return; return;
} }
} }
@ -456,31 +460,31 @@ void ShowPage()
address_box.offset=0; address_box.offset=0;
edit_box_draw stdcall(#address_box); edit_box_draw stdcall(#address_box);
if (!filesize) if (!bufsize)
{ {
PageLinks.Clear(); PageLinks.Clear();
if (GetProcessSlot(downloader_id)<>0) if (GetProcessSlot(downloader_id)<>0)
{ {
filesize = sizeof(loading); bufsize = sizeof(loading);
WB1.ParseHTML(#loading); WB1.ParseHTML(#loading);
} }
else else
{ {
if (strncmp(#URL,"http:",5)==0) if (strncmp(#URL,"http:",5)==0)
{ {
filesize = sizeof(page_not_found_no_internet); bufsize = sizeof(page_not_found_no_internet);
WB1.ParseHTML(#page_not_found_no_internet); WB1.ParseHTML(#page_not_found_no_internet);
} }
else else
{ {
filesize = sizeof(page_not_found); bufsize = sizeof(page_not_found);
WB1.ParseHTML(#page_not_found); WB1.ParseHTML(#page_not_found);
} }
} }
//return; //return;
} }
else else
WB1.ParseHTML(buf); WB1.ParseHTML(bufpointer);
if (!header) strcpy(#header, #version); if (!header) strcpy(#header, #version);
if (!strcmp(#version, #header)) DrawTitle(#header); if (!strcmp(#version, #header)) DrawTitle(#header);

View File

@ -355,8 +355,9 @@ void InitTWB() {
} }
void DrawLetter() { void DrawLetter() {
filesize = strlen(mdata); pre_text = 2;
if (filesize) WB1.ParseHTML(mdata); bufsize = strlen(mdata);
if (bufsize) WB1.ParseHTML(mdata);
} }