விஷுவல் ஸ்டுடியோவில் பல திட்டங்களில் Git மாற்றங்களைக் கையாளுதல்

PowerShell

Git மாற்றங்களை நிர்வகிப்பதற்கான அறிமுகம்

நாங்கள் சமீபத்தில் Azure DevOps க்கு மாறினோம், மேலும் 482 பயன்பாடுகளின் விரிவான தொகுப்பில் பயன்பாட்டுச் சிக்கலை எதிர்கொண்டோம். இந்தப் பயன்பாடுகள் களஞ்சியங்களாகத் தொகுக்கப்பட்டுள்ளன, ஒவ்வொன்றும் பல தீர்வுகளைக் கொண்டிருக்கும். அத்தகைய ஒரு களஞ்சியத்தில் ஐந்து பயன்பாடுகள் உள்ளன, ஒரு தீர்வில் 20+ திட்டங்கள் உள்ளன, அதில் ஒன்று மட்டுமே பயன்பாடுகள் முழுவதும் பகிரப்படும், மற்றவை 10 முதல் 15 தனிப்பட்ட திட்டங்கள் உள்ளன.

ஒரே களஞ்சியத்தில் ஒரே நேரத்தில் பல பயன்பாடுகளில் பணிபுரியும் போது எங்கள் சவால் எழுகிறது. SVN போலல்லாமல், வடிகட்டப்பட்ட மாற்றங்களைத் திட்டத்திற்குத் தொடர்புடையவற்றை மட்டுமே தீர்வுகளில் காண்பிக்கும், விஷுவல் ஸ்டுடியோவின் Git மாற்றங்கள் களஞ்சியத்தில் அனைத்து மாற்றங்களையும் காண்பிக்கும். இது ஒரு இரைச்சலான காட்சியை உருவாக்குகிறது, குறிப்பிட்ட திட்டங்களில் கவனம் செலுத்துவதை கடினமாக்குகிறது. இதை திறம்பட நிர்வகிப்பதற்கான வழிகளை ஆராய்ந்து வருகிறோம்.

கட்டளை விளக்கம்
git -C $repoPath rev-parse --abbrev-ref HEAD குறிப்பிட்ட களஞ்சியத்தில் தற்போதைய கிளை பெயரை மீட்டெடுக்கிறது.
git -C $repoPath diff --name-only $branch குறிப்பிட்ட கிளையுடன் ஒப்பிடும்போது தற்போதைய கிளையில் மாற்றப்பட்ட கோப்புகளின் பெயர்களை பட்டியலிடுகிறது.
Where-Object PowerShell இல் குறிப்பிட்ட நிபந்தனைகளின் அடிப்படையில் சேகரிப்பில் உள்ள பொருட்களை வடிகட்டுகிறது.
IVsWindowFrame கருவி சாளரங்களைத் தனிப்பயனாக்கப் பயன்படும் விஷுவல் ஸ்டுடியோவில் ஒரு சாளரச் சட்டத்தைக் குறிக்கிறது.
Package.Initialize() தனிப்பயன் லாஜிக்கைச் சேர்க்க விஷுவல் ஸ்டுடியோ தொகுப்பிற்கான துவக்க முறையை மேலெழுதுகிறது.
IVsWindowFrame.Show() விஷுவல் ஸ்டுடியோவில் ஒரு கருவி சாளரத்தைக் காட்டுகிறது.
Package ஐடிஇ நீட்டிக்கக்கூடிய விஷுவல் ஸ்டுடியோ தொகுப்பை உருவாக்குவதற்கான அடிப்படை வகுப்பு.

ஸ்கிரிப்ட் தீர்வுகளைப் புரிந்துகொள்வது

