X-Recipient: archive-cygwin AT delorie DOT com X-SWARE-Spam-Status: No, hits=-0.8 required=5.0 tests=AWL,BAYES_50 X-Spam-Check-By: sourceware.org Message-ID: <4BE0F722.1040009@bopp.net> Date: Tue, 04 May 2010 23:42:10 -0500 From: Jeremy Bopp User-Agent: Thunderbird 2.0.0.24 (X11/20100411) MIME-Version: 1.0 To: cygwin AT cygwin DOT com Subject: Re: Cygwin make target is never determined up to date References: <28454344 DOT post AT talk DOT nabble DOT com> In-Reply-To: <28454344.post@talk.nabble.com> Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit X-IsSubscribed: yes Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm List-Id: List-Subscribe: List-Archive: List-Post: List-Help: , Sender: cygwin-owner AT cygwin DOT com Mail-Followup-To: cygwin AT cygwin DOT com Delivered-To: mailing list cygwin AT cygwin DOT com MichaelKim wrote: > Cygwin make always processing `$(chrome_jar_file)` target, after first > successful build. So I never get up to date message and always see commands > for `$(chrome_jar_file)` are executing. > > However it happens only on Windows 7. On Windows XP once it built and > intact, no more builds. > I narrowed down the issue to one prerequisite - `$(jar_target_dir)`. > > Here is part of the code > > # The location where the JAR file will be created. > jar_target_dir := $(build_dir)/chrome > > # The main chrome JAR file. > chrome_jar_file := $(jar_target_dir)/$(extension_name).jar > > # The root of the JAR sources. > jar_source_root := chrome > > # The sources for the JAR file. > jar_sources := bla #... some files, doesn't matter > > jar_sources_no_dir := $(subst $(jar_source_root)/,,$(jar_sources)) > > $(chrome_jar_file): $(jar_sources) $(jar_target_dir) > @echo "Creating chrome JAR file." > @cd $(jar_source_root); $(ZIP) ../$(chrome_jar_file) > $(jar_sources_no_dir) > @echo "Creating chrome JAR file. Done!" > > $(jar_target_dir): $(build_dir) > echo "Creating jar target dir..." > if [ ! -x $(jar_target_dir) ]; \ > then \ > mkdir $(jar_target_dir); \ > fi > > $(build_dir): > @if [ ! -x $(build_dir) ]; \ > then \ > mkdir $(build_dir); \ > fi > > > so if I just remove `$(jar_target_dir)` from `$(chrome_jar_file)` rule, it > works fine. > Also tried to use `-e` in `if`. > So again, question is why in windows 7 target is never up to date and it has > always to process it. Have you tried adding a short sleep after creating $(jar_target_dir)? Maybe try something in the range of 2 to 5 seconds. BTW, are you building on a FAT filesystem or NTFS? My guess here is that the timestamps on $(jar_target_dir) and $(chrome_jar_file) are the same, at least as far as make is concerned. The FAT filesystem, with its 2 second resolution, is somewhat prone to this kind of problem. -Jeremy -- Problem reports: http://cygwin.com/problems.html FAQ: http://cygwin.com/faq/ Documentation: http://cygwin.com/docs.html Unsubscribe info: http://cygwin.com/ml/#unsubscribe-simple