X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=perl-module%2FPSPP.xs;h=dbdc73a106f0311ca6669b49927cca4000aa64fb;hb=9a8e4c91d3d909487e6820b40b29a0f1f830359d;hp=0f0d16b34321cc8d05165725a75be1455f1c31ae;hpb=9b43ed0de590acc1926e4787c74c86870577c65a;p=pspp diff --git a/perl-module/PSPP.xs b/perl-module/PSPP.xs index 0f0d16b343..dbdc73a106 100644 --- a/perl-module/PSPP.xs +++ b/perl-module/PSPP.xs @@ -46,7 +46,6 @@ #include #include #include -#include #include #include #include @@ -78,7 +77,7 @@ struct syswriter_info /* A thin wrapper around sfm_reader */ struct sysreader_info { - struct sfm_read_info opts; + struct any_read_info opts; /* A pointer to the reader. The reader is owned by the struct */ struct casereader *reader; @@ -424,7 +423,7 @@ set_label (var, label) struct variable *var; char *label CODE: - var_set_label (var, label, false); + var_set_label (var, label); void @@ -633,13 +632,13 @@ INIT: opts.create_writeable = readonly ? ! SvIV (*readonly) : true; opts.compression = (compress && SvIV (*compress) - ? SFM_COMP_SIMPLE - : SFM_COMP_NONE); + ? ANY_COMP_SIMPLE + : ANY_COMP_NONE); opts.version = version ? SvIV (*version) : 3 ; } CODE: struct file_handle *fh = - fh_create_file (NULL, name, fh_default_properties () ); + fh_create_file (NULL, name, "UTF-8", fh_default_properties () ); struct syswriter_info *swi = xmalloc (sizeof (*swi)); swi->writer = sfm_open_writer (fh, dict->dict, opts); swi->dict = dict; @@ -753,28 +752,18 @@ CODE: struct casereader *reader; struct sysreader_info *sri = NULL; struct file_handle *fh = - fh_create_file (NULL, name, fh_default_properties () ); + fh_create_file (NULL, name, "UTF-8", fh_default_properties () ); struct dictionary *dict; - struct sfm_reader *r; sri = xmalloc (sizeof (*sri)); - r = sfm_open (fh); - if (r) - { - sri->reader = sfm_decode (r, NULL, &dict, &sri->opts); - if (sri->reader) - sri->dict = create_pspp_dict (dict); - else - { - free (sri); - sri = NULL; - } - } + sri->reader = any_reader_open_and_decode (fh, NULL, &dict, &sri->opts); + if (sri->reader) + sri->dict = create_pspp_dict (dict); else { free (sri); sri = NULL; - } + } RETVAL = sri; OUTPUT: