[XBUP]XBUP - Dokumentace: Úrovně protokolu

Úvod

Tento dokument je součástí dokumentace projektu eXtensible Binary Universal Protocol. Obsahuje popis ...

O úroveň výše

Obsah

1. Úvod
2. Hierarchie úrovní
  2.1. Typy atributů
  2.2. Povolené podbloky
  2.3. Omezení rozsahu
  2.4. Dědičnost
  2.5. Instrukce pro zpracování
  2.6. Implicitní hodnoty
  2.7. Samopopisnost
  2.8. Významnost bloku

1. Úvod

Zde uvedený nástin úrovní protokolu rozvádí úvahy o postupném přidávání nových vlastností a omezení do protokolu.

2. Hierarchie úrovní

Navržená hierarchie úrovní je zatím dosti nejasná. Jednotlivé návrhy se překrývají a jejich lineární seřazení může býti dosti obtížné. V nejhorším případě by struktura úrovní tvořila svaz.

Všechny další úrovně jsou víceméně spekulativní a uteče ještě hodně vody než budu schopen rozhodnout, které řešení je to nejvhodnější. Tedy pokud na tom budu pracovat pořád jenom sám ;-)

2.1. Typy atributů

Jedním z jistých rozšíření je zavedení typů atributů. Typ atributu je už zmiňován při zavádění typů bloků. Jsou to kromě standardních typů UBNatural, UBInteger a UBRatio například UBPointer, či vícepoložkové UBReal, UBVersion, UBList... Ačkoliv všechny atributy jsou kódovány jako hodnoty typu UBNumber, přesto se zdá vhodné nějakým způsobem umožnit rozlišovat, jaký význam má daná položka. Přesto typ atributu není významný pro základní validaci dokumentu, a proto asi nemá smysl jej zahrnout do úrovně 1.

Atributy v podstatě tvoří stromovou hierarchii (obdoba dědění objektových tříd). Například všechny atributy jsou typu UBNumber, některé atributy mají "rozhraní" pro nekonečné hodnoty atp. Kromě dědění by bylo vhodné zvážit, zda nemá smysl typy atributů prezentovat jako bloky určitého typu a zajistit jim tak ekvivalenci.

V případě atributů se dá také hovořit o jisté formě programování. Typ atributu v jisté formě tvoří jazyk, nebo také programový předpis, jakým je zkonstruován z jednodušších typů. Z pohledu while-programů jsou typy konstruovány pomocí sekvence a cyklu, jak konečného, tak nekonečného. Podobně v případě vícevýznamového typu se dá hovořit o podobnosti s paralelismem. Příkladem můžou být víceatributové typy UBReal a UBPath.

Je UBLength zároveň UBPath i UBCount? Problém dědění / zavedení rozhraní?

Možná úroveň umístění: 1+ (2)

2.2. Povolené podbloky

Především v případě, kdy blok obsahuje UBPointer (či UBList), by mělo být možné definovat, na jaký typ bloku může být odkazováno. To, že je odkazováno na blok, který patří do platného rozsahu typů ještě neznamená, že jej bude možné zpracovat. Samozřejmě se musí zohledňovat odkazovací bloky a i bloky transformační. Přesto je možné tuto variantu provozovat i bez transformačních bloků.

Možná úroveň umístění: 1+

2.3. Omezení rozsahu

Mezi další jisté rozšíření patří realizace omezení rozsahu. Především pro použití na malých zařízeních je vhodné dostat soubor do omezených mezí. Řekněme, že je například potřeba omezit maximální velikost bloku na 64kB, aby ji bylo na malém zařízení možné zpracovat. Nebo případně omezit velikost bloku jako celku.

Příkladem může být omezení délky textu názvu souboru pro použití na malých zařízeních, nebo určení maximálního rozlišení obrázku.

Možná úroveň umístění: 2+

2.4. Dědičnost

Zřejmě by bylo vhodné umožnit realizaci přenášení atributů bloku. Například blok reprezentující seznam konkrétních položek by mohl potomkem bloku, který je seznamem libovolných položek. Tato vlastnost nemá opět vliv na konkrétní validitu dokumentu, ačkoliv lze validovat splnění podmínek dědičnosti. Případně uvádět bloky jako rozšíření jiných - nutné zpracování celé sekvence bloků.

Možná úroveň umístění: 1+

2.5. Instrukce pro zpracování

Tato úroveň obsahuje navíc podporu pro instrukce zpracování dokumentů a jeho transformaci do jiných tvarů a instrukční předpisy pro platnost dokumentu.

Příkladem může být pokyn pro ignorování části dokumentu, nebo vložení dokumentu jiného z definovaného zdroje. Dále různé typy podmínek a testů, například na vlastnosti prostředí.

Jedná se o transformační bloky?

Možná úroveň umístění: 3+

2.6. Implicitní hodnoty

Touto vlastností je míněna obdoba vlastností CSS. Ty umožňují měnit implicitní hodnoty podstromů dokumentu. Například pro textový soubor by se dalo místo definice kódování pro každý textový řetězec toto definovat pro celé podstromy a pouze položky v odlišném kódování by měly toto definováno zvlášť. Pravděpodobně se spíše nejedná ve všech případech o kompresi, neboť náhradou těchto bloků by mohlo být možné například měnit vzhled dokumentu a podobně, tudíž by tyto definice implicitních hodnot mohly být zaměnitelné.

Například dvě varianty, první by pro danou skupinu a typ bloku, pro atribut na daném místě bloku, uváděla jeho implicitní hodnotu v případě neuvedení, nebo tak něco.

Druhá, zajímavější, určená především pro typ UBPointer, pracuje tak, že pro uvedený typ bloku a jeho atribut definuje existenci ukazatele na virtuální blok, na který sama ukazuje. Zřejmě tato varianta by byla realizována jako převodní transformační blok (strom na strom), kde by jeden vstup představoval seznam implicitních bloků a druhý strom do kterého by byly v případě jejich nepřítomnosti doplňovány.

Možná úroveň umístění: 2+

2.7. Samopopisnost

Rozšíření o bloky, které by umožnily definovat význam bloku jiným než slovním popisem, například popisným algoritmem, nebo vazbou na aplikaci, která je schopna daný blok zobrazit v grafické podobě.

Možná úroveň umístění: 4+

2.8. Významnost bloku

Tato vlastnost říká, zda zpracování daného bloku je nutné pro získání údajů z dokumentu jako celku. Například v případě obrázku, údaje o autorovi nejsou esenciální součástí dokumentu, i když mohou mít svůj podstatný význam. Tato vlastnost by mohla být realizována použitím definičních bloků na různých stupních zanoření, případně také uvedením významu ve specifikaci skupin. Tyto údaje by pak měli význam pro validitu použitelnosti dokumentu.

Možná úroveň umístění: 2+

Homepage: http://xbup.sf.net
License: GNU Free Documentation License (FDL)
Latest update: 2007-02-13