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:11 | IT novinky

    Google, potažmo YouTube umožní návrat tvůrcům, kteří byli zablokováni kvůli údajnému šíření dezinformací souvisejících s COVID-19 a volbami. Tvůrci teď mohou požádat o navrácení přístupu. Společnost Alphabet v této souvislosti uvedla, že zákazy byly uděleny kvůli tlaku tehdejší Bidenovy administrativy.

    karkar | Komentářů: 14
    včera 18:33 | Zajímavý článek

    Vývojári z distribúcie Artix, ktorá je postavená na Arch Linuxe, alebo skôr jeho forkom, už skôr prešli na Open-RC init systém, stále však niektoré projekty ako GNOME boli závislé na systemd. Teraz pretiekol pohár trpezlivosti a počnúc GNOME 49, kvôli ktorému komponenta gnome-session je úplne závislá na systemd-init, padlo rozhodnutie na odstránenie GNOME z repozitárov Artixu. Táto zmena sa podľa všetkého týka viac než 90 distribúcií, ktoré tiež nepoužívajú systemd. Viac v príspevku na DistroWatch.

    lukve | Komentářů: 7
    včera 17:33 | IT novinky

    Magazín IEEE Spectrum opět po roce publikoval svůj žebříček programovacích jazyků. Vedou Python, Java, C++, SQL a C#.

    Ladislav Hagara | Komentářů: 2
    včera 15:11 | Komunita

    Repozitáře pro spolupráci v rámci projektu Fedora se přesunou z Pagure na nově vzniklý Fedora Forge. Ten stejně jako třeba Codeberg běží na softwaru Forgejo, které bylo už před časem vybráno jako náhrada za Pagure. Pagure pochází z dílny Fedory, ale mimo ni se příliš neuchytil. Jeho vývoj a údržba byly náročné a Fedora se rozhodla jít cestou úspěšnějšího projektu, který má větší základnu přispěvatelů.

    Ladislav Hagara | Komentářů: 0
    včera 12:22 | Nová verze

    Byla vydána (𝕏) nová verze 2025.3 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek se seznamem nových nástrojů v oficiálním oznámení na blogu.

    Ladislav Hagara | Komentářů: 0
    23.9. 12:33 | IT novinky

    V IT4Innovations národním superpočítačovém centru byl dnes slavnostně spuštěn první český kvantový počítač VLQ disponující 24 fyzickými qubity s unikátní hvězdicovou topologií. Systém dodala společnost IQM Quantum Computers a jeho celková pořizovací cena činila přibližně 125 milionů korun.

    Ladislav Hagara | Komentářů: 31
    23.9. 12:22 | IT novinky

    Výrobce čipů Nvidia chce investovat až 100 miliard dolarů (přes dva biliony Kč) do společnosti zaměřené na umělou inteligenci OpenAI. Firmy o tom informují v tiskové zprávě. Oznámené partnerství přichází v době, kdy se mezi technologickými giganty a start-upy zostřuje konkurence o zajištění přístupu k energii a čipům potřebným pro rozvoj umělé inteligence (AI).

    Ladislav Hagara | Komentářů: 0
    23.9. 05:22 | Zajímavý článek

    Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 157 (pdf).

    Ladislav Hagara | Komentářů: 0
    23.9. 00:11 | Komunita

    Společnost Cloudflare oznámila, že sponzoruje nezávislý webový prohlížeč Ladybird a linuxovou distribuci pro vývojáře Omarchy (Arch Linux s dlaždicovým správcem oken Hyprland).

    Ladislav Hagara | Komentářů: 0
    22.9. 17:11 | Zajímavý software

    Společnost XTX Markets zabývající se algoritmickým obchodováním pro své potřeby vyvinula a dnes představila a otevřela souborový systém TernFS. Zdrojové kódy jsou k dispozici na GitHubu. Vývoj TernFS začal počátkem roku 2022. Od léta 2023 jej XTX Markets používá v produkčním prostředí.

    Ladislav Hagara | Komentářů: 8
    Jaké řešení používáte k vývoji / práci?
     (42%)
     (52%)
     (9%)
     (10%)
     (13%)
     (10%)
     (18%)
     (10%)
     (15%)
    Celkem 88 hlasů
     Komentářů: 9, poslední včera 17:28
    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: 207×
    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.