2013-02-16 12:25:37 +01:00
|
|
|
|
|
|
|
|
|
int cmd_cp(char param[])
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
char* argv[100];
|
|
|
|
|
int argc;
|
2017-02-06 13:35:58 +01:00
|
|
|
|
char *filename_in = NULL;
|
|
|
|
|
char *filename_out = NULL;
|
|
|
|
|
char *buffer = NULL;
|
2013-02-16 12:25:37 +01:00
|
|
|
|
|
|
|
|
|
kol_struct70 k70_in;
|
|
|
|
|
kol_struct70 k70_out;
|
|
|
|
|
|
|
|
|
|
kol_struct_BDVK bdvk;
|
|
|
|
|
|
2017-02-06 13:35:58 +01:00
|
|
|
|
unsigned long long filesize;
|
|
|
|
|
unsigned result, buf_size;
|
2013-02-16 12:25:37 +01:00
|
|
|
|
|
|
|
|
|
argc = parameters_prepare(param, argv);
|
|
|
|
|
|
|
|
|
|
if (argc != 2)
|
|
|
|
|
{
|
|
|
|
|
#if LANG_ENG
|
|
|
|
|
printf(" cp <file_in> <file_out>\n\r");
|
|
|
|
|
#elif LANG_RUS
|
|
|
|
|
printf(" cp <<3C><><EFBFBD><EFBFBD>筨<EFBFBD>> <१<><E0A5A7><EFBFBD><EFBFBD><EFBFBD><EFBFBD>>\n\r");
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
parameters_free(argc, argv);
|
|
|
|
|
|
2013-02-17 16:22:51 +01:00
|
|
|
|
return TRUE;
|
2013-02-16 12:25:37 +01:00
|
|
|
|
}
|
|
|
|
|
|
2017-01-06 22:23:13 +01:00
|
|
|
|
filename_in = (char*) malloc(FILENAME_MAX);
|
|
|
|
|
filename_out = (char*) malloc(FILENAME_MAX);
|
2013-02-16 12:25:37 +01:00
|
|
|
|
|
|
|
|
|
if (argv[0][0] != '/')
|
|
|
|
|
{
|
|
|
|
|
strcpy(filename_in, cur_dir);
|
|
|
|
|
if (filename_in[strlen(filename_in)-1] != '/')
|
|
|
|
|
strcat(filename_in, "/"); // add slash
|
|
|
|
|
strcat(filename_in, argv[0]);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
strcpy(filename_in, argv[0]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (argv[1][0] != '/')
|
|
|
|
|
{
|
|
|
|
|
strcpy(filename_out, cur_dir);
|
|
|
|
|
if (filename_out[strlen(filename_out)-1] != '/')
|
|
|
|
|
strcat(filename_out, "/"); // add slash
|
|
|
|
|
strcat(filename_out, argv[1]);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
strcpy(filename_out, argv[1]);
|
|
|
|
|
}
|
2017-02-06 13:35:58 +01:00
|
|
|
|
|
|
|
|
|
// add ability to use directory as destination
|
|
|
|
|
if ( dir_check(filename_out) )
|
|
|
|
|
{
|
|
|
|
|
char *fname = strrchr(filename_in, '/') + 1; // always exist, as we add curdir
|
|
|
|
|
if (filename_out[strlen(filename_out)-1] != '/')
|
|
|
|
|
strcat(filename_out, "/"); // add slash
|
|
|
|
|
strcat(filename_out, fname);
|
|
|
|
|
}
|
2013-02-16 12:25:37 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
k70_in.p00 = 5;
|
2017-02-06 13:35:58 +01:00
|
|
|
|
k70_in.p04 = 0LL;
|
|
|
|
|
k70_in.p12 = 0;
|
2013-02-16 12:25:37 +01:00
|
|
|
|
k70_in.p16 = (unsigned) &bdvk;
|
|
|
|
|
k70_in.p20 = 0;
|
|
|
|
|
k70_in.p21 = filename_in;
|
|
|
|
|
|
|
|
|
|
result = kol_file_70(&k70_in); // <20><><EFBFBD><EFBFBD>砥<EFBFBD> <20><><EFBFBD><EFBFBD>ଠ<EFBFBD><E0ACA0><EFBFBD> <20> 䠩<><E4A0A9>
|
|
|
|
|
if ( 0 != result )
|
2017-02-06 13:35:58 +01:00
|
|
|
|
goto lbl_exit;
|
2013-02-16 12:25:37 +01:00
|
|
|
|
|
2017-02-06 13:35:58 +01:00
|
|
|
|
// count buffer size up to 1Mb, but no more than 1/2 of free memory
|
|
|
|
|
buf_size = 1 << 20; // 1Mb
|
|
|
|
|
while( ((buf_size >> 10) > kol_system_memfree()) && (buf_size > 4096) )
|
|
|
|
|
buf_size /= 2;
|
2013-02-16 12:25:37 +01:00
|
|
|
|
|
2017-02-06 13:35:58 +01:00
|
|
|
|
filesize = bdvk.p32; // <20><><EFBFBD><EFBFBD>砥<EFBFBD> ࠧ<><E0A0A7><EFBFBD> 䠩<><E4A0A9>(<28><>࠭<EFBFBD>祭<EFBFBD><E7A5AD> - 4 <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> ⮫쪮 <20><><EFBFBD> FAT)
|
|
|
|
|
if (buf_size > filesize)
|
|
|
|
|
buf_size = (unsigned)filesize; // may be zero!
|
|
|
|
|
if (buf_size == 0) buf_size = 4096; // ...
|
|
|
|
|
|
|
|
|
|
buffer = (char*) malloc(buf_size);
|
|
|
|
|
if (!buffer)
|
|
|
|
|
{
|
|
|
|
|
result = E_NOMEM;
|
|
|
|
|
goto lbl_exit;
|
|
|
|
|
}
|
2013-02-16 12:25:37 +01:00
|
|
|
|
|
|
|
|
|
k70_in.p00 = 0;
|
2017-02-06 13:35:58 +01:00
|
|
|
|
//k70_in.p08 = 0;
|
|
|
|
|
k70_in.p12 = buf_size;
|
2013-02-16 12:25:37 +01:00
|
|
|
|
k70_in.p16 = (unsigned) buffer;
|
|
|
|
|
k70_in.p20 = 0;
|
|
|
|
|
k70_in.p21 = filename_in;
|
|
|
|
|
|
|
|
|
|
k70_out.p00 = 2;
|
2017-02-06 13:35:58 +01:00
|
|
|
|
//k70_out.p08 = 0;
|
|
|
|
|
k70_out.p12 = buf_size;
|
2013-02-16 12:25:37 +01:00
|
|
|
|
k70_out.p16 = (unsigned) buffer;
|
|
|
|
|
k70_out.p20 = 0;
|
|
|
|
|
k70_out.p21 = filename_out;
|
|
|
|
|
|
2017-02-06 13:35:58 +01:00
|
|
|
|
unsigned long long offset = 0;
|
|
|
|
|
do {
|
|
|
|
|
k70_in.p04 = offset;
|
|
|
|
|
if (offset + buf_size > filesize) // last chunk
|
|
|
|
|
{
|
|
|
|
|
k70_in.p12 = k70_out.p12 = (unsigned)(filesize - offset); // filesize % buf_size;
|
|
|
|
|
}
|
|
|
|
|
|
2013-02-16 12:25:37 +01:00
|
|
|
|
result = kol_file_70(&k70_in); // <20>⥭<EFBFBD><E2A5AD>
|
|
|
|
|
if (result != 0)
|
2017-02-06 13:35:58 +01:00
|
|
|
|
goto lbl_exit;
|
2013-02-16 12:25:37 +01:00
|
|
|
|
|
2017-02-06 13:35:58 +01:00
|
|
|
|
k70_out.p04 = offset;
|
2013-02-16 12:25:37 +01:00
|
|
|
|
result = kol_file_70(&k70_out); // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
if (result != 0)
|
2017-02-06 13:35:58 +01:00
|
|
|
|
goto lbl_exit;
|
2013-02-16 12:25:37 +01:00
|
|
|
|
|
2017-02-06 13:35:58 +01:00
|
|
|
|
if (k70_out.p00 == 2)
|
|
|
|
|
k70_out.p00 = 3; // <20><><EFBFBD>塞 <20>㭪<EFBFBD><E3ADAA><EFBFBD> <20> ᮧ<><E1AEA7><EFBFBD><EFBFBD><EFBFBD> (2) <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (3)
|
|
|
|
|
offset += buf_size;
|
|
|
|
|
} while (offset < filesize);
|
2013-02-16 12:25:37 +01:00
|
|
|
|
|
2017-02-06 13:35:58 +01:00
|
|
|
|
lbl_exit:
|
2013-02-16 12:25:37 +01:00
|
|
|
|
|
|
|
|
|
parameters_free(argc, argv);
|
|
|
|
|
free(filename_in);
|
|
|
|
|
free(filename_out);
|
|
|
|
|
free(buffer);
|
|
|
|
|
|
2017-02-06 13:35:58 +01:00
|
|
|
|
return (result == 0);
|
2013-02-16 12:25:37 +01:00
|
|
|
|
}
|
|
|
|
|
|