/* PSPP - a program for statistical analysis.
- Copyright (C) 2011 Free Software Foundation, Inc.
+ Copyright (C) 2011, 2012 Free Software Foundation, Inc.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
*/
-
struct interaction *
interaction_create (const struct variable *v)
{
return i;
}
+/* Deep copy an interaction */
+struct interaction *
+interaction_clone (const struct interaction *iact)
+{
+ int v;
+ struct interaction *i = xmalloc (sizeof *i);
+ i->vars = xcalloc (iact->n_vars, sizeof *i->vars);
+ i->n_vars = iact->n_vars;
+
+ for (v = 0; v < iact->n_vars; ++v)
+ {
+ i->vars[v] = iact->vars[v];
+ }
+
+ return i;
+}
+
+
void
interaction_destroy (struct interaction *i)
{
interaction_dump (const struct interaction *i)
{
int v = 0;
- printf ("%s", var_get_name (i->vars[v]));
- for (v = 1; v < i->n_vars; ++v)
+ if ( i->n_vars == 0)
{
- printf (" * %s", var_get_name (i->vars[v]));
+ printf ("(empty)\n");
+ return;
}
+ printf ("%s", var_get_name (i->vars[v]));
+ for (v = 1; v < i->n_vars; ++v)
+ printf (" * %s", var_get_name (i->vars[v]));
printf ("\n");
}
interaction_to_string (const struct interaction *iact, struct string *str)
{
int v = 0;
+ if ( iact->n_vars == 0)
+ return;
ds_put_cstr (str, var_to_string (iact->vars[v]));
for (v = 1; v < iact->n_vars; ++v)
{