From d6ba9999928ae41c5e3801c5c271860615b00700 Mon Sep 17 00:00:00 2001 From: Hans-Christoph Steiner Date: Fri, 9 Apr 2010 19:57:15 +0000 Subject: ported purepd to template Makefile/debian svn path=/trunk/abstractions/purepd/; revision=13417 --- LICENSE.txt | 290 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ Makefile | 274 +++++++++++++++++++++++++++++++++++++++++++++++++++ README | 15 --- README.txt | 15 +++ alternate-help.pd | 84 ++++++++++++++++ clip-help.pd | 106 ++++++++++++++++++++ cosh-help.pd | 19 ++++ debian/changelog | 5 + debian/compat | 1 + debian/control | 15 +++ debian/copyright | 18 ++++ debian/rules | 16 +++ delta-help.pd | 20 ++++ inv-help.pd | 10 ++ moses-help.pd | 17 ++++ once-help.pd | 36 +++++++ oneshot-help.pd | 11 +++ purepd-meta.pd | 1 + sinh-help.pd | 19 ++++ tanh-help.pd | 19 ++++ velocity-help.pd | 14 +++ 21 files changed, 990 insertions(+), 15 deletions(-) create mode 100644 LICENSE.txt create mode 100644 Makefile delete mode 100644 README create mode 100644 README.txt create mode 100644 alternate-help.pd create mode 100644 clip-help.pd create mode 100644 cosh-help.pd create mode 100644 debian/changelog create mode 100644 debian/compat create mode 100644 debian/control create mode 100644 debian/copyright create mode 100755 debian/rules create mode 100644 delta-help.pd create mode 100644 inv-help.pd create mode 100644 moses-help.pd create mode 100644 once-help.pd create mode 100644 oneshot-help.pd create mode 100644 sinh-help.pd create mode 100644 tanh-help.pd create mode 100644 velocity-help.pd diff --git a/LICENSE.txt b/LICENSE.txt new file mode 100644 index 0000000..fa0bef4 --- /dev/null +++ b/LICENSE.txt @@ -0,0 +1,290 @@ +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/Makefile b/Makefile new file mode 100644 index 0000000..922d45c --- /dev/null +++ b/Makefile @@ -0,0 +1,274 @@ +## Pd library template version 1.0 +# For instructions on how to use this template, see: +# http://puredata.info/docs/developer/MakefileTemplate +LIBRARY_NAME = purepd + +# add your .c source files to the SOURCES variable, help files will be +# included automatically +SOURCES = + +# For objects that only build on certain platforms, add those to the SOURCES +# line for the right platforms. +SOURCES_android = +SOURCES_cygwin = +SOURCES_macosx = +SOURCES_iphoneos = +SOURCES_linux = +SOURCES_windows = + +# list all pd objects (i.e. myobject.pd) files here, and their helpfiles will +# be included automatically +PDOBJECTS = alternate.pd any_argument.pd clip.pd cosh.pd delta.pd delta~.pd fifo.pd float_argument.pd for++.pd gt2~.pd gt~.pd inv.pd log10.pd lt2~.pd lt~.pd moses.pd once.pd oneshot.pd purepd_error.pd sgn~.pd sinh.pd symbol_argument.pd tanh.pd uzi.pd velocity.pd + +# example patches and related files, in the 'examples' subfolder +EXAMPLES = + +# manuals and related files, in the 'manual' subfolder +MANUAL = + +# if you want to include any other files in the source and binary tarballs, +# list them here. This can be anything from header files, example patches, +# documentation, etc. README.txt and LICENSE.txt are required and therefore +# automatically included +EXTRA_DIST = + + + +#------------------------------------------------------------------------------# +# +# you shouldn't need to edit anything below here, if we did it right :) +# +#------------------------------------------------------------------------------# + +# get library version from meta file +LIBRARY_VERSION = $(shell sed -n 's|^\#X text [0-9][0-9]* [0-9][0-9]* VERSION \(.*\);|\1|p' $(LIBRARY_NAME)-meta.pd) + +# where Pd lives +PD_PATH = ../../pd +# where to install the library +prefix = /usr/local +libdir = $(prefix)/lib +pkglibdir = $(libdir)/pd-externals +objectsdir = $(pkglibdir) + + +INSTALL = install +INSTALL_FILE = $(INSTALL) -p -m 644 +INSTALL_DIR = $(INSTALL) -p -m 755 -d + +CFLAGS = -DPD -I$(PD_PATH)/src -Wall -W -g +LDFLAGS = +LIBS = +ALLSOURCES := $(SOURCES) $(SOURCES_android) $(SOURCES_cygwin) $(SOURCES_macosx) \ + $(SOURCES_iphoneos) $(SOURCES_linux) $(SOURCES_windows) + +UNAME := $(shell uname -s) +ifeq ($(UNAME),Darwin) + CPU := $(shell uname -p) + ifeq ($(CPU),arm) # iPhone/iPod Touch + SOURCES += $(SOURCES_macosx) + EXTENSION = pd_darwin + OS = iphoneos + IPHONE_BASE=/Developer/Platforms/iPhoneOS.platform/Developer/usr/bin + CC=$(IPHONE_BASE)/gcc + CPP=$(IPHONE_BASE)/cpp + CXX=$(IPHONE_BASE)/g++ + ISYSROOT = -isysroot /Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS3.0.sdk + IPHONE_CFLAGS = -miphoneos-version-min=3.0 $(ISYSROOT) -arch armv6 + OPT_CFLAGS = -fast -funroll-loops -fomit-frame-pointer + CFLAGS := $(IPHONE_CFLAGS) $(OPT_CFLAGS) $(CFLAGS) \ + -I/Applications/Pd-extended.app/Contents/Resources/include + LDFLAGS += -arch armv6 -bundle -undefined dynamic_lookup $(ISYSROOT) + LIBS += -lc + STRIP = strip -x + DISTDIR=$(LIBRARY_NAME)-$(LIBRARY_VERSION) + DISTBINDIR=$(DISTDIR)-$(OS) + else # Mac OS X + SOURCES += $(SOURCES_macosx) + EXTENSION = pd_darwin + OS = macosx + OPT_CFLAGS = -ftree-vectorize -ftree-vectorizer-verbose=2 -fast + FAT_FLAGS = -arch i386 -arch ppc -mmacosx-version-min=10.4 + CFLAGS += $(FAT_FLAGS) -fPIC -I/sw/include \ + -I/Applications/Pd-extended.app/Contents/Resources/include + LDFLAGS += $(FAT_FLAGS) -bundle -undefined dynamic_lookup -L/sw/lib + # if the 'pd' binary exists, check the linking against it to aid with stripping + LDFLAGS += $(shell test -e $(PD_PATH)/bin/pd && echo -bundle_loader $(PD_PATH)/bin/pd) + LIBS += -lc + STRIP = strip -x + DISTDIR=$(LIBRARY_NAME)-$(LIBRARY_VERSION) + DISTBINDIR=$(DISTDIR)-$(OS) + endif +endif +ifeq ($(UNAME),Linux) + SOURCES += $(SOURCES_linux) + EXTENSION = pd_linux + OS = linux + OPT_CFLAGS = -O6 -funroll-loops -fomit-frame-pointer + CFLAGS += -fPIC + LDFLAGS += -Wl,--export-dynamic -shared -fPIC + LIBS += -lc + STRIP = strip --strip-unneeded -R .note -R .comment + DISTDIR=$(LIBRARY_NAME)-$(LIBRARY_VERSION) + DISTBINDIR=$(DISTDIR)-$(OS)-$(shell uname -m) +endif +ifeq (CYGWIN,$(findstring CYGWIN,$(UNAME))) + SOURCES += $(SOURCES_cygwin) + EXTENSION = dll + OS = cygwin + OPT_CFLAGS = -O6 -funroll-loops -fomit-frame-pointer + CFLAGS += + LDFLAGS += -Wl,--export-dynamic -shared -L$(PD_PATH)/src + LIBS += -lc -lpd + STRIP = strip --strip-unneeded -R .note -R .comment + DISTDIR=$(LIBRARY_NAME)-$(LIBRARY_VERSION) + DISTBINDIR=$(DISTDIR)-$(OS) +endif +ifeq (MINGW,$(findstring MINGW,$(UNAME))) + SOURCES += $(SOURCES_windows) + EXTENSION = dll + OS = windows + OPT_CFLAGS = -O3 -funroll-loops -fomit-frame-pointer -march=i686 -mtune=pentium4 + CFLAGS += -mms-bitfields + LDFLAGS += -s -shared -Wl,--enable-auto-import + LIBS += -L$(PD_PATH)/src -L$(PD_PATH)/bin -L$(PD_PATH)/obj -lpd -lwsock32 -lkernel32 -luser32 -lgdi32 + STRIP = strip --strip-unneeded -R .note -R .comment + DISTDIR=$(LIBRARY_NAME)-$(LIBRARY_VERSION) + DISTBINDIR=$(DISTDIR)-$(OS) +endif + +CFLAGS += $(OPT_CFLAGS) + + +.PHONY = install libdir_install single_install install-doc install-exec install-examples install-manual clean dist etags + +all: $(SOURCES:.c=.$(EXTENSION)) + +%.o: %.c + $(CC) $(CFLAGS) -o "$*.o" -c "$*.c" + +%.$(EXTENSION): %.o + $(CC) $(LDFLAGS) -o "$*.$(EXTENSION)" "$*.o" $(LIBS) + chmod a-x "$*.$(EXTENSION)" + +# this links everything into a single binary file +$(LIBRARY_NAME): $(SOURCES:.c=.o) $(LIBRARY_NAME).o + $(CC) $(LDFLAGS) -o $(LIBRARY_NAME).$(EXTENSION) $(SOURCES:.c=.o) $(LIBRARY_NAME).o $(LIBS) + chmod a-x $(LIBRARY_NAME).$(EXTENSION) + + +install: libdir_install + +# The meta and help files are explicitly installed to make sure they are +# actually there. Those files are not optional, then need to be there. +libdir_install: $(SOURCES:.c=.$(EXTENSION)) install-doc install-examples install-manual + $(INSTALL_DIR) $(DESTDIR)$(objectsdir)/$(LIBRARY_NAME) + $(INSTALL_FILE) $(LIBRARY_NAME)-meta.pd \ + $(DESTDIR)$(objectsdir)/$(LIBRARY_NAME) + test -z "$(strip $(SOURCES))" || (\ + $(INSTALL_FILE) $(SOURCES:.c=.$(EXTENSION)) $(DESTDIR)$(objectsdir)/$(LIBRARY_NAME) && \ + $(STRIP) $(addprefix $(DESTDIR)$(objectsdir)/$(LIBRARY_NAME)/,$(SOURCES:.c=.$(EXTENSION)))) + test -z "$(strip $(PDOBJECTS))" || \ + $(INSTALL_FILE) $(PDOBJECTS) \ + $(DESTDIR)$(objectsdir)/$(LIBRARY_NAME) + +# install library linked as single binary +single_install: $(LIBRARY_NAME) install-doc install-exec + $(INSTALL_DIR) $(DESTDIR)$(objectsdir)/$(LIBRARY_NAME) + $(INSTALL_FILE) $(LIBRARY_NAME).$(EXTENSION) $(DESTDIR)$(objectsdir)/$(LIBRARY_NAME) + $(STRIP) $(DESTDIR)$(objectsdir)/$(LIBRARY_NAME)/$(LIBRARY_NAME).$(EXTENSION) + +install-doc: + $(INSTALL_DIR) $(DESTDIR)$(objectsdir)/$(LIBRARY_NAME) + test -z "$(strip $(SOURCES))" || \ + $(INSTALL_FILE) $(SOURCES:.c=-help.pd) \ + $(DESTDIR)$(objectsdir)/$(LIBRARY_NAME) + test -z "$(strip $(PDOBJECTS))" || \ + $(INSTALL_FILE) $(PDOBJECTS:.pd=-help.pd) \ + $(DESTDIR)$(objectsdir)/$(LIBRARY_NAME) + $(INSTALL_FILE) README.txt $(DESTDIR)$(objectsdir)/$(LIBRARY_NAME)/README.txt + $(INSTALL_FILE) LICENSE.txt $(DESTDIR)$(objectsdir)/$(LIBRARY_NAME)/LICENSE.txt + +install-examples: + test -z "$(strip $(EXAMPLES))" || \ + $(INSTALL_DIR) $(DESTDIR)$(objectsdir)/$(LIBRARY_NAME)/examples && \ + for file in $(EXAMPLES); do \ + $(INSTALL_FILE) examples/$$file $(DESTDIR)$(objectsdir)/$(LIBRARY_NAME)/examples; \ + done + +install-manual: + test -z "$(strip $(MANUAL))" || \ + $(INSTALL_DIR) $(DESTDIR)$(objectsdir)/$(LIBRARY_NAME)/manual && \ + for file in $(MANUAL); do \ + $(INSTALL_FILE) manual/$$file $(DESTDIR)$(objectsdir)/$(LIBRARY_NAME)/manual; \ + done + + +clean: + -rm -f -- $(SOURCES:.c=.o) + -rm -f -- $(SOURCES:.c=.$(EXTENSION)) + -rm -f -- $(LIBRARY_NAME).o + -rm -f -- $(LIBRARY_NAME).$(EXTENSION) + +distclean: clean + -rm -f -- $(DISTBINDIR).tar.gz + -rm -rf -- $(DISTBINDIR) + -rm -f -- $(DISTDIR).tar.gz + -rm -rf -- $(DISTDIR) + + +$(DISTBINDIR): + $(INSTALL_DIR) $(DISTBINDIR) + +libdir: all $(DISTBINDIR) + $(INSTALL_FILE) $(LIBRARY_NAME)-meta.pd $(DISTBINDIR) + $(INSTALL_FILE) $(SOURCES) $(DISTBINDIR) + $(INSTALL_FILE) $(SOURCES:.c=-help.pd) $(DISTBINDIR) + test -z "$(strip $(EXTRA_DIST))" || \ + $(INSTALL_FILE) $(EXTRA_DIST) $(DISTBINDIR) +# tar --exclude-vcs -czpf $(DISTBINDIR).tar.gz $(DISTBINDIR) + +$(DISTDIR): + $(INSTALL_DIR) $(DISTDIR) + +dist: $(DISTDIR) + $(INSTALL_FILE) Makefile $(DISTDIR) + $(INSTALL_FILE) README.txt $(DISTDIR) + $(INSTALL_FILE) LICENSE.txt $(DISTDIR) + $(INSTALL_FILE) $(LIBRARY_NAME)-meta.pd $(DISTDIR) + test -z "$(strip $(ALLSOURCES))" || \ + $(INSTALL_FILE) $(ALLSOURCES) $(DISTDIR) + test -z "$(strip $(ALLSOURCES))" || \ + $(INSTALL_FILE) $(ALLSOURCES:.c=-help.pd) $(DISTDIR) + test -z "$(strip $(PDOBJECTS))" || \ + $(INSTALL_FILE) $(PDOBJECTS) $(DISTDIR) + test -z "$(strip $(PDOBJECTS))" || \ + $(INSTALL_FILE) $(PDOBJECTS:.pd=-help.pd) $(DISTDIR) + test -z "$(strip $(EXTRA_DIST))" || \ + $(INSTALL_FILE) $(EXTRA_DIST) $(DISTDIR) + test -z "$(strip $(EXAMPLES))" || \ + $(INSTALL_DIR) $(DISTDIR)/examples && \ + for file in $(EXAMPLES); do \ + $(INSTALL_FILE) examples/$$file $(DISTDIR)/examples; \ + done + test -z "$(strip $(MANUAL))" || \ + $(INSTALL_DIR) $(DISTDIR)/manual && \ + for file in $(MANUAL); do \ + $(INSTALL_FILE) manual/$$file $(DISTDIR)/manual; \ + done + tar --exclude-vcs -czpf $(DISTDIR).tar.gz $(DISTDIR) + + +etags: + etags *.h $(SOURCES) ../../pd/src/*.[ch] /usr/include/*.h /usr/include/*/*.h + +showsetup: + @echo "PD_PATH: $(PD_PATH)" + @echo "objectsdir: $(objectsdir)" + @echo "LIBRARY_NAME: $(LIBRARY_NAME)" + @echo "LIBRARY_VERSION: $(LIBRARY_VERSION)" + @echo "SOURCES: $(SOURCES)" + @echo "PDOBJECTS: $(PDOBJECTS)" + @echo "ALLSOURCES: $(ALLSOURCES)" + @echo "UNAME: $(UNAME)" + @echo "CPU: $(CPU)" diff --git a/README b/README deleted file mode 100644 index 8c17464..0000000 --- a/README +++ /dev/null @@ -1,15 +0,0 @@ - -PurePd is a library of objects are written purely in Pd. The idea is to -replace standard externals with Pd objects so that Pd its more and more a -language written in Pd. - -WARNING! This library is a place for development of ideas. Anything is up for -change given a good reason. But be courteous: If you do change the interface -of an object in this collection, make sure that you print a warning to the Pd -window. - -If you want a static, unchanging interfaces, please include it elsewhere. If -you want a place to freely explore implementing things in Pd, please include -it in the purepd library. - - diff --git a/README.txt b/README.txt new file mode 100644 index 0000000..8c17464 --- /dev/null +++ b/README.txt @@ -0,0 +1,15 @@ + +PurePd is a library of objects are written purely in Pd. The idea is to +replace standard externals with Pd objects so that Pd its more and more a +language written in Pd. + +WARNING! This library is a place for development of ideas. Anything is up for +change given a good reason. But be courteous: If you do change the interface +of an object in this collection, make sure that you print a warning to the Pd +window. + +If you want a static, unchanging interfaces, please include it elsewhere. If +you want a place to freely explore implementing things in Pd, please include +it in the purepd library. + + diff --git a/alternate-help.pd b/alternate-help.pd new file mode 100644 index 0000000..0350367 --- /dev/null +++ b/alternate-help.pd @@ -0,0 +1,84 @@ +#N canvas 47 22 568 493 10; +#X obj 4 439 cnv 15 550 20 empty \$0-pddp.cnv.footer empty 20 12 0 +14 -228856 -66577 0; +#X obj 4 -17 cnv 15 550 40 empty \$0-pddp.cnv.header alternate 3 12 +0 18 -204280 -1 0; +#X obj 3 239 cnv 3 550 3 empty \$0-pddp.cnv.inlets inlet 15 12 0 13 +-228856 -1 0; +#N canvas 779 22 498 348 META 0; +#X text 12 65 TEMPLATE template-help.pd v0.1; +#X text 12 85 PLATFORM windows macosx gnulinux; +#X text 12 25 KEYWORDS control alternate; +#X text 12 45 LICENSE GPLv2 or later; +#X text 12 105 DATATYPE any message; +#X text 12 125 LIBRARY markex; +#X restore 504 441 pd META; +#X obj 3 299 cnv 3 550 3 empty \$0-pddp.cnv.outlets outlets 15 12 0 +13 -228856 -1 0; +#X obj 3 389 cnv 3 550 3 empty \$0-pddp.cnv.argument argument 15 12 +0 13 -228856 -1 0; +#N canvas 309 454 609 478 guts 0; +#X obj 117 95 textfile; +#X msg 116 24 symbol template-HCS.pd; +#X msg 116 54 read \$1 \, rewind \, bang; +#X obj 117 141 trigger bang anything; +#X obj 58 117 bang; +#X obj 240 162 route #X; +#X obj 240 183 route text; +#X obj 240 250 route DESCRIPTION; +#X obj 239 276 print; +#X obj 140 277 print TEXT; +#X connect 0 0 3 0; +#X connect 1 0 2 0; +#X connect 2 0 0 0; +#X connect 3 0 4 0; +#X connect 3 1 5 0; +#X connect 4 0 0 0; +#X connect 5 0 6 0; +#X connect 7 0 8 0; +#X restore 453 441 pd guts; +#X obj 488 -14 alternate; +#X obj 437 5 pddp/pddplink http://pdpedia.org/en/markex/alternate -text +pdpedia: alternate; +#X text 15 6 description: alternates messages between its two outlets +; +#X obj 74 351 cnv 17 3 25 empty \$0-pddp.cnv.let.0 1 5 9 0 16 -228856 +-162280 0; +#X obj 74 321 cnv 17 3 25 empty \$0-pddp.cnv.let.0 0 5 9 0 16 -228856 +-162280 0; +#X obj 315 152 cnv 10 57 16 empty \$0-pddp.cnv.highlight empty 20 12 +0 14 -262126 -66577 0; +#X obj 63 115 cnv 10 57 16 empty \$0-pddp.cnv.highlight empty 20 12 +0 14 -262126 -66577 0; +#X msg 309 56 1; +#X obj 315 152 alternate; +#X msg 262 55 bang; +#X msg 349 123 reset; +#X msg 342 56 symbol blah; +#X obj 366 174 pddp/print; +#X obj 315 201 pddp/print; +#X obj 63 115 alternate; +#X obj 63 143 bng 25 250 50 0 empty empty empty 0 -6 0 10 -262144 -1 +-1; +#X obj 114 143 bng 25 250 50 0 empty empty empty 0 -6 0 10 -262144 +-1 -1; +#X obj 63 80 bng 25 250 50 0 empty empty empty 0 -6 0 10 -204786 -1 +-1; +#X msg 352 83 1 2 3 4; +#X text 105 257 any message can be send to [alternate] \, it will just +pass it through to the outlets; +#X text 102 407 [alternate] ignores all arguments; +#X text 105 317 first message that was received on the inlet \, and +all following messages that are numbered odd in the sequence; +#X text 105 348 second message that was received on the inlet \, and +all following messages that are numbered even in the sequence; +#X connect 14 0 15 0; +#X connect 15 0 20 0; +#X connect 15 1 19 0; +#X connect 16 0 15 0; +#X connect 17 0 15 0; +#X connect 18 0 15 0; +#X connect 21 0 22 0; +#X connect 21 1 23 0; +#X connect 24 0 21 0; +#X connect 25 0 15 0; diff --git a/clip-help.pd b/clip-help.pd new file mode 100644 index 0000000..f1df628 --- /dev/null +++ b/clip-help.pd @@ -0,0 +1,106 @@ +#N canvas 3 22 569 590 10; +#X obj 114 540 pddp/pddplink http://puredata.info/dev/pddp -text pddp; +#X obj 8 3 cnv 15 90 578 empty empty empty 20 12 0 14 -233017 -66577 +0; +#X text 38 36 INLETS:; +#X text 38 51 - LEFT:; +#X text 32 230 - RIGHT:; +#X text 29 346 OUTLETS:; +#X text 13 281 ARGUMENTS:; +#X text 20 392 EXAMPLES:; +#X text 20 488 SEE ALSO:; +#N canvas 58 22 423 272 Related_Objects 0; +#X text 25 11 Native Pd Objects; +#X text 23 92 Externals and other object libraries; +#X obj 45 54 int; +#X obj 85 53 f; +#X obj 123 53 min; +#X obj 166 53 max; +#X obj 206 53 clip~; +#X obj 260 53 min~; +#X obj 308 53 max~; +#X text 44 125 - none that I am aware of; +#X restore 114 488 pd Related_Objects; +#N canvas 57 22 651 632 More_Info 0; +#X text 40 187 LOW AND HIGH VALUES; +#X text 304 34 Consider the following:; +#X floatatom 101 66 5 0 0 0 - - -; +#X floatatom 83 147 5 0 0 0 - - -; +#X obj 83 121 min 50; +#X obj 83 95 max -50; +#X text 170 106 same as; +#X obj 271 104 clip -50 50; +#X floatatom 271 133 5 0 0 0 - - -; +#X text 43 18 [clip] is a tool which combines the functionality of +[min] and [max] into a single object.; +#X text 56 208 [clip] always assumes that the first argument (second +inlet) is the low extreme of the range and the second argument (third +inlet) is the high extreme. However \, strange behaviour should be +expected if you mix these arguments up.; +#X obj 64 331 clip -50 50; +#X obj 190 325 clip 72 -104; +#X floatatom 64 298 5 0 0 0 - - -; +#X floatatom 64 360 5 0 0 0 - - -; +#X floatatom 190 357 5 0 0 0 - - -; +#X text 195 284 Numbers below 72 are clipped to 72; +#X text 195 304 Numbers above -104 are clipped to -104; +#X text 72 405 This could be used effectively to toggle between two +numbers.; +#X floatatom 401 383 5 0 0 0 - - -; +#X obj 370 360 tgl 15 0 empty empty empty 0 -6 0 8 -262144 -1 -1 0 +1; +#X obj 402 352 clip 1 -1024; +#X connect 2 0 5 0; +#X connect 2 0 7 0; +#X connect 4 0 3 0; +#X connect 5 0 4 0; +#X connect 7 0 8 0; +#X connect 11 0 14 0; +#X connect 12 0 15 0; +#X connect 13 0 11 0; +#X connect 13 0 12 0; +#X connect 20 0 21 0; +#X connect 21 0 19 0; +#X restore 114 514 pd More_Info; +#X obj 57 11 clip; +#X text 105 51 Float - A float at the left inlet will be clipped to +the low and high values stored in the object.; +#X text 105 82 List - A list at the left inlet will be truncated to +include only the first three elements. The first element in the list +is the number which will be clipped. The second element will update +the value stored at the second inlet. The third element will update +the value stored at the third inlet.; +#X text 25 180 - CENTER:; +#X text 105 180 Float - A float at the second inlet is stored for later +use. It will be used as either the low or high value at which to clip +incoming floats at that left inlet.; +#X text 105 231 Float - A float at the third inlet is stored for later +use. It will be used as either the low or high value at which to clip +incoming floats at that left inlet.; +#X text 104 281 Two - [float] accepts two floats as creation arguments +which initializes the first values to be stored in the object and duplicate +the functions of the second and third inlet.; +#X text 108 12 - FORCE A NUMBER INTO A RANGE; +#X obj 122 428 clip -50 50; +#X floatatom 122 455 5 0 0 0 - - -; +#X floatatom 122 404 5 0 0 0 - - -; +#X text 181 405 creation arguments; +#X obj 411 466 clip; +#X floatatom 410 437 5 0 0 0 - - -; +#X floatatom 460 437 5 0 0 0 - - -; +#X floatatom 510 437 5 0 0 0 - - -; +#X floatatom 411 492 5 0 0 0 - - -; +#X text 464 468 no arguments; +#X text 450 405 list; +#X text 158 541 - Dave Sabine \, April 25 \, 2003; +#X msg 373 405 42 100 500; +#X text 344 565 updated for Pd version 0.38-2; +#X text 102 346 One - outputs a float which is limited to a range within +the high and low values of the second and third inlet.; +#X connect 19 0 20 0; +#X connect 21 0 19 0; +#X connect 23 0 27 0; +#X connect 24 0 23 0; +#X connect 25 0 23 1; +#X connect 26 0 23 2; +#X connect 31 0 23 0; diff --git a/cosh-help.pd b/cosh-help.pd new file mode 100644 index 0000000..3f887f2 --- /dev/null +++ b/cosh-help.pd @@ -0,0 +1,19 @@ +#N canvas 217 155 421 323 10; +#X obj 4 4 cnv 15 400 40 empty empty empty 20 12 0 14 -262130 -66577 0; +#X text 21 278 docs based on the MAX/MSP reference (c) cycling'74 +; +#X text 20 292 ___________________________________________________ ; +#X floatatom 46 216 8 0 0 0 - - -; +#X msg 46 83 bang; +#X obj 67 152 / 100; +#X floatatom 67 132 5 0 0 0 - - -; +#X text 123 185 arg sets initial value; +#X obj 42 22 cosh 0.2; +#X text 108 24 calculate hyperbolic cosine function; +#X obj 46 183 cosh 0.2; +#X text 95 82 output cosh of current val; +#X text 121 130 calculate and output cosh; +#X connect 4 0 10 0; +#X connect 5 0 10 0; +#X connect 6 0 5 0; +#X connect 10 0 3 0; diff --git a/debian/changelog b/debian/changelog new file mode 100644 index 0000000..28325f5 --- /dev/null +++ b/debian/changelog @@ -0,0 +1,5 @@ +pd-purepd (0.1-1) unstable; urgency=low + + * Initial release (Closes: #nnnn) + + -- Hans-Christoph Steiner Thu, 21 Jan 2010 23:27:04 -0500 diff --git a/debian/compat b/debian/compat new file mode 100644 index 0000000..7f8f011 --- /dev/null +++ b/debian/compat @@ -0,0 +1 @@ +7 diff --git a/debian/control b/debian/control new file mode 100644 index 0000000..e57770e --- /dev/null +++ b/debian/control @@ -0,0 +1,15 @@ +Source: pd-purepd +Section: sound +Priority: optional +Maintainer: Paul Brossier +Build-Depends: debhelper (>= 7.0.50~), puredata (>= 0.42.5-3.1~) +Standards-Version: 3.8.3 +Homepage: http://puredata.info + +Package: pd-purepd +Architecture: any +Depends: ${shlibs:Depends}, ${misc:Depends}, pd +Description: a library of objects re-implemented using only Pd-vanilla + This is a library focused on re-implementing existing objects written in C + using only objects that are included in Pd-vanilla. The idea is to provide + drop-in replacements for the binary objects usable on any platform. diff --git a/debian/copyright b/debian/copyright new file mode 100644 index 0000000..ac31d2c --- /dev/null +++ b/debian/copyright @@ -0,0 +1,18 @@ +Debianized-By: Hans-Christoph Steiner +Debianized-Date: Tue, 9 Feb 2010 17:14:25 -0400 +Files: * +Copyright: 1997-1999, Miller Puckette + 1997-2002, Dieter Kovacic + 2003-2010, Free Software Foundation + 2004, Tim Blechmann + 2009, IOhannes m. zmoelnig + +License: GPL-2+ + This package 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 of the License, or + (at your option) any later version. + . + On Debian systems, the complete text of the GNU General Public License + version 2 can be found in file "/usr/share/common-licenses/GPL-2". + diff --git a/debian/rules b/debian/rules new file mode 100755 index 0000000..2876d32 --- /dev/null +++ b/debian/rules @@ -0,0 +1,16 @@ +#!/usr/bin/make -f + +LIBRARY_NAME = purepd +PACKAGE = pd-$(LIBRARY_NAME) +pkglibdir = /usr/lib/pd/extra + +%: + dh $@ + +override_dh_auto_install: + make DESTDIR=$(CURDIR)/debian/$(PACKAGE) pkglibdir=$(pkglibdir) install + +override_dh_shlibdeps: + dpkg-shlibdeps $(CURDIR)/debian/$(PACKAGE)$(pkglibdir)/$(LIBRARY_NAME)/*.pd_linux \ + -T$(CURDIR)/debian/$(PACKAGE).substvars + diff --git a/delta-help.pd b/delta-help.pd new file mode 100644 index 0000000..fa865e3 --- /dev/null +++ b/delta-help.pd @@ -0,0 +1,20 @@ +#N canvas 328 264 466 318 12; +#X floatatom 54 217 5 0 0; +#X floatatom 54 108 5 0 0; +#X msg 23 83 bang; +#X text 69 82 calculate and output result now; +#X obj 54 172 delta; +#X obj 54 133 * 3; +#X floatatom 127 218 5 0 0; +#X floatatom 127 109 5 0 0; +#X obj 127 134 * 3; +#X obj 127 173 delta 2; +#X text 53 259 use creation arguments to set order (1st or 2nd); +#X text 39 20 delta :: calculate 1st or 2nd order difference; +#X connect 1 0 5 0; +#X connect 2 0 4 0; +#X connect 4 0 0 0; +#X connect 5 0 4 0; +#X connect 7 0 8 0; +#X connect 8 0 9 0; +#X connect 9 0 6 0; diff --git a/inv-help.pd b/inv-help.pd new file mode 100644 index 0000000..69f0d2d --- /dev/null +++ b/inv-help.pd @@ -0,0 +1,10 @@ +#N canvas 141 276 450 300 10; +#X obj 165 115 inv; +#X floatatom 165 164 5 0 0 0 - - -; +#X text 41 32 perform 1/x using float from inlet; +#X obj 166 77 hsl 128 15 0 127 0 0 empty empty empty -2 -8 0 10 -262144 +-1 -1 1500 1; +#X msg 126 77 5; +#X connect 0 0 1 0; +#X connect 3 0 0 0; +#X connect 4 0 0 0; diff --git a/moses-help.pd b/moses-help.pd new file mode 100644 index 0000000..c1f23c9 --- /dev/null +++ b/moses-help.pd @@ -0,0 +1,17 @@ +#N canvas 0 0 624 300 12; +#X obj 72 196 moses 10; +#X floatatom 72 164 4 0 0; +#X floatatom 139 167 4 0 0; +#X floatatom 72 229 4 0 0; +#X floatatom 139 230 4 0 0; +#X obj 63 24 moses; +#X text 118 23 - part a stream of numbers; +#X text 303 235 updated for Pd version 0.33; +#X text 24 64 Moses takes numbers and outputs them at left if they're +less than a control value \, and at right if they're greater or equal +to it. The creation argument initializes the control value (10 in this +example) and the right inlet changes it.; +#X connect 0 0 3 0; +#X connect 0 1 4 0; +#X connect 1 0 0 0; +#X connect 2 0 0 1; diff --git a/once-help.pd b/once-help.pd new file mode 100644 index 0000000..bec086c --- /dev/null +++ b/once-help.pd @@ -0,0 +1,36 @@ +#N canvas 231 172 401 466 10; +#X obj 66 326 print; +#X msg 66 133 1; +#X obj 301 113 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262144 -1 +-1; +#X obj 66 112 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262144 -1 +-1; +#X msg 66 197 11 22; +#X msg 66 153 symbol foo; +#X msg 66 175 set; +#X msg 66 218 list aaa 123; +#X msg 66 241 jkl 555 uuu; +#X obj 66 272 once; +#X text 13 7 once; +#X text 69 6 only the first message passes through; +#X text 48 86 message in; +#X text 80 292 message out (only once); +#X text 239 92 anything to init once; +#X text 115 408 IEM KUG; +#X text 99 396 musil; +#X text 129 396 @; +#X text 135 396 iem.at; +#X text 50 385 (c) Thomas Musil 2000 - 2005; +#X text 98 418 Graz \, Austria; +#X text 122 372 @; +#X text 128 372 iem.at; +#X text 50 372 (c) zmoelnig; +#X connect 1 0 9 0; +#X connect 2 0 9 1; +#X connect 3 0 9 0; +#X connect 4 0 9 0; +#X connect 5 0 9 0; +#X connect 6 0 9 0; +#X connect 7 0 9 0; +#X connect 8 0 9 0; +#X connect 9 0 0 0; diff --git a/oneshot-help.pd b/oneshot-help.pd new file mode 100644 index 0000000..f976360 --- /dev/null +++ b/oneshot-help.pd @@ -0,0 +1,11 @@ +#N canvas 151 485 600 500 10; +#X text 124 68 GEM object; +#X obj 123 298 print out1; +#X msg 123 155 bang; +#X text 138 23 oneshot; +#X obj 123 219 oneshot; +#X msg 188 154 clear; +#X text 61 385 oneshot blocks after the initial bang \, until a clear message is received.; +#X connect 2 0 4 0; +#X connect 4 0 1 0; +#X connect 5 0 4 0; diff --git a/purepd-meta.pd b/purepd-meta.pd index 43ff249..e58e01c 100644 --- a/purepd-meta.pd +++ b/purepd-meta.pd @@ -4,4 +4,5 @@ #X text 10 30 NAME purepd; #X text 10 50 LICENSE GNU GPL; #X text 10 70 DESCRIPTION existing objects reimplemented in Pd; +#X text 10 90 VERSION 0.1; #X restore 10 10 pd META; diff --git a/sinh-help.pd b/sinh-help.pd new file mode 100644 index 0000000..c758596 --- /dev/null +++ b/sinh-help.pd @@ -0,0 +1,19 @@ +#N canvas 217 155 421 323 10; +#X obj 4 4 cnv 15 400 40 empty empty empty 20 12 0 14 -262130 -66577 0; +#X text 21 278 docs based on the MAX/MSP reference (c) cycling'74 +; +#X text 20 292 ___________________________________________________ ; +#X floatatom 46 216 8 0 0 0 - - -; +#X msg 46 83 bang; +#X obj 67 152 / 100; +#X floatatom 67 132 5 0 0 0 - - -; +#X text 123 185 arg sets initial value; +#X text 121 130 calculate and output cosh; +#X obj 42 22 sinh 0.2; +#X text 108 25 calculate hyperbolic sine function; +#X obj 46 183 sinh 0.2; +#X text 95 82 output sinh of current val; +#X connect 4 0 11 0; +#X connect 5 0 11 0; +#X connect 6 0 5 0; +#X connect 11 0 3 0; diff --git a/tanh-help.pd b/tanh-help.pd new file mode 100644 index 0000000..c96d1b5 --- /dev/null +++ b/tanh-help.pd @@ -0,0 +1,19 @@ +#N canvas 217 155 421 323 10; +#X obj 4 4 cnv 15 400 40 empty empty empty 20 12 0 14 -262130 -66577 0; +#X text 21 278 docs based on the MAX/MSP reference (c) cycling'74 +; +#X text 20 292 ___________________________________________________ ; +#X floatatom 46 216 8 0 0 0 - - -; +#X msg 46 83 bang; +#X obj 67 152 / 100; +#X floatatom 67 132 5 0 0 0 - - -; +#X text 123 185 arg sets initial value; +#X obj 42 22 tanh 0.2; +#X text 95 82 output tanh of current val; +#X text 121 130 calculate and output tanh; +#X obj 46 183 tanh 0.2; +#X text 108 25 calculate hyperbolic tangent function; +#X connect 4 0 11 0; +#X connect 5 0 11 0; +#X connect 6 0 5 0; +#X connect 11 0 3 0; diff --git a/velocity-help.pd b/velocity-help.pd new file mode 100644 index 0000000..38f8f0c --- /dev/null +++ b/velocity-help.pd @@ -0,0 +1,14 @@ +#N canvas 239 183 454 304 12; +#X text 30 16 velocity :: get velocity of digits per second; +#X obj 50 137 velocity; +#X floatatom 50 72 5 0 0; +#X floatatom 50 187 8 0 0; +#X text 150 77 sending a float every second would; +#X text 151 95 result in a velocity of 1 \, higher; +#X text 151 114 rates produce higher velocities; +#X msg 65 102 bang; +#X text 151 148 originally written for Max by; +#X text 151 164 Trond Lossius \, BEK; +#X connect 1 0 3 0; +#X connect 2 0 1 0; +#X connect 7 0 1 0; -- cgit v1.2.1