_ prefix not required
[strongswan.git] / src / libcharon / processing / jobs / delete_child_sa_job.c
index ca55721..29122cd 100644 (file)
@@ -46,18 +46,14 @@ struct private_delete_child_sa_job_t {
        u_int32_t spi;
 };
 
-/**
- * Implementation of job_t.destroy.
- */
-static void destroy(private_delete_child_sa_job_t *this)
+METHOD(job_t, destroy, void,
+       private_delete_child_sa_job_t *this)
 {
        free(this);
 }
 
-/**
- * Implementation of job_t.execute.
- */
-static void execute(private_delete_child_sa_job_t *this)
+METHOD(job_t, execute, void,
+       private_delete_child_sa_job_t *this)
 {
        ike_sa_t *ike_sa;
 
@@ -84,16 +80,19 @@ delete_child_sa_job_t *delete_child_sa_job_create(u_int32_t reqid,
                                                                                                  protocol_id_t protocol,
                                                                                                  u_int32_t spi)
 {
-       private_delete_child_sa_job_t *this = malloc_thing(private_delete_child_sa_job_t);
-
-       /* interface functions */
-       this->public.job_interface.execute = (void (*) (job_t *)) execute;
-       this->public.job_interface.destroy = (void (*)(job_t*)) destroy;
-
-       /* private variables */
-       this->reqid = reqid;
-       this->protocol = protocol;
-       this->spi = spi;
+       private_delete_child_sa_job_t *this;
+
+       INIT(this,
+               .public = {
+                       .job_interface = {
+                               .execute = _execute,
+                               .destroy = _destroy,
+                       },
+               },
+               .reqid = reqid,
+               .protocol = protocol,
+               .spi = spi,
+       );
 
        return &this->public;
 }