forked from KolibriOS/kolibrios
drvinst: v1.0, add to ISO
git-svn-id: svn://kolibrios.org@6654 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
7ce6f6bd28
commit
0db7a95137
@ -205,6 +205,8 @@ extra_files = {
|
||||
{"kolibrios/grafx2/scripts/libs/", "common/media/grafx2/scripts/*"},
|
||||
{"kolibrios/grafx2/skins/", "common/media/grafx2/skins/*"},
|
||||
{"kolibrios/grafx2/", "common/media/grafx2/*"},
|
||||
{"kolibrios/drivers/drvinf.ini", "common/drivers/drvinf.ini"},
|
||||
{"kolibrios/drivers/drvinst.kex", "common/drivers/drvinst.com"},
|
||||
{"kolibrios/drivers/ahci/", "common/drivers/ahci/*"},
|
||||
{"kolibrios/drivers/atikms/", "common/drivers/atikms/*"},
|
||||
{"kolibrios/drivers/i915/", "common/drivers/i915/*"},
|
||||
|
22
data/common/drivers/drvinf.ini
Normal file
22
data/common/drivers/drvinf.ini
Normal file
@ -0,0 +1,22 @@
|
||||
[AHCI]
|
||||
ver=ver rc06
|
||||
description=<EFBFBD>®¨áª ª®â஫«¥à®¢ ¨ ®¯à¥¤¥«¥¨¥ ¯®¤ª«îçñëå €’€ ¤¨áª®¢. ‚ á«ãç ¥ ãᯥå , ¤¥« ¥â ¢¨¤¨¬ë¬¨ ¢ Š«®¡¨à¨ ¦¥á⪨¥ ¤¨áª¨ ¯®¤ª«îç¥ë¥ ç¥à¥§ ACHI.
|
||||
install=/kolibrios/drivers/ahci/ahci
|
||||
|
||||
[Video ATI KMS]
|
||||
ver=ver 4.4
|
||||
description=„à ©¢¥à ¤«ï ¢¨¤¥®ª àâ ATI Radeon. <20>®¤¤¥à¦¨¢ îâáï ¤¨áªà¥âë¥ ¨ ¨â¥£à¨à®¢ ë¥ ç¨¯á¥âë ᥬ¥©á⢠ATI R100-R600, Evergreen, Northern Islands, Southern Islands. “áâ ¢«¨¢ ¥â ¢¨¤¥®à¥¦¨¬ ¯à¨ ¯¥à¢®¬ § ¯ã᪥ ¨ ¤¥« ¥â ¤®áâã¯ë¬ ᬥ㠢¨¤¥®à¥¦¨¬ ¢ ¯à®æ¥áá¥ à ¡®âë (SYSPANEL -> VideoMode).
|
||||
readme=/kolibrios/drivers/atikms/readme.txt
|
||||
install=/kolibrios/drivers/atikms/atikms
|
||||
|
||||
[Video Intel i915]
|
||||
ver=ver 4.4.1
|
||||
description=„à ©¢¥à ¤«ï ¢¨¤¥®ª àâ Intel. <20>®¤¤¥à¦¨¢ îâáï ¢á¥ PCI Express ¢¨¤¥®ï¤à Intel ®â i915 ¤® Skylake. “áâ ¢«¨¢ ¥â ¢¨¤¥®à¥¦¨¬ ¯à¨ ¯¥à¢®¬ § ¯ã᪥ ¨ ¤¥« ¥â ¤®áâã¯ë¬ ᬥ㠢¨¤¥®à¥¦¨¬ ¢ ¯à®æ¥áá¥ à ¡®âë (SYSPANEL -> VideoMode).
|
||||
readme=/kolibrios/drivers/i915/readme.txt
|
||||
install=/kolibrios/drivers/i915/i915
|
||||
|
||||
[Video VmWare]
|
||||
ver=ver 3.14-rc2
|
||||
description=„à ©¢¥à ¤«ï VMware SVGA II.
|
||||
readme=/kolibrios/drivers/vmware/readme.txt
|
||||
install=/kolibrios/drivers/vmware/vmwgfx
|
@ -16,6 +16,7 @@ SkinConfig=skincfg,59
|
||||
Volume=@VOLUME,64
|
||||
Panels=panels_cfg,63
|
||||
Mouse=/sys/mouse_cfg,54
|
||||
DriverInstall=/kolibrios/driver/drvinst.kex,71
|
||||
|
||||
[Monitoring]
|
||||
Debug Board=/sys/develop/board,19
|
||||
|
@ -1,27 +0,0 @@
|
||||
[ahci]
|
||||
title=ACHI
|
||||
ver=rc06
|
||||
description=Поиск контроллеров и определение подключённых АТА дисков. В случае успеха, делает видимыми в Клобири жесткие диски подключенные через ACHI.
|
||||
readme=ahci/readme.txt
|
||||
app=ahci/ahci
|
||||
|
||||
[atikms]
|
||||
title=ATI KMS
|
||||
ver=4.4
|
||||
description=Драйвера для видеокарт ATI Radeon. Поддерживаются дискретные и интегрированные чипсеты семейств ATI R100-R600, Evergreen, Northern Islands, Southern Islands. Устанавливает видеорежима при первом запуске и делает доступным смену видеорежима в процессе работы (SYSPANEL -> VideoMode).
|
||||
readme=atikms/readme.txt
|
||||
app=atikms/atikms
|
||||
|
||||
[i915]
|
||||
title=Intel i915
|
||||
ver=4.4.1
|
||||
description=Драйвера для видеокарт Intel. Поддерживаются все PCI Express видеоядра Intel от i915 до Skylake. Устанавливает видеорежима при первом запуске и делает доступным смену видеорежима в процессе работы (SYSPANEL -> VideoMode).
|
||||
readme=i915/readme.txt
|
||||
app=i915/i915
|
||||
|
||||
[vmware]
|
||||
title=VmWare
|
||||
ver=3.14-rc2
|
||||
description=Драйвера для видеокарт Intel. Поддерживаются все PCI Express видеоядра Intel от i915 до Skylake. Устанавливает видеорежима при первом запуске и делает доступным смену видеорежима в процессе работы (SYSPANEL -> VideoMode).
|
||||
readme=i915/readme.txt
|
||||
app=i915/i915
|
@ -11,6 +11,8 @@
|
||||
#include "../lib/obj/box_lib.h"
|
||||
#include "../lib/obj/libio_lib.h"
|
||||
#include "../lib/obj/libini.h"
|
||||
#include "../lib/collection.h"
|
||||
#include "../lib/io.h"
|
||||
#include "../lib/patterns/select_list.h"
|
||||
|
||||
//===================================================//
|
||||
@ -37,6 +39,14 @@ proc_info Form;
|
||||
#define WINDOW_STEP_DRIVER_LIST 2;
|
||||
char window_step = WINDOW_STEP_INTRO;
|
||||
|
||||
collection ini_sections;
|
||||
|
||||
char drvinf_path[4096] = "/sys/drvinf.ini";
|
||||
char cur_version[64];
|
||||
char cur_description[1024];
|
||||
char cur_readme_path[4096];
|
||||
char cur_install_path[4096];
|
||||
|
||||
//===================================================//
|
||||
// //
|
||||
// CODE //
|
||||
@ -45,18 +55,14 @@ char window_step = WINDOW_STEP_INTRO;
|
||||
|
||||
void GetIniData()
|
||||
{
|
||||
ini_enum_sections stdcall ("/sys/drvinf.ini", #process_sections);
|
||||
select_list.count = 0;
|
||||
ini_enum_sections stdcall (#drvinf_path, #process_sections);
|
||||
}
|
||||
|
||||
byte process_sections(dword sec_name, f_name)
|
||||
{
|
||||
ini_enum_keys stdcall (f_name, sec_name, #process_keys);
|
||||
return true;
|
||||
}
|
||||
|
||||
byte process_keys(dword key_value, key_name, sec_name, f_name)
|
||||
{
|
||||
debugln(key_value);
|
||||
select_list.count++;
|
||||
ini_sections.add(sec_name);
|
||||
return true;
|
||||
}
|
||||
|
||||
@ -66,12 +72,12 @@ void main()
|
||||
load_dll(libio, #libio_init,1);
|
||||
load_dll(libini, #lib_init,1);
|
||||
load_dll(boxlib, #box_lib_init,0);
|
||||
//GetIniData();
|
||||
GetIniData();
|
||||
SetEventMask(0x27);
|
||||
loop() switch(WaitEvent())
|
||||
{
|
||||
case evMouse:
|
||||
if (!CheckActiveProcess(Form.ID)) return;
|
||||
if (!CheckActiveProcess(Form.ID)) break;
|
||||
SelectList_ProcessMouse();
|
||||
break;
|
||||
|
||||
@ -109,22 +115,24 @@ void draw_intro_window()
|
||||
void draw_driver_list_window()
|
||||
{
|
||||
int PADDING = 12;
|
||||
int right_frame_x = Form.cwidth/2 + PADDING + calc(PADDING/2);
|
||||
int right_frame_x = Form.cwidth*46/100;
|
||||
int readme_w = 0;
|
||||
//LEFT FRAME
|
||||
select_list.count = 4;
|
||||
SelectList_Init(PADDING,
|
||||
PADDING,
|
||||
Form.cwidth/2 - PADDING - scroll1.size_x,
|
||||
right_frame_x - PADDING - PADDING - 8 - scroll1.size_x,
|
||||
Form.cheight - PADDING - PADDING,
|
||||
false);
|
||||
SelectList_Draw();
|
||||
//RIGHT FRAME
|
||||
WriteTextB(right_frame_x, PADDING+3, 0x81, system.color.work_text, "ATI KMS");
|
||||
WriteText(right_frame_x, PADDING+23, 0x80, MixColors(system.color.work, system.color.work_text,120), "ver 4.4");
|
||||
DrawTextViewArea(right_frame_x-2, PADDING+53, Form.cwidth - right_frame_x - PADDING, Form.cheight-100,
|
||||
T_CAUTION_PARAGRAPH, -1, system.color.work_text);
|
||||
right_frame_x += DrawStandartCaptButton(right_frame_x, Form.cheight-40, BUTTON_ID_README, T_README);
|
||||
DrawStandartCaptButton(right_frame_x, Form.cheight-40, BUTTON_ID_INSTALL, T_INSTALL);
|
||||
GetCurrentSectionData();
|
||||
DrawBar(right_frame_x, PADDING+3, Form.cwidth - right_frame_x - PADDING, 80, system.color.work);
|
||||
WriteTextB(right_frame_x, PADDING+3, 0x81, system.color.work_text, ini_sections.get(select_list.cur_y));
|
||||
WriteText(right_frame_x, PADDING+23, 0x80, system.color.work_text, #cur_version);
|
||||
if(cur_readme_path[0]) readme_w = DrawStandartCaptButton(right_frame_x, PADDING+45, BUTTON_ID_README, T_README);
|
||||
DrawStandartCaptButton(right_frame_x + readme_w, PADDING+45, BUTTON_ID_INSTALL, T_INSTALL);
|
||||
DrawTextViewArea(right_frame_x-2, PADDING+83, Form.cwidth - right_frame_x - PADDING, Form.cheight-PADDING-PADDING,
|
||||
#cur_description, system.color.work, system.color.work_text);
|
||||
}
|
||||
|
||||
void SelectList_DrawLine(dword i)
|
||||
@ -136,18 +144,27 @@ void SelectList_DrawLine(dword i)
|
||||
if (select_list.cur_y-select_list.first==i)
|
||||
{
|
||||
DrawBar(select_list.x, yyy, select_list.w, select_list.item_h, system.color.work_button);
|
||||
WriteText(select_list.x+12,yyy+select_list.text_y,select_list.font_type,system.color.work_button_text, "Hello");
|
||||
WriteText(select_list.x+12,yyy+select_list.text_y,select_list.font_type,system.color.work_button_text, ini_sections.get(i));
|
||||
}
|
||||
else
|
||||
{
|
||||
DrawBar(select_list.x,yyy,select_list.w, select_list.item_h, 0xFFFfff);
|
||||
WriteText(select_list.x+12,yyy+select_list.text_y,select_list.font_type,0, "Hello");
|
||||
WriteText(select_list.x+12,yyy+select_list.text_y,select_list.font_type,0, ini_sections.get(i));
|
||||
}
|
||||
}
|
||||
|
||||
void SelectList_LineChanged()
|
||||
{
|
||||
SelectList_Draw();
|
||||
draw_driver_list_window();
|
||||
}
|
||||
|
||||
void GetCurrentSectionData()
|
||||
{
|
||||
dword cur_section_name = ini_sections.get(select_list.cur_y);
|
||||
ini_get_str stdcall (#drvinf_path, cur_section_name, "ver", #cur_version, sizeof(cur_version), 0);
|
||||
ini_get_str stdcall (#drvinf_path, cur_section_name, "description", #cur_description, sizeof(cur_description), 0);
|
||||
ini_get_str stdcall (#drvinf_path, cur_section_name, "readme", #cur_readme_path, sizeof(cur_readme_path), 0);
|
||||
ini_get_str stdcall (#drvinf_path, cur_section_name, "install", #cur_install_path, sizeof(cur_install_path), 0);
|
||||
}
|
||||
|
||||
//===================================================//
|
||||
@ -161,6 +178,9 @@ void Event_DrawWindow()
|
||||
system.color.get();
|
||||
DefineAndDrawWindow(215, 100, 600, 400, 0x33, system.color.work, WINDOW_TITLE);
|
||||
GetProcessInfo(#Form, SelfInfo);
|
||||
if (Form.status_window>2) return;
|
||||
if (Form.width < 450) { MoveSize(OLD,OLD,450,OLD); return; }
|
||||
if (Form.height < 250) { MoveSize(OLD,OLD,OLD,250); return; }
|
||||
if (window_step == WINDOW_STEP_INTRO) draw_intro_window();
|
||||
if (window_step == WINDOW_STEP_DRIVER_LIST) draw_driver_list_window();
|
||||
return;
|
||||
@ -174,10 +194,10 @@ void Event_AsseptRisk()
|
||||
|
||||
void Event_ShowReadme()
|
||||
{
|
||||
return;
|
||||
io.run("/sys/textreader", #cur_readme_path);
|
||||
}
|
||||
|
||||
void Event_RunInstall()
|
||||
{
|
||||
return;
|
||||
io.run(#cur_install_path, NULL);
|
||||
}
|
Loading…
Reference in New Issue
Block a user