DMS Yazılım Yeniden Yapılandırma Araç Seti - DMS Software Reengineering Toolkit

DMS Yazılım Yeniden Yapılandırma Araç Seti
Geliştirici (ler)Anlamsal Tasarımlar
Lisanstescilli
İnternet sitesiwww.semanticdesigns.com/Ürün:% s/ DMS/ DMSToolkit.html

DMS Yazılım Yeniden Yapılandırma Araç Seti[1] tescilli bir kümedir program dönüşümü büyük ölçekli yazılım sistemleri için kaynak dillerin rastgele karışımları için özel kaynak program analizini, modifikasyonunu, çevirisini veya yazılım sistemlerinin üretimini otomatikleştirmek için mevcut araçlar.

Kullanım

DMS, çok çeşitli pratik araçları uygulamak için kullanılmıştır. alana özgü diller (fabrika kontrolü için kod üretimi gibi), test kapsamı[2] ve profil oluşturma araçları, klon algılama,[3] dil taşıma araçları, C ++ bileşen yeniden mühendisliği.,[4] ve C ++ 'yı güvenilir bir şekilde yeniden düzenleme gibi zor konuları araştırmak için.[5]

Araç seti, dil gramerlerini tanımlamak için araçlar sağlar ve ayrıştırıcılar otomatik olarak inşa eden soyut sözdizimi ağaçları (AST'ler) ve güzel yazıcılar orijinal veya değiştirilmiş AST'leri tekrar derlenebilir kaynak metne dönüştürmek için. Ayrıştırma ağaçları yakalar ve güzel yazıcılar, yeniden oluşturulan kaynak metnin bir programcı tarafından orijinal metin modulosu kadar tanınabilir olmasını sağlamak için kaynak konumu, yorumlar, sayıların tabanı ve formatı dahil olmak üzere orijinal kaynak programla ilgili tüm ayrıntıları yeniden oluşturur. uygulanan dönüşümler.

Birçok program analizi ve dönüştürme aracı aşağıdakilerle sınırlıdır: ASCII veya gibi Batı Avrupa karakter kümeleri ISO-8859; DMS bunları halledebilir. UTF-8, UTF-16, EBCDIC, Shift-JIS ve çeşitli Microsoft karakter kodlamaları.

DMS kullanır GLR ayrıştırma teknolojisi, tüm pratik bağlamdan bağımsız gramerleri işlemesini sağlar. Anlamsal yüklemler, bu yeteneği ilginç bağlamdan bağımsız gramerler için genişletir (Fortran birden çok DO döngüsünün etikete göre paylaşılan CONTINUE deyimleriyle eşleştirilmesini gerektirir; Anlamsal yüklemlere sahip GLR, DMS Fortran ayrıştırıcısının ayrıştırırken doğru iç içe döngüler için AST üretmesini sağlar).

DMS sağlar öznitelik grameri AST'ler üzerinden ölçümler gibi özel analizleri hesaplamak için değerlendiriciler ve aşağıdakiler için özel destek dahil sembol tablosu inşaat. Diğer program gerçekleri yerleşik kontrol ve verilerle çıkarılabilir. akış analizi motorlar, yerel ve küresel işaretçi analizi, tüm program arama grafiği çıkarma ve sembolik aralık analizi soyut yorumlama.

AST'lerde yapılan değişiklikler, hem PARLANSE'de kodlanmış prosedür yöntemleriyle hem de şu şekilde kodlanmış kaynaktan kaynağa ağaç dönüşümleriyle gerçekleştirilebilir. kuralları yeniden yaz DMS'nin Kural Tanımlama Dili (RSL) kullanılarak, çıkarılan herhangi bir program olgusuna göre koşullandırılan yüzey sözdizimini kullanarak. RSL'yi destekleyen yeniden yazma kuralı motoru, ilişkisel ve değişmeli kuralları yönetir. C'nin karmaşık bir koşulu, ?: operatör şu şekilde yazılmalıdır:

   kural simplify_conditional_assignment (v: left_hand_side, e1: ifade, e2: ifade, e3: ifade): ifade-> ifade = "if (e1) v = e2; else v = e3;" -> "v = e1? e2: e3 ; "eğer no_side_effects (v);

Yeniden yazmak kuralisimleri vardır, ör. simplify_conditional_assignment. Her kuralın bir "bunu eşleştir" ve "bununla değiştir" ile ayrılmış desen çifti ->, bizim örneğimizde, okunabilirlik için ayrı satırlarda. Kalıplar, dil sözdizimi kategorilerine karşılık gelmelidir; bu durumda, her iki kalıp da sözdizimi kategorisinde olmalıdır Beyan ayrıca kalıplara sempati içinde ayrıldı. ->. Hedef dil (örneğin, C) yüzey sözdizimi meta-tırnak içinde kodlanmıştır ", yeniden yazma kuralı sözdizimini hedef dilinkinden ayırmak için. Meta-tırnaklar içindeki ters eğik çizgiler, kalıp meta değişkenlerini (ör., v, e1, e2) imza satırındaki meta değişken bildirime karşılık gelen herhangi bir dil yapısıyla eşleşen, ör. e1 sözdizimsel kategoride olmalıdır: (herhangi) ifade. Meta değişkenden birden çok kez bahsediliyorsa eşleşme desen, aynı alt ağaçlarla eşleşmelidir; aynı aynı şekilli v bu örnekteki eşleşme modelindeki her iki atamada da gerçekleşmelidir. Meta değişkenler yerine koymak desen sol taraftan karşılık gelen eşleşmelerle değiştirilir. Koşullu bir cümle Eğer kuralın uygulanması için karşılanması gereken ek bir koşul sağlar, ör. eşleşen meta değişken vkeyfi bir sol taraf olmak, bir yan etkiye sahip olmamalıdır (örneğin, şu şekilde olamaz a [i ++]; yan efektleri olmayan yüklem, diğer DMS mekanizmalarıyla oluşturulmuş bir analizci tarafından tanımlanır).

Kod üzerinde karmaşık bir dönüşüm gerçekleştirmek, istenen etkiyi elde etmek için işbirliği yapan bir dizi kural sağlayarak başarılır. Kural seti, PARLANSE ile kodlanmış metaprogramlar tarafından programın bölümlerine odaklanır.

Bir tam örnek Bir dil tanımının tanımlanması ve uygulanan kaynaktan kaynağa dönüşüm kuralları lise kullanılarak gösterilir cebir ve biraz hesap alana özgü bir dil olarak.

DMS, birçok gerçek lehçeyi kapsayan önceden tanımlanmış çeşitli ön uçlara sahiptir. C ve C ++ dahil olmak üzere C ++ 0x, C #, Java, Python, PHP, EGL, Fortran, COBOL, Visual Basic, Verilog, VHDL ve 20 veya daha fazla başka dil. Önceden tanımlanmış diller, özelleştiricilerin işlenecek dillerin ayrıntıları yerine yeniden yapılandırma görevlerine hemen odaklanmalarına olanak tanır.

DMS ayrıca bir paralel programlama dil, PARLANSE, kullanan simetrik çok işlemciler emtia üzerinde mevcut iş istasyonları. Bu, DMS'nin büyük sistem analizleri ve dönüşümleri için daha hızlı yanıtlar sağlamasını sağlar.

DMS, başlangıçta adı verilen yazılım tasarımlarını sürdürmek için bir teori ile motive edildi. Tasarım Bakım Sistemleri.[6]

DMS ve "Design Maintenance System", Semantic Designs'ın tescilli ticari markalarıdır.

Referanslar

  1. ^ DMS: Pratik Ölçeklenebilir Yazılım Evrimi için Program Dönüşümleri. Proceedings International Conference on Software Engineering 2004 Yeniden yazdır
  2. ^ Keyfi Diller için Şube Kapsamı Kolaylaştırıldı
  3. ^ "Soyut Sözdizimi Ağaçlarını Kullanarak Klon Algılama. Proceedings International Conference on Software Maintenance 1998 ". Arşivlenen orijinal 2012-10-10 tarihinde. Alındı 2010-11-06.
  4. ^ "Örnek olay: C ++ bileşen modellerini otomatik program dönüşümü yoluyla yeniden tasarlayın". doi:10.1016 / j.infsof.2006.10.012. Alıntı dergisi gerektirir | günlük = (Yardım)
  5. ^ Küçük İşletme İnovasyon Araştırması (DoE): Refactor ++
  6. ^ Tasarım Bakım Sistemleri. ACM 1992 İletişimleriYeniden yazdır

Dış bağlantılar