प्लेन ओल्ड डॉक्यूमेंटेशन: Difference between revisions

From Vigyanwiki
No edit summary
 
(6 intermediate revisions by 4 users not shown)
Line 6: Line 6:
* विश्लेषण करना आसान
* विश्लेषण करना आसान
* [[XML|एक्सएमएल]], [[TeX|टीईएक्स]] या [[Markdown|मार्कडाउन]] जैसे अन्य प्रारूपों में परिवर्तित करना आसान है
* [[XML|एक्सएमएल]], [[TeX|टीईएक्स]] या [[Markdown|मार्कडाउन]] जैसे अन्य प्रारूपों में परिवर्तित करना आसान है
* नमूना कोड सम्मिलित करना आसान है
* सैंपल कोड सम्मिलित करना आसान है
* पॉड फ़ॉर्मेटर के बिना पढ़ना आसान है (अर्थात इसके स्रोत-कोड रूप में)
* पॉड फ़ॉर्मेटर के बिना पढ़ना आसान है (अर्थात इसके स्रोत-कोड रूप में)
* लिखना आसान है
* लिखना आसान है
Line 12: Line 12:
विशेष रूप से [[लैरी वॉल]], [[टॉम क्रिस्टियनसेन]] और जॉन ऑरवंत द्वारा [[प्रोग्रामिंग पर्ल|''प्रोग्रामिंग पर्ल'']] पॉड का विस्तारित संस्करण जो स्यूडोपीओडी नामक तालिकाओं और फ़ुटनोट्स का समर्थन करता है, का उपयोग ओ'रेली एंड एसोसिएट्स द्वारा कई पर्ल पुस्तकों का उत्पादन करने के लिए किया गया है।
विशेष रूप से [[लैरी वॉल]], [[टॉम क्रिस्टियनसेन]] और जॉन ऑरवंत द्वारा [[प्रोग्रामिंग पर्ल|''प्रोग्रामिंग पर्ल'']] पॉड का विस्तारित संस्करण जो स्यूडोपीओडी नामक तालिकाओं और फ़ुटनोट्स का समर्थन करता है, का उपयोग ओ'रेली एंड एसोसिएट्स द्वारा कई पर्ल पुस्तकों का उत्पादन करने के लिए किया गया है।


पॉड [[मैनपेज]] लिखना आसान बनाता है, जो उपयोगकर्ता-उन्मुख डॉक्यूमेंट के लिए उपयुक्त है। इसके विपरीत, अन्य डॉक्यूमेंट प्रणालियाँ, जैसे कि पायथन की [[डॉकस्ट्रिंग]] या जावा की [[जावाडोक]], हालांकि उनका उपयोग उपयोगकर्ता डॉक्यूमेंटेशन के लिए किया जा सकता है, सॉफ़्टवेयर प्रोजेक्ट के लिए स्रोत कोड के बारे में डेवलपर-उन्मुख डॉक्यूमेंट तैयार करने की सुविधा के लिए डिज़ाइन की गई हैं।
पॉड [[मैनपेज]] लिखना आसान बनाता है, जो उपयोगकर्ता-उन्मुख डॉक्यूमेंट के लिए उपयुक्त है। इसके विपरीत, अन्य डॉक्यूमेंट प्रणालियाँ, जैसे कि पायथन की [[डॉकस्ट्रिंग]] या जावा की [[जावाडोक]], चूंकि उनका उपयोग उपयोगकर्ता डॉक्यूमेंटेशन के लिए किया जा सकता है, सॉफ़्टवेयर प्रोजेक्ट के लिए स्रोत कोड के बारे में डेवलपर-उन्मुख डॉक्यूमेंट तैयार करने की सुविधा के लिए डिज़ाइन की गई हैं।


==उपयोग==
==उपयोग==


