Rexx - Hata Ayıklama

Hata ayıklama, herhangi bir programlama dilinde önemli bir özelliktir. Geliştiricinin hataları teşhis etmesine, temel nedeni bulmasına ve ardından bunları uygun şekilde çözmesine yardımcı olur. Rexx'te izleme aracı, hata ayıklama için kullanılır. İzleme talimatı, biri toplu mod ve diğeri etkileşimli mod olmak üzere 2 şekilde uygulanabilir. Her iki seçeneğin nasıl uygulanacağına bakalım.

Toplu Modda İzleme

İzleme komutu, yürütülen her Rexx komutunun ayrıntılı bir düzeyini vermek için kullanılır.

Trace ifadesinin genel sözdizimi aşağıdaki gibi gösterilir -

Sözdizimi

trace [setting]

Ayar aşağıdaki seçeneklerden herhangi biri olabilir -

  • A - Tüm komutları takip eder.

  • C - Yalnızca işletim sistemine gönderilen ana bilgisayar komutlarını izler.

  • E - Yalnızca işletim sistemine gönderilen ve bir hatayla sonuçlanan ana bilgisayar komutlarını izler.

  • F - Yalnızca bir arızayla sonuçlanan işletim sistemine gönderilen ana bilgisayar komutlarını izler.

  • I - Bu, Rexx komutlarının orta düzeyde izlenmesini sağlar.

  • L - Bu seçenek, izlemeyi gerçekleşirken etiketlemek istemeniz içindir.

  • N - Bu, hiçbir izleme yapılmayan varsayılan seçenektir.

Trace komutunun bir örneğine bakalım.

Misal

/* Main program */ 
trace A 

/* Main program */ 
n = 100.45 if datatype( n, wholenumber ) then signal msg 

say 'This is a whole number' 
return 0 

msg : 
   say ' This is an incorrect number '

Yukarıdaki programın çıktısı aşağıdaki gibi olacaktır -

5 *-* n = 100.45 if datatype( n, wholenumber ) then signal msg
   7 *-* say 'This is a whole number
This is a whole number                                                   
   8 *-* return 0

Çıktıdan, programın çıktısına ek bir iz eklendiğini görebilirsiniz. Çıktıyla ilgili olarak aşağıdaki hususlar not edilebilir -

  • Yürütülen ifade ile birlikte satır numarası izleme çıktısına eklenir.

  • Yürütülen her satır izleme çıktısında gösterilir.

İzleme Fonksiyonu

İzleme işlevi sayesinde izleme de etkinleştirilebilir. Genel sözdizimi ve örnek aşağıda gösterilmiştir.

Sözdizimi

trace()

Yukarıdaki işlev, geçerli izleme seviyesini döndürür.

Parametreler

Yok

Geri dönüş değeri

Yukarıdaki işlev, mevcut izleme seviyesini verir.

Misal

/* Main program */ 
say trace() 

/* Main program */ 
n = 100.45 if datatype( n, wholenumber ) then signal msg 

say 'This is a whole number' 
return 0 
msg : 

say 'This is an incorrect number '

Yukarıdaki programın çıktısı aşağıdaki gibi olacaktır.

N 
This is an incorrect number

N'nin ilk satırı, izlemenin Normal olarak ayarlandığını gösterir.

İz Değerini Ayarlama

İzleme seviyesi, izleme fonksiyonu ile ayarlanabilir. Genel sözdizimi ve örnek aşağıda gösterilmiştir.

Sözdizimi

trace(travel_level)

Parametreler

  • trace_level - Bu, izleme düzeyini ayarlamak için mevcut seçeneklere benzer.

Geri dönüş değeri

Yukarıdaki işlev, mevcut izleme seviyesini verir.

Misal

/* Main program */ 
say trace() 
current_trace = trace('A') 
say current_trace 

/* Main program */ 
n = 100.45 if datatype( n, wholenumber ) then 
signal msg say 'This is a whole number' 
return 0 
msg : 
say ' This is an incorrect number '

Yukarıdaki programın çıktısı aşağıdaki gibi olacaktır -

N 
   4 *-* say current_trace 
N 
   6 *-* n = 100.45 
   7 *-* if \ datatype( n, wholenumber ) then 
   8 *-* signal msg 
   12 *-* say 'This is an incorrect number' 
'This is an incorrect number'

Etkileşimli İzleme

Etkileşimli izleme, program çalışırken izleme işleminin yapıldığı yerdir. Tıpkı .Net için Visual Studio gibi bir IDE'de olduğu gibi, kesme noktaları ekleyebilir ve her bir ifadenin nasıl çalıştığını görebilir, benzer şekilde burada da her kod satırı çalışırken programı görebilirsiniz.

Genel sözdizimi aşağıdaki gibidir -

Sözdizimi

trace ?options

Burada, seçenekler aşağıda gösterildiği gibi izleme komutu için aynıdır.

  • A - Tüm komutları takip eder

  • C - Yalnızca işletim sistemine gönderilen ana bilgisayar komutlarını izler.

  • E - Yalnızca işletim sistemine gönderilen ve bir hatayla sonuçlanan ana bilgisayar komutlarını izler.

  • F - Yalnızca bir arızayla sonuçlanan işletim sistemine gönderilen ana bilgisayar komutlarını izler.

  • I - Bu, Rexx komutlarının orta düzeyde izlenmesini sağlar.

  • L - Bu seçenek, izlemeyi gerçekleşirken etiketlemek istemeniz içindir.

  • N - Bu, hiçbir izleme yapılmayan varsayılan seçenektir.

Aktif izleme uygulama örneğine bir göz atalım.

Misal

/* Main program */ 
trace ?A

/* Main program */ 
n = 100.45 if datatype( n, wholenumber ) then 
signal msg 

say 'This is a whole number' 
return 0 
msg : say 'This is an incorrect number'

Yukarıdaki programın çıktısı aşağıdaki programda gösterildiği gibi olacaktır. İzleme, her kod satırında duracaktır; ardından bir sonraki kod satırına geçmek için Enter düğmesine basmanız gerekir.

This is an incorrect number
       +++ "LINUX COMMAND /home/cg/root/5798511/main.rex"
     5 *-* n = 100.45 if datatype( n, wholenumber ) then 
+++ Interactive trace. "Trace Off" to end debug, ENTER to Continue. +++
     6 *-* signal msg 
    10 *-* msg :
    10 *-* say 'This is an incorrect number'