Webový prohlížeč Dillo (Wikipedie) byl vydán ve verzi 3.1.0. Po devíti letech od vydání předchozí verze 3.0.5. Doména dillo.org již nepatří vývojářům Dilla.
O víkendu probíhá v Bostonu, a také virtuálně, konference LibrePlanet 2024 organizovaná nadací Free Software Foundation (FSF).
Nová vývojová verze Wine 9.8 řeší mimo jiné chybu #3689 při instalaci Microsoft Office 97 nahlášenou v roce 2005.
Coppwr, tj. GUI nástroj pro nízkoúrovňové ovládání PipeWire, byl vydán v nové verzi 1.6.0. Zdrojové kódy jsou k dispozici na GitHubu. Instalovat lze také z Flathubu.
Byla vydána dubnová aktualizace aneb nová verze 1.89 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a animovanými gify v poznámkách k vydání. Vypíchnout lze, že v terminálu lze nově povolit vkládání kopírovaného textu stisknutím středního tlačítka myši. Ve verzi 1.89 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Proton, tj. fork Wine integrovaný v Steam Play a umožňující v Linuxu přímo ze Steamu hrát hry určené pouze pro Windows, byl vydán ve verzi 9.0-1 (𝕏). Přehled novinek se seznamem nově podporovaných her na GitHubu. Aktuální přehled her pro Windows běžících díky Protonu také na Linuxu na stránkách ProtonDB.
Byla vydána verze 1.78.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání na GitHubu. Vyzkoušet Rust lze například na stránce Rust by Example.
Služba Dropbox Sign (původně HelloSign) pro elektronické podepisování smluv byla hacknuta.
Byla vydána nová major verze 8.0 textového editoru GNU nano (Wikipedie). Podrobný přehled novinek a oprav v oznámení v diskusním listu info-nano nebo v souboru ChangeLog na Savannah. Volbou --modernbindings (-/) lze povolit "moderní" klávesové zkratky: ^C kopírování, ^V vložení, ^Z vrácení zpět, … Tato volba je aktivována také pokud binárka s nano nebo link na ni začíná písmenem "e".
Před 60 lety, 1. května 1964, byl představen programovací jazyk BASIC (Beginners' All-purpose Symbolic Instruction Code).
==7096== Invalid write of size 8
==7096== at 0x5CA1AA3: Trida::Trida(char const*) (Trida.cpp:17)
==7096== by 0x47D284: JinaTrida::JinaTrida(QString, QString, QWidget*) (in /cesta/program)
==7096== by 0x45AFC5: EsteJinaTrida::mujQtSLOT(trida)(QString, QString) (in /cesta/program)
==7096== by 0x45CE9E: EsteJinaTrida::EsteJinaTrida(QWidget*) (in /cesta/program)
==7096== by 0x413733: main (in /cesta/program)
==7096== Address 0x13c4c2b0 is 8 bytes after a block of size 8 alloc'd
==7096== at 0x4C2BA77: operator new(unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==7096== by 0x47D276: JinaTrida::JinaTrida(QString, QString, QWidget*) (in /cesta/program)
==7096== by 0x45AFC5: EsteJinaTrida::mujQtSLOT(trida)(QString, QString) (in /cesta/program)
==7096== by 0x45CE9E: EsteJinaTrida::EsteJinaTrida(QWidget*) (in /cesta/program)
==7096== by 0x413733: main (in /cesta/program)
==7096==
==7096== Invalid write of size 8
==7096== at 0x5CA1ABA: Trida::Trida(char const*) (Trida.cpp:18)
==7096== Address 0x13c4c2a8 is 0 bytes after a block of size 8 alloc'd
==7096== at 0x4C2BA77: operator new(unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==7096==
==7096== Invalid read of size 8
==7096== at 0x5CA1AC2: Trida::Trida(char const*) (Trida.cpp:19)
==7096== Address 0x13c4c2b0 is 8 bytes after a block of size 8 alloc'd
==7096== at 0x4C2BA77: operator new(unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==7096==
==7096== Invalid read of size 8
==7096== at 0x5CA1ACF: Trida::Trida(char const*) (Trida.cpp:19)
==7096== Address 0x13c4c2a8 is 0 bytes after a block of size 8 alloc'd
==7096== at 0x4C2BA77: operator new(unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==7096==
==7096== Invalid write of size 4
==7096== at 0x5CA1AED: Trida::Trida(char const*) (Trida.cpp:24)
==7096== Address 0x13c4c2bc is 20 bytes after a block of size 8 alloc'd
==7096== at 0x4C2BA77: operator new(unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
(U většiny jsem smazal "by", protože bylo stejné, jako u prvního)
Následující kód má způsobovat chyby - je v dynamické knihovně.
class Trida {
public:
Trida(const char *archive);
virtual ~Trida();
private:
char* archive;
char* tmpDir;
int curDev;
}
Trida::Trida(const char *archive) {
tmpDir = (char*) malloc(256); //radek 17
this->archive = strdup(archive); //radek 18
if(tmpDir == NULL || this->archive == NULL) //radek 19
{
printf("\n Allocating memory failed.");
}
curDev = 0; //radek 24
srand(time(NULL));
}
Trida::~Trida() {
free(archive);
free(tmpDir);
}
V když tohle dám do samostatného programu, Valgrind si nestěžuje.
Nechápu, kde vidí Valgrind problém a jestli to je opravdu problém nebo jen falešný poplach.
Řešení dotazu:
sizeof(Trida)
? Není možné, že to linkujete proti jiné verzi knihovny, než od které máte ten hlavičkový soubor?
Tiskni Sdílej: