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 01:55 | IT novinky

    Nejvyšší správní soud (NSS) podruhé zrušil pokutu za únik zákaznických údajů z e-shopu Mall.cz. Incidentem se musí znovu zabývat Úřad pro ochranu osobních údajů (ÚOOÚ). Samotný únik ještě neznamená, že správce dat porušil svou povinnost zajistit jejich bezpečnost, plyne z rozsudku dočasně zpřístupněného na úřední desce. Úřad musí vždy posoudit, zda byla přijatá opatření přiměřená povaze rizik, stavu techniky a nákladům.

    Ladislav Hagara | Komentářů: 2
    včera 18:44 | Komunita

    Organizace Free Software Foundation Europe (FSFE) zrušila svůj účet na 𝕏 (Twitter) s odůvodněním: "To, co mělo být původně místem pro dialog a výměnu informací, se proměnilo v centralizovanou arénu nepřátelství, dezinformací a ziskem motivovaného řízení, což je daleko od ideálů svobody, za nimiž stojíme". FSFE je aktivní na Mastodonu.

    Ladislav Hagara | Komentářů: 13
    včera 17:55 | IT novinky

    Paramount nabízí za celý Warner Bros. Discovery 30 USD na akcii, tj. celkově o 18 miliard USD více než nabízí Netflix. V hotovosti.

    Ladislav Hagara | Komentářů: 3
    včera 13:22 | IT novinky

    Nájemný botnet Aisuru prolomil další "rekord". DDoS útok na Cloudflare dosáhl 29,7 Tbps. Aisuru je tvořený až čtyřmi miliony kompromitovaných zařízení.

    Ladislav Hagara | Komentářů: 4
    včera 12:11 | Nová verze

    Iced, tj. multiplatformní GUI knihovna pro Rust, byla vydána ve verzi 0.14.0.

    Ladislav Hagara | Komentářů: 3
    včera 05:22 | Komunita

    FEX, tj. open source emulátor umožňující spouštět aplikace pro x86 a x86_64 na architektuře ARM64, byl vydán ve verzi 2512. Před pár dny FEX oslavil sedmé narozeniny. Hlavní vývojář FEXu Ryan Houdek v oznámení poděkoval společnosti Valve za podporu. Pierre-Loup Griffais z Valve, jeden z architektů stojících za SteamOS a Steam Deckem, v rozhovoru pro The Verge potvrdil, že FEX je od svého vzniku sponzorován společností Valve.

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

    Byla vydána nová verze 2.24 svobodného video editoru Flowblade (GitHub, Wikipedie). Přehled novinek v poznámkách k vydání. Videoukázky funkcí Flowblade na Vimeu. Instalovat lze také z Flathubu.

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

    Společnost Proton AG stojící za Proton Mailem a dalšími službami přidala do svého portfolia online tabulky Proton Sheets v Proton Drive.

    Ladislav Hagara | Komentářů: 8
    6.12. 15:55 | Komunita

    O víkendu (15:00 až 23:00) probíha EmacsConf 2025, tj. online konference vývojářů a uživatelů editoru GNU Emacs. Sledovat ji lze na stránkách konference. Záznamy budou k dispozici přímo z programu.

    Ladislav Hagara | Komentářů: 1
    6.12. 15:44 | Komunita

    Provozovatel internetové encyklopedie Wikipedia jedná s velkými technologickými firmami o uzavření dohod podobných té, kterou má s Googlem. Snaží se tak zpeněžit rostoucí závislost firem zabývajících se umělou inteligencí (AI) na svém obsahu. Firmy využívají volně dostupná data z Wikipedie k trénování jazykových modelů, což zvyšuje náklady, které musí nezisková organizace provozující Wikipedii sama nést. Automatické programy

    … více »
    Ladislav Hagara | Komentářů: 32
    Jaké řešení používáte k vývoji / práci?
     (34%)
     (48%)
     (19%)
     (17%)
     (22%)
     (15%)
     (24%)
     (16%)
     (18%)
    Celkem 445 hlasů
     Komentářů: 18, poslední 2.12. 18:34
    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: 250×
    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.