#include #include #include #include #include "cc4group.h" const char* formatTime(int32_t time) { time_t tTime = time; static char ret[128]; strftime(ret, sizeof(ret), "%c", localtime(&tTime)); return ret; } const char* formatSize(uint32_t size) { static char ret[128]; if(size < 1000) { snprintf(ret, 128, "%4u", size); return ret; } static const char prefixes[] = " KMGTPE"; const char* prefix = prefixes; uint32_t fract = 0; while(size >= 1000 && *(prefix + 1) != '\0') { ++prefix; fract = size % 1000; size /= 1000; } if(size < 10) { snprintf(ret, 128, "%1.1f%c", (float)size + (float)fract / 1000, *prefix); } else { snprintf(ret, 128, "%3u%c", size, *prefix); } return ret; } int main(int argc, char* argv[]) { if(argc != 2 && argc != 3) { fprintf(stderr, "USAGE: %s [subgroup]\n", argv[0]); return EXIT_FAILURE; } CC4Group* group = cc4group.new(); bool success = cc4group.openExisting(group, argv[1]); if(!success) { fprintf(stderr, "ERROR: Can not open group file \"%s\": %s\n", argv[1], cc4group.getErrorMessage(group)); } else { CC4Group_EntryInfo* infos; size_t entries; success = cc4group.getEntryInfos(group, argc == 3 ? argv[2] : NULL, &infos, &entries); if(!success) { fprintf(stderr, "ERROR: Can not list group entries: %s\n", cc4group.getErrorMessage(group)); } else { for(size_t i = 0; i < entries; ++i) { printf("%c %s %s %s\t%s\n", infos[i].directory ? 'd' : infos[i].executable ? 'x' : ' ', formatTime(infos[i].modified), formatSize(infos[i].totalSize), infos[i].fileName, infos[i].author); } free(infos); } } cc4group.delete(group); return success ? EXIT_SUCCESS : EXIT_FAILURE; }