summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/include/eiotas_particle.h3
-rw-r--r--src/lib/eiotas_particle.c12
2 files changed, 15 insertions, 0 deletions
diff --git a/src/include/eiotas_particle.h b/src/include/eiotas_particle.h
index 52c8011..0f93959 100644
--- a/src/include/eiotas_particle.h
+++ b/src/include/eiotas_particle.h
@@ -44,6 +44,9 @@ struct _Eiotas_Particle {
Eiotas_Iota *dst; /**< current destination */
Eina_Array *dsts; /**< array of destinatinon strings */
unsigned int cur_dst; /**< current destination index */
+ Eina_Stringshare *cur_action; /**< action part of the current destination */
+ Eina_Stringshare *cur_door; /**< door part of the current destination */
+ Eina_Stringshare *cur_room; /**< room part of the current destination */
Eina_Hash *payload; /**< string data carried by this particle */
Eina_Inlist *merged; /**< list of merged particles */
Eina_Array *link_fields; /**< fields used to generate the link value */
diff --git a/src/lib/eiotas_particle.c b/src/lib/eiotas_particle.c
index 6148845..35f3691 100644
--- a/src/lib/eiotas_particle.c
+++ b/src/lib/eiotas_particle.c
@@ -35,6 +35,9 @@ Eiotas_Particle* eiotas_particle_alloc()
particle->link_fields = eina_array_new(EIOTAS_PARTICLE_ARRAY_STEP);
particle->link_value = NULL;
particle->cur_dst = 0;
+ particle->cur_action = NULL;
+ particle->cur_door = NULL;
+ particle->cur_room = NULL;
return particle;
}
@@ -56,6 +59,9 @@ void eiotas_particle_free(Eiotas_Particle *particle)
EINA_ARRAY_ITER_NEXT(particle->link_fields, i, s, it) eina_stringshare_del(s);
eina_array_free(particle->link_fields);
if(particle->link_value) eina_stringshare_del(particle->link_value);
+ if(particle->cur_action) eina_stringshare_del(particle->cur_action);
+ if(particle->cur_door) eina_stringshare_del(particle->cur_door);
+ if(particle->cur_room) eina_stringshare_del(particle->cur_room);
free(particle);
}
@@ -80,6 +86,12 @@ EAPI void eiotas_particle_reset(Eiotas_Particle *particle)
eina_array_clean(particle->link_fields);
if(particle->link_value) eina_stringshare_del(particle->link_value);
particle->link_value = NULL;
+ if(particle->cur_action) eina_stringshare_del(particle->cur_action);
+ particle->cur_action = NULL;
+ if(particle->cur_door) eina_stringshare_del(particle->cur_door);
+ particle->cur_door = NULL;
+ if(particle->cur_room) eina_stringshare_del(particle->cur_room);
+ particle->cur_room = NULL;
}
EAPI void eiotas_particle_init(Eiotas_Particle *particle, Eiotas_Iota *iota)