summaryrefslogtreecommitdiff
path: root/call-process_digest_list-after-files-are-added.patch
blob: 4809b5856a436374a03f83da6ceeac59c1961967 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
From 641ec5a50cb5057e02c4cfe7bd537a32fafdd665 Mon Sep 17 00:00:00 2001
From: Roberto Sassu <roberto.sassu@huawei.com>
Date: Mon, 26 Oct 2020 12:10:31 +0800
Subject: [PATCH] call process_digest_list after files are added

Signed-off-by: Anakin Zhang <benjamin93@163.com>
---
 plugins/digest_list.c | 78 ++++++++++++++++++++++++++++++++++++++-----
 1 file changed, 69 insertions(+), 9 deletions(-)

diff --git a/plugins/digest_list.c b/plugins/digest_list.c
index 9fcb5c4..7213b41 100644
--- a/plugins/digest_list.c
+++ b/plugins/digest_list.c
@@ -479,28 +479,88 @@ out:
 	return ret;
 }
 
+rpmte cur_te;
+int digest_list_counter;
+
 static rpmRC digest_list_psm_pre(rpmPlugin plugin, rpmte te)
 {
-	process_digest_list(te, 0);
-	if (!strcmp(rpmteN(te), "digest-list-tools"))
-		process_digest_list(te, 1);
+	Header rpm = rpmteHeader(te);
+	rpmtd dirnames;
+	int i;
+
+	digest_list_counter = 0;
+
+	dirnames = rpmtdNew();
+	headerGet(rpm, RPMTAG_DIRNAMES, dirnames, 0);
+
+	while ((i = rpmtdNext(dirnames)) >= 0) {
+		char *dirname = (char *) rpmtdGetString(dirnames);
+		if (!strncmp(dirname, DIGEST_LIST_DEFAULT_PATH,
+			     sizeof(DIGEST_LIST_DEFAULT_PATH) - 1))
+			digest_list_counter++;
+	}
 
+	rpmtdFree(dirnames);
+
+	cur_te = te;
 	return RPMRC_OK;
 }
 
-static rpmRC digest_list_psm_post(rpmPlugin plugin, rpmte te, int res)
+static rpmRC digest_list_file_common(rpmPlugin plugin, rpmfi fi,
+				     const char* path, mode_t file_mode,
+				     rpmFsmOp op, int pre, int res)
 {
-	if (res != RPMRC_OK)
+	rpmFileAction action = XFO_ACTION(op);
+
+	if (!digest_list_counter)
+		return RPMRC_OK;
+
+	if (!cur_te)
+		return RPMRC_OK;
+
+	if (!pre && res != RPMRC_OK)
+		return res;
+
+	if ((pre && action != FA_ERASE) ||
+	    (!pre && action != FA_CREATE))
 		return RPMRC_OK;
 
-	process_digest_list(te, 0);
-	if (!strcmp(rpmteN(te), "digest-list-tools"))
-		process_digest_list(te, 1);
+	if (digest_list_counter) {
+		if (!pre) {
+			if (!strncmp(path, DIGEST_LIST_DEFAULT_PATH,
+				     sizeof(DIGEST_LIST_DEFAULT_PATH) - 1))
+				digest_list_counter--;
+		} else {
+			digest_list_counter = 0;
+		}
+
+		if (digest_list_counter)
+			return RPMRC_OK;
+	}
+
+	process_digest_list(cur_te, 0);
+	if (!strcmp(rpmteN(cur_te), "digest-list-tools"))
+		process_digest_list(cur_te, 1);
 
 	return RPMRC_OK;
 }
 
+static rpmRC digest_list_file_pre(rpmPlugin plugin, rpmfi fi,
+				  const char* path, mode_t file_mode,
+				  rpmFsmOp op)
+{
+	return digest_list_file_common(plugin, fi, path, file_mode, op, 1, 0);
+}
+
+static rpmRC digest_list_file_post(rpmPlugin plugin, rpmfi fi,
+				  const char* path, mode_t file_mode,
+				  rpmFsmOp op, int res)
+{
+	return digest_list_file_common(plugin, fi, path, file_mode, op, 0, res);
+}
+
 struct rpmPluginHooks_s digest_list_hooks = {
 	.psm_pre = digest_list_psm_pre,
-	.psm_post = digest_list_psm_post,
+	.fsm_file_pre = digest_list_file_pre,
+	.fsm_file_post = digest_list_file_post,
 };
-- 
2.23.0