- struct user_stats_info usi;
- enum enum_user_list ula = conf.user_list_arg;
- int print_size_list = (ula == user_list_arg_size
- || ula == user_list_arg_both);
-
- if (print_size_list) {
- usi.count = conf.limit_arg;
- usi.ui = ui;
- usi.flags = USF_PRINT_DIRNAME | USF_PRINT_BYTES | USF_COMPUTE_SUMMARY;
- if (!conf.no_headers_given)
- printf("%s (uid %u), by size%s:\n",
- ui->pw_name? ui->pw_name : "?", (unsigned)ui->uid,
- size_unit_buf);
- ret = adu_loop_reverse(ui->table, UT_BYTES, &usi, user_stats_loop_function,
- &usi.ret, &usi.osl_errno);
- if (ret < 0)
- return ret;
- printf("\n");
- }
- if (ula == user_list_arg_file_count || ula == user_list_arg_both) {
- if (!conf.no_headers_given)
- printf("%s (uid %u), by file count%s:\n",
- ui->pw_name? ui->pw_name : "?", (unsigned)ui->uid,
- count_unit_buf);
- usi.count = conf.limit_arg,
- usi.ui = ui;
- usi.flags = USF_PRINT_DIRNAME | USF_PRINT_FILES;
- ret = adu_loop_reverse(ui->table, UT_FILES, &usi, user_stats_loop_function,
- &usi.ret, &usi.osl_errno);
- if (ret < 0)
- return ret;
- printf("\n");
- }
- if (ula == user_list_arg_none && !conf.no_user_summary_given) {
- usi.count = conf.limit_arg;
- usi.ui = ui;
- usi.flags = USF_COMPUTE_SUMMARY;
- ret = adu_loop_reverse(ui->table, UT_FILES, &usi, user_stats_loop_function,
- &usi.ret, &usi.osl_errno);
+ enum user_table_columns sort_column = UT_BYTES;
+ struct user_list_info uli = {
+ .ui = ui,
+ .fi = fi,
+ .count = select_conf.limit_arg
+ };
+
+ if (select_conf.list_sort_arg == list_sort_arg_file_count)
+ sort_column = UT_FILES;
+
+ if (!select_conf.no_headers_given) {
+ ret = output("%s (uid %u)\n",
+ ui->pw_name? ui->pw_name : "?", (unsigned)ui->uid);