abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 04:44 | Nová verze

    Po roce vývoje od vydání verze 1.24.0 byla vydána nová stabilní verze 1.26.0 webového serveru a reverzní proxy nginx (Wikipedie). Nová verze přináší řadu novinek. Podrobný přehled v souboru CHANGES-1.26.

    Ladislav Hagara | Komentářů: 0
    dnes 04:33 | Nová verze

    Byla vydána nová verze 6.2 ž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.14.

    Ladislav Hagara | Komentářů: 0
    dnes 04:22 | Nová verze

    Byla vydána nová verze 30.0.0 frameworku pro vývoj multiplatformních desktopových aplikací pomocí JavaScriptu, HTML a CSS Electron (Wikipedie, GitHub). Chromium bylo aktualizováno na verzi 124.0.6367.49, V8 na verzi 12.4 a Node.js na verzi 20.11.1. Electron byl původně vyvíjen pro editor Atom pod názvem Atom Shell. Dnes je na Electronu postavena celá řada dalších aplikací.

    Ladislav Hagara | Komentářů: 0
    dnes 04:11 | Nová verze

    Byla vydána nová verze 9.0.0 otevřeného emulátoru procesorů a virtualizačního nástroje QEMU (Wikipedie). Přispělo 220 vývojářů. Provedeno bylo více než 2 700 commitů. Přehled úprav a nových vlastností v seznamu změn.

    Ladislav Hagara | Komentářů: 0
    včera 23:22 | IT novinky

    Evropský parlament dnes přijal směrnici týkající se tzv. práva spotřebitele na opravu. Poslanci ji podpořili 584 hlasy (3 bylo proti a 14 se zdrželo hlasování). Směrnice ujasňuje povinnosti výrobců opravovat zboží a motivovat spotřebitele k tomu, aby si výrobky nechávali opravit a prodloužili tak jejich životnost.

    Ladislav Hagara | Komentářů: 2
    včera 16:11 | Nová verze

    Bylo oznámeno (cs) vydání Fedora Linuxu 40. Přehled novinek ve Fedora Workstation 40 a Fedora KDE 40 na stránkách Fedora Magazinu. Současně byl oznámen notebook Slimbook Fedora 2.

    Ladislav Hagara | Komentářů: 8
    včera 13:44 | Upozornění

    ČTK (Česká tisková kancelář) upozorňuje (X), že na jejím zpravodajském webu České noviny byly dnes dopoledne neznámým útočníkem umístěny dva smyšlené texty, které nepocházejí z její produkce. Jde o text s titulkem „BIS zabránila pokusu o atentát na nově zvoleného slovenského prezidenta Petra Pelligriniho“ a o údajné mimořádné prohlášení ministra Lipavského k témuž. Tyto dezinformace byly útočníky zveřejněny i s příslušnými notifikacemi v mobilní aplikaci Českých novin. ČTK ve svém zpravodajském servisu žádnou informaci v tomto znění nevydala.

    Ladislav Hagara | Komentářů: 18
    včera 13:33 | Komunita

    Byla založena nadace Open Home Foundation zastřešující více než 240 projektů, standardů, ovladačů a knihoven (Home Assistant, ESPHome, Zigpy, Piper, Improv Wi-Fi, Wyoming, …) pro otevřenou chytrou domácnost s důrazem na soukromí, možnost výběru a udržitelnost.

    Ladislav Hagara | Komentářů: 0
    včera 13:00 | Nová verze

    Společnost Meta otevírá svůj operační systém Meta Horizon OS pro headsety pro virtuální a rozšířenou realitu. Vedle Meta Quest se bude používat i v připravovaných headsetech od Asusu a Lenova.

    Ladislav Hagara | Komentářů: 0
    včera 04:33 | IT novinky

    Společnost Espressif (ESP8266, ESP32, …) získala většinový podíl ve společnosti M5Stack, čímž posiluje ekosystém AIoT.

    Ladislav Hagara | Komentářů: 0
    KDE Plasma 6
     (72%)
     (10%)
     (2%)
     (17%)
    Celkem 705 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník
    Štítky: není přiřazen žádný štítek


    Vložit další komentář
    Jardík avatar 9.3.2011 17:01 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    Navrhuji řešení použít environment proměnné XDG_DATA_HOME a XDG_DATA_DIRS (s příslušnými fallbacky dle freedesktop "standardu") a pokud nikde data nejsou, tak teprve poté přistoupit k použití hardkódované cesty nastavené configure skriptem. Takové řešení je (podle mě) nejlepší.
    Věřím v jednoho Boha.
    9.3.2011 17:54 Martin Doucha | skóre: 23 | blog: Yet another blog
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    Nikdo ti nebrání poslat patch. Jestli s tím budou lidé souhlasit a ten kód bude vypadat rozumně, tak nevidím důvod, proč to nezařadit.
    Jardík avatar 9.3.2011 20:01 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    Já ten program nepoužívám, ani nevím, k čemu to je. Já jen napsal, jak by to bylo podle mě nejlepší. Jestli to tak někdo chce/nechce, nebo jestli to tak někdo udělá/neudělá, mi je fakt jedno. Věta "Nikdo ti nebrání poslat patch" mi vyzní jako "trhni si nohou a nechtěj mi přidělávat starosti". Teď jsem kouknul do jednoho náhodného zdrojáku, spatřil myšlenku sizeof() vrací int a tak si o tomto projektu dále myslím své a mlčím :-)
    Věřím v jednoho Boha.
    9.3.2011 20:05 polymorf | skóre: 14 | blog: tar_zxpf
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    +1 tiež ma jeho odpoveď trochu šokovala, myslel som že sa pýta ako na to.
    vain avatar 9.3.2011 20:08 vain | skóre: 16
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    No evidentně ptal.
    rád si nechám v diskuzi poradit
    If the only choice you've got is to do the wrong thing, then it's not really the wrong thing, it's more like fate.
    10.3.2011 00:08 Martin Doucha | skóre: 23 | blog: Yet another blog
    Rozbalit Rozbalit vše Re: Skeldal a autoconf

    Co je šokujícího na tom, že na feature request, který nemá nijak zásadní vliv na funkčnost hry, odpovím "tak to napiš sám a pošli mi patch"? Ze 144 commitů v mojí větvi jsou jen tři patche od někoho jiného, z toho jeden jsou ikonky a další jsem musel sám z poloviny přepsat, protože autor se mi na žádost o vylepšení patche už neozval.

    BTW, měl bych Jardíkovi poděkovat. Při opravování typů proměnných a návratových hodnot, co přímo pracují se sizeof, se mi podařilo najít a opravit jeden bug v pointerové aritmetice.

    10.3.2011 08:39 polymorf | skóre: 14 | blog: tar_zxpf
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    Jak som pochopil tento blog:

    Ty: Program skeldal, nieco zmenili a neviem ako upravit konfigurak aby nacitaval data z ineho miesta. Neviete niekto ako na to?

    Jardik: Myslim ze by stacilo upravit premennu X a Y.

    Ty: Nikdo ti nebrání poslat patch.
    10.3.2011 09:36 Martin Doucha | skóre: 23 | blog: Yet another blog
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    Tak to jsi pochopil špatně. Tuhle změnu ve Skeldalu jsem spáchal já, a tohle je v podstatě changelog, aby se uživatelé nedivili, že jim Skeldal najednou odmítá načítat data. Dotaz byl na znalce Autoconfu co napsat do configure.ac, aby build systém defaultně hledal data na starém místě i bez zásahu uživatele.
    10.3.2011 09:57 polymorf | skóre: 14 | blog: tar_zxpf
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    Aj tak znies ako buran:

    Ty: Upravil som cestu dat v programe skeldal, neviem ako upravit configure.ac aby nacitaval data zo spravneho miesta. Neviete niekto ako na to?

    Jardik: Myslim ze by stacilo upravit premennu X a Y.

    Ty: Nikdo ti nebrání poslat patch.
    10.3.2011 10:19 Martin Doucha | skóre: 23 | blog: Yet another blog
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    V tom případě jsi nepochopil ani Jardíkův komentář. XDG_* tenhle problém nevyřeší, protože na různých strojích můžou mít různý obsah. Jardík jenom prudí s dalším Jediným® Správným© Řešením™, navíc na úplně jiný problém.
    Jardík avatar 10.3.2011 14:09 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    Tedy jsem ti opravil fci (idx by si zasloužilo být size_t, ale ...:
    // skeldal/branches/next_ghost/unix/init.cpp
    
    void Sys_SetPath(unsigned idx, const char *path) {
    	size_t len = strlen(path); // tady byl int
    	assert(idx < PATHTABLE_SIZE);
    
    	if (pathtable[idx]) {
    		free(pathtable[idx]);
    	}
    
    	// tady nebyl test *path == 0, což mohlo způsobit pád v kódu
    	// níže, protože len-1 by šlo na neplatný index SIZE_MAX
    	if (!*path || *path == 0) { 
    		pathtable[idx] = (char*)malloc(1);
    		pathtable[idx][0] = '\0';
    		return;
    	}
    
    	if (path[len - 1] != '/') {
    		len++;
    	}
    
    	pathtable[idx] = (char*)malloc(len + 1);
    	strcpy(pathtable[idx], path);
    	pathtable[idx][len-1] = '/';
    	pathtable[idx][len] = '\0';
    }
    
    Ještě tam teda chybí kontrola návratových hodnot z malloc(), to už se mi nechce dělat.

    Další chyby:
    // není reentrant
    char *Sys_FullPath(unsigned idx, const char *file) {
    	static char ret[PATH_MAX];
    	assert(idx < PATHTABLE_SIZE);
    	// tady může dojít k přetečení fixně velikého bufferu
    	strcpy(ret, pathtable[idx]);
    	strncat(ret, file, PATH_MAX - strlen(ret) - 1);
    	return ret;
    }
    
    // není reentrant
    char *Sys_DOSPath(unsigned defdir, const char *path) {
    	static char ret[PATH_MAX];
    	int i, length;        // "má" být size_t
    	assert(defdir < PATHTABLE_SIZE);
    
    	// možnost přetečení bufferu
    	strcpy(ret, pathtable[defdir]);
    	length = strlen(ret);
    	strncat(ret + length, path, PATH_MAX - length - 1);
    	strupr(ret + length);
    
    	for (i = length; ret[i]; i++) {
    		if (ret[i] == '\\') {
    			ret[i] = '/';
    		}
    	}
    
    	return ret;
    }
    
    void Sys_Init(void) {
    	char home[PATH_MAX]; // smyšlená hodnota maximální velikosti cesty
    	int len; // size_t
    	// možnost přetečení bufferu, getenv() může vrátit NULL
    	strcpy(home, getenv("HOME"));
    	len = strlen(home);
    	// neplatný index při len == 0
    	if (home[len-1] != '/') {
    		home[len++] = '/';
    	}
    	// další možnost přetečení bufferu
    	strcpy(home + len, ".skeldal/");
    
    Nakonec dotaz: znáš třeba std::map a std::string? Když je to C++ kód, proč to nepoužít? Ušetřil bys si spoustu starostí, např. Sys_SetPath by mohl vypadat nějak takto:
    typedef std::map<unsigned, std::string> Mapa;
    Mapa mapa;
    
    void Sys_SetPath(unsigned id, const std::string& path)
    {
      std::string& oldVal = mapa[id];
      std::string::size_type len;
      oldVal = path;
      len = oldVal.size();
      if (len > 0 && oldVal[len-1] != '/') oldVal += '/';
    }
    
    A při chybné alokaci ti to prostě vyprskne std::bad_alloc
    Věřím v jednoho Boha.
    Jardík avatar 10.3.2011 14:17 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    Příloha:
    BTW máš co dělat, tady je log z kompilace (prsknul jsem tam -Wall -pedantic):
    Věřím v jednoho Boha.
    10.3.2011 16:47 Martin Doucha | skóre: 23 | blog: Yet another blog
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    Hezké. Jenže většina těch problémů je v původním kódu z roku 1997. Opravovat to budu průběžně až na daný kus kódu přijde řada.
    10.3.2011 16:43 Martin Doucha | skóre: 23 | blog: Yet another blog
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    Zformátuj to a pošli to jako patch, ať jsou vidět změny. STL znám a odmítám to použít, protože bych tím akorát zablokoval možnost portovat Skeldal na mobilní platformy s omezenou pamětí.
    Jardík avatar 10.3.2011 21:24 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    STL znám a odmítám to použít, protože bych tím akorát zablokoval možnost portovat Skeldal na mobilní platformy s omezenou pamětí.
    To je škoda. Já si trochu procházel ten kód a místama jsou tam takové čuňárny a je to tak nepřehledné, všude možně chybí kontrola chyb, některé funkce vůbec neupozorní na chyby (ani nějakým kódem, ani výjimkou, ani vypsáním) a vypadá to fakt neudržitelně. Ale snaha se cení.
    Věřím v jednoho Boha.
    12.3.2011 09:02 Vin
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    A STL by těm čuňárnám nějak zamezilo?

    Jinak sám autor napsal, že by to dnes řešil jinak - http://www.root.cz/clanky/rozhovor-s-ondrejem-novakem-vyvojarem-hry-brany-skeldalu/

    otázkou je, jestli by se tehdy stihnul deadline pro vydání hry, než by se to naučil (navíc, jak zmiňuje v rozhovoru, potřeboval řešit jiné problémy, které dnes už asi nejsou).

    Bedňa avatar 12.3.2011 15:52 Bedňa | skóre: 34 | blog: Žumpa | Horňany
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    Mirek Fidler o STL:
    Proč děláme takovou hloupost? Stručná, byť možná trochu nesrozumitelná, odpověď na tuto otázku by se dala shrnout do věty: "Protože STL vás nutí si přát, aby C++ mělo automatickou správu paměti (garbage collector - GC)".

    Problém je v tom, že do STL kontejneru můžete vkládat pouze objekty, které mají definovanou kopii. Navíc, pokud aspoň trochu dbáte na rychlost aplikace, musí tato kopie pokud možno být jednoduše proveditelná (rychlá).

    To v praxi znamená, že do STL kontejneru je možné efektivně ukládat fundamentální typy, možná ještě tak řetězce a pár dalších jednoduchých typů. Všechno ostatní lze uložit pouze nepřímo pomocí ukazatele. Tím se ztrácí jedna ze základních výhod, kterou používaní kontejnerových šablon přináší - automatická správa paměti.
    KERNEL ULTRAS video channel >>>
    Jardík avatar 13.3.2011 04:21 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    V C++0x to řeší move constructor.
    Věřím v jednoho Boha.
    Bedňa avatar 10.3.2011 18:30 Bedňa | skóre: 34 | blog: Žumpa | Horňany
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    Hackery sa takto bavia bežne, keď nevieš o čom je reč tak sa nezapájaj, sa čudujem že Martin na teba vôbec reagoval.
    KERNEL ULTRAS video channel >>>
    stativ avatar 9.3.2011 20:09 stativ | skóre: 54 | blog: SlaNé roury
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    Řekl bych, že vzhledem k tomu, z jakých zdrojáků to vzešlo je to detail a cením si práce, které na tom Martin udělal, aby to vůbec fungovalo s moderními systémy.
    Ať sežeru elfa i s chlupama!!! ljirkovsky.wordpress.com stativ.tk
    9.3.2011 23:05 Drew | skóre: 15 | blog: Supi_hnizdo | Praha
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    Hm, to by se ale týkalo ledatak uložených pozic a nastavení (je ve skeldalu vůbec nějaké?) - herní data by přece měla být nainstalována ne v domovském adresáři nějakého uživatele ale někde, kde jsou dostupná všem, ne?
    10.3.2011 00:13 Martin Doucha | skóre: 23 | blog: Yet another blog
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    XDG_DATA_DIRS má na mém stroji hodnotu /usr/share:/usr/local/share:/usr/share a XDG_DATA_HOME nemám nastavenou vůbec. Tyhle proměnné jsou dobré tak akorát pro proprietární soft, aby se dal instalovat na víc možných míst. Skeldal je open source a od začátku mám v plánu protlačit do repozitářů minimálně Gentoo a Debianu, takže takovou věc nepotřebuje.
    10.3.2011 10:55 Scarabeus IV | skóre: 20 | blog: blogisek_o_gentoo | Praha
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    A ty beres jaky drogy chlape, i kdyz se Jardik vetsinou chova jako idiot tak ma pravdu.

    XDG je freedesktop specifikace...

    A nyni par veci k autotools:
    1) v repozitari se ponechavaji pouze Makefile.am a configure.{ac,in} zbytek je generovan pouze pro release.
    2) proc nepouzivas pkgconfig kdyz hledas sdl a sdl-mixer: PKG_CHECK_MODULES(SDL, sdl sdl-mixer) a pak se pouzije v Makefile.am skeldal_LDADD = $(SDL_LIBS) skeldal_CXXFLAGS=$(SDL_CFLAGS) nebo tak nejak. 3) zadratovat cestu v prubehu configure je sakrapekna prasarna viz XDG specifikace vejs, ale pokud po tom touzis tak se vyplati tam dat neco jako --with-gamedata=/path do configure, a to predat do Makefile.am nez redefinovat datadir.
    4) CPPFLAGS jsou nastaveni pro C Pre Processor ne pro C++ to je CXXFLAGS.
    5) Chybi tam autogen.sh na generovani configure/Makefile, viz bod 1.

    ad 3)
    AC_ARG_WITH(gamedata-prefix,
    	[AS_HELP_STRING([--with-gamedata-prefix=PREFIX], [Prefix for game data.])],
    )
    ad 5)
    set -e
    : ${AUTORECONF:=autoreconf}
    if test "$*"; then
    	ARGS="$*"
    else
    	if test -f config.log ; then
    		ARGS=`grep '^  \$ \./configure ' config.log | sed 's/^  \$ \.\/configure //' 2> /dev/null`
    	fi
    fi
    
    echo "Running ${AUTORECONF}..."
    $AUTORECONF --install --verbose
    test x$NOCONFIGURE = x && echo "Running ./configure $ARGS" && ./configure $ARGS
    10.3.2011 11:57 Martin Doucha | skóre: 23 | blog: Yet another blog
    Rozbalit Rozbalit vše Re: Skeldal a autoconf

    ad 1) a 5) Neznám moc balíků, které by tohle dělaly, a UNIXový standard je ./configure; make; make install. Dokud se ze "svaté trojice" nestane čtveřice, která začíná ./autogen.sh nebo něčím podobným, budu mít configure skript přímo v repozitáři, stejně jako většina ostatních projektů. Navíc takový skript GNU Coding Standards nevyžaduje.

    ad 2) Díky za tip, tohle jsem neznal.

    ad 3) Podle GNU Coding Standard je to zcela v pořádku a já se s dovolením budu držet GNU Coding Standards. Freedesktop si může vymýšlet, co chce, ale to ještě neznamená, že to má smysl používat.

    ad 4) -Dcosi je flag preprocesoru, takže AM_CPPFLAGS je naprosto správné umístění. CPPFLAGS se používá při kompilaci C i C++, CXXFLAGS jen pro C++.

    10.3.2011 12:12 Scarabeus IV | skóre: 20 | blog: blogisek_o_gentoo | Praha
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    1 az 5) Podivej se na cgit.freedesktop.org nebo http://git.gnome.org/browse/.

    3) Prekvapive tahle prkotina kterou oznacujes za vymyslenost kterou nema smysl pouzivat je pouzivana vsemy DE aprotoze se dodrzuje na vsech platformach stejne. Zaroven uz to nastesti zacina podporovat spousta 3rd party aplikaci taky takze treba v home slozkach prestane bejt tak nechutnej bordel.

    4) no ja se ani nekoukal co v ni je, vetsinou je pouzita blbe, v tomhle pripade bych ovsem spis sel do skeldal_CPPFLAGS nez to nastavovat globalne :)
    10.3.2011 12:47 Martin Doucha | skóre: 23 | blog: Yet another blog
    Rozbalit Rozbalit vše Re: Skeldal a autoconf
    ad 3) DE to implementovat musí, jinak celá tahle ptákovina nebude fungovat. Já ale portuju hru, ne DE.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.