വിഷ്വൽ സ്റ്റുഡിയോയിൽ ഒന്നിലധികം പ്രോജക്‌റ്റുകളിലുടനീളം 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 IDE വിപുലീകരിക്കാൻ കഴിയുന്ന ഒരു വിഷ്വൽ സ്റ്റുഡിയോ പാക്കേജ് സൃഷ്ടിക്കുന്നതിനുള്ള അടിസ്ഥാന ക്ലാസ്.

സ്ക്രിപ്റ്റ് സൊല്യൂഷനുകൾ മനസ്സിലാക്കുന്നു

നൽകിയിരിക്കുന്ന പവർഷെൽ സ്‌ക്രിപ്റ്റ് രൂപകൽപ്പന ചെയ്‌തിരിക്കുന്നത് ഒരു വലിയ ശേഖരത്തിനുള്ളിൽ ഒരു നിർദ്ദിഷ്ട പരിഹാരത്തിന് പ്രസക്തമായവ മാത്രം കാണിക്കുന്നതിനായി Git മാറ്റങ്ങൾ ഫിൽട്ടർ ചെയ്യുന്നതിനാണ്. റിപ്പോസിറ്ററിയിലേക്കുള്ള പാത നിർവചിച്ചുകൊണ്ട് ഇത് ആരംഭിക്കുകയും കമാൻഡ് ഉപയോഗിച്ച് നിലവിലെ ബ്രാഞ്ച് വീണ്ടെടുക്കുകയും ചെയ്യുന്നു . അടുത്തതായി, നിലവിലുള്ള ബ്രാഞ്ചിൽ മാറിയ ഫയലുകളുടെ പേരുകൾ ഇത് പട്ടികപ്പെടുത്തുന്നു . സ്‌ക്രിപ്റ്റ് പിന്നീട് ഈ മാറ്റിയ ഫയലുകൾ ഫിൽട്ടർ ചെയ്‌ത് ഉപയോഗിക്കുന്ന നിർദ്ദിഷ്ട പരിഹാര പാതയിലുള്ളവ മാത്രം ഉൾപ്പെടുത്തും , ഫയൽ പാതകൾ പരിഹാര പാതയുമായി പൊരുത്തപ്പെടണം എന്ന ഒരു വ്യവസ്ഥ പ്രയോഗിക്കാൻ ഞങ്ങളെ അനുവദിക്കുന്നു.

മറുവശത്ത്, C#-ൽ എഴുതിയിരിക്കുന്ന വിഷ്വൽ സ്റ്റുഡിയോ എക്സ്റ്റൻഷൻ, പ്രസക്തമായ മാറ്റങ്ങൾ ഫിൽട്ടർ ചെയ്യുന്നതിനും പ്രദർശിപ്പിക്കുന്നതിനും Git മാറ്റങ്ങൾ വിൻഡോ ഇഷ്ടാനുസൃതമാക്കുന്നു. ഇത് ഉപയോഗിച്ച് വിഷ്വൽ സ്റ്റുഡിയോ പരിതസ്ഥിതിയിലേക്ക് ഹുക്ക് ചെയ്യുന്നു ക്ലാസ്, വിഷ്വൽ സ്റ്റുഡിയോയിലെ ഒരു വിൻഡോ ഫ്രെയിമിനെ പ്രതിനിധീകരിക്കുന്നു. വിപുലീകരണത്തിൻ്റെ പ്രധാന ലോജിക് ഇതിൽ ഉൾക്കൊള്ളിച്ചിരിക്കുന്നു രീതി, അവിടെ അത് Git മാറ്റങ്ങൾ വിൻഡോ ഫ്രെയിം കണ്ടെത്തുകയും നിലവിലെ പരിഹാരത്തിൻ്റെ ഭാഗമായ മാറ്റങ്ങൾ മാത്രം പ്രദർശിപ്പിക്കുന്നതിന് ഇഷ്ടാനുസൃത ഫിൽട്ടറിംഗ് ലോജിക്ക് പ്രയോഗിക്കുകയും ചെയ്യുന്നു. റിപ്പോസിറ്ററിയിലെ ബന്ധമില്ലാത്ത പരിഷ്കാരങ്ങളിൽ നിന്ന് ശ്രദ്ധ തിരിക്കാതെ, പ്രസക്തമായ മാറ്റങ്ങളിൽ ശ്രദ്ധ കേന്ദ്രീകരിക്കാൻ ഇത് ഡവലപ്പർമാരെ സഹായിക്കുന്നു.

വിഷ്വൽ സ്റ്റുഡിയോയിൽ പരിഹാരം വഴി Git മാറ്റങ്ങൾ ഫിൽട്ടർ ചെയ്യുന്നു

PowerShell സ്ക്രിപ്റ്റ് ഉപയോഗിക്കുന്നു

# 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 സബ്‌മോഡ്യൂളുകൾ അല്ലെങ്കിൽ Git സ്പാർസ്-ചെക്കൗട്ട് പോലുള്ള ഉപകരണങ്ങൾ ഉപയോഗിക്കാം. ഒരു റിപ്പോസിറ്ററിയിൽ മറ്റ് റിപ്പോസിറ്ററികൾ ഉൾപ്പെടുത്താൻ Git സബ്‌മോഡ്യൂളുകൾ നിങ്ങളെ അനുവദിക്കുന്നു, ഇത് ഡിപൻഡൻസികളിലും പ്രോജക്റ്റ് വേർതിരിവിലും മികച്ച നിയന്ത്രണം നൽകുന്നു. റിപ്പോസിറ്ററിയിലെ ഫയലുകളുടെ ഒരു ഉപവിഭാഗം മാത്രം പരിശോധിക്കാൻ Git സ്പേസ്-ചെക്ക്ഔട്ട് നിങ്ങളെ അനുവദിക്കുന്നു, വർക്കിംഗ് ഡയറക്ടറിയിലെ അലങ്കോലങ്ങൾ കുറയ്ക്കുകയും നിർദ്ദിഷ്ട പ്രോജക്റ്റുകളിൽ ശ്രദ്ധ കേന്ദ്രീകരിക്കുന്നത് എളുപ്പമാക്കുകയും ചെയ്യുന്നു. സങ്കീർണ്ണമായ മൾട്ടി-പ്രൊജക്റ്റ് ശേഖരണങ്ങൾ കൈകാര്യം ചെയ്യുമ്പോൾ ഈ സാങ്കേതിക വിദ്യകൾക്ക് ഉത്പാദനക്ഷമത ഗണ്യമായി വർദ്ധിപ്പിക്കാൻ കഴിയും.

  1. ഒരു മൾട്ടി-പ്രൊജക്റ്റ് റിപ്പോസിറ്ററിയിൽ ഒരു നിർദ്ദിഷ്‌ട പ്രോജക്റ്റിലേക്കുള്ള മാറ്റങ്ങൾ എങ്ങനെ ഫിൽട്ടർ ചെയ്യാം?
  2. നിങ്ങൾക്ക് ഉപയോഗിക്കാം നിർദ്ദിഷ്‌ട പരിഹാര പാതയിലുള്ളവ മാത്രം ഉൾപ്പെടുത്തുന്നതിന് മാറ്റിയ ഫയലുകൾ ഫിൽട്ടർ ചെയ്യാൻ PowerShell-ൽ കമാൻഡ് ചെയ്യുക.
  3. എന്താണ് Git സബ്‌മോഡ്യൂളുകൾ, അവ എങ്ങനെ സഹായിക്കും?
  4. ഒരു റിപ്പോസിറ്ററിയിൽ മറ്റ് ശേഖരണങ്ങൾ ഉൾപ്പെടുത്താൻ നിങ്ങളെ അനുവദിക്കുന്നു, ഇത് ഡിപൻഡൻസികളിലും പ്രോജക്റ്റ് വേർതിരിവിലും മികച്ച നിയന്ത്രണം നൽകുന്നു.
  5. മാറ്റങ്ങൾ കൈകാര്യം ചെയ്യാൻ ബ്രാഞ്ച് തന്ത്രങ്ങൾ എങ്ങനെ സഹായിക്കുന്നു?
  6. ഓരോ ആപ്ലിക്കേഷനും അല്ലെങ്കിൽ ആപ്ലിക്കേഷനുകളുടെ ഗ്രൂപ്പിനും പ്രത്യേക ബ്രാഞ്ചുകൾ സൃഷ്ടിക്കുന്നതിലൂടെ, നിങ്ങൾക്ക് മാറ്റങ്ങൾ വേർതിരിച്ച് അവ ബന്ധമില്ലാത്ത പ്രോജക്റ്റുകളെ ബാധിക്കുന്നതിൽ നിന്ന് തടയാം.
  7. എന്താണ് Git സ്പേസ് ചെക്ക്ഔട്ട്?
  8. നിർദ്ദിഷ്‌ട പ്രോജക്‌റ്റുകളിൽ ശ്രദ്ധ കേന്ദ്രീകരിക്കുന്നത് എളുപ്പമാക്കിക്കൊണ്ട്, റിപ്പോസിറ്ററിയിലെ ഫയലുകളുടെ ഒരു ഉപവിഭാഗം മാത്രം പരിശോധിക്കാൻ നിങ്ങളെ അനുവദിക്കുന്നു.
  9. എനിക്ക് വിഷ്വൽ സ്റ്റുഡിയോയിൽ Git മാറ്റങ്ങൾ വിൻഡോ ഇഷ്ടാനുസൃതമാക്കാനാകുമോ?
  10. അതെ, C#-ൽ എഴുതിയിരിക്കുന്ന ഒരു വിഷ്വൽ സ്റ്റുഡിയോ എക്സ്റ്റൻഷൻ ഉപയോഗിച്ച് നിങ്ങൾക്ക് ഇത് ഇഷ്ടാനുസൃതമാക്കാൻ കഴിയും, അത് Git മാറ്റങ്ങൾ വിൻഡോയിലേക്ക് ഹുക്ക് ചെയ്യുകയും ഇഷ്‌ടാനുസൃത ഫിൽട്ടറിംഗ് ലോജിക് പ്രയോഗിക്കുകയും ചെയ്യുന്നു.
  11. ഒരു റിപ്പോസിറ്ററിയിൽ നിലവിലുള്ള ബ്രാഞ്ചിൻ്റെ പേര് എങ്ങനെ വീണ്ടെടുക്കാം?
  12. നിങ്ങൾക്ക് കമാൻഡ് ഉപയോഗിക്കാം നിലവിലെ ശാഖയുടെ പേര് വീണ്ടെടുക്കാൻ.
  13. നിലവിലെ ബ്രാഞ്ചിൽ മാറിയ ഫയലുകളുടെ പേരുകൾ എങ്ങനെ ലിസ്റ്റ് ചെയ്യാം?
  14. കമാൻഡ് ഉപയോഗിക്കുക നിലവിലെ ബ്രാഞ്ചിൽ മാറിയ ഫയലുകളുടെ പേരുകൾ പട്ടികപ്പെടുത്താൻ.
  15. വിഷ്വൽ സ്റ്റുഡിയോയിലെ Package.Initialize() രീതിയുടെ ഉദ്ദേശ്യം എന്താണ്?
  16. ദി ഒരു വിഷ്വൽ സ്റ്റുഡിയോ പാക്കേജ് ആരംഭിക്കുന്നതിനും Git മാറ്റങ്ങൾ വിൻഡോ ഫിൽട്ടർ ചെയ്യുന്നത് പോലെയുള്ള ഇഷ്‌ടാനുസൃത ലോജിക് ചേർക്കുന്നതിനും രീതി ഉപയോഗിക്കുന്നു.
  17. വിഷ്വൽ സ്റ്റുഡിയോയിൽ എനിക്ക് എങ്ങനെ ഒരു ടൂൾ വിൻഡോ പ്രദർശിപ്പിക്കാം?
  18. നിങ്ങൾക്ക് ഉപയോഗിക്കാം വിഷ്വൽ സ്റ്റുഡിയോയിൽ ഒരു ടൂൾ വിൻഡോ പ്രദർശിപ്പിക്കുന്നതിനുള്ള രീതി.