வழங்கப்பட்ட பவர்ஷெல் ஸ்கிரிப்ட் Git மாற்றங்களை வடிகட்ட வடிவமைக்கப்பட்டுள்ளது, இது ஒரு பெரிய களஞ்சியத்தில் ஒரு குறிப்பிட்ட தீர்வுக்கு பொருத்தமானவற்றை மட்டுமே காண்பிக்கும். இது களஞ்சியத்திற்கான பாதையை வரையறுப்பதன் மூலம் தொடங்குகிறது மற்றும் கட்டளையைப் பயன்படுத்தி தற்போதைய கிளையை மீட்டெடுக்கிறது . அடுத்து, தற்போதைய கிளையில் மாற்றப்பட்ட கோப்புகளின் பெயர்களை இது பட்டியலிடுகிறது . ஸ்கிரிப்ட் இந்த மாற்றப்பட்ட கோப்புகளை வடிகட்டுகிறது , இது கோப்பு பாதைகள் தீர்வு பாதையுடன் பொருந்த வேண்டும் என்ற நிபந்தனையைப் பயன்படுத்த அனுமதிக்கிறது.

மறுபுறம், C# இல் எழுதப்பட்ட விஷுவல் ஸ்டுடியோ நீட்டிப்பு தொடர்புடைய மாற்றங்களை வடிகட்ட மற்றும் காண்பிக்க Git மாற்றங்கள் சாளரத்தை தனிப்பயனாக்குகிறது. இது விஷுவல் ஸ்டுடியோ சூழலை பயன்படுத்தி இணைக்கிறது வர்க்கம், விஷுவல் ஸ்டுடியோவில் உள்ள ஒரு சாளர சட்டத்தை குறிக்கிறது. நீட்டிப்பின் முக்கிய தர்க்கம் இதில் இணைக்கப்பட்டுள்ளது முறை, இது Git மாற்றங்கள் சாளர சட்டத்தைக் கண்டறிந்து, தற்போதைய தீர்வின் ஒரு பகுதியாக இருக்கும் மாற்றங்களை மட்டும் காண்பிக்க தனிப்பயன் வடிகட்டுதல் தர்க்கத்தைப் பயன்படுத்துகிறது. டெவலப்பர்கள் களஞ்சியத்தில் உள்ள தொடர்பில்லாத மாற்றங்களால் திசைதிருப்பப்படாமல் தொடர்புடைய மாற்றங்களில் கவனம் செலுத்த இது உதவுகிறது.

விஷுவல் ஸ்டுடியோவில் தீர்வு மூலம் ஜிட் மாற்றங்களை வடிகட்டுதல்

பவர்ஷெல் ஸ்கிரிப்டைப் பயன்படுத்துதல்

# Define the path to the repository
$repoPath = "C:\path\to\your\repository"
# Get the current branch
$branch = git -C $repoPath rev-parse --abbrev-ref HEAD
# Get the list of changed files
$changedFiles = git -C $repoPath diff --name-only $branch
# Define the solution path
$solutionPath = "C:\path\to\your\solution"
# Filter the changed files to include only those in the solution
$filteredFiles = $changedFiles | Where-Object { $_ -like "$solutionPath\*" }
# Output the filtered files
$filteredFiles

விஷுவல் ஸ்டுடியோவில் Git மாற்றங்களின் காட்சியைத் தனிப்பயனாக்குதல்

