summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Larson <slioch@eng-140.vyatta.com>2008-04-15 13:54:13 -0700
committerMichael Larson <slioch@eng-140.vyatta.com>2008-04-15 13:54:13 -0700
commit6f76a6068eff7d50f9725e3edff3bb963d8f1e88 (patch)
tree969c30cbc03e8827e58a42da63ff63f8bd53ec67
parent043d8925a06ad6a6ac01939b263d474a31721352 (diff)
downloadvyatta-cfg-6f76a6068eff7d50f9725e3edff3bb963d8f1e88.tar.gz
vyatta-cfg-6f76a6068eff7d50f9725e3edff3bb963d8f1e88.zip
reverse sort order on delete
-rw-r--r--src/commit.c34
1 files changed, 25 insertions, 9 deletions
diff --git a/src/commit.c b/src/commit.c
index c0051a2..1221e37 100644
--- a/src/commit.c
+++ b/src/commit.c
@@ -76,8 +76,19 @@ compare_dirname(const void *p, const void *q)
return ((long)b->priority - (long)a->priority);
}
+static int
+compare_dirname_reverse_priority(const void *p, const void *q)
+{
+ const struct DirSort *a = (const struct DirSort*)*(struct Dirsort **)p;
+ const struct DirSort *b = (const struct DirSort*)*(struct Dirsort **)q;
+ if (a->priority == b->priority) {
+ return strcmp(a->name,b->name);
+ }
+ return ((long)a->priority - (long)b->priority);
+}
+
struct DirIndex*
-init_next_filtered_dirname(DIR *dp, int exclude_wh)
+init_next_filtered_dirname(DIR *dp, int sort_order, int exclude_wh)
{
struct DirIndex *di = malloc(sizeof(struct DirIndex));
di->dirname = malloc(1024 * sizeof(char*));
@@ -118,7 +129,12 @@ init_next_filtered_dirname(DIR *dp, int exclude_wh)
}
}
}
- qsort(di->dirname, di->dirname_ct, sizeof(char*), compare_dirname);
+ if (sort_order == 0) {
+ qsort(di->dirname, di->dirname_ct, sizeof(char*), compare_dirname);
+ }
+ else {
+ qsort(di->dirname, di->dirname_ct, sizeof(char*), compare_dirname_reverse_priority);
+ }
return di;
}
@@ -206,7 +222,7 @@ static boolean validate_dir_for_commit()
if (def_present && def.tag) {
push_path(&t_path, tag_name); /* PUSH 2a */
}
- struct DirIndex *di = init_next_filtered_dirname(dp,1);
+ struct DirIndex *di = init_next_filtered_dirname(dp,0,1);
while ((dirname = get_next_filtered_dirname(di)) != NULL) {
subdirs_number++;
@@ -1037,13 +1053,13 @@ valstruct_append(valstruct *mvals, char *cp, vtw_type_e type)
*/
static void
get_filtered_directory_listing(DIR *dp, valstruct *mvals, vtw_type_e type,
- int exclude_wh)
+ int exclude_wh, int sort_order)
{
char *dname = NULL;
char *cp = NULL;
memset(mvals, 0, sizeof (valstruct));
- struct DirIndex *di = init_next_filtered_dirname(dp,exclude_wh);
+ struct DirIndex *di = init_next_filtered_dirname(dp, sort_order, exclude_wh);
while ((dname = get_next_filtered_dirname(di)) != NULL) {
cp = clind_unescape(dname);
valstruct_append(mvals, cp, type);
@@ -1152,19 +1168,19 @@ static boolean commit_delete_children(vtw_def *defp, boolean deleting,
memset(&cur_sorted, 0, sizeof(vtw_sorted));
/* changes directory */
- get_filtered_directory_listing(dp, &mvals, type, 0);
+ get_filtered_directory_listing(dp, &mvals, type, 0, 1);
if (closedir(dp) != 0) {
INTERNAL;
}
if (adp && mdp) {
/* active directory */
- get_filtered_directory_listing(adp, &valsA, type, 0);
+ get_filtered_directory_listing(adp, &valsA, type, 0, 1);
if (closedir(adp) != 0) {
INTERNAL;
}
/* modified directory */
- get_filtered_directory_listing(mdp, &valsM, type, 0);
+ get_filtered_directory_listing(mdp, &valsM, type, 0, 1);
if (closedir(mdp) != 0) {
INTERNAL;
}
@@ -1243,7 +1259,7 @@ static boolean commit_update_children(vtw_def *defp, boolean creating,
if (type == ERROR_TYPE)
type = TEXT_TYPE;
- get_filtered_directory_listing(dp, &mvals, type, 0);
+ get_filtered_directory_listing(dp, &mvals, type, 0, 0);
if (closedir(dp) != 0) {
INTERNAL;
}