Сегодня мы раcсмотрим еще один тип заданий, которые умеет выполнять полезный инструмент Ant. Мы увидим, как он удаляет вредные файлы, в данном случае -- кэш браузера. Послушайте меня, на самом деле, это -- не самое лучшее, что вы можете сделать (лучше дерево посадить), но бывает, что процесс отладки приложения заходит так далеко, что в вашем исходном коде все уже проверено-перепроверено, везде где только можно стоят брейкпойнты и трейсы, а все равно ничего не работает. Тогда становится ясно, что подлый баг засел в кэше браузера, и единственный шас его замочить -- это тотальная экстерминация всего кэша. Затем, когда кэш очищен, а баг снова радостно машет вам красным платочком зарождающегося разочарования в людях и технологиях, вы понимаете, что, чорт побери, действительно где-то допустили ошибку... и после этого уже за считаные минуты находите кириллическую "с" вместо латинской "c" в проверке типа "if (mcContainer._name = "mcContainerTest")", а затем еще быстрее находите оператор присваивания ("=") вместо оператора сравнения ("==") в этой же строке кода. Поэтому, что бы кто ни говорил, а очистка кэша браузера имеет важнейшее психологическое значение, заставляя мозг разработчика начинать думать -- а потому что отступать некуда; позади -- чистый кэш!
if (mcContainer._name = "mcContainerTest")
А чтобы удалить файл, нужно знать только одно: путь к нему. В моем случае (кэш браузера Firefox) это путь типа "c:\Documents and Settings\[USERNAME]\Local Settings\Application Data\Mozilla\Firefox\Profiles\[SOME_RANDOM_STRING]default\Cache". (Кстати, сегодня я совершил для себя приятнейшее открытие, обнаружив, что Firefox имеет встроенный навороченный браузер собственного кэша, и вызывается он по гениальнейшему адресу about:cache (вводите этот адрес вручную или открывайте средним кликом в новой вкладке -- иначе не сработает. А если вы еще не иcпользуете Firefox, то начните делать это прямо сейчас, -- и ничего, что коньки IEще не сносились -- на дворе уж лето, вдохните свежего воздуха полной грудью!
c:\Documents and Settings\[USERNAME]\Local Settings\Application Data\Mozilla\Firefox\Profiles\[SOME_RANDOM_STRING]default\Cache
Для очистки кэша заведем в нашем билд-файле (он был описан в предыдущей статье, посвященной сердитой компиляции, вследствие которой ваша сложная флэшка cкомпилится за секунду, и автоматически откроется не в беспомощном стэнделон-проигрывателе, а сразу в окне тестового браузера, да еще и с вашего же сервера, -- и все это по нажатию Ctrl+Enter!)
Итак, вот исходный код, который нужно добавить в билд-файл, чтобь почистить кэш браузера (изменить параметры по вкусу!):
<target name="browser.cache.clean"> <delete> <fileset includes="*" defaultexcludes="no" dir="c:\Documents and Settings\[USERNAME]\Local Settings\Application Data\Mozilla\Firefox\Profiles\[SOME_RANDOM_STRING]default\Cache" /> </delete> </target>
Обратите внимание на то, что операция удаления -- настраиваема: можно указать и шаблон имен файлов для удаления (includes), и шаблон имен для тех, кого не трогать, и, конечно, каталог с жертвами. А чтобы просто удалить нежелательный каталог со всеми потрохами, достаточно написать <delete dir="c:/Program Files/Internet Explorer" /> (нe забудьте после этого установить Firefox). И, наконец, чтобы удалить абсолютно все ненужные файлы, можно обойтись совсем короткой командой <delete dir="*" />, выключить комп навсегда и устроиться в ЖЭК кочегаром, чтобы начать приносить людям пользу.
<delete dir="c:/Program Files/Internet Explorer" />
<delete dir="*" />
На самом деле, цель этой заметки -- еще раз показать функциональность Ant, чтобы убедить еще хоть одного флэш-разработчика перейти к использованию таких повышающих продуктивность работы инструментов, как Eclipse, Ant, MTASC, ASDT/FDT, SWFObject и неконтролируемое чувство юмора. Буквально сегодня я нашел еще пару отличных страниц-путеводителей по Анту: "Apache Ant -- Википедия" и "Top 15 Ant Best Practices". Читайте, применяйте и радуйтесь новой скорости разработки!
А как вы думаете я снова нашел время для написания этих длиннющих, всем уже надоевших статей-новостей? Во всем виноваты Apache Ant, Клишин и Constantiner!
Вот.
Ой, Рост. Ну убедил, убедил. =)
А почему последний?
Единственное что бы я сделал - это перенес бы зависимость от цели "build.number.increment" в цель "run.html". В дефолтной цели прямой ее вызов по-моему ни к чему, к тому же в твоем примере нельзя вызвать просто "run.html", так чтобы итерация тоже выполнялась.
Почему последний? Надоело все! "Я хочу быть кочегором, кочегаром.. работать сутки-через-трое, через трое.. ;)"
Бармалей, это уже от проекта зависит. Например, если собирать много файлов, и каждый из них при комп-ии читает с диска содержимое buid.number (например, файлы для CD-презентации, у меня такое было) -- то лучше инкрементировать номер билда первым делом.
Опять я во всем виноват ;) Кстати, вчера чуть не написал пост "Встречайте Флэш-риппер -- первый в России блог об Apache Ant" :)
Мда... я знал что мне чегото нехатает помимо знаний, теперь понял что Apache Ant :)
хорошо что есть не ленивые люди которые постят полезные посты как Constantiner, Antares и Рост.
Блин, а я прочетал "в ЖЖ последним кочегаром" :)
А там про ЖЭК :)
Отож! Бросай ты этоt IE :-)
Не брошу. Я его обернул в Maxthon: и пользоваться удобно, и имею гарантию, что просматриваемый мной контент под IE со стопроцентной вероятностью протестирован :)