Sada nástrojů pro reengineering softwaru DMS - DMS Software Reengineering Toolkit

Sada nástrojů pro reengineering softwaru DMS
VývojářiSémantické vzory
Licenceproprietární
webová stránkawww.sémantický design.com/Produkty/ DMS/ DMSToolkit.html

The Sada nástrojů pro reengineering softwaru DMS[1] je vlastnická sada transformace programu dostupné nástroje pro automatizaci vlastní analýzy zdrojových programů, úpravy, překlady nebo generování softwarových systémů pro libovolné směsi zdrojových jazyků pro rozsáhlé softwarové systémy.

Používání

DMS se používá k implementaci široké škály praktických nástrojů, včetně jazyky specifické pro doménu (například generování kódu pro řízení z výroby), pokrytí testu[2] a profilovací nástroje, detekce klonů,[3] nástroje pro migraci jazyků, reengineering komponent C ++.,[4] a pro výzkum obtížných témat, jako je spolehlivé refaktorování C ++.[5]

Sada nástrojů poskytuje prostředky pro definování jazykových gramatik a bude produkovat analyzátory které automaticky vytvářejí abstraktní syntaxové stromy (AST) a hezké tiskárny převést původní nebo upravené AST zpět na kompilovatelný zdrojový text. Zachycení analyzovaných stromů a regenerace hezkých tiskáren poskytuje úplné podrobnosti o původním zdrojovém programu, včetně polohy zdroje, komentářů, radixů a formátu čísel atd., Aby bylo zajištěno, že regenerovaný zdrojový text bude pro programátora rozpoznatelný stejně jako původní text modulo jakékoli použité transformace.

Mnoho nástrojů pro analýzu a transformaci programů je omezeno na ASCII nebo západoevropské znakové sady jako ISO-8859; DMS to zvládne stejně dobře UTF-8, UTF-16, EBCDIC, Shift-JIS a řadu kódování znaků Microsoft.

DMS používá GLR technologie analýzy, která jí umožňuje zpracovávat všechny praktické bezkontextové gramatiky. Sémantické predikáty rozšiřují tuto schopnost na zajímavé bezkontextové gramatiky (Fortran vyžaduje shodu více smyček DO se sdílenými příkazy POKRAČOVAT podle štítku; GLR se sémantickými predikáty umožňuje analyzátoru DMS Fortran vyrábět AST pro správně vnořené smyčky při jeho analýze).

DMS poskytuje atribut gramatiky hodnotitelé pro výpočet vlastních analýz přes AST, jako jsou metriky, a včetně speciální podpory pro tabulka symbolů konstrukce. Další fakta o programu lze extrahovat pomocí vestavěných řídicích a datových analýza toku motory, místní i globální analýza ukazatele, celý program graf volání extrakce a analýza symbolického rozsahu pomocí abstraktní interpretace.

Změny AST lze provést jak procedurálními metodami kódovanými v PARLANSE, tak transformacemi stromu zdroj-zdroj kódovanými jako přepsat pravidla pomocí povrchové syntaxe podmíněné jakýmkoli extrahovaným faktem o programu pomocí DMS Rule Specification Language (RSL). Modul pravidel přepisu podporující RSL zpracovává asociativní a komutativní pravidla. Pravidlo přepisu pro C, které nahradí složitou podmínku znakem ?: operátor psát jako:

   pravidlo zjednodušit_podmíněné přiřazení (v: left_hand_side, e1: expression, e2: expression, e3: expression): statement-> statement = "if (e1) v = e2; else v = e3;" -> "v = e1? e2: e3 ; "if no_side_effects (v);

Přepsat pravidlomají jména, např. zjednodušit_podmínečné_přiřazení. Každé pravidlo má a „odpovídat tomuto“ a "nahradit tímto" dvojice vzorů oddělená ->, v našem příkladu na samostatných řádcích kvůli čitelnosti. Vzory musí odpovídat kategoriím jazykových syntaxí; v tomto případě musí být oba vzory syntaxe kategorie prohlášení také odděleny v souladu se vzory podle ->. Syntaxe povrchu cílového jazyka (např. C) je kódována uvnitř meta-uvozovek ", k oddělení syntaxe pravidla přepsání od syntaxe cílového jazyka. Zpětná lomítka uvnitř meta-uvozovek představují úniky domén, které označují meta proměnné vzoru (např. proti, e1, e2), které odpovídají libovolnému jazykovému konstruktu odpovídajícímu deklaraci metavariabilní v řádku podpisu, např. e1 musí být syntaktické kategorie: (jakýkoli) výraz. Pokud je metavariable v souboru zmíněna vícekrát zápas vzor, ​​musí odpovídat identickým podstromům; stejné identicky tvarované proti se musí v tomto příkladu vyskytnout u obou přiřazení ve vzoru shody. Metavariable v nahradit vzor jsou nahrazeny odpovídajícími shodami z levé strany. Podmíněná klauzule -li poskytuje další podmínku, která musí být splněna, aby pravidlo mohlo platit, např. že odpovídající metavariable proti, jelikož je libovolnou levou stranou, nesmí mít vedlejší účinek (např. nemůže mít formu a [i ++]; the no_side_effects predikát je definován analyzátorem vytvořeným s jinými mechanismy DMS).

Dosažení komplexní transformace kódu je dosaženo poskytnutím řady pravidel, která spolupracují na dosažení požadovaného efektu. Sada pravidel je zaměřena na části programu metaprogramy kódovanými v PARLANSE.

A úplný příklad definice jazyka a definovaných a aplikovaných pravidel transformace ze zdroje na zdroj se zobrazuje na střední škole algebra a trochu počet jako jazyk specifický pro doménu.

DMS má řadu předdefinovaných jazykových rozhraní, pokrývající většinu skutečných dialektů C a C ++ počítaje v to C ++ 0x, C#, Jáva, Krajta, PHP, EGL, Fortran, COBOL, Visual Basic, Verilog, VHDL a asi 20 nebo více dalších jazyků. Předdefinované jazyky umožňují přizpůsobovatelům okamžitě se soustředit na svůj úkol reengineeringu, nikoli na podrobnosti jazyků, které mají být zpracovány.

DMS je navíc neobvyklý v implementaci v paralelní programování jazyk, PARLANSE, který používá symetrické multiprocesory k dispozici na komoditě pracovní stanice. To umožňuje DMS poskytovat rychlejší odpovědi na velké systémové analýzy a převody.

DMS byl původně motivován teorií pro udržování návrhů softwaru zvaného Systémy údržby designu.[6]

DMS a „Design Maintenance System“ jsou registrované ochranné známky společnosti Semantic Designs.

Reference

  1. ^ DMS: Transformace programů pro praktickou škálovatelnou evoluci softwaru. Proceedings International Conference on Software Engineering 2004 Dotisk
  2. ^ Snadné pokrytí poboček pro libovolné jazyky
  3. ^ "Detekce klonů pomocí abstraktních syntaxových stromů. Proceedings International Conference on Software Maintenance 1998 ". Archivovány od originál dne 10.10.2012. Citováno 2010-11-06.
  4. ^ "Případová studie: Přepracování modelů komponent C ++ pomocí automatické transformace programu". doi:10.1016 / j.infsof.2006.10.012. Citovat deník vyžaduje | deník = (Pomoc)
  5. ^ Inovační výzkum v oblasti malých podniků (DoE): Refactor ++
  6. ^ Systémy údržby designu. Sdělení ACM 1992Dotisk

externí odkazy