बैश उपनाम - वरीयता/छायांकन (/छिपाना/असफल होना)
मेरे पास .bashrc में कुछ उपनाम सेटअप हैं (इस क्रम में):
alias ls="lsc"
alias lsc='ls -Flatr --color=always'
alias lscR='ls -FlatrR --color=always'
alias
सोर्सिंग के बाद उनकी पुष्टि करना :
alias ls='lsc'
alias lsc='ls -Flatr --color=always'
alias lscR='ls -FlatrR --color=always'
मैं नए ls
अलियास को ठीक से चला सकता हूं, और यह lsc उपनाम के माध्यम से जंजीर करता है, और फिर lsc उपनाम से जुड़े कमांड को निष्पादित करता है। मैं दौड़ भी सकता हूं lscR
और यह उम्मीद के मुताबिक काम करता है।
अगर मैं lsc
खुद को चलाने की कोशिश करता हूं, तो मुझे मिलता है:
$ lsc
lsc: command not found
किसी भी विचार से शेल इस परिदृश्य में lsc उपनाम को छायांकन/छुपाता हुआ क्यों प्रतीत होता है? (मुझे एहसास है कि 'एलएससी' चलाने के लिए यह व्यर्थ है जब मैं यहां एक ही परिणाम प्राप्त करने के लिए 'एलएस' चला सकता हूं, लेकिन मैं इस परिदृश्य में गोले व्यवहार को समझने की कोशिश कर रहा हूं)।
संपादित करें: प्रश्न उत्तर में प्रदान किए गए (बैश) शेल व्यवहार के लिए नीचे दिए गए समाधान।
मूल प्रश्न के कुछ वास्तव में सहायक उत्तर प्रदान किए गए हैं। उत्तरों में बताए गए विस्तार व्यवहार को शॉर्ट-सर्किट करने के लिए, दूसरे उपनाम को रोकने के कम से कम दो तरीके प्रतीत होते हैं, एक कमांड का विस्तार करने की कोशिश करने से जिसे आपने पहले ही अलियास कर दिया है। उदाहरण के लिए, यदि आपके पास , alias cmd='cmd --stuff'
नामक नेटिव कमांड को ओवरराइड कर रहा है , तो cmd
आप 'cmd' एलियास को cmd
अन्य एलियासेस में नेटिव के स्थान पर इस्तेमाल होने से रोक सकते हैं:
(इस पहले दृष्टिकोण के लिए wjandrea की टिप्पणी के लिए धन्यवाद)
cmd
अन्य उपनाम जैसे 'कमांड' के साथ उपसर्ग करनाalias other-cmd-alias='command cmd --other-stuff'
या,
- इसी तरह, आप उपनामों से बच सकते हैं (जैसा कि आप कमांड लाइन पर भी कर सकते हैं), अन्य उपनामों के भीतर एक बैकस्लैश '' के साथ उपसर्ग करके, उदाहरण के लिए
alias other-cmd-alias='\cmd --other-stuff'
।
जवाब
बैश उपनामों को उपनाम रखने की अनुमति देता है लेकिन इसमें अनंत लूप के खिलाफ अंतर्निहित सुरक्षा है। आपके मामले में, जब आप टाइप करते हैं , तो lsc
बैश पहले उपनाम का विस्तार करता है:
ls -Flatr --color=always
चूँकि ls
एक अन्य नाम भी है, बैश इसका विस्तार करता है:
lsc -Flatr --color=always
lsc
एक उपनाम है लेकिन, काफी समझदारी से, बैश इसे दूसरी बार विस्तारित करने से मना कर देता है । अगर नाम का कोई प्रोग्राम lsc
होता, तो बैश उसे चला देता। लेकिन, ऐसा नहीं है और इसीलिए आपको मिलता है command not found
।
परिशिष्ट
जब lscR
चलता है तो अलग होता है। lscR
इसका विस्तार होता है:
ls -FlatrR --color=always
चूँकि ls
एक उपनाम है, यह इस तक विस्तृत है:
lsc -FlatrR --color=always
चूँकि lsc
एक उपनाम है, यह इस तक विस्तृत है:
ls -Flatr --color=always -FlatrR --color=always
चूंकि पहले ही एक बार विस्तार किया जा चुका है, बैश इसे दूसरी बारls
विस्तारित करने से मना कर देता है । चूंकि एक वास्तविक आदेश मौजूद है, इसे चलाया जाता है।ls
इतिहास
जैसा कि टिप्पणियों में शिली ने उल्लेख किया है, बैश ने ksh से दूसरी बार उपनाम का विस्तार नहीं करने की अवधारणा उधार ली है ।
अलग
उपनाम उपयोगी हैं लेकिन बहुत शक्तिशाली नहीं हैं। यदि आप एक उपनाम के साथ कुछ जटिल करने के लिए ललचाते हैं, जैसे कि तर्क प्रतिस्थापन, नहीं; इसके बजाय शेल फ़ंक्शन का उपयोग करें।
बैश मैनुअल से :
प्रतिस्थापन पाठ का पहला शब्द उपनामों के लिए परीक्षण किया गया है, लेकिन एक शब्द जो एक उपनाम के समान है, का विस्तार दूसरी बार नहीं किया गया है। इसका मतलब यह है कि कोई व्यक्ति
ls
"ls -F
" के लिए उपनाम कर सकता है, उदाहरण के लिए, और बैश प्रतिस्थापन पाठ को पुनरावर्ती रूप से विस्तारित करने का प्रयास नहीं करता है।
ls
एलियास में, को और फिर से तक ls
विस्तारित किया जाता है , और वहाँ अलियास विस्तार बंद हो जाता है, क्योंकि मूल रूप से इसका विस्तार किया जा रहा था। तो, आदेश ठीक चलता है, अब बाहरी कमांड को हल किया जा रहा है।lsc
ls -Flatr --color=always
ls
ls
lsc
उपनाम में, तक lsc
विस्तारित किया जाता है ls -Flatr --color=always
, और उसके बाद ls
अब विस्तारित किया जाता है lsc
और वहां उपनाम विस्तार बंद हो जाता है, क्योंकि lsc
मूल रूप से विस्तारित किया जा रहा था। इसलिए, आदेश विफल हो जाता है, क्योंकि बैश किसी अन्य के बारे में नहीं जानता है lsc
।