ds_list_load
NOTE: This script is made somewhat redundant by the addition of
native functions ds_list_read()
and ds_list_write()
,
although this script works differently.
- ds_list_load(filename [,separator])
- Returns as ds_list retrieved from a given file, or (-1) on error.
COPY/// ds_list_load(filename [,separator])
//
// Returns as ds_list retrieved from a given file, or (-1) on error.
//
// filename file path to save the list to, string
// separator separator used between elements, string (optional)
//
// If separator is not given, each list element must be on a separate line.
// If separator also appears within data, the list will not load correctly.
//
/// GMLscripts.com/license
{
var dsid,filename,sep,fid,dat,len,ind,pos;
filename = argument0;
if (is_string(argument1)) sep = argument1; else sep = chr(13)+chr(10);
fid = file_text_open_read(filename);
if (fid > 0) {
dat = "";
while (!file_text_eof(fid)) {
dat += file_text_read_string(fid);
file_text_readln(fid);
}
dat += sep;
len = string_length(sep);
ind = 0;
dsid = ds_list_create();
repeat (string_count(sep,dat)) {
pos = string_pos(sep,dat)-1;
ds_list_add(dsid,string_copy(dat,1,pos));
dat = string_delete(dat,1,pos+len);
ind += 1;
}
file_text_close(fid);
return dsid;
}else{
return -1;
}
}
Contributors: Leif902, xot
GitHub: View · Commits · Blame · Raw