From d606c5096124332d18a55bb5b554372e437c02d5 Mon Sep 17 00:00:00 2001 From: Doug Torrance Date: Mon, 8 Aug 2016 11:41:15 -0400 Subject: [PATCH] wmmp3: Add version 0.12 to repository. --- wmmp3/AUTHORS | 24 + wmmp3/COPYING | 169 +++ wmmp3/ChangeLog | 18 + wmmp3/INSTALL | 27 + wmmp3/Makefile.am | 4 + wmmp3/Makefile.in | 321 ++++++ wmmp3/NEWS | 0 wmmp3/README | 20 + wmmp3/TODO | 33 + wmmp3/aclocal.m4 | 104 ++ wmmp3/buttons.c | 83 ++ wmmp3/buttons.h | 20 + wmmp3/charset.xpm | 21 + wmmp3/configure | 2402 +++++++++++++++++++++++++++++++++++++++++++ wmmp3/configure.in | 19 + wmmp3/install-sh | 251 +++++ wmmp3/main.c | 301 ++++++ wmmp3/main.h | 33 + wmmp3/missing | 190 ++++ wmmp3/mkinstalldirs | 40 + wmmp3/mpg123ctl.c | 479 +++++++++ wmmp3/mpg123ctl.h | 47 + wmmp3/sample.wmmp3 | 46 + wmmp3/song_hash.c | 110 ++ wmmp3/song_hash.h | 18 + wmmp3/wmgeneral.c | 531 ++++++++++ wmmp3/wmgeneral.h | 71 ++ wmmp3/wmmp3.xpm | 138 +++ 28 files changed, 5520 insertions(+) create mode 100644 wmmp3/AUTHORS create mode 100644 wmmp3/COPYING create mode 100644 wmmp3/ChangeLog create mode 100644 wmmp3/INSTALL create mode 100644 wmmp3/Makefile.am create mode 100644 wmmp3/Makefile.in create mode 100644 wmmp3/NEWS create mode 100644 wmmp3/README create mode 100644 wmmp3/TODO create mode 100644 wmmp3/aclocal.m4 create mode 100644 wmmp3/buttons.c create mode 100644 wmmp3/buttons.h create mode 100644 wmmp3/charset.xpm create mode 100755 wmmp3/configure create mode 100644 wmmp3/configure.in create mode 100755 wmmp3/install-sh create mode 100644 wmmp3/main.c create mode 100644 wmmp3/main.h create mode 100755 wmmp3/missing create mode 100755 wmmp3/mkinstalldirs create mode 100644 wmmp3/mpg123ctl.c create mode 100644 wmmp3/mpg123ctl.h create mode 100644 wmmp3/sample.wmmp3 create mode 100644 wmmp3/song_hash.c create mode 100644 wmmp3/song_hash.h create mode 100644 wmmp3/wmgeneral.c create mode 100644 wmmp3/wmgeneral.h create mode 100644 wmmp3/wmmp3.xpm diff --git a/wmmp3/AUTHORS b/wmmp3/AUTHORS new file mode 100644 index 0000000..3a823a7 --- /dev/null +++ b/wmmp3/AUTHORS @@ -0,0 +1,24 @@ +wmmp3 Authors: + +Primary Author: + Patrick Crosby + +Contributors: + Matthew D. Campbell + (random play functionality, plus alwaysscroll) + Steven Jorgensen + (bug fixes with song names, added ability for + song names to have spaces) + +Borrowed/Looked at code from: + Kristian Wiklund (jb-1.23 curses mp3 jukebox) + Malcolm Cowe (wmrecord) + +Character Set courtesy of: + Steven Cook from wmsvencd + http://www.linuxfreak.com/~wmsvencd + +mpg123 Author: + Michael Hipp + + diff --git a/wmmp3/COPYING b/wmmp3/COPYING new file mode 100644 index 0000000..5c1f80c --- /dev/null +++ b/wmmp3/COPYING @@ -0,0 +1,169 @@ +GNU GENERAL PUBLIC LICENSE + +Version 2, June 1991 + +Copyright (C) 1989, 1991 Free Software Foundation, Inc. +59 Temple Place - Suite 330, Boston, MA 02111-1307, USA + +Everyone is permitted to copy and distribute verbatim copies +of this license document, but changing it is not allowed. + +Preamble + +The licenses for most software are designed to take away your freedom to share and change it. By contrast, the GNU General Public License is intended to +guarantee your freedom to share and change free software--to make sure the software is free for all its users. This General Public License applies to most +of the Free Software Foundation's software and to any other program whose authors commit to using it. (Some other Free Software Foundation software is +covered by the GNU Library General Public License instead.) You can apply it to your programs, too. + +When we speak of free software, we are referring to freedom, not price. Our General Public Licenses are designed to make sure that you have the freedom +to distribute copies of free software (and charge for this service if you wish), that you receive source code or can get it if you want it, that you can change the +software or use pieces of it in new free programs; and that you know you can do these things. + +To protect your rights, we need to make restrictions that forbid anyone to deny you these rights or to ask you to surrender the rights. These restrictions +translate to certain responsibilities for you if you distribute copies of the software, or if you modify it. + +For example, if you distribute copies of such a program, whether gratis or for a fee, you must give the recipients all the rights that you have. You must make +sure that they, too, receive or can get the source code. And you must show them these terms so they know their rights. + +We protect your rights with two steps: (1) copyright the software, and (2) offer you this license which gives you legal permission to copy, distribute and/or +modify the software. + +Also, for each author's protection and ours, we want to make certain that everyone understands that there is no warranty for this free software. If the +software is modified by someone else and passed on, we want its recipients to know that what they have is not the original, so that any problems introduced +by others will not reflect on the original authors' reputations. + +Finally, any free program is threatened constantly by software patents. We wish to avoid the danger that redistributors of a free program will individually +obtain patent licenses, in effect making the program proprietary. To prevent this, we have made it clear that any patent must be licensed for everyone's free +use or not licensed at all. + +The precise terms and conditions for copying, distribution and modification follow. + +TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION + +0. This License applies to any program or other work which contains a notice placed by the copyright holder saying it may be distributed under the terms of +this General Public License. The "Program", below, refers to any such program or work, and a "work based on the Program" means either the Program or +any derivative work under copyright law: that is to say, a work containing the Program or a portion of it, either verbatim or with modifications and/or +translated into another language. (Hereinafter, translation is included without limitation in the term "modification".) Each licensee is addressed as "you". + +Activities other than copying, distribution and modification are not covered by this License; they are outside its scope. The act of running the Program is not +restricted, and the output from the Program is covered only if its contents constitute a work based on the Program (independent of having been made by +running the Program). Whether that is true depends on what the Program does. + +1. You may copy and distribute verbatim copies of the Program's source code as you receive it, in any medium, provided that you conspicuously and +appropriately publish on each copy an appropriate copyright notice and disclaimer of warranty; keep intact all the notices that refer to this License and to the +absence of any warranty; and give any other recipients of the Program a copy of this License along with the Program. + +You may charge a fee for the physical act of transferring a copy, and you may at your option offer warranty protection in exchange for a fee. + +2. You may modify your copy or copies of the Program or any portion of it, thus forming a work based on the Program, and copy and distribute such +modifications or work under the terms of Section 1 above, provided that you also meet all of these conditions: + + a) You must cause the modified files to carry prominent notices stating that you changed the files and the date of any change. + + b) You must cause any work that you distribute or publish, that in whole or in part contains or is derived from the Program or any part thereof, to be + licensed as a whole at no charge to all third parties under the terms of this License. + + c) If the modified program normally reads commands interactively when run, you must cause it, when started running for such interactive use in the + most ordinary way, to print or display an announcement including an appropriate copyright notice and a notice that there is no warranty (or else, + saying that you provide a warranty) and that users may redistribute the program under these conditions, and telling the user how to view a copy of this + License. (Exception: if the Program itself is interactive but does not normally print such an announcement, your work based on the Program is not + required to print an announcement.) + +These requirements apply to the modified work as a whole. If identifiable sections of that work are not derived from the Program, and can be reasonably +considered independent and separate works in themselves, then this License, and its terms, do not apply to those sections when you distribute them as +separate works. But when you distribute the same sections as part of a whole which is a work based on the Program, the distribution of the whole must be on +the terms of this License, whose permissions for other licensees extend to the entire whole, and thus to each and every part regardless of who wrote it. + +Thus, it is not the intent of this section to claim rights or contest your rights to work written entirely by you; rather, the intent is to exercise the right to control +the distribution of derivative or collective works based on the Program. + +In addition, mere aggregation of another work not based on the Program with the Program (or with a work based on the Program) on a volume of a storage +or distribution medium does not bring the other work under the scope of this License. + +3. You may copy and distribute the Program (or a work based on it, under Section 2) in object code or executable form under the terms of Sections 1 and 2 +above provided that you also do one of the following: + + a) Accompany it with the complete corresponding machine-readable source code, which must be distributed under the terms of Sections 1 and 2 + above on a medium customarily used for software interchange; or, + + b) Accompany it with a written offer, valid for at least three years, to give any third party, for a charge no more than your cost of physically performing + source distribution, a complete machine-readable copy of the corresponding source code, to be distributed under the terms of Sections 1 and 2 above + on a medium customarily used for software interchange; or, + + c) Accompany it with the information you received as to the offer to distribute corresponding source code. (This alternative is allowed only for + noncommercial distribution and only if you received the program in object code or executable form with such an offer, in accord with Subsection b + above.) + +The source code for a work means the preferred form of the work for making modifications to it. For an executable work, complete source code means all +the source code for all modules it contains, plus any associated interface definition files, plus the scripts used to control compilation and installation of the +executable. However, as a special exception, the source code distributed need not include anything that is normally distributed (in either source or binary +form) with the major components (compiler, kernel, and so on) of the operating system on which the executable runs, unless that component itself +accompanies the executable. + +If distribution of executable or object code is made by offering access to copy from a designated place, then offering equivalent access to copy the source +code from the same place counts as distribution of the source code, even though third parties are not compelled to copy the source along with the object +code. + +4. You may not copy, modify, sublicense, or distribute the Program except as expressly provided under this License. Any attempt otherwise to copy, modify, +sublicense or distribute the Program is void, and will automatically terminate your rights under this License. However, parties who have received copies, or +rights, from you under this License will not have their licenses terminated so long as such parties remain in full compliance. + +5. You are not required to accept this License, since you have not signed it. However, nothing else grants you permission to modify or distribute the Program +or its derivative works. These actions are prohibited by law if you do not accept this License. Therefore, by modifying or distributing the Program (or any +work based on the Program), you indicate your acceptance of this License to do so, and all its terms and conditions for copying, distributing or modifying the +Program or works based on it. + +6. Each time you redistribute the Program (or any work based on the Program), the recipient automatically receives a license from the original licensor to +copy, distribute or modify the Program subject to these terms and conditions. You may not impose any further restrictions on the recipients' exercise of the +rights granted herein. You are not responsible for enforcing compliance by third parties to this License. + +7. If, as a consequence of a court judgment or allegation of patent infringement or for any other reason (not limited to patent issues), conditions are imposed +on you (whether by court order, agreement or otherwise) that contradict the conditions of this License, they do not excuse you from the conditions of this +License. If you cannot distribute so as to satisfy simultaneously your obligations under this License and any other pertinent obligations, then as a +consequence you may not distribute the Program at all. For example, if a patent license would not permit royalty-free redistribution of the Program by all +those who receive copies directly or indirectly through you, then the only way you could satisfy both it and this License would be to refrain entirely from +distribution of the Program. + +If any portion of this section is held invalid or unenforceable under any particular circumstance, the balance of the section is intended to apply and the section +as a whole is intended to apply in other circumstances. + +It is not the purpose of this section to induce you to infringe any patents or other property right claims or to contest validity of any such claims; this section has +the sole purpose of protecting the integrity of the free software distribution system, which is implemented by public license practices. Many people have +made generous contributions to the wide range of software distributed through that system in reliance on consistent application of that system; it is up to the +author/donor to decide if he or she is willing to distribute software through any other system and a licensee cannot impose that choice. + +This section is intended to make thoroughly clear what is believed to be a consequence of the rest of this License. + +8. If the distribution and/or use of the Program is restricted in certain countries either by patents or by copyrighted interfaces, the original copyright holder +who places the Program under this License may add an explicit geographical distribution limitation excluding those countries, so that distribution is permitted +only in or among countries not thus excluded. In such case, this License incorporates the limitation as if written in the body of this License. + +9. The Free Software Foundation may publish revised and/or new versions of the General Public License from time to time. Such new versions will be similar +in spirit to the present version, but may differ in detail to address new problems or concerns. + +Each version is given a distinguishing version number. If the Program specifies a version number of this License which applies to it and "any later version", +you have the option of following the terms and conditions either of that version or of any later version published by the Free Software Foundation. If the +Program does not specify a version number of this License, you may choose any version ever published by the Free Software Foundation. + +10. If you wish to incorporate parts of the Program into other free programs whose distribution conditions are different, write to the author to ask for +permission. For software which is copyrighted by the Free Software Foundation, write to the Free Software Foundation; we sometimes make exceptions for +this. Our decision will be guided by the two goals of preserving the free status of all derivatives of our free software and of promoting the sharing and reuse of +software generally. + +NO WARRANTY + +11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT +PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER +PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT +NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE +RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU +ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + +12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY +OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, +INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO +USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES +SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH +HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. + +END OF TERMS AND CONDITIONS diff --git a/wmmp3/ChangeLog b/wmmp3/ChangeLog new file mode 100644 index 0000000..0e0707f --- /dev/null +++ b/wmmp3/ChangeLog @@ -0,0 +1,18 @@ +Fri Nov 19 23:15:00 1999 Matthew D. Campbell + * added random play + * added continuous filename scrolling + +Wed Oct 6 16:56:00 1999 Patrick Crosby + * changed pixmap + * added support for directory changing + * added repeat support + + +Wed Oct 6 12:55:00 1999 Patrick Crosby + + * configure.in added + * Makefile.am added + * configure added...whole building process should be working + now. + + \ No newline at end of file diff --git a/wmmp3/INSTALL b/wmmp3/INSTALL new file mode 100644 index 0000000..ac8dade --- /dev/null +++ b/wmmp3/INSTALL @@ -0,0 +1,27 @@ +wmmp3 v0.06 INSTALL -- Patrick Crosby + +1. Type './configure' + +2. Type 'make' + +3. Type 'make install' + +The default will probably put it in /usr/local/bin. Use + + ./configure --help + +to set various options if the default is not right for you. + +4. Copy the sample .wmmp3 file to your home directory: + + cp sample.wmmp3 ~/.wmmp3 + +5. Edit ~/.wmmp3 to set the directories where your mp3 files live. + +6. The executable is 'wmmp3', so run it. + + + + + + diff --git a/wmmp3/Makefile.am b/wmmp3/Makefile.am new file mode 100644 index 0000000..26d391a --- /dev/null +++ b/wmmp3/Makefile.am @@ -0,0 +1,4 @@ +bin_PROGRAMS = wmmp3 +wmmp3_SOURCES = main.c mpg123ctl.c wmgeneral.c buttons.c main.h mpg123ctl.h wmgeneral.h buttons.h charset.xpm wmmp3.xpm song_hash.c song_hash.h +EXTRA_DIST = sample.wmmp3 + diff --git a/wmmp3/Makefile.in b/wmmp3/Makefile.in new file mode 100644 index 0000000..65dbf77 --- /dev/null +++ b/wmmp3/Makefile.in @@ -0,0 +1,321 @@ +# Makefile.in generated automatically by automake 1.4 from Makefile.am + +# Copyright (C) 1994, 1995-8, 1999 Free Software Foundation, Inc. +# This Makefile.in is free software; the Free Software Foundation +# gives unlimited permission to copy and/or distribute it, +# with or without modifications, as long as this notice is preserved. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY, to the extent permitted by law; without +# even the implied warranty of MERCHANTABILITY or FITNESS FOR A +# PARTICULAR PURPOSE. + + +SHELL = @SHELL@ + +srcdir = @srcdir@ +top_srcdir = @top_srcdir@ +VPATH = @srcdir@ +prefix = @prefix@ +exec_prefix = @exec_prefix@ + +bindir = @bindir@ +sbindir = @sbindir@ +libexecdir = @libexecdir@ +datadir = @datadir@ +sysconfdir = @sysconfdir@ +sharedstatedir = @sharedstatedir@ +localstatedir = @localstatedir@ +libdir = @libdir@ +infodir = @infodir@ +mandir = @mandir@ +includedir = @includedir@ +oldincludedir = /usr/include + +DESTDIR = + +pkgdatadir = $(datadir)/@PACKAGE@ +pkglibdir = $(libdir)/@PACKAGE@ +pkgincludedir = $(includedir)/@PACKAGE@ + +top_builddir = . + +ACLOCAL = @ACLOCAL@ +AUTOCONF = @AUTOCONF@ +AUTOMAKE = @AUTOMAKE@ +AUTOHEADER = @AUTOHEADER@ + +INSTALL = @INSTALL@ +INSTALL_PROGRAM = @INSTALL_PROGRAM@ $(AM_INSTALL_PROGRAM_FLAGS) +INSTALL_DATA = @INSTALL_DATA@ +INSTALL_SCRIPT = @INSTALL_SCRIPT@ +transform = @program_transform_name@ + +NORMAL_INSTALL = : +PRE_INSTALL = : +POST_INSTALL = : +NORMAL_UNINSTALL = : +PRE_UNINSTALL = : +POST_UNINSTALL = : +CC = @CC@ +MAKEINFO = @MAKEINFO@ +PACKAGE = @PACKAGE@ +VERSION = @VERSION@ + +bin_PROGRAMS = wmmp3 +wmmp3_SOURCES = main.c mpg123ctl.c wmgeneral.c buttons.c main.h mpg123ctl.h wmgeneral.h buttons.h charset.xpm wmmp3.xpm song_hash.c song_hash.h +EXTRA_DIST = sample.wmmp3 +ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 +mkinstalldirs = $(SHELL) $(top_srcdir)/mkinstalldirs +CONFIG_CLEAN_FILES = +PROGRAMS = $(bin_PROGRAMS) + + +DEFS = @DEFS@ -I. -I$(srcdir) +CPPFLAGS = @CPPFLAGS@ +LDFLAGS = @LDFLAGS@ +LIBS = @LIBS@ +X_CFLAGS = @X_CFLAGS@ +X_LIBS = @X_LIBS@ +X_EXTRA_LIBS = @X_EXTRA_LIBS@ +X_PRE_LIBS = @X_PRE_LIBS@ +wmmp3_OBJECTS = main.o mpg123ctl.o wmgeneral.o buttons.o song_hash.o +wmmp3_LDADD = $(LDADD) +wmmp3_DEPENDENCIES = +wmmp3_LDFLAGS = +CFLAGS = @CFLAGS@ +COMPILE = $(CC) $(DEFS) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) +CCLD = $(CC) +LINK = $(CCLD) $(AM_CFLAGS) $(CFLAGS) $(LDFLAGS) -o $@ +DIST_COMMON = README AUTHORS COPYING ChangeLog INSTALL Makefile.am \ +Makefile.in NEWS TODO aclocal.m4 configure configure.in install-sh \ +missing mkinstalldirs + + +DISTFILES = $(DIST_COMMON) $(SOURCES) $(HEADERS) $(TEXINFOS) $(EXTRA_DIST) + +TAR = gtar +GZIP_ENV = --best +SOURCES = $(wmmp3_SOURCES) +OBJECTS = $(wmmp3_OBJECTS) + +all: all-redirect +.SUFFIXES: +.SUFFIXES: .S .c .o .s +$(srcdir)/Makefile.in: Makefile.am $(top_srcdir)/configure.in $(ACLOCAL_M4) + cd $(top_srcdir) && $(AUTOMAKE) --gnu --include-deps Makefile + +Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status + cd $(top_builddir) \ + && CONFIG_FILES=$@ CONFIG_HEADERS= $(SHELL) ./config.status + +$(ACLOCAL_M4): configure.in + cd $(srcdir) && $(ACLOCAL) + +config.status: $(srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) + $(SHELL) ./config.status --recheck +$(srcdir)/configure: $(srcdir)/configure.in $(ACLOCAL_M4) $(CONFIGURE_DEPENDENCIES) + cd $(srcdir) && $(AUTOCONF) + +mostlyclean-binPROGRAMS: + +clean-binPROGRAMS: + -test -z "$(bin_PROGRAMS)" || rm -f $(bin_PROGRAMS) + +distclean-binPROGRAMS: + +maintainer-clean-binPROGRAMS: + +install-binPROGRAMS: $(bin_PROGRAMS) + @$(NORMAL_INSTALL) + $(mkinstalldirs) $(DESTDIR)$(bindir) + @list='$(bin_PROGRAMS)'; for p in $$list; do \ + if test -f $$p; then \ + echo " $(INSTALL_PROGRAM) $$p $(DESTDIR)$(bindir)/`echo $$p|sed 's/$(EXEEXT)$$//'|sed '$(transform)'|sed 's/$$/$(EXEEXT)/'`"; \ + $(INSTALL_PROGRAM) $$p $(DESTDIR)$(bindir)/`echo $$p|sed 's/$(EXEEXT)$$//'|sed '$(transform)'|sed 's/$$/$(EXEEXT)/'`; \ + else :; fi; \ + done + +uninstall-binPROGRAMS: + @$(NORMAL_UNINSTALL) + list='$(bin_PROGRAMS)'; for p in $$list; do \ + rm -f $(DESTDIR)$(bindir)/`echo $$p|sed 's/$(EXEEXT)$$//'|sed '$(transform)'|sed 's/$$/$(EXEEXT)/'`; \ + done + +.c.o: + $(COMPILE) -c $< + +.s.o: + $(COMPILE) -c $< + +.S.o: + $(COMPILE) -c $< + +mostlyclean-compile: + -rm -f *.o core *.core + +clean-compile: + +distclean-compile: + -rm -f *.tab.c + +maintainer-clean-compile: + +wmmp3: $(wmmp3_OBJECTS) $(wmmp3_DEPENDENCIES) + @rm -f wmmp3 + $(LINK) $(wmmp3_LDFLAGS) $(wmmp3_OBJECTS) $(wmmp3_LDADD) $(LIBS) + +tags: TAGS + +ID: $(HEADERS) $(SOURCES) $(LISP) + list='$(SOURCES) $(HEADERS)'; \ + unique=`for i in $$list; do echo $$i; done | \ + awk ' { files[$$0] = 1; } \ + END { for (i in files) print i; }'`; \ + here=`pwd` && cd $(srcdir) \ + && mkid -f$$here/ID $$unique $(LISP) + +TAGS: $(HEADERS) $(SOURCES) $(TAGS_DEPENDENCIES) $(LISP) + tags=; \ + here=`pwd`; \ + list='$(SOURCES) $(HEADERS)'; \ + unique=`for i in $$list; do echo $$i; done | \ + awk ' { files[$$0] = 1; } \ + END { for (i in files) print i; }'`; \ + test -z "$(ETAGS_ARGS)$$unique$(LISP)$$tags" \ + || (cd $(srcdir) && etags $(ETAGS_ARGS) $$tags $$unique $(LISP) -o $$here/TAGS) + +mostlyclean-tags: + +clean-tags: + +distclean-tags: + -rm -f TAGS ID + +maintainer-clean-tags: + +distdir = $(PACKAGE)-$(VERSION) +top_distdir = $(distdir) + +# This target untars the dist file and tries a VPATH configuration. Then +# it guarantees that the distribution is self-contained by making another +# tarfile. +distcheck: dist + -rm -rf $(distdir) + GZIP=$(GZIP_ENV) $(TAR) zxf $(distdir).tar.gz + mkdir $(distdir)/=build + mkdir $(distdir)/=inst + dc_install_base=`cd $(distdir)/=inst && pwd`; \ + cd $(distdir)/=build \ + && ../configure --srcdir=.. --prefix=$$dc_install_base \ + && $(MAKE) $(AM_MAKEFLAGS) \ + && $(MAKE) $(AM_MAKEFLAGS) dvi \ + && $(MAKE) $(AM_MAKEFLAGS) check \ + && $(MAKE) $(AM_MAKEFLAGS) install \ + && $(MAKE) $(AM_MAKEFLAGS) installcheck \ + && $(MAKE) $(AM_MAKEFLAGS) dist + -rm -rf $(distdir) + @banner="$(distdir).tar.gz is ready for distribution"; \ + dashes=`echo "$$banner" | sed s/./=/g`; \ + echo "$$dashes"; \ + echo "$$banner"; \ + echo "$$dashes" +dist: distdir + -chmod -R a+r $(distdir) + GZIP=$(GZIP_ENV) $(TAR) chozf $(distdir).tar.gz $(distdir) + -rm -rf $(distdir) +dist-all: distdir + -chmod -R a+r $(distdir) + GZIP=$(GZIP_ENV) $(TAR) chozf $(distdir).tar.gz $(distdir) + -rm -rf $(distdir) +distdir: $(DISTFILES) + -rm -rf $(distdir) + mkdir $(distdir) + -chmod 777 $(distdir) + @for file in $(DISTFILES); do \ + d=$(srcdir); \ + if test -d $$d/$$file; then \ + cp -pr $$d/$$file $(distdir)/$$file; \ + else \ + test -f $(distdir)/$$file \ + || ln $$d/$$file $(distdir)/$$file 2> /dev/null \ + || cp -p $$d/$$file $(distdir)/$$file || :; \ + fi; \ + done + +info-am: +info: info-am +dvi-am: +dvi: dvi-am +check-am: all-am +check: check-am +installcheck-am: +installcheck: installcheck-am +install-exec-am: install-binPROGRAMS +install-exec: install-exec-am + +install-data-am: +install-data: install-data-am + +install-am: all-am + @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am +install: install-am +uninstall-am: uninstall-binPROGRAMS +uninstall: uninstall-am +all-am: Makefile $(PROGRAMS) +all-redirect: all-am +install-strip: + $(MAKE) $(AM_MAKEFLAGS) AM_INSTALL_PROGRAM_FLAGS=-s install +installdirs: + $(mkinstalldirs) $(DESTDIR)$(bindir) + + +mostlyclean-generic: + +clean-generic: + +distclean-generic: + -rm -f Makefile $(CONFIG_CLEAN_FILES) + -rm -f config.cache config.log stamp-h stamp-h[0-9]* + +maintainer-clean-generic: +mostlyclean-am: mostlyclean-binPROGRAMS mostlyclean-compile \ + mostlyclean-tags mostlyclean-generic + +mostlyclean: mostlyclean-am + +clean-am: clean-binPROGRAMS clean-compile clean-tags clean-generic \ + mostlyclean-am + +clean: clean-am + +distclean-am: distclean-binPROGRAMS distclean-compile distclean-tags \ + distclean-generic clean-am + +distclean: distclean-am + -rm -f config.status + +maintainer-clean-am: maintainer-clean-binPROGRAMS \ + maintainer-clean-compile maintainer-clean-tags \ + maintainer-clean-generic distclean-am + @echo "This command is intended for maintainers to use;" + @echo "it deletes files that may require special tools to rebuild." + +maintainer-clean: maintainer-clean-am + -rm -f config.status + +.PHONY: mostlyclean-binPROGRAMS distclean-binPROGRAMS clean-binPROGRAMS \ +maintainer-clean-binPROGRAMS uninstall-binPROGRAMS install-binPROGRAMS \ +mostlyclean-compile distclean-compile clean-compile \ +maintainer-clean-compile tags mostlyclean-tags distclean-tags \ +clean-tags maintainer-clean-tags distdir info-am info dvi-am dvi check \ +check-am installcheck-am installcheck install-exec-am install-exec \ +install-data-am install-data install-am install uninstall-am uninstall \ +all-redirect all-am all installdirs mostlyclean-generic \ +distclean-generic clean-generic maintainer-clean-generic clean \ +mostlyclean distclean maintainer-clean + + +# Tell versions [3.59,3.63) of GNU make to not export all variables. +# Otherwise a system limit (for SysV at least) may be exceeded. +.NOEXPORT: diff --git a/wmmp3/NEWS b/wmmp3/NEWS new file mode 100644 index 0000000..e69de29 diff --git a/wmmp3/README b/wmmp3/README new file mode 100644 index 0000000..2e4956f --- /dev/null +++ b/wmmp3/README @@ -0,0 +1,20 @@ +wmmp3 v0.08 README -- Patrick Crosby + +wmmp3 is an mpg123 frontend. It is a small X application that will also +work as a windowmaker dock app. + +All user options are contained in a config file, ~/.wmmp3 . There is a +sample.wmmp3 file in the distribution that can be used as an +example/template. + +Basically, enter in the config file any directories that contain mp3 files +and wmmp3 right now will play all the files in each directory sequentially +when you press play. You can select which directory to start with by using +the up/down buttons in the left frame when the player is stopped. Pressing +the "infinity" button will cause the player to repeat the songs in the current +directory instead of just playing them once. Pressing the "random" (R) button +will cause the player to randomly select songs from the current directory. + +More documentation can be found at http://dotfiles.com/software/wmmp3/ + +If you find any bugs, please let me know at diff --git a/wmmp3/TODO b/wmmp3/TODO new file mode 100644 index 0000000..88a641e --- /dev/null +++ b/wmmp3/TODO @@ -0,0 +1,33 @@ + +TODO: + +* realize when done playing +* use playlist +* pause +* get rid of directory limit + +DONE: + +* make back button work +* call mpg123 with -q flag +* write readme +* have play continue to next directory when done with current +* display filename +* scrolling + - once first time + - any time they click in the box (once) +* make buttons depress +* allow user to change directory +* repeat +* -v,--version +* -h, --help +* when not playing, clicking in title puts depressed stop button there +* get rid of song limit (do it dynamically) +* fix previous bug +* random + + + + + + diff --git a/wmmp3/aclocal.m4 b/wmmp3/aclocal.m4 new file mode 100644 index 0000000..9f8add8 --- /dev/null +++ b/wmmp3/aclocal.m4 @@ -0,0 +1,104 @@ +dnl aclocal.m4 generated automatically by aclocal 1.4 + +dnl Copyright (C) 1994, 1995-8, 1999 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +dnl This program is distributed in the hope that it will be useful, +dnl but WITHOUT ANY WARRANTY, to the extent permitted by law; without +dnl even the implied warranty of MERCHANTABILITY or FITNESS FOR A +dnl PARTICULAR PURPOSE. + +# Do all the work for Automake. This macro actually does too much -- +# some checks are only needed if your package does certain things. +# But this isn't really a big deal. + +# serial 1 + +dnl Usage: +dnl AM_INIT_AUTOMAKE(package,version, [no-define]) + +AC_DEFUN(AM_INIT_AUTOMAKE, +[AC_REQUIRE([AC_PROG_INSTALL]) +PACKAGE=[$1] +AC_SUBST(PACKAGE) +VERSION=[$2] +AC_SUBST(VERSION) +dnl test to see if srcdir already configured +if test "`cd $srcdir && pwd`" != "`pwd`" && test -f $srcdir/config.status; then + AC_MSG_ERROR([source directory already configured; run "make distclean" there first]) +fi +ifelse([$3],, +AC_DEFINE_UNQUOTED(PACKAGE, "$PACKAGE", [Name of package]) +AC_DEFINE_UNQUOTED(VERSION, "$VERSION", [Version number of package])) +AC_REQUIRE([AM_SANITY_CHECK]) +AC_REQUIRE([AC_ARG_PROGRAM]) +dnl FIXME This is truly gross. +missing_dir=`cd $ac_aux_dir && pwd` +AM_MISSING_PROG(ACLOCAL, aclocal, $missing_dir) +AM_MISSING_PROG(AUTOCONF, autoconf, $missing_dir) +AM_MISSING_PROG(AUTOMAKE, automake, $missing_dir) +AM_MISSING_PROG(AUTOHEADER, autoheader, $missing_dir) +AM_MISSING_PROG(MAKEINFO, makeinfo, $missing_dir) +AC_REQUIRE([AC_PROG_MAKE_SET])]) + +# +# Check to make sure that the build environment is sane. +# + +AC_DEFUN(AM_SANITY_CHECK, +[AC_MSG_CHECKING([whether build environment is sane]) +# Just in case +sleep 1 +echo timestamp > conftestfile +# Do `set' in a subshell so we don't clobber the current shell's +# arguments. Must try -L first in case configure is actually a +# symlink; some systems play weird games with the mod time of symlinks +# (eg FreeBSD returns the mod time of the symlink's containing +# directory). +if ( + set X `ls -Lt $srcdir/configure conftestfile 2> /dev/null` + if test "[$]*" = "X"; then + # -L didn't work. + set X `ls -t $srcdir/configure conftestfile` + fi + if test "[$]*" != "X $srcdir/configure conftestfile" \ + && test "[$]*" != "X conftestfile $srcdir/configure"; then + + # If neither matched, then we have a broken ls. This can happen + # if, for instance, CONFIG_SHELL is bash and it inherits a + # broken ls alias from the environment. This has actually + # happened. Such a system could not be considered "sane". + AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken +alias in your environment]) + fi + + test "[$]2" = conftestfile + ) +then + # Ok. + : +else + AC_MSG_ERROR([newly created file is older than distributed files! +Check your system clock]) +fi +rm -f conftest* +AC_MSG_RESULT(yes)]) + +dnl AM_MISSING_PROG(NAME, PROGRAM, DIRECTORY) +dnl The program must properly implement --version. +AC_DEFUN(AM_MISSING_PROG, +[AC_MSG_CHECKING(for working $2) +# Run test in a subshell; some versions of sh will print an error if +# an executable is not found, even if stderr is redirected. +# Redirect stdin to placate older versions of autoconf. Sigh. +if ($2 --version) < /dev/null > /dev/null 2>&1; then + $1=$2 + AC_MSG_RESULT(found) +else + $1="$3/missing $2" + AC_MSG_RESULT(missing) +fi +AC_SUBST($1)]) + diff --git a/wmmp3/buttons.c b/wmmp3/buttons.c new file mode 100644 index 0000000..fb86eb7 --- /dev/null +++ b/wmmp3/buttons.c @@ -0,0 +1,83 @@ +/* + * wmmp3 + * Copyright (c)1999 Patrick Crosby . + * This software covered by the GPL. See COPYING file for details. + * + * buttons.c + * + * This file contains button code. + * + * $Id: mpg123ctl.c,v 1.12 1999/10/08 06:21:41 pcrosby Exp $ + */ + +#include "buttons.h" + +struct coord { + int x; + int y; + int w; + int h; +}; + +struct coord btn_pos[] = { + {35, 34, 12, 11}, /* stop */ + {46, 34, 12, 11}, /* play */ + {35, 45, 12, 11}, /* back */ + {46, 45, 12, 11}, /* next */ + {6, 34, 12, 11}, /* prev_dir */ + {17, 34, 12, 11}, /* random */ + {6, 45, 12, 11}, /* next_dir */ + {17, 45, 12, 11}, /* repeat */ + {5, 18, 54, 12} /* song title */ +}; + +struct coord btn_up[] = { + {35, 70, 12, 11}, /* stop */ + {46, 70, 12, 11}, /* play */ + {35, 81, 12, 11}, /* back */ + {46, 81, 12, 11}, /* next */ + {6, 70, 12, 11}, /* prev_dir */ + {17, 70, 12, 11}, /* random */ + {6, 81, 12, 11}, /* next_dir */ + {17, 81, 12, 11} /* repeat */ +}; + +struct coord btn_down[] = { + {35, 97, 12, 11}, /* stop */ + {46, 97, 12, 11}, /* play */ + {35, 108, 12, 11}, /* back */ + {46, 108, 12, 11}, /* next */ + {6, 97, 12, 11}, /* prev_dir */ + {17, 97, 12, 11}, /* random */ + {6, 108, 12, 11}, /* next_dir */ + {17, 108, 12, 11} /* repeat */ +}; + +struct coord btn_gray[] = { + {95, 70, 12, 11}, /* stop */ + {106, 70, 12, 11}, /* play */ + {95, 81, 12, 11}, /* back */ + {106, 81, 12, 11}, /* next */ + {66, 70, 12, 11}, /* prev_dir */ + {77, 70, 12, 11}, /* random */ + {66, 81, 12, 11}, /* next_dir */ + {77, 81, 12, 11} /* repeat */ +}; + +void button_down(int i) +{ + copyXPMArea(btn_down[i].x, btn_down[i].y, btn_down[i].w, btn_down[i].h, + btn_pos[i].x, btn_pos[i].y); +} + +void button_up(int i) +{ + copyXPMArea(btn_up[i].x, btn_up[i].y, btn_up[i].w, btn_up[i].h, + btn_pos[i].x, btn_pos[i].y); +} + +void button_gray(int i) +{ + copyXPMArea(btn_gray[i].x, btn_gray[i].y, btn_gray[i].w, btn_gray[i].h, + btn_pos[i].x, btn_pos[i].y); +} diff --git a/wmmp3/buttons.h b/wmmp3/buttons.h new file mode 100644 index 0000000..019de56 --- /dev/null +++ b/wmmp3/buttons.h @@ -0,0 +1,20 @@ +/* + * wmmp3 + * Copyright (c)1999 Patrick Crosby . + * This software covered by the GPL. See COPYING file for details. + * + * buttons.h + * + * header file for buttons.c + * + * $Id: mpg123ctl.c,v 1.12 1999/10/08 06:21:41 pcrosby Exp $ + */ + +#ifndef __BUTTONS__ +#define __BUTTONS__ + +void button_down(int i); +void button_up(int i); +void button_gray(int i); + +#endif diff --git a/wmmp3/charset.xpm b/wmmp3/charset.xpm new file mode 100644 index 0000000..b87e6a0 --- /dev/null +++ b/wmmp3/charset.xpm @@ -0,0 +1,21 @@ +/* XPM */ +static char * charset_xpm[] = { +"590 14 4 1", +" c None", +". c #202020 s back_colour", +"+ c #188A86 s semi_colour", +"@ c #20B2AE s led_colour", +".........+....@.@..........+.........+@@+.........+@....@+.......................................+@@@+...+...+@@@+.+@@@+.+...+.+@@@+.+@@@+.+@@@+.+@@@+.+@@@+................@.........@....+@@@+.+@@@+.+@@@+.+@@@...@@@+.+@@@..+@@@+.+@@@+.+@@@+.+...+...+.......+.+...+.+.....@...@.@...+.+@@@+.+@@@+.+@@@+.+@@@+.+@@@+.+@@@+.+...+.+...+.+...+.+...+.+...+.+@@@+..@@+.........+@@....@.....................+...............+........+@@+.......+.................+.......+...............................................+.........................................++.........++............................", +".........@....+.+...+.+..+@@@+....@..@..@....@....@......@...+.+.+...+........................@..@...@...@.......@.....@.@...@.@.....@.........@.@...@.@...@...@...........@...........@...@...@.@...@.@...@.@...@.@.....@...@.@.....@.....@.....@...@...@.......@.@...@.@.....@@.@@.@@..@.@...@.@...@.@...@.@...@.@.......@...@...@.@...@.@...@.@...@.@...@.....@..@.....@.......@...@.@..........@.........@...............@........@..@.......@.......@......@..@.......@...............................................@.........................................@.....@.....@............................", +".........@.........+@@@+.@.@...@..@..@..@....+....@......@....@@@....@........................@..@...@...@.......@.....@.@...@.@.....@.........@.@...@.@...@...@.....@....@.............@......@.@.+.@.@...@.@...@.@.....@...@.@.....@.....@.....@...@...@.......@.@...@.@.....@.@.@.@.@.@.@...@.@...@.@...@.@...@.@.......@...@...@.@...@.@...@..@.@..@...@....@...@.....@.......@................+...+@@@+.@...............@.+@@@+..@....+@@@@.@.................@..@+...@.....................@@@@+.+@@@@.@+@@+.+@@@+.+@@@+...................+...+.+...+.+@@@+...@.....@.....@.....@.@....................", +".........@..........@.@..+@@@+...@...@@@..........@......@.....@...+@@@+.......+@@@+.........@...@...@...@...+@@@+..@@@+.+@@@@.+@@@+.@@@@+.....@.+@@@+.+@@@@.........@...@...............@....@..@.@.@.@@@@@.@@@@..@.....@...@.@@@@..@@@@..@.+@+.@@@@@...@.......@.@@@@..@.....@...@.@.@.@.@...@.@@@@+.@@..@.@@@@..+@@@+...@...@...@.@...@.@...@...@...+@@@+...@....@......@......@........................@.@@@@+.@@@@+.+@@@@.@...@.@@@...@...@.@@@@+...+......+..@.@.....@...@@+@+.@@@@+.+@@@+.@...@.@...@.@...+.@.......@...+...+.+...+.+...+..@.@..@...@....@...@......@......@...@.@.....................", +".........@.........+@@@+...@.@...@...@+@.@........@......@....@@@....@.......................@...@...@...@...@.........@.....@.....@.@...@.....@.@...@.....@...@..........@.............@....@...@.+@@.@...@.@...@.@.....@...@.@.....@.....@...@.@...@...@...+...@.@...@.@.....@...@.@..+@.@...@.@.....@.@.@.@...@.....@...@...@...@.@...@.@.@.@..@.@....@....@.....@......@......@....................+@@@@.@...@.@.....@...@.@@@@+..@....+@@@@.@...@...@......@..@@......@...@.@.@.@...@.@...@.@@@@+.+@@@@.@.....+@@@+...@...@...@.@...@.@.+.@...@...+@@@@...@.....@.....@.....@............................", +"....................+.+..+@@@+..@..@.@..@.........@......@...+.+.+...+.....@................@....@...@...@...@.........@.....@.....@.@...@.....@.@...@.....@...@.....@.....@...........@.........@.....@...@.@...@.@.....@...@.@.....@.....@...@.@...@...@...@...@.@...@.@.....@...@.@..@@.@...@.@.....@..@@.@...@.....@...@...@...@.@...@.@@.@@.@...@...@...@......@.......@.....@....................@...@.@...@.@.....@...@.@......@........@.@...@...@....@.@..@.@.....@...@.@.@.@...@.@...@.@.........@.@.........@...@...@...@..@.@..@.@.@..@.@......@..@......@.....@.....@............................", +".........@.................+....@....+@@+@........+@....@+.................+...........@....@....+@@@+...+...+@@@+.+@@@+.....+.+@@@+.+@@@+.....+.+@@@+.+@@@+.........+......@.........@......@...+@@@+.+...+.+@@@...@@@+.+@@@..+@@@+.+.....+@@@+.+...+...+...+@@@+.+...+.+@@@+.+...+.+...@.+@@@+.+.....+@@@+.+...+.+@@@+...+...+@@@@..@@@..+...+.+...+...@...+@@@+..@@+.....@...+@@........@@@@@.......+@@@+.@@@@+.@@@@+.+@@@@.+@@@+..@....+@@@+.+...+...+....+@+..+..@+...+...+.+.+.+...+.+@@@+.+.........@.+.....+@@@+...+...+@@@@...@...+@+@+.+...+.+@@@+.+@@@+...++....@....++............................", +".........@............@........+...+...@.....@.........+@@@+..@@+....................+@@@+.+@@@+..+@+.........+@+...+@+..............+@@@@...............@....+@+........@.....@.......@....@@.....@@....@....@.+...@.@....@...+@@@+.+@@@+..@@.....@@....@....@.@...@@.....@@....@....@.@...@@@+..@.+...@@.....@@....@....@.+...@.@........+@@@+..@@.....@@....@....@.@....@@..+.....@@@@+..@@.....@@....@....@.+...@.@....@................@@.....@@....@....@.@...@@.....@@....@.........+.+....@.+...@@.....@@....@....@.+.....................@@.....@@....@...........@@.........@.@.....................", +"...............+.....@.@.@...@.@...@...@....@.....@.@..@...@..+@@....@.@.............@...@........@.@....@......@.....@.....@........@@@.@...............@....+@+..@.@...@...+.@...+.........+.....+....+.+..+.@...............@.@...@.......+.....+....+.+..........+.....+....+.+.........@..@.+.@.....+.....+....+.+..+.@.........+...+.@..+@...+.....+....+.+..........+...@.....@...@...+.....+....+.+..+.@.............................+.....+....+.+..........+.....+....+.+...@.@...@@...+.@.....+.....+....+.+..+.@....@.@....@...........+.....+....+.+...@.@....+..................................", +".........@...+@@@+...@....@@@..@...@...@....+@+........@.@+@..+@@...@.@..@@@@@.......@@@@@........+@+...@@@....@.....@+....@...+...+.@@@.@...............@..........@.@..@..@..@..@....@...+@@@+.+@@@+.+@@@+.+@@@+.+@@@+.+@@@+.@.@...@.....@@@@+.@@@@+.@@@@+.@@@@+...+.....+.....+.....+....@..@.@...+.+@@@+.+@@@+.+@@@+.+@@@+.+@@@+..@.@..@..@@.+...+.+...+.+...+.+...+.@...@.@@@@+.@@@@+.+@@@+.+@@@+.+@@@+.+@@@+.+@@@+.+@@@+.+@+@+.+@@@+.+@@@+.+@@@+.+@@@+.+@@@+.........................+..@..........................................................................+...+.+.....+...+....................", +".........@...@.@....@@@...@.@..+@@@+........@.@........@@..@..@@@..@.@.......@..@@@..@@@+@...............@....@@@...+@@........@...@.@@@.@...@................@@@....@.@...@.....@....@....@...@.@...@.@...@.@...@.@...@.@...@.@@@@+.@.....@.....@.....@.....@.......@.....@.....@.....@...+@+.@.@@..@.@...@.@...@.@...@.@...@.@...@...@...@.@.@.@...@.@...@.@...@.@...@.@...@.@...@.@...@.....@.....@.....@.....@.....@.....@...@.@.@.....@...@.@...@.@...@.@...@...+.....+.....+.....+...+@@@+.@@@@+.+@@@+.+@@@+.+@@@+.+@@@+.+@@@+.+@@@+.+@@@+.+...+.+...+.+...+.+...+.@...@.@@@@+.@...@....................", +".........@...@.@.....@....@@@....@.....@....+@+........@.@+@........@.@..............@@.@@.....................................@...@.+@@@@..........................@.@...@..@..@.@@.@.....@@@@@.@@@@@.@@@@@.@@@@@.@@@@@.@@@@@.@.@...+@@@+.@@@+..@@@+..@@@+..@@@+....@.....@.....@.....@....@..@.@.@.@.@...@.@...@.@...@.@...@.@...@..@.@..@@..@.@...@.@...@.@...@.@...@.+@@@+.@@@@+.@...@.+@@@@.+@@@@.+@@@@.+@@@@.+@@@@.+@@@@.+@@@+.+@@@+.@@@@+.+@@@+.+@@@+.+@@@+...@.....@.....@.....@...@...@.@...@.@...@.@...@.@...@.@...@.@...@.......@.+@@.@...@.@...@.@...@.@...@.+@@@@.@...@.+@@@@....................", +".........@...+@@@+...@...@...@..@@@....@......@........@...@.........@.@.............@...@..............@@@....................@@@@+...@.@..........@..............@.@...+..@@.+..++.@...@.@...@.@...@.@...@.@...@.@...@.@...@.@.@......@..@.....@.....@.....@.......@.....@.....@.....@....@..@.@..@@.@...@.@...@.@...@.@...@.@...@.+...+.@+..@.@...@.@...@.@...@.@...@...@...@.....@@@@+.@...@.@...@.@...@.@...@.@...@.@...@.@.@......@..@.....@.....@.....@.......@.....@.....@.....@...@...@.@...@.@...@.@...@.@...@.@...@.@...@...@...@@+.@.@...@.@...@.@...@.@...@.....@.@@@@+.....@....................", +".........+.....+...+@+@+.........@.....@.....@.........+@@@+.........................+@@@+.....................................@.......+.+.........@@........................@....@@.+@@@+.+...+.+...+.+...+.+...+.+...+.+...+.+.@@+...+...@@@@+.@@@@+.@@@@+.@@@@+...+.....+.....+.....+....@@@+.+...@.+@@@+.+@@@+.+@@@+.+@@@+.+@@@+.......+@@@+.+@@@+.+@@@+.+@@@+.+@@@+...+...+.....+.....+@@@+.+@@@+.+@@@+.+@@@+.+@@@+.+@@@+.+@+@+...+...+@@@+.+@@@+.+@@@+.+@@@+...+.....+.....+.....+...+@@@+.+...+.+@@@+.+@@@+.+@@@+.+@@@+.+@@@+.......+@@@+.+@@@@.+@@@@.+@@@@.+@@@@.+@@@+.+.....+@@@+...................."}; diff --git a/wmmp3/configure b/wmmp3/configure new file mode 100755 index 0000000..0675bd0 --- /dev/null +++ b/wmmp3/configure @@ -0,0 +1,2402 @@ +#! /bin/sh + +# Guess values for system-dependent variables and create Makefiles. +# Generated automatically using autoconf version 2.13 +# Copyright (C) 1992, 93, 94, 95, 96 Free Software Foundation, Inc. +# +# This configure script is free software; the Free Software Foundation +# gives unlimited permission to copy, distribute and modify it. + +# Defaults: +ac_help= +ac_default_prefix=/usr/local +# Any additions from configure.in: +ac_help="$ac_help + --with-x use the X Window System" + +# Initialize some variables set by options. +# The variables have the same names as the options, with +# dashes changed to underlines. +build=NONE +cache_file=./config.cache +exec_prefix=NONE +host=NONE +no_create= +nonopt=NONE +no_recursion= +prefix=NONE +program_prefix=NONE +program_suffix=NONE +program_transform_name=s,x,x, +silent= +site= +srcdir= +target=NONE +verbose= +x_includes=NONE +x_libraries=NONE +bindir='${exec_prefix}/bin' +sbindir='${exec_prefix}/sbin' +libexecdir='${exec_prefix}/libexec' +datadir='${prefix}/share' +sysconfdir='${prefix}/etc' +sharedstatedir='${prefix}/com' +localstatedir='${prefix}/var' +libdir='${exec_prefix}/lib' +includedir='${prefix}/include' +oldincludedir='/usr/include' +infodir='${prefix}/info' +mandir='${prefix}/man' + +# Initialize some other variables. +subdirs= +MFLAGS= MAKEFLAGS= +SHELL=${CONFIG_SHELL-/bin/sh} +# Maximum number of lines to put in a shell here document. +ac_max_here_lines=12 + +ac_prev= +for ac_option +do + + # If the previous option needs an argument, assign it. + if test -n "$ac_prev"; then + eval "$ac_prev=\$ac_option" + ac_prev= + continue + fi + + case "$ac_option" in + -*=*) ac_optarg=`echo "$ac_option" | sed 's/[-_a-zA-Z0-9]*=//'` ;; + *) ac_optarg= ;; + esac + + # Accept the important Cygnus configure options, so we can diagnose typos. + + case "$ac_option" in + + -bindir | --bindir | --bindi | --bind | --bin | --bi) + ac_prev=bindir ;; + -bindir=* | --bindir=* | --bindi=* | --bind=* | --bin=* | --bi=*) + bindir="$ac_optarg" ;; + + -build | --build | --buil | --bui | --bu) + ac_prev=build ;; + -build=* | --build=* | --buil=* | --bui=* | --bu=*) + build="$ac_optarg" ;; + + -cache-file | --cache-file | --cache-fil | --cache-fi \ + | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c) + ac_prev=cache_file ;; + -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \ + | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* | --c=*) + cache_file="$ac_optarg" ;; + + -datadir | --datadir | --datadi | --datad | --data | --dat | --da) + ac_prev=datadir ;; + -datadir=* | --datadir=* | --datadi=* | --datad=* | --data=* | --dat=* \ + | --da=*) + datadir="$ac_optarg" ;; + + -disable-* | --disable-*) + ac_feature=`echo $ac_option|sed -e 's/-*disable-//'` + # Reject names that are not valid shell variable names. + if test -n "`echo $ac_feature| sed 's/[-a-zA-Z0-9_]//g'`"; then + { echo "configure: error: $ac_feature: invalid feature name" 1>&2; exit 1; } + fi + ac_feature=`echo $ac_feature| sed 's/-/_/g'` + eval "enable_${ac_feature}=no" ;; + + -enable-* | --enable-*) + ac_feature=`echo $ac_option|sed -e 's/-*enable-//' -e 's/=.*//'` + # Reject names that are not valid shell variable names. + if test -n "`echo $ac_feature| sed 's/[-_a-zA-Z0-9]//g'`"; then + { echo "configure: error: $ac_feature: invalid feature name" 1>&2; exit 1; } + fi + ac_feature=`echo $ac_feature| sed 's/-/_/g'` + case "$ac_option" in + *=*) ;; + *) ac_optarg=yes ;; + esac + eval "enable_${ac_feature}='$ac_optarg'" ;; + + -exec-prefix | --exec_prefix | --exec-prefix | --exec-prefi \ + | --exec-pref | --exec-pre | --exec-pr | --exec-p | --exec- \ + | --exec | --exe | --ex) + ac_prev=exec_prefix ;; + -exec-prefix=* | --exec_prefix=* | --exec-prefix=* | --exec-prefi=* \ + | --exec-pref=* | --exec-pre=* | --exec-pr=* | --exec-p=* | --exec-=* \ + | --exec=* | --exe=* | --ex=*) + exec_prefix="$ac_optarg" ;; + + -gas | --gas | --ga | --g) + # Obsolete; use --with-gas. + with_gas=yes ;; + + -help | --help | --hel | --he) + # Omit some internal or obsolete options to make the list less imposing. + # This message is too long to be a string in the A/UX 3.1 sh. + cat << EOF +Usage: configure [options] [host] +Options: [defaults in brackets after descriptions] +Configuration: + --cache-file=FILE cache test results in FILE + --help print this message + --no-create do not create output files + --quiet, --silent do not print \`checking...' messages + --version print the version of autoconf that created configure +Directory and file names: + --prefix=PREFIX install architecture-independent files in PREFIX + [$ac_default_prefix] + --exec-prefix=EPREFIX install architecture-dependent files in EPREFIX + [same as prefix] + --bindir=DIR user executables in DIR [EPREFIX/bin] + --sbindir=DIR system admin executables in DIR [EPREFIX/sbin] + --libexecdir=DIR program executables in DIR [EPREFIX/libexec] + --datadir=DIR read-only architecture-independent data in DIR + [PREFIX/share] + --sysconfdir=DIR read-only single-machine data in DIR [PREFIX/etc] + --sharedstatedir=DIR modifiable architecture-independent data in DIR + [PREFIX/com] + --localstatedir=DIR modifiable single-machine data in DIR [PREFIX/var] + --libdir=DIR object code libraries in DIR [EPREFIX/lib] + --includedir=DIR C header files in DIR [PREFIX/include] + --oldincludedir=DIR C header files for non-gcc in DIR [/usr/include] + --infodir=DIR info documentation in DIR [PREFIX/info] + --mandir=DIR man documentation in DIR [PREFIX/man] + --srcdir=DIR find the sources in DIR [configure dir or ..] + --program-prefix=PREFIX prepend PREFIX to installed program names + --program-suffix=SUFFIX append SUFFIX to installed program names + --program-transform-name=PROGRAM + run sed PROGRAM on installed program names +EOF + cat << EOF +Host type: + --build=BUILD configure for building on BUILD [BUILD=HOST] + --host=HOST configure for HOST [guessed] + --target=TARGET configure for TARGET [TARGET=HOST] +Features and packages: + --disable-FEATURE do not include FEATURE (same as --enable-FEATURE=no) + --enable-FEATURE[=ARG] include FEATURE [ARG=yes] + --with-PACKAGE[=ARG] use PACKAGE [ARG=yes] + --without-PACKAGE do not use PACKAGE (same as --with-PACKAGE=no) + --x-includes=DIR X include files are in DIR + --x-libraries=DIR X library files are in DIR +EOF + if test -n "$ac_help"; then + echo "--enable and --with options recognized:$ac_help" + fi + exit 0 ;; + + -host | --host | --hos | --ho) + ac_prev=host ;; + -host=* | --host=* | --hos=* | --ho=*) + host="$ac_optarg" ;; + + -includedir | --includedir | --includedi | --included | --include \ + | --includ | --inclu | --incl | --inc) + ac_prev=includedir ;; + -includedir=* | --includedir=* | --includedi=* | --included=* | --include=* \ + | --includ=* | --inclu=* | --incl=* | --inc=*) + includedir="$ac_optarg" ;; + + -infodir | --infodir | --infodi | --infod | --info | --inf) + ac_prev=infodir ;; + -infodir=* | --infodir=* | --infodi=* | --infod=* | --info=* | --inf=*) + infodir="$ac_optarg" ;; + + -libdir | --libdir | --libdi | --libd) + ac_prev=libdir ;; + -libdir=* | --libdir=* | --libdi=* | --libd=*) + libdir="$ac_optarg" ;; + + -libexecdir | --libexecdir | --libexecdi | --libexecd | --libexec \ + | --libexe | --libex | --libe) + ac_prev=libexecdir ;; + -libexecdir=* | --libexecdir=* | --libexecdi=* | --libexecd=* | --libexec=* \ + | --libexe=* | --libex=* | --libe=*) + libexecdir="$ac_optarg" ;; + + -localstatedir | --localstatedir | --localstatedi | --localstated \ + | --localstate | --localstat | --localsta | --localst \ + | --locals | --local | --loca | --loc | --lo) + ac_prev=localstatedir ;; + -localstatedir=* | --localstatedir=* | --localstatedi=* | --localstated=* \ + | --localstate=* | --localstat=* | --localsta=* | --localst=* \ + | --locals=* | --local=* | --loca=* | --loc=* | --lo=*) + localstatedir="$ac_optarg" ;; + + -mandir | --mandir | --mandi | --mand | --man | --ma | --m) + ac_prev=mandir ;; + -mandir=* | --mandir=* | --mandi=* | --mand=* | --man=* | --ma=* | --m=*) + mandir="$ac_optarg" ;; + + -nfp | --nfp | --nf) + # Obsolete; use --without-fp. + with_fp=no ;; + + -no-create | --no-create | --no-creat | --no-crea | --no-cre \ + | --no-cr | --no-c) + no_create=yes ;; + + -no-recursion | --no-recursion | --no-recursio | --no-recursi \ + | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r) + no_recursion=yes ;; + + -oldincludedir | --oldincludedir | --oldincludedi | --oldincluded \ + | --oldinclude | --oldinclud | --oldinclu | --oldincl | --oldinc \ + | --oldin | --oldi | --old | --ol | --o) + ac_prev=oldincludedir ;; + -oldincludedir=* | --oldincludedir=* | --oldincludedi=* | --oldincluded=* \ + | --oldinclude=* | --oldinclud=* | --oldinclu=* | --oldincl=* | --oldinc=* \ + | --oldin=* | --oldi=* | --old=* | --ol=* | --o=*) + oldincludedir="$ac_optarg" ;; + + -prefix | --prefix | --prefi | --pref | --pre | --pr | --p) + ac_prev=prefix ;; + -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*) + prefix="$ac_optarg" ;; + + -program-prefix | --program-prefix | --program-prefi | --program-pref \ + | --program-pre | --program-pr | --program-p) + ac_prev=program_prefix ;; + -program-prefix=* | --program-prefix=* | --program-prefi=* \ + | --program-pref=* | --program-pre=* | --program-pr=* | --program-p=*) + program_prefix="$ac_optarg" ;; + + -program-suffix | --program-suffix | --program-suffi | --program-suff \ + | --program-suf | --program-su | --program-s) + ac_prev=program_suffix ;; + -program-suffix=* | --program-suffix=* | --program-suffi=* \ + | --program-suff=* | --program-suf=* | --program-su=* | --program-s=*) + program_suffix="$ac_optarg" ;; + + -program-transform-name | --program-transform-name \ + | --program-transform-nam | --program-transform-na \ + | --program-transform-n | --program-transform- \ + | --program-transform | --program-transfor \ + | --program-transfo | --program-transf \ + | --program-trans | --program-tran \ + | --progr-tra | --program-tr | --program-t) + ac_prev=program_transform_name ;; + -program-transform-name=* | --program-transform-name=* \ + | --program-transform-nam=* | --program-transform-na=* \ + | --program-transform-n=* | --program-transform-=* \ + | --program-transform=* | --program-transfor=* \ + | --program-transfo=* | --program-transf=* \ + | --program-trans=* | --program-tran=* \ + | --progr-tra=* | --program-tr=* | --program-t=*) + program_transform_name="$ac_optarg" ;; + + -q | -quiet | --quiet | --quie | --qui | --qu | --q \ + | -silent | --silent | --silen | --sile | --sil) + silent=yes ;; + + -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb) + ac_prev=sbindir ;; + -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \ + | --sbi=* | --sb=*) + sbindir="$ac_optarg" ;; + + -sharedstatedir | --sharedstatedir | --sharedstatedi \ + | --sharedstated | --sharedstate | --sharedstat | --sharedsta \ + | --sharedst | --shareds | --shared | --share | --shar \ + | --sha | --sh) + ac_prev=sharedstatedir ;; + -sharedstatedir=* | --sharedstatedir=* | --sharedstatedi=* \ + | --sharedstated=* | --sharedstate=* | --sharedstat=* | --sharedsta=* \ + | --sharedst=* | --shareds=* | --shared=* | --share=* | --shar=* \ + | --sha=* | --sh=*) + sharedstatedir="$ac_optarg" ;; + + -site | --site | --sit) + ac_prev=site ;; + -site=* | --site=* | --sit=*) + site="$ac_optarg" ;; + + -srcdir | --srcdir | --srcdi | --srcd | --src | --sr) + ac_prev=srcdir ;; + -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*) + srcdir="$ac_optarg" ;; + + -sysconfdir | --sysconfdir | --sysconfdi | --sysconfd | --sysconf \ + | --syscon | --sysco | --sysc | --sys | --sy) + ac_prev=sysconfdir ;; + -sysconfdir=* | --sysconfdir=* | --sysconfdi=* | --sysconfd=* | --sysconf=* \ + | --syscon=* | --sysco=* | --sysc=* | --sys=* | --sy=*) + sysconfdir="$ac_optarg" ;; + + -target | --target | --targe | --targ | --tar | --ta | --t) + ac_prev=target ;; + -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*) + target="$ac_optarg" ;; + + -v | -verbose | --verbose | --verbos | --verbo | --verb) + verbose=yes ;; + + -version | --version | --versio | --versi | --vers) + echo "configure generated by autoconf version 2.13" + exit 0 ;; + + -with-* | --with-*) + ac_package=`echo $ac_option|sed -e 's/-*with-//' -e 's/=.*//'` + # Reject names that are not valid shell variable names. + if test -n "`echo $ac_package| sed 's/[-_a-zA-Z0-9]//g'`"; then + { echo "configure: error: $ac_package: invalid package name" 1>&2; exit 1; } + fi + ac_package=`echo $ac_package| sed 's/-/_/g'` + case "$ac_option" in + *=*) ;; + *) ac_optarg=yes ;; + esac + eval "with_${ac_package}='$ac_optarg'" ;; + + -without-* | --without-*) + ac_package=`echo $ac_option|sed -e 's/-*without-//'` + # Reject names that are not valid shell variable names. + if test -n "`echo $ac_package| sed 's/[-a-zA-Z0-9_]//g'`"; then + { echo "configure: error: $ac_package: invalid package name" 1>&2; exit 1; } + fi + ac_package=`echo $ac_package| sed 's/-/_/g'` + eval "with_${ac_package}=no" ;; + + --x) + # Obsolete; use --with-x. + with_x=yes ;; + + -x-includes | --x-includes | --x-include | --x-includ | --x-inclu \ + | --x-incl | --x-inc | --x-in | --x-i) + ac_prev=x_includes ;; + -x-includes=* | --x-includes=* | --x-include=* | --x-includ=* | --x-inclu=* \ + | --x-incl=* | --x-inc=* | --x-in=* | --x-i=*) + x_includes="$ac_optarg" ;; + + -x-libraries | --x-libraries | --x-librarie | --x-librari \ + | --x-librar | --x-libra | --x-libr | --x-lib | --x-li | --x-l) + ac_prev=x_libraries ;; + -x-libraries=* | --x-libraries=* | --x-librarie=* | --x-librari=* \ + | --x-librar=* | --x-libra=* | --x-libr=* | --x-lib=* | --x-li=* | --x-l=*) + x_libraries="$ac_optarg" ;; + + -*) { echo "configure: error: $ac_option: invalid option; use --help to show usage" 1>&2; exit 1; } + ;; + + *) + if test -n "`echo $ac_option| sed 's/[-a-z0-9.]//g'`"; then + echo "configure: warning: $ac_option: invalid host type" 1>&2 + fi + if test "x$nonopt" != xNONE; then + { echo "configure: error: can only configure for one host and one target at a time" 1>&2; exit 1; } + fi + nonopt="$ac_option" + ;; + + esac +done + +if test -n "$ac_prev"; then + { echo "configure: error: missing argument to --`echo $ac_prev | sed 's/_/-/g'`" 1>&2; exit 1; } +fi + +trap 'rm -fr conftest* confdefs* core core.* *.core $ac_clean_files; exit 1' 1 2 15 + +# File descriptor usage: +# 0 standard input +# 1 file creation +# 2 errors and warnings +# 3 some systems may open it to /dev/tty +# 4 used on the Kubota Titan +# 6 checking for... messages and results +# 5 compiler messages saved in config.log +if test "$silent" = yes; then + exec 6>/dev/null +else + exec 6>&1 +fi +exec 5>./config.log + +echo "\ +This file contains any messages produced by compilers while +running configure, to aid debugging if configure makes a mistake. +" 1>&5 + +# Strip out --no-create and --no-recursion so they do not pile up. +# Also quote any args containing shell metacharacters. +ac_configure_args= +for ac_arg +do + case "$ac_arg" in + -no-create | --no-create | --no-creat | --no-crea | --no-cre \ + | --no-cr | --no-c) ;; + -no-recursion | --no-recursion | --no-recursio | --no-recursi \ + | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r) ;; + *" "*|*" "*|*[\[\]\~\#\$\^\&\*\(\)\{\}\\\|\;\<\>\?]*) + ac_configure_args="$ac_configure_args '$ac_arg'" ;; + *) ac_configure_args="$ac_configure_args $ac_arg" ;; + esac +done + +# NLS nuisances. +# Only set these to C if already set. These must not be set unconditionally +# because not all systems understand e.g. LANG=C (notably SCO). +# Fixing LC_MESSAGES prevents Solaris sh from translating var values in `set'! +# Non-C LC_CTYPE values break the ctype check. +if test "${LANG+set}" = set; then LANG=C; export LANG; fi +if test "${LC_ALL+set}" = set; then LC_ALL=C; export LC_ALL; fi +if test "${LC_MESSAGES+set}" = set; then LC_MESSAGES=C; export LC_MESSAGES; fi +if test "${LC_CTYPE+set}" = set; then LC_CTYPE=C; export LC_CTYPE; fi + +# confdefs.h avoids OS command line length limits that DEFS can exceed. +rm -rf conftest* confdefs.h +# AIX cpp loses on an empty file, so make sure it contains at least a newline. +echo > confdefs.h + +# A filename unique to this package, relative to the directory that +# configure is in, which we can look for to find out if srcdir is correct. +ac_unique_file=main.c + +# Find the source files, if location was not specified. +if test -z "$srcdir"; then + ac_srcdir_defaulted=yes + # Try the directory containing this script, then its parent. + ac_prog=$0 + ac_confdir=`echo $ac_prog|sed 's%/[^/][^/]*$%%'` + test "x$ac_confdir" = "x$ac_prog" && ac_confdir=. + srcdir=$ac_confdir + if test ! -r $srcdir/$ac_unique_file; then + srcdir=.. + fi +else + ac_srcdir_defaulted=no +fi +if test ! -r $srcdir/$ac_unique_file; then + if test "$ac_srcdir_defaulted" = yes; then + { echo "configure: error: can not find sources in $ac_confdir or .." 1>&2; exit 1; } + else + { echo "configure: error: can not find sources in $srcdir" 1>&2; exit 1; } + fi +fi +srcdir=`echo "${srcdir}" | sed 's%\([^/]\)/*$%\1%'` + +# Prefer explicitly selected file to automatically selected ones. +if test -z "$CONFIG_SITE"; then + if test "x$prefix" != xNONE; then + CONFIG_SITE="$prefix/share/config.site $prefix/etc/config.site" + else + CONFIG_SITE="$ac_default_prefix/share/config.site $ac_default_prefix/etc/config.site" + fi +fi +for ac_site_file in $CONFIG_SITE; do + if test -r "$ac_site_file"; then + echo "loading site script $ac_site_file" + . "$ac_site_file" + fi +done + +if test -r "$cache_file"; then + echo "loading cache $cache_file" + . $cache_file +else + echo "creating cache $cache_file" + > $cache_file +fi + +ac_ext=c +# CFLAGS is not in ac_cpp because -g, -O, etc. are not valid cpp options. +ac_cpp='$CPP $CPPFLAGS' +ac_compile='${CC-cc} -c $CFLAGS $CPPFLAGS conftest.$ac_ext 1>&5' +ac_link='${CC-cc} -o conftest${ac_exeext} $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS 1>&5' +cross_compiling=$ac_cv_prog_cc_cross + +ac_exeext= +ac_objext=o +if (echo "testing\c"; echo 1,2,3) | grep c >/dev/null; then + # Stardent Vistra SVR4 grep lacks -e, says ghazi@caip.rutgers.edu. + if (echo -n testing; echo 1,2,3) | sed s/-n/xn/ | grep xn >/dev/null; then + ac_n= ac_c=' +' ac_t=' ' + else + ac_n=-n ac_c= ac_t= + fi +else + ac_n= ac_c='\c' ac_t= +fi + + +ac_aux_dir= +for ac_dir in $srcdir $srcdir/.. $srcdir/../..; do + if test -f $ac_dir/install-sh; then + ac_aux_dir=$ac_dir + ac_install_sh="$ac_aux_dir/install-sh -c" + break + elif test -f $ac_dir/install.sh; then + ac_aux_dir=$ac_dir + ac_install_sh="$ac_aux_dir/install.sh -c" + break + fi +done +if test -z "$ac_aux_dir"; then + { echo "configure: error: can not find install-sh or install.sh in $srcdir $srcdir/.. $srcdir/../.." 1>&2; exit 1; } +fi +ac_config_guess=$ac_aux_dir/config.guess +ac_config_sub=$ac_aux_dir/config.sub +ac_configure=$ac_aux_dir/configure # This should be Cygnus configure. + +# Find a good install program. We prefer a C program (faster), +# so one script is as good as another. But avoid the broken or +# incompatible versions: +# SysV /etc/install, /usr/sbin/install +# SunOS /usr/etc/install +# IRIX /sbin/install +# AIX /bin/install +# AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag +# AFS /usr/afsws/bin/install, which mishandles nonexistent args +# SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" +# ./install, which can be erroneously created by make from ./install.sh. +echo $ac_n "checking for a BSD compatible install""... $ac_c" 1>&6 +echo "configure:558: checking for a BSD compatible install" >&5 +if test -z "$INSTALL"; then +if eval "test \"`echo '$''{'ac_cv_path_install'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + IFS="${IFS= }"; ac_save_IFS="$IFS"; IFS=":" + for ac_dir in $PATH; do + # Account for people who put trailing slashes in PATH elements. + case "$ac_dir/" in + /|./|.//|/etc/*|/usr/sbin/*|/usr/etc/*|/sbin/*|/usr/afsws/bin/*|/usr/ucb/*) ;; + *) + # OSF1 and SCO ODT 3.0 have their own names for install. + # Don't use installbsd from OSF since it installs stuff as root + # by default. + for ac_prog in ginstall scoinst install; do + if test -f $ac_dir/$ac_prog; then + if test $ac_prog = install && + grep dspmsg $ac_dir/$ac_prog >/dev/null 2>&1; then + # AIX install. It has an incompatible calling convention. + : + else + ac_cv_path_install="$ac_dir/$ac_prog -c" + break 2 + fi + fi + done + ;; + esac + done + IFS="$ac_save_IFS" + +fi + if test "${ac_cv_path_install+set}" = set; then + INSTALL="$ac_cv_path_install" + else + # As a last resort, use the slow shell script. We don't cache a + # path for INSTALL within a source directory, because that will + # break other packages using the cache if that directory is + # removed, or if the path is relative. + INSTALL="$ac_install_sh" + fi +fi +echo "$ac_t""$INSTALL" 1>&6 + +# Use test -z because SunOS4 sh mishandles braces in ${var-val}. +# It thinks the first close brace ends the variable substitution. +test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' + +test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL_PROGRAM}' + +test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' + +echo $ac_n "checking whether build environment is sane""... $ac_c" 1>&6 +echo "configure:611: checking whether build environment is sane" >&5 +# Just in case +sleep 1 +echo timestamp > conftestfile +# Do `set' in a subshell so we don't clobber the current shell's +# arguments. Must try -L first in case configure is actually a +# symlink; some systems play weird games with the mod time of symlinks +# (eg FreeBSD returns the mod time of the symlink's containing +# directory). +if ( + set X `ls -Lt $srcdir/configure conftestfile 2> /dev/null` + if test "$*" = "X"; then + # -L didn't work. + set X `ls -t $srcdir/configure conftestfile` + fi + if test "$*" != "X $srcdir/configure conftestfile" \ + && test "$*" != "X conftestfile $srcdir/configure"; then + + # If neither matched, then we have a broken ls. This can happen + # if, for instance, CONFIG_SHELL is bash and it inherits a + # broken ls alias from the environment. This has actually + # happened. Such a system could not be considered "sane". + { echo "configure: error: ls -t appears to fail. Make sure there is not a broken +alias in your environment" 1>&2; exit 1; } + fi + + test "$2" = conftestfile + ) +then + # Ok. + : +else + { echo "configure: error: newly created file is older than distributed files! +Check your system clock" 1>&2; exit 1; } +fi +rm -f conftest* +echo "$ac_t""yes" 1>&6 +if test "$program_transform_name" = s,x,x,; then + program_transform_name= +else + # Double any \ or $. echo might interpret backslashes. + cat <<\EOF_SED > conftestsed +s,\\,\\\\,g; s,\$,$$,g +EOF_SED + program_transform_name="`echo $program_transform_name|sed -f conftestsed`" + rm -f conftestsed +fi +test "$program_prefix" != NONE && + program_transform_name="s,^,${program_prefix},; $program_transform_name" +# Use a double $ so make ignores it. +test "$program_suffix" != NONE && + program_transform_name="s,\$\$,${program_suffix},; $program_transform_name" + +# sed with no file args requires a program. +test "$program_transform_name" = "" && program_transform_name="s,x,x," + +echo $ac_n "checking whether ${MAKE-make} sets \${MAKE}""... $ac_c" 1>&6 +echo "configure:668: checking whether ${MAKE-make} sets \${MAKE}" >&5 +set dummy ${MAKE-make}; ac_make=`echo "$2" | sed 'y%./+-%__p_%'` +if eval "test \"`echo '$''{'ac_cv_prog_make_${ac_make}_set'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + cat > conftestmake <<\EOF +all: + @echo 'ac_maketemp="${MAKE}"' +EOF +# GNU make sometimes prints "make[1]: Entering...", which would confuse us. +eval `${MAKE-make} -f conftestmake 2>/dev/null | grep temp=` +if test -n "$ac_maketemp"; then + eval ac_cv_prog_make_${ac_make}_set=yes +else + eval ac_cv_prog_make_${ac_make}_set=no +fi +rm -f conftestmake +fi +if eval "test \"`echo '$ac_cv_prog_make_'${ac_make}_set`\" = yes"; then + echo "$ac_t""yes" 1>&6 + SET_MAKE= +else + echo "$ac_t""no" 1>&6 + SET_MAKE="MAKE=${MAKE-make}" +fi + + +PACKAGE=wmmp3 + +VERSION=0.12 + +if test "`cd $srcdir && pwd`" != "`pwd`" && test -f $srcdir/config.status; then + { echo "configure: error: source directory already configured; run "make distclean" there first" 1>&2; exit 1; } +fi +cat >> confdefs.h <> confdefs.h <&6 +echo "configure:714: checking for working aclocal" >&5 +# Run test in a subshell; some versions of sh will print an error if +# an executable is not found, even if stderr is redirected. +# Redirect stdin to placate older versions of autoconf. Sigh. +if (aclocal --version) < /dev/null > /dev/null 2>&1; then + ACLOCAL=aclocal + echo "$ac_t""found" 1>&6 +else + ACLOCAL="$missing_dir/missing aclocal" + echo "$ac_t""missing" 1>&6 +fi + +echo $ac_n "checking for working autoconf""... $ac_c" 1>&6 +echo "configure:727: checking for working autoconf" >&5 +# Run test in a subshell; some versions of sh will print an error if +# an executable is not found, even if stderr is redirected. +# Redirect stdin to placate older versions of autoconf. Sigh. +if (autoconf --version) < /dev/null > /dev/null 2>&1; then + AUTOCONF=autoconf + echo "$ac_t""found" 1>&6 +else + AUTOCONF="$missing_dir/missing autoconf" + echo "$ac_t""missing" 1>&6 +fi + +echo $ac_n "checking for working automake""... $ac_c" 1>&6 +echo "configure:740: checking for working automake" >&5 +# Run test in a subshell; some versions of sh will print an error if +# an executable is not found, even if stderr is redirected. +# Redirect stdin to placate older versions of autoconf. Sigh. +if (automake --version) < /dev/null > /dev/null 2>&1; then + AUTOMAKE=automake + echo "$ac_t""found" 1>&6 +else + AUTOMAKE="$missing_dir/missing automake" + echo "$ac_t""missing" 1>&6 +fi + +echo $ac_n "checking for working autoheader""... $ac_c" 1>&6 +echo "configure:753: checking for working autoheader" >&5 +# Run test in a subshell; some versions of sh will print an error if +# an executable is not found, even if stderr is redirected. +# Redirect stdin to placate older versions of autoconf. Sigh. +if (autoheader --version) < /dev/null > /dev/null 2>&1; then + AUTOHEADER=autoheader + echo "$ac_t""found" 1>&6 +else + AUTOHEADER="$missing_dir/missing autoheader" + echo "$ac_t""missing" 1>&6 +fi + +echo $ac_n "checking for working makeinfo""... $ac_c" 1>&6 +echo "configure:766: checking for working makeinfo" >&5 +# Run test in a subshell; some versions of sh will print an error if +# an executable is not found, even if stderr is redirected. +# Redirect stdin to placate older versions of autoconf. Sigh. +if (makeinfo --version) < /dev/null > /dev/null 2>&1; then + MAKEINFO=makeinfo + echo "$ac_t""found" 1>&6 +else + MAKEINFO="$missing_dir/missing makeinfo" + echo "$ac_t""missing" 1>&6 +fi + + +# Extract the first word of "gcc", so it can be a program name with args. +set dummy gcc; ac_word=$2 +echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 +echo "configure:782: checking for $ac_word" >&5 +if eval "test \"`echo '$''{'ac_cv_prog_CC'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else + IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS=":" + ac_dummy="$PATH" + for ac_dir in $ac_dummy; do + test -z "$ac_dir" && ac_dir=. + if test -f $ac_dir/$ac_word; then + ac_cv_prog_CC="gcc" + break + fi + done + IFS="$ac_save_ifs" +fi +fi +CC="$ac_cv_prog_CC" +if test -n "$CC"; then + echo "$ac_t""$CC" 1>&6 +else + echo "$ac_t""no" 1>&6 +fi + +if test -z "$CC"; then + # Extract the first word of "cc", so it can be a program name with args. +set dummy cc; ac_word=$2 +echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 +echo "configure:812: checking for $ac_word" >&5 +if eval "test \"`echo '$''{'ac_cv_prog_CC'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else + IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS=":" + ac_prog_rejected=no + ac_dummy="$PATH" + for ac_dir in $ac_dummy; do + test -z "$ac_dir" && ac_dir=. + if test -f $ac_dir/$ac_word; then + if test "$ac_dir/$ac_word" = "/usr/ucb/cc"; then + ac_prog_rejected=yes + continue + fi + ac_cv_prog_CC="cc" + break + fi + done + IFS="$ac_save_ifs" +if test $ac_prog_rejected = yes; then + # We found a bogon in the path, so make sure we never use it. + set dummy $ac_cv_prog_CC + shift + if test $# -gt 0; then + # We chose a different compiler from the bogus one. + # However, it has the same basename, so the bogon will be chosen + # first if we set CC to just the basename; use the full file name. + shift + set dummy "$ac_dir/$ac_word" "$@" + shift + ac_cv_prog_CC="$@" + fi +fi +fi +fi +CC="$ac_cv_prog_CC" +if test -n "$CC"; then + echo "$ac_t""$CC" 1>&6 +else + echo "$ac_t""no" 1>&6 +fi + + if test -z "$CC"; then + case "`uname -s`" in + *win32* | *WIN32*) + # Extract the first word of "cl", so it can be a program name with args. +set dummy cl; ac_word=$2 +echo $ac_n "checking for $ac_word""... $ac_c" 1>&6 +echo "configure:863: checking for $ac_word" >&5 +if eval "test \"`echo '$''{'ac_cv_prog_CC'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + if test -n "$CC"; then + ac_cv_prog_CC="$CC" # Let the user override the test. +else + IFS="${IFS= }"; ac_save_ifs="$IFS"; IFS=":" + ac_dummy="$PATH" + for ac_dir in $ac_dummy; do + test -z "$ac_dir" && ac_dir=. + if test -f $ac_dir/$ac_word; then + ac_cv_prog_CC="cl" + break + fi + done + IFS="$ac_save_ifs" +fi +fi +CC="$ac_cv_prog_CC" +if test -n "$CC"; then + echo "$ac_t""$CC" 1>&6 +else + echo "$ac_t""no" 1>&6 +fi + ;; + esac + fi + test -z "$CC" && { echo "configure: error: no acceptable cc found in \$PATH" 1>&2; exit 1; } +fi + +echo $ac_n "checking whether the C compiler ($CC $CFLAGS $LDFLAGS) works""... $ac_c" 1>&6 +echo "configure:895: checking whether the C compiler ($CC $CFLAGS $LDFLAGS) works" >&5 + +ac_ext=c +# CFLAGS is not in ac_cpp because -g, -O, etc. are not valid cpp options. +ac_cpp='$CPP $CPPFLAGS' +ac_compile='${CC-cc} -c $CFLAGS $CPPFLAGS conftest.$ac_ext 1>&5' +ac_link='${CC-cc} -o conftest${ac_exeext} $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS 1>&5' +cross_compiling=$ac_cv_prog_cc_cross + +cat > conftest.$ac_ext << EOF + +#line 906 "configure" +#include "confdefs.h" + +main(){return(0);} +EOF +if { (eval echo configure:911: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + ac_cv_prog_cc_works=yes + # If we can't run a trivial program, we are probably using a cross compiler. + if (./conftest; exit) 2>/dev/null; then + ac_cv_prog_cc_cross=no + else + ac_cv_prog_cc_cross=yes + fi +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + ac_cv_prog_cc_works=no +fi +rm -fr conftest* +ac_ext=c +# CFLAGS is not in ac_cpp because -g, -O, etc. are not valid cpp options. +ac_cpp='$CPP $CPPFLAGS' +ac_compile='${CC-cc} -c $CFLAGS $CPPFLAGS conftest.$ac_ext 1>&5' +ac_link='${CC-cc} -o conftest${ac_exeext} $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS 1>&5' +cross_compiling=$ac_cv_prog_cc_cross + +echo "$ac_t""$ac_cv_prog_cc_works" 1>&6 +if test $ac_cv_prog_cc_works = no; then + { echo "configure: error: installation or configuration problem: C compiler cannot create executables." 1>&2; exit 1; } +fi +echo $ac_n "checking whether the C compiler ($CC $CFLAGS $LDFLAGS) is a cross-compiler""... $ac_c" 1>&6 +echo "configure:937: checking whether the C compiler ($CC $CFLAGS $LDFLAGS) is a cross-compiler" >&5 +echo "$ac_t""$ac_cv_prog_cc_cross" 1>&6 +cross_compiling=$ac_cv_prog_cc_cross + +echo $ac_n "checking whether we are using GNU C""... $ac_c" 1>&6 +echo "configure:942: checking whether we are using GNU C" >&5 +if eval "test \"`echo '$''{'ac_cv_prog_gcc'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + cat > conftest.c <&5; (eval $ac_try) 2>&5; }; } | egrep yes >/dev/null 2>&1; then + ac_cv_prog_gcc=yes +else + ac_cv_prog_gcc=no +fi +fi + +echo "$ac_t""$ac_cv_prog_gcc" 1>&6 + +if test $ac_cv_prog_gcc = yes; then + GCC=yes +else + GCC= +fi + +ac_test_CFLAGS="${CFLAGS+set}" +ac_save_CFLAGS="$CFLAGS" +CFLAGS= +echo $ac_n "checking whether ${CC-cc} accepts -g""... $ac_c" 1>&6 +echo "configure:970: checking whether ${CC-cc} accepts -g" >&5 +if eval "test \"`echo '$''{'ac_cv_prog_cc_g'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + echo 'void f(){}' > conftest.c +if test -z "`${CC-cc} -g -c conftest.c 2>&1`"; then + ac_cv_prog_cc_g=yes +else + ac_cv_prog_cc_g=no +fi +rm -f conftest* + +fi + +echo "$ac_t""$ac_cv_prog_cc_g" 1>&6 +if test "$ac_test_CFLAGS" = set; then + CFLAGS="$ac_save_CFLAGS" +elif test $ac_cv_prog_cc_g = yes; then + if test "$GCC" = yes; then + CFLAGS="-g -O2" + else + CFLAGS="-g" + fi +else + if test "$GCC" = yes; then + CFLAGS="-O2" + else + CFLAGS= + fi +fi + +# Find a good install program. We prefer a C program (faster), +# so one script is as good as another. But avoid the broken or +# incompatible versions: +# SysV /etc/install, /usr/sbin/install +# SunOS /usr/etc/install +# IRIX /sbin/install +# AIX /bin/install +# AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag +# AFS /usr/afsws/bin/install, which mishandles nonexistent args +# SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" +# ./install, which can be erroneously created by make from ./install.sh. +echo $ac_n "checking for a BSD compatible install""... $ac_c" 1>&6 +echo "configure:1013: checking for a BSD compatible install" >&5 +if test -z "$INSTALL"; then +if eval "test \"`echo '$''{'ac_cv_path_install'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + IFS="${IFS= }"; ac_save_IFS="$IFS"; IFS=":" + for ac_dir in $PATH; do + # Account for people who put trailing slashes in PATH elements. + case "$ac_dir/" in + /|./|.//|/etc/*|/usr/sbin/*|/usr/etc/*|/sbin/*|/usr/afsws/bin/*|/usr/ucb/*) ;; + *) + # OSF1 and SCO ODT 3.0 have their own names for install. + # Don't use installbsd from OSF since it installs stuff as root + # by default. + for ac_prog in ginstall scoinst install; do + if test -f $ac_dir/$ac_prog; then + if test $ac_prog = install && + grep dspmsg $ac_dir/$ac_prog >/dev/null 2>&1; then + # AIX install. It has an incompatible calling convention. + : + else + ac_cv_path_install="$ac_dir/$ac_prog -c" + break 2 + fi + fi + done + ;; + esac + done + IFS="$ac_save_IFS" + +fi + if test "${ac_cv_path_install+set}" = set; then + INSTALL="$ac_cv_path_install" + else + # As a last resort, use the slow shell script. We don't cache a + # path for INSTALL within a source directory, because that will + # break other packages using the cache if that directory is + # removed, or if the path is relative. + INSTALL="$ac_install_sh" + fi +fi +echo "$ac_t""$INSTALL" 1>&6 + +# Use test -z because SunOS4 sh mishandles braces in ${var-val}. +# It thinks the first close brace ends the variable substitution. +test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' + +test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL_PROGRAM}' + +test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' + +echo $ac_n "checking how to run the C preprocessor""... $ac_c" 1>&6 +echo "configure:1066: checking how to run the C preprocessor" >&5 +# On Suns, sometimes $CPP names a directory. +if test -n "$CPP" && test -d "$CPP"; then + CPP= +fi +if test -z "$CPP"; then +if eval "test \"`echo '$''{'ac_cv_prog_CPP'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + # This must be in double quotes, not single quotes, because CPP may get + # substituted into the Makefile and "${CC-cc}" will confuse make. + CPP="${CC-cc} -E" + # On the NeXT, cc -E runs the code through the compiler's parser, + # not just through cpp. + cat > conftest.$ac_ext < +Syntax Error +EOF +ac_try="$ac_cpp conftest.$ac_ext >/dev/null 2>conftest.out" +{ (eval echo configure:1087: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } +ac_err=`grep -v '^ *+' conftest.out | grep -v "^conftest.${ac_ext}\$"` +if test -z "$ac_err"; then + : +else + echo "$ac_err" >&5 + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + CPP="${CC-cc} -E -traditional-cpp" + cat > conftest.$ac_ext < +Syntax Error +EOF +ac_try="$ac_cpp conftest.$ac_ext >/dev/null 2>conftest.out" +{ (eval echo configure:1104: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } +ac_err=`grep -v '^ *+' conftest.out | grep -v "^conftest.${ac_ext}\$"` +if test -z "$ac_err"; then + : +else + echo "$ac_err" >&5 + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + CPP="${CC-cc} -nologo -E" + cat > conftest.$ac_ext < +Syntax Error +EOF +ac_try="$ac_cpp conftest.$ac_ext >/dev/null 2>conftest.out" +{ (eval echo configure:1121: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } +ac_err=`grep -v '^ *+' conftest.out | grep -v "^conftest.${ac_ext}\$"` +if test -z "$ac_err"; then + : +else + echo "$ac_err" >&5 + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + CPP=/lib/cpp +fi +rm -f conftest* +fi +rm -f conftest* +fi +rm -f conftest* + ac_cv_prog_CPP="$CPP" +fi + CPP="$ac_cv_prog_CPP" +else + ac_cv_prog_CPP="$CPP" +fi +echo "$ac_t""$CPP" 1>&6 + +# If we find X, set shell vars x_includes and x_libraries to the +# paths, otherwise set no_x=yes. +# Uses ac_ vars as temps to allow command line to override cache and checks. +# --without-x overrides everything else, but does not touch the cache. +echo $ac_n "checking for X""... $ac_c" 1>&6 +echo "configure:1150: checking for X" >&5 + +# Check whether --with-x or --without-x was given. +if test "${with_x+set}" = set; then + withval="$with_x" + : +fi + +# $have_x is `yes', `no', `disabled', or empty when we do not yet know. +if test "x$with_x" = xno; then + # The user explicitly disabled X. + have_x=disabled +else + if test "x$x_includes" != xNONE && test "x$x_libraries" != xNONE; then + # Both variables are already set. + have_x=yes + else +if eval "test \"`echo '$''{'ac_cv_have_x'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + # One or both of the vars are not set, and there is no cached value. +ac_x_includes=NO ac_x_libraries=NO +rm -fr conftestdir +if mkdir conftestdir; then + cd conftestdir + # Make sure to not put "make" in the Imakefile rules, since we grep it out. + cat > Imakefile <<'EOF' +acfindx: + @echo 'ac_im_incroot="${INCROOT}"; ac_im_usrlibdir="${USRLIBDIR}"; ac_im_libdir="${LIBDIR}"' +EOF + if (xmkmf) >/dev/null 2>/dev/null && test -f Makefile; then + # GNU make sometimes prints "make[1]: Entering...", which would confuse us. + eval `${MAKE-make} acfindx 2>/dev/null | grep -v make` + # Open Windows xmkmf reportedly sets LIBDIR instead of USRLIBDIR. + for ac_extension in a so sl; do + if test ! -f $ac_im_usrlibdir/libX11.$ac_extension && + test -f $ac_im_libdir/libX11.$ac_extension; then + ac_im_usrlibdir=$ac_im_libdir; break + fi + done + # Screen out bogus values from the imake configuration. They are + # bogus both because they are the default anyway, and because + # using them would break gcc on systems where it needs fixed includes. + case "$ac_im_incroot" in + /usr/include) ;; + *) test -f "$ac_im_incroot/X11/Xos.h" && ac_x_includes="$ac_im_incroot" ;; + esac + case "$ac_im_usrlibdir" in + /usr/lib | /lib) ;; + *) test -d "$ac_im_usrlibdir" && ac_x_libraries="$ac_im_usrlibdir" ;; + esac + fi + cd .. + rm -fr conftestdir +fi + +if test "$ac_x_includes" = NO; then + # Guess where to find include files, by looking for this one X11 .h file. + test -z "$x_direct_test_include" && x_direct_test_include=X11/Intrinsic.h + + # First, try using that file with no special directory specified. +cat > conftest.$ac_ext < +EOF +ac_try="$ac_cpp conftest.$ac_ext >/dev/null 2>conftest.out" +{ (eval echo configure:1217: \"$ac_try\") 1>&5; (eval $ac_try) 2>&5; } +ac_err=`grep -v '^ *+' conftest.out | grep -v "^conftest.${ac_ext}\$"` +if test -z "$ac_err"; then + rm -rf conftest* + # We can compile using X headers with no special include directory. +ac_x_includes= +else + echo "$ac_err" >&5 + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + # Look for the header file in a standard set of common directories. +# Check X11 before X11Rn because it is often a symlink to the current release. + for ac_dir in \ + /usr/X11/include \ + /usr/X11R6/include \ + /usr/X11R5/include \ + /usr/X11R4/include \ + \ + /usr/include/X11 \ + /usr/include/X11R6 \ + /usr/include/X11R5 \ + /usr/include/X11R4 \ + \ + /usr/local/X11/include \ + /usr/local/X11R6/include \ + /usr/local/X11R5/include \ + /usr/local/X11R4/include \ + \ + /usr/local/include/X11 \ + /usr/local/include/X11R6 \ + /usr/local/include/X11R5 \ + /usr/local/include/X11R4 \ + \ + /usr/X386/include \ + /usr/x386/include \ + /usr/XFree86/include/X11 \ + \ + /usr/include \ + /usr/local/include \ + /usr/unsupported/include \ + /usr/athena/include \ + /usr/local/x11r5/include \ + /usr/lpp/Xamples/include \ + \ + /usr/openwin/include \ + /usr/openwin/share/include \ + ; \ + do + if test -r "$ac_dir/$x_direct_test_include"; then + ac_x_includes=$ac_dir + break + fi + done +fi +rm -f conftest* +fi # $ac_x_includes = NO + +if test "$ac_x_libraries" = NO; then + # Check for the libraries. + + test -z "$x_direct_test_library" && x_direct_test_library=Xt + test -z "$x_direct_test_function" && x_direct_test_function=XtMalloc + + # See if we find them without any special options. + # Don't add to $LIBS permanently. + ac_save_LIBS="$LIBS" + LIBS="-l$x_direct_test_library $LIBS" +cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + LIBS="$ac_save_LIBS" +# We can link X programs with no special library path. +ac_x_libraries= +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + LIBS="$ac_save_LIBS" +# First see if replacing the include by lib works. +# Check X11 before X11Rn because it is often a symlink to the current release. +for ac_dir in `echo "$ac_x_includes" | sed s/include/lib/` \ + /usr/X11/lib \ + /usr/X11R6/lib \ + /usr/X11R5/lib \ + /usr/X11R4/lib \ + \ + /usr/lib/X11 \ + /usr/lib/X11R6 \ + /usr/lib/X11R5 \ + /usr/lib/X11R4 \ + \ + /usr/local/X11/lib \ + /usr/local/X11R6/lib \ + /usr/local/X11R5/lib \ + /usr/local/X11R4/lib \ + \ + /usr/local/lib/X11 \ + /usr/local/lib/X11R6 \ + /usr/local/lib/X11R5 \ + /usr/local/lib/X11R4 \ + \ + /usr/X386/lib \ + /usr/x386/lib \ + /usr/XFree86/lib/X11 \ + \ + /usr/lib \ + /usr/local/lib \ + /usr/unsupported/lib \ + /usr/athena/lib \ + /usr/local/x11r5/lib \ + /usr/lpp/Xamples/lib \ + /lib/usr/lib/X11 \ + \ + /usr/openwin/lib \ + /usr/openwin/share/lib \ + ; \ +do + for ac_extension in a so sl; do + if test -r $ac_dir/lib${x_direct_test_library}.$ac_extension; then + ac_x_libraries=$ac_dir + break 2 + fi + done +done +fi +rm -f conftest* +fi # $ac_x_libraries = NO + +if test "$ac_x_includes" = NO || test "$ac_x_libraries" = NO; then + # Didn't find X anywhere. Cache the known absence of X. + ac_cv_have_x="have_x=no" +else + # Record where we found X for the cache. + ac_cv_have_x="have_x=yes \ + ac_x_includes=$ac_x_includes ac_x_libraries=$ac_x_libraries" +fi +fi + fi + eval "$ac_cv_have_x" +fi # $with_x != no + +if test "$have_x" != yes; then + echo "$ac_t""$have_x" 1>&6 + no_x=yes +else + # If each of the values was on the command line, it overrides each guess. + test "x$x_includes" = xNONE && x_includes=$ac_x_includes + test "x$x_libraries" = xNONE && x_libraries=$ac_x_libraries + # Update the cache value to reflect the command line values. + ac_cv_have_x="have_x=yes \ + ac_x_includes=$x_includes ac_x_libraries=$x_libraries" + echo "$ac_t""libraries $x_libraries, headers $x_includes" 1>&6 +fi + +if test "$no_x" = yes; then + # Not all programs may use this symbol, but it does not hurt to define it. + cat >> confdefs.h <<\EOF +#define X_DISPLAY_MISSING 1 +EOF + + X_CFLAGS= X_PRE_LIBS= X_LIBS= X_EXTRA_LIBS= +else + if test -n "$x_includes"; then + X_CFLAGS="$X_CFLAGS -I$x_includes" + fi + + # It would also be nice to do this for all -L options, not just this one. + if test -n "$x_libraries"; then + X_LIBS="$X_LIBS -L$x_libraries" + # For Solaris; some versions of Sun CC require a space after -R and + # others require no space. Words are not sufficient . . . . + case "`(uname -sr) 2>/dev/null`" in + "SunOS 5"*) + echo $ac_n "checking whether -R must be followed by a space""... $ac_c" 1>&6 +echo "configure:1399: checking whether -R must be followed by a space" >&5 + ac_xsave_LIBS="$LIBS"; LIBS="$LIBS -R$x_libraries" + cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + ac_R_nospace=yes +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + ac_R_nospace=no +fi +rm -f conftest* + if test $ac_R_nospace = yes; then + echo "$ac_t""no" 1>&6 + X_LIBS="$X_LIBS -R$x_libraries" + else + LIBS="$ac_xsave_LIBS -R $x_libraries" + cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + ac_R_space=yes +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + ac_R_space=no +fi +rm -f conftest* + if test $ac_R_space = yes; then + echo "$ac_t""yes" 1>&6 + X_LIBS="$X_LIBS -R $x_libraries" + else + echo "$ac_t""neither works" 1>&6 + fi + fi + LIBS="$ac_xsave_LIBS" + esac + fi + + # Check for system-dependent libraries X programs must link with. + # Do this before checking for the system-independent R6 libraries + # (-lICE), since we may need -lsocket or whatever for X linking. + + if test "$ISC" = yes; then + X_EXTRA_LIBS="$X_EXTRA_LIBS -lnsl_s -linet" + else + # Martyn.Johnson@cl.cam.ac.uk says this is needed for Ultrix, if the X + # libraries were built with DECnet support. And karl@cs.umb.edu says + # the Alpha needs dnet_stub (dnet does not exist). + echo $ac_n "checking for dnet_ntoa in -ldnet""... $ac_c" 1>&6 +echo "configure:1464: checking for dnet_ntoa in -ldnet" >&5 +ac_lib_var=`echo dnet'_'dnet_ntoa | sed 'y%./+-%__p_%'` +if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + ac_save_LIBS="$LIBS" +LIBS="-ldnet $LIBS" +cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=yes" +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=no" +fi +rm -f conftest* +LIBS="$ac_save_LIBS" + +fi +if eval "test \"`echo '$ac_cv_lib_'$ac_lib_var`\" = yes"; then + echo "$ac_t""yes" 1>&6 + X_EXTRA_LIBS="$X_EXTRA_LIBS -ldnet" +else + echo "$ac_t""no" 1>&6 +fi + + if test $ac_cv_lib_dnet_dnet_ntoa = no; then + echo $ac_n "checking for dnet_ntoa in -ldnet_stub""... $ac_c" 1>&6 +echo "configure:1505: checking for dnet_ntoa in -ldnet_stub" >&5 +ac_lib_var=`echo dnet_stub'_'dnet_ntoa | sed 'y%./+-%__p_%'` +if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + ac_save_LIBS="$LIBS" +LIBS="-ldnet_stub $LIBS" +cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=yes" +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=no" +fi +rm -f conftest* +LIBS="$ac_save_LIBS" + +fi +if eval "test \"`echo '$ac_cv_lib_'$ac_lib_var`\" = yes"; then + echo "$ac_t""yes" 1>&6 + X_EXTRA_LIBS="$X_EXTRA_LIBS -ldnet_stub" +else + echo "$ac_t""no" 1>&6 +fi + + fi + + # msh@cis.ufl.edu says -lnsl (and -lsocket) are needed for his 386/AT, + # to get the SysV transport functions. + # chad@anasazi.com says the Pyramis MIS-ES running DC/OSx (SVR4) + # needs -lnsl. + # The nsl library prevents programs from opening the X display + # on Irix 5.2, according to dickey@clark.net. + echo $ac_n "checking for gethostbyname""... $ac_c" 1>&6 +echo "configure:1553: checking for gethostbyname" >&5 +if eval "test \"`echo '$''{'ac_cv_func_gethostbyname'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + cat > conftest.$ac_ext < +/* Override any gcc2 internal prototype to avoid an error. */ +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char gethostbyname(); + +int main() { + +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined (__stub_gethostbyname) || defined (__stub___gethostbyname) +choke me +#else +gethostbyname(); +#endif + +; return 0; } +EOF +if { (eval echo configure:1581: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_func_gethostbyname=yes" +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_func_gethostbyname=no" +fi +rm -f conftest* +fi + +if eval "test \"`echo '$ac_cv_func_'gethostbyname`\" = yes"; then + echo "$ac_t""yes" 1>&6 + : +else + echo "$ac_t""no" 1>&6 +fi + + if test $ac_cv_func_gethostbyname = no; then + echo $ac_n "checking for gethostbyname in -lnsl""... $ac_c" 1>&6 +echo "configure:1602: checking for gethostbyname in -lnsl" >&5 +ac_lib_var=`echo nsl'_'gethostbyname | sed 'y%./+-%__p_%'` +if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + ac_save_LIBS="$LIBS" +LIBS="-lnsl $LIBS" +cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=yes" +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=no" +fi +rm -f conftest* +LIBS="$ac_save_LIBS" + +fi +if eval "test \"`echo '$ac_cv_lib_'$ac_lib_var`\" = yes"; then + echo "$ac_t""yes" 1>&6 + X_EXTRA_LIBS="$X_EXTRA_LIBS -lnsl" +else + echo "$ac_t""no" 1>&6 +fi + + fi + + # lieder@skyler.mavd.honeywell.com says without -lsocket, + # socket/setsockopt and other routines are undefined under SCO ODT + # 2.0. But -lsocket is broken on IRIX 5.2 (and is not necessary + # on later versions), says simon@lia.di.epfl.ch: it contains + # gethostby* variants that don't use the nameserver (or something). + # -lsocket must be given before -lnsl if both are needed. + # We assume that if connect needs -lnsl, so does gethostbyname. + echo $ac_n "checking for connect""... $ac_c" 1>&6 +echo "configure:1651: checking for connect" >&5 +if eval "test \"`echo '$''{'ac_cv_func_connect'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + cat > conftest.$ac_ext < +/* Override any gcc2 internal prototype to avoid an error. */ +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char connect(); + +int main() { + +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined (__stub_connect) || defined (__stub___connect) +choke me +#else +connect(); +#endif + +; return 0; } +EOF +if { (eval echo configure:1679: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_func_connect=yes" +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_func_connect=no" +fi +rm -f conftest* +fi + +if eval "test \"`echo '$ac_cv_func_'connect`\" = yes"; then + echo "$ac_t""yes" 1>&6 + : +else + echo "$ac_t""no" 1>&6 +fi + + if test $ac_cv_func_connect = no; then + echo $ac_n "checking for connect in -lsocket""... $ac_c" 1>&6 +echo "configure:1700: checking for connect in -lsocket" >&5 +ac_lib_var=`echo socket'_'connect | sed 'y%./+-%__p_%'` +if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + ac_save_LIBS="$LIBS" +LIBS="-lsocket $X_EXTRA_LIBS $LIBS" +cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=yes" +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=no" +fi +rm -f conftest* +LIBS="$ac_save_LIBS" + +fi +if eval "test \"`echo '$ac_cv_lib_'$ac_lib_var`\" = yes"; then + echo "$ac_t""yes" 1>&6 + X_EXTRA_LIBS="-lsocket $X_EXTRA_LIBS" +else + echo "$ac_t""no" 1>&6 +fi + + fi + + # gomez@mi.uni-erlangen.de says -lposix is necessary on A/UX. + echo $ac_n "checking for remove""... $ac_c" 1>&6 +echo "configure:1743: checking for remove" >&5 +if eval "test \"`echo '$''{'ac_cv_func_remove'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + cat > conftest.$ac_ext < +/* Override any gcc2 internal prototype to avoid an error. */ +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char remove(); + +int main() { + +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined (__stub_remove) || defined (__stub___remove) +choke me +#else +remove(); +#endif + +; return 0; } +EOF +if { (eval echo configure:1771: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_func_remove=yes" +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_func_remove=no" +fi +rm -f conftest* +fi + +if eval "test \"`echo '$ac_cv_func_'remove`\" = yes"; then + echo "$ac_t""yes" 1>&6 + : +else + echo "$ac_t""no" 1>&6 +fi + + if test $ac_cv_func_remove = no; then + echo $ac_n "checking for remove in -lposix""... $ac_c" 1>&6 +echo "configure:1792: checking for remove in -lposix" >&5 +ac_lib_var=`echo posix'_'remove | sed 'y%./+-%__p_%'` +if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + ac_save_LIBS="$LIBS" +LIBS="-lposix $LIBS" +cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=yes" +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=no" +fi +rm -f conftest* +LIBS="$ac_save_LIBS" + +fi +if eval "test \"`echo '$ac_cv_lib_'$ac_lib_var`\" = yes"; then + echo "$ac_t""yes" 1>&6 + X_EXTRA_LIBS="$X_EXTRA_LIBS -lposix" +else + echo "$ac_t""no" 1>&6 +fi + + fi + + # BSDI BSD/OS 2.1 needs -lipc for XOpenDisplay. + echo $ac_n "checking for shmat""... $ac_c" 1>&6 +echo "configure:1835: checking for shmat" >&5 +if eval "test \"`echo '$''{'ac_cv_func_shmat'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + cat > conftest.$ac_ext < +/* Override any gcc2 internal prototype to avoid an error. */ +/* We use char because int might match the return type of a gcc2 + builtin and then its argument prototype would still apply. */ +char shmat(); + +int main() { + +/* The GNU C library defines this for functions which it implements + to always fail with ENOSYS. Some functions are actually named + something starting with __ and the normal name is an alias. */ +#if defined (__stub_shmat) || defined (__stub___shmat) +choke me +#else +shmat(); +#endif + +; return 0; } +EOF +if { (eval echo configure:1863: \"$ac_link\") 1>&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_func_shmat=yes" +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_func_shmat=no" +fi +rm -f conftest* +fi + +if eval "test \"`echo '$ac_cv_func_'shmat`\" = yes"; then + echo "$ac_t""yes" 1>&6 + : +else + echo "$ac_t""no" 1>&6 +fi + + if test $ac_cv_func_shmat = no; then + echo $ac_n "checking for shmat in -lipc""... $ac_c" 1>&6 +echo "configure:1884: checking for shmat in -lipc" >&5 +ac_lib_var=`echo ipc'_'shmat | sed 'y%./+-%__p_%'` +if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + ac_save_LIBS="$LIBS" +LIBS="-lipc $LIBS" +cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=yes" +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=no" +fi +rm -f conftest* +LIBS="$ac_save_LIBS" + +fi +if eval "test \"`echo '$ac_cv_lib_'$ac_lib_var`\" = yes"; then + echo "$ac_t""yes" 1>&6 + X_EXTRA_LIBS="$X_EXTRA_LIBS -lipc" +else + echo "$ac_t""no" 1>&6 +fi + + fi + fi + + # Check for libraries that X11R6 Xt/Xaw programs need. + ac_save_LDFLAGS="$LDFLAGS" + test -n "$x_libraries" && LDFLAGS="$LDFLAGS -L$x_libraries" + # SM needs ICE to (dynamically) link under SunOS 4.x (so we have to + # check for ICE first), but we must link in the order -lSM -lICE or + # we get undefined symbols. So assume we have SM if we have ICE. + # These have to be linked with before -lX11, unlike the other + # libraries we check for below, so use a different variable. + # --interran@uluru.Stanford.EDU, kb@cs.umb.edu. + echo $ac_n "checking for IceConnectionNumber in -lICE""... $ac_c" 1>&6 +echo "configure:1936: checking for IceConnectionNumber in -lICE" >&5 +ac_lib_var=`echo ICE'_'IceConnectionNumber | sed 'y%./+-%__p_%'` +if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + ac_save_LIBS="$LIBS" +LIBS="-lICE $X_EXTRA_LIBS $LIBS" +cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=yes" +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=no" +fi +rm -f conftest* +LIBS="$ac_save_LIBS" + +fi +if eval "test \"`echo '$ac_cv_lib_'$ac_lib_var`\" = yes"; then + echo "$ac_t""yes" 1>&6 + X_PRE_LIBS="$X_PRE_LIBS -lSM -lICE" +else + echo "$ac_t""no" 1>&6 +fi + + LDFLAGS="$ac_save_LDFLAGS" + +fi + + +if test "$x_includes" != "NONE"; then + CFLAGS="$CFLAGS -I$x_includes" +fi + +if test "$x_libraries" != "NONE"; then + LDFLAGS="$LDFLAGS -L$x_libraries" +fi + +echo $ac_n "checking for XOpenDisplay in -lX11""... $ac_c" 1>&6 +echo "configure:1989: checking for XOpenDisplay in -lX11" >&5 +ac_lib_var=`echo X11'_'XOpenDisplay | sed 'y%./+-%__p_%'` +if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + ac_save_LIBS="$LIBS" +LIBS="-lX11 $LIBS" +cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=yes" +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=no" +fi +rm -f conftest* +LIBS="$ac_save_LIBS" + +fi +if eval "test \"`echo '$ac_cv_lib_'$ac_lib_var`\" = yes"; then + echo "$ac_t""yes" 1>&6 + ac_tr_lib=HAVE_LIB`echo X11 | sed -e 's/[^a-zA-Z0-9_]/_/g' \ + -e 'y/abcdefghijklmnopqrstuvwxyz/ABCDEFGHIJKLMNOPQRSTUVWXYZ/'` + cat >> confdefs.h <&6 +fi + +echo $ac_n "checking for XShapeCombineMask in -lXext""... $ac_c" 1>&6 +echo "configure:2036: checking for XShapeCombineMask in -lXext" >&5 +ac_lib_var=`echo Xext'_'XShapeCombineMask | sed 'y%./+-%__p_%'` +if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + ac_save_LIBS="$LIBS" +LIBS="-lXext $LIBS" +cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=yes" +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=no" +fi +rm -f conftest* +LIBS="$ac_save_LIBS" + +fi +if eval "test \"`echo '$ac_cv_lib_'$ac_lib_var`\" = yes"; then + echo "$ac_t""yes" 1>&6 + ac_tr_lib=HAVE_LIB`echo Xext | sed -e 's/[^a-zA-Z0-9_]/_/g' \ + -e 'y/abcdefghijklmnopqrstuvwxyz/ABCDEFGHIJKLMNOPQRSTUVWXYZ/'` + cat >> confdefs.h <&6 +fi + +echo $ac_n "checking for XpmCreatePixmapFromData in -lXpm""... $ac_c" 1>&6 +echo "configure:2083: checking for XpmCreatePixmapFromData in -lXpm" >&5 +ac_lib_var=`echo Xpm'_'XpmCreatePixmapFromData | sed 'y%./+-%__p_%'` +if eval "test \"`echo '$''{'ac_cv_lib_$ac_lib_var'+set}'`\" = set"; then + echo $ac_n "(cached) $ac_c" 1>&6 +else + ac_save_LIBS="$LIBS" +LIBS="-lXpm $LIBS $LIBS" +cat > conftest.$ac_ext <&5; (eval $ac_link) 2>&5; } && test -s conftest${ac_exeext}; then + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=yes" +else + echo "configure: failed program was:" >&5 + cat conftest.$ac_ext >&5 + rm -rf conftest* + eval "ac_cv_lib_$ac_lib_var=no" +fi +rm -f conftest* +LIBS="$ac_save_LIBS" + +fi +if eval "test \"`echo '$ac_cv_lib_'$ac_lib_var`\" = yes"; then + echo "$ac_t""yes" 1>&6 + ac_tr_lib=HAVE_LIB`echo Xpm | sed -e 's/[^a-zA-Z0-9_]/_/g' \ + -e 'y/abcdefghijklmnopqrstuvwxyz/ABCDEFGHIJKLMNOPQRSTUVWXYZ/'` + cat >> confdefs.h <&6 +fi + + +trap '' 1 2 15 +cat > confcache <<\EOF +# This file is a shell script that caches the results of configure +# tests run on this system so they can be shared between configure +# scripts and configure runs. It is not useful on other systems. +# If it contains results you don't want to keep, you may remove or edit it. +# +# By default, configure uses ./config.cache as the cache file, +# creating it if it does not exist already. You can give configure +# the --cache-file=FILE option to use a different cache file; that is +# what configure does when it calls configure scripts in +# subdirectories, so they share the cache. +# Giving --cache-file=/dev/null disables caching, for debugging configure. +# config.status only pays attention to the cache file if you give it the +# --recheck option to rerun configure. +# +EOF +# The following way of writing the cache mishandles newlines in values, +# but we know of no workaround that is simple, portable, and efficient. +# So, don't put newlines in cache variables' values. +# Ultrix sh set writes to stderr and can't be redirected directly, +# and sets the high bit in the cache file unless we assign to the vars. +(set) 2>&1 | + case `(ac_space=' '; set | grep ac_space) 2>&1` in + *ac_space=\ *) + # `set' does not quote correctly, so add quotes (double-quote substitution + # turns \\\\ into \\, and sed turns \\ into \). + sed -n \ + -e "s/'/'\\\\''/g" \ + -e "s/^\\([a-zA-Z0-9_]*_cv_[a-zA-Z0-9_]*\\)=\\(.*\\)/\\1=\${\\1='\\2'}/p" + ;; + *) + # `set' quotes correctly as required by POSIX, so do not add quotes. + sed -n -e 's/^\([a-zA-Z0-9_]*_cv_[a-zA-Z0-9_]*\)=\(.*\)/\1=${\1=\2}/p' + ;; + esac >> confcache +if cmp -s $cache_file confcache; then + : +else + if test -w $cache_file; then + echo "updating cache $cache_file" + cat confcache > $cache_file + else + echo "not updating unwritable cache $cache_file" + fi +fi +rm -f confcache + +trap 'rm -fr conftest* confdefs* core core.* *.core $ac_clean_files; exit 1' 1 2 15 + +test "x$prefix" = xNONE && prefix=$ac_default_prefix +# Let make expand exec_prefix. +test "x$exec_prefix" = xNONE && exec_prefix='${prefix}' + +# Any assignment to VPATH causes Sun make to only execute +# the first set of double-colon rules, so remove it if not needed. +# If there is a colon in the path, we need to keep it. +if test "x$srcdir" = x.; then + ac_vpsub='/^[ ]*VPATH[ ]*=[^:]*$/d' +fi + +trap 'rm -f $CONFIG_STATUS conftest*; exit 1' 1 2 15 + +# Transform confdefs.h into DEFS. +# Protect against shell expansion while executing Makefile rules. +# Protect against Makefile macro expansion. +cat > conftest.defs <<\EOF +s%#define \([A-Za-z_][A-Za-z0-9_]*\) *\(.*\)%-D\1=\2%g +s%[ `~#$^&*(){}\\|;'"<>?]%\\&%g +s%\[%\\&%g +s%\]%\\&%g +s%\$%$$%g +EOF +DEFS=`sed -f conftest.defs confdefs.h | tr '\012' ' '` +rm -f conftest.defs + + +# Without the "./", some shells look in PATH for config.status. +: ${CONFIG_STATUS=./config.status} + +echo creating $CONFIG_STATUS +rm -f $CONFIG_STATUS +cat > $CONFIG_STATUS </dev/null | sed 1q`: +# +# $0 $ac_configure_args +# +# Compiler output produced by configure, useful for debugging +# configure, is in ./config.log if it exists. + +ac_cs_usage="Usage: $CONFIG_STATUS [--recheck] [--version] [--help]" +for ac_option +do + case "\$ac_option" in + -recheck | --recheck | --rechec | --reche | --rech | --rec | --re | --r) + echo "running \${CONFIG_SHELL-/bin/sh} $0 $ac_configure_args --no-create --no-recursion" + exec \${CONFIG_SHELL-/bin/sh} $0 $ac_configure_args --no-create --no-recursion ;; + -version | --version | --versio | --versi | --vers | --ver | --ve | --v) + echo "$CONFIG_STATUS generated by autoconf version 2.13" + exit 0 ;; + -help | --help | --hel | --he | --h) + echo "\$ac_cs_usage"; exit 0 ;; + *) echo "\$ac_cs_usage"; exit 1 ;; + esac +done + +ac_given_srcdir=$srcdir +ac_given_INSTALL="$INSTALL" + +trap 'rm -fr `echo "Makefile" | sed "s/:[^ ]*//g"` conftest*; exit 1' 1 2 15 +EOF +cat >> $CONFIG_STATUS < conftest.subs <<\\CEOF +$ac_vpsub +$extrasub +s%@SHELL@%$SHELL%g +s%@CFLAGS@%$CFLAGS%g +s%@CPPFLAGS@%$CPPFLAGS%g +s%@CXXFLAGS@%$CXXFLAGS%g +s%@FFLAGS@%$FFLAGS%g +s%@DEFS@%$DEFS%g +s%@LDFLAGS@%$LDFLAGS%g +s%@LIBS@%$LIBS%g +s%@exec_prefix@%$exec_prefix%g +s%@prefix@%$prefix%g +s%@program_transform_name@%$program_transform_name%g +s%@bindir@%$bindir%g +s%@sbindir@%$sbindir%g +s%@libexecdir@%$libexecdir%g +s%@datadir@%$datadir%g +s%@sysconfdir@%$sysconfdir%g +s%@sharedstatedir@%$sharedstatedir%g +s%@localstatedir@%$localstatedir%g +s%@libdir@%$libdir%g +s%@includedir@%$includedir%g +s%@oldincludedir@%$oldincludedir%g +s%@infodir@%$infodir%g +s%@mandir@%$mandir%g +s%@INSTALL_PROGRAM@%$INSTALL_PROGRAM%g +s%@INSTALL_SCRIPT@%$INSTALL_SCRIPT%g +s%@INSTALL_DATA@%$INSTALL_DATA%g +s%@PACKAGE@%$PACKAGE%g +s%@VERSION@%$VERSION%g +s%@ACLOCAL@%$ACLOCAL%g +s%@AUTOCONF@%$AUTOCONF%g +s%@AUTOMAKE@%$AUTOMAKE%g +s%@AUTOHEADER@%$AUTOHEADER%g +s%@MAKEINFO@%$MAKEINFO%g +s%@SET_MAKE@%$SET_MAKE%g +s%@CC@%$CC%g +s%@CPP@%$CPP%g +s%@X_CFLAGS@%$X_CFLAGS%g +s%@X_PRE_LIBS@%$X_PRE_LIBS%g +s%@X_LIBS@%$X_LIBS%g +s%@X_EXTRA_LIBS@%$X_EXTRA_LIBS%g + +CEOF +EOF + +cat >> $CONFIG_STATUS <<\EOF + +# Split the substitutions into bite-sized pieces for seds with +# small command number limits, like on Digital OSF/1 and HP-UX. +ac_max_sed_cmds=90 # Maximum number of lines to put in a sed script. +ac_file=1 # Number of current file. +ac_beg=1 # First line for current file. +ac_end=$ac_max_sed_cmds # Line after last line for current file. +ac_more_lines=: +ac_sed_cmds="" +while $ac_more_lines; do + if test $ac_beg -gt 1; then + sed "1,${ac_beg}d; ${ac_end}q" conftest.subs > conftest.s$ac_file + else + sed "${ac_end}q" conftest.subs > conftest.s$ac_file + fi + if test ! -s conftest.s$ac_file; then + ac_more_lines=false + rm -f conftest.s$ac_file + else + if test -z "$ac_sed_cmds"; then + ac_sed_cmds="sed -f conftest.s$ac_file" + else + ac_sed_cmds="$ac_sed_cmds | sed -f conftest.s$ac_file" + fi + ac_file=`expr $ac_file + 1` + ac_beg=$ac_end + ac_end=`expr $ac_end + $ac_max_sed_cmds` + fi +done +if test -z "$ac_sed_cmds"; then + ac_sed_cmds=cat +fi +EOF + +cat >> $CONFIG_STATUS <> $CONFIG_STATUS <<\EOF +for ac_file in .. $CONFIG_FILES; do if test "x$ac_file" != x..; then + # Support "outfile[:infile[:infile...]]", defaulting infile="outfile.in". + case "$ac_file" in + *:*) ac_file_in=`echo "$ac_file"|sed 's%[^:]*:%%'` + ac_file=`echo "$ac_file"|sed 's%:.*%%'` ;; + *) ac_file_in="${ac_file}.in" ;; + esac + + # Adjust a relative srcdir, top_srcdir, and INSTALL for subdirectories. + + # Remove last slash and all that follows it. Not all systems have dirname. + ac_dir=`echo $ac_file|sed 's%/[^/][^/]*$%%'` + if test "$ac_dir" != "$ac_file" && test "$ac_dir" != .; then + # The file is in a subdirectory. + test ! -d "$ac_dir" && mkdir "$ac_dir" + ac_dir_suffix="/`echo $ac_dir|sed 's%^\./%%'`" + # A "../" for each directory in $ac_dir_suffix. + ac_dots=`echo $ac_dir_suffix|sed 's%/[^/]*%../%g'` + else + ac_dir_suffix= ac_dots= + fi + + case "$ac_given_srcdir" in + .) srcdir=. + if test -z "$ac_dots"; then top_srcdir=. + else top_srcdir=`echo $ac_dots|sed 's%/$%%'`; fi ;; + /*) srcdir="$ac_given_srcdir$ac_dir_suffix"; top_srcdir="$ac_given_srcdir" ;; + *) # Relative path. + srcdir="$ac_dots$ac_given_srcdir$ac_dir_suffix" + top_srcdir="$ac_dots$ac_given_srcdir" ;; + esac + + case "$ac_given_INSTALL" in + [/$]*) INSTALL="$ac_given_INSTALL" ;; + *) INSTALL="$ac_dots$ac_given_INSTALL" ;; + esac + + echo creating "$ac_file" + rm -f "$ac_file" + configure_input="Generated automatically from `echo $ac_file_in|sed 's%.*/%%'` by configure." + case "$ac_file" in + *Makefile*) ac_comsub="1i\\ +# $configure_input" ;; + *) ac_comsub= ;; + esac + + ac_file_inputs=`echo $ac_file_in|sed -e "s%^%$ac_given_srcdir/%" -e "s%:% $ac_given_srcdir/%g"` + sed -e "$ac_comsub +s%@configure_input@%$configure_input%g +s%@srcdir@%$srcdir%g +s%@top_srcdir@%$top_srcdir%g +s%@INSTALL@%$INSTALL%g +" $ac_file_inputs | (eval "$ac_sed_cmds") > $ac_file +fi; done +rm -f conftest.s* + +EOF +cat >> $CONFIG_STATUS <> $CONFIG_STATUS <<\EOF + +exit 0 +EOF +chmod +x $CONFIG_STATUS +rm -fr confdefs* $ac_clean_files +test "$no_create" = yes || ${CONFIG_SHELL-/bin/sh} $CONFIG_STATUS || exit 1 + diff --git a/wmmp3/configure.in b/wmmp3/configure.in new file mode 100644 index 0000000..69a6c9d --- /dev/null +++ b/wmmp3/configure.in @@ -0,0 +1,19 @@ +AC_INIT(main.c) +AM_INIT_AUTOMAKE(wmmp3,0.12) +AC_PROG_CC +AC_PROG_INSTALL +AC_PATH_XTRA + +if test "$x_includes" != "NONE"; then + CFLAGS="$CFLAGS -I$x_includes" +fi + +if test "$x_libraries" != "NONE"; then + LDFLAGS="$LDFLAGS -L$x_libraries" +fi + +AC_CHECK_LIB(X11, XOpenDisplay) +AC_CHECK_LIB(Xext, XShapeCombineMask) +AC_CHECK_LIB(Xpm, XpmCreatePixmapFromData, , , $LIBS) + +AC_OUTPUT(Makefile) diff --git a/wmmp3/install-sh b/wmmp3/install-sh new file mode 100755 index 0000000..e9de238 --- /dev/null +++ b/wmmp3/install-sh @@ -0,0 +1,251 @@ +#!/bin/sh +# +# install - install a program, script, or datafile +# This comes from X11R5 (mit/util/scripts/install.sh). +# +# Copyright 1991 by the Massachusetts Institute of Technology +# +# Permission to use, copy, modify, distribute, and sell this software and its +# documentation for any purpose is hereby granted without fee, provided that +# the above copyright notice appear in all copies and that both that +# copyright notice and this permission notice appear in supporting +# documentation, and that the name of M.I.T. not be used in advertising or +# publicity pertaining to distribution of the software without specific, +# written prior permission. M.I.T. makes no representations about the +# suitability of this software for any purpose. It is provided "as is" +# without express or implied warranty. +# +# Calling this script install-sh is preferred over install.sh, to prevent +# `make' implicit rules from creating a file called install from it +# when there is no Makefile. +# +# This script is compatible with the BSD install script, but was written +# from scratch. It can only install one file at a time, a restriction +# shared with many OS's install programs. + + +# set DOITPROG to echo to test this script + +# Don't use :- since 4.3BSD and earlier shells don't like it. +doit="${DOITPROG-}" + + +# put in absolute paths if you don't have them in your path; or use env. vars. + +mvprog="${MVPROG-mv}" +cpprog="${CPPROG-cp}" +chmodprog="${CHMODPROG-chmod}" +chownprog="${CHOWNPROG-chown}" +chgrpprog="${CHGRPPROG-chgrp}" +stripprog="${STRIPPROG-strip}" +rmprog="${RMPROG-rm}" +mkdirprog="${MKDIRPROG-mkdir}" + +transformbasename="" +transform_arg="" +instcmd="$mvprog" +chmodcmd="$chmodprog 0755" +chowncmd="" +chgrpcmd="" +stripcmd="" +rmcmd="$rmprog -f" +mvcmd="$mvprog" +src="" +dst="" +dir_arg="" + +while [ x"$1" != x ]; do + case $1 in + -c) instcmd="$cpprog" + shift + continue;; + + -d) dir_arg=true + shift + continue;; + + -m) chmodcmd="$chmodprog $2" + shift + shift + continue;; + + -o) chowncmd="$chownprog $2" + shift + shift + continue;; + + -g) chgrpcmd="$chgrpprog $2" + shift + shift + continue;; + + -s) stripcmd="$stripprog" + shift + continue;; + + -t=*) transformarg=`echo $1 | sed 's/-t=//'` + shift + continue;; + + -b=*) transformbasename=`echo $1 | sed 's/-b=//'` + shift + continue;; + + *) if [ x"$src" = x ] + then + src=$1 + else + # this colon is to work around a 386BSD /bin/sh bug + : + dst=$1 + fi + shift + continue;; + esac +done + +if [ x"$src" = x ] +then + echo "install: no input file specified" + exit 1 +else + true +fi + +if [ x"$dir_arg" != x ]; then + dst=$src + src="" + + if [ -d $dst ]; then + instcmd=: + chmodcmd="" + else + instcmd=mkdir + fi +else + +# Waiting for this to be detected by the "$instcmd $src $dsttmp" command +# might cause directories to be created, which would be especially bad +# if $src (and thus $dsttmp) contains '*'. + + if [ -f $src -o -d $src ] + then + true + else + echo "install: $src does not exist" + exit 1 + fi + + if [ x"$dst" = x ] + then + echo "install: no destination specified" + exit 1 + else + true + fi + +# If destination is a directory, append the input filename; if your system +# does not like double slashes in filenames, you may need to add some logic + + if [ -d $dst ] + then + dst="$dst"/`basename $src` + else + true + fi +fi + +## this sed command emulates the dirname command +dstdir=`echo $dst | sed -e 's,[^/]*$,,;s,/$,,;s,^$,.,'` + +# Make sure that the destination directory exists. +# this part is taken from Noah Friedman's mkinstalldirs script + +# Skip lots of stat calls in the usual case. +if [ ! -d "$dstdir" ]; then +defaultIFS=' +' +IFS="${IFS-${defaultIFS}}" + +oIFS="${IFS}" +# Some sh's can't handle IFS=/ for some reason. +IFS='%' +set - `echo ${dstdir} | sed -e 's@/@%@g' -e 's@^%@/@'` +IFS="${oIFS}" + +pathcomp='' + +while [ $# -ne 0 ] ; do + pathcomp="${pathcomp}${1}" + shift + + if [ ! -d "${pathcomp}" ] ; + then + $mkdirprog "${pathcomp}" + else + true + fi + + pathcomp="${pathcomp}/" +done +fi + +if [ x"$dir_arg" != x ] +then + $doit $instcmd $dst && + + if [ x"$chowncmd" != x ]; then $doit $chowncmd $dst; else true ; fi && + if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd $dst; else true ; fi && + if [ x"$stripcmd" != x ]; then $doit $stripcmd $dst; else true ; fi && + if [ x"$chmodcmd" != x ]; then $doit $chmodcmd $dst; else true ; fi +else + +# If we're going to rename the final executable, determine the name now. + + if [ x"$transformarg" = x ] + then + dstfile=`basename $dst` + else + dstfile=`basename $dst $transformbasename | + sed $transformarg`$transformbasename + fi + +# don't allow the sed command to completely eliminate the filename + + if [ x"$dstfile" = x ] + then + dstfile=`basename $dst` + else + true + fi + +# Make a temp file name in the proper directory. + + dsttmp=$dstdir/#inst.$$# + +# Move or copy the file name to the temp name + + $doit $instcmd $src $dsttmp && + + trap "rm -f ${dsttmp}" 0 && + +# and set any options; do chmod last to preserve setuid bits + +# If any of these fail, we abort the whole thing. If we want to +# ignore errors from any of these, just make sure not to ignore +# errors from the above "$doit $instcmd $src $dsttmp" command. + + if [ x"$chowncmd" != x ]; then $doit $chowncmd $dsttmp; else true;fi && + if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd $dsttmp; else true;fi && + if [ x"$stripcmd" != x ]; then $doit $stripcmd $dsttmp; else true;fi && + if [ x"$chmodcmd" != x ]; then $doit $chmodcmd $dsttmp; else true;fi && + +# Now rename the file to the real destination. + + $doit $rmcmd -f $dstdir/$dstfile && + $doit $mvcmd $dsttmp $dstdir/$dstfile + +fi && + + +exit 0 diff --git a/wmmp3/main.c b/wmmp3/main.c new file mode 100644 index 0000000..675e99f --- /dev/null +++ b/wmmp3/main.c @@ -0,0 +1,301 @@ +/* + * wmmp3 + * Copyright (c)1999 Patrick Crosby . + * This software covered by the GPL. See COPYING file for details. + * + * main.c + * + * This is the main body of the application. Handles all initialization + * plus the X event loop. + * + * $Id: main.c,v 1.11 1999/10/08 22:21:32 pcrosby Exp $ + */ + +#include "main.h" + +#define B_STOP 0 +#define B_PLAY 1 +#define B_BACK 2 +#define B_NEXT 3 +#define B_PREV_DIR 4 +#define B_RAND 5 +#define B_NEXT_DIR 6 +#define B_REPEAT 7 +#define B_TITLE 8 + +void loadconfig(); +void show_help(); +void show_version(); +int check_options(int argc, char *argv[]); +int handle_button_press(int x, int y); +void handle_button_release(int i); + +struct coord { + int x; + int y; + int w; + int h; +}; + +/* from Steven Jorgensen */ +void stripspace(char *s) { + char *t; + t = s + strlen(s) - 1; + while (t > s && isspace(*t)) { + t--; + } + t++; + *t = '\0'; +} + +int handle_button_press(int x, int y) { + int i; + + i = CheckMouseRegion(x, y); + switch (i) { + case B_STOP: + button_down(i); + button_up(B_PLAY); /* raise play */ + button_up(B_PREV_DIR); /* reactivate directory up/down */ + button_up(B_NEXT_DIR); + stop(); + break; + case B_PLAY: + button_down(i); + button_gray(B_PREV_DIR); /* gray out directory up/down */ + button_gray(B_NEXT_DIR); + user_play(); + break; + case B_BACK: + button_down(i); + back(); + break; + case B_NEXT: + button_down(i); + next(); + break; + case B_PREV_DIR: + dir_up(i); + break; + case B_RAND: + random_toggle(i); + break; + case B_NEXT_DIR: + dir_down(i); + break; + case B_REPEAT: + repeat_toggle(i); + break; + case B_TITLE: + turn_on_scroll(); + break; + default: + fprintf(stderr, "unknown button pressed\n"); + } + RedrawWindow(); + + return(i); +} + +void handle_button_release(int i) +{ + /* play stays down, don't mess with toggles */ + /* ignore song title press too */ + if (((i != B_PLAY) && (i != B_RAND)) && + ((i != B_REPEAT) && (i != B_TITLE))) { + if (!is_playing()) { + button_up(i); + RedrawWindow(); + } else { + /* don't undo gray of dir up/down */ + if (((i == B_STOP) || (i == B_BACK)) || (i == B_NEXT)) { + button_up(i); + RedrawWindow(); + } + } + } +} + +void loadconfig() +{ + struct passwd *pw; + char *config_filename; + FILE *fp; + + errno = 0; + + /* set defualts in case anything fails */ + set_mpg123("/usr/local/bin/mpg123"); + set_mp3ext(".mp3"); + set_playlistext(".m3u"); + + pw = getpwuid(getuid()); + /* don't forget about the string terminator... */ + config_filename = (char *) malloc(sizeof(char) * + (strlen(pw->pw_dir) + 8)); + sprintf(config_filename, "%s/.wmmp3", pw->pw_dir); + + + fp = fopen(config_filename, "r"); + if (fp != NULL) { + char line[256]; + char variable[256]; + char value[256]; + + fgets(line, 256, fp); + while (!feof(fp)) { + if ((line[0] != '#') && (line[0] != '\n')) { + if (sscanf(line, " %s = %[^\n]", variable, value) < 2) { + fprintf(stderr, "Malformed line in config file: %s\n", line); + } else { + if (strcmp(variable, "mpg123") == 0) { + stripspace(value); + set_mpg123(value); + } else if (strcmp(variable, "mp3dir") == 0) { + stripspace(value); + add_mp3dir(value); + } else if (strcmp(variable, "mp3dirname") == 0) { + stripspace(value); + add_mp3dirname(value); + } else if (strcmp(variable, "mp3ext") == 0) { + stripspace(value); + set_mp3ext(value); + } else if (strcmp(variable, "playlistext") == 0) { + stripspace(value); + set_playlistext(value); + } else if (strcmp(variable, "alwaysscroll") == 0) { + stripspace(value); + set_alwaysscroll(value); + } else { + fprintf(stderr, "Unrecognized variable in config file: %s\n", + variable); + } + } + } + fgets(line, 256, fp); + } + + + fclose(fp); + } else { + fprintf(stderr, "open of %s failed: %s\n", + config_filename, + strerror(errno)); + } + + free(config_filename); +} + +void show_help() +{ + printf("wmmp3 -- by Patrick Crosby -- Version %s\n", VERSION); + printf("At this moment, there are no command line options that do\n"); + printf("anything special:\n"); + printf("\t-h,--help: print this message\n"); + printf("\t-v,--version: print version info\n"); + printf("All options are set in ~/.wmmp3. See sample.wmmp3 in the\n"); + printf("distribution or http://dotfiles.com/software/ for more info.\n"); +} + +void show_version() +{ + printf("wmmp3 -- by Patrick Crosby -- Version %s\n", VERSION); +} + +int check_options(int argc, char *argv[]) +{ + int option_entered = 0; + int i; + + + for (i = 1; i < argc; i++) { + if (streq(argv[i], "-h")) { + option_entered = 1; + show_help(); + } + else if (streq(argv[i], "--help")) { + option_entered = 1; + show_help(); + } + else if (streq(argv[i], "-v")) { + option_entered = 1; + show_version(); + } + else if (streq(argv[i], "--version")) { + option_entered = 1; + show_version(); + } + } + + return option_entered; +} + +void main(int argc, char *argv[]) +{ + struct coord pos[] = { + {35, 34, 12, 11}, /* stop */ + {46, 34, 12, 11}, /* play */ + {35, 45, 12, 11}, /* back */ + {46, 45, 12, 11}, /* next */ + {6, 34, 12, 11}, /* prev_dir */ + {17, 34, 12, 11}, /* random */ + {6, 45, 12, 11}, /* next_dir */ + {17, 45, 12, 11}, /* repeat */ + {5, 18, 54, 12} /* song title */ + }; + + char mask_bits[64 * 64]; + int mask_width = 64; + int mask_height = 64; + XEvent Event; + int i; + int btn_num; + + if (check_options(argc, argv)) { + exit(1); + } + + loadconfig(); + + /* set up the display area for wmmp3 */ + createXBMfromXPM(mask_bits, wmmp3_xpm, mask_width, mask_height); + openXwindow(argc, argv, wmmp3_xpm, mask_bits, mask_width, mask_height); + + font_init(); + draw_string("wmmp3", 5, 5); + + + i = 0; + for (i = 0; i < 9; i++) + AddMouseRegion(i, pos[i].x, pos[i].y, + pos[i].x + pos[i].w, + pos[i].y + pos[i].h); + + /* event loop */ + while (1) { + while (XPending(display)) { + XNextEvent(display, &Event); + switch (Event.type) { + case Expose: + RedrawWindow(); + break; + case ClientMessage: + break; + case DestroyNotify: + XCloseDisplay(display); + exit(0); + case ButtonPress: + btn_num = handle_button_press(Event.xbutton.x, + Event.xbutton.y); + break; + case ButtonRelease: + handle_button_release(btn_num); + break; + } + + } + usleep(50000); + } + exit(0); +} + diff --git a/wmmp3/main.h b/wmmp3/main.h new file mode 100644 index 0000000..70404c4 --- /dev/null +++ b/wmmp3/main.h @@ -0,0 +1,33 @@ +/* + * wmmp3 + * Copyright (c)1999 Patrick Crosby . + * This software covered by the GPL. See COPYING file for details. + * + * main.h + * + * Header file for main.c + * + * $Id: main.h,v 1.4 1999/10/08 22:21:32 pcrosby Exp $ + */ + +#ifndef __MAIN_H__ + +#define __MAIN_H__ + +#include +#include +#include +#include +#include +#include +#include + +#include "buttons.h" +#include "wmgeneral.h" +#include "mpg123ctl.h" +#include "wmmp3.xpm" + +#define streq(s1, s2) \ + (strcmp(s1, s2) == 0) + +#endif diff --git a/wmmp3/missing b/wmmp3/missing new file mode 100755 index 0000000..7789652 --- /dev/null +++ b/wmmp3/missing @@ -0,0 +1,190 @@ +#! /bin/sh +# Common stub for a few missing GNU programs while installing. +# Copyright (C) 1996, 1997 Free Software Foundation, Inc. +# Franc,ois Pinard , 1996. + +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2, or (at your option) +# any later version. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. + +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA +# 02111-1307, USA. + +if test $# -eq 0; then + echo 1>&2 "Try \`$0 --help' for more information" + exit 1 +fi + +case "$1" in + + -h|--h|--he|--hel|--help) + echo "\ +$0 [OPTION]... PROGRAM [ARGUMENT]... + +Handle \`PROGRAM [ARGUMENT]...' for when PROGRAM is missing, or return an +error status if there is no known handling for PROGRAM. + +Options: + -h, --help display this help and exit + -v, --version output version information and exit + +Supported PROGRAM values: + aclocal touch file \`aclocal.m4' + autoconf touch file \`configure' + autoheader touch file \`config.h.in' + automake touch all \`Makefile.in' files + bison create \`y.tab.[ch]', if possible, from existing .[ch] + flex create \`lex.yy.c', if possible, from existing .c + lex create \`lex.yy.c', if possible, from existing .c + makeinfo touch the output file + yacc create \`y.tab.[ch]', if possible, from existing .[ch]" + ;; + + -v|--v|--ve|--ver|--vers|--versi|--versio|--version) + echo "missing - GNU libit 0.0" + ;; + + -*) + echo 1>&2 "$0: Unknown \`$1' option" + echo 1>&2 "Try \`$0 --help' for more information" + exit 1 + ;; + + aclocal) + echo 1>&2 "\ +WARNING: \`$1' is missing on your system. You should only need it if + you modified \`acinclude.m4' or \`configure.in'. You might want + to install the \`Automake' and \`Perl' packages. Grab them from + any GNU archive site." + touch aclocal.m4 + ;; + + autoconf) + echo 1>&2 "\ +WARNING: \`$1' is missing on your system. You should only need it if + you modified \`configure.in'. You might want to install the + \`Autoconf' and \`GNU m4' packages. Grab them from any GNU + archive site." + touch configure + ;; + + autoheader) + echo 1>&2 "\ +WARNING: \`$1' is missing on your system. You should only need it if + you modified \`acconfig.h' or \`configure.in'. You might want + to install the \`Autoconf' and \`GNU m4' packages. Grab them + from any GNU archive site." + files=`sed -n 's/^[ ]*A[CM]_CONFIG_HEADER(\([^)]*\)).*/\1/p' configure.in` + test -z "$files" && files="config.h" + touch_files= + for f in $files; do + case "$f" in + *:*) touch_files="$touch_files "`echo "$f" | + sed -e 's/^[^:]*://' -e 's/:.*//'`;; + *) touch_files="$touch_files $f.in";; + esac + done + touch $touch_files + ;; + + automake) + echo 1>&2 "\ +WARNING: \`$1' is missing on your system. You should only need it if + you modified \`Makefile.am', \`acinclude.m4' or \`configure.in'. + You might want to install the \`Automake' and \`Perl' packages. + Grab them from any GNU archive site." + find . -type f -name Makefile.am -print | + sed 's/\.am$/.in/' | + while read f; do touch "$f"; done + ;; + + bison|yacc) + echo 1>&2 "\ +WARNING: \`$1' is missing on your system. You should only need it if + you modified a \`.y' file. You may need the \`Bison' package + in order for those modifications to take effect. You can get + \`Bison' from any GNU archive site." + rm -f y.tab.c y.tab.h + if [ $# -ne 1 ]; then + eval LASTARG="\${$#}" + case "$LASTARG" in + *.y) + SRCFILE=`echo "$LASTARG" | sed 's/y$/c/'` + if [ -f "$SRCFILE" ]; then + cp "$SRCFILE" y.tab.c + fi + SRCFILE=`echo "$LASTARG" | sed 's/y$/h/'` + if [ -f "$SRCFILE" ]; then + cp "$SRCFILE" y.tab.h + fi + ;; + esac + fi + if [ ! -f y.tab.h ]; then + echo >y.tab.h + fi + if [ ! -f y.tab.c ]; then + echo 'main() { return 0; }' >y.tab.c + fi + ;; + + lex|flex) + echo 1>&2 "\ +WARNING: \`$1' is missing on your system. You should only need it if + you modified a \`.l' file. You may need the \`Flex' package + in order for those modifications to take effect. You can get + \`Flex' from any GNU archive site." + rm -f lex.yy.c + if [ $# -ne 1 ]; then + eval LASTARG="\${$#}" + case "$LASTARG" in + *.l) + SRCFILE=`echo "$LASTARG" | sed 's/l$/c/'` + if [ -f "$SRCFILE" ]; then + cp "$SRCFILE" lex.yy.c + fi + ;; + esac + fi + if [ ! -f lex.yy.c ]; then + echo 'main() { return 0; }' >lex.yy.c + fi + ;; + + makeinfo) + echo 1>&2 "\ +WARNING: \`$1' is missing on your system. You should only need it if + you modified a \`.texi' or \`.texinfo' file, or any other file + indirectly affecting the aspect of the manual. The spurious + call might also be the consequence of using a buggy \`make' (AIX, + DU, IRIX). You might want to install the \`Texinfo' package or + the \`GNU make' package. Grab either from any GNU archive site." + file=`echo "$*" | sed -n 's/.*-o \([^ ]*\).*/\1/p'` + if test -z "$file"; then + file=`echo "$*" | sed 's/.* \([^ ]*\) *$/\1/'` + file=`sed -n '/^@setfilename/ { s/.* \([^ ]*\) *$/\1/; p; q; }' $file` + fi + touch $file + ;; + + *) + echo 1>&2 "\ +WARNING: \`$1' is needed, and you do not seem to have it handy on your + system. You might have modified some files without having the + proper tools for further handling them. Check the \`README' file, + it often tells you about the needed prerequirements for installing + this package. You may also peek at any GNU archive site, in case + some other package would contain this missing \`$1' program." + exit 1 + ;; +esac + +exit 0 diff --git a/wmmp3/mkinstalldirs b/wmmp3/mkinstalldirs new file mode 100755 index 0000000..4f58503 --- /dev/null +++ b/wmmp3/mkinstalldirs @@ -0,0 +1,40 @@ +#! /bin/sh +# mkinstalldirs --- make directory hierarchy +# Author: Noah Friedman +# Created: 1993-05-16 +# Public domain + +# $Id: mkinstalldirs,v 1.13 1999/01/05 03:18:55 bje Exp $ + +errstatus=0 + +for file +do + set fnord `echo ":$file" | sed -ne 's/^:\//#/;s/^://;s/\// /g;s/^#/\//;p'` + shift + + pathcomp= + for d + do + pathcomp="$pathcomp$d" + case "$pathcomp" in + -* ) pathcomp=./$pathcomp ;; + esac + + if test ! -d "$pathcomp"; then + echo "mkdir $pathcomp" + + mkdir "$pathcomp" || lasterr=$? + + if test ! -d "$pathcomp"; then + errstatus=$lasterr + fi + fi + + pathcomp="$pathcomp/" + done +done + +exit $errstatus + +# mkinstalldirs ends here diff --git a/wmmp3/mpg123ctl.c b/wmmp3/mpg123ctl.c new file mode 100644 index 0000000..b2e116b --- /dev/null +++ b/wmmp3/mpg123ctl.c @@ -0,0 +1,479 @@ +/* + * wmmp3 + * Copyright (c)1999 Patrick Crosby . + * This software covered by the GPL. See COPYING file for details. + * + * mpg123ctl.c + * + * This file contains all the functions for controlling the + * mpg123 backend processes. + * + * Random play functionality courtesy of: + * Matthew D. Campbell + * + * $Id: mpg123ctl.c,v 1.15 1999/10/12 04:41:20 pcrosby Exp $ + */ + +#include "mpg123ctl.h" + +#define MAXDIRS 100 +#define MAX_TITLE_LEN 9 + +void set_playlist(); +void signal_play(); +void play(); +void play_next(); +void play_prev(); +void init_ctl(); +void push_dir(char *s); +void push_dirname(char *s); +char *pop_dir(); +char *next_mp3dir(); +char *prev_mp3dir(); +char *current_mp3dir(); +void show_directory_name(); +void load_next_dir(); +void load_prev_dir(); +void alarmhandler(int sig); +void scroll_title(); +void finish(); +void dostuff(); + +char *dirs[MAXDIRS]; +int top = 0; +int max_dirs = 0; +int current_dir = 0; + +char *dirnames[MAXDIRS]; +int ntop = 0; +int nmax_dirs = 0; + +char mpg123_cmd[512]; +char mp3ext[12]; +char playlistext[12]; + +int next_song = 0; +int num_songs = 0; +int play_pid = 0; + +char title[512]; +int scroll_pos = 0; +int do_scroll = 0; +int always_scroll = 0; + +int repeat_flag = 0; +int random_flag = 0; +int *rand_song_num = NULL; + +int is_playing() +{ + if (play_pid > 0) + return 1; + else + return 0; +} + +/* + * patch received from Steven Jorgensen to fix following function + */ + +void set_playlist() +{ + char *directory; + DIR *dp; + struct dirent *entry; + char filename[512]; + + int i, tempnum, temppos; + + directory = (char *) current_mp3dir(); + + if (directory) + { + dp = opendir(directory); + if (dp == NULL) { + char *new_directory; + new_directory = (char *) next_mp3dir(); + dp = opendir(new_directory); + while (new_directory && (strcmp(new_directory, directory) != 0) && + (dp == NULL)) { + strcpy(directory, new_directory); + new_directory = (char *) next_mp3dir(); + dp = opendir(new_directory); + } + if (new_directory) + strcpy(directory, new_directory); + } + if (dp != NULL) { + show_directory_name(); + num_songs = 0; + empty_hash(); + entry = readdir(dp); + while (entry != NULL) { + if (strstr(entry->d_name, mp3ext)) { + sprintf(filename, "%s/%s", directory, entry->d_name); + insert_song(num_songs, entry->d_name, filename); + num_songs++; + } + entry = readdir(dp); + } + next_song = 0; + + /* Create Pseudo-random permutation of list */ + srand(time(NULL)); + rand_song_num = (int *)malloc(sizeof(int)*num_songs); + if (!rand_song_num) { + /* This shouldn't happen - the list isn't that big */ + fprintf(stderr, + "Error: cannot allocate randomized list\n"); + exit(1); + } + for (i=0; i= num_songs) { + if (repeat_flag == 0) { + load_next_dir(); + } else { + next_song = 0; + } + } + song = get_song(next_song); + if (random_flag) { + song = get_song(rand_song_num[next_song]); + } + if (song) { + strcpy(title, song->title); + strcat(title, " "); + scroll_pos = 0; + do_scroll = 1; + scroll_title(); + + play(song->filename); + next_song++; + signal(SIGCHLD, signal_play); + signal(SIGALRM, alarmhandler); + alarm(1); + } +} + +void play_prev() +{ + struct hash_elt *song; + + if (next_song <= 1) { + next_song = 0; + } + else { + next_song = next_song - 2; + } + + play_next(); +} + +void user_play() +{ + if (play_pid == 0) { + signal(SIGCHLD, signal_play); + set_playlist(); + play_next(); + } +} + +void stop() +{ + int status; + + if (play_pid > 0) { + signal(SIGCHLD, SIG_IGN); + kill(play_pid, SIGINT); + kill(play_pid, SIGTERM); + kill(play_pid, SIGKILL); + waitpid(play_pid, &status, 0); + play_pid = 0; + } +} + +void next() +{ + stop(); + play_next(); +} + +void back() +{ + stop(); + play_prev(); +} + +/* + * initialization functions + */ + +void init_ctl() +{ + signal(SIGINT, finish); + signal(SIGCHLD, dostuff); + set_playlist(); +} + +void set_mpg123(char *s) +{ + + strcpy(mpg123_cmd, s); +} + +void set_mp3ext(char *s) +{ + strcpy(mp3ext, s); +} + +void set_playlistext(char *s) +{ + strcpy(playlistext, s); +} + +void set_alwaysscroll(char *s) { + char *temp = s; + while (*temp) { + *temp = tolower(*temp); + temp++; + } + if ( !strcmp(s, "on") || !strcmp(s, "yes") || !strcmp(s, "1") || + !strcmp(s, "true")) { + always_scroll = 1; + } else { + always_scroll = 0; + } +} + + +void push_dir(char *s) +{ + dirs[top] = (char *) malloc(strlen(s) + 1); + strcpy(dirs[top], s); + top++; + max_dirs++; +} + +void push_dirname(char *s) +{ + /* from Steven Jorgensen */ + if ((strlen(s) + 1) < 10) + dirnames[ntop] = (char *) malloc(10); + else + dirnames[ntop] = (char *) malloc(strlen(s) + 1); + strcpy(dirnames[ntop], s); + ntop++; + nmax_dirs++; +} + +char *pop_dir() +{ + max_dirs--; + return (dirs[top--]); +} + +void add_mp3dir(char *s) +{ + push_dir(s); +} + +void add_mp3dirname(char *s) +{ + push_dirname(s); +} + +/* + * directory manipulation + */ + +char *next_mp3dir() +{ + if (current_dir < (max_dirs - 1)) { + current_dir++; + } + return (dirs[current_dir]); +} + +char *prev_mp3dir() +{ + if (current_dir > 0) { + current_dir--; + } + return (dirs[current_dir]); +} + +char *current_mp3dir() +{ + return (dirs[current_dir]); +} + +void show_directory_name() +{ + if (dirnames[current_dir] != NULL) { + while (strlen(dirnames[current_dir]) < 9) { + strcat(dirnames[current_dir], " "); + } + draw_string(dirnames[current_dir], 5, 5); + } else { + draw_string("no dirname", 5, 5); + } +} + +void dir_up(int button_num) +{ + if (!is_playing()) { + button_down(button_num); + load_prev_dir(); + } +} + +void dir_down(int button_num) +{ + if (!is_playing()) { + button_down(button_num); + load_next_dir(); + } +} + +void load_next_dir() +{ + next_mp3dir(); + set_playlist(); +} + +void load_prev_dir() +{ + prev_mp3dir(); + set_playlist(); +} + +/* + * song title functions + */ + +void alarmhandler(int sig) +{ + if ((play_pid > 0) && (do_scroll == 1)) { + scroll_title(); + signal(SIGALRM, alarmhandler); + alarm(1); + } +} + +void scroll_title() +{ + char s[MAX_TITLE_LEN + 1]; + int i; + int title_len; + + title_len = strlen(title); + if (do_scroll) { + for (i = 0; i < MAX_TITLE_LEN; i++) { + s[i] = title[(i + scroll_pos) % title_len]; + } + s[i] = '\0'; + draw_string(s, 5, 19); + scroll_pos++; + if (scroll_pos > title_len) { + scroll_pos = 0; + if (!always_scroll) { + do_scroll = 0; + } + } + } else { + draw_string(title, 5, 19); + } + RedrawWindow(); +} + +void turn_on_scroll() +{ + if ((!do_scroll) && (is_playing())) { + do_scroll = 1; + scroll_pos = 0; + signal(SIGALRM, alarmhandler); + alarm(1); + } +} + +/* + * toggles + */ + +void random_toggle(int button_num) +{ +/* button_gray(button_num); */ + if (random_flag == 0) { + button_down(button_num); + random_flag = 1; + } else { + button_up(button_num); + random_flag = 0; + } +} + +void repeat_toggle(int button_num) +{ + if (repeat_flag == 0) { + button_down(button_num); + repeat_flag = 1; + } else { + button_up(button_num); + repeat_flag = 0; + } +} + +/* + * cleanup + */ + +void finish() +{ + stop(); +} + +/* + * misc + */ +void dostuff() +{ + /* empty */ +} + diff --git a/wmmp3/mpg123ctl.h b/wmmp3/mpg123ctl.h new file mode 100644 index 0000000..c3c7bc6 --- /dev/null +++ b/wmmp3/mpg123ctl.h @@ -0,0 +1,47 @@ +/* + * wmmp3 + * Copyright (c)1999 Patrick Crosby . + * This software covered by the GPL. See COPYING file for details. + * + * mpg123ctl.h + * + * Header file for mpg123ctl.c + * + * $Id: mpg123ctl.h,v 1.6 1999/10/12 03:03:33 pcrosby Exp $ + */ + +#ifndef __MPG123CTL__ + +#define __MPG123CTL__ + +#include +#include +#include +#include +#include +#include +#include +#include "wmgeneral.h" +#include "buttons.h" +#include "song_hash.h" + +int is_playing(); +void user_play(); +void stop(); +void next(); +void back(); +void set_mpg123(char *s); +void set_mp3ext(char *s); +void set_playlistext(char *s); +void set_alwaysscroll(char *s); +void add_mp3dir(char *s); +void add_mp3dirname(char *s); +void dir_up(int button_num); +void dir_down(int button_num); +void turn_on_scroll(); +void random_toggle(int button_num); +void repeat_toggle(int button_num); + +#endif + + diff --git a/wmmp3/sample.wmmp3 b/wmmp3/sample.wmmp3 new file mode 100644 index 0000000..0c5f2a3 --- /dev/null +++ b/wmmp3/sample.wmmp3 @@ -0,0 +1,46 @@ +# full path to mpg123 executable +mpg123 = /usr/local/bin/mpg123 + +# +# mp3 directories, 1 per line +# +mp3dir = /mnt/msdos/tmp/mp3/radiohead +mp3dir = /mnt/msdos/tmp/mp3/pharcyde-labcabincalifornia +mp3dir = /mnt/msdos/tmp/mp3/blue_in_the_face +mp3dir = /mnt/msdos/tmp/mp3/dj_shadow +mp3dir = /mnt/msdos/tmp/mp3/fatboyslim +mp3dir = /mnt/msdos/tmp/mp3/genius +mp3dir = /mnt/msdos/tmp/mp3/glenn_gould +mp3dir = /mnt/msdos/tmp/mp3/portishead +mp3dir = /mnt/msdos/tmp/mp3/sea_and_cake + +# +# mp3 directory names (9 chars or less), same order as mp3dir's above +# +# These are nicknames for the directories above +# +mp3dirname = radiohead +mp3dirname = pharcyde2 +mp3dirname = blueface +mp3dirname = djshadow +mp3dirname = fatboy +mp3dirname = genius +mp3dirname = gould +mp3dirname = portis +mp3dirname = seacake + +# +# play list extension +# (not used yet) +playlistext = .m3u + +# +# extension for all mp3 files +# +mp3ext = .mp3 + +# +# always scroll the song names? +# (default = no) +alwaysscroll = 0 + diff --git a/wmmp3/song_hash.c b/wmmp3/song_hash.c new file mode 100644 index 0000000..492fba5 --- /dev/null +++ b/wmmp3/song_hash.c @@ -0,0 +1,110 @@ +#include "song_hash.h" + +#define HASH_TABLE_SIZE 11 + +struct hash_elt *Table[HASH_TABLE_SIZE]; + +int hash_fn(int num); +void free_elt(struct hash_elt *elt); + +int hash_fn(int num) +{ + return (num % HASH_TABLE_SIZE); +} + +void insert_song(int track_num, char *title, char *filename) +{ + int hash_value; + struct hash_elt *hash_list; + struct hash_elt *new_elt; + + + new_elt = (struct hash_elt *) malloc(sizeof(struct hash_elt)); + if (new_elt != NULL) + { + new_elt->track_num = track_num; + new_elt->title = (char *)strdup(title); + new_elt->filename = (char *)strdup(filename); + new_elt->next = NULL; + } + + hash_value = hash_fn(track_num); + hash_list = Table[hash_value]; + if (hash_list != NULL) { + while (hash_list->next != NULL) { + hash_list = hash_list->next; + } + hash_list->next = new_elt; + } + else + { + Table[hash_value] = new_elt; + } +} + +struct hash_elt *get_song(int track_num) +{ + int hash_value; + struct hash_elt *hash_list; + + hash_value = hash_fn(track_num); + hash_list = Table[hash_value]; + if (hash_list) { + while ((hash_list->track_num != track_num) && + (hash_list->next != NULL)) { + hash_list = hash_list->next; + } + if (hash_list->track_num == track_num) { + return hash_list; + } + else { + return NULL; + } + } + else { + return NULL; + } +} + +void free_elt(struct hash_elt *elt) +{ + if (elt != NULL) + { + if (elt->next != NULL) { + free_elt(elt->next); + } + free(elt); + } +} + +void empty_hash() +{ + int i; + + for (i = 0; i < HASH_TABLE_SIZE; i++) { + free_elt(Table[i]); + Table[i] = NULL; + } +} + +void print_hash() +{ + int i; + struct hash_elt *hash_list; + + for (i = 0; i < HASH_TABLE_SIZE; i++) { + printf("%d:\n", i); + hash_list = Table[i]; + while (hash_list != NULL) { + printf("\t%d: %s\n", + hash_list->track_num, + hash_list->title); + hash_list = hash_list->next; + } + } + +} + + + + diff --git a/wmmp3/song_hash.h b/wmmp3/song_hash.h new file mode 100644 index 0000000..18b887e --- /dev/null +++ b/wmmp3/song_hash.h @@ -0,0 +1,18 @@ +#ifndef __SONG_HASH__ +#define __SONG_HASH__ + +#include + +struct hash_elt { + struct hash_elt *next; + char *title; + char *filename; + int track_num; +}; + +void insert_song(int track_num, char *title, char *filename); +struct hash_elt *get_song(int track_num); +void empty_hash(); +void print_hash(); + +#endif diff --git a/wmmp3/wmgeneral.c b/wmmp3/wmgeneral.c new file mode 100644 index 0000000..9e75a51 --- /dev/null +++ b/wmmp3/wmgeneral.c @@ -0,0 +1,531 @@ +/* + Best viewed with GNU Emacs 19 + + wmgeneral was taken from wmppp. + + It has a lot of routines which most of the wm* programs use. + + ------------------------------------------------------------ + + Author: Martijn Pieterse (pieterse@xs4all.nl) + + --- + CHANGES: + --- + + + 14/09/1998 (Dave Clark, clarkd@skyia.com) + * Updated createXBMfromXPM routine + * Now supports >256 colors + 11/09/1998 (Martijn Pieterse, pieterse@xs4all.nl) + * Removed a bug from parse_rcfile. You could + not use "start" in a command if a label was + also start. + * Changed the needed geometry string. + We don't use window size, and don't support + negative positions. + 03/09/1998 (Martijn Pieterse, pieterse@xs4all.nl) + * Added parse_rcfile2 + 02/09/1998 (Martijn Pieterse, pieterse@xs4all.nl) + * Added -geometry support (untested) + 28/08/1998 (Martijn Pieterse, pieterse@xs4all.nl) + * Added createXBMfromXPM routine + * Saves a lot of work with changing xpm's. + 02/05/1998 (Martijn Pieterse, pieterse@xs4all.nl) + * changed the read_rc_file to parse_rcfile, as suggested by Marcelo E. Magallon + * debugged the parse_rc file. + 30/04/1998 (Martijn Pieterse, pieterse@xs4all.nl) + * Ripped similar code from all the wm* programs, + and put them in a single file. + + */ + +#include +#include +#include +#include +#include +#include + +#include +#include +#include + +#include "wmgeneral.h" +#include "charset.xpm" + +/*****************/ + /* X11 Variables */ +/*****************/ + +int screen; +int x_fd; +int d_depth; +XSizeHints mysizehints; +XWMHints mywmhints; +Pixel back_pix, fore_pix; +char *Geometry = ""; +GC NormalGC; +Pixmap pixmask; + +/*****************/ + /* Mouse Regions */ +/*****************/ + +typedef struct { + int enable; + int top; + int bottom; + int left; + int right; +} MOUSE_REGION; + +MOUSE_REGION mouse_region[MAX_MOUSE_REGION]; + +/***********************/ + /* Function Prototypes */ +/***********************/ + +static void GetXPM(XpmIcon *, char **); +static Pixel GetColor(char *); +void RedrawWindow(void); +void AddMouseRegion(int, int, int, int, int); +int CheckMouseRegion(int, int); +void PutPixel(int, int, int); +int GetPixel(int, int); + +/*******************************************************************************\ +|* parse_rcfile *| +\*******************************************************************************/ + +void parse_rcfile(const char *filename, rckeys * keys) +{ + + char *p, *q; + char temp[128]; + char *tokens = " :\t\n"; + FILE *fp; + int i, key; + + fp = fopen(filename, "r"); + if (fp) { + while (fgets(temp, 128, fp)) { + key = 0; + q = strdup(temp); + q = strtok(q, tokens); + while (key >= 0 && keys[key].label) { + if ((!strcmp(q, keys[key].label))) { + p = strstr(temp, keys[key].label); + p += strlen(keys[key].label); + p += strspn(p, tokens); + if ((i = strcspn(p, "#\n"))) + p[i] = 0; + free(*keys[key].var); + *keys[key].var = strdup(p); + key = -1; + } else + key++; + } + free(q); + } + fclose(fp); + } +} + +/*******************************************************************************\ +|* parse_rcfile2 *| +\*******************************************************************************/ + +void parse_rcfile2(const char *filename, rckeys2 * keys) +{ + + char *p; + char temp[128]; + char *tokens = " :\t\n"; + FILE *fp; + int i, key; + char *family = NULL; + + fp = fopen(filename, "r"); + if (fp) { + while (fgets(temp, 128, fp)) { + key = 0; + while (key >= 0 && keys[key].label) { + if ((p = strstr(temp, keys[key].label))) { + p += strlen(keys[key].label); + p += strspn(p, tokens); + if ((i = strcspn(p, "#\n"))) + p[i] = 0; + free(*keys[key].var); + *keys[key].var = strdup(p); + key = -1; + } else + key++; + } + } + fclose(fp); + } + free(family); +} + + +/*******************************************************************************\ +|* GetXPM *| +\*******************************************************************************/ + +static void GetXPM(XpmIcon * wmgen, char *pixmap_bytes[]) +{ + + XWindowAttributes attributes; + int err; + + /* For the colormap */ + XGetWindowAttributes(display, Root, &attributes); + + wmgen->attributes.valuemask |= (XpmReturnPixels | XpmReturnExtensions); + + err = XpmCreatePixmapFromData(display, Root, pixmap_bytes, &(wmgen->pixmap), + &(wmgen->mask), &(wmgen->attributes)); + + if (err != XpmSuccess) { + fprintf(stderr, "Not enough free colorcells.\n"); + exit(1); + } +} + +/*******************************************************************************\ +|* GetColor *| +\*******************************************************************************/ + +static Pixel GetColor(char *name) +{ + + XColor color; + XWindowAttributes attributes; + + XGetWindowAttributes(display, Root, &attributes); + + color.pixel = 0; + if (!XParseColor(display, attributes.colormap, name, &color)) { + fprintf(stderr, "wm.app: can't parse %s.\n", name); + } else if (!XAllocColor(display, attributes.colormap, &color)) { + fprintf(stderr, "wm.app: can't allocate %s.\n", name); + } + return color.pixel; +} + +/*******************************************************************************\ +|* flush_expose *| +\*******************************************************************************/ + +static int flush_expose(Window w) +{ + + XEvent dummy; + int i = 0; + + while (XCheckTypedWindowEvent(display, w, Expose, &dummy)) + i++; + + return i; +} + +/*******************************************************************************\ +|* RedrawWindow *| +\*******************************************************************************/ + +void RedrawWindow(void) +{ + + flush_expose(iconwin); + XCopyArea(display, wmgen.pixmap, iconwin, NormalGC, + 0, 0, wmgen.attributes.width, wmgen.attributes.height, 0, 0); + flush_expose(win); + XCopyArea(display, wmgen.pixmap, win, NormalGC, + 0, 0, wmgen.attributes.width, wmgen.attributes.height, 0, 0); +} + +/*******************************************************************************\ +|* RedrawWindowXY *| +\*******************************************************************************/ + +void RedrawWindowXY(int x, int y) +{ + + flush_expose(iconwin); + XCopyArea(display, wmgen.pixmap, iconwin, NormalGC, + x, y, wmgen.attributes.width, wmgen.attributes.height, 0, 0); + flush_expose(win); + XCopyArea(display, wmgen.pixmap, win, NormalGC, + x, y, wmgen.attributes.width, wmgen.attributes.height, 0, 0); +} + +/*******************************************************************************\ +|* AddMouseRegion *| +\*******************************************************************************/ + +void AddMouseRegion(int index, int left, int top, int right, int bottom) +{ + + if (index < MAX_MOUSE_REGION) { + mouse_region[index].enable = 1; + mouse_region[index].top = top; + mouse_region[index].left = left; + mouse_region[index].bottom = bottom; + mouse_region[index].right = right; + } +} + +/*******************************************************************************\ +|* CheckMouseRegion *| +\*******************************************************************************/ + +int CheckMouseRegion(int x, int y) +{ + + int i; + int found; + + found = 0; + + for (i = 0; i < MAX_MOUSE_REGION && !found; i++) { + if (mouse_region[i].enable && + x <= mouse_region[i].right && + x >= mouse_region[i].left && + y <= mouse_region[i].bottom && + y >= mouse_region[i].top) + found = 1; + } + if (!found) + return -1; + return (i - 1); +} + +/***************************************************************************\ +|* createXBMfromXPM *| +\***************************************************************************/ +void createXBMfromXPM(char *xbm, char **xpm, int sx, int sy) +{ + + int i, j, k; + int width, height, numcol, depth; + int zero = 0; + unsigned char bwrite; + int bcount; + int curpixel; + + sscanf(*xpm, "%d %d %d %d", &width, &height, &numcol, &depth); + + + for (k = 0; k != depth; k++) { + zero <<= 8; + zero |= xpm[1][k]; + } + + for (i = numcol + 1; i < numcol + sy + 1; i++) { + bcount = 0; + bwrite = 0; + for (j = 0; j < sx * depth; j += depth) { + bwrite >>= 1; + + curpixel = 0; + for (k = 0; k != depth; k++) { + curpixel <<= 8; + curpixel |= xpm[i][j + k]; + } + + if (curpixel != zero) { + bwrite += 128; + } + bcount++; + if (bcount == 8) { + *xbm = bwrite; + xbm++; + bcount = 0; + bwrite = 0; + } + } + } +} + +/*******************************************************************************\ +|* copyXPMArea *| +\*******************************************************************************/ + +void copyXPMArea(int x, int y, int sx, int sy, int dx, int dy) +{ + + XCopyArea(display, wmgen.pixmap, wmgen.pixmap, NormalGC, x, y, sx, sy, dx, dy); + +} + +/*******************************************************************************\ +|* copyXBMArea *| +\*******************************************************************************/ + +void copyXBMArea(int x, int y, int sx, int sy, int dx, int dy) +{ + + XCopyArea(display, wmgen.mask, wmgen.pixmap, NormalGC, x, y, sx, sy, dx, dy); +} + + +/*******************************************************************************\ +|* setMaskXY *| +\*******************************************************************************/ + +void setMaskXY(int x, int y) +{ + + XShapeCombineMask(display, win, ShapeBounding, x, y, pixmask, ShapeSet); + XShapeCombineMask(display, iconwin, ShapeBounding, x, y, pixmask, ShapeSet); +} + +/*******************************************************************************\ +|* openXwindow *| +\*******************************************************************************/ +void openXwindow(int argc, char *argv[], char *pixmap_bytes[], char *pixmask_bits, int pixmask_width, int pixmask_height) +{ + + unsigned int borderwidth = 1; + XClassHint classHint; + char *display_name = NULL; + char *wname = argv[0]; + XTextProperty name; + + XGCValues gcv; + unsigned long gcm; + + char *geometry = NULL; + + int dummy = 0; + int i, wx, wy; + + for (i = 1; argv[i]; i++) { + if (!strcmp(argv[i], "-display")) { + display_name = argv[i + 1]; + i++; + } + if (!strcmp(argv[i], "-geometry")) { + geometry = argv[i + 1]; + i++; + } + } + + if (!(display = XOpenDisplay(display_name))) { + fprintf(stderr, "%s: can't open display %s\n", + wname, XDisplayName(display_name)); + exit(1); + } + screen = DefaultScreen(display); + Root = RootWindow(display, screen); + d_depth = DefaultDepth(display, screen); + x_fd = XConnectionNumber(display); + + /* Convert XPM to XImage */ + GetXPM(&wmgen, pixmap_bytes); + + /* Create a window to hold the stuff */ + mysizehints.flags = USSize | USPosition; + mysizehints.x = 0; + mysizehints.y = 0; + + back_pix = GetColor("white"); + fore_pix = GetColor("black"); + + XWMGeometry(display, screen, Geometry, NULL, borderwidth, &mysizehints, + &mysizehints.x, &mysizehints.y, &mysizehints.width, &mysizehints.height, &dummy); + + mysizehints.width = 64; + mysizehints.height = 64; + + win = XCreateSimpleWindow(display, Root, mysizehints.x, mysizehints.y, + mysizehints.width, mysizehints.height, borderwidth, fore_pix, back_pix); + + iconwin = XCreateSimpleWindow(display, win, mysizehints.x, mysizehints.y, + mysizehints.width, mysizehints.height, borderwidth, fore_pix, back_pix); + + /* Activate hints */ + XSetWMNormalHints(display, win, &mysizehints); + classHint.res_name = wname; + classHint.res_class = wname; + XSetClassHint(display, win, &classHint); + + XSelectInput(display, win, ButtonPressMask | ExposureMask | ButtonReleaseMask | PointerMotionMask | StructureNotifyMask); + XSelectInput(display, iconwin, ButtonPressMask | ExposureMask | ButtonReleaseMask | PointerMotionMask | StructureNotifyMask); + + if (XStringListToTextProperty(&wname, 1, &name) == 0) { + fprintf(stderr, "%s: can't allocate window name\n", wname); + exit(1); + } + XSetWMName(display, win, &name); + + /* Create GC for drawing */ + + gcm = GCForeground | GCBackground | GCGraphicsExposures; + gcv.foreground = fore_pix; + gcv.background = back_pix; + gcv.graphics_exposures = 0; + NormalGC = XCreateGC(display, Root, gcm, &gcv); + + /* ONLYSHAPE ON */ + + pixmask = XCreateBitmapFromData(display, win, pixmask_bits, pixmask_width, pixmask_height); + + XShapeCombineMask(display, win, ShapeBounding, 0, 0, pixmask, ShapeSet); + XShapeCombineMask(display, iconwin, ShapeBounding, 0, 0, pixmask, ShapeSet); + + /* ONLYSHAPE OFF */ + + mywmhints.initial_state = WithdrawnState; + mywmhints.icon_window = iconwin; + mywmhints.icon_x = mysizehints.x; + mywmhints.icon_y = mysizehints.y; + mywmhints.window_group = win; + mywmhints.flags = StateHint | IconWindowHint | IconPositionHint | WindowGroupHint; + + XSetWMHints(display, win, &mywmhints); + + XSetCommand(display, win, argv, argc); + XMapWindow(display, win); + + + if (geometry) { + if (sscanf(geometry, "+%d+%d", &wx, &wy) != 2) { + fprintf(stderr, "Bad geometry string.\n"); + exit(1); + } + XMoveWindow(display, win, wx, wy); + } +} + +/* + + * font_init + */ +void font_init() +{ + GetXPM(&wmfont, charset_xpm); +} + +void draw_char(char c, int x, int y) +{ + int sx, sy; + sx = (c - 32) * 6; + sy = 0; + XCopyArea(display, wmfont.pixmap, wmgen.pixmap, NormalGC, sx, sy, 6, 7, + x, y); +} + +void draw_string(char *s, int x, int y) +{ + int i = 0; + int x_space = 6; + + while (i < strlen(s)) { + if ((x + (x_space * i)) < 64) { + draw_char(s[i], x + (x_space * i), y); + } + i++; + } +} diff --git a/wmmp3/wmgeneral.h b/wmmp3/wmgeneral.h new file mode 100644 index 0000000..6158891 --- /dev/null +++ b/wmmp3/wmgeneral.h @@ -0,0 +1,71 @@ +#ifndef WMGENERAL_H_INCLUDED +#define WMGENERAL_H_INCLUDED + +#include +#include +#include + + +/***********/ + /* Defines */ +/***********/ + +#define MAX_MOUSE_REGION (16) + +/************/ + /* Typedefs */ +/************/ + +typedef struct _rckeys rckeys; + +struct _rckeys { + const char *label; + char **var; +}; + +typedef struct _rckeys2 rckeys2; + +struct _rckeys2 { + const char *family; + const char *label; + char **var; +}; + +typedef struct { + Pixmap pixmap; + Pixmap mask; + XpmAttributes attributes; +} XpmIcon; + +/*******************/ + /* Global variable */ +/*******************/ + +Display *display; +Window Root, iconwin, win; +XpmIcon wmgen; +XpmIcon wmfont; + +/***********************/ + /* Function Prototypes */ +/***********************/ + +void AddMouseRegion(int index, int left, int top, int right, int bottom); +int CheckMouseRegion(int x, int y); + +void openXwindow(int argc, char *argv[], char **, char *, int, int); +void RedrawWindow(void); +void RedrawWindowXY(int x, int y); + +void createXBMfromXPM(char *, char **, int, int); +void copyXPMArea(int, int, int, int, int, int); +void copyXBMArea(int, int, int, int, int, int); +void setMaskXY(int, int); + +void parse_rcfile(const char *, rckeys *); + +void font_init(); +void draw_char(char c, int x, int y); +void draw_string(char *s, int x, int y); + +#endif diff --git a/wmmp3/wmmp3.xpm b/wmmp3/wmmp3.xpm new file mode 100644 index 0000000..68077b1 --- /dev/null +++ b/wmmp3/wmmp3.xpm @@ -0,0 +1,138 @@ +/* XPM */ +static char * wmmp3_xpm[] = { +"128 128 7 1", +" c None", +". c #000000", +"+ c #202020", +"@ c #C7C7C7", +"# c #FFFFFF", +"$ c #86828E", +"% c #AEAAAE", +" ", +" ", +" ", +" ", +" ...........+........................................... ", +" .+++++++++++++++++++++++++++++++++++++++++++++++++++++@ ", +" .+++++++++++++++++++++++++++++++++++++++++++++++++++++@ ", +" .+++++++++++++++++++++++++++++++++++++++++++++++++++++@ ", +" .+++++++++++++++++++++++++++++++++++++++++++++++++++++@ ", +" .+++++++++++++++++++++++++++++++++++++++++++++++++++++@ ", +" .+++++++++++++++++++++++++++++++++++++++++++++++++++++@ ", +" .+++++++++++++++++++++++++++++++++++++++++++++++++++++@ ", +" .+++++++++++++++++++++++++++++++++++++++++++++++++++++@ ", +" .+++++++++++++++++++++++++++++++++++++++++++++++++++++@ ", +" .+++++++++++++++++++++++++++++++++++++++++++++++++++++@ ", +" @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ ", +" ", +" ", +" ....................................................... ", +" ......................................................@ ", +" ......................................................@ ", +" ......................................................@ ", +" ......................................................@ ", +" ......................................................@ ", +" ......................................................@ ", +" ......................................................@ ", +" ......................................................@ ", +" ......................................................@ ", +" ......................................................@ ", +" @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ ", +" ", +" ", +" ", +" .........................@ .........................@ ", +" .###########$###########$@ .###########$###########$@ ", +" .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ ", +" .#%%%%%%%%%%.#%%....%%%%.@ .#%%......%%.#%%%.%%%%%%.@ ", +" .#%%%%..%%%%.#%%.%%%.%%%.@ .#%%......%%.#%%%..%%%%%.@ ", +" .#%%%....%%%.#%%.%%%.%%%.@ .#%%......%%.#%%%...%%%%.@ ", +" .#%%..%%..%%.#%%....%%%%.@ .#%%......%%.#%%%....%%%.@ ", +" .#%..%%%%..%.#%%.%.%%%%%.@ .#%%......%%.#%%%...%%%%.@ ", +" .#%%%%%%%%%%.#%%.%%.%%%%.@ .#%%......%%.#%%%..%%%%%.@ ", +" .#%%%%%%%%%%.#%%.%%%.%%%.@ .#%%......%%.#%%%.%%%%%%.@ ", +" .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ ", +" .$...........$...........@ .$...........$...........@ ", +" .###########$###########$@ .###########$###########$@ ", +" .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ ", +" .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%.%%%.%%%.#%%%.%%%.%%.@ ", +" .#%%%%%%%%%%.#%%..%%..%%.@ .#%%.%%..%%%.#%%%..%%.%%.@ ", +" .#%..%%%%..%.#%.%%$.%%.%.@ .#%%.%..%%%%.#%%%%..%.%%.@ ", +" .#%%..%%..%%.#%.%%.$%%.%.@ .#%%...%%%%%.#%%%%%...%%.@ ", +" .#%%%....%%%.#%%..%%..%%.@ .#%%.%..%%%%.#%%%%..%.%%.@ ", +" .#%%%%..%%%%.#%%%%%%%%%%.@ .#%%.%%..%%%.#%%%..%%.%%.@ ", +" .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%.%%%.%%%.#%%%.%%%.%%.@ ", +" .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ ", +" .$...........$...........@ .$...........$...........@ ", +" @@@@@@@@@@@@@@@@@@@@@@@@@@ @@@@@@@@@@@@@@@@@@@@@@@@@@ ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" .........................@ .........................@ .........................@ .........................@ ", +" .###########$###########$@ .###########$###########$@ .###########$###########$@ .###########$###########$@ ", +" .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ ", +" .#%%%%%%%%%%.#%%....%%%%.@ .#%%......%%.#%%%.%%%%%%.@ .#%%%%%%%%%%.#%%$$$$%%%%.@ .#%%$$$$$$%%.#%%%$%%%%%%.@ ", +" .#%%%%..%%%%.#%%.%%%.%%%.@ .#%%......%%.#%%%..%%%%%.@ .#%%%%$$%%%%.#%%$%%%$%%%.@ .#%%$$$$$$%%.#%%%$$%%%%%.@ ", +" .#%%%....%%%.#%%.%%%.%%%.@ .#%%......%%.#%%%...%%%%.@ .#%%%$$$$%%%.#%%$%%%$%%%.@ .#%%$$$$$$%%.#%%%$$$%%%%.@ ", +" .#%%..%%..%%.#%%....%%%%.@ .#%%......%%.#%%%....%%%.@ .#%%$$%%$$%%.#%%$$$$%%%%.@ .#%%$$$$$$%%.#%%%$$$$%%%.@ ", +" .#%..%%%%..%.#%%.%.%%%%%.@ .#%%......%%.#%%%...%%%%.@ .#%$$%%%%$$%.#%%$%$%%%%%.@ .#%%$$$$$$%%.#%%%$$$%%%%.@ ", +" .#%%%%%%%%%%.#%%.%%.%%%%.@ .#%%......%%.#%%%..%%%%%.@ .#%%%%%%%%%%.#%%$%%$%%%%.@ .#%%$$$$$$%%.#%%%$$%%%%%.@ ", +" .#%%%%%%%%%%.#%%.%%%.%%%.@ .#%%......%%.#%%%.%%%%%%.@ .#%%%%%%%%%%.#%%$%%%$%%%.@ .#%%$$$$$$%%.#%%%$%%%%%%.@ ", +" .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ ", +" .$...........$...........@ .$...........$...........@ .$...........$...........@ .$...........$...........@ ", +" .###########$###########$@ .###########$###########$@ .###########$###########$@ .###########$###########$@ ", +" .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ ", +" .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%.%%%.%%%.#%%%.%%%.%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%$%%%$%%%.#%%%$%%%$%%.@ ", +" .#%%%%%%%%%%.#%%..%%..%%.@ .#%%.%%..%%%.#%%%..%%.%%.@ .#%%%%%%%%%%.#%%$$%%$$%%.@ .#%%$%%$$%%%.#%%%$$%%$%%.@ ", +" .#%..%%%%..%.#%.%%$.%%.%.@ .#%%.%..%%%%.#%%%%..%.%%.@ .#%$$%%%%$$%.#%$%%$$%%$%.@ .#%%$%$$%%%%.#%%%%$$%$%%.@ ", +" .#%%..%%..%%.#%.%%.$%%.%.@ .#%%...%%%%%.#%%%%%...%%.@ .#%%$$%%$$%%.#%$%%$$%%$%.@ .#%%$$$%%%%%.#%%%%%$$$%%.@ ", +" .#%%%....%%%.#%%..%%..%%.@ .#%%.%..%%%%.#%%%%..%.%%.@ .#%%%$$$$%%%.#%%$$%%$$%%.@ .#%%$%$$%%%%.#%%%%$$%$%%.@ ", +" .#%%%%..%%%%.#%%%%%%%%%%.@ .#%%.%%..%%%.#%%%..%%.%%.@ .#%%%%$$%%%%.#%%%%%%%%%%.@ .#%%$%%$$%%%.#%%%$$%%$%%.@ ", +" .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%.%%%.%%%.#%%%.%%%.%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%$%%%$%%%.#%%%$%%%$%%.@ ", +" .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ .#%%%%%%%%%%.#%%%%%%%%%%.@ ", +" .$...........$...........@ .$...........$...........@ .$...........$...........@ .$...........$...........@ ", +" @@@@@@@@@@@@@@@@@@@@@@@@@@ @@@@@@@@@@@@@@@@@@@@@@@@@@ @@@@@@@@@@@@@@@@@@@@@@@@@@ @@@@@@@@@@@@@@@@@@@@@@@@@@ ", +" ", +" ", +" ", +" .........................@ .........................@ ", +" ............$...........$@ ............$...........$@ ", +" ..%%%%%%%%%%#.%%%%%%%%%%#@ ..%%%%%%%%%%#.%%%%%%%%%%#@ ", +" ..%%%%%%%%%%#.%%....%%%%#@ ..%%......%%#.%%%.%%%%%%#@ ", +" ..%%%%..%%%%#.%%.%%%.%%%#@ ..%%......%%#.%%%..%%%%%#@ ", +" ..%%%....%%%#.%%.%%%.%%%#@ ..%%......%%#.%%%...%%%%#@ ", +" ..%%..%%..%%#.%%....%%%%#@ ..%%......%%#.%%%....%%%#@ ", +" ..%..%%%%..%#.%%.%.%%%%%#@ ..%%......%%#.%%%...%%%%#@ ", +" ..%%%%%%%%%%#.%%.%%.%%%%#@ ..%%......%%#.%%%..%%%%%#@ ", +" ..%%%%%%%%%%#.%%.%%%.%%%#@ ..%%......%%#.%%%.%%%%%%#@ ", +" ..%%%%%%%%%%#.%%%%%%%%%%#@ ..%%%%%%%%%%#.%%%%%%%%%%#@ ", +" .$###########$###########@ .$###########$###########@ ", +" ............$...........$@ ............$...........$@ ", +" ..%%%%%%%%%%#.%%%%%%%%%%#@ ..%%%%%%%%%%#.%%%%%%%%%%#@ ", +" ..%%%%%%%%%%#.%%%%%%%%%%#@ ..%%.%%%.%%%#.%%%.%%%.%%#@ ", +" ..%%%%%%%%%%#.%%..%%..%%#@ ..%%.%%..%%%#.%%%..%%.%%#@ ", +" ..%..%%%%..%#.%.%%$.%%.%#@ ..%%.%..%%%%#.%%%%..%.%%#@ ", +" ..%%..%%..%%#.%.%%.$%%.%#@ ..%%...%%%%%#.%%%%%...%%#@ ", +" ..%%%....%%%#.%%..%%..%%#@ ..%%.%..%%%%#.%%%%..%.%%#@ ", +" ..%%%%..%%%%#.%%%%%%%%%%#@ ..%%.%%..%%%#.%%%..%%.%%#@ ", +" ..%%%%%%%%%%#.%%%%%%%%%%#@ ..%%.%%%.%%%#.%%%.%%%.%%#@ ", +" ..%%%%%%%%%%#.%%%%%%%%%%#@ ..%%%%%%%%%%#.%%%%%%%%%%#@ ", +" .$###########$###########@ .$###########$###########@ ", +" @@@@@@@@@@@@@@@@@@@@@@@@@@ @@@@@@@@@@@@@@@@@@@@@@@@@@ ", +" ", +" ", +" ", +" ", +" ", +" ", +" ", +" "};