/// ===========================================================

int script_check(char file[])
{

kol_struct70	k70;
char		buf[4];

k70.p00 = 0;
k70.p04 = 0;
//k70.p08 = 0;
k70.p12 = 4; // ÷èòàòü 4 áàéòà
k70.p16 = (unsigned) buf;
k70.p20 = 0;
k70.p21 = file;

kol_file_70(&k70);

if ( !strcmp(buf, script_sign) )
	return TRUE;
else
	return FALSE;
}

/// ===========================================================

int script_run(char exec[], char args[])
{

kol_struct70	k70;
kol_struct_BDVK	bdvk;
unsigned	result, i;
unsigned	long long filesize, pos;
char		*buf; //áóôåğ, êóäà êîïèğóåòñÿ ñêğèïò

k70.p00 = 5;
k70.p04 = k70.p12 = 0;
//k70.p08 = 0;
k70.p16 = (unsigned) &bdvk;
k70.p20 = 0;
k70.p21 = exec;

result = kol_file_70(&k70); // ïîëó÷àåì èíôîğìàöèş î ôàéëå
if ( 0 != result ) 
	return FALSE;

filesize = bdvk.p32; // ïîëó÷àåì ğàçìåğ ôàéëà

buf = malloc(filesize+256); // may fail for over 4Gb file, but impossible case
if (NULL == buf)
	return FALSE;

buf[filesize]=0;

k70.p00 = 0;
k70.p04 = 0;
//k70.p08 = 0;
k70.p12 = filesize;
k70.p16 = (unsigned) buf;
k70.p20 = 0;
k70.p21 = exec;

result = kol_file_70(&k70); // ñ÷èòûâàåì ôàéë â áóôåğ
if ( 0 != result ) 
	{
	free(buf);
	return FALSE;
	}

pos = 0;

for (;;) // îáğàáîòêà ñêğèïòà
	{

	if (pos > filesize)
		break;

	for (i=0;;i++) // ñ÷èòûâàíèå ñòğîêè
		{
		if ((0x0A == buf[pos])||(0x0D == buf[pos])||(0 == buf[pos]))
			{
			pos++;
			CMD[i] = '\0';
			break;
			}
		CMD[i] = buf[pos];
		pos++;
		}

	if ( 0 == strlen(CMD) ) // ïóñòàÿ ñòğîêà
		continue;

	if ('#' == CMD[0]) // êîììåíòàğèé
		continue;

	command_execute();

	}

free(buf);
return TRUE;
}

/// ===========================================================