Я написал эту программу на C , а также на erlang
На практике я пытался переписать на D. Друг также написал ее на D, но написал по-другому
Шаги просты.Псевдокод:
While not end of file:
X = Read ulong from file and covert to little endian
Y = Read X bytes from file into ubyte array
subtract 1 from each byte in Y
save Y as an ogg file
Моя попытка D:
import std.file, std.stdio, std.bitmanip, std.conv, core.stdc.stdio : fread;
void main(){
auto file = File("./sounds.pk", "r+");
auto fp = file.getFP();
ulong x;
int i,cnt;
while(fread(&x, 8, 1, fp)){
writeln("start");
x=swapEndian(x);
writeln(x," ",cnt++,"\n");
ubyte[] arr= new ubyte[x];
fread(&arr, x, 1, fp);
for(i=0;i<x;i++) arr[i]-=1;
std.file.write("/home/fold/wak_oggs/"~to!string(cnt)~".ogg",arr);
}
}
Кажется, я не могу просто использовать fread для обр.sizeof равен 16, и это дает ошибку сегментации, когда я добираюсь до вычитающей части.Я не могу автоматически выделить статический массив, или, по крайней мере, я не знаю как.Я также не могу использовать malloc, потому что он дает мне ошибки, когда я пытаюсь разыграть void *, когда я перебираю байты.Как бы вы написали это, или что я мог бы сделать лучше?