पॉड पर्ल दुनिया में अधिकांश डॉक्यूमेंटेशन के लिए उपयोग की जाने वाली लैंग्वेज है। इसमें स्वयं पर्ल, लगभग सभी सार्वजनिक रूप से जारी [[पर्ल मॉड्यूल]], कई [[स्क्रिप्ट (कंप्यूटर प्रोग्रामिंग)]], अधिकांश डिज़ाइन डॉक्यूमेंट, [http://www.perl.com/ Perl.com] पर कई लेख और अन्य पर्ल-संबंधित वेब साइटें सम्मिलित हैं।
पॉड पर्ल दुनिया में अधिकांश डॉक्यूमेंटेशन के लिए उपयोग की जाने वाली लैंग्वेज है। इसमें स्वयं पर्ल, लगभग सभी सार्वजनिक रूप से जारी [[पर्ल मॉड्यूल]], कई [[स्क्रिप्ट (कंप्यूटर प्रोग्रामिंग)]], अधिकांश डिज़ाइन डॉक्यूमेंट, [http://www.perl.com/ Perl.com] पर कई लेख और अन्य पर्ल-संबंधित वेब साइटें और [[तोता आभासी मशीन|पैरेट वर्चुअल मशीन]] सम्मिलित हैं।
और [[तोता आभासी मशीन]]


पॉड को कच्चे रूप में शायद ही कभी पढ़ा जाता है, हालाँकि इसे फ़ॉर्मेटिंग टूल की सहायता के बिना पढ़ने योग्य बनाने के लिए डिज़ाइन किया गया है। इसके बजाय, इसे इसके साथ पढ़ा जाता है {{anchor|perldoc}}perldoc टूल, या यूनिक्स [[मैन पेज]] या वेब-मानक HTML पेज में परिवर्तित किया गया।
पॉड को अपरिष्कृत रूप में शायद ही कभी पढ़ा जाता है, हालाँकि इसे संरूपण उपकरण की सहायता के बिना पढ़ने योग्य बनाने के लिए डिज़ाइन किया गया है। इसके अतिरिक्त, इसे इसके साथ पढ़ा जाता है पेरलडॉ उपकरण, या यूनिक्स [[मैन पेज]] या वेब-मानक एचटीएमएल पेज में परिवर्तित किया गया।


पर्ल के अलावा अन्य संदर्भों में पॉड का उपयोग करना भी संभव है। उदाहरण के लिए, [[बैश (यूनिक्स शेल)]] में सरल डॉक्यूमेंट जोड़ना, जिसे बाद में आसानी से मैन पेजों में परिवर्तित किया जा सकता है।<ref name="pod_in_bash">[http://bahut.alma.ch/2007/08/embedding-documentation-in-shell-script_16.html एक शेल स्क्रिप्ट में POD दस्तावेज़ को एम्बेड करना] (10 जनवरी 2011 को पुनः प्राप्त)</ref> ऐसे उपयोग पॉड भाग को छिपाने के लिए लैंग्वेज-विशिष्ट हैक पर निर्भर करते हैं, जैसे (बैश में) लाइन के साथ POD अनुभाग को उपसर्ग करना <code>:<<=cut</code> जो बैश के [[क्लोज़ अप]] को कॉल करके काम करता है <code>:</code> कमांड, पॉड के पूरे ब्लॉक को यहां डॉक्यूमेंट के रूप में इनपुट के रूप में।
पर्ल के अतिरिक्त अन्य संदर्भों में पॉड का उपयोग करना भी संभव है। उदाहरण के लिए, [[बैश (यूनिक्स शेल)]] में सरल डॉक्यूमेंट जोड़ना, जिसे बाद में आसानी से मैन पेजों में परिवर्तित किया जा सकता है।<ref name="pod_in_bash">[http://bahut.alma.ch/2007/08/embedding-documentation-in-shell-script_16.html एक शेल स्क्रिप्ट में POD दस्तावेज़ को एम्बेड करना] (10 जनवरी 2011 को पुनः प्राप्त)</ref> ऐसे उपयोग पॉड भाग को छिपाने के लिए लैंग्वेज-विशिष्ट हैक पर निर्भर करते हैं, जैसे (बैश में) लाइन के साथ पॉड अनुभाग को उपसर्ग करना <code>:<<=cut</code>जो पूरे ब्लॉक के साथ बैश के [[क्लोज़ अप|नो-ऑप]] <code>:</code> कमांड को कॉल करके काम करता है पॉड को यहां एक डॉक्यूमेंट के रूप में इनपुट के रूप में देखें।


शुद्ध पॉड फ़ाइलों में आमतौर पर एक्सटेंशन होता है <code>.pod</code>, लेकिन पॉड का उपयोग ज्यादातर सीधे पर्ल में किया जाता है
शुद्ध पॉड फ़ाइलों में सामान्यतः एक्सटेंशन <code>.पॉड</code> होता है, लेकिन पॉड का उपयोग ज्यादातर सीधे पर्ल कोड में किया जाता है, जो सामान्यतः <code>.pl</code> और <code>.pm</code> एक्सटेंशन का उपयोग करता है। (पर्ल [[दुभाषिया (कंप्यूटिंग)]] के [[पार्सर|पद निरूपण]] को पर्ल कोड में पॉड को अनदेखा करने के लिए डिज़ाइन किया गया है।) स्रोत कोड फ़ाइलों में, डॉक्यूमेंटेशन को आम तौर <code>__END__</code> मार्कर के बाद रखा जाता है (जो इसे टिप्पणियों के रूप में प्रदर्शित करने के लिए कुछ संपादकों में [[ वाक्य - विन्यास पर प्रकाश डालना |सिंटैक्स हाइलाइटिंग]] में भी मदद करता है)।
कोड, जो आम तौर पर उपयोग करता है <code>.pl</code> और <code>.pm</code> एक्सटेंशन. (पर्ल
[[दुभाषिया (कंप्यूटिंग)]] के [[पार्सर]] को पर्ल कोड में पॉड को अनदेखा करने के लिए डिज़ाइन किया गया है।) स्रोत कोड फ़ाइलों में, डॉक्यूमेंटेशन को आम तौर पर के बाद रखा जाता है <code>__END__</code> मार्कर (जो कुछ संपादकों में [[ वाक्य - विन्यास पर प्रकाश डालना ]] को टिप्पणियों के रूप में प्रदर्शित करने में भी मदद करता है)।


पॉड को आसानी से अन्य प्रारूपों में परिवर्तित किया जा सकता है, उदाहरण के लिए कुछ विभिन्न [[ एक सप्ताह ]] प्रारूप जैसे: [[विकिविकिवेब]], [[ किसलिए ]], [[ट्विकी]], [[आप मॉडविकी पर हैं]], [[टिडलीविकी]], टेक्सटाइल (मार्कअप लैंग्वेज), [[मीडियाविकि]], [[ मोइन मोइन ]] या [[संगम हे]], पॉड::सिंपल::विकी का उपयोग करके।
पॉड को आसानी से अन्य प्रारूपों में परिवर्तित किया जा सकता है, उदाहरण के लिए कुछ विभिन्न[[ एक सप्ताह | विकी]] प्रारूप जैसे: [[विकिविकिवेब]], [[ किसलिए |क्विकी]], [[ट्विकी]], [[आप मॉडविकी पर हैं|यूजमोडविकी]], [[टिडलीविकी]], टेक्सटाइल (मार्कअप लैंग्वेज), [[मीडियाविकि]], [[ मोइन मोइन |मोइन मोइन]] या कॉन्फ्लुएंस, पॉड::सिंपल::विकी का उपयोग करके किया जा सकता है।


==उदाहरण==
==उदाहरण==
Line 85: Line 82:
==स्वरूपण विवरण==
==स्वरूपण विवरण==


पॉड फ़ाइलें [[ASCII]]-संगत [[ अक्षरों को सांकेतिक अक्षरों में बदलना ]] में लिखी जाती हैं, जैसे [[लैटिन -1]] या [[UTF-8]]। एक पॉड पार्सर हमेशा मानता है कि जिस फ़ाइल को वह विश्लेषण कर रहा है वह पॉड से शुरू नहीं होती है; यह सभी पंक्तियों को अनदेखा करता है
पॉड फ़ाइलें [[ASCII|आस्की]]-संगत [[ अक्षरों को सांकेतिक अक्षरों में बदलना |अक्षर कोडन]] में लिखी जाती हैं, जैसे [[लैटिन -1]] या [[UTF-8|यूटीएफ-8]]। एक पॉड पद निरूपण हमेशा मानता है कि जिस फ़ाइल को वह विश्लेषण कर रहा है वह पॉड से प्रारंभ नहीं होती है; यह सभी पंक्तियों को अनदेखा करता है जब तक यह पॉड निर्देश नहीं देखता। पॉड निर्देश पंक्ति की प्रारंभ में आने चाहिए, और सभी एक समान चिह्न से प्रारंभ होने चाहिए। पॉड पद निरूपण तब मान लेगा कि निम्नलिखित सभी पंक्तियाँ पॉड हैं, जब तक कि उसे "= कट" निर्देश वाली पंक्ति का सामना न करना पड़े। इसके बाद की किसी भी सामग्री को तब तक नजरअंदाज कर दिया जाता है जब तक पद निरूपण को किसी अन्य पॉड निर्देश का सामना नहीं करना पड़ता। इस प्रकार, पॉड को निष्पादन योग्य स्रोत कोड के साथ अन्तर्मिश्र किया जा सकता है यदि लैंग्वेज का पद निरूपण पॉड को पहचानना और अनदेखा करना जानता है।
जब तक यह एक पॉड निर्देश नहीं देखता। पॉड निर्देश एक पंक्ति की शुरुआत में आने चाहिए, और सभी एक समान चिह्न से शुरू होने चाहिए। पॉड पार्सर तब मान लेगा कि निम्नलिखित सभी पंक्तियाँ पॉड हैं, जब तक कि उसे = कट निर्देश वाली एक पंक्ति का सामना न करना पड़े। इसके बाद की किसी भी सामग्री को तब तक नजरअंदाज कर दिया जाता है जब तक पार्सर को किसी अन्य पॉड निर्देश का सामना नहीं करना पड़ता। इस प्रकार, पॉड को निष्पादन योग्य स्रोत कोड के साथ इंटरमिक्स किया जा सकता है यदि लैंग्वेज का पार्सर पॉड को पहचानना और अनदेखा करना जानता है।


पॉड सामग्री को खाली पंक्तियों द्वारा पैराग्राफ में विभाजित किया गया है। जो पैराग्राफ [[ व्हाईटस्पेस वर्ण ]] कैरेक्टर्स-टैब या स्पेस-से शुरू होते हैं, उन्हें शब्दशः पैराग्राफ माना जाता है, और उन्हें पूरी तरह से बिना स्वरूपित छोड़ दिया जाता है; इनका उपयोग नमूना कोड, ASCII कला आदि के लिए किया जाता है। जो पैराग्राफ समान चिह्न से शुरू होते हैं वे कमांड पैराग्राफ होते हैं; समान चिह्न के तुरंत बाद अल्फ़ान्यूमेरिक वर्णों के अनुक्रम को पॉड निर्देश के रूप में माना जाता है, और शेष पैराग्राफ को उस निर्देश के अनुसार स्वरूपित किया जाता है। कुछ निर्देश निम्नलिखित अनुच्छेदों को भी प्रभावित करते हैं। यदि कोई पैराग्राफ किसी समान चिह्न या रिक्त स्थान के अलावा किसी अन्य चीज़ से शुरू होता है, तो इसे एक सामान्य पैराग्राफ माना जाता है।
पॉड सामग्री को खाली पंक्तियों द्वारा '''पैराग्राफ''' में विभाजित किया गया है। जो पैराग्राफ [[ व्हाईटस्पेस वर्ण | व्हाईटस्पेस वर्ण]] कैरेक्टर्स-टैब या स्पेस-से प्रारंभ होते हैं, उन्हें शब्दशः पैराग्राफ माना जाता है, और उन्हें पूरी तरह से बिना स्वरूपित छोड़ दिया जाता है; इनका उपयोग सैंपल कोड, आस्की कला आदि के लिए किया जाता है। जो पैराग्राफ समान चिह्न से प्रारंभ होते हैं वे "कमांड पैराग्राफ" होते हैं; समान चिह्न के तुरंत बाद वर्णांक वर्णों के अनुक्रम को पॉड निर्देश के रूप में माना जाता है, और शेष पैराग्राफ को उस निर्देश के अनुसार स्वरूपित किया जाता है। कुछ निर्देश निम्नलिखित अनुच्छेदों को भी प्रभावित करते हैं। यदि कोई पैराग्राफ किसी समान चिह्न या रिक्त स्थान के अतिरिक्त किसी अन्य चीज़ से प्रारंभ होता है, तो इसे सामान्य पैराग्राफ माना जाता है।


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


* एक एकल अपरकेस अक्षर, उसके बाद कम-से-चिह्न (<), स्वरूपित की जाने वाली सामग्री, और एक बड़े-से-अधिक चिह्न (>), उदाहरण के लिए। <code>B<bolded text></code>, या
* एकल अपरकेस अक्षर, उसके बाद कम-से-चिह्न (<), स्वरूपित की जाने वाली सामग्री, और एक बड़े-से-अधिक चिह्न (>), उदाहरण के लिए <code>B<bolded text></code>, ''या''
* एक एकल अपरकेस अक्षर, दो या दो से अधिक कम-से-चिह्न (<<), एक स्थान, स्वरूपित की जाने वाली सामग्री, एक अन्य स्थान, और पहले इस्तेमाल किए गए समान संख्या में बड़े-से-अधिक संकेत, उदाहरण के लिए। <code>B<< bolded text >></code>. इस फॉर्म का उपयोग अक्सर उन कोड स्निपेट्स के लिए किया जाता है जिनमें ग्रेटर-दैन चिह्न होता है, जो अन्यथा फ़ॉर्मेटिंग कोड को समाप्त कर देगा।
* एकल अपरकेस अक्षर, दो या दो से अधिक कम-से-चिह्न (<<), स्थान, स्वरूपित की जाने वाली सामग्री, अन्य स्थान, और पहले उपयोग किए गए समान संख्या में बड़े-से-अधिक संकेत, उदाहरण के लिए <code>B<< bolded text >>,</code> इस फॉर्म का उपयोग अधिकांशतः उन कोड स्निपेट्स के लिए किया जाता है जिनमें ग्रेटर-दैन चिह्न होता है, जो अन्यथा संरूपण कोड को समाप्त कर देगा।


पॉड में कमांड में शीर्षकों के चार स्तर, बुलेटेड और क्रमांकित सूचियां, और अनुभागों को किसी अन्य लैंग्वेज में चिह्नित करने के कमांड सम्मिलित हैं। बाद वाली सुविधा इसका समर्थन करने वाले पार्सर्स को विशेष स्वरूपण देने की अनुमति देती है।
पॉड में कमांड में शीर्षकों के चार स्तर, बुलेटेड और क्रमांकित सूचियां, और अनुभागों को किसी अन्य लैंग्वेज में चिह्नित करने के कमांड सम्मिलित हैं। बाद वाली सुविधा इसका समर्थन करने वाले पार्सर्स को विशेष स्वरूपण देने की अनुमति देती है।
Line 102: Line 98:
==संदर्भ==
==संदर्भ==
* Wall, Larry; Christiansen, Tom; & Orwant, Jon (2000). ''[[Programming Perl]]'' (3rd ed.). Sebastopol: O'Reilly & Associates. {{ISBN|0-596-00027-8}}.
* Wall, Larry; Christiansen, Tom; & Orwant, Jon (2000). ''[[Programming Perl]]'' (3rd ed.). Sebastopol: O'Reilly & Associates. {{ISBN|0-596-00027-8}}.
* Chapter 15, "Working with Pod", in [[brian d foy|foy, brian d]] (2007). ''[[Mastering Perl]]''. Sebastopol: [[O'Reilly Media]]. {{ISBN|0-596-52724-1}}.
* Chapter 15, "Working with पॉड", in [[brian d foy|foy, brian d]] (2007). ''[[Mastering Perl]]''. Sebastopol: [[O'Reilly Media]]. {{ISBN|0-596-52724-1}}.
* Section 5.2, "Embedding Documentation in Shell Scripts", in Albing, Carl; Vossen, JP; & Cameron Newham. (2007). ''bash Cookbook: Solutions and Examples for bash Users''; O'Reilly & Associates. {{ISBN|0-596-52678-4}}.
* Section 5.2, "Embedding Documentation in Shell Scripts", in Albing, Carl; Vossen, JP; & Cameron Newham. (2007). ''bash Cookbook: Solutions and Examples for bash Users''; O'Reilly & Associates. {{ISBN|0-596-52678-4}}.
{{Reflist}}
{{Reflist}}
==बाहरी संबंध==
==बाहरी संबंध==
* [http://perldoc.perl.org/perlpod.html perlpod (documentation on pod for people writing documents in it)]
* [http://perldoc.perl.org/perlpod.html perlpod (documentation on पॉड for people writing documents in it)]
* [http://perldoc.perl.org/perlpodspec.html perlpodspec (documentation on pod for people writing parsers for it)]
* [http://perldoc.perl.org/perlpodspec.html perlpodspec (documentation on पॉड for people writing parsers for it)]
* [https://metacpan.org/source/RJBS/perl-5.18.1/pod The Perl manpages in raw pod format]
* [https://metacpan.org/source/RJBS/perl-5.18.1/pod The Perl manpages in raw पॉड format]
* [ftp://ftp.ora.com/pub/labs/pseudopod.html (PseudoPOD)]
* [ftp://ftp.ora.com/pub/labs/pseudopod.html (PseudoPOD)]
* [https://metacpan.org/source/RJBS/perl-5.18.1/lib The directory contains many modules with embedded pod formatting]
* [https://metacpan.org/source/RJBS/perl-5.18.1/lib The directory contains many modules with embedded पॉड formatting]
* The [https://metacpan.org/module/Getopt::Euclid Getopt::Euclid module] parses input to a Perl script automatically based on pod tags
* The [https://metacpan.org/module/Getopt::Euclid Getopt::Euclid module] parses input to a Perl script automatically based on पॉड tags
* The [https://metacpan.org/module/Pod::Simple::Wiki Pod::Simple::Wiki] converts pod into various [[Wiki]] formats
* The [https://metacpan.org/module/Pod::Simple::Wiki पॉड::Simple::Wiki] converts पॉड into various [[Wiki]] formats
* The [https://metacpan.org/pod/Pod::Markdown Pod::मार्कडाउन] converts pod into [[Markdown|मार्कडाउन]]
* The [https://metacpan.org/pod/Pod::Markdown पॉड::मार्कडाउन] converts पॉड into [[Markdown|मार्कडाउन]]
 
{{Perl}}
{{Document markup languages}}
[[Category: मुफ़्त दस्तावेज़ीकरण जेनरेटर]] [[Category: हल्की मार्कअप भाषाएँ]] [[Category: पर्ल]]
 
 


[[Category: Machine Translated Page]]
[[Category:Created On 25/07/2023]]
[[Category:Created On 25/07/2023]]
[[Category:Lua-based templates]]
[[Category:Machine Translated Page]]
[[Category:Pages with script errors]]
[[Category:Short description with empty Wikidata description]]
[[Category:Templates Vigyan Ready]]
[[Category:Templates that add a tracking category]]
[[Category:Templates that generate short descriptions]]
[[Category:Templates using TemplateData]]
[[Category:पर्ल]]
[[Category:मुफ़्त दस्तावेज़ीकरण जेनरेटर]]
[[Category:हल्की मार्कअप भाषाएँ]]

Latest revision as of 18:00, 21 August 2023

प्लेन ओल्ड डॉक्यूमेंटेशन (पॉड) लाइटवेट मार्कअप लैंग्वेज है जिसका उपयोग पर्ल प्रोग्रामिंग लैंग्वेज के साथ-साथ पर्ल मॉड्यूल और प्रोग्राम को डॉक्यूमेंट (दस्तावेज) करने के लिए किया जाता है।

डिज़ाइन

पॉड को उपयोगी होने के लिए पर्याप्त वाक्यविन्यास के साथ सरल, क्लीन लैंग्वेज के रूप में डिज़ाइन किया गया है। इसमें उद्देश्यपूर्ण ढंग से फ़ॉन्ट, चित्र, रंग या तालिकाओं के लिए तंत्र सम्मिलित नहीं हैं। इसके कुछ लक्ष्य हैं:

  • विश्लेषण करना आसान
  • एक्सएमएल, टीईएक्स या मार्कडाउन जैसे अन्य प्रारूपों में परिवर्तित करना आसान है
  • सैंपल कोड सम्मिलित करना आसान है
  • पॉड फ़ॉर्मेटर के बिना पढ़ना आसान है (अर्थात इसके स्रोत-कोड रूप में)
  • लिखना आसान है

विशेष रूप से लैरी वॉल, टॉम क्रिस्टियनसेन और जॉन ऑरवंत द्वारा प्रोग्रामिंग पर्ल पॉड का विस्तारित संस्करण जो स्यूडोपीओडी नामक तालिकाओं और फ़ुटनोट्स का समर्थन करता है, का उपयोग ओ'रेली एंड एसोसिएट्स द्वारा कई पर्ल पुस्तकों का उत्पादन करने के लिए किया गया है।

पॉड मैनपेज लिखना आसान बनाता है, जो उपयोगकर्ता-उन्मुख डॉक्यूमेंट के लिए उपयुक्त है। इसके विपरीत, अन्य डॉक्यूमेंट प्रणालियाँ, जैसे कि पायथन की डॉकस्ट्रिंग या जावा की जावाडोक, चूंकि उनका उपयोग उपयोगकर्ता डॉक्यूमेंटेशन के लिए किया जा सकता है, सॉफ़्टवेयर प्रोजेक्ट के लिए स्रोत कोड के बारे में डेवलपर-उन्मुख डॉक्यूमेंट तैयार करने की सुविधा के लिए डिज़ाइन की गई हैं।

उपयोग

पॉड पर्ल दुनिया में अधिकांश डॉक्यूमेंटेशन के लिए उपयोग की जाने वाली लैंग्वेज है। इसमें स्वयं पर्ल, लगभग सभी सार्वजनिक रूप से जारी पर्ल मॉड्यूल, कई स्क्रिप्ट (कंप्यूटर प्रोग्रामिंग), अधिकांश डिज़ाइन डॉक्यूमेंट, Perl.com पर कई लेख और अन्य पर्ल-संबंधित वेब साइटें और पैरेट वर्चुअल मशीन सम्मिलित हैं।

पॉड को अपरिष्कृत रूप में शायद ही कभी पढ़ा जाता है, हालाँकि इसे संरूपण उपकरण की सहायता के बिना पढ़ने योग्य बनाने के लिए डिज़ाइन किया गया है। इसके अतिरिक्त, इसे इसके साथ पढ़ा जाता है पेरलडॉ उपकरण, या यूनिक्स मैन पेज या वेब-मानक एचटीएमएल पेज में परिवर्तित किया गया।

पर्ल के अतिरिक्त अन्य संदर्भों में पॉड का उपयोग करना भी संभव है। उदाहरण के लिए, बैश (यूनिक्स शेल) में सरल डॉक्यूमेंट जोड़ना, जिसे बाद में आसानी से मैन पेजों में परिवर्तित किया जा सकता है।[1] ऐसे उपयोग पॉड भाग को छिपाने के लिए लैंग्वेज-विशिष्ट हैक पर निर्भर करते हैं, जैसे (बैश में) लाइन के साथ पॉड अनुभाग को उपसर्ग करना :<<=cutजो पूरे ब्लॉक के साथ बैश के नो-ऑप : कमांड को कॉल करके काम करता है पॉड को यहां एक डॉक्यूमेंट के रूप में इनपुट के रूप में देखें।

शुद्ध पॉड फ़ाइलों में सामान्यतः एक्सटेंशन .पॉड होता है, लेकिन पॉड का उपयोग ज्यादातर सीधे पर्ल कोड में किया जाता है, जो सामान्यतः .pl और .pm एक्सटेंशन का उपयोग करता है। (पर्ल दुभाषिया (कंप्यूटिंग) के पद निरूपण को पर्ल कोड में पॉड को अनदेखा करने के लिए डिज़ाइन किया गया है।) स्रोत कोड फ़ाइलों में, डॉक्यूमेंटेशन को आम तौर __END__ मार्कर के बाद रखा जाता है (जो इसे टिप्पणियों के रूप में प्रदर्शित करने के लिए कुछ संपादकों में सिंटैक्स हाइलाइटिंग में भी मदद करता है)।

पॉड को आसानी से अन्य प्रारूपों में परिवर्तित किया जा सकता है, उदाहरण के लिए कुछ विभिन्न विकी प्रारूप जैसे: विकिविकिवेब, क्विकी, ट्विकी, यूजमोडविकी, टिडलीविकी, टेक्सटाइल (मार्कअप लैंग्वेज), मीडियाविकि, मोइन मोइन या कॉन्फ्लुएंस, पॉड::सिंपल::विकी का उपयोग करके किया जा सकता है।

उदाहरण

यह डॉक्यूमेंट वाक्यात्मक रूप से सही पॉड है, जो अनुभाग नामकरण पर प्रमुख परंपराओं का भी पालन करने का प्रयास करता है।[2]

Source code
=head1 NAME

My::Module - An example module

=head1 SYNOPSIS

    use My::Module;
    my $object = My::Module->new();
    print $object->as_string;

=head1 DESCRIPTION

This module does not really exist, it
was made for the sole purpose of
demonstrating how POD works.

=head2 Methods

=over 12

=item C<new>

Returns a new My::Module object.

=item C<as_string>

Returns a stringified representation of
the object. This is mainly for debugging
purposes.

=back

=head1 LICENSE

This is released under the Artistic 
License. See L<perlartistic>.

=head1 AUTHOR

Juerd - L<http://juerd.nl/>

=head1 SEE ALSO

L<perlpod>, L<perlpodspec>

=cut

स्वरूपण विवरण

पॉड फ़ाइलें आस्की-संगत अक्षर कोडन में लिखी जाती हैं, जैसे लैटिन -1 या यूटीएफ-8। एक पॉड पद निरूपण हमेशा मानता है कि जिस फ़ाइल को वह विश्लेषण कर रहा है वह पॉड से प्रारंभ नहीं होती है; यह सभी पंक्तियों को अनदेखा करता है जब तक यह पॉड निर्देश नहीं देखता। पॉड निर्देश पंक्ति की प्रारंभ में आने चाहिए, और सभी एक समान चिह्न से प्रारंभ होने चाहिए। पॉड पद निरूपण तब मान लेगा कि निम्नलिखित सभी पंक्तियाँ पॉड हैं, जब तक कि उसे "= कट" निर्देश वाली पंक्ति का सामना न करना पड़े। इसके बाद की किसी भी सामग्री को तब तक नजरअंदाज कर दिया जाता है जब तक पद निरूपण को किसी अन्य पॉड निर्देश का सामना नहीं करना पड़ता। इस प्रकार, पॉड को निष्पादन योग्य स्रोत कोड के साथ अन्तर्मिश्र किया जा सकता है यदि लैंग्वेज का पद निरूपण पॉड को पहचानना और अनदेखा करना जानता है।

पॉड सामग्री को खाली पंक्तियों द्वारा पैराग्राफ में विभाजित किया गया है। जो पैराग्राफ व्हाईटस्पेस वर्ण कैरेक्टर्स-टैब या स्पेस-से प्रारंभ होते हैं, उन्हें शब्दशः पैराग्राफ माना जाता है, और उन्हें पूरी तरह से बिना स्वरूपित छोड़ दिया जाता है; इनका उपयोग सैंपल कोड, आस्की कला आदि के लिए किया जाता है। जो पैराग्राफ समान चिह्न से प्रारंभ होते हैं वे "कमांड पैराग्राफ" होते हैं; समान चिह्न के तुरंत बाद वर्णांक वर्णों के अनुक्रम को पॉड निर्देश के रूप में माना जाता है, और शेष पैराग्राफ को उस निर्देश के अनुसार स्वरूपित किया जाता है। कुछ निर्देश निम्नलिखित अनुच्छेदों को भी प्रभावित करते हैं। यदि कोई पैराग्राफ किसी समान चिह्न या रिक्त स्थान के अतिरिक्त किसी अन्य चीज़ से प्रारंभ होता है, तो इसे सामान्य पैराग्राफ माना जाता है।

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

  • एकल अपरकेस अक्षर, उसके बाद कम-से-चिह्न (<), स्वरूपित की जाने वाली सामग्री, और एक बड़े-से-अधिक चिह्न (>), उदाहरण के लिए B<bolded text>, या
  • एकल अपरकेस अक्षर, दो या दो से अधिक कम-से-चिह्न (<<), स्थान, स्वरूपित की जाने वाली सामग्री, अन्य स्थान, और पहले उपयोग किए गए समान संख्या में बड़े-से-अधिक संकेत, उदाहरण के लिए B<< bolded text >>, इस फॉर्म का उपयोग अधिकांशतः उन कोड स्निपेट्स के लिए किया जाता है जिनमें ग्रेटर-दैन चिह्न होता है, जो अन्यथा संरूपण कोड को समाप्त कर देगा।

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

यह भी देखें

संदर्भ

  • Wall, Larry; Christiansen, Tom; & Orwant, Jon (2000). Programming Perl (3rd ed.). Sebastopol: O'Reilly & Associates. ISBN 0-596-00027-8.
  • Chapter 15, "Working with पॉड", in foy, brian d (2007). Mastering Perl. Sebastopol: O'Reilly Media. ISBN 0-596-52724-1.
  • Section 5.2, "Embedding Documentation in Shell Scripts", in Albing, Carl; Vossen, JP; & Cameron Newham. (2007). bash Cookbook: Solutions and Examples for bash Users; O'Reilly & Associates. ISBN 0-596-52678-4.

बाहरी संबंध