यह बहुत कुछ इस बात पर निर्भर करता है कि आप "रिवर्ट" से क्या मतलब है।
अस्थायी रूप से एक अलग प्रतिबद्ध पर स्विच करें
यदि आप अस्थायी रूप से इसे वापस जाना चाहते हैं, तो चारों ओर बेवकूफ बनाएं, फिर आप जहां हैं वहां वापस आएं, आपको बस इतना करना है कि वांछित कमिटमेंट देखें:
# This will detach your HEAD, that is, leave you with no branch checked out:
git checkout 0d1d7fc32
या यदि आप वहां रहते हुए कमिट करना चाहते हैं, तो आगे बढ़ें और जब आप उस पर हों तो एक नई शाखा बनाएं:
git checkout -b old-state 0d1d7fc32
जहां आप थे, वहां वापस जाने के लिए, बस उस शाखा की जांच करें, जिस पर आप फिर से थे। (यदि आपने परिवर्तन किए हैं, तो हमेशा जब शाखाओं को स्विच करते हैं, तो आपको उनके साथ उचित व्यवहार करना होगा। आप उन्हें फेंकने के लिए रीसेट कर सकते हैं; आप उन्हें अपने साथ ले जाने के लिए स्टेश, चेकआउट, स्टैश पॉप कर सकते हैं; आप प्रतिबद्ध कर सकते हैं। यदि आप वहां एक शाखा चाहते हैं तो उन्हें एक शाखा में भेज दें।)
अप्रकाशित कमिट हटाएं
यदि, दूसरी ओर, आप वास्तव में अपने द्वारा किए गए हर चीज से छुटकारा पाना चाहते हैं, तो दो संभावनाएं हैं। एक, यदि आपने इनमें से कोई भी कमिट प्रकाशित नहीं किया है, तो बस रीसेट करें:
# This will destroy any local modifications.
# Don't do it if you have uncommitted work you want to keep.
git reset --hard 0d1d7fc32
# Alternatively, if there's work to keep:
git stash
git reset --hard 0d1d7fc32
git stash pop
# This saves the modifications, then reapplies that patch after resetting.
# You could get merge conflicts, if you've modified things which were
# changed since the commit you reset to.
यदि आप गड़बड़ करते हैं, तो आप पहले से ही अपने स्थानीय परिवर्तनों को दूर फेंक चुके हैं, लेकिन आप कम से कम वापस उसी स्थान पर पहुंच सकते हैं जहां आप फिर से रीसेट करने से पहले थे।
पूर्व में प्रकाशित किए गए नए कमिट के साथ शुरू होते हैं
दूसरी ओर, यदि आपने काम प्रकाशित किया है, तो आप शायद शाखा को रीसेट नहीं करना चाहते हैं, क्योंकि यह इतिहास को प्रभावी ढंग से लिख रहा है। उस स्थिति में, आप वास्तव में कमिट्स को वापस ला सकते हैं। गिट के साथ, रिवर्ट का एक बहुत विशिष्ट अर्थ है: इसे रद्द करने के लिए रिवर्स पैच के साथ एक कमिट बनाएं। इस तरह आप किसी भी इतिहास को दोबारा नहीं लिखते हैं।
# This will create three separate revert commits:
git revert a867b4af 25eee4ca 0766c053
# It also takes ranges. This will revert the last two commits:
git revert HEAD~2..HEAD
#Similarly, you can revert a range of commits using commit hashes:
git revert a867b4af..0766c053
# Reverting a merge commit
git revert -m 1 <merge_commit_sha>
# To get just one, you could use `rebase -i` to squash them afterwards
# Or, you could do it manually (be sure to do this at top level of the repo)
# get your index and work tree into the desired state, without changing HEAD:
git checkout 0d1d7fc32 .
# Then commit. Be sure and write a good message describing what you just did
git commit
git-revert
मैनपेज वास्तव में इसके विवरण में इस का एक बहुत शामिल हैं। एक और उपयोगी लिंक यह git-scm.com अनुभाग है जो git-revert पर चर्चा कर रहा है ।
यदि आप तय करते हैं कि आप सब के बाद वापस नहीं करना चाहते हैं, तो आप रिवर्ट को वापस कर सकते हैं (जैसा कि यहां वर्णित है) या रिवर्ट से पहले वापस रीसेट करें (पिछला अनुभाग देखें)।
आपको यह उत्तर इस मामले में मददगार भी लग सकता है:
HEAD को पिछले स्थान पर वापस कैसे ले जाना है? (अलग किया गया सिर)