Laravel Pennant ਦੀ "ਕਮਾਂਡ ਰਜਿਸਟਰਡ ਮਲਟੀਪਲ ਨਾਮਾਂ" ਗਲਤੀ ਨੂੰ ਠੀਕ ਕਰਨਾ

Laravel Pennant ਦੀ ਕਮਾਂਡ ਰਜਿਸਟਰਡ ਮਲਟੀਪਲ ਨਾਮਾਂ ਗਲਤੀ ਨੂੰ ਠੀਕ ਕਰਨਾ
Laravel Pennant ਦੀ ਕਮਾਂਡ ਰਜਿਸਟਰਡ ਮਲਟੀਪਲ ਨਾਮਾਂ ਗਲਤੀ ਨੂੰ ਠੀਕ ਕਰਨਾ

Laravel Pennant ਵਿੱਚ ਕਮਾਂਡ ਦੀਆਂ ਗਲਤੀਆਂ ਦਾ ਨਿਪਟਾਰਾ ਕਰਨਾ

ਨਾਲ ਕੰਮ ਕਰ ਰਿਹਾ ਹੈ Laravel Pennant ਕਈ ਵਾਰ ਅਚਾਨਕ ਚੁਣੌਤੀਆਂ ਪੇਸ਼ ਕਰ ਸਕਦੀਆਂ ਹਨ, ਖਾਸ ਕਰਕੇ ਜਦੋਂ ਨਵੇਂ ਪੈਕੇਜ ਏਕੀਕ੍ਰਿਤ ਹੁੰਦੇ ਹਨ। ਦੀ ਵਰਤੋਂ ਕਰਦੇ ਸਮੇਂ ਅਜਿਹਾ ਇੱਕ ਮੁੱਦਾ ਪੈਦਾ ਹੁੰਦਾ ਹੈ php ਕਾਰੀਗਰ ਟਿੰਕਰ ਨੂੰ ਇੰਸਟਾਲ ਕਰਨ ਤੋਂ ਬਾਅਦ ਕਮਾਂਡ Laravel Pennant v1.12.0 'ਤੇ ਲਾਰਵੇਲ 10.15.0. ਗਲਤੀ ਸੁਨੇਹਾ ਜੋ ਦਿਸਦਾ ਹੈ, "'pennant:purge|pennant:clear' ਕਮਾਂਡ ਨਹੀਂ ਲੱਭੀ ਜਾ ਸਕਦੀ ਕਿਉਂਕਿ ਇਹ ਕਈ ਨਾਵਾਂ ਹੇਠ ਰਜਿਸਟਰ ਕੀਤੀ ਗਈ ਹੈ," ਨੇ ਬਹੁਤ ਸਾਰੇ ਡਿਵੈਲਪਰਾਂ ਨੂੰ ਪਰੇਸ਼ਾਨ ਕਰ ਦਿੱਤਾ ਹੈ।

ਇਹ ਗਲਤੀ ਪਹਿਲਾਂ ਉਲਝਣ ਵਾਲੀ ਲੱਗ ਸਕਦੀ ਹੈ, ਖਾਸ ਕਰਕੇ ਜੇ ਤੁਸੀਂ ਇਸ ਗੱਲ ਤੋਂ ਜਾਣੂ ਨਹੀਂ ਹੋ ਕਿ ਕਾਰੀਗਰ ਕਮਾਂਡਾਂ ਕਿਵੇਂ ਰਜਿਸਟਰ ਕੀਤੀਆਂ ਜਾਂਦੀਆਂ ਹਨ। ਲਾਰਵੇਲ ਵਿੱਚ, ਕਮਾਂਡਾਂ ਨੂੰ ਕਈ ਉਪਨਾਮ ਦਿੱਤੇ ਜਾ ਸਕਦੇ ਹਨ, ਅਤੇ ਜਦੋਂ ਇਹਨਾਂ ਨੂੰ ਸਹੀ ਢੰਗ ਨਾਲ ਨਹੀਂ ਸੰਭਾਲਿਆ ਜਾਂਦਾ, ਤਾਂ ਵਿਵਾਦ ਪੈਦਾ ਹੁੰਦੇ ਹਨ। ਇਹ ਅਜਿਹੇ ਟਕਰਾਅ ਦਾ ਮਾਮਲਾ ਹੈ, ਪਰ ਸ਼ੁਕਰ ਹੈ, ਇਹ ਫਰੇਮਵਰਕ ਕਿਵੇਂ ਕੰਮ ਕਰਦਾ ਹੈ ਇਸ ਬਾਰੇ ਕੁਝ ਸਮਝ ਨਾਲ ਠੀਕ ਕੀਤਾ ਜਾ ਸਕਦਾ ਹੈ।

ਜੇਕਰ ਤੁਸੀਂ ਇਸ ਲਈ ਨਵੇਂ ਹੋ ਲਾਰਵੇਲ ਜਾਂ ਪਹਿਲਾਂ ਇਸ ਖਾਸ ਗਲਤੀ ਦਾ ਸਾਹਮਣਾ ਨਹੀਂ ਕੀਤਾ ਹੈ, ਚਿੰਤਾ ਨਾ ਕਰੋ। ਇਹ ਇੱਕ ਨਾਜ਼ੁਕ ਬੱਗ ਨਹੀਂ ਹੈ ਬਲਕਿ ਇੱਕ ਕਮਾਂਡ ਰਜਿਸਟ੍ਰੇਸ਼ਨ ਮੁੱਦਾ ਹੈ ਜਿਸ ਨੂੰ ਕੁਝ ਟਵੀਕਸ ਨਾਲ ਹੱਲ ਕੀਤਾ ਜਾ ਸਕਦਾ ਹੈ। ਇਹ ਸਮਝਣਾ ਕਿ ਅਜਿਹਾ ਕਿਉਂ ਹੁੰਦਾ ਹੈ ਅਤੇ ਸੁਚਾਰੂ ਵਿਕਾਸ ਲਈ ਸਹੀ ਹੱਲ ਜਾਣਨਾ ਜ਼ਰੂਰੀ ਹੈ।

