MINOR: tcp-rules: Add release functions for existing TCP actions

TCP actions allocating memory during configuration parsing now use dedicated
functions to release it.
diff --git a/src/tcp_rules.c b/src/tcp_rules.c
index 4f90ced..25cc3fb 100644
--- a/src/tcp_rules.c
+++ b/src/tcp_rules.c
@@ -702,6 +702,17 @@
 	return ACT_RET_CONT;
 }
 
+static void release_tcp_capture(struct act_rule * rule)
+{
+	release_sample_expr(rule->arg.cap.expr);
+}
+
+
+static void release_tcp_track_sc(struct act_rule * rule)
+{
+	release_sample_expr(rule->arg.trk_ctr.expr);
+}
+
 /* Parse a tcp-request rule. Return a negative value in case of failure */
 static int tcp_parse_request_rule(char **args, int arg, int section_type,
                                   struct proxy *curpx, struct proxy *defpx,
@@ -811,6 +822,7 @@
 		rule->action = ACT_CUSTOM;
 		rule->action_ptr = tcp_action_capture;
 		rule->check_ptr = check_capture;
+		rule->release_ptr  = release_tcp_capture;
 	}
 	else if (strncmp(args[arg], "track-sc", 8) == 0) {
 		struct sample_expr *expr;
@@ -863,6 +875,7 @@
 		rule->arg.trk_ctr.expr = expr;
 		rule->action_ptr = tcp_action_track_sc;
 		rule->check_ptr = check_trk_action;
+		rule->release_ptr  = release_tcp_track_sc;
 	}
 	else if (strcmp(args[arg], "expect-proxy") == 0) {
 		if (strcmp(args[arg+1], "layer4") != 0) {