Rexx - डिबगिंग

डिबगिंग किसी भी प्रोग्रामिंग भाषा में एक महत्वपूर्ण विशेषता है। यह डेवलपर को त्रुटियों का निदान करने, मूल कारण खोजने और फिर उनके अनुसार समाधान करने में मदद करता है। Rexx में, डीबगिंग के लिए ट्रेस सुविधा का उपयोग किया जाता है। ट्रेस निर्देश को 2 तरीकों से लागू किया जा सकता है, एक है बैच मोड और दूसरा इंटरेक्टिव मोड। आइए देखें कि दोनों विकल्पों को कैसे लागू किया जाए।

बैच मोड में ट्रेस

ट्रेस कमांड का उपयोग प्रत्येक Rexx कमांड का एक विस्तृत स्तर देने के लिए किया जाता है जिसे निष्पादित किया जाता है।

ट्रेस स्टेटमेंट का सामान्य सिंटैक्स निम्नानुसार दिखाया गया है -

वाक्य - विन्यास

trace [setting]

जहाँ सेटिंग निम्नलिखित विकल्पों में से किसी की भी हो सकती है -

  • A - सभी आदेशों का पता लगाता है।

  • C - केवल होस्ट कमांड का पता लगाता है जो ऑपरेटिंग सिस्टम पर भेजे जाते हैं।

  • E - केवल उन होस्ट कमांड को ट्रेस करता है जो ऑपरेटिंग सिस्टम को भेजी जाती हैं जिसके परिणामस्वरूप त्रुटि हुई है।

  • F - केवल होस्ट कमांड का पता लगाता है जो ऑपरेटिंग सिस्टम को भेजे जाते हैं जिसके परिणामस्वरूप विफलता हुई है।

  • I - यह Rexx कमांड्स का इंटरमीडिएट लेवल ट्रेसिंग प्रदान करता है।

  • L - यह विकल्प है यदि आप अनुरेखण लेबल करना चाहते हैं जैसा कि होता है।

  • N - यह डिफ़ॉल्ट विकल्प है जिसमें कोई भी ट्रेसिंग नहीं होती है।

आइए ट्रेस कमांड के एक उदाहरण पर एक नज़र डालें।

उदाहरण

/* 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 '

उपरोक्त कार्यक्रम का आउटपुट निम्नानुसार होगा -

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

आउटपुट से, आप देख सकते हैं कि प्रोग्राम के आउटपुट में एक अतिरिक्त ट्रेस जोड़ा गया था। आउटपुट के बारे में निम्नलिखित बातों पर ध्यान दिया जा सकता है -

  • निष्पादित स्टेटमेंट के साथ लाइन नंबर ट्रेस आउटपुट में जोड़ा जाता है।

  • निष्पादित होने वाली प्रत्येक पंक्ति को ट्रेस आउटपुट में दिखाया गया है।

ट्रेस फंक्शन

ट्रेस फ़ंक्शन की मदद से ट्रेस को भी सक्षम किया जा सकता है। सामान्य सिंटैक्स और उदाहरण नीचे दिखाया गया है।

वाक्य - विन्यास

trace()

उपरोक्त फ़ंक्शन वर्तमान ट्रेस स्तर देता है।

मापदंडों

कोई नहीं

प्रतिलाभ की मात्रा

उपरोक्त फ़ंक्शन वर्तमान ट्रेस स्तर देता है।

उदाहरण

/* 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 '

उपरोक्त कार्यक्रम का आउटपुट निम्नानुसार होगा।

N 
This is an incorrect number

एन की पहली पंक्ति दर्शाती है कि ट्रेस सामान्य पर सेट है।

ट्रेस मान सेट करना

ट्रेस स्तर को ट्रेस फ़ंक्शन के साथ सेट किया जा सकता है। सामान्य सिंटैक्स और उदाहरण नीचे दिखाया गया है।

वाक्य - विन्यास

trace(travel_level)

मापदंडों

  • trace_level - यह ट्रेस स्तर सेट करने के लिए उपलब्ध विकल्पों के समान है।

प्रतिलाभ की मात्रा

उपरोक्त फ़ंक्शन वर्तमान ट्रेस स्तर देता है।

उदाहरण

/* 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 '

उपरोक्त कार्यक्रम का आउटपुट निम्नानुसार होगा -

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'

इंटरएक्टिव ट्रेसिंग

इंटरएक्टिव ट्रेसिंग जिसमें, ट्रेसिंग को प्रोग्राम रन के रूप में किया जाता है। ठीक उसी तरह जैसे आईडीई में .Net के लिए विजुअल स्टूडियो, जिसमें आप ब्रेकप्वाइंट जोड़ सकते हैं और देख सकते हैं कि प्रत्येक स्टेटमेंट कैसे निष्पादित होता है, इसी तरह यहां भी आप प्रोग्राम को प्रत्येक कोड लाइन के रूप में देख सकते हैं।

सामान्य वाक्य विन्यास इस प्रकार है -

वाक्य - विन्यास

trace ?options

जहां, विकल्प ट्रेस कमांड के लिए समान हैं जैसा कि नीचे दिखाया गया है।

  • A - सभी आदेशों का पता लगाता है

  • C - केवल होस्ट कमांड का पता लगाता है जो ऑपरेटिंग सिस्टम पर भेजे जाते हैं।

  • E - केवल उन होस्ट कमांड को ट्रेस करता है जो ऑपरेटिंग सिस्टम को भेजी जाती हैं जिसके परिणामस्वरूप त्रुटि हुई है।

  • F - केवल होस्ट कमांड का पता लगाता है जो ऑपरेटिंग सिस्टम को भेजे जाते हैं जिसके परिणामस्वरूप विफलता हुई है।

  • I - यह Rexx कमांड्स का इंटरमीडिएट लेवल ट्रेसिंग प्रदान करता है।

  • L - यह विकल्प है यदि आप अनुरेखण लेबल करना चाहते हैं जैसा कि होता है।

  • N - यह डिफ़ॉल्ट विकल्प है जिसमें कोई भी ट्रेसिंग नहीं होती है।

आइए सक्रिय अनुरेखण को लागू करने के एक उदाहरण पर एक नज़र डालें।

उदाहरण

/* 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'

उपरोक्त कार्यक्रम का आउटपुट निम्न कार्यक्रम में दिखाया जाएगा। ट्रेस कोड की प्रत्येक पंक्ति पर रुक जाएगा; फिर आपको कोड की अगली पंक्ति में जाने के लिए Enter बटन दबाना होगा।

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'