Rebasing
રિબેઝિંગ તમને કમિટ હિસ્ટ્રીમાં ફેરફાર કરીને એક શાખામાંથી બીજી શાખામાં ફેરફારોને સામેલ કરવાની મંજૂરી આપે છે. તે સ્ત્રોત શાખામાંથી કમિટ્સને લક્ષ્ય શાખા પર ફરીથી ચલાવે છે. આના પરિણામે ક્લીનર અને વધુ રેખીય કમિટ ઇતિહાસ થાય છે.
ઉદાહરણ: ધારો કે તમારી પાસે ફીચર બ્રાન્ચ કહેવાય છે feature-branch
અને તમે બ્રાન્ચના નવીનતમ ફેરફારોને સામેલ કરવા માંગો છો main
. તમે નીચેના આદેશનો ઉપયોગ કરી શકો છો:
આ શાખામાંથી કમિટ્સને main
પર લાગુ કરશે feature-branch
. રિબેઝ પ્રક્રિયા દરમિયાન કોઈપણ તકરારને ઉકેલવાની જરૂર પડશે.
Stashing
સ્ટેશિંગ તમને તમારા વર્તમાન ફેરફારોને સાચવવાની મંજૂરી આપે છે, જે પ્રતિબદ્ધ થવા માટે તૈયાર નથી, અને અસ્થાયી રૂપે સ્વચ્છ કાર્યકારી નિર્દેશિકા પર પાછા ફરો. જ્યારે તમે હાલમાં કામ કરી રહ્યાં છો તે ફેરફારોને કમિટ કર્યા વિના તમારે કોઈ અલગ શાખા પર સ્વિચ કરવાની અથવા કોઈ અલગ સુવિધા પર કામ કરવાની જરૂર હોય ત્યારે આ ઉપયોગી છે.
ઉદાહરણ: ધારો કે તમે ફીચર બ્રાન્ચ પર કામ કરી રહ્યા છો અને તમે કેટલાક ફેરફારો કર્યા છે, પરંતુ તમારે બીજી બ્રાન્ચ પર સ્વિચ કરવાની જરૂર છે. તમે તમારા ફેરફારોને છુપાવવા માટે નીચેના આદેશોનો ઉપયોગ કરી શકો છો:
નવી શાખા પર સ્વિચ કર્યા પછી, તમે પછી આનો ઉપયોગ કરીને છુપાયેલા ફેરફારો લાગુ કરી શકો છો:
Git Hooks
Git Hooks
એ સ્ક્રિપ્ટો છે જે ચોક્કસ ગિટ ઇવેન્ટ્સ દ્વારા ટ્રિગર થાય છે, જેમ કે પ્રી-કમિટ, પોસ્ટ-કમિટ, પ્રી-પુશ વગેરે. તેઓ તમને અમુક ક્રિયાઓને સ્વચાલિત કરવા અથવા તમારા વર્કફ્લોમાં ચોક્કસ નિયમો લાગુ કરવાની મંજૂરી આપે છે.
ઉદાહરણ: ધારો કે તમે પ્રતિબદ્ધતા પહેલા તમારા કોડ પર લિંટર ચલાવવા માંગો છો. તમે પ્રી-કમિટ હૂક સ્ક્રિપ્ટ બનાવી શકો છો જે લિંટરને ટ્રિગર કરે છે અને જો કોઈ લિંટિંગ ભૂલો હોય તો કમિટને અટકાવે છે.
Git Submodule
Git Submodule
તમને તમારા મુખ્ય ભંડારમાં સબડિરેક્ટરી તરીકે અન્ય ગિટ રિપોઝીટરીનો સમાવેશ કરવાની મંજૂરી આપો. જ્યારે તમારી પાસે બાહ્ય પુસ્તકાલયો અથવા ઘટકો પર આધારિત પ્રોજેક્ટ હોય ત્યારે આ ઉપયોગી છે.
ઉદાહરણ: તમારી પાસે એક પ્રોજેક્ટ છે જેને ચોક્કસ લાઇબ્રેરીની જરૂર છે. તમારી રીપોઝીટરીમાં લાઇબ્રેરીના કોડને ડુપ્લિકેટ કરવાને બદલે, તમે તેને સબમોડ્યુલ તરીકે ઉમેરી શકો છો. આ રીતે, તમે લાઇબ્રેરી કોડને અલગ રાખી શકો છો અને જરૂર પડ્યે તેને સરળતાથી અપડેટ કરી શકો છો.
Git Revert and Git Reset
Git Revert
નવી કમિટ બનાવીને પાછલી કમિટને પૂર્વવત્ કરે છે જે મૂળ કમિટમાં કરેલા ફેરફારોને પૂર્વવત્ કરે છે. Git Reset
, બીજી બાજુ, તમને બ્રાન્ચ પોઈન્ટરને અલગ કમિટ પર ખસેડવાની મંજૂરી આપે છે, કમિટ ઇતિહાસમાંથી કમિટ્સને અસરકારક રીતે કાઢી નાખે છે.
ઉદાહરણ: જો તમે છેલ્લી કમિટને પૂર્વવત્ કરવા માંગતા હો, તો તમે git revert HEAD
નવી કમિટ બનાવવા માટે ઉપયોગ કરી શકો છો જે છેલ્લા કમિટમાં કરેલા ફેરફારોને પૂર્વવત્ કરે છે. જો તમે છેલ્લી કમિટને સંપૂર્ણપણે કાઢી નાખવા માંગતા હો, તો તમે git reset HEAD~1
શાખા નિર્દેશકને એક કમિટ દ્વારા પાછા ખસેડવા માટે ઉપયોગ કરી શકો છો.
Git માં આ અદ્યતન ખ્યાલો તમારી રીપોઝીટરીને અસરકારક રીતે સંચાલિત કરવા માટે શક્તિશાળી ક્ષમતાઓ પ્રદાન કરે છે. તેનો ઉપયોગ કેવી રીતે કરવો અને ક્યારે લાગુ કરવો તે સમજવું તમારા ગિટ વર્કફ્લો અને પ્રોજેક્ટ મેનેજમેન્ટને મોટા પ્રમાણમાં વધારશે.