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í
×
    včera 23:55 | Nová verze

    Byla vydána nová stabilní verze 24.05 linuxové distribuce NixOS (Wikipedie). Její kódové označení je Uakari. Podrobný přehled novinek v poznámkách k vydání. O balíčky se v NixOS stará správce balíčků Nix.

    Ladislav Hagara | Komentářů: 0
    včera 17:33 | Nová verze

    Byla vydána nová verze 1.48.0 sady nástrojů pro správu síťových připojení NetworkManager. Novinkám se v příspěvku na blogu NetworkManageru věnuje Fernando F. Mancera. Mimo jiné se v nastavení místo mac-address-blacklist nově používá mac-address-denylist.

    Ladislav Hagara | Komentářů: 5
    včera 17:11 | Komunita

    Před 25 lety, 31. května 1999, započal vývoj grafického editoru Krita (Wikipedie). Tenkrát ještě pod názvem KImageShop a později pod názvem Krayon.

    Ladislav Hagara | Komentářů: 2
    včera 12:55 | Nová verze

    Farid Abdelnour se v příspěvku na blogu rozepsal o novinkám v nejnovější verzi 24.05.0 editoru videa Kdenlive (Wikipedie). Ke stažení brzy také na Flathubu.

    Ladislav Hagara | Komentářů: 0
    včera 11:22 | Zajímavý článek

    David Revoy, autor mj. komiksu Pepper&Carrot, se rozepsal o své aktuální grafické pracovní stanici: Debian 12 Bookworm, okenní systém X11, KDE Plasma 5.27, …

    Ladislav Hagara | Komentářů: 5
    30.5. 22:44 | Nová verze

    Wayland (Wikipedie) byl vydán ve verzi 1.23.0. Z novinek lze vypíchnout podporu OpenBSD.

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

    Craig Loewen na blogu Microsoftu představil novinky ve Windows Subsystému pro Linux (WSL). Vypíchnout lze GUI aplikaci pro nastavování WSL nebo správu WSL z Dev Home.

    Ladislav Hagara | Komentářů: 0
    30.5. 12:44 | Pozvánky

    V sobotu 1. června lze navštívit Maker Faire Ostrava, festival plný workshopů, interaktivních činností a především nadšených a zvídavých lidí.

    Ladislav Hagara | Komentářů: 0
    30.5. 12:22 | Nová verze

    Webový server Caddy (Wikipedie) s celou řadou zajímavých vlastností byl vydán ve verzi 2.8 (𝕏). Přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 12
    29.5. 22:11 | Nová verze

    Byla vydána verze 3.0 (@, 𝕏) svobodného softwaru HAProxy (The Reliable, High Performance TCP/HTTP Load Balancer; Wikipedie) řešícího vysokou dostupnost, vyvažování zátěže a reverzní proxy. Detailní přehled novinek v příspěvku na blogu společnosti HAProxy Technologies.

    Ladislav Hagara | Komentářů: 7
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (90%)
     (3%)
     (4%)
     (4%)
    Celkem 1062 hlasů
     Komentářů: 17, poslední včera 15:31
    Rozcestník

    Dotaz: Správa C++ projektů (odkazy ve správě verzí?)

    microcz avatar 26.8.2011 13:32 microcz | skóre: 18 | blog: Michalův zápisník | Praha
    Správa C++ projektů (odkazy ve správě verzí?)
    Přečteno: 362×
    Dobrý den,

    předem se omlouvám za případnou stupiditu dotazu, ale potřeboval bych od Vás poradit....

    Pracujeme ve firmě na několika rozsáhlejších projektech v C++. Jednotlivé projekty mají mezi sebou závislosti, například projekty B a C používají různé podmnožiny z množiny tříd projektu A, který byl vytvořen dříve. Zároveň pro projekt A beží podpora a je potřeba uvedené třídy měnit (vylepšovat, opravovat)

    Řešením by mohlo být rozdrobit projekty do mnoha malých knihoven a v každém projektu si pak stahovat ze správy verzí aktuální verze potřebných knihoven. V jave by tohle byla paráda, ale problémem je C++ ... psát CMake pro každou knihovnu, uvažovat fakt že každá knihovna může být závislá na jiných knihovnách, být schopen zkompilovat každou knihovnu pro všechny požadované architektury, operační systémy a začlenit ji do projektů, nutnost stromovitě překompilovávat závislosti, to vše činí z tohohle způsobu řešení peklo.

    Proto bych se chtěl zeptat zda nějaký existující verzovací systém neobsahuje něco jako tvorbu odkazů...

    PŘEDSTAVA:
    1. Existovali by oddělené složky pro projekty A,B,C...atd
    2. Každý projekt by měl svou adresářovou strukturu, ale z růzých míst v B a C by mohli být odkazovány třídy nebo celé adresáře projektu A.
    3. Pokud by někdo stáhl z repozitáře pouze projekt B nebo C, stáhli by se mu místo linků reálné soubory a adresáře, aniž by vědět o přítomnosti linků na projekt A, při commitu změn v těchto souborech by se ale updatovaly i soubory v A.
    Zdá se Vám to jako hloupost? Jak byste podobný problém řešili vy?

    Odpovědi

    26.8.2011 16:47 vbar
    Rozbalit Rozbalit vše Re: Správa C++ projektů (odkazy ve správě verzí?)
    Subversion podporuje symlinky, ale bohužel nikoli pod Windows... Osobně jsem tenhle problém řešil na svém posledním projektu hrubou silou, tj. sdílené soubory se udržovaly zvlášť a každý projekt který je potřeboval si je v rámci buildu zkopíroval. Je pravda že to ten build komplikuje, a dělat změny na originálu mimo projekt je nepohodlné, ale pro podporu bouřlivě se vyvíjejících závislostí a obskurních platforem to má své výhody. Stabilnější části jsem ale stejně tlačil do sdílené knihovny - kolik jich na konkrétním projektu má být a jak velké je podle mně hlavně otázka osobních preferencí architekta...
    26.8.2011 18:40 Sten
    Rozbalit Rozbalit vše Re: Správa C++ projektů (odkazy ve správě verzí?)
    Subversion hlavně podporuje svn:externals a není problém sdílený kód umístit do jedné složky, kterou takhle „nalinkujete“. S tímto přístupem mám na Windows dobré zkušenosti. Nicméně už nějakou dobu používám git, který externals umí také.
    26.8.2011 17:43 pht | skóre: 48 | blog: pht
    Rozbalit Rozbalit vše Re: Správa C++ projektů (odkazy ve správě verzí?)
    Dejte si to vše do jednoho repa, nebo vyjměte z A jednu knihovnu na kterou budou odkazovat A B C.
    aniž by vědět o přítomnosti linků na projekt A, při commitu změn v těchto souborech by se ale updatovaly i soubory v A
    To je dost nebezpečné řešení.
    In Ada the typical infinite loop would normally be terminated by detonation.
    26.8.2011 20:33 l4m4
    Rozbalit Rozbalit vše Re: Správa C++ projektů (odkazy ve správě verzí?)
    Nebezpečného na tom není nic.

    Akorát normálnější je sdílená knihovna (blouznění tazatele o samostatných makefiles nechápu, to snad už takhle je, nebo má rozbitý build system).
    Josef Kufner avatar 29.8.2011 22:34 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Správa C++ projektů (odkazy ve správě verzí?)
    V Gitu bych to řešil pomocí submodulů.

    Ten makefile napíšeš jen jednou a pak ho budeš jen kopírovat a kopírovat pro každou knihovnu.

    Závislosti můžeš vyřešit celkem jednoduše malým scriptem. V kořeni každého submodulu bys mohl mít soubor, kde na samostatných řádcích budou uvedeny závislosti dané knihovny. Pak jen uděláš cat lib/*/závislosti | uniq a odečteš seznam souborů (| while read d ; do [ -d "$d" ] || echo "Missing $d" ; done).

    Build takového projektu bude jen o tom, že v tom adresáři lib/ budeš mít makefile, který rekurzivně zavolá makefily všech knihoven. Pokud je pořadí kompilace důležité (nemělo by být, hlavičkové soubory by měly stačit), tak ty soubory se závislostmi jednoduchým scriptem poskládáš do makefilu (každý soubor spojit v jeden řádek uvozený jeho jménem a dvojtečkou, tedy ještě to asi bude chtít převést názvy na jména archivů knihoven). Jo a ten makefile v lib zavoláš na začátku kompilace tvého projektu.
    Hello world ! Segmentation fault (core dumped)

    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.