ਇਸ ਗਾਈਡ ਵਿੱਚ, ਅਸੀਂ ਇਸ ਗਲਤੀ ਦੇ ਕਾਰਨਾਂ ਦੀ ਪੜਚੋਲ ਕਰਾਂਗੇ ਅਤੇ ਇਸਨੂੰ ਠੀਕ ਕਰਨ ਦੇ ਤਰੀਕੇ ਬਾਰੇ ਸਪਸ਼ਟ ਕਦਮ ਪ੍ਰਦਾਨ ਕਰਾਂਗੇ। ਇਸ ਲੇਖ ਦੇ ਅੰਤ ਤੱਕ, ਤੁਸੀਂ ਵਰਤੋਂ ਕਰਦੇ ਸਮੇਂ ਭਵਿੱਖ ਵਿੱਚ ਇਸ ਤਰ੍ਹਾਂ ਦੀਆਂ ਸਮੱਸਿਆਵਾਂ ਨੂੰ ਰੋਕਣ ਲਈ ਗਿਆਨ ਨਾਲ ਲੈਸ ਹੋ ਜਾਵੋਗੇ Laravel Pennant.

ਹੁਕਮ ਵਰਤੋਂ ਦੀ ਉਦਾਹਰਨ
app()->app()->extend() ਇਹ ਕਮਾਂਡ Laravel ਕੰਟੇਨਰ ਵਿੱਚ ਇੱਕ ਖਾਸ ਸੇਵਾ ਨੂੰ ਵਧਾਉਣ ਜਾਂ ਓਵਰਰਾਈਡ ਕਰਨ ਲਈ ਵਰਤੀ ਜਾਂਦੀ ਹੈ। ਇਸ ਲੇਖ ਦੇ ਸੰਦਰਭ ਵਿੱਚ, ਇਹ ਸਾਨੂੰ ਰਜਿਸਟਰਡ ਆਰਟਿਸਨ ਕਮਾਂਡ (ਉਦਾਹਰਨ ਲਈ, pennant:purge) ਦੇ ਵਿਹਾਰ ਨੂੰ ਨਵੀਂ ਕਾਰਜਸ਼ੀਲਤਾ ਨਿਰਧਾਰਤ ਕਰਕੇ ਜਾਂ ਇਸਦੀ ਮੌਜੂਦਾ ਕਾਰਜਕੁਸ਼ਲਤਾ ਨੂੰ ਬਦਲ ਕੇ ਸੰਸ਼ੋਧਿਤ ਕਰਨ ਦੀ ਆਗਿਆ ਦਿੰਦਾ ਹੈ।
Artisan::starting() ਇਹ ਕਮਾਂਡ ਆਰਟੀਸਨ ਕੰਸੋਲ ਦੀ ਸ਼ੁਰੂਆਤੀ ਪ੍ਰਕਿਰਿਆ ਨੂੰ ਅਨੁਕੂਲਿਤ ਜਾਂ ਸੰਸ਼ੋਧਿਤ ਕਰਨ ਲਈ ਜੋੜਦੀ ਹੈ ਕਿ ਕਮਾਂਡਾਂ ਕਿਵੇਂ ਰਜਿਸਟਰ ਕੀਤੀਆਂ ਜਾਂਦੀਆਂ ਹਨ। ਇਹ ਯਕੀਨੀ ਬਣਾਉਂਦਾ ਹੈ ਕਿ ਕੰਸੋਲ ਸ਼ੁਰੂ ਹੋਣ ਤੋਂ ਪਹਿਲਾਂ, ਕੁਝ ਕਮਾਂਡਾਂ (ਜਿਵੇਂ ਕਿ ਸਾਡੀ ਕਸਟਮ ਪੇਨੈਂਟ:ਪਰਜ ਅਤੇ ਪੇਨੈਂਟ:ਕਲੀਅਰ) ਬਿਨਾਂ ਕਿਸੇ ਵਿਵਾਦ ਦੇ ਸਹੀ ਢੰਗ ਨਾਲ ਰਜਿਸਟਰ ਕੀਤੀਆਂ ਗਈਆਂ ਹਨ।
resolveCommands() ਕੰਸੋਲ ਵਿੱਚ ਆਰਟੀਸਨ ਕਮਾਂਡਾਂ ਦੀ ਇੱਕ ਸੂਚੀ ਨੂੰ ਸਪਸ਼ਟ ਤੌਰ 'ਤੇ ਰਜਿਸਟਰ ਕਰਨ ਲਈ ਵਰਤਿਆ ਜਾਂਦਾ ਹੈ। ਇਹ ਉਦੋਂ ਮਹੱਤਵਪੂਰਨ ਹੁੰਦਾ ਹੈ ਜਦੋਂ ਕਮਾਂਡਾਂ ਵਿਚਕਾਰ ਸੰਭਾਵੀ ਟਕਰਾਅ ਹੁੰਦਾ ਹੈ। ਹੱਲ ਕੀਤੇ ਜਾਣ ਵਾਲੇ ਸਹੀ ਕਮਾਂਡਾਂ ਨੂੰ ਨਿਸ਼ਚਿਤ ਕਰਕੇ, ਅਸੀਂ ਇਹ ਸੁਨਿਸ਼ਚਿਤ ਕਰਦੇ ਹਾਂ ਕਿ ਜਦੋਂ ਬੁਲਾਇਆ ਜਾਂਦਾ ਹੈ ਤਾਂ ਸਹੀ ਕਮਾਂਡਾਂ ਨੂੰ ਚਲਾਇਆ ਜਾਂਦਾ ਹੈ।
artisan('command') ਲਾਰਵੇਲ ਦੇ ਟੈਸਟਿੰਗ ਫਰੇਮਵਰਕ ਵਿੱਚ, ਇਸ ਕਮਾਂਡ ਦੀ ਵਰਤੋਂ ਆਰਟੀਸਨ ਕਮਾਂਡਾਂ ਨੂੰ ਪ੍ਰੋਗਰਾਮੇਟਿਕ ਤੌਰ 'ਤੇ ਚਲਾਉਣ ਲਈ ਕੀਤੀ ਜਾਂਦੀ ਹੈ। ਇਹ ਜਾਂਚ ਕਰਨ ਵਿੱਚ ਮਦਦ ਕਰਦਾ ਹੈ ਕਿ ਕੀ ਕਮਾਂਡ ਉਮੀਦ ਅਨੁਸਾਰ ਵਿਹਾਰ ਕਰਦੀ ਹੈ, ਜਿਵੇਂ ਕਿ ਸਹੀ ਸੰਦੇਸ਼ ਨੂੰ ਆਉਟਪੁੱਟ ਕਰਨਾ ਜਾਂ ਗਲਤੀਆਂ ਤੋਂ ਬਿਨਾਂ ਪੂਰਾ ਕਰਨਾ।
expectsOutput() ਇਹ ਜਾਂਚ ਕਰਨ ਲਈ ਕਿ ਕੀ ਕਮਾਂਡ ਦਾ ਆਉਟਪੁੱਟ ਸੰਭਾਵਿਤ ਨਤੀਜੇ ਨਾਲ ਮੇਲ ਖਾਂਦਾ ਹੈ, ਕਾਰੀਗਰ() ਦੇ ਨਾਲ ਜੋੜ ਕੇ ਕੰਮ ਕਰਦਾ ਹੈ। ਇਸ ਸੰਦਰਭ ਵਿੱਚ, ਅਸੀਂ ਇਸਦੀ ਵਰਤੋਂ ਇਹ ਤਸਦੀਕ ਕਰਨ ਲਈ ਕਰਦੇ ਹਾਂ ਕਿ ਕਮਾਂਡਾਂ pennant:purge and pennant:clear ਆਊਟਪੁੱਟ ਸਹੀ ਸਫਲਤਾ ਸੰਦੇਸ਼ ਦਿੰਦੀਆਂ ਹਨ।
assertExitCode(0) ਇਹ ਕਮਾਂਡ ਜਾਂਚ ਕਰਦੀ ਹੈ ਕਿ ਆਰਟੀਸਨ ਕਮਾਂਡ ਸਫਲਤਾਪੂਰਵਕ ਬੰਦ ਹੋ ਗਈ ਹੈ (ਐਗਜ਼ਿਟ ਕੋਡ 0 ਦਾ ਮਤਲਬ ਕੋਈ ਗਲਤੀ ਨਹੀਂ ਹੈ)। ਇਹ ਪੁਸ਼ਟੀ ਕਰਨ ਲਈ ਖਾਸ ਤੌਰ 'ਤੇ ਮਹੱਤਵਪੂਰਨ ਹੈ ਕਿ ਕਮਾਂਡ ਐਗਜ਼ੀਕਿਊਸ਼ਨ ਫੇਲ ਨਹੀਂ ਹੋਈ ਅਤੇ ਉਮੀਦ ਮੁਤਾਬਕ ਪ੍ਰਦਰਸ਼ਨ ਕੀਤਾ ਗਿਆ।
signature Laravel ਕਮਾਂਡ ਕਲਾਸਾਂ ਵਿੱਚ, $signature ਆਰਟੀਸਨ ਕਮਾਂਡ ਲਈ ਨਾਮ ਅਤੇ ਇਨਪੁਟ ਪੈਰਾਮੀਟਰਾਂ ਨੂੰ ਪਰਿਭਾਸ਼ਿਤ ਕਰਦਾ ਹੈ। ਇਹ ਯਕੀਨੀ ਬਣਾਉਣ ਲਈ ਜ਼ਰੂਰੀ ਹੈ ਕਿ ਹਰੇਕ ਕਮਾਂਡ ਦਾ ਇੱਕ ਵਿਲੱਖਣ ਪਛਾਣਕਰਤਾ ਹੈ, ਜਿਸ ਤਰ੍ਹਾਂ ਦੇ ਵਿਵਾਦਾਂ ਨੂੰ ਰੋਕਦਾ ਹੈ ਜਿਵੇਂ ਅਸੀਂ ਇਸ ਗਾਈਡ ਵਿੱਚ ਹੱਲ ਕਰ ਰਹੇ ਹਾਂ।
handle() ਆਰਟੀਸਨ ਕਮਾਂਡ ਕਲਾਸ ਦੇ ਅੰਦਰ ਕੋਰ ਵਿਧੀ ਜਿੱਥੇ ਕਮਾਂਡ ਲਈ ਤਰਕ ਰਹਿੰਦਾ ਹੈ। ਸਾਡੀਆਂ ਉਦਾਹਰਣਾਂ ਵਿੱਚ, ਇਹ ਉਹ ਥਾਂ ਹੈ ਜਿੱਥੇ ਅਸੀਂ ਪਰਿਭਾਸ਼ਿਤ ਕਰਦੇ ਹਾਂ ਕਿ ਕੀ ਹੁੰਦਾ ਹੈ ਜਦੋਂ pennant:purge or pennant:clear ਕਮਾਂਡਾਂ ਚਲਾਈਆਂ ਜਾਂਦੀਆਂ ਹਨ, ਜਿਵੇਂ ਕਿ ਡੇਟਾ ਕਲੀਅਰ ਕਰਨਾ ਜਾਂ ਸਫਲਤਾ ਸੁਨੇਹੇ ਪ੍ਰਦਰਸ਼ਿਤ ਕਰਨਾ।

ਕਸਟਮ ਸਕ੍ਰਿਪਟਾਂ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਲਾਰਵੇਲ ਪੈਨੈਂਟ ਵਿੱਚ ਕਮਾਂਡ ਦੇ ਵਿਵਾਦਾਂ ਨੂੰ ਹੱਲ ਕਰਨਾ

ਪਹਿਲੀ ਸਕ੍ਰਿਪਟ ਉਦਾਹਰਨ ਵਿੱਚ, ਅਸੀਂ ਕਾਰੀਗਰ ਕਮਾਂਡ ਨਾਮ ਦੇ ਟਕਰਾਅ ਨੂੰ ਓਵਰਰਾਈਡ ਕਰਕੇ ਸੰਬੋਧਿਤ ਕੀਤਾ ਹੈ ਕਿ ਕਿਵੇਂ pennant: purge ਕਮਾਂਡ ਰਜਿਸਟਰਡ ਹੈ। ਦੀ ਵਰਤੋਂ ਕਰਦੇ ਹੋਏ app()->ਐਪ()->ਵਿਸਤਾਰ () ਵਿਧੀ, ਅਸੀਂ ਦਾ ਇੱਕ ਕਸਟਮ ਸੰਸਕਰਣ ਬਣਾਇਆ ਹੈ PurgeCommand ਅਤੇ ਇਹ ਸੁਨਿਸ਼ਚਿਤ ਕੀਤਾ ਕਿ ਇਹ ਲਾਰਵੇਲ ਕੰਟੇਨਰ ਦੇ ਅੰਦਰ ਵਿਲੱਖਣ ਤੌਰ 'ਤੇ ਸੰਭਾਲਿਆ ਗਿਆ ਹੈ। ਇਹ ਪਹੁੰਚ ਮਹੱਤਵਪੂਰਨ ਹੁੰਦੀ ਹੈ ਜਦੋਂ ਦੋ ਜਾਂ ਦੋ ਤੋਂ ਵੱਧ ਕਮਾਂਡਾਂ ਇੱਕੋ ਜਿਹੇ ਨਾਂ ਸਾਂਝੇ ਕਰਦੀਆਂ ਹਨ ਜਾਂ ਮਲਟੀਪਲ ਉਪਨਾਮਾਂ ਅਧੀਨ ਰਜਿਸਟਰ ਹੁੰਦੀਆਂ ਹਨ। ਡਿਫੌਲਟ ਰਜਿਸਟ੍ਰੇਸ਼ਨ ਨੂੰ ਓਵਰਰਾਈਡ ਕਰਕੇ, ਅਸੀਂ ਇਹ ਯਕੀਨੀ ਬਣਾਉਂਦੇ ਹਾਂ ਕਿ ਚਲਾਉਣ ਵੇਲੇ ਕੋਈ ਵਿਵਾਦ ਪੈਦਾ ਨਹੀਂ ਹੁੰਦਾ php ਕਾਰੀਗਰ ਹੁਕਮ. ਕੁੰਜੀ ਕਮਾਂਡ ਨੂੰ ਸੰਭਾਲਣ ਲਈ ਇੱਕ ਵਿਲੱਖਣ, ਸਪਸ਼ਟ ਤੌਰ 'ਤੇ ਪਰਿਭਾਸ਼ਿਤ ਢੰਗ ਪ੍ਰਦਾਨ ਕਰਨਾ ਹੈ।

