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'