projects
/
pspp
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
macro: Fix memory leak expanding !DO loop over list.
[pspp]
/
src
/
data
/
por-file-reader.c
diff --git
a/src/data/por-file-reader.c
b/src/data/por-file-reader.c
index 343615a826fcecb70f6e013b101b4cba1c6f36b1..b5cc35b825ba73c27ae015971fd249afdf9e749e 100644
(file)
--- a/
src/data/por-file-reader.c
+++ b/
src/data/por-file-reader.c
@@
-112,12
+112,13
@@
error (struct pfm_reader *r, const char *msg, ...)
ds_put_vformat (&text, msg, args);
va_end (args);
ds_put_vformat (&text, msg, args);
va_end (args);
- struct msg m = {
+ struct msg *m = xmalloc (sizeof *m);
+ *m = (struct msg) {
.category = MSG_C_GENERAL,
.severity = MSG_S_ERROR,
.category = MSG_C_GENERAL,
.severity = MSG_S_ERROR,
- .text = ds_cstr (&text),
+ .text = ds_
steal_
cstr (&text),
};
};
- msg_emit (
&
m);
+ msg_emit (m);
r->ok = false;
r->ok = false;
@@
-139,12
+140,13
@@
warning (struct pfm_reader *r, const char *msg, ...)
ds_put_vformat (&text, msg, args);
va_end (args);
ds_put_vformat (&text, msg, args);
va_end (args);
- struct msg m = {
+ struct msg *m = xmalloc (sizeof *m);
+ *m = (struct msg) {
.category = MSG_C_GENERAL,
.severity = MSG_S_WARNING,
.category = MSG_C_GENERAL,
.severity = MSG_S_WARNING,
- .text = ds_cstr (&text),
+ .text = ds_
steal_
cstr (&text),
};
};
- msg_emit (
&
m);
+ msg_emit (m);
}
/* Close and destroy R.
}
/* Close and destroy R.
@@
-899,7
+901,7
@@
por_file_casereader_read (struct casereader *reader, void *r_)
int width = caseproto_get_width (r->proto, i);
if (width == 0)
int width = caseproto_get_width (r->proto, i);
if (width == 0)
-
case_data_rw_idx (c, i)->f
= read_float (r);
+
*case_num_rw_idx (c, i)
= read_float (r);
else
{
uint8_t buf[256];
else
{
uint8_t buf[256];