Skip to content

Git Conflict উদাহরণ (Conflict Example)

Git-এ Merge Conflict তখন ঘটে যখন দুটি ব্রাঞ্চের মধ্যে একই ফাইলে একে অপরের সাথে বিরোধপূর্ণ পরিবর্তন করা হয়। এই অবস্থায়, Git জানে না কোন পরিবর্তনটি রাখতে হবে, ফলে কনফ্লিক্ট তৈরি হয়।

এই পর্বে আমরা বিভিন্ন ধরনের কনফ্লিক্টের উদাহরণ দেখব এবং কীভাবে সেগুলো সমাধান করা যায় তা শিখব।

১. এক লাইনে দুটি ভিন্ন পরিবর্তন (Conflict - Same Line)

ধরা যাক, আমাদের দুটি ব্রাঞ্চ রয়েছে: main এবং feature। এদের মধ্যে একটি ফাইল index.html এ একে অপরের সাথে বিরোধপূর্ণ পরিবর্তন করা হয়েছে।

Main ব্রাঞ্চ:

html
<h1>Welcome to My Website</h1>
<h1>Welcome to My Website</h1>

Feature ব্রাঞ্চ:

html
<h1>Welcome to Our Website</h1>
<h1>Welcome to Our Website</h1>

এখন, যদি আমরা feature ব্রাঞ্চটি main ব্রাঞ্চের সাথে মর্জ করি, Git কনফ্লিক্ট দেখাবে, কারণ একই লাইনে দুটি ভিন্ন পরিবর্তন রয়েছে।

Git কনফ্লিক্ট এভাবে দেখা যাবে:

html
<<<<<<< HEAD
<h1>Welcome to My Website</h1>
=======
<h1>Welcome to Our Website</h1>
>>>>>>> feature
<<<<<<< HEAD
<h1>Welcome to My Website</h1>
=======
<h1>Welcome to Our Website</h1>
>>>>>>> feature

এখানে <<<<<<< HEAD হলো আপনার বর্তমান ব্রাঞ্চের পরিবর্তন, এবং >>>>>>> feature হলো মার্জ করা ব্রাঞ্চের পরিবর্তন। ======= এর মধ্যে পার্থক্য দেখানো হয়েছে।

সমাধান:

এখানে আপনি দুটি পরিবর্তন মিশিয়ে নতুন একটি পরিবর্তন তৈরি করতে পারেন:

html
<h1>Welcome to My Amazing Website!</h1>
<h1>Welcome to My Amazing Website!</h1>

এবং তারপর git add এবং git commit ব্যবহার করে এই পরিবর্তনটি স্টেজ ও কমিট করতে হবে।

২. একটি ফাইল মুছে ফেলা এবং অন্য একটি পরিবর্তন করা (Conflict - File Deleted vs Edited)

ধরা যাক, একটি ফাইল app.css দুটি ব্রাঞ্চে ভিন্নভাবে সংশোধন করা হয়েছে:

  • Main ব্রাঞ্চ: ফাইলটি মুছে ফেলেছে।
  • Feature ব্রাঞ্চ: ফাইলটিতে কিছু নতুন CSS স্টাইল যোগ করেছে।

এখন, যদি আপনি feature ব্রাঞ্চটি main ব্রাঞ্চের সাথে মার্জ করেন, Git জানবে না কি করতে হবে। একে অপরের সাথে বিরোধপূর্ণ দুটি পরিবর্তন রয়েছে—একটি ফাইল মুছে ফেলা এবং অন্যটি পরিবর্তন করা।

Main ব্রাঞ্চ (app.css মুছে ফেলা):

bash
git rm app.css
git rm app.css

Feature ব্রাঞ্চ (app.css পরিবর্তন করা):

css
body {
  background-color: #f0f0f0;
}
body {
  background-color: #f0f0f0;
}

Git কনফ্লিক্ট এমন দেখতে হবে:

bash
error: The following untracked working tree files would be overwritten by checkout:
    app.css
Please move or remove them before you can switch branches.
Aborting
error: The following untracked working tree files would be overwritten by checkout:
    app.css
Please move or remove them before you can switch branches.
Aborting

সমাধান:

এখানে আপনার সিদ্ধান্ত নিতে হবে:

  • যদি আপনি app.css ফাইলটি রাখতে চান, তাহলে git add app.css ব্যবহার করে ফাইলটি আবার স্টেজ করুন।
  • যদি আপনি ফাইলটি মুছে ফেলতে চান, তাহলে git rm app.css ব্যবহার করে মুছে দিন।

৩. একই ফাইলের নাম পরিবর্তন করা (Conflict - Renamed vs Edited)

ধরা যাক, দুটি ব্রাঞ্চে একই ফাইল app.js ভিন্নভাবে পরিবর্তিত হয়েছে:

  • Main ব্রাঞ্চ: ফাইলটির নাম পরিবর্তন করেছে।
  • Feature ব্রাঞ্চ: ফাইলটিতে কিছু নতুন কোড যোগ করেছে।

এখন, আপনি যখন feature ব্রাঞ্চটি main ব্রাঞ্চের সাথে মর্জ করবেন, Git জানে না কোনটি রাখতে হবে—ফাইলের নাম পরিবর্তন করা বা ফাইলের মধ্যে পরিবর্তন করা।

Main ব্রাঞ্চ (ফাইলের নাম পরিবর্তন করা):

bash
git mv app.js main.js
git mv app.js main.js

Feature ব্রাঞ্চ (app.js এ পরিবর্তন করা):

javascript
console.log('Hello World');
console.log('Hello World');

Git কনফ্লিক্ট এভাবে দেখাবে:

bash
error: The following untracked working tree files would be overwritten by checkout:
    app.js
Please move or remove them before you can switch branches.
Aborting
error: The following untracked working tree files would be overwritten by checkout:
    app.js
Please move or remove them before you can switch branches.
Aborting

সমাধান:

এখানে আপনি ম্যানুয়ালি একে অপরের পরিবর্তনগুলিকে একত্রিত করতে পারেন:

  • git mv app.js main.js দিয়ে নাম পরিবর্তন করুন এবং ফাইলটিতে নতুন কোড যোগ করুন।
  • এরপর git add ব্যবহার করে পরিবর্তনগুলো স্টেজ করুন।

৪. একটি ব্রাঞ্চে ফাইলের মধ্যে পরিবর্তন এবং অন্যটিতে একই ফাইলের নাম পরিবর্তন করা

ধরা যাক, file.txt ফাইলটি দুটি ব্রাঞ্চে আলাদা আলাদা ভাবে পরিবর্তিত হয়েছে:

  • Main ব্রাঞ্চ: ফাইলটি মুছে ফেলেছে।
  • Feature ব্রাঞ্চ: ফাইলটির কিছু অংশে পরিবর্তন করেছে।

এখন আপনি যখন এই দুটি ব্রাঞ্চ একত্রিত করবেন, Git মর্জ কনফ্লিক্ট তৈরি করবে, কারণ এক ব্রাঞ্চে ফাইলটি মুছে ফেলা হয়েছে এবং অন্যটিতে তা পরিবর্তন করা হয়েছে।

Main ব্রাঞ্চ (file.txt মুছে ফেলা):

bash
git rm file.txt
git rm file.txt

Feature ব্রাঞ্চ (file.txt পরিবর্তন):

txt
This is a modified file.
This is a modified file.

সমাধান:

এখানে আপনাকে সিদ্ধান্ত নিতে হবে:

  • যদি আপনি ফাইলটি মুছে ফেলতে চান, তবে git rm file.txt ব্যবহার করুন।
  • যদি আপনি ফাইলটির পরিবর্তন রাখতে চান, তবে git add file.txt দিয়ে স্টেজ করুন।

৫. একাধিক ফাইলের কনফ্লিক্ট

অনেক সময় একাধিক ফাইলে কনফ্লিক্ট হতে পারে। ধরুন, আপনি feature ব্রাঞ্চে কাজ করছেন এবং main ব্রাঞ্চ থেকে কয়েকটি ফাইল মার্জ করতে যাচ্ছেন। যদি আপনি একাধিক ফাইলের মধ্যে পরিবর্তন করে থাকেন, তবে সেগুলির কনফ্লিক্ট একসাথে সমাধান করতে হবে।

প্রক্রিয়া:

  1. প্রথমে git status দিয়ে কনফ্লিক্টের ফাইলগুলো চেক করুন।
  2. তারপর, প্রতিটি কনফ্লিক্টেড ফাইল খুলে এগুলোর মধ্যে পার্থক্য দেখে, কোন অংশ রাখবেন তা সিদ্ধান্ত নিন।
  3. শেষে, git add দিয়ে সেগুলো স্টেজ করে git commit দিয়ে কনফ্লিক্ট সমাধান করুন।

⚡️ কনফ্লিক্টের মধ্যে Avoid করার কৌশল

  1. নিয়মিত Pull করুন: git pull করে সর্বশেষ আপডেট নিয়ে আসুন। এতে কনফ্লিক্ট কম হবে।
  2. ফিচার ব্রাঞ্চ ব্যবহার করুন: মূল ব্রাঞ্চে সরাসরি কাজ না করে, ফিচার ব্রাঞ্চে কাজ করুন।
  3. কনফ্লিক্ট শনাক্তকরণে মনোযোগ দিন: কোনো পরিবর্তন করলে প্রথমে git status চেক করুন।
  4. কনফ্লিক্ট সমাধানকারী টুল ব্যবহার করুন: যেসব IDE গুলি Git সমর্থন করে, সেগুলি কনফ্লিক্ট সমাধানের জন্য সহায়ক টুল সরবরাহ করে।

🎯 সারাংশ

Git-এ Merge Conflict এমন একটি অবস্থা যেখানে দুটি ব্রাঞ্চের মধ্যে একই ফাইলের উপর পরিবর্তন থাকে। আপনি যখন দুটি ব্রাঞ্চ একত্রিত করবেন, Git জানে না কোন পরিবর্তনটি রাখতে হবে এবং কনফ্লিক্ট তৈরি হয়। তবে, ম্যানুয়ালি এই কনফ্লিক্ট সমাধান করা সম্ভব এবং বিভিন্ন ধাপে এই প্রক্রিয়া সম্পন্ন করা যায়।

Released under the MIT License.