ਦੂਜੀ ਸਕ੍ਰਿਪਟ ਦਾ ਲਾਭ ਉਠਾਉਂਦੀ ਹੈ ਕਾਰੀਗਰ::ਸ਼ੁਰੂ() ਵਿਧੀ, ਜੋ ਕਿ ਲਾਰਵੇਲ ਦੇ ਆਰਟੀਸਨ ਕੰਸੋਲ ਸਟਾਰਟਅਪ ਪ੍ਰਕਿਰਿਆ ਨੂੰ ਜੋੜਨ ਲਈ ਉਪਯੋਗੀ ਹੈ। ਇਹ ਸਾਨੂੰ ਕਸਟਮਾਈਜ਼ ਕਰਨ ਦੀ ਇਜਾਜ਼ਤ ਦਿੰਦਾ ਹੈ ਕਿ ਕਮਾਂਡਾਂ ਕਿਵੇਂ ਅਤੇ ਕਦੋਂ ਰਜਿਸਟਰ ਕੀਤੀਆਂ ਜਾਂਦੀਆਂ ਹਨ, ਖਾਸ ਕਰਕੇ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਰੈਜ਼ੋਲੂਸ਼ਨਕਮਾਂਡਸ() ਵਿਰੋਧੀ ਕਮਾਂਡਾਂ ਨੂੰ ਸਪਸ਼ਟ ਤੌਰ 'ਤੇ ਹੱਲ ਕਰਨ ਦਾ ਤਰੀਕਾ। ਇਹ ਵਿਧੀ ਕਮਾਂਡਾਂ ਨੂੰ ਸੂਚੀਬੱਧ ਕਰਕੇ ਕੰਮ ਕਰਦੀ ਹੈ (ਉਦਾਹਰਨ ਲਈ, PurgeCommand ਅਤੇ ClearCommand) ਅਤੇ ਇਹ ਯਕੀਨੀ ਬਣਾਉਣਾ ਕਿ ਹਰ ਇੱਕ ਸਹੀ ਢੰਗ ਨਾਲ ਰਜਿਸਟਰ ਕੀਤਾ ਗਿਆ ਹੈ। ਇਹ ਪਹੁੰਚ ਵਿਸ਼ੇਸ਼ ਤੌਰ 'ਤੇ ਲਾਭਦਾਇਕ ਹੋ ਸਕਦੀ ਹੈ ਜਦੋਂ ਤੁਹਾਡੇ ਕੋਲ ਕਈ ਕਮਾਂਡਾਂ ਹਨ ਜੋ ਸੰਭਾਵੀ ਤੌਰ 'ਤੇ ਟਕਰਾ ਸਕਦੀਆਂ ਹਨ ਜੇਕਰ ਉਹਨਾਂ ਦੇ ਦਸਤਖਤ ਵੱਖਰੇ ਤੌਰ 'ਤੇ ਸੈੱਟ ਨਹੀਂ ਕੀਤੇ ਗਏ ਹਨ।

ਤੀਸਰੀ ਸਕ੍ਰਿਪਟ ਵਿੱਚ, ਅਸੀਂ ਇਹ ਯਕੀਨੀ ਬਣਾਉਣ ਲਈ ਯੂਨਿਟ ਟੈਸਟਿੰਗ ਨੂੰ ਸ਼ਾਮਲ ਕੀਤਾ ਹੈ ਕਿ ਕਾਰੀਗਰ ਕਮਾਂਡ ਸੰਘਰਸ਼ ਨੂੰ ਹੱਲ ਕਰਨ ਵਿੱਚ ਕੀਤੀਆਂ ਤਬਦੀਲੀਆਂ ਪ੍ਰਭਾਵਸ਼ਾਲੀ ਸਨ। ਲਾਰਵੇਲ ਦੀ ਵਰਤੋਂ ਕਰਨਾ ਕਾਰੀਗਰ() ਟੈਸਟਿੰਗ ਵਿੱਚ ਵਿਧੀ, ਅਸੀਂ ਚਲਾ ਰਹੇ ਹਾਂ pennant: purge ਅਤੇ ਪੇਨੈਂਟ: ਸਪਸ਼ਟ ਕਮਾਂਡਾਂ, ਉਹਨਾਂ ਦੇ ਆਉਟਪੁੱਟ ਅਤੇ ਸਫਲਤਾ ਦੀ ਪੁਸ਼ਟੀ ਕਰਦੇ ਹੋਏ। ਦ ਉਮੀਦ ਆਉਟਪੁੱਟ() ਫੰਕਸ਼ਨ ਜਾਂਚ ਕਰਦਾ ਹੈ ਕਿ ਕੀ ਕਮਾਂਡ ਦਾ ਆਉਟਪੁੱਟ ਸਾਡੀਆਂ ਉਮੀਦਾਂ ਨਾਲ ਮੇਲ ਖਾਂਦਾ ਹੈ, ਜਦੋਂ ਕਿ assertExitCode(0) ਇਹ ਯਕੀਨੀ ਬਣਾਉਂਦਾ ਹੈ ਕਿ ਕਮਾਂਡ ਬਿਨਾਂ ਕਿਸੇ ਤਰੁੱਟੀ ਦੇ ਚਲਾਈ ਗਈ ਹੈ। ਇਹ ਜਾਂਚ ਪਹੁੰਚ ਇਸ ਗੱਲ ਦੀ ਪੁਸ਼ਟੀ ਕਰਨ ਵਿੱਚ ਮਦਦ ਕਰਦੀ ਹੈ ਕਿ ਵਿਰੋਧੀ ਕਮਾਂਡਾਂ 'ਤੇ ਲਾਗੂ ਕੀਤੇ ਹੱਲ ਵੱਖ-ਵੱਖ ਵਾਤਾਵਰਣਾਂ ਵਿੱਚ ਕਾਰਜਸ਼ੀਲ ਹਨ।

ਕੁੱਲ ਮਿਲਾ ਕੇ, ਇਹ ਹੱਲ ਨਾ ਸਿਰਫ਼ ਮਲਟੀਪਲ ਕਮਾਂਡ ਨਾਮਾਂ ਕਾਰਨ ਹੋਣ ਵਾਲੀ ਸ਼ੁਰੂਆਤੀ ਗਲਤੀ ਨੂੰ ਹੱਲ ਕਰਦੇ ਹਨ ਬਲਕਿ ਮਾਡਯੂਲਰ ਅਤੇ ਮੁੜ ਵਰਤੋਂ ਯੋਗ ਕੋਡ ਨੂੰ ਬਣਾਈ ਰੱਖਣ ਲਈ ਵਧੀਆ ਅਭਿਆਸਾਂ ਦੀ ਪਾਲਣਾ ਵੀ ਕਰਦੇ ਹਨ। ਹਰੇਕ ਕਮਾਂਡ ਦਾ ਇੱਕ ਖਾਸ ਦਸਤਖਤ ਹੁੰਦਾ ਹੈ, ਅਸਪਸ਼ਟਤਾ ਨੂੰ ਦੂਰ ਕਰਦਾ ਹੈ, ਅਤੇ ਯੂਨਿਟ ਟੈਸਟਾਂ ਦੀ ਵਰਤੋਂ ਇਹ ਯਕੀਨੀ ਬਣਾਉਂਦੀ ਹੈ ਕਿ ਕਮਾਂਡਾਂ ਉਮੀਦ ਅਨੁਸਾਰ ਕੰਮ ਕਰਦੀਆਂ ਹਨ। ਇਸ ਤੋਂ ਇਲਾਵਾ, ਕਮਾਂਡਾਂ ਅਤੇ ਕਾਰੀਗਰ ਰਜਿਸਟ੍ਰੇਸ਼ਨ ਪ੍ਰਕਿਰਿਆ ਨੂੰ ਮਾਡਿਊਲਰਾਈਜ਼ ਕਰਕੇ, ਅਸੀਂ ਇਹ ਯਕੀਨੀ ਬਣਾਉਂਦੇ ਹਾਂ ਕਿ ਭਵਿੱਖ ਦੇ ਅਪਡੇਟਾਂ ਵਿੱਚ ਇਹਨਾਂ ਫਿਕਸਾਂ ਨੂੰ ਆਸਾਨੀ ਨਾਲ ਵਧਾਇਆ ਜਾਂ ਸੋਧਿਆ ਜਾ ਸਕਦਾ ਹੈ। ਸਕ੍ਰਿਪਟ ਬਣਾਉਣ ਅਤੇ ਟੈਸਟਿੰਗ ਦਾ ਇਹ ਸੁਮੇਲ ਲਾਰਵੇਲ ਪੇਨੈਂਟ ਵਿੱਚ ਇੱਕ ਮਜ਼ਬੂਤ, ਸੰਘਰਸ਼-ਮੁਕਤ ਕਾਰੀਗਰ ਕਮਾਂਡ ਸੈੱਟਅੱਪ ਨੂੰ ਯਕੀਨੀ ਬਣਾਉਂਦਾ ਹੈ।

ਕਸਟਮ ਆਰਟੀਸਨ ਕਮਾਂਡ ਰਜਿਸਟ੍ਰੇਸ਼ਨ ਦੇ ਨਾਲ ਲਾਰਵੇਲ ਆਰਟੀਸਨ ਕਮਾਂਡ ਨਾਮ ਵਿਵਾਦ ਨੂੰ ਸੰਭਾਲਣਾ

ਪਹੁੰਚ 1: ਕਾਰੀਗਰ ਕਮਾਂਡ ਰਜਿਸਟ੍ਰੇਸ਼ਨ ਨੂੰ ਸੋਧਣ ਲਈ PHP ਦੀ ਵਰਤੋਂ ਕਰਨਾ

// Step 1: Locate the service provider where the command is registered
// This is typically found in the boot method of your service provider class
use Illuminate\Support\ServiceProvider;
use Illuminate\Console\Command;

class AppServiceProvider extends ServiceProvider {
    public function boot() {
        // Step 2: Override the default Artisan command registration
        $this->app->extend('command.pennant.purge', function() {
            return new PurgeCommand();
        });
    }
}

// Step 3: Define a new PurgeCommand with unique functionality
namespace App\Console\Commands;
use Illuminate\Console\Command;

class PurgeCommand extends Command {
    protected $signature = 'pennant:purge';
    protected $description = 'Clear Pennant data safely';

    public function handle() {
        // Handle command functionality here
        $this->info('Pennant data purged!');
    }
}

ਕਾਰੀਗਰ ਕਮਾਂਡਾਂ ਲਈ ਉਪਨਾਮ ਬਣਾ ਕੇ ਲਾਰਵੇਲ ਪੈਨੈਂਟ ਟਕਰਾਅ ਨੂੰ ਹੱਲ ਕਰਨਾ

ਪਹੁੰਚ 2: ਨਾਮ ਦੇ ਵਿਵਾਦਾਂ ਨੂੰ ਹੱਲ ਕਰਨ ਲਈ ਕਮਾਂਡ ਉਪਨਾਮ ਬਣਾਉਣਾ

// Step 1: Open your AppServiceProvider.php file and locate the boot method
use Illuminate\Support\ServiceProvider;
use Illuminate\Console\Application as Artisan;

class AppServiceProvider extends ServiceProvider {
    public function boot() {
        // Step 2: Create alias for the conflicting commands
        Artisan::starting(function ($artisan) {
            $artisan->resolveCommands([
                'App\Console\Commands\PurgeCommand',
                'App\Console\Commands\ClearCommand',
            ]);
        });
    }
}

// Step 3: Define each command uniquely with its own alias
namespace App\Console\Commands;
use Illuminate\Console\Command;

class ClearCommand extends Command {
    protected $signature = 'pennant:clear';
    protected $description = 'Clear cache for Pennant';

    public function handle() {
        // Clear cache logic here
        $this->info('Pennant cache cleared!');
    }
}

ਲਾਰਵੇਲ ਵਿੱਚ ਨਾਮ ਟਕਰਾਅ ਦੇ ਹੱਲ ਲਈ ਯੂਨਿਟ ਟੈਸਟਿੰਗ ਕਾਰੀਗਰ ਕਮਾਂਡਾਂ

ਪਹੁੰਚ 3: ਇਹ ਯਕੀਨੀ ਬਣਾਉਣ ਲਈ ਕਿ ਕਾਰੀਗਰ ਕਮਾਂਡਾਂ ਨੂੰ ਸਹੀ ਢੰਗ ਨਾਲ ਰਜਿਸਟਰ ਕੀਤਾ ਗਿਆ ਹੈ, ਲਿਖਣ ਦੇ ਯੂਨਿਟ ਟੈਸਟ

// Step 1: Set up PHPUnit test for the custom commands
namespace Tests\Feature;
use Illuminate\Foundation\Testing\RefreshDatabase;
use Tests\TestCase;

class ArtisanCommandTest extends TestCase {
    public function test_purge_command_executes_successfully() {
        // Step 2: Run Artisan command to test it
        $this->artisan('pennant:purge')
             ->expectsOutput('Pennant data purged!')
             ->assertExitCode(0);
    }

    public function test_clear_command_executes_successfully() {
        $this->artisan('pennant:clear')
             ->expectsOutput('Pennant cache cleared!')
             ->assertExitCode(0);
    }
}

Laravel Pennant ਵਿੱਚ ਕਾਰੀਗਰ ਕਮਾਂਡ ਰਜਿਸਟ੍ਰੇਸ਼ਨ ਟਕਰਾਅ ਨੂੰ ਸਮਝਣਾ

ਇੱਕ ਮਹੱਤਵਪੂਰਨ ਪਹਿਲੂ ਜਿਸ ਬਾਰੇ ਅਜੇ ਤੱਕ ਚਰਚਾ ਨਹੀਂ ਕੀਤੀ ਗਈ ਹੈ, ਵਿੱਚ ਗਲਤ ਸੰਰਚਿਤ ਸੇਵਾ ਪ੍ਰਦਾਤਾਵਾਂ ਦਾ ਸੰਭਾਵੀ ਪ੍ਰਭਾਵ ਹੈ ਲਾਰਵੇਲ. ਸੇਵਾ ਪ੍ਰਦਾਤਾ ਕੇਂਦਰੀ ਸਥਾਨ ਹਨ ਜਿੱਥੇ ਜ਼ਿਆਦਾਤਰ ਐਪਲੀਕੇਸ਼ਨ ਦੀ ਬੂਟਸਟਰੈਪਿੰਗ ਹੁੰਦੀ ਹੈ, ਅਤੇ ਦੇ ਮਾਮਲੇ ਵਿੱਚ ਕਾਰੀਗਰ ਕਮਾਂਡਾਂ, ਉਹ ਕਮਾਂਡਾਂ ਨੂੰ ਸਹੀ ਢੰਗ ਨਾਲ ਰਜਿਸਟਰ ਕਰਨ ਲਈ ਵੀ ਜ਼ਿੰਮੇਵਾਰ ਹਨ। ਜੇ ਕਮਾਂਡਾਂ ਪਸੰਦ ਹਨ pennant: purge ਅਤੇ ਪੇਨੈਂਟ: ਸਾਫ ਵਿਲੱਖਣ ਤੌਰ 'ਤੇ ਰਜਿਸਟਰਡ ਨਹੀਂ ਹਨ, ਜਦੋਂ ਤੁਸੀਂ ਇਹਨਾਂ ਕਮਾਂਡਾਂ ਨੂੰ ਚਲਾਉਣ ਦੀ ਕੋਸ਼ਿਸ਼ ਕਰਦੇ ਹੋ ਤਾਂ ਇੱਕ ਵਿਵਾਦ ਪੈਦਾ ਹੋਵੇਗਾ php artisan tinker.

ਸਮੱਸਿਆ ਦਾ ਇੱਕ ਹੋਰ ਸੰਭਵ ਕਾਰਨ ਪੁਰਾਣਾ ਹੋ ਸਕਦਾ ਹੈ ਲਾਰਵੇਲ ਸੰਸਕਰਣ ਜਾਂ ਪੈਕੇਜ। Laravel ਅਤੇ ਸੰਬੰਧਿਤ ਪੈਕੇਜਾਂ ਨੂੰ ਰੱਖਣਾ ਪੈਨੈਂਟ ਅੱਪ ਟੂ ਡੇਟ ਮਹੱਤਵਪੂਰਨ ਹੈ ਕਿਉਂਕਿ ਜਦੋਂ ਤੁਸੀਂ ਵੱਖ-ਵੱਖ ਸੰਸਕਰਣਾਂ ਦੇ ਮਿਸ਼ਰਣ ਦੀ ਵਰਤੋਂ ਕਰਦੇ ਹੋ ਤਾਂ ਅਕਸਰ ਵਿਵਾਦ ਪੈਦਾ ਹੁੰਦੇ ਹਨ। ਚਲਾ ਕੇ composer update ਨਿਯਮਿਤ ਤੌਰ 'ਤੇ ਕਮਾਂਡ, ਤੁਸੀਂ ਇਹ ਯਕੀਨੀ ਬਣਾਉਂਦੇ ਹੋ ਕਿ ਤੁਸੀਂ Laravel ਪੈਕੇਜਾਂ ਦੇ ਨਵੀਨਤਮ ਅਤੇ ਸਭ ਤੋਂ ਅਨੁਕੂਲ ਸੰਸਕਰਣਾਂ ਦੀ ਵਰਤੋਂ ਕਰ ਰਹੇ ਹੋ, ਜੋ ਅਜਿਹੇ ਕਮਾਂਡ ਅਪਵਾਦ ਦੇ ਜੋਖਮ ਨੂੰ ਘਟਾਉਂਦਾ ਹੈ।

ਅੰਤ ਵਿੱਚ, Laravel ਦਾ ਹੁਕਮ ਕੈਸ਼ਿੰਗ ਸਿਸਟਮ ਵੀ ਇੱਕ ਕਾਰਕ ਹੋ ਸਕਦਾ ਹੈ. ਜਦੋਂ ਤੁਸੀਂ ਕਮਾਂਡਾਂ ਜਾਂ ਸੇਵਾ ਪ੍ਰਦਾਤਾਵਾਂ ਨੂੰ ਸੰਸ਼ੋਧਿਤ ਕਰਦੇ ਹੋ, ਤਾਂ Laravel ਉਹਨਾਂ ਤਬਦੀਲੀਆਂ ਨੂੰ ਕੈਸ਼ ਕਰਦਾ ਹੈ। ਸੋਧਾਂ ਕਰਨ ਤੋਂ ਬਾਅਦ ਕੈਸ਼ ਨੂੰ ਸਾਫ਼ ਕਰਨ ਵਿੱਚ ਅਸਫਲ ਰਹਿਣ ਦੇ ਨਤੀਜੇ ਵਜੋਂ ਸਿਸਟਮ ਅਜੇ ਵੀ ਕਮਾਂਡਾਂ ਦੇ ਪੁਰਾਣੇ, ਵਿਰੋਧੀ ਸੰਸਕਰਣਾਂ ਨੂੰ ਲੋਡ ਕਰਨ ਦੀ ਕੋਸ਼ਿਸ਼ ਕਰ ਰਿਹਾ ਹੈ। ਤੁਸੀਂ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਕੈਸ਼ ਨੂੰ ਸਾਫ਼ ਕਰ ਸਕਦੇ ਹੋ php artisan cache:clear ਇਹ ਯਕੀਨੀ ਬਣਾਉਣ ਲਈ ਕਮਾਂਡ ਹੈ ਕਿ ਸਿਸਟਮ ਅੱਪਡੇਟ ਕੀਤੀ ਸੰਰਚਨਾ ਨੂੰ ਚਲਾਉਂਦਾ ਹੈ। ਕਮਾਂਡ ਅਪਵਾਦਾਂ ਨੂੰ ਡੀਬੱਗ ਕਰਨ ਵੇਲੇ ਇਹ ਇੱਕ ਜ਼ਰੂਰੀ ਕਦਮ ਹੈ।

Laravel ਵਿੱਚ Artisan Command Conflicts ਬਾਰੇ ਆਮ ਪੁੱਛੇ ਜਾਂਦੇ ਸਵਾਲ

  1. "ਮਲਟੀਪਲ ਨਾਵਾਂ ਦੇ ਤਹਿਤ ਰਜਿਸਟਰਡ ਕਮਾਂਡ" ਗਲਤੀ ਦਾ ਕੀ ਅਰਥ ਹੈ?
  2. ਇਹ ਗਲਤੀ ਉਦੋਂ ਵਾਪਰਦੀ ਹੈ ਜਦੋਂ ਦੋ ਜਾਂ ਵੱਧ Artisan ਕਮਾਂਡਾਂ ਇੱਕੋ ਨਾਮ ਨੂੰ ਸਾਂਝਾ ਕਰਦੀਆਂ ਹਨ, ਜਿਸ ਨਾਲ ਲਾਰਵੇਲ ਕਮਾਂਡ ਰਜਿਸਟਰੀ ਵਿੱਚ ਵਿਵਾਦ ਪੈਦਾ ਹੁੰਦਾ ਹੈ।
  3. ਮੈਂ ਆਰਟੀਸਨ ਕਮਾਂਡਾਂ ਵਿਚਕਾਰ ਨਾਮ ਦੇ ਵਿਵਾਦ ਨੂੰ ਕਿਵੇਂ ਹੱਲ ਕਰਾਂ?
  4. ਤੁਸੀਂ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਕਮਾਂਡ ਰਜਿਸਟ੍ਰੇਸ਼ਨ ਨੂੰ ਓਵਰਰਾਈਡ ਕਰ ਸਕਦੇ ਹੋ app()->extend() ਵਿਧੀ ਜਾਂ ਹਰੇਕ ਕਮਾਂਡ ਲਈ ਵਿਲੱਖਣ ਉਪਨਾਮ ਪਰਿਭਾਸ਼ਿਤ ਕਰੋ।
  5. ਲਾਰਵੇਲ ਪੇਨੈਂਟ ਵਿੱਚ ਆਰਟੀਸਨ ਕਮਾਂਡ ਦੇ ਟਕਰਾਅ ਦਾ ਕੀ ਕਾਰਨ ਹੈ?
  6. ਟਕਰਾਅ ਆਮ ਤੌਰ 'ਤੇ ਸੇਵਾ ਪ੍ਰਦਾਤਾਵਾਂ ਵਿੱਚ ਡੁਪਲੀਕੇਟ ਰਜਿਸਟ੍ਰੇਸ਼ਨਾਂ ਜਾਂ ਇੱਕੋ ਨਾਮ ਹੇਠ ਕਈ ਕਮਾਂਡਾਂ ਦੇ ਰਜਿਸਟਰ ਹੋਣ ਕਾਰਨ ਹੁੰਦਾ ਹੈ।
  7. ਕੀ ਮੈਨੂੰ ਕਮਾਂਡ ਅਪਵਾਦ ਨੂੰ ਠੀਕ ਕਰਨ ਲਈ Laravel ਨੂੰ ਅਪਡੇਟ ਕਰਨਾ ਚਾਹੀਦਾ ਹੈ?
  8. ਹਾਂ, ਰੱਖਣਾ Laravel ਅਤੇ ਇਸਦੇ ਅੱਪ-ਟੂ-ਡੇਟ ਪੈਕੇਜ ਸੰਸਕਰਣ-ਸਬੰਧਤ ਵਿਵਾਦਾਂ ਨੂੰ ਰੋਕ ਸਕਦੇ ਹਨ ਅਤੇ ਮੌਜੂਦਾ ਨੂੰ ਠੀਕ ਕਰ ਸਕਦੇ ਹਨ।
  9. ਕਮਾਂਡਾਂ ਨੂੰ ਸੋਧਣ ਤੋਂ ਬਾਅਦ ਕੈਸ਼ ਨੂੰ ਸਾਫ਼ ਕਰਨਾ ਮਹੱਤਵਪੂਰਨ ਕਿਉਂ ਹੈ?
  10. php artisan cache:clear ਕਮਾਂਡ ਇਹ ਯਕੀਨੀ ਬਣਾਉਂਦੀ ਹੈ ਕਿ ਕਮਾਂਡ ਰਜਿਸਟ੍ਰੇਸ਼ਨ ਜਾਂ ਸੰਰਚਨਾ ਵਿੱਚ ਕੋਈ ਤਬਦੀਲੀ ਤੁਰੰਤ ਲਾਗੂ ਕੀਤੀ ਜਾਂਦੀ ਹੈ, ਕੈਸ਼ ਕੀਤੇ ਸੰਸਕਰਣਾਂ ਨਾਲ ਟਕਰਾਅ ਤੋਂ ਬਚਦੇ ਹੋਏ।

ਕਾਰੀਗਰ ਕਮਾਂਡ ਦੇ ਟਕਰਾਅ ਨੂੰ ਹੱਲ ਕਰਨ ਬਾਰੇ ਅੰਤਿਮ ਵਿਚਾਰ

ਇਹ ਤਰੁੱਟੀ Laravel Pennant ਨਾਲ ਕੰਮ ਕਰਨ ਵਾਲੇ ਡਿਵੈਲਪਰਾਂ ਲਈ ਨਿਰਾਸ਼ਾਜਨਕ ਹੋ ਸਕਦੀ ਹੈ, ਪਰ ਕਮਾਂਡ ਰਜਿਸਟ੍ਰੇਸ਼ਨ ਅਭਿਆਸਾਂ ਨੂੰ ਸੋਧ ਕੇ ਇਸ ਨੂੰ ਹੱਲ ਕਰਨਾ ਸੰਭਵ ਹੈ। ਸੇਵਾ ਪ੍ਰਦਾਤਾਵਾਂ ਅਤੇ ਕਮਾਂਡ ਐਕਸਟੈਂਸ਼ਨਾਂ ਦੇ ਨਾਲ ਲਾਰਵੇਲ ਦੀ ਲਚਕਤਾ ਇਹਨਾਂ ਵਿਵਾਦਾਂ ਤੋਂ ਬਚਣ ਦੇ ਤਰੀਕੇ ਪੇਸ਼ ਕਰਦੀ ਹੈ।

ਕੈਸ਼ ਨੂੰ ਸਾਫ਼ ਕਰਨਾ ਅਤੇ ਨਿਯਮਿਤ ਤੌਰ 'ਤੇ ਅੱਪਡੇਟ ਕਰਨਾ ਲਾਰਵੇਲ ਪੈਕੇਜ ਵਾਧੂ ਕਦਮ ਹਨ ਜੋ ਕਿ ਇੱਕ ਵਿਵਾਦ-ਮੁਕਤ ਵਾਤਾਵਰਣ ਨੂੰ ਬਣਾਈ ਰੱਖਣ ਵਿੱਚ ਮਦਦ ਕਰਦੇ ਹਨ। ਇਹਨਾਂ ਕਦਮਾਂ ਦੀ ਪਾਲਣਾ ਕਰਨ ਨਾਲ ਇਹ ਯਕੀਨੀ ਹੁੰਦਾ ਹੈ ਕਿ ਤੁਹਾਡੇ ਵਿਕਾਸ ਕਾਰਜ ਪ੍ਰਵਾਹ ਵਿੱਚ ਆਵਰਤੀ ਕਮਾਂਡ ਸਮੱਸਿਆਵਾਂ ਦੇ ਬਿਨਾਂ ਸੁਚਾਰੂ ਢੰਗ ਨਾਲ ਜਾਰੀ ਰਹੇ ਲਾਰਵੇਲ.

Laravel ਕਮਾਂਡ ਟਕਰਾਅ ਲਈ ਹਵਾਲੇ ਅਤੇ ਸਰੋਤ
  1. ਕਮਾਂਡ ਰਜਿਸਟ੍ਰੇਸ਼ਨ ਅਤੇ ਸੇਵਾ ਪ੍ਰਦਾਤਾਵਾਂ 'ਤੇ ਲਾਰਵੇਲ ਦਸਤਾਵੇਜ਼। ਵਧੇਰੇ ਵਿਸਤ੍ਰਿਤ ਜਾਣਕਾਰੀ ਲਈ, 'ਤੇ ਅਧਿਕਾਰਤ Laravel ਦਸਤਾਵੇਜ਼ਾਂ 'ਤੇ ਜਾਓ ਲਾਰਵੇਲ ਆਰਟੀਸਨ ਕਮਾਂਡਾਂ .
  2. Laravel Pennant GitHub ਰਿਪੋਜ਼ਟਰੀ ਜਿੱਥੇ Laravel Pennant ਨਾਲ ਸਬੰਧਤ ਅੱਪਡੇਟ ਅਤੇ ਮੁੱਦਿਆਂ ਨੂੰ ਟਰੈਕ ਕੀਤਾ ਜਾ ਸਕਦਾ ਹੈ। ਮੁਲਾਕਾਤ Laravel Pennant GitHub ਸਰੋਤ ਵੇਰਵਿਆਂ ਲਈ।
  3. ਆਰਟੀਸਨ ਕਮਾਂਡਾਂ ਵਿਚਕਾਰ ਵਿਵਾਦਾਂ ਨੂੰ ਸੁਲਝਾਉਣ 'ਤੇ ਸਟੈਕ ਓਵਰਫਲੋ ਚਰਚਾ। 'ਤੇ ਸੰਬੰਧਿਤ ਹੱਲਾਂ ਦੀ ਜਾਂਚ ਕਰੋ ਸਟੈਕ ਓਵਰਫਲੋ ਲਾਰਵੇਲ ਟੈਗ .