വിഷ്വൽ സ്റ്റുഡിയോയിലെ ഒന്നിലധികം പ്രോജക്റ്റുകളിൽ ഉടനീളം Git മാറ്റങ്ങൾ കൈകാര്യം ചെയ്യുന്നത് വെല്ലുവിളിയാണ്, പ്രത്യേകിച്ച് Azure DevOps-ലേക്ക് മാറിയതിന് ശേഷം. പവർഷെൽ സ്ക്രിപ്റ്റുകളും വിഷ്വൽ സ്റ്റുഡിയോ വിപുലീകരണങ്ങളും ഉൾപ്പെടെ ചർച്ച ചെയ്ത പരിഹാരങ്ങൾ, മാറ്റങ്ങൾ ഫിൽട്ടർ ചെയ്യുന്നതിനും നിർദ്ദിഷ്ട പ്രോജക്റ്റുകളിൽ ശ്രദ്ധ കേന്ദ്രീകരിക്കുന്നതിനുമുള്ള ഫലപ്രദമായ മാർഗങ്ങൾ വാഗ്ദാനം ചെയ്യുന്നു. ബ്രാഞ്ച് സ്ട്രാറ്റജികൾ, Git സബ്‌മോഡ്യൂളുകൾ, സ്പേസ് ചെക്ക്ഔട്ട് എന്നിവ നടപ്പിലാക്കുന്നത് വർക്ക്ഫ്ലോ കൂടുതൽ കാര്യക്ഷമമാക്കാനും ഉൽപ്പാദനക്ഷമത മെച്ചപ്പെടുത്താനും കഴിയും. ഈ രീതികൾ വ്യക്തതയും ഓർഗനൈസേഷനും നിലനിർത്താൻ സഹായിക്കുന്നു, ഡവലപ്പർമാർക്ക് അവരുടെ നിലവിലെ ജോലിയിൽ ഏറ്റവും പ്രാധാന്യമുള്ള മാറ്റങ്ങളിൽ അനാവശ്യ ശ്രദ്ധയില്ലാതെ ശ്രദ്ധ കേന്ദ്രീകരിക്കാൻ കഴിയുമെന്ന് ഉറപ്പാക്കുന്നു.