விஷுவல் ஸ்டுடியோ நீட்டிப்பைப் பயன்படுத்துதல் (C#)

using System;
using Microsoft.VisualStudio.Shell;
using Microsoft.VisualStudio.Shell.Interop;
namespace GitChangesFilter
{
    public class GitChangesFilterPackage : Package
    {
        protected override void Initialize()
        {
            base.Initialize();
            // Hook into the Git Changes window
            IVsWindowFrame windowFrame = /* Get the Git Changes window frame */
            if (windowFrame != null)
            {
                // Customize the Git Changes display
                // Apply filtering logic here
            }
        }
    }
}

Git உடன் விஷுவல் ஸ்டுடியோவில் பல திட்டங்களை நிர்வகித்தல்

விஷுவல் ஸ்டுடியோவில் Git மாற்றங்களை நிர்வகிப்பதற்கான மற்றொரு அணுகுமுறை கிளை உத்திகளை திறம்பட பயன்படுத்துவதாகும். ஒரே களஞ்சியத்தில் உள்ள ஒவ்வொரு பயன்பாட்டிற்கும் அல்லது பயன்பாடுகளின் குழுவிற்கும் தனித்தனி கிளைகளை உருவாக்குவதன் மூலம், நீங்கள் மாற்றங்களைத் தனிமைப்படுத்தி, அவை தொடர்பில்லாத திட்டங்களில் காட்டப்படுவதைத் தடுக்கலாம். இந்த வழியில், நீங்கள் கிளைகளுக்கு இடையில் மாறும்போது, ​​தற்போதைய கிளையுடன் தொடர்புடைய மாற்றங்கள் மட்டுமே Git Changes சாளரத்தில் காட்டப்படும். குழு உறுப்பினர்கள் ஒருவருக்கொருவர் வேலையில் தலையிடாமல் வெவ்வேறு கிளைகளில் வேலை செய்ய முடியும் என்பதால், இந்த முறை சிறந்த ஒத்துழைப்பை அனுமதிக்கிறது.

கூடுதலாக, Git submodules அல்லது Git sparse-checkout போன்ற கருவிகள் பல திட்டங்களுடன் பெரிய களஞ்சியங்களை நிர்வகிக்க பயன்படுத்தப்படலாம். ஒரு களஞ்சியத்தில் மற்ற களஞ்சியங்களைச் சேர்க்க Git துணைத் தொகுதிகள் உங்களை அனுமதிக்கின்றன, சார்புகள் மற்றும் திட்டப் பிரிப்பு ஆகியவற்றின் மீது சிறந்த கட்டுப்பாட்டை வழங்குகிறது. Git sparse-checkout ஆனது, களஞ்சியத்தில் உள்ள கோப்புகளின் துணைக்குழுவை மட்டும் பார்க்க உங்களை அனுமதிக்கிறது, வேலை செய்யும் கோப்பகத்தில் உள்ள ஒழுங்கீனத்தை குறைக்கிறது மற்றும் குறிப்பிட்ட திட்டங்களில் கவனம் செலுத்துவதை எளிதாக்குகிறது. சிக்கலான பல-திட்ட களஞ்சியங்களைக் கையாளும் போது இந்த நுட்பங்கள் உற்பத்தித்திறனை கணிசமாக மேம்படுத்தும்.

  1. பல திட்ட களஞ்சியத்தில் ஒரு குறிப்பிட்ட திட்டத்திற்கான மாற்றங்களை எவ்வாறு வடிகட்டுவது?
  2. நீங்கள் பயன்படுத்தலாம் மாற்றப்பட்ட கோப்புகளை வடிகட்ட பவர்ஷெலில் கட்டளையிடவும், குறிப்பிட்ட தீர்வு பாதையில் உள்ளவற்றை மட்டும் சேர்க்க வேண்டும்.
  3. Git துணைத் தொகுதிகள் என்றால் என்ன, அவை எவ்வாறு உதவுகின்றன?
  4. ஒரு களஞ்சியத்திற்குள் மற்ற களஞ்சியங்களைச் சேர்க்க உங்களை அனுமதிக்கிறது, சார்புகள் மற்றும் திட்டப் பிரிப்பு ஆகியவற்றின் மீது சிறந்த கட்டுப்பாட்டை வழங்குகிறது.
  5. மாற்றங்களை நிர்வகிக்க கிளை உத்திகள் எவ்வாறு உதவுகின்றன?
  6. ஒவ்வொரு பயன்பாட்டிற்கும் அல்லது பயன்பாடுகளின் குழுவிற்கும் தனித்தனி கிளைகளை உருவாக்குவதன் மூலம், நீங்கள் மாற்றங்களைத் தனிமைப்படுத்தி, அவை தொடர்பில்லாத திட்டங்களை பாதிக்காமல் தடுக்கலாம்.
  7. Git sparse-checkout என்றால் என்ன?
  8. களஞ்சியத்தில் உள்ள கோப்புகளின் துணைக்குழுவை மட்டும் பார்க்க உங்களை அனுமதிக்கிறது, இது குறிப்பிட்ட திட்டங்களில் கவனம் செலுத்துவதை எளிதாக்குகிறது.
  9. விஷுவல் ஸ்டுடியோவில் Git மாற்றங்கள் சாளரத்தை தனிப்பயனாக்க முடியுமா?
  10. ஆம், C# இல் எழுதப்பட்ட விஷுவல் ஸ்டுடியோ நீட்டிப்பைப் பயன்படுத்தி நீங்கள் அதைத் தனிப்பயனாக்கலாம், இது Git மாற்றங்கள் சாளரத்தில் இணைக்கப்பட்டு தனிப்பயன் வடிகட்டுதல் தர்க்கத்தைப் பயன்படுத்துகிறது.
  11. ஒரு களஞ்சியத்தில் தற்போதைய கிளை பெயரை எவ்வாறு மீட்டெடுப்பது?
  12. நீங்கள் கட்டளையைப் பயன்படுத்தலாம் தற்போதைய கிளை பெயரை மீட்டெடுக்க.
  13. தற்போதைய கிளையில் மாற்றப்பட்ட கோப்புகளின் பெயர்களை எவ்வாறு பட்டியலிடுவது?
  14. கட்டளையைப் பயன்படுத்தவும் தற்போதைய கிளையில் மாறிய கோப்புகளின் பெயர்களை பட்டியலிட.
  15. விஷுவல் ஸ்டுடியோவில் Package.Initialize() முறையின் நோக்கம் என்ன?
  16. தி ஒரு விஷுவல் ஸ்டுடியோ தொகுப்பை துவக்கவும் மற்றும் Git Changes சாளரத்தை வடிகட்டுதல் போன்ற தனிப்பயன் தர்க்கத்தை சேர்க்கவும் இந்த முறை பயன்படுத்தப்படுகிறது.
  17. விஷுவல் ஸ்டுடியோவில் டூல் விண்டோவை எப்படிக் காட்டுவது?
  18. நீங்கள் பயன்படுத்தலாம் விஷுவல் ஸ்டுடியோவில் ஒரு கருவி சாளரத்தைக் காண்பிக்கும் முறை.

விஷுவல் ஸ்டுடியோவில் பல திட்டங்களில் Git மாற்றங்களை நிர்வகிப்பது சவாலானது, குறிப்பாக Azure DevOps க்கு மாறிய பிறகு. பவர்ஷெல் ஸ்கிரிப்டுகள் மற்றும் விஷுவல் ஸ்டுடியோ நீட்டிப்புகள் உட்பட விவாதிக்கப்பட்ட தீர்வுகள், மாற்றங்களை வடிகட்டுவதற்கும் குறிப்பிட்ட திட்டங்களில் கவனம் செலுத்துவதற்கும் பயனுள்ள வழிகளை வழங்குகின்றன. கிளை உத்திகள், ஜிட் சப்மாட்யூல்கள் மற்றும் ஸ்பேர்ஸ்-செக் அவுட் ஆகியவற்றைச் செயல்படுத்துவது பணிப்பாய்வுகளை மேலும் சீராக்கலாம் மற்றும் உற்பத்தித்திறனை மேம்படுத்தலாம். இந்த முறைகள் தெளிவு மற்றும் ஒழுங்கமைப்பைப் பராமரிக்க உதவுகின்றன, டெவலப்பர்கள் தேவையற்ற கவனச்சிதறல்கள் இல்லாமல் தங்கள் தற்போதைய வேலைக்கு மிகவும் முக்கியமான மாற்றங்களில் கவனம் செலுத்த முடியும் என்பதை உறுதிப்படுத்துகிறது.