Konference Prague PostgreSQL Developer Day 2026 (P2D2) se koná 27. a 28. ledna 2026. Konference je zaměřena na témata zajímavá pro uživatele a vývojáře. Příjem přednášek a workshopů je otevřen do 14. listopadu. Vítáme témata související s PostgreSQL či s databázemi obecně, a mohou být v češtině či angličtině.
Byl vydán Devuan 6 Excalibur. Přehled novinek v poznámkách k vydání. Kódové jméno Excalibur bylo vybráno podle planetky 9499 Excalibur. Devuan (Wikipedie) je fork Debianu bez systemd. Devuan 6 Excalibur vychází z Debianu 13 Trixie. Devuan 7 ponese kódové jméno Freia.
Společnost Valve aktualizovala přehled o hardwarovém a softwarovém vybavení uživatelů služby Steam. Podíl uživatelů Linuxu poprvé překročil 3 %, aktuálně 3,05 %. Nejčastěji používané linuxové distribuce jsou Arch Linux, Linux Mint a Ubuntu. Při výběru jenom Linuxu vede SteamOS Holo s 27,18 %. Procesor AMD používá 67,10 % hráčů na Linuxu.
Joel Severin v diskusním listu LKML představil svůj projekt linuxového jádra ve WebAssembly (Wasm). Linux tak "nativně" běží ve webovém prohlížeči. Potřebné skripty pro převod jsou k dispozici na GitHubu.
Byla vydána nová verze 25.10.31 svobodného multiplatformního video editoru Shotcut (Wikipedie) postaveného nad multimediálním frameworkem MLT. Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.
O víkendu probíhá konference OpenAlt 2025 (Stream). Na programu je spousta zajímavých přednášek. Pokud jste v Brně, stavte se. Vstup zdarma.
Josef Průša představil novou velkoformátovou uzavřenou CoreXY 3D tiskárnu Prusa CORE One L a nový open source standard chytrých cívek OpenPrintTag i s novou přepracovanou špulkou.
Na GOG.com běží Autumn Sale. Při té příležitosti je zdarma hororová počítačová hra STASIS (ProtonDB: Platinum).
Ubuntu 25.10 má nově balíčky sestavené také pro úroveň mikroarchitektury x86-64-v3 (amd64v3).
Byla vydána verze 1.91.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
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: