ਫਲਟਰ ਬਿਲਡ ਤਰੁਟੀਆਂ ਨੂੰ ਹੱਲ ਕਰਨਾ: ਪਲੱਗਇਨ ਅਤੇ ਸੰਕਲਨ ਸਮੱਸਿਆਵਾਂ ਦਾ ਨਿਪਟਾਰਾ ਕਰਨਾ

ਫਲਟਰ ਬਿਲਡ ਤਰੁਟੀਆਂ ਨੂੰ ਹੱਲ ਕਰਨਾ: ਪਲੱਗਇਨ ਅਤੇ ਸੰਕਲਨ ਸਮੱਸਿਆਵਾਂ ਦਾ ਨਿਪਟਾਰਾ ਕਰਨਾ
ਫਲਟਰ ਬਿਲਡ ਤਰੁਟੀਆਂ ਨੂੰ ਹੱਲ ਕਰਨਾ: ਪਲੱਗਇਨ ਅਤੇ ਸੰਕਲਨ ਸਮੱਸਿਆਵਾਂ ਦਾ ਨਿਪਟਾਰਾ ਕਰਨਾ

ਤੁਹਾਡੀ ਫਲਟਰ ਬਿਲਡ ਪ੍ਰਕਿਰਿਆ ਵਿੱਚ ਅਚਾਨਕ ਗਲਤੀਆਂ ਦਾ ਸਾਹਮਣਾ ਕਰ ਰਹੇ ਹੋ?

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

ਪਹਿਲੀ ਰੁਕਾਵਟ ਉਦੋਂ ਪ੍ਰਗਟ ਹੋਈ ਜਦੋਂ ਮੈਂ ਆਪਣੇ ਪ੍ਰੋਜੈਕਟ ਨੂੰ ਦੁਬਾਰਾ ਬਣਾਉਣ ਦੀ ਕੋਸ਼ਿਸ਼ ਕੀਤੀ। ਸ਼ੁਰੂ ਵਿੱਚ, ਇਹ ਮੁੱਦਾ ਇੱਕ ਪੁਰਾਣੇ ਪਲੱਗਇਨ ਨਾਲ ਜੁੜਿਆ ਜਾਪਦਾ ਸੀ, ਖਾਸ ਤੌਰ 'ਤੇ "ਸ਼ਾਨਦਾਰ ਸੂਚਨਾਵਾਂ" ਪਲੱਗਇਨ। ਇਸਨੂੰ ਨਵੀਨਤਮ ਸੰਸਕਰਣ (0.10.0) ਵਿੱਚ ਅੱਪਡੇਟ ਕਰਨ ਤੋਂ ਬਾਅਦ, ਮੈਨੂੰ ਇੱਕ ਨਿਰਵਿਘਨ ਪ੍ਰਕਿਰਿਆ ਦੀ ਉਮੀਦ ਸੀ। ਹਾਲਾਂਕਿ, ਅਜਿਹਾ ਨਹੀਂ ਸੀ।

ਸਮੱਸਿਆ ਨੂੰ ਹੱਲ ਕਰਨ ਦੀ ਬਜਾਏ, ਪਲੱਗਇਨ ਨੂੰ ਅੱਪਡੇਟ ਕਰਨ ਨਾਲ ਨਵੀਆਂ ਗਲਤੀਆਂ ਆਈਆਂ। ਇਸ ਵਾਰ, D8 ਬਿਲਡ ਪ੍ਰਕਿਰਿਆ ਦੇ ਦੌਰਾਨ ਮੈਨੂੰ ਕਈ `java.lang.NullPointerException` ਗਲਤੀਆਂ ਨਾਲ ਸਵਾਗਤ ਕੀਤਾ ਗਿਆ ਸੀ। ਇਹ ਤਰੁੱਟੀਆਂ ਗ੍ਰੇਡਲ ਕੈਸ਼ ਦੇ ਅੰਦਰ ਡੂੰਘੇ ਨੇਸਟ ਕੀਤੀਆਂ ਗਈਆਂ ਸਨ, ਜਿਸ ਨਾਲ ਸਮੱਸਿਆ ਨਿਪਟਾਰਾ ਕਰਨ ਦੀ ਗੁੰਝਲਤਾ ਵਧ ਗਈ ਸੀ।

ਜੇਕਰ ਤੁਸੀਂ ਕਦੇ ਵੀ ਅਜਿਹੀ ਸਥਿਤੀ ਵਿੱਚ ਫਸ ਗਏ ਹੋ, ਤਾਂ ਤੁਹਾਨੂੰ ਪਤਾ ਲੱਗੇਗਾ ਕਿ ਇਹ ਕਿੰਨੀ ਡਰੇਨਿੰਗ ਹੋ ਸਕਦੀ ਹੈ। ਪਰ ਡਰੋ ਨਾ—ਹਰ ਸਮੱਸਿਆ ਦਾ ਇੱਕ ਹੱਲ ਹੁੰਦਾ ਹੈ, ਅਤੇ ਬਿਲਡ ਗਲਤੀਆਂ ਨਾਲ ਨਜਿੱਠਣ ਵਿੱਚ ਅਕਸਰ ਧਿਆਨ ਨਾਲ ਡੀਬੱਗਿੰਗ ਅਤੇ ਥੋੜਾ ਸਬਰ ਸ਼ਾਮਲ ਹੁੰਦਾ ਹੈ। ਆਓ ਮਿਲ ਕੇ ਇਸ ਮੁੱਦੇ ਨੂੰ ਹੱਲ ਕਰਨ ਲਈ ਡੂੰਘਾਈ ਵਿੱਚ ਡੁਬਕੀ ਕਰੀਏ! 🚀

ਹੁਕਮ ਵਰਤੋਂ ਦੀ ਉਦਾਹਰਨ
deleteRecursively() ਇੱਕ ਕੋਟਲਿਨ ਫੰਕਸ਼ਨ ਇੱਕ ਡਾਇਰੈਕਟਰੀ ਅਤੇ ਇਸ ਦੀਆਂ ਸਮੱਗਰੀਆਂ ਨੂੰ ਵਾਰ-ਵਾਰ ਮਿਟਾਉਣ ਲਈ ਵਰਤਿਆ ਜਾਂਦਾ ਹੈ। ਖਰਾਬ ਫਾਈਲਾਂ ਨੂੰ ਹੱਲ ਕਰਨ ਲਈ ਗ੍ਰੇਡਲ ਕੈਸ਼ ਨੂੰ ਪੂਰੀ ਤਰ੍ਹਾਂ ਸਾਫ਼ ਕਰਨ ਲਈ ਜ਼ਰੂਰੀ।
File() ਕੋਟਲਿਨ ਵਿੱਚ, ਫਾਈਲ ਕਲਾਸ ਦੀ ਵਰਤੋਂ ਫਾਈਲ ਮਾਰਗਾਂ ਨੂੰ ਹੇਰਾਫੇਰੀ ਕਰਨ ਲਈ ਕੀਤੀ ਜਾਂਦੀ ਹੈ। ਇੱਥੇ, ਇਹ ਮਿਟਾਉਣ ਵਰਗੀਆਂ ਕਾਰਵਾਈਆਂ ਲਈ ਗ੍ਰੇਡਲ ਕੈਸ਼ ਡਾਇਰੈਕਟਰੀ ਦੀ ਪਛਾਣ ਕਰਦਾ ਹੈ।
./gradlew clean ਇੱਕ ਗ੍ਰੇਡਲ ਕਮਾਂਡ ਜੋ ਬਿਲਡ ਡਾਇਰੈਕਟਰੀ ਵਿੱਚ ਸਾਰੀਆਂ ਕੈਸ਼ ਕੀਤੀਆਂ ਫਾਈਲਾਂ ਅਤੇ ਅਸਥਾਈ ਡੇਟਾ ਨੂੰ ਹਟਾਉਂਦੀ ਹੈ, ਇੱਕ ਸਾਫ਼ ਬਿਲਡ ਵਾਤਾਵਰਣ ਨੂੰ ਯਕੀਨੀ ਬਣਾਉਂਦੀ ਹੈ।
--refresh-dependencies ਇਹ ਗ੍ਰੇਡਲ ਵਿਕਲਪ ਸਾਰੀਆਂ ਨਿਰਭਰਤਾਵਾਂ ਨੂੰ ਤਾਜ਼ਾ ਕਰਨ ਲਈ ਮਜਬੂਰ ਕਰਦਾ ਹੈ, ਇਹ ਯਕੀਨੀ ਬਣਾਉਂਦਾ ਹੈ ਕਿ ਬਿਲਡ ਪ੍ਰਕਿਰਿਆ ਲਾਇਬ੍ਰੇਰੀਆਂ ਦੇ ਨਵੀਨਤਮ ਅਤੇ ਸਹੀ ਸੰਸਕਰਣਾਂ ਦੀ ਵਰਤੋਂ ਕਰਦੀ ਹੈ।
rm -rf ਇੱਕ ਯੂਨਿਕਸ ਸ਼ੈੱਲ ਕਮਾਂਡ ਜੋ ਫਾਈਲਾਂ ਅਤੇ ਡਾਇਰੈਕਟਰੀਆਂ ਨੂੰ ਜ਼ਬਰਦਸਤੀ ਅਤੇ ਵਾਰ-ਵਾਰ ਹਟਾਉਣ ਲਈ ਵਰਤੀ ਜਾਂਦੀ ਹੈ। ਖਰਾਬ ਗ੍ਰੇਡਲ ਕੈਚਾਂ ਨੂੰ ਸਾਫ਼ ਕਰਨ ਲਈ ਮਹੱਤਵਪੂਰਨ।
import 'package:test/test.dart'; ਯੂਨਿਟ ਟੈਸਟਿੰਗ ਲਈ ਵਰਤਿਆ ਜਾਣ ਵਾਲਾ ਡਾਰਟ ਪੈਕੇਜ ਆਯਾਤ। ਇਹ ਬਿਲਡ ਪ੍ਰਕਿਰਿਆ ਨੂੰ ਪ੍ਰਮਾਣਿਤ ਕਰਨ ਲਈ ਟੈਸਟ ਕੇਸਾਂ ਨੂੰ ਬਣਾਉਣ ਦੇ ਯੋਗ ਬਣਾਉਂਦਾ ਹੈ।
expect() ਇੱਕ ਡਾਰਟ ਫੰਕਸ਼ਨ ਯੂਨਿਟ ਟੈਸਟਾਂ ਵਿੱਚ ਇਹ ਦਾਅਵਾ ਕਰਨ ਲਈ ਵਰਤਿਆ ਜਾਂਦਾ ਹੈ ਕਿ ਇੱਕ ਖਾਸ ਸਥਿਤੀ ਸਹੀ ਹੈ। ਇਹ ਯਕੀਨੀ ਬਣਾਉਂਦਾ ਹੈ ਕਿ ਸਿਮੂਲੇਟਿਡ ਗ੍ਰੇਡਲ ਬਿਲਡ ਉਮੀਦ ਕੀਤੇ ਨਤੀਜੇ ਪੈਦਾ ਕਰਦਾ ਹੈ।
println() ਕੰਸੋਲ ਉੱਤੇ ਸੁਨੇਹੇ ਪ੍ਰਿੰਟ ਕਰਨ ਲਈ ਇੱਕ ਕੋਟਲਿਨ ਫੰਕਸ਼ਨ। ਇੱਥੇ ਡੀਬੱਗਿੰਗ ਅਤੇ ਕੈਸ਼-ਕਲੀਅਰਿੰਗ ਓਪਰੇਸ਼ਨਾਂ ਦੀ ਸਫਲਤਾ ਦੀ ਪੁਸ਼ਟੀ ਕਰਨ ਲਈ ਵਰਤਿਆ ਜਾਂਦਾ ਹੈ।
Future.value() ਗ੍ਰੇਡਲ ਵਾਤਾਵਰਣ ਵਿੱਚ ਅਸਿੰਕ ਬਿਲਡ ਪ੍ਰਕਿਰਿਆਵਾਂ ਦੀ ਨਕਲ ਕਰਦੇ ਹੋਏ, ਇੱਕ ਮੁੱਲ ਦੇ ਨਾਲ ਇੱਕ ਭਵਿੱਖ ਨੂੰ ਵਾਪਸ ਕਰਨ ਲਈ ਇੱਕ ਡਾਰਟ ਵਿਸ਼ੇਸ਼ਤਾ।
deleteRecursively() ਇਹ ਯਕੀਨੀ ਬਣਾਉਣ ਲਈ ਕੋਟਲਿਨ ਸਕ੍ਰਿਪਟਾਂ ਤੋਂ ਦੁਬਾਰਾ ਵਰਤਿਆ ਜਾਂਦਾ ਹੈ ਕਿ ਖਾਸ ਮਾਰਗ ਪੂਰੀ ਤਰ੍ਹਾਂ ਹਟਾਏ ਗਏ ਹਨ। ਇਹ ਕਮਾਂਡ ਬਿਲਡ ਆਰਟੀਫੈਕਟਾਂ ਨੂੰ ਸੁਰੱਖਿਅਤ ਢੰਗ ਨਾਲ ਸਾਫ਼ ਕਰਨ ਲਈ ਮਹੱਤਵਪੂਰਨ ਹੈ।

ਮਾਡਿਊਲਰ ਸਕ੍ਰਿਪਟਾਂ ਨਾਲ ਫਲਟਰ ਬਿਲਡ ਮੁੱਦਿਆਂ ਨੂੰ ਸਮਝਣਾ ਅਤੇ ਹੱਲ ਕਰਨਾ

ਫਲਟਰ ਵਿੱਚ ਨਿਰੰਤਰ ਨਿਰਮਾਣ ਮੁੱਦਿਆਂ ਨੂੰ ਹੱਲ ਕਰਨ ਲਈ, ਪ੍ਰਦਾਨ ਕੀਤੀਆਂ ਸਕ੍ਰਿਪਟਾਂ ਗ੍ਰੇਡਲ ਕੈਸ਼ ਨੂੰ ਸਾਫ਼ ਕਰਨ, ਨਿਰਭਰਤਾ ਨੂੰ ਤਾਜ਼ਾ ਕਰਨ, ਅਤੇ ਨਿਰਵਿਘਨ ਪ੍ਰੋਜੈਕਟ ਸੰਕਲਨ ਨੂੰ ਯਕੀਨੀ ਬਣਾਉਣ 'ਤੇ ਕੇਂਦ੍ਰਤ ਕਰਦੀਆਂ ਹਨ। ਕੋਟਲਿਨ ਸਕ੍ਰਿਪਟ Gradle ਕੈਸ਼ ਡਾਇਰੈਕਟਰੀ ਵਿੱਚ ਸਾਰੀਆਂ ਨਿਕਾਰਾ ਫਾਈਲਾਂ ਨੂੰ ਸਾਫ਼ ਕਰਨ ਲਈ `deleteRecursively()` ਫੰਕਸ਼ਨ ਦੀ ਵਰਤੋਂ ਕਰਦੀ ਹੈ। ਇਹ ਓਪਰੇਸ਼ਨ ਯਕੀਨੀ ਬਣਾਉਂਦਾ ਹੈ ਕਿ ਬਿਲਡ ਪ੍ਰਕਿਰਿਆ ਪੁਰਾਣੀ ਜਾਂ ਟੁੱਟੀਆਂ ਨਿਰਭਰਤਾਵਾਂ 'ਤੇ ਭਰੋਸਾ ਨਹੀਂ ਕਰਦੀ ਹੈ। ਉਦਾਹਰਨ ਲਈ, ਜੇਕਰ ਕੋਈ ਗਲਤੀ ਕਿਸੇ ਖਾਸ 'ਟ੍ਰਾਂਸਫਾਰਮ' ਫੋਲਡਰ ਵੱਲ ਇਸ਼ਾਰਾ ਕਰਦੀ ਹੈ, ਤਾਂ ਇਸਨੂੰ ਗ੍ਰੇਡਲ ਸਿੰਕ ਦੁਆਰਾ ਹਟਾਉਣਾ ਅਤੇ ਦੁਬਾਰਾ ਬਣਾਉਣਾ ਅਕਸਰ ਸਮੱਸਿਆ ਨੂੰ ਹੱਲ ਕਰਦਾ ਹੈ। ਕੋਟਲਿਨ ਵਿੱਚ ਮਾਡਯੂਲਰ ਪਹੁੰਚ ਡਿਵੈਲਪਰਾਂ ਨੂੰ ਇਸ ਔਖੇ ਕੰਮ ਨੂੰ ਸਵੈਚਾਲਤ ਕਰਨ ਦੀ ਆਗਿਆ ਦਿੰਦੀ ਹੈ। 😊

ਸ਼ੈੱਲ-ਅਧਾਰਿਤ ਹੱਲ ਗ੍ਰੇਡਲ ਨਿਰਭਰਤਾ ਨੂੰ ਸਾਫ਼ ਕਰਨ ਅਤੇ ਤਾਜ਼ਗੀ ਦੇਣ ਲਈ ਕਮਾਂਡ-ਲਾਈਨ ਵਿਧੀ ਦੀ ਪੇਸ਼ਕਸ਼ ਕਰਕੇ ਕੋਟਲਿਨ ਸਕ੍ਰਿਪਟ ਨੂੰ ਪੂਰਾ ਕਰਦਾ ਹੈ। `rm -rf` ਕਮਾਂਡ ਪ੍ਰਭਾਵਸ਼ਾਲੀ ਢੰਗ ਨਾਲ ਸਮੱਸਿਆ ਵਾਲੀ Gradle ਕੈਸ਼ ਡਾਇਰੈਕਟਰੀ ਨੂੰ ਮਿਟਾ ਦਿੰਦੀ ਹੈ, ਜਦੋਂ ਕਿ `--refresh-dependencies` ਫਲੈਗ Gradle ਨੂੰ ਅੱਪਡੇਟ ਕੀਤੀਆਂ ਨਿਰਭਰਤਾਵਾਂ ਪ੍ਰਾਪਤ ਕਰਨ ਲਈ ਮਜ਼ਬੂਰ ਕਰਦਾ ਹੈ। ਇਹ ਕਮਾਂਡਾਂ ਖਾਸ ਤੌਰ 'ਤੇ CI/CD ਪਾਈਪਲਾਈਨਾਂ ਵਿੱਚ ਕੰਮ ਕਰਨ ਵਾਲੇ ਡਿਵੈਲਪਰਾਂ ਲਈ ਉਪਯੋਗੀ ਹਨ, ਜਿੱਥੇ ਸਵੈਚਲਿਤ ਬਿਲਡ ਪ੍ਰਕਿਰਿਆਵਾਂ ਜ਼ਰੂਰੀ ਹਨ। ਇੱਕ ਅਸਲ-ਸੰਸਾਰ ਦ੍ਰਿਸ਼ ਵਿੱਚ ਇੱਕ ਡਿਵੈਲਪਰ ਨੂੰ ਇੱਕ ਪਲੱਗਇਨ ਨੂੰ ਅੱਪਡੇਟ ਕਰਨਾ ਸ਼ਾਮਲ ਹੋ ਸਕਦਾ ਹੈ, ਜਿਵੇਂ ਕਿ "ਸ਼ਾਨਦਾਰ ਸੂਚਨਾਵਾਂ," ਅਤੇ ਕੈਸ਼ ਕੀਤੀਆਂ, ਪੁਰਾਣੀਆਂ ਕਲਾਕ੍ਰਿਤੀਆਂ ਦੇ ਕਾਰਨ ਸਮੱਸਿਆਵਾਂ ਦਾ ਸਾਹਮਣਾ ਕਰਨਾ।

ਇਹਨਾਂ ਹੱਲਾਂ ਦੀ ਪ੍ਰਭਾਵਸ਼ੀਲਤਾ ਦੀ ਪੁਸ਼ਟੀ ਕਰਨ ਲਈ, ਡਾਰਟ ਸਕ੍ਰਿਪਟ ਯੂਨਿਟ ਟੈਸਟ ਪੇਸ਼ ਕਰਦੀ ਹੈ। `Future.value()` ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਇੱਕ Gradle ਬਿਲਡ ਦੀ ਨਕਲ ਕਰਕੇ ਅਤੇ `expect()` ਨਾਲ ਸੰਭਾਵਿਤ ਨਤੀਜਿਆਂ ਦੀ ਜਾਂਚ ਕਰਕੇ, ਡਿਵੈਲਪਰ ਇਹ ਯਕੀਨੀ ਬਣਾ ਸਕਦੇ ਹਨ ਕਿ ਉਹਨਾਂ ਦੇ ਫਿਕਸ ਇੱਕ ਕਾਰਜਸ਼ੀਲ ਬਿਲਡ ਵਾਤਾਵਰਨ ਵੱਲ ਲੈ ਜਾਂਦੇ ਹਨ। ਇਹ ਮਾਡਯੂਲਰਿਟੀ ਵੱਡੀਆਂ ਟੀਮਾਂ ਲਈ ਖਾਸ ਤੌਰ 'ਤੇ ਮਹੱਤਵਪੂਰਨ ਹੈ, ਜਿੱਥੇ ਕਈ ਡਿਵੈਲਪਰ ਇੱਕੋ ਪ੍ਰੋਜੈਕਟ 'ਤੇ ਕੰਮ ਕਰਦੇ ਹਨ। ਜਾਂਚ ਇਹ ਯਕੀਨੀ ਬਣਾਉਂਦੀ ਹੈ ਕਿ ਲਾਗੂ ਕੀਤੇ ਹੱਲ ਵੱਖ-ਵੱਖ ਵਾਤਾਵਰਣਾਂ ਵਿੱਚ ਕੰਮ ਕਰਦੇ ਹਨ, ਆਵਰਤੀ ਗਲਤੀਆਂ ਦੇ ਜੋਖਮ ਨੂੰ ਘਟਾਉਂਦੇ ਹਨ। 🚀

ਇਹਨਾਂ ਵਿੱਚੋਂ ਹਰੇਕ ਸਕ੍ਰਿਪਟ ਨੂੰ ਮੁੜ ਵਰਤੋਂਯੋਗਤਾ ਅਤੇ ਪ੍ਰਦਰਸ਼ਨ ਨੂੰ ਧਿਆਨ ਵਿੱਚ ਰੱਖ ਕੇ ਤਿਆਰ ਕੀਤਾ ਗਿਆ ਹੈ। ਕੋਟਲਿਨ ਅਤੇ ਸ਼ੈੱਲ ਹੱਲ ਕੈਚ ਕਲੀਅਰਿੰਗ ਅਤੇ ਨਿਰਭਰਤਾ ਪ੍ਰਬੰਧਨ ਨੂੰ ਸੁਚਾਰੂ ਬਣਾਉਂਦੇ ਹਨ, ਜਦੋਂ ਕਿ ਡਾਰਟ ਟੈਸਟ ਕਾਰਜਕੁਸ਼ਲਤਾ ਦੀ ਪੁਸ਼ਟੀ ਕਰਨ ਦਾ ਇੱਕ ਮਜ਼ਬੂਤ ​​ਤਰੀਕਾ ਪ੍ਰਦਾਨ ਕਰਦੇ ਹਨ। ਇਕੱਠੇ ਮਿਲ ਕੇ, ਉਹ ਮੁੱਖ ਸਮੱਸਿਆ ਨੂੰ ਹੱਲ ਕਰਦੇ ਹਨ: ਪੁਰਾਣੇ ਜਾਂ ਵਿਰੋਧੀ ਗਰੇਡਲ ਸਰੋਤਾਂ ਦੇ ਕਾਰਨ NullPointerExceptions ਨੂੰ ਹੱਲ ਕਰਨਾ। ਅਨੁਕੂਲਿਤ ਤਰੀਕਿਆਂ ਦੀ ਵਰਤੋਂ ਜਿਵੇਂ `deleteRecursively()` ਅਤੇ ਮਾਡਿਊਲਰ ਸਕ੍ਰਿਪਟਿੰਗ ਸਭ ਤੋਂ ਵਧੀਆ ਅਭਿਆਸਾਂ ਦੀ ਉਦਾਹਰਨ ਦਿੰਦੀ ਹੈ, ਇਹ ਯਕੀਨੀ ਬਣਾਉਣਾ ਕਿ ਡਿਵੈਲਪਰ ਇਹਨਾਂ ਨਿਰਾਸ਼ਾਜਨਕ ਬਿਲਡ ਤਰੁੱਟੀਆਂ ਨੂੰ ਜਲਦੀ ਹੱਲ ਕਰ ਸਕਦੇ ਹਨ। ਭਾਵੇਂ ਤੁਸੀਂ ਏਪੀਕੇ ਬਣਾ ਰਹੇ ਹੋ ਜਾਂ ਡੀਬਗਿੰਗ ਕਰ ਰਹੇ ਹੋ, ਇਹ ਟੂਲ ਪ੍ਰਕਿਰਿਆ ਨੂੰ ਵਧੇਰੇ ਕੁਸ਼ਲ ਅਤੇ ਗਲਤੀ-ਮੁਕਤ ਬਣਾਉਂਦੇ ਹਨ।

ਡੀਬੱਗਿੰਗ ਫਲਟਰ ਬਿਲਡ ਤਰੁੱਟੀਆਂ: NullPointerException ਲਈ ਮਾਡਿਊਲਰ ਹੱਲ

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

// Import required classes
import java.io.File
import java.lang.Exception
// Define a utility function to clear Gradle cache
fun clearGradleCache(): Boolean {
    try {
        val gradleCacheDir = File(System.getProperty("user.home") + "/.gradle/caches")
        if (gradleCacheDir.exists()) {
            gradleCacheDir.deleteRecursively()
            println("Gradle cache cleared successfully.")
            return true
        } else {
            println("Gradle cache directory not found.")
            return false
        }
    } catch (e: Exception) {
        println("Error clearing Gradle cache: ${e.message}")
        return false
    }
}
// Run the function
fun main() {
    clearGradleCache()
}

ਫਲਟਰ ਕੰਪਾਇਲੇਸ਼ਨ ਮੁੱਦਿਆਂ ਨੂੰ ਫਿਕਸ ਕਰਨਾ: ਗ੍ਰੇਡਲ ਦੀ ਸਫਾਈ ਅਤੇ ਸਮਕਾਲੀਕਰਨ

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

#!/bin/bash
# Function to clean Gradle cache
clean_gradle_cache() {
    GRADLE_CACHE_DIR="$HOME/.gradle/caches"
    if [ -d "$GRADLE_CACHE_DIR" ]; then
        echo "Clearing Gradle cache..."
        rm -rf "$GRADLE_CACHE_DIR"
        echo "Gradle cache cleared."
    else
        echo "Gradle cache directory not found."
    fi
}
# Function to sync Gradle
sync_gradle() {
    echo "Syncing Gradle..."
    ./gradlew clean build --refresh-dependencies
    echo "Gradle sync complete."
}
# Execute functions
clean_gradle_cache
sync_gradle

ਬਿਲਡ ਫਿਕਸ ਦੀ ਪੁਸ਼ਟੀ ਕਰਨ ਲਈ ਯੂਨਿਟ ਟੈਸਟ

ਡਾਰਟ ਵਿੱਚ ਯੂਨਿਟ ਟੈਸਟਾਂ ਦੀ ਵਰਤੋਂ ਫਲਟਰ ਐਪਲੀਕੇਸ਼ਨਾਂ ਲਈ ਬਿਲਡ ਪ੍ਰਕਿਰਿਆ ਵਿੱਚ ਲਾਗੂ ਕੀਤੇ ਗਏ ਫਿਕਸਾਂ ਨੂੰ ਪ੍ਰਮਾਣਿਤ ਕਰਨ ਲਈ ਕੀਤੀ ਜਾਂਦੀ ਹੈ।

import 'package:test/test.dart';
// Function to simulate a Gradle build
Future<bool> simulateGradleBuild() async {
  try {
    // Simulating build success
    return Future.value(true);
  } catch (e) {
    return Future.value(false);
  }
}
void main() {
  test('Gradle build success test', () async {
    bool result = await simulateGradleBuild();
    expect(result, true, reason: 'Gradle build should complete successfully.');
  });
}

ਫਲਟਰ ਅਤੇ ਗ੍ਰੇਡਲ ਬਿਲਡ ਅਸਫਲਤਾਵਾਂ ਵਿੱਚ ਪਲੱਗਇਨ ਵਿਵਾਦਾਂ ਦੀ ਪੜਚੋਲ ਕਰਨਾ

ਫਲਟਰ ਨਾਲ ਕੰਮ ਕਰਦੇ ਸਮੇਂ, ਪਲੱਗਇਨਾਂ ਜਾਂ ਨਿਰਭਰਤਾਵਾਂ ਨੂੰ ਅੱਪਡੇਟ ਕਰਨ ਤੋਂ ਬਾਅਦ ਗ੍ਰੇਡਲ ਬਿਲਡ ਤਰੁੱਟੀਆਂ ਦਾ ਸਾਹਮਣਾ ਕਰਨਾ ਆਮ ਗੱਲ ਹੈ। ਅਜਿਹਾ ਇੱਕ ਪਲੱਗਇਨ, "ਸ਼ਾਨਦਾਰ ਸੂਚਨਾਵਾਂ," ਅਨੁਕੂਲਤਾ ਸਮੱਸਿਆਵਾਂ ਦਾ ਕਾਰਨ ਬਣ ਸਕਦੀ ਹੈ ਜਦੋਂ ਇਸਨੂੰ ਅਪਡੇਟ ਕੀਤਾ ਜਾਂਦਾ ਹੈ ਪਰ ਹੋਰ ਨਿਰਭਰਤਾਵਾਂ ਨਹੀਂ ਹੁੰਦੀਆਂ ਹਨ। ਅਜਿਹਾ ਇਸ ਲਈ ਹੁੰਦਾ ਹੈ ਕਿਉਂਕਿ ਇਹਨਾਂ ਵਰਗੇ ਪਲੱਗਇਨ ਅਕਸਰ ਦੂਜੀਆਂ ਲਾਇਬ੍ਰੇਰੀਆਂ 'ਤੇ ਨਿਰਭਰ ਕਰਦੇ ਹਨ, ਜਿਵੇਂ ਕਿ Jetpack ਜਾਂ AppCompat, ਜੋ ਤੁਹਾਡੇ ਪ੍ਰੋਜੈਕਟ ਦੇ ਸੰਸਕਰਣ ਨਾਲ ਮੇਲ ਨਹੀਂ ਖਾਂਦੇ। ਇਸ ਨੂੰ ਹੱਲ ਕਰਨ ਲਈ ਨਿਰਭਰਤਾ ਸੰਸਕਰਣਾਂ ਦਾ ਧਿਆਨ ਨਾਲ ਪ੍ਰਬੰਧਨ ਕਰਨਾ ਅਤੇ ਇਹ ਯਕੀਨੀ ਬਣਾਉਣ ਦੀ ਲੋੜ ਹੈ ਕਿ ਉਹ ਤੁਹਾਡੇ ਪ੍ਰੋਜੈਕਟ ਵਿੱਚ ਅਨੁਕੂਲ ਹਨ। ਇੱਕ ਅਸਲ-ਸੰਸਾਰ ਦ੍ਰਿਸ਼ ਵਿੱਚ ਨਵੀਆਂ ਵਿਸ਼ੇਸ਼ਤਾਵਾਂ ਲਈ ਪਲੱਗਇਨ ਨੂੰ ਅੱਪਡੇਟ ਕਰਨਾ ਸ਼ਾਮਲ ਹੋ ਸਕਦਾ ਹੈ, ਸਿਰਫ਼ `java.lang.NullPointerException` ਵਰਗੀਆਂ ਤਰੁੱਟੀਆਂ ਲੱਭਣ ਲਈ। 😓

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

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

ਫਲਟਰ ਬਿਲਡ ਮੁੱਦਿਆਂ ਨੂੰ ਹੱਲ ਕਰਨ ਬਾਰੇ ਪ੍ਰਮੁੱਖ ਸਵਾਲ

  1. ਫਲਟਰ ਵਿੱਚ ਗ੍ਰੇਡਲ ਬਿਲਡ ਫੇਲ੍ਹ ਹੋਣ ਦਾ ਕੀ ਕਾਰਨ ਹੈ?
  2. ਗ੍ਰੇਡਲ ਬਿਲਡ ਅਸਫਲਤਾਵਾਂ ਅਕਸਰ ਪਲੱਗਇਨ ਸੰਸਕਰਣ ਅਪਵਾਦ, ਕੈਸ਼ਡ ਕਰੱਪਟਡ ਫਾਈਲਾਂ, ਜਾਂ ਪੁਰਾਣੀ ਨਿਰਭਰਤਾਵਾਂ ਦੇ ਨਤੀਜੇ ਵਜੋਂ ਹੁੰਦੀਆਂ ਹਨ।
  3. ਮੈਂ ਗ੍ਰੇਡਲ ਕੈਸ਼ ਨੂੰ ਕਿਵੇਂ ਸਾਫ਼ ਕਰ ਸਕਦਾ ਹਾਂ?
  4. ਵਰਤੋ rm -rf ~/.gradle/caches ਯੂਨਿਕਸ-ਅਧਾਰਿਤ ਸਿਸਟਮਾਂ 'ਤੇ ਜਾਂ ਕੈਸ਼ ਨੂੰ ਮਿਟਾਉਣ ਲਈ ਵਿੰਡੋਜ਼ 'ਤੇ ਬਰਾਬਰ ਦੀ ਡਾਇਰੈਕਟਰੀ.
  5. ਪਲੱਗਇਨ ਨੂੰ ਅੱਪਡੇਟ ਕਰਨ ਨਾਲ ਗਲਤੀਆਂ ਕਿਉਂ ਹੁੰਦੀਆਂ ਹਨ?
  6. ਪਲੱਗਇਨ ਅੱਪਡੇਟ ਲਾਇਬ੍ਰੇਰੀਆਂ ਦੇ ਨਵੇਂ ਸੰਸਕਰਣਾਂ 'ਤੇ ਨਿਰਭਰ ਹੋ ਸਕਦੇ ਹਨ ਜੋ ਹਾਲੇ ਤੱਕ ਤੁਹਾਡੇ ਪ੍ਰੋਜੈਕਟ ਵਿੱਚ ਸ਼ਾਮਲ ਨਹੀਂ ਹਨ, ਜਿਸ ਨਾਲ NullPointerException ਵਰਗੀਆਂ ਤਰੁੱਟੀਆਂ ਹੋ ਸਕਦੀਆਂ ਹਨ।
  7. `--ਤਾਜ਼ਾ-ਨਿਰਭਰਤਾ` ਦੀ ਭੂਮਿਕਾ ਕੀ ਹੈ?
  8. --refresh-dependencies ਫਲੈਗ ਗ੍ਰੇਡਲ ਨੂੰ ਸਾਰੀਆਂ ਨਿਰਭਰਤਾਵਾਂ ਨੂੰ ਮੁੜ-ਡਾਊਨਲੋਡ ਕਰਨ ਲਈ ਮਜ਼ਬੂਰ ਕਰਦਾ ਹੈ, ਇਹ ਯਕੀਨੀ ਬਣਾਉਂਦੇ ਹੋਏ ਕਿ ਕੋਈ ਪੁਰਾਣੀ ਕਲਾਕ੍ਰਿਤੀਆਂ ਦੀ ਵਰਤੋਂ ਨਹੀਂ ਕੀਤੀ ਗਈ ਹੈ।
  9. ਪਲੱਗਇਨ ਅੱਪਡੇਟ ਤੋਂ ਬਾਅਦ ਮੈਂ ਬਿਲਡ ਫੇਲ੍ਹ ਹੋਣ ਨੂੰ ਕਿਵੇਂ ਰੋਕ ਸਕਦਾ ਹਾਂ?
  10. ਅਲੱਗ-ਥਲੱਗ ਵਿੱਚ ਪਲੱਗਇਨ ਅਪਡੇਟਾਂ ਦੀ ਜਾਂਚ ਕਰੋ, ਵਰਤਦੇ ਹੋਏ ਅਨੁਕੂਲਤਾ ਦੀ ਪੁਸ਼ਟੀ ਕਰੋ gradlew dependencies, ਅਤੇ ਨਿਰਭਰਤਾ ਨੂੰ ਲਗਾਤਾਰ ਅੱਪਡੇਟ ਕਰੋ।

ਫਲਟਰ ਪ੍ਰੋਜੈਕਟਾਂ ਵਿੱਚ ਬਿਲਡ ਅਸਫਲਤਾਵਾਂ ਨੂੰ ਦੂਰ ਕਰਨਾ

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

ਸਕ੍ਰਿਪਟਾਂ ਅਤੇ ਮਾਡਯੂਲਰ ਹੱਲਾਂ ਦਾ ਲਾਭ ਲੈ ਕੇ, ਡਿਵੈਲਪਰ ਮੁੱਦਿਆਂ ਨੂੰ ਪ੍ਰਭਾਵਸ਼ਾਲੀ ਢੰਗ ਨਾਲ ਹੱਲ ਕਰ ਸਕਦੇ ਹਨ। ਇੱਕ ਭਰੋਸੇਮੰਦ ਪ੍ਰਕਿਰਿਆ ਬਣਾਉਣਾ ਇਹ ਯਕੀਨੀ ਬਣਾਉਂਦਾ ਹੈ ਕਿ NullPointerException ਵਰਗੀਆਂ ਗਲਤੀਆਂ ਐਪ ਦੀ ਪ੍ਰਗਤੀ ਵਿੱਚ ਵਿਘਨ ਨਹੀਂ ਪਾਉਂਦੀਆਂ ਹਨ। ਇਹ ਰਣਨੀਤੀਆਂ ਨਾ ਸਿਰਫ਼ ਮੌਜੂਦਾ ਸਮੱਸਿਆਵਾਂ ਦਾ ਹੱਲ ਕਰਦੀਆਂ ਹਨ ਸਗੋਂ ਭਵਿੱਖ ਦੇ ਵਿਕਾਸ ਦੇ ਯਤਨਾਂ ਨੂੰ ਵੀ ਸੁਰੱਖਿਅਤ ਕਰਦੀਆਂ ਹਨ, ਇੱਕ ਸਹਿਜ ਅਤੇ ਕੁਸ਼ਲ ਨਿਰਮਾਣ ਅਨੁਭਵ ਨੂੰ ਸਮਰੱਥ ਬਣਾਉਂਦੀਆਂ ਹਨ। 😊

ਫਲਟਰ ਬਿਲਡ ਗਲਤੀਆਂ ਨੂੰ ਹੱਲ ਕਰਨ ਲਈ ਸਰੋਤ ਅਤੇ ਹਵਾਲੇ
  1. ਗ੍ਰੇਡਲ ਬਿਲਡ ਅਸਫਲਤਾਵਾਂ ਨੂੰ ਹੱਲ ਕਰਨ ਬਾਰੇ ਵਿਸਤ੍ਰਿਤ ਵਿਆਖਿਆ: Android ਵਿਕਾਸਕਾਰ - ਆਪਣੀ ਐਪ ਬਣਾਓ ਅਤੇ ਚਲਾਓ
  2. ਸ਼ਾਨਦਾਰ ਸੂਚਨਾਵਾਂ ਪਲੱਗਇਨ ਲਈ ਅਧਿਕਾਰਤ ਦਸਤਾਵੇਜ਼: Pub.dev - ਸ਼ਾਨਦਾਰ ਸੂਚਨਾਵਾਂ
  3. NullPointerException ਗਲਤੀਆਂ ਨੂੰ ਠੀਕ ਕਰਨ ਲਈ ਕਦਮ-ਦਰ-ਕਦਮ ਗਾਈਡ: ਸਟੈਕ ਓਵਰਫਲੋ - Gradle NullPointerException ਫਿਕਸ ਕਰਨਾ
  4. ਫਲਟਰ ਨਿਰਭਰਤਾ ਪ੍ਰਬੰਧਨ ਲਈ ਵਧੀਆ ਅਭਿਆਸ: ਫਲਟਰ - ਪੈਕੇਜ ਅਤੇ ਪਲੱਗਇਨ ਦੀ ਵਰਤੋਂ ਕਰਨਾ