- Added pkill command

git-svn-id: svn://kolibrios.org@8662 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
turbocat
2021-04-01 22:06:12 +00:00
parent 232277e20f
commit e54c8af781
5 changed files with 54 additions and 0 deletions

View File

@@ -0,0 +1,50 @@
int cmd_pkill(char param[])
{
int i=1, n=0; int process_count=0;
char *buf1k=NULL;
unsigned PID=0;
#ifdef LANG_RUS
#define PKILL_HELP " pkill <<3C><><EFBFBD>_<EFBFBD><5F><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>>\n\r"
#define PKILL_KILL " PID: %u - 㡨<>\n"
#define PKILL_NOT_KILL " PID: %u - <20><><>\n"
#define PKILL_NOT_FOUND " <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><20><><E2A0AA> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>!\n"
#else
#define PKILL_HELP " pkill <process_name>\n\r"
#define PKILL_KILL " PID: %u - killed\n"
#define PKILL_NOT_KILL " PID: %u - not killed\n"
#define PKILL_NOT_FOUND " No processes with this name were found!\n"
#endif
if(!strlen(param)){
printf(PKILL_HELP);
return TRUE;
}
buf1k = malloc(1024);
if(buf1k==NULL){
return FALSE;
}
while(i!=n){
n = kol_process_info(i, buf1k);
if(!strnicmp(buf1k+10, param, 10)){
memcpy(&PID, buf1k+30 ,sizeof(unsigned));
if(kol_process_kill_pid(PID)){
printf(PKILL_NOT_KILL, PID);
}else{
printf(PKILL_KILL, PID);
}
process_count++;
}
i++;
}
if(!process_count){
printf(PKILL_NOT_FOUND);
}
free(buf1k);
return TRUE;
}