Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za duben (YouTube). Na Linuxu je vedle Qt frontendu nově k dispozici také GTK4 / libadwaita frontend.
Neziskové průmyslové konsorcium Khronos Group vydalo verzi 3.1 specifikace OpenCL (Open Computing Language). OpenCL je průmyslový standard pro paralelní programování heterogenních počítačových systémů.
Homebridge pro integraci chytrých domácích zařízení byl vydán ve verzi 2.0.0. Nově vedle protokolu HomeKit Accessory Protocol (HAP) podporuje standard chytré domácnosti Matter.
Omarchy je linuxová distribuce s dlaždicovým správcem oken Hyprland. Založena je na Arch Linuxu. Vydána byla v nové verzi 3.7.0 - The Gaming Edition. Z novinek lze vypíchnout příkaz omarchy a celou řadu herních možností.
CyberChef byl vydán v nové major verzi 11. Přehled novinek v Changelogu. CyberChef je webová aplikace pro analýzu dat a jejich kódování a dekódování, šifrování a dešifrování, kompresi a dekompresi, atd. Často je využívaná při kybernetických cvičeních a CTF (Capture the Flag).
Byla vydána nová verze 2.4.67 svobodného multiplatformního webového serveru Apache (httpd). Řešeno je mimo jiné 11 zranitelností.
Brush (Bo(u)rn(e) RUsty SHell) je v Rustu napsaný shell kompatibilní s Bash (Bourne Again SHell). Vydána byla verze 0.4.0.
Google zveřejnil seznam 1 141 projektů (vývojářů) od 184 organizací přijatých do letošního, již dvaadvacátého, Google Summer of Code. Přihlášeno bylo celkově 23 371 projektů od 15 245 vývojářů ze 131 zemí.
Na čem pracovali vývojáři GNOME a KDE Plasma minulý týden? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE Plasma.
Open source počítačová hra na hrdiny NetHack (Wikipedie, GitHub) byla vydána v nové verzi 5.0.0. První verze této hry byla vydána v roce 1987.
Access not within mapped region at address 0x0 ==26680== at 0x3BD606CD90: fwrite (in /usr/lib64/libc-2.17.so)Je mozne, ze se nekdy nejak nekorektne otevre soubor pro psani? Premyslim, v cem to muze byt. Lze kod nejak osetrit tak, aby to bylo vzdy korektni?
void send_file(char *source, char *destination) {
FILE * filer, * filew;
int numr, numw;
char buffer[1024];
if ((filer = fopen(source, "rb")) == NULL) {
perror("open read file error.\n");
//exit(1);
}
if ((filew = fopen(destination, "wb")) == NULL) {
perror("open write file error.\n");
//exit(1);
}
while (feof(filer) == 0) {
if ((numr = fread(buffer, 1, 100, filer)) != 100) {
if (ferror(filer) != 0) {
perror("read file error.\n");
//exit(1);
} else if (feof(filer) != 0);
}
if ((numw = fwrite(buffer, 1, numr, filew)) != numr) {
perror("write file error.\n");
//exit(1);
}
}
fclose(filer);
fclose(filew);
}
Řešení dotazu:
A nejsou právě problémem ty zakomentované exit-y?, tedy dle hlášky zrovna ten ve fopen pro filew.
U zapisovaného souboru je dobré kontroloval návratový kód fclose, moc se to sice nedělá, ale…
#include <stdlib.h>
#include <unistd.h>
#include <stdio.h>
void send_file(const char *source, const char *destination) {
FILE * filer, * filew;
int numr;
const int SIZE_OF_BUFFER=1024;
char buffer[SIZE_OF_BUFFER];
if ((filer = fopen(source, "rb")) == NULL) {
perror("open read file error.\n");
exit(1);
}
if ((filew = fopen(destination, "wb")) == NULL) {
perror("open write file error.\n");
fclose(filer);
exit(1);
}
while (feof(filer) == 0) {
if ((numr = fread(buffer, 1, SIZE_OF_BUFFER, filer)) != SIZE_OF_BUFFER) {
if (ferror(filer) != 0) {
perror("read file error.\n");
fclose(filer);
fclose(filew);
exit(1);
}
}
if (fwrite(buffer, 1, numr, filew) != numr) {
perror("write file error.\n");
fclose(filer);
fclose(filew);
exit(1);
}
}
if(fclose(filer) != 0)
printf("read file - close error.\n");//has read-file been deleted ... ???
if(fclose(filew) != 0)
printf("write file - close error.\n");//flush C buffer fails
//fsync ????
}
int main( int argc, const char* argv[] ){
if (argc == 3 ) {
send_file(argv[1], argv[2]);
} else {
printf("Main error, two params needed (from, to).\n");
return 1;
}
return 0;
}
Tiskni
Sdílej: