Byla vydána (𝕏) nová major verze 17 softwarového nástroje s webovým rozhraním umožňujícího spolupráci na zdrojových kódech GitLab (Wikipedie). Představení nových vlastností i s náhledy a videi v oficiálním oznámení.
Sovereign Tech Fund, tj. program financování otevřeného softwaru německým ministerstvem hospodářství a ochrany klimatu, podpoří vývoj FFmpeg částkou 157 580 eur. V listopadu loňského roku podpořil GNOME částkou 1 milion eur.
24. září 2024 budou zveřejněny zdrojové kódy přehrávače Winamp.
Google Chrome 125 byl prohlášen za stabilní. Nejnovější stabilní verze 125.0.6422.60 přináší řadu oprav a vylepšení (YouTube). Podrobný přehled v poznámkách k vydání. Opraveno bylo 9 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.
Textový editor Neovim byl vydán ve verzi 0.10 (𝕏). Přehled novinek v příspěvku na blogu a v poznámkách k vydání.
Byla vydána nová verze 6.3 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Přehled změn v příslušném seznamu. Tor Browser byl povýšen na verzi 13.0.15.
Dnes ve 12:00 byla spuštěna první aukce domén .CZ. Zatím největší zájem je o dro.cz, kachnicka.cz, octavie.cz, uvycepu.cz a vnady.cz [𝕏].
JackTrip byl vydán ve verzi 2.3.0. Jedná se o multiplatformní open source software umožňující hudebníkům z různých částí světa společné hraní. JackTrip lze instalovat také z Flathubu.
Patnáctý ročník ne-konference jOpenSpace se koná 4. – 6. října 2024 v Hotelu Antoň v Telči. Pro účast je potřeba vyplnit registrační formulář. Ne-konference neznamená, že se organizátorům nechce připravovat program, ale naopak dává prostor všem pozvaným, aby si program sami složili z toho nejzajímavějšího, čím se v poslední době zabývají nebo co je oslovilo. Obsah, který vytváří všichni účastníci, se skládá z desetiminutových
… více »Program pro generování 3D lidských postav MakeHuman (Wikipedie, GitHub) byl vydán ve verzi 1.3.0. Hlavní novinkou je výběr tvaru těla (body shapes).
Dobry den, mam nasledujici kod v C, prvni cast naalokuje pole retezcu s "boxes" radky a pro delku kazdeho retezce "BOXLEN+1" znaku. V tomto pripade je boxes rovno peti, kod tedy naalokuje misto pro pet retezcu.
V druhe casti kodu do kazdeho z peti retezcu nakopiruji nejaky text ("123"). Problem je vsak s poslednim retezcem (parts[4]), kdy mi program pri pokusu o jeho inicializaci pres strncpy hodi segmentation fault.
char **parts = (char **) malloc(boxes); for (int i = 0; i < boxes; i++) parts[i] = (char *) malloc(BOXLEN + 1); strncpy(parts[0], "123", BOXLEN); strncpy(parts[1], "123", BOXLEN); strncpy(parts[2], "123", BOXLEN); strncpy(parts[3], "123", BOXLEN); strncpy(parts[4], "123", BOXLEN);
Nevite prosim, cim by to mohlo byt?
parts = (char **) malloc(boxes * sizeof(char *));Pokud je velikost ukazatele jiná než 1, což je prakticky všude, je přepisována nepřidělená paměť. Moje další připomínky jsou více méně formální. Pokud je
boxes < 4
, pak je parts[3]
poslední zapisovatelný prvek. Pokud je boxes
makro nebo konstanta rovná nejméně pěti, o nic nejde.
Dalším problém může nastat, pokud BOXLEN < 4
, protože se řetězce "123"
s koncovým nulovým
znakem nevejdou do alokovaných prostorů.
Pokud jePokud jeboxes < 4
, pak jeparts[3]
poslední zapisovatelný prvek.
boxes < 5
, pak do parts[4]
nepůjde zapisovat, tedy přidělit adresu pro alokovaný řetězec.
char **parts = (char **) malloc(boxes * sizeof(char *));
A na to pozor.
Dalsi mene napadna chyba je v
strncpy(parts[4], "123", BOXLEN); kde by melo byt BOXLEN + 1, pokud tedy BOXLEN ma byt max. delka retezce (coz vyvozuju z alokace BOXLEN + 1 vyse). Jinak neni zajisten ukoncovaci null znak, protoze strncpy ho neresi.
Tiskni Sdílej: