delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2012/09/19/17:07:21

X-Recipient: archive-cygwin AT delorie DOT com
X-SWARE-Spam-Status: No, hits=1.6 required=5.0 tests=AWL,BAYES_00,DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FROM,KHOP_SC_TOP_CIDR24,KHOP_THREADED,RCVD_IN_DNSWL_NONE,RCVD_IN_HOSTKARMA_YE,RP_MATCHES_RCVD
X-Spam-Check-By: sourceware.org
Message-ID: <1348088813.66748.YahooMailClassic@web111515.mail.gq1.yahoo.com>
Date: Wed, 19 Sep 2012 14:06:53 -0700 (PDT)
From: Richard Haney <rfhaney AT yahoo DOT com>
Subject: Re: bash output: ./configure: line 16: $'\r': command not found
To: cygwin AT cygwin DOT com
In-Reply-To: <505961A4.3000000@molconn.com>
MIME-Version: 1.0
X-IsSubscribed: yes
Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm
List-Id: <cygwin.cygwin.com>
List-Unsubscribe: <mailto:cygwin-unsubscribe-archive-cygwin=delorie DOT com AT cygwin DOT com>
List-Subscribe: <mailto:cygwin-subscribe AT cygwin DOT com>
List-Archive: <http://sourceware.org/ml/cygwin/>
List-Post: <mailto:cygwin AT cygwin DOT com>
List-Help: <mailto:cygwin-help AT cygwin DOT com>, <http://sourceware.org/ml/#faqs>
Sender: cygwin-owner AT cygwin DOT com
Mail-Followup-To: cygwin AT cygwin DOT com
Delivered-To: mailing list cygwin AT cygwin DOT com
X-MIME-Autoconverted: from quoted-printable to 8bit by delorie.com id q8JL7H1W032004

Two problems (at least).

But there is a fix-up that appears to work (at least for me); see the end of this reply message.

Generally, there are lots and lots of script files for every build.  That means my builds could be crashing right and left all over the place if bash does not always ignore carriage returns when it is supposed to.  So I need for bash to be able to always ignore carriage returns -- at least all carriage returns immediately before newlines.

But the original 'configure' source file -- the one with the problem -- was OK up to line 16.  Line 16 was the first blank line after nothing but # comment lines before that.  I used Windows Explorer to make a copy of the file (i.e., via CTRL-C followed by CTRL-V) and renamed the copy 'configure.txt'; diagnostic output was the same with execution of '$ ./configure.txt --version'.  So, using MS WordPad, I added a # as the only character on line 16, and the problem went away at that line, but the subsequent two diagnostics remain:

$ ./configure.txt --version
./configure.txt: line 31: syntax error near unexpected token `newline'
'/configure.txt: line 31: `     ;;

Upon viewing with an editor, line 31 appears to have nothing but five spaces followed by two semicolons.

However, I read 'configure.txt' and then wrote the file out using an editor that removes ending carriage returns (presumably those before newlines).  (I assume dos2unix may do the same.)  And the output from execution of './configure.txt --version' was fine:

$ ./configure.txt --version
gsl configure 1.15
generated by GNU Autoconf 2.68
...

So it seems that bash has a bug -- namely, it apparently fails to ignore carriage returns when there is a newline immediately before.  (But there is some other problem with line 31 of 'configure.txt'; it seems to be an end-of-line problem of some sort, but exactly what is not clear.)

And/or GNU Autoconf 2.68 has a bug that puts out some line endings that bash can't handle even with the '-o igncr' command-line option.

So it seems to be a problem of bugs in both bash and Autoconf 2.68, and the bug ("unclean" design?) in bash might be OK if Autoconf 2.68 did not also have bugs/"unclean" design that brings out bash's bug.

The second problem is that I can find no documentation for the bash '-o igncr' command-line option.

But it turns out that the first problem seems to go away when I follow the advice of http://chess.eecs.berkeley.edu/softdevel/faq/5.html and add the lines

export SHELLOPTS
set -o igncr

to the end of my '.bash_profile' file.

Richard Haney


--- On Tue, 9/18/12, LMH [e-mail address deleted] wrote:

> From: LMH [e-mail address deleted]
> Subject: Re: bash output: ./configure: line 16: $'\r': command not found
> To: cygwin (at) cygwin (dot) com
> Date: Tuesday, September 18, 2012, 11:09 PM
> That error is a sign that the file is
> in the DOS format and not the UNIX 
> format. Bash doesn't recognize the windows end of line
> character \r.
> 
> Just run dos2unix on the file
> dos2unix configure
> 
> that should take care of the error.
> 
> LMH
> 
> 
> 
> Richard Haney wrote:
> > I am trying to get set up to build the Gnu Scientific
> Library using Cygwin bash for my command-line
> processor.  I eventually plan to use the tdm64-1 copy
> of MinGW gcc 4.6.1 to do the building:
> >
> > $ gcc --version
> > gcc.exe (tdm64-1) 4.6.1
> >
> > But I have not gotten to using the gcc tools yet. 
> (I also want to eventually rebuild all or parts of the gcc
> package optimized for my Intel i5 processor.)
> >
> > So in particular, I wanted to run ./configure --help ,
> to find out what options I need to use to build the Gnu
> Scientific Library, besides what is said in the INSTALL
> file.  (For example, I am wondering about revising the
> "make install" defaults.)
> >
> > But first I ran, and got:
> >
> > $ ./configure --version
> > ./configure: line 16: $'\r': command not found
> > ./configure: line 31: syntax error near unexpected
> token
> > `newline'
> > '/configure: line 31: `     ;;
> >
> > I recall having a similar problem on another laptop
> (probably Cygwin on Windows XP), and I recall that I fixed
> the problem (after a terribly long, horrendous search for
> info and finally realizing that '\r' in C is a carriage
> return; but the details were a long time ago)
> >
> > Anyway, I believe I copied my Cygwin.bat (with the fix)
> from my old laptop to my new one, the one I'm now using
> (with Windows 7 and an Intel i5 processor).
> >
> > Here is the Cygwin.bat file listing:
> >
> > @echo off
> > C:
> > chdir C:\cygwin\bin
> > rem   bash --login -i
> > bash --login -i -o igncr
> >
> > Evidently the "igncr" is supposed to tell bash to
> ignore carriage returns.
> >
> > But on this system, it apparently is not ignoring
> carriage returns.
> >
> > I even searched the bash.info file for the string
> "igncr", but I found no such string.  Even the old
> bash.info file seems to lack that info.
> >
> > However, I did find a web page
> >
> > http://sourceware.org/ml/cygwin-announce/2011-02/msg00027.html
> >
> > that discusses the matter, but that does not seem to
> help in this case.
> >
> > So what's the problem?
> >
> > Has my more recently installed Cygwin dropped the
> "igncr" option capability from the bash command line?
> >
> > Here is my current bash version:
> >
> > $ bash --version
> > GNU bash, version 4.1.10(4)-release (i686-pc-cygwin)
> >
> >
> >
> > --
> > 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
> >
> >
> 
> --
> 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
> 
>

--
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


- Raw text -


  webmaster     delorie software   privacy  
  Copyright © 2019   by DJ Delorie     Updated Jul 2019