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 04:44 | Komunita

Před týdnem společnost Feral Interactive zabývající se vydáváním počítačových her pro operační systémy macOS a Linux oznámila, že pro macOS a Linux vydají hru Rise of the Tomb Raider. Včera společnost oznámila (YouTube), že pro macOS a Linux vydají také hru Total War Saga: Thrones of Britannia. Verze pro Windows by měla vyjít 19. dubna. Verze pro macOS a Linux krátce na to.

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

Byla vydána nová major verze 7.10 svobodného systému pro řízení vztahů se zákazníky (CRM) s názvem SuiteCRM (Wikipedie). Jedná se o fork systému SugarCRM (Wikipedie). Zdrojové kódy SuiteCRM jsou k dispozici na GitHubu pod licencí AGPL.

Ladislav Hagara | Komentářů: 0
včera 16:44 | Nová verze

Byla vydána nová verze 0.30 display serveru Mir (Wikipedie) a nová verze 2.31 nástrojů snapd pro práci s balíčky ve formátu snap (Wikipedie). Z novinek Miru vývojáři zdůrazňují vylepšenou podporu Waylandu nebo možnost sestavení a spouštění Miru ve Fedoře. Nová verze snapd umí Mir spouštět jako snap.

Ladislav Hagara | Komentářů: 0
včera 14:00 | Komunita

Na Indiegogo běží kampaň na podporu Sway Hackathonu, tj. pracovního setkání klíčových vývojářů s i3 kompatibilního dlaždicového (tiling) správce oken pro Wayland Sway. Cílová částka 1 500 dolarů byla vybrána již za 9 hodin. Nový cíl 2 000 dolarů byl dosažen záhy. Vývojáři přemýšlejí nad dalšími cíli.

Ladislav Hagara | Komentářů: 1
včera 11:11 | Nasazení Linuxu

Před dvěma týdny se skupina fail0verflow (Blog, Twitter, GitHub) pochlubila, že se jim podařilo dostat Linux na herní konzoli Nintendo Switch. O víkendu bylo Twitteru zveřejněno další video. Povedlo se jim na Nintendo Switch rozchodit KDE Plasmu [reddit].

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

Byla vydána vývojová verze 3.2 softwaru Wine (Wikipedie), tj. softwaru, který vytváří aplikační rozhraní umožňující chod aplikací pro Microsoft Windows také pod GNU/Linuxem. Z novinek lze zdůraznit například podporu HID gamepadů. Aktuální stabilní verze Wine je 3.0, viz verzování. Nejistá je budoucnost testovací větve Wine Staging s řadou experimentálních vlastností. Současní vývojáři na ni již nemají čas. Alexandre Julliard, vedoucí projektu Wine, otevřel v diskusním listu wine-devel diskusi o její budoucnosti.

Ladislav Hagara | Komentářů: 2
18.2. 16:55 | Komunita

Do 22. března se lze přihlásit do dalšího kola programu Outreachy (Wikipedie), jehož cílem je přitáhnout do světa svobodného a otevřeného softwaru lidi ze skupin, jež jsou ve světě svobodného a otevřeného softwaru málo zastoupeny. Za 3 měsíce práce, od 14. května do 14. srpna 2018, v participujících organizacích lze vydělat 5 500 USD.

Ladislav Hagara | Komentářů: 46
17.2. 15:44 | Komunita

Nadace The Document Foundation (TDF) zastřešující vývoj svobodného kancelářského balíku LibreOffice dnes slaví 6 let od svého oficiálního vzniku. Nadace byla představena 28. září 2010. Formálně ale byla založena až 17. února 2012. Poslední lednový den byl vydán LibreOffice 6.0. Dle zveřejněných statistik byl za dva týdny stažen již cca milionkrát.

Ladislav Hagara | Komentářů: 1
17.2. 04:44 | Bezpečnostní upozornění

CSIRT.CZ upozorňuje, že byla vydána nová verze 1.2.3 svobodného routovacího démona Quagga (Wikipedie) přinášející několik bezpečnostních záplat. Při nejhorší variantě může dojít až k ovládnutí běžícího procesu, mezi dalšími možnostmi je únik informací z běžícího procesu nebo odepření služby DoS. Konkrétní zranitelnosti mají následující ID CVE-2018-5378, CVE-2018-5379, CVE-2018-5380 a CVE-2018-5381.

Ladislav Hagara | Komentářů: 0
17.2. 00:22 | Pozvánky

V sobota 7. dubna proběhne v Brně na FIT VUT nekomerční konference Security Session '18 věnovaná novinkám a aktuálním problémům v oblasti bezpečnosti mobilních a informačních technologií. Organizátoři vyhlásili CFP. Návrhy přednášek a workshopů lze zaslat do 4. března. Spuštěna byla registrace.

Ladislav Hagara | Komentářů: 0
Který webový vyhledávač používáte nejčastěji?
 (2%)
 (28%)
 (62%)
 (2%)
 (3%)
 (1%)
 (1%)
 (1%)
Celkem 374 hlasů
 Komentářů: 34, poslední 14.2. 18:44
    Rozcestník

    Dotaz: XML scheme

    16.10.2008 15:20 Tomáš Skočdopole | skóre: 13
    XML scheme
    Přečteno: 514×
    Ahoj, chtel bych se zeptat, zda je korektni v navrhu XML struktury pouzit stejny nazev elementu, který bude mit jiné vlastnosti v zavislosti na to, kde se nachazi.
    Priklad:
    <resistor>
    …
    	<value unit-prefix="k">10</value>
    …
    <resistor>
    
    <condensator>
    	…
    	<value unit-prefix="u">10</value>
    	…
    </condensator>
    
    Zde konkretne element <value>, jednou muze jeho atribut unit-prefix nabyvat hodnot: m|R|k|M. Kdezto když je to u kondenzatoru, tak muze tento atribut nabyvat hodnot: m|u|n|p.

    Ted tvorim schema dle XML Schema (http://www.w3.org/2001/XMLSchema) a nevim jak mam definovat element value tak aby se rozlišilo, kde se element nachazi.

    Dekuji predem za pomoc!

    Tomas

    Odpovědi

    default avatar 16.10.2008 15:46 default | skóre: 22 | Madrid
    Rozbalit Rozbalit vše Re: XML scheme
    Jen z hlavy. Budeš to muset doladit:
    <xsd:complexType name="rootType">
        <xsd:sequence>
            <xsd:element name="resistor" type="resistorType" />
            <xsd:element name="condensator" type="condensatorType" />
        </xsd:sequence>
    </xsd:complexType>
    
    <xsd:complexType name="resistorType">
        <xsd:sequence>
            <xsd:element name="value" type="valueType" />
        </xsd:sequence>
    </xsd:complexType>
    
    <xsd:complexType name="condensatorType">
        <xsd:sequence>
            <xsd:element name="value" type="valueType" />
        </xsd:sequence>
    </xsd:complexType>
    
    <xsd:complexType name="valueType">
        <xsd:simpleContent>
            <xsd:extension base="xsd:integer" use="required">
                <xsd:attribute name="unit-prefix" type="unitsType" use="required" />
            </xsd:extendsion>
        </xsd:simpleContent>
    </xsd:complexType>
    
    <xsd:simpleType="unitsType">
        <xsd:restriction base="xsd:string">
            <xsd:enumeration value="k" />
            <xsd:enumeration value="M" />
            <xsd:enumeration value="G" />
            <xsd:enumeration value="T" />
            <xsd:enumeration value="P" />
            <xsd:enumeration value="E" />
            <xsd:enumeration value="Y" />
    
            <xsd:enumeration value="m" />
            <xsd:enumeration value="u" />
            <xsd:enumeration value="n" />
            <xsd:enumeration value="p" />
            <xsd:enumeration value="f" />
            <xsd:enumeration value="a" />
            <xsd:enumeration value="y" />
    
            <xsd:enumeration value="d" />
            <xsd:enumeration value="dk" />
            <xsd:enumeration value="h" />
        </xsd:restriction>
    </xsd:simpleType>
    
    17.10.2008 10:25 Tomáš Skočdopole | skóre: 13
    Rozbalit Rozbalit vše Re: XML scheme
    Diky za reakci,

    no, mozna jsem nesikovne napsal ten ukazkovy (umele vytvoreny) priklad, ale potreboval bych neco jineho. Potreboval bych definovat element <value> vice zpusoby - aby zalezelo, ve ktere pozici se v XML hierarchii nachazi. To znamena aby treba jednou mel element <value> pouze ciselnou hodnotu a bez atributu, podruhe, kdyz se treba nachazi uvnitr <rezistor> tak aby mel atribut unit-prefix a ten atribut aby mohl nabyvat hodnot m R k M. Dale pokud bude treba uvnitr jineho elementu, tak aby mohl mit i podrazene elementy a tak dale.

    Omlouvam se za nepresny popis v prvnim prispevku. Snad uz to bude jasnejsi.

    Dekuji Tomas
    default avatar 17.10.2008 14:28 default | skóre: 22 | Madrid
    Rozbalit Rozbalit vše Re: XML scheme
    Přílohy:
    Tak se na to jukni. XML má tuto strukturu:
    <ns:root xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xmlns:ns="http://hadrabap.googlepages.com/projects/xmlutilities/example.xsd"
             xsi:schemaLocation="http://hadrabap.googlepages.com/projects/xmlutilities/example.xsd file:/Users/petr/NetBeansProjects/xmlutilities/test/global/sandbox/xmlutilities/example.xsd">
        
        <ns:resistor>
            <ns:value unit-prefix="k">12</ns:value>
        </ns:resistor>
        
        <ns:condensator>
            <ns:value>
                12
            </ns:value>
        </ns:condensator>
        
        <ns:other>
            <ns:value unit-prefix="xm">14</ns:value>
        </ns:other>
        
        <ns:resistor>
            <ns:value unit-prefix="M">13</ns:value>
        </ns:resistor>
        
    </ns:root>
    
    Kořenem je element root. V něm můžou být tyto elementy:
    • resistor
    • condensator
    • other
    Všechny tyto elementy v sobě mají element value, který může obsahovat jen číselnou hodnotu (desetinné číslo). Element value v elementu resistor žere navíc atribut unit-prefix, který může nabývat hodnot m, R, k a M. Element value v elementu condensator nemá žádný atribut. Element value v elementu other má též atribut unit-prefix, ale s hodnotami xm, xR, xk a xM.

    Schéma vypadá takto:
    <?xml version="1.0" encoding="UTF-8"?>
    
    <xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema"
                xmlns="http://hadrabap.googlepages.com/projects/xmlutilities/example.xsd"
                targetNamespace="http://hadrabap.googlepages.com/projects/xmlutilities/example.xsd"
                elementFormDefault="qualified"
                attributeFormDefault="unqualified">
        
        <xsd:element name="root" type="rootType" />
        
        <xsd:complexType name="rootType">
            <xsd:sequence minOccurs="0" maxOccurs="unbounded">
                <xsd:choice>
                    <xsd:element name="resistor" type="resistorType" />
                    <xsd:element name="condensator" type="condensatorType" />
                    <xsd:element name="other" type="otherType" />
                </xsd:choice>
            </xsd:sequence>
        </xsd:complexType>
        
        <xsd:complexType name="resistorType">
            <xsd:sequence>
                <xsd:element name="value">
                    <xsd:complexType>
                        <xsd:simpleContent>
                            <xsd:extension base="xsd:decimal">
                                <xsd:attribute name="unit-prefix" type="unitsType" />
                            </xsd:extension>
                        </xsd:simpleContent>
                    </xsd:complexType>
                </xsd:element>
            </xsd:sequence>
        </xsd:complexType>
        
        <xsd:complexType name="condensatorType">
            <xsd:sequence>
                <xsd:element name="value">
                    <xsd:complexType>
                        <xsd:simpleContent>
                            <xsd:extension base="xsd:decimal" />
                        </xsd:simpleContent>
                    </xsd:complexType>
                </xsd:element>
            </xsd:sequence>
        </xsd:complexType>
        
        <xsd:complexType name="otherType">
            <xsd:sequence>
                <xsd:element name="value">
                    <xsd:complexType>
                        <xsd:simpleContent>
                            <xsd:extension base="xsd:decimal">
                                <xsd:attribute name="unit-prefix" type="units2Type" />
                            </xsd:extension>
                        </xsd:simpleContent>
                    </xsd:complexType>
                </xsd:element>
            </xsd:sequence>
        </xsd:complexType>
        
        <xsd:simpleType name="unitsType">
            <xsd:restriction base="xsd:string">
                <xsd:enumeration value="m" />
                <xsd:enumeration value="R" />
                <xsd:enumeration value="k" />
                <xsd:enumeration value="M" />
            </xsd:restriction>
        </xsd:simpleType>
        
        <xsd:simpleType name="units2Type">
            <xsd:restriction base="xsd:string">
                <xsd:enumeration value="xm" />
                <xsd:enumeration value="xR" />
                <xsd:enumeration value="xk" />
                <xsd:enumeration value="xM" />
            </xsd:restriction>
        </xsd:simpleType>
        
    </xsd:schema>
    
    Když si stáhneš XMLUtilities a do adresáře xmlutilities/test/global/sandbox/xmlutilities/ nahraješ soubory z přílohy, získáš další TestCase, pomocí kterého si můžeš hrát s tím schémátkem. Je to projekt NetBeans 6.1 a všechny knihovny jsou součástí distribuce knihovny. Vyžaduje to JavaSE 5 a vyšší.

    Tak snad jsem trošku pomohl. Dej vědět, co dál ;-)
    29.10.2008 16:27 Tomáš Skočdopole | skóre: 13
    Rozbalit Rozbalit vše Re: XML scheme
    Ahoj,

    ano to je presne ono jak jsem to potreboval. Dekuji mnohokrat!

    Jinak mohl bych se zeptat, jak v teto sekci:
    <location>
         <coordinate name="x">20</coordinate>
         <coordinate name="y">50</coordinate>
    </location>
    
    nadefinovat to, aby se prvek coordinate mohl vyskytnout vicenasobne ale abynevznikla duplicitni definice u hodnoty atributu name. Cili nejak takto ne:
    <location>
         <coordinate name="x">20</coordinate>
         <coordinate name="x">50</coordinate>
         <coordinate name="y">50</coordinate>
    </location>
    
    Dekuji Vam!
    default avatar 29.10.2008 19:54 default | skóre: 22 | Madrid
    Rozbalit Rozbalit vše Re: XML scheme
    No, tady je to již trošku horší. Bohužel dva stejně pojmenované elementy s různými typy nelze v XML Schema nadefinovat. Buď bych to ošetřil v parseru (tam je to docela jednoduché, protože předtím, než nasmažíš do svých struktur hodnotu pro např. coordinate-x, tak se podíváš, jestli je nadefinovaná a když jo, tak vyhučíš), nebo změnil strukturu XML (například mít dva elementy <coordinate-x /> a <coordinate-y /> bez toho atributu)…

    Bohužel, i XML Schema má své limity a tohle není jediná. Například nejde udělat, že když má atribut někde v nějakym elementu nahoře tuhle hodnotu, tak někde dole musí být hodnota jiná :-/
    17.10.2008 10:59 FooBar
    Rozbalit Rozbalit vše Re: XML scheme
    Ano, je to kosher, ale pozor -- DTD tohle neumi, jsi omezenej pak prave na XSD, RelaxNG apod.

    Jen bych se zeptal, proc omezovat u kondensatoru jen na male hodnoty a u odporu jen na velke hodnoty -- neprijde mi to jako rozumny pristup k validaci dat... kdyz nekdo bude chtit zadat pidiodpor nebo megakondensator, tak ma peska i kdyby to treba davalo v realnym svete smysl... osobne bych proste omezil "unit-prefix" na zname prefixy jednotek a tim to haslo.
    17.10.2008 11:23 Tomáš Skočdopole | skóre: 13
    Rozbalit Rozbalit vše Re: XML scheme
    Aha, to jsem nevedel ze DTD toto neumi... Nastesti jsem hned od zacatku sahl po XML Scheme :) Ale nevim jak tam toto zadefinovat :(

    Jinak jak jsem psal vyse, tento priklad jsem vytvoril umele. Ve zkutecnosti to mam k necemu uplne jinemu.

    Tomas
    17.10.2008 22:24 FooBar
    Rozbalit Rozbalit vše Re: XML scheme
    V tom pripade by mozna bylo pro lepsi odpovedi dat lepsi ukazkovy vzorek dat:)
    29.10.2008 21:25 cronin | skóre: 49
    Rozbalit Rozbalit vše Re: XML scheme
    Bez ohladu na to, ci to mozne je alebo nie je, moja rada je, aby si sa tomu vyhol. Usetris problemy sebe a zmatok pre buducich pouzivatelov. A ako bolo naznacene neschopnostou DTD osetrit tuto situaciu, patrne sa vyhnes aj niektorym technickym problemom. Napr. vo vyssie uvedenom pripade je vhodne value nahradit raz pomocou "resistance", raz pomocou "capacity", alebo pod. I ked, vyssie uvedeny priklad je umelo vykonstruovany, ze ano.

    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.