이 파일 https://github.com/HaarigerHarald/omxiv/blob/master/omxiv.c을 수정하려고합니다.이 파일은 getImageFilesInDir 함수라고 생각합니다. 알파벳순으로 오름차순으로 디렉토리에있는 파일이 아닌 알파벳순으로 내림차순으로 (img05.png, img04.png, img03.png, img02.png, img01.png) 다시 표시하도록 이미지 뷰어를 표시하도록 변경해야합니다. 가장 큰 번호로 파일 한 첫 번째 이미지 (내 경우 img05.png)알파벳순으로 내림차순으로 파일 정렬
나는 for(i=0; i-1; i--)
과 같은 것을 시도했지만 도움이되지 않았습니다. 어떤 아이디어로 만드시겠습니까?
static int getImageFilesInDir(char ***list, const char* path){
struct dirent **namelist;
int imageNum;
imageNum = scandir(path, &namelist, imageFilter, alphasort);
if (imageNum < 0)
return imageNum;
else {
*list=malloc(sizeof(char*) *imageNum);
int i;
for(i=0; i<imageNum; i++) {
if(strcmp(path, ".") == 0 || strcmp(path, "./") == 0){
(*list)[i]= malloc(strlen(namelist[i]->d_name)+1);
strcpy((*list)[i], namelist[i]->d_name);
}else{
if(strrchr(path, '/')- path != strlen(path)-1){
(*list)[i]= malloc(strlen(path)+strlen(namelist[i]->d_name)+2);
strcpy((*list)[i],path);
(*list)[i][strlen(path)]='/';
strcpy((*list)[i]+strlen(path)+1,namelist[i]->d_name);
}else{
(*list)[i]= malloc(strlen(path)+strlen(namelist[i]->d_name)+1);
strcpy((*list)[i],path);
strcpy((*list)[i]+strlen(path),namelist[i]->d_name);
}
}
free(namelist[i]);
}
free(namelist);
}
return imageNum;
}
당신은 단지 scandir()
가 alphasort()
가하는 일의 부정적인를 수행 콜백을 비교 줄 필요가
[mcve] 또는 [SSCCE (Short, Self Contained, Correct Example)]로 질문을 ** 편집하십시오. (http://sscce.org) – NathanOliver
비교 콜백 함수를 구현하고 싶습니다. 'alphasort'를 대체합니다. 'scandir()'에 대한 RTFM. – alk
또는 반환 된 네임리스트 배열의 항목 순서 만 바꿀 수 있습니다. – FredK