abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 21:00 | Nová verze

    Po 9 týdnech vývoje od vydání Linuxu 7.0 oznámil Linus Torvalds vydání Linuxu 7.1. Přehled novinek a vylepšení na LWN.net: první a druhá polovina začleňovacího okna a časem také na Linux Kernel Newbies.

    Ladislav Hagara | Komentářů: 0
    včera 13:33 | Zajímavý software

    Cheat Engine (Wikipedie) je s verzí 7.7 k dispozici už také pro Linux. Jedná se o proprietární skener/debugger paměti používaný především k cheatování v počítačových hrách.

    Ladislav Hagara | Komentářů: 0
    13.6. 15:22 | IT novinky

    Vláda USA nařídila společnosti Anthropic pozastavit přístup k modelům Fable 5 a Mythos 5 pro všechny cizince, včetně zaměstnanců Anthropicu.

    Ladislav Hagara | Komentářů: 6
    13.6. 02:22 | Nová verze

    Společnost Murena představila (YouTube) novou verzi 4.0 mobilního operačního systému /e/OS (Wikipedie) založeného na Androidu a LineageOS bez aplikací a služeb od Googlu.

    Ladislav Hagara | Komentářů: 0
    12.6. 16:33 | Bezpečnostní upozornění

    V Arch User Repository (AUR) bylo kompromitováno přes 400 opomíjených balíčků (jejich seznam). Útočník do nich začlenil škodlivý npm balíček atomic-lockfile, který krade citlivá data uživatelů. Publikována byla předběžná analýza spouštěného malwaru deps.

    Ladislav Hagara | Komentářů: 11
    12.6. 11:33 | Nová verze

    Homebrew, správce balíčků nejen pro macOS, byl vydán ve verzi 6.0.0 (seznam změn). Hlavními novinkami jsou bezpečnostní mechanismus tap trust kvůli důvěryhodnosti závislostí, vylepšení sandboxingu na Linuxu, interní JSON API nebo zlepšení výkonu.

    |🇵🇸 | Komentářů: 0
    12.6. 03:33 | Bezpečnostní upozornění

    Byla nalezena a 9. června opravena kritická zranitelnost ve FreeBSD v Kernel TLS (KTLS). Pojmenována byla Bumsrakete (FreeBSD-SA-26:26.ktls, CVE-2026-45257). Lokální neprivilegovaný uživatel může přepisovat soubory, ke kterým má právo pouze pro čtení. Přepsáním setuid binárky a jejím spuštěním může získat roota. Na všech verzích od verze 13.0 vydané v dubnu 2021.

    Ladislav Hagara | Komentářů: 2
    11.6. 14:11 | Komunita

    Vývojáři open source operačního systému ReactOS (Wikipedie), jehož cílem je kompletní binární kompatibilita s aplikacemi a ovladači pro Windows, se na síti 𝕏 pochlubili, že ReactOS zvládne počítačovou hru Half-Life.

    Ladislav Hagara | Komentářů: 5
    11.6. 10:44 | Nová verze

    Byla vydána nová verze 4.8 multiplatformního integrovaného vývojového prostředí (IDE) pro rychlý vývoj aplikaci (RAD) ve Free Pascalu Lazarus (Wikipedie). Využíván je Free Pascal Compiler (FPC) 3.2.2.

    Ladislav Hagara | Komentářů: 0
    11.6. 04:44 | Nová verze

    Apple container dospěl do verze 1.0.0. Jedná se o open source nástroj pro spouštění linuxových kontejnerů na macOS postavený nad containerization. Napsaný je v programovacím jazyce Swift a optimalizovaný pro Apple silicon.

    Ladislav Hagara | Komentářů: 5
    Které desktopové prostředí na Linuxu používáte?
     (11%)
     (8%)
     (2%)
     (16%)
     (31%)
     (3%)
     (6%)
     (3%)
     (15%)
     (26%)
    Celkem 1906 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník


    Dotaz: C a nftw() pro rekurzivni prochazeni adresaru

    18.7.2010 15:27 ext3fs
    C a nftw() pro rekurzivni prochazeni adresaru
    Přečteno: 270×
    Ahoj, resim nasledujici problem:
    static int file_info(const char *fpath, const struct stat *sb,
                        int tflag, struct FTW *ftwbuf)
    {   	
    
            if (tflag == FTW_D)
            {
                    //tady bych chtel volat dalsi funkci
                    //fce((struct tree *)first);
    		printf("%s, D(%d), %d\n", fpath, ftwbuf->level, (long long)sb->st_size);
             }
    	else if (tflag == FTW_F)
    		printf("%s, F(%d), %d\n", fpath,ftwbuf->level, (long long)sb->st_size);
    
    	return(0);
    }
    
    int main(int argc, char *argv[])
    {
        int flags = 0;
    
       //flags |= FTW_DEPTH;
       //flags |= FTW_PHYS;
    
        nftw(argv[1], file_info, 20, 0);
        exit(EXIT_SUCCESS);
    }
    
    Potrebuji volat z funkce file_info() dalsi funkci, ktere bych predal ukazatel na strukturu (kde budou ulozeny informace o souborech).

    Jedno reseni je pouzit dlobalni promenne a nebo promene ve funkci kterou chci volat pouzit jako staticke. A nebo posledni reseni nepouzit ftw()/nftw() a napsat si to cele sam.

    Poradi nekdo?

    Odpovědi

    18.7.2010 16:13 R
    Rozbalit Rozbalit vše Re: C a nftw() pro rekurzivni prochazeni adresaru
    Zalezi od toho, co to ma robit. Ak chces vytvarat v pamati celu stromovu strukturu, tak mam lepsiu radu: nerob to, je to pravdepodobne nespravny postup.
    18.7.2010 16:25 ext3fs
    Rozbalit Rozbalit vše Re: C a nftw() pro rekurzivni prochazeni adresaru
    Potrebuji spocitat pocty souboru v dilcich slozkach a obsazenou velikost jak jednotlivych podslozek + celkovou velikost a pocet souboru. Nevim jak jinak to spocitat nez si drzet ve strukture info o celem strome.
    18.7.2010 18:39 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: C a nftw() pro rekurzivni prochazeni adresaru
    Zajímavé, nftw vidím poprvé. Asi to ale nedělá nic víc, než bych sám svedl s opendir/stat...

    V mé manuálové stránce je napsáno These functions are provided for compatibility with legacy code. New code should use the fts(3) functions.. Co ty na to?

    Funkce, kterým se předává nějaký callback, který pak ony volají, obvykle umožňují použít jeden pointer právě na nějaká vlastní data, které tomu callbacku chceme propašovat. Viz např. pthread_create. U nftw ale nic takového nevidím, přístup fts je v tomhle tedy lepší.

    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.