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í
×
    dnes 19:33 | Nová verze

    Byla vydána první verze 0.0.1 [Mastodon] multipatformního renderovacího jádra webového prohlížeče Servo (Wikipedie). Vývoj Serva započal v roce 2012 v Mozilla Corporation. V roce 2020 bylo Servo předáno nadaci Linux Foundation. Servo je napsané v programovacím jazyce Rust.

    Ladislav Hagara | Komentářů: 0
    dnes 15:11 | IT novinky

    Cloudovou službu Amazon Web Services (AWS) americké firmy Amazon dnes postihl globální výpadek. Omezil dostupnost řady aplikací a webů, například populární platformu Snapchat nebo aplikaci s prvky umělé inteligence (AI) Perplexity. Podle webu Downdetector hlásily problémy také uživatelé obchodu Amazon, streamovací platformy PrimeVideo nebo platební služby PayPal.

    Ladislav Hagara | Komentářů: 4
    dnes 13:33 | Zajímavý software Ladislav Hagara | Komentářů: 0
    dnes 12:44 | Pozvánky

    Od 3. do 16. listopadu proběhnou Dny AI 2025. V úterý 11. listopadu proběhne Open source AI day v Red Hatu v Brně.

    Ladislav Hagara | Komentářů: 0
    dnes 12:22 | Zajímavý článek

    Nová čísla časopisů od nakladatelství Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 158 (pdf) a Hello World 28 (pdf).

    Ladislav Hagara | Komentářů: 0
    dnes 01:44 | Komunita

    Vývojáři GIMPu nově vydávají oficiální snap balíčky GIMPu. Jsou sestavovány přímo v jejich CI (Continuous Integration) systému.

    Ladislav Hagara | Komentářů: 7
    včera 15:22 | Nová verze

    Správce sbírky fotografií digiKam byl vydán ve verzi 8.8.0. Jedná se o převážně opravné vydání provázené aktualizacemi knihoven. Novinky zahrnují implicitní použití systémového barevného profilu monitoru, import/export hierarchie štítků, editační nástroj rozostření aj.

    |🇵🇸 | Komentářů: 1
    17.10. 13:22 | IT novinky

    Steve Jobs a superpočítač Cray-1 budou vyobrazeny na pamětních jednodolarových mincích vyražených v příštím roce v rámci série Americká inovace. Série má 57 mincí, tj. 57 inovací. Poslední 4 mince budou vyraženy v roce 2032.

    Ladislav Hagara | Komentářů: 15
    17.10. 12:22 | Pozvánky

    Byl zveřejněn průběžně aktualizovaný program konference OpenAlt 2025 o otevřeném softwaru a datech, IT bezpečnosti, DIY a IoT. Konference proběhne o víkendu 1. a 2. listopadu v prostorách FIT VUT v Brně. Vstup je zdarma.

    Ladislav Hagara | Komentářů: 0
    17.10. 12:00 | IT novinky

    Senát včera opětovně nepřijal návrh ústavního zákona, který měl do Listiny základních práv a svobod zakotvit právo občanů platit v hotovosti nebo být off-line. Návrh předložila skupina senátorů již v roce 2023. Senát dnes návrh neschválil, ale ani nezamítl. Pokud by ho přijal, dostala by ho k projednání Sněmovna a vyjádřila by se k němu vláda.

    Ladislav Hagara | Komentářů: 65
    Jaké řešení používáte k vývoji / práci?
     (37%)
     (47%)
     (20%)
     (20%)
     (23%)
     (18%)
     (21%)
     (18%)
     (18%)
    Celkem 246 hlasů
     Komentářů: 14, poslední 14.10. 09:04
    Rozcestník

    Dotaz: fw=fopen(SETUP_FILE, "wb");

    5.8.2006 12:28 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
    fw=fopen(SETUP_FILE, "wb");
    Přečteno: 215×
    Mám takový menší problém:

    Potřebuji zapisovat do souboru takže mám:

    fw=fopen(SETUP_FILE, "wb");

    No a pokud jako soubor uvedu pouze soubor tak se mě tam zapíše do aktuálního adresáře,

    #define SETUP_FILE "setup.cfg"

    ale to nechci chci ho zapisovat do /home/petr/.turnusy/ což se mě nedaří.

    #define SETUP_FILE "/home/petr/.turnusy/setup.cfg"

    Přitom ten soubor je spuštěn pod tím uživatelem petr, potřebuji poradit jak se to správně zapisuje pod linuxem, naposledy jsem si něco psal pod dosem a tam prava nejsou takže mi to fungovalo.

    Odpovědi

    Luboš Doležel (Doli) avatar 5.8.2006 12:31 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Existuje adresář /home/petr/.turnusy/ ?
    5.8.2006 12:41 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    I když existuje tak to hodí chybu.

    Právě nevím jak se to vlastně dělá zda se pod linuxem musí vytvářet adresáře zvlášť a potom se do těch adresářů přepnout a pak zapisovat jenom ty soubory.

    Právě fopen pokud je jako parametr pouze soubor tak OK pokud i s cestou tak je chyba.
    5.8.2006 12:56 Semo | skóre: 45 | blog: Semo
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Aka chyba? kontrolovat navratovu hodnotu a errno.
    If you hold a Unix shell up to your ear, you can you hear the C.
    5.8.2006 13:05 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Jo už jsem přišel na chybičku měl jsem tam blbé písmenko v cestě, takže mě to do toho adresáře zapíše pokud existuje.

    Teď bych potřeboval poradit jak vlastně najít cestu do domovského adresáře abych nemusel mít v programu natvrdo /home/petr/ když to bude spouštět třeba franta aby tam bylo /home/franta/ ?
    5.8.2006 13:08 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Abych byl přesnější něco jako ~ v bashu ?
    5.8.2006 13:41 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    printf("$HOME = %s\n", getenv("HOME"));;-)
    Kdo si hraje nezlobí:-)
    5.8.2006 13:57 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Dík taková blbost a nenapadla mě :-(
    5.8.2006 14:23 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Neni zac, preju hodne zdaru.
    Kdo si hraje nezlobí:-)
    5.8.2006 16:13 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Záleží na tom, co přesně vás zajímá. Tohle nezjistí domácí adresář, ale obsah proměnné HOME. Skutečný domácí adresář by se zjistil zhruba takto:
      buf_length = sysconf(_SC_GETPW_R_SIZE_MAX);
      char buff[buf_length];
      struct passwd pwd;
      struct passwd* rptr;
      getpwuid_r(id, &pwd, buff, buf_length, &rptr);
      if (!rptr) ...
      /* máte to v pwd.pw_name */
    
    5.8.2006 16:25 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    ano souhlasim, jen tedy s tim ze getpwuid_r() je zamaskovano v hlavickovych souborech pomoci # if defined __USE_SVID || defined __USE_MISC narozdil od getenv(), ktere je volne... holt zalezi jestli se treba program nekompiloval s -ansi... pak by to byl problem... ale jinak je jasne ze getenv() vraci pouze prommenne prostredi...
    Kdo si hraje nezlobí:-)
    5.8.2006 16:30 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Mě getenv() stačí pokud si uživatel nastaví proměnnou HOME jinam bude mít samozřejmě konfigurační soubory jinde což mě netrápí.

    PS. Program je to pouze pro mě který mi bude z databáze vypisovat co mám mět za směnu u nepravidelného turnusu.
    5.8.2006 16:30 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Jste si tím jistý? V mém pwd.h je tato funkce deklarována vždy, blok, o kterém pravděpodobně mluvíte, obsahuje pouze getpwent_r(). Pokud by byly problémy, můžete samozřejmě použít getpwuid(), ale od té doby, co jsem si začal hrát s thready, používám raději reentrantní varianty všude.
    5.8.2006 16:47 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    to proc jste pouzil _r funkci je mi zrejme, taky by me nebavilo porad pouzivat pthread_mutex_lock() a pthread_mutex_unlock() pro zamykani sdilenych dat... ovsem u me je skutecne v souboru pwd.h funkce getpwent_r() zamaskovana... staci dat man getpwent_r a zobrazi se toto (cast):
    SYNOPSIS
           #define _GNU_SOURCE
           #include <pwd.h>
    
           int getpwent_r(struct passwd *pwbuf, char *buf,
                          size_t buflen, struct passwd **pwbufp);
    
           int fgetpwent_r(FILE *fp, struct passwd *pwbuf, char *buf,
                           size_t buflen, struct passwd **pwbufp);
    coz je snad vserikajici...
    Kdo si hraje nezlobí:-)
    5.8.2006 17:05 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Co máte za distribuci? Já tam žádné '#define _GNU_SOURCE' nemám. Dokonce mám dvě verze té stránky, ani jedna neobsahuje požadavek na žádná další makra a jedna z nich je navíc označena jako POSIX Programmer's Manual. Příslušná část pwd.h pak vypadá takto:
    # if defined __USE_SVID || defined __USE_MISC
    /* This function is not part of POSIX and therefore no official
       cancellation point.  But due to similarity with an POSIX interface
       or due to the implementation it is a cancellation point and
       therefore not marked with __THROW.  */
    extern int getpwent_r (struct passwd *__restrict __resultbuf,
                           char *__restrict __buffer, size_t __buflen,
                           struct passwd **__restrict __result);
    # endif
    
    extern int getpwuid_r (__uid_t __uid,
                           struct passwd *__restrict __resultbuf,
                           char *__restrict __buffer, size_t __buflen,
                           struct passwd **__restrict __result);
    
    extern int getpwnam_r (__const char *__restrict __name,
                           struct passwd *__restrict __resultbuf,
                           char *__restrict __buffer, size_t __buflen,
                           struct passwd **__restrict __result);
    
    5.8.2006 17:18 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Distribuce gentoo... navic mam v te manualove strance vyslovne napsano ze je to GNU rozsireni posixovych funkci... V tom vasem vypisu je ale ta cast okolo te funkce taktez zamaskovana viz komentar
    This function is not part of POSIX and therefore no official
    cancellation point.  But due to similarity with an POSIX interface
    or due to the implementation it is a cancellation point and
    therefore not marked with __THROW.
    jinak jeste z manualove stranky:
    CONFORMING TO
           These  functions  are  GNU  extensions,  done in a style resembling the
           POSIX version of functions like getpwnam_r(3).
    Kdo si hraje nezlobí:-)
    5.8.2006 17:27 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");

    Kdyby to bylo rozšíření, neměla by ta funkce manuálovou stránku označenou POSIX Programmer's Manual, ty jsou jen u skutečně posixových funkcí.

    V tom vasem vypisu je ale ta cast okolo te funkce taktez zamaskovana viz komentar…

    Není. Ten komentář a podmíněný překlad se týkají jen funkce getpwent_r(), ale hned za ní je #endif, takže na getpwuid_r() a getpwnam_r() se to už nevztahuje, ty jsou deklarovány vždy.

    5.8.2006 18:30 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    sorry, trochu jsem se prekoukl co potom vlastne hledam za funkci...:-) my fault... Jo jenom tak naokraj ohledne hlavickovyho souboru pwd.h respektive aji grp.h nestalo se ti, ze kdyz jsi projizdel alokovanou pamet valgrindem pri pouziti funkci getpwnam(user); a getgrnam(group);, tak zustala alokovana pamet, ktera nesla zrusit... lamal jsem si s tim hlavu celej den a nic... free hazelo errory a jeste napsal ze tu pamet nejde zrusit ale zustalo ji tam pak min, ale porad nejaka zustala... pouzivam to na zmenu opravneni na takovym programku, nevim jak to nazvat, asi jednosmerna proxy... je to primo z nejakejch doporucenejch zdroju, jak na to... koukal jsem se trebas do zdrojaku apache a tam na nejaky uvolnovani uplne pecou, presne tak jak to bylo v tom prikladu... stejne tak v jakymkoli serveru co jsem se dival na zdrojaky... jen me stve ze tam nekde neco zustane, tak nevim...
    Kdo si hraje nezlobí:-)
    5.8.2006 19:18 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Tohle jsem nezkoumal, ale moc by mne to nepřekvapilo. Někde se paměť pro strukturu, kterou ty funkce vracejí, vzít musí a dealokovat ji knihovna dost dobře nemůže, protože neví, jak dlouho ji program bude potřebovat. Naštěstí aspoň může použít při opakovaném volání funkce stejný buffer. Tenhle přístup, kdy za uvolnění paměti není zodpovědná ani knihovna ani aplikace, považuji právě za jeden z důvodů, proč dávat přednost reentrantním verzím i v single-thread programech.
    5.8.2006 13:52 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    printf("$HOME = %s\n", getenv("HOME"));;-)
    Kdo si hraje nezlobí:-)
    5.8.2006 14:55 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Takže jsem to vyřešil tak že program nastaví svůj pracovní adresář na HOME uživatele.

    chdir( getenv("HOME") );

    No a potom otevření pro zápis do souboru:
    
    #define SETUP_FILE ".turnusy/setup.cfg"
    
    FILE *fw;
    
    fw=fopen(SETUP_FILE, "wb");
    
    if(fw==NULL)
    {
      mkdir(".turnusy", 0770);
      fw=fopen(SETUP_FILE, "wb");
      if(fw==NULL)
       {
         perror("Chyba");
         return -1;
       }
    }
    
    
    Jinak díky za pomoc.
    Luboš Doležel (Doli) avatar 5.8.2006 14:57 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Není lepší dát natvrdo ten mkdir() před první fopen()?
    5.8.2006 15:06 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Není protože ten adresář už může existovat se starými soubory.

    A snažit se vytvořit adresář který už existuje se mi nezdá správné, prostě vytvářím ho až když zjistím že tam není.
    Luboš Doležel (Doli) avatar 5.8.2006 15:17 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    No jak myslíte. Takhle máte akorát mnohem nepřehlednější kód, který se dá zkrátit. mkdir() navíc vám nic nezkazí.
    5.8.2006 15:38 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    No jo ale zase se zbytečně používá když už je adresář vytvořen, chtělo by to vyjádření nějakého odborníka na C aby rozhodl co je lepší.
    Luboš Doležel (Doli) avatar 5.8.2006 15:41 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    V každém programu se najde mnoho zbytečných věcí navíc. Jeden syscall na začátku programu navíc, tomu tedy říkám opravdu "hrůza".
    5.8.2006 16:02 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    No tak jsem dal na vás a předělal to :-)
    5.8.2006 16:02 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    No ale zase proc ho tam zbytecne vnaset, ze... no myslim ze na takoveto urvni to nema cenu ani moc resit, takoveto mini programky a jejich mini casti ktere se volaji jednou za zivot programu, stejnak mnoho zla neudelaji... mnohem dulezitejsi si myslim je otazka, zda se testuje existence $HOME a nasledne jeho adresare, s tim jestli se do nej povedlo prejit... toto je opravdu jedno, hlavne ze se to testuje a pobezi to...
    Kdo si hraje nezlobí:-)
    5.8.2006 16:07 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Osobně bych dal přednost kontrole existence a případně i access(..., W_OK). Ale asi je to věc vkusu.
    5.8.2006 16:11 horimir | skóre: 6
    Rozbalit Rozbalit vše Re: fw=fopen(SETUP_FILE, "wb");
    Plne souhlasim;-) ale v zrovna v tomto pripade je to i takle snad dostacujici... cili toto je na konkretnim autorovi...
    Kdo si hraje nezlobí:-)

    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.