আমার সম্পাদক আমার উত্স ফাইলগুলির লাইন শেষগুলি পরিবর্তন করছে। আমি যখন করি তখন আমি git diff
একই লাইনটি দু'বার দেখি - একবার -
এবং একবার সাথে +
- কোনও দৃশ্যমান পার্থক্য ছাড়াই।
git diff
এই পরিবর্তনটি আসলে কী ছিল তা আমাকে কীভাবে দেখাব?
উত্তর:
প্রথমে নিশ্চিত হয়ে নিন যে আপনি রঙিন আউটপুট ব্যবহার করছেন (উদাহরণস্বরূপ git diff --color
) এবং আপনি (যেমন) এর সাথে হাইটস্পেস হাইলাইটিং সক্ষম করেছেন
git config color.diff.whitespace "red reverse"
এটি সমস্ত ক্ষেত্রে কার্যকর নাও হতে পারে, যেমন মুছে ফেলা রেখাগুলির git
জন্য পেছনের সাদা স্থানটিকে হাইলাইট করার মতো মনে হয় না । আপনি মুছে ফেলা সাদা স্থানটি দেখতে, কেবল ব্যবহার করুন
git diff -R
সাদা অংশটিকে তুলনার 'যুক্ত' দিকে রেখে যেখানে এটি হাইলাইট হয়।
আরও তথ্যের জন্য, এই এসও প্রশ্নের উত্তরগুলি দেখুন ।
000000f0 2d 2d 7d 0a 2b 2b 7d 0a |--}.++}.|
7 ডি হ'ল '}' কোঁকড়া-ব্রেস।
আপনি নিম্নলিখিত কমান্ডের সাথে লাইন-শেষের পার্থক্য দেখতে পাবেন।
git diff | cat -v
তারপরে সিআরএলএফ (ডস) সমাপ্তির জন্য "^ এম" মুদ্রিত হয়, এলএফ (ইউনিক্স) সমাপ্তির জন্য কিছুই নেই।
দৃশ্যত গিট ডিফ সঠিক কাজ করছে, সিআরএলএফ শেষ হওয়ার জন্য সিআর এবং এলএফ অক্ষর মুদ্রণ করছে। তবে সিআর কনসোল দ্বারা গ্রাস করা হয়েছে বলে আমরা এটি দেখতে পারি না। ক্যাট-ভি ব্যবহার করে আমরা এটি দৃশ্যমান করতে পারি।
git diff > somediff && vi somediff
, ভিএম সিআরএলএফকে এম এম হিসাবেও দেখায়। তবে cat -v
ঝরঝরে।
cat
আমি অবগত ছিলাম না। :-)
হোয়াইটস্পেস পরিবর্তনগুলি দেখার একটি উপায় হ'ল একটি অক্ষর দ্বারা অক্ষর "শব্দের সাথে পৃথক" করা
git diff --color --word-diff-regex=.
এটি সর্বত্র লাইনগুলিতে সমস্ত সাদা স্থান পরিবর্তনকে হাইলাইট করে । সরানো হয়নি হোয়াইটস্পেস জড়িয়ে রাখা হয়েছে [-
এবং -]
এবং হোয়াইটস্পেস যোগ {+
এবং +}
।
বিকল্প হিসাবে, অ্যালেক্স দ্বারা পরামর্শ হিসাবে
git diff --color --ws-error-highlight=new,old
লাইনের প্রান্তে সমস্ত সাদা স্থান পরিবর্তন হাইলাইট করে ।
git diff --ws-error-highlight=new,old
পরিবর্তিত লাইনে সাদা স্থান স্পষ্ট করে হাইলাইট করে।
একটি গ্রাফিকাল ডিফ সরঞ্জাম আপনাকে আরও ভাল পরিবর্তন দেখাবে - চেষ্টা করুন git difftool
।
মেল্ডটি ব্যবহার করুন এবং সাদা স্থান দেখানোর জন্য পছন্দগুলি সেট করুন। (সম্পাদনা করুন -> পছন্দসমূহ -> সাদা স্থান দেখান Show)
অন্যান্য গ্রাফিকাল সরঞ্জামগুলিতে সম্ভবত অনুরূপ বিকল্প রয়েছে - @ সুতির উত্তর + মন্তব্য আপনাকে কীভাবে ভিমডিফ দিয়ে এটি করবেন তা বলে tells
git difftool --tool=meld doesn't
এমনকি মেল্ডও চালু করুন। আমি জানি না যে এটি একটি রিবেস প্রক্রিয়াধীন রয়েছে বা না হওয়ার কারণে।
git config diff.wsErrorHighlight all