উত্তর:
আপনি 'আমাদের' মার্জ কৌশলটি ব্যবহার করতে পারেন:
$ git checkout staging
$ git merge -s ours email # Merge branches, but use our branch head
;
প্রতিটি কমান্ডের শেষে? আমি ছাড়া এটি করেছি ;
এবং এটি কাজ করে বলে মনে হচ্ছে। এছাড়াও এই উত্তরটি অসম্পূর্ণ, তৃতীয় ধাপটি হল পুরানো শাখা (ইমেল) চেকআউট এবং তারপরে আবার মঞ্চে মেশানো।
git rebase -s theirs <oldbranc> <newbranch>
পাশাপাশি কাজ করে (আপনি কোন শাখারই হন না)। মনে রাখবেন যে রিবেসে 'ওদের' আসলে নতুন ব্র্যাঞ্চ কারণ 'আমাদের' প্রধান হ'ল আমরা বর্তমানে চুক্তিগুলি প্রয়োগ করছি।
আপনি যদি কেবল দুটি শাখা 'ইমেল' এবং 'স্টেজিং' একই হতে চান তবে আপনি 'ইমেল' শাখা ট্যাগ করতে পারেন, তারপরে 'ইমেল' শাখাকে 'স্টেজেজিং'তে পুনরায় সেট করুন:
$ git checkout email
$ git tag old-email-branch
$ git reset --hard staging
আপনি 'ইমেল' শাখায় 'স্টেজিং' শাখাটিও পুনরায় চালু করতে পারেন। তবে ফলাফলটিতে দুটি শাখার সংশোধন থাকবে।
git checkout
, git check
আমার জ্ঞানের অস্তিত্ব নেই
email
শাখার মাথাটি কেবল একই মাথাটির দিকে নির্দেশ করা উচিত staging
এবং তাদের উভয়ের একই কমিট, একই ইতিহাস থাকবে।
আমি বেশ কয়েকটি উত্তর দেখেছি এবং এটাই একমাত্র প্রক্রিয়া যা আমাকে কোনও দ্বন্দ্ব ছাড়াই এটি ঠিক করতে দেয়।
আপনি যদি শাখা_লোক থেকে নতুন_আর সমস্ত পরিবর্তন চান, তবে:
git checkout branch_new
git merge -s ours branch_old
git checkout branch_old
git merge branch_new
একবারে এই চারটি কমান্ড প্রয়োগ করে আপনি কোনও সমস্যা ছাড়াই ব্রাঞ্চ_ল্ডকে চাপ দিতে পারেন can
অন্যান্য উত্তরগুলি আমাকে সঠিক সংকেত দিয়েছে, কিন্তু তারা সম্পূর্ণরূপে সহায়তা করে নি।
$ git checkout email
$ git tag old-email-branch # This is optional
$ git reset --hard staging
$
$ # Using a custom commit message for the merge below
$ git merge -m 'Merge -s our where _ours_ is the branch staging' -s ours origin/email
$ git push origin email
আমাদের কৌশলটির সাথে একত্রিত হওয়ার চতুর্থ পদক্ষেপ ব্যতীত, পুশটিকে একটি দ্রুত-অগ্রগতির আপডেট হিসাবে বিবেচনা করা হয় এবং এটি (গিটহাব দ্বারা) প্রত্যাখ্যাত হবে।
merge -m 'This is not my beautiful house.' -s ours origin/email
।
আপনি যদি আমার মতো হন এবং আপনি মার্জিংয়ের বিষয়ে ডিল করতে না চান, আপনি মার্জ করার পরিবর্তে বল প্রয়োগ ছাড়া উপরের পদক্ষেপগুলি করতে পারেন, কারণ এটি একটি বিভ্রান্তিকর লগ পেপার ট্রেইল তৈরি করবে:
git checkout email
git reset --hard staging
git push origin email --force
দ্রষ্টব্য: এটি কেবলমাত্র যদি আপনি সত্যিই আর কোনও ইমেইলে জিনিসটি দেখতে না চান is
আমি দুটি শাখা মার্জ করতে চেয়েছিলাম যাতে সমস্ত old_branch
বিষয়বস্তু থেকে সামগ্রীর সাথে আপডেট হওয়া যায়new_branch
আমার জন্য এটি একটি কবজির মতো কাজ করেছে:
$ git checkout new_branch
$ git merge -m 'merge message' -s ours origin/old_branch
$ git checkout old_branch
$ git merge new_branch
$ git push origin old_branch
কেমন:
git branch -D email
git checkout staging
git checkout -b email
git push origin email --force-with-lease
অন্যান্য উত্তরগুলি অসম্পূর্ণ দেখাচ্ছে।
আমি নীচে সম্পূর্ণ চেষ্টা করেছি, এবং এটি দুর্দান্ত কাজ করেছে।
দ্রষ্টব্য:
1. নিরাপদ দিকে থাকতে নীচে চেষ্টা করার আগে আপনার ভাণ্ডারটির একটি অনুলিপি তৈরি করুন।
বিবরণ:
১. সমস্ত বিকাশ দেব শাখায় ঘটে
q.কিউ শাখাটি দেবের একই কপি
৩ Time সময়ে সময়ে, দেব কোডটি QA শাখায় সরানো / ওভাররাইট করা দরকার
সুতরাং আমাদের ডিএ শাখা থেকে কিউ শাখাটি ওভাররাইট করা দরকার
পর্ব 1:
নীচের কমান্ডগুলির সাথে, পুরানো qa নতুন দেবকে আপডেট করা হয়েছে:
git checkout dev
git merge -s ours qa
git checkout qa
git merge dev
git push
শেষ ধাক্কার জন্য স্বয়ংক্রিয় মন্তব্য নীচে দেয়:
// Output:
// *<MYNAME> Merge branch 'qa' into dev,*
এই মন্তব্যটি বিপরীত দেখাচ্ছে, কারণ উপরের ক্রমটিও বিপরীত দেখায়
অংশ ২:
নীচে অপ্রত্যাশিত, নতুন স্থানীয় প্রতিশ্রুতিবদ্ধ হয়, অপ্রয়োজনীয়গুলি
তাই, আমাদের ফেলে দেওয়া উচিত, এবং দেবকে ছোঁয়াতে হবে।
git checkout dev
// Output:
// Switched to branch 'dev'
// Your branch is ahead of 'origin/dev' by 15 commits.
// (use "git push" to publish your local commits)
git reset --hard origin/dev
// Now we threw away the unexpected commits
পার্ট 3:
যা যা প্রত্যাশা করা হয়েছে তা যাচাই করুন:
git status
// Output:
// *On branch dev
// Your branch is up-to-date with 'origin/dev'.
// nothing to commit, working tree clean*
এখানেই শেষ.
1. পুরানো কএএ এখন নতুন দেব শাখা কোড দ্বারা ওভাররাইট করা হয়েছে
2. স্থানীয় পরিষ্কার (দূরবর্তী উত্স / দেব অনুচ্ছন্ন)
এটি করার সহজতম উপায়:
//the branch you want to overwrite
git checkout email
//reset to the new branch
git reset --hard origin/staging
// push to remote
git push -f
এখন ইমেল শাখা এবং মঞ্চটি একই রকম।
email
শাখার সমস্ত কমান্ড মুছে ফেলে । এটি email
শাখাটি মুছে ফেলার এবং শাখার মাথায় নতুন করে তৈরি করার মতো staging
।
git checkout email
git merge -m "Making email same as staging disregarding any conflicts from email in the process" -s recursive -X theirs staging
এইটি মূল নতুন শাখাটি পরিবর্তন করে না এবং চূড়ান্ত প্রতিশ্রুতি দেওয়ার আগে আপনাকে আরও পরিবর্তন করার সুযোগ দেয়।
git checkout new -b tmp
git merge -s ours old -m 'irrelevant'
git checkout old
git merge --squash tmp
git branch -D tmp
#do any other stuff you want
git add -A; git commit -m 'foo' #commit (or however you like)