diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/pdlua-help.pd | 422 |
1 files changed, 209 insertions, 213 deletions
diff --git a/src/pdlua-help.pd b/src/pdlua-help.pd index 53a83a2..7824b68 100644 --- a/src/pdlua-help.pd +++ b/src/pdlua-help.pd @@ -1,213 +1,209 @@ -#N canvas 626 402 534 259 10;
-#X declare -stdpath doc/examples/pdlua;
-#X msg 44 58;
-#X text 70 57 << more methods will come (maybe);
-#X text 53 99 << global interface to pdlua;
-#X text 113 20 << load and run a Lua file (searches Pd's path);
-#X msg 17 21 load hello.lua;
-#X text 17 191 See also:;
-#X obj 37 216 hello;
-#X text 15 135 Side-effects:;
-#X obj 17 101 pdlua;
-#X obj 87 216 pdluax hello;
-#X text 29 157 [pdlua] registers a loader that allows Pd classes written
-in Lua to be loaded.;
-#X obj 282 108 declare -stdpath doc/examples/pdlua;
-#N canvas 14 464 573 837 pdlua_HOWTO 0;
-#X obj 13 3 cnv 15 400 140 empty empty pdlua_HOWTO 20 12 0 14 -135137
--66577 0;
-#X obj 13 144 cnv 15 400 160 empty empty Class_Creation 20 12 0 14
--203904 -66577 0;
-#X obj 13 305 cnv 15 400 300 empty empty Object_Initialization 20 12
-0 14 -261234 -66577 0;
-#X obj 13 606 cnv 15 400 120 empty empty empty 20 12 0 14 -135137 -66577
-0;
-#X obj 13 727 cnv 15 400 170 empty empty empty 20 12 0 14 -203904 -66577
-0;
-#X obj 13 1601 cnv 15 400 100 empty empty Sending_To_Receivers 20 12
-0 14 -261234 -66577 0;
-#X obj 13 1702 cnv 15 400 120 empty empty Receivers 20 12 0 14 -135137
--66577 0;
-#X text 31 28 The Lua loader included in -lib pdlua allows externals
-for Pd to be written in the Lua programming language. (http://www.lua.org/)
-;
-#X text 31 70 If you try to create an object [foo] in Pd \, Pd checks
-if the class "foo" exists. If it doesn't \, it tries to load an external
-file that "probably" will contain code for "foo". The Lua loader adds
-support for loading "foo.pd_lua" when you try to create [foo].;
-#X obj 13 898 cnv 15 400 70 empty empty Object_Finalization 20 12 0
-14 -261234 -66577 0;
-#X text 31 216 This creates a new Pd class called "foo". The 'local'
-declaration is optional \, but recommended -- without it \, 'foo' is
-global \, which means any Lua code can modify it (possibly by accident).
-;
-#X text 31 164 The first expression/statement in the text file "foo.pd_lua"
-should be of the form:;
-#X obj 13 969 cnv 15 400 400 empty empty Inlet_Methods 20 12 0 14 -135137
--66577 0;
-#X text 31 418 or equivalently:;
-#X obj 13 1370 cnv 15 400 230 empty empty Sending_To_Outlets 20 12
-0 14 -203904 -66577 0;
-#X text 31 326 Then you can add methods to the Pd class. The most important
-one is 'initialize' \, which is executed when a new object is created:
-;
-#X text 47 514 [foo a b 1 2 3 c];
-#X text 31 485 'sel' is usually (always?) the class name \, 'atoms'
-are the creation arguments in a Lua table. For example a Pd object
-;
-#X text 32 532 would have sel equal to "foo" and the atoms:;
-#X text 31 605 Being a method \, 'initialize' has a 'self' variable
-(which is the object to be created) \, and if you want your objects
-to have inlets or outlets you need need to set those fields in this
-method (Pd doesn't support changing the number of inlets or outlets
-after an object is created):;
-#X text 31 699 The default inlet/outlet counts are 0;
-#X text 31 732 The return value of 'initialize' is used to allow objects
-to fail to create (for example \, if the creation arguments are bad).
-Most of the time you will 'return true' \, but if you really can't
-create then you can 'return false'.;
-#X text 31 920 The 'finalize' method is called when the object is deleted
-by Pd. You can clean up stuff here if needed. The default implementation
-does nothing.;
-#X text 31 1620 You can send messages to receivers like this:;
-#X text 31 567 where <> should be curly brackets \, but Pd won't print
-them in a comment.;
-#X text 30 1661 (again the <> represent curly brackets);
-#X text 32 1782 Remember to clean up your receivers in object:finalize()
-\, or weird things will happen.;
-#X obj 13 1823 cnv 15 400 120 empty empty Clocks 20 12 0 14 -203904
--66577 0;
-#X obj 13 1944 cnv 15 400 120 empty empty Miscellaneous_Object_Methods
-20 12 0 14 -261234 -66577 0;
-#X text 32 1843 You can bind methods to clocks \, for timing based
-on Pd's logical clock.;
-#X text 32 1886 Remember to clean up your clocks in object:finalize()
-\, or weird things will happen.;
-#X text 31 1964 Execute a Lua file using Pd's path to find it:;
-#X text 31 2001 Report an error to Pd's console:;
-#X obj 13 2065 cnv 15 400 120 empty empty Miscellaneous_Functions 20
-12 0 14 -135137 -66577 0;
-#X text 31 2088 Print a string to Pd's console:;
-#X text 31 2124 Note that pd.post() should not really be used for errors.
-;
-#X text 31 2145 FIXME: add pd.error() for error messages;
-#X obj 9 2198 pdlua;
-#X obj 9 6 bng 15 250 50 0 empty empty empty 17 7 0 10 -262144 -1 -1
-;
-#X text 31 1724 You can bind methods to receivers \, to get messages
-from [send receiver] and " \; receiver message".;
-#X obj 389 1900 bng 15 250 50 0 empty empty empty 17 7 0 10 -13381
--4034 -1;
-#X obj 48 195 cnv 15 300 20 empty empty empty 20 12 0 14 -204786 -66577
-0;
-#X text 57 197 local foo = pd.Class:new():register("foo");
-#X obj 48 368 cnv 15 300 50 empty empty empty 20 12 0 14 -204786 -66577
-0;
-#X obj 48 437 cnv 15 300 50 empty empty empty 20 12 0 14 -204786 -66577
-0;
-#X text 55 367 function foo:initialize(sel \, atoms);
-#X text 56 380 -- code;
-#X text 56 394 end;
-#X text 56 436 foo.initialize = function (self \, sel \, atoms);
-#X text 55 450 -- code;
-#X text 56 463 end;
-#X obj 48 844 cnv 15 300 50 empty empty empty 20 12 0 14 -204786 -66577
-0;
-#X obj 48 666 cnv 15 300 30 empty empty empty 20 12 0 14 -204786 -66577
-0;
-#X text 48 551 <"a" \, "b" \, 1 \, 2 \, 3 \, "c">;
-#X text 56 664 self.inlets = 1;
-#X text 56 680 self.outlets = atoms[1];
-#X text 55 843 function foo:postinitialize();
-#X text 55 857 -- code;
-#X text 56 872 end;
-#X obj 48 1982 cnv 15 300 20 empty empty empty 20 12 0 14 -204786 -66577
-0;
-#X obj 48 2025 cnv 15 300 20 empty empty empty 20 12 0 14 -204786 -66577
-0;
-#X obj 48 2105 cnv 15 300 20 empty empty empty 20 12 0 14 -204786 -66577
-0;
-#X text 56 1982 self:dofile("filename");
-#X text 56 2025 self:error("message");
-#X text 56 2105 pd.post("a string");
-#X obj 389 1663 bng 15 250 50 0 empty empty empty 17 7 0 10 -4034 -257985
--1;
-#X floatatom 512 1789 5 0 0 0 - - -;
-#X msg 424 1614 1000;
-#X msg 462 1614 100;
-#X text 32 1761 See doc/examples/lreceive.pd_lua for details.;
-#X text 32 1682 See doc/examples/lsend.pd_lua for details.;
-#X text 32 1871 See doc/examples/ldelay.pd_lua for details.;
-#X obj 389 1685 lsend splat-1;
-#X obj 424 1667 lsend splat-2;
-#X obj 389 1760 lreceive splat- 1 2 3;
-#X obj 389 1870 ldelay 1000;
-#X text 75 2183 modified from doc/examples/pdlua/lua.txt;
-#X text 75 2196 by mrpeach 2011/10/05;
-#X text 31 994 Each inlet should have at least one method that will
-be called when an item it can handle arrives at that input.;
-#X obj 48 1080 cnv 15 300 50 empty empty empty 20 12 0 14 -204786 -66577
-0;
-#X text 55 1084 function foo:in_1_float(f);
-#X text 54 1097 -- code;
-#X text 56 1110 end;
-#X obj 48 1153 cnv 15 300 50 empty empty empty 20 12 0 14 -204786 -66577
-0;
-#X text 54 1170 -- code;
-#X text 56 1183 end;
-#X obj 48 1227 cnv 15 300 50 empty empty empty 20 12 0 14 -204786 -66577
-0;
-#X text 54 1244 -- code;
-#X text 56 1257 end;
-#X text 32 1206 A "gimme" method for [foo] accepts any input:;
-#X text 55 1231 function foo:in_1(sel \, atoms);
-#X obj 44 712 bng 15 250 50 0 empty empty empty 17 7 0 10 -262144 -1
--1;
-#X obj 44 1716 tgl 15 0 empty empty empty 17 7 0 10 -262144 -1 -1 0
-1;
-#X text 31 1455;
-#X obj 48 1428 cnv 15 300 20 empty empty empty 20 12 0 14 -204786 -66577
-0;
-#X text 55 1432 self:outlet(2 \, "bang" \, <>);
-#X text 29 1451 (as usual <> should be curly brackets);
-#X text 31 1403 This will cause the second outlet to emit a bang:;
-#X obj 48 1498 cnv 15 300 20 empty empty empty 20 12 0 14 -204786 -66577
-0;
-#X text 31 1473 This will cause the second outlet to emit a float:
-;
-#X text 55 1502 self:outlet(2 \, "float" \, <123>);
-#X obj 48 1548 cnv 15 300 40 empty empty empty 20 12 0 14 -204786 -66577
-0;
-#X text 31 1523 This will cause the first outlet to emit a list:;
-#X text 55 1569 self:outlet(1 \, "list" \, somelist);
-#X text 55 1552 self.somelist = <some items in a list>;
-#X text 32 1132 A "stop" method for inlet 2 of [foo]:;
-#X text 55 1157 function foo:in_2_stop();
-#X text 31 1024 The name of the method is constructed as "in_n_selector"
-where n is the inlet number (starting from 1) and selector is a type
-such as "float" or "bang" \, or a selector name such as "start". Here
-is a float method for [foo] inlet 1:;
-#X obj 48 1639 cnv 15 360 20 empty empty empty 20 12 0 14 -204786 -66577
-0;
-#X text 55 1639 pd.send("receiver" \, "selector" \, <"a" \, "message"
-\, 1 \, 2 \, 3>;
-#X obj 48 1301 cnv 15 300 50 empty empty empty 20 12 0 14 -204786 -66577
-0;
-#X text 54 1318 -- code;
-#X text 56 1331 end;
-#X text 32 1280 A method for symbols on any input:;
-#X text 55 1305 function foo:in_n_symbol(i \, s);
-#X text 31 786 If you need to do things after the Pd object is created
-\, but before control is returned to Pd \, (such as registering receivers
-or clocks) you can use the 'postinitialize' method:;
-#X connect 38 0 37 0;
-#X connect 65 0 72 0;
-#X connect 67 0 73 0;
-#X connect 68 0 73 0;
-#X connect 74 0 75 0;
-#X connect 74 1 66 0;
-#X connect 75 0 40 0;
-#X connect 91 0 92 0;
-#X restore 282 90 pd pdlua_HOWTO;
-#X connect 0 0 8 0;
-#X connect 4 0 8 0;
+#N canvas 574 199 637 279 10; +#X declare -stdpath doc/examples/pdlua; +#X declare -stdpath extra/pdlua/examples; +#X msg 44 58; +#X text 70 57 << more methods will come (maybe); +#X text 53 99 << global interface to pdlua; +#X text 113 20 << load and run a Lua file (searches Pd's path); +#X msg 17 21 load hello.lua; +#X text 17 191 See also:; +#X obj 37 216 hello; +#X text 15 135 Side-effects:; +#X obj 17 101 pdlua; +#X obj 87 216 pdluax hello; +#X text 29 157 [pdlua] registers a loader that allows Pd classes written +in Lua to be loaded.; +#X obj 282 109 declare -stdpath doc/examples/pdlua; +#N canvas 177 101 621 402 pdlua_HOWTO 0; +#X obj 13 3 cnv 15 500 140 empty empty pdlua_HOWTO 20 12 0 14 -135137 +-66577 0; +#X obj 13 144 cnv 15 500 160 empty empty Class_Creation 20 12 0 14 +-203904 -66577 0; +#X obj 13 305 cnv 15 500 300 empty empty Object_Initialization 20 12 +0 14 -261234 -66577 0; +#X obj 13 606 cnv 15 500 120 empty empty empty 20 12 0 14 -135137 -66577 +0; +#X obj 13 727 cnv 15 500 170 empty empty empty 20 12 0 14 -203904 -66577 +0; +#X obj 13 1601 cnv 15 500 100 empty empty Sending_To_Receivers 20 12 +0 14 -261234 -66577 0; +#X obj 13 1702 cnv 15 500 120 empty empty Receivers 20 12 0 14 -135137 +-66577 0; +#X text 31 28 The Lua loader included in -lib pdlua allows externals +for Pd to be written in the Lua programming language. (http://www.lua.org/) +; +#X text 31 70 If you try to create an object [foo] in Pd \, Pd checks +if the class "foo" exists. If it doesn't \, it tries to load an external +file that "probably" will contain code for "foo". The Lua loader adds +support for loading "foo.pd_lua" when you try to create [foo].; +#X obj 13 898 cnv 15 500 70 empty empty Object_Finalization 20 12 0 +14 -261234 -66577 0; +#X text 31 216 This creates a new Pd class called "foo". The 'local' +declaration is optional \, but recommended -- without it \, 'foo' is +global \, which means any Lua code can modify it (possibly by accident). +; +#X text 31 164 The first expression/statement in the text file "foo.pd_lua" +should be of the form:; +#X obj 13 969 cnv 15 500 400 empty empty Inlet_Methods 20 12 0 14 -135137 +-66577 0; +#X text 31 418 or equivalently:; +#X obj 13 1370 cnv 15 500 230 empty empty Sending_To_Outlets 20 12 +0 14 -203904 -66577 0; +#X text 31 326 Then you can add methods to the Pd class. The most important +one is 'initialize' \, which is executed when a new object is created: +; +#X text 47 514 [foo a b 1 2 3 c]; +#X text 31 485 'sel' is usually (always?) the class name \, 'atoms' +are the creation arguments in a Lua table. For example a Pd object +; +#X text 32 532 would have sel equal to "foo" and the atoms:; +#X text 31 605 Being a method \, 'initialize' has a 'self' variable +(which is the object to be created) \, and if you want your objects +to have inlets or outlets you need need to set those fields in this +method (Pd doesn't support changing the number of inlets or outlets +after an object is created):; +#X text 31 712 The default inlet/outlet counts are 0; +#X text 31 732 The return value of 'initialize' is used to allow objects +to fail to create (for example \, if the creation arguments are bad). +Most of the time you will 'return true' \, but if you really can't +create then you can 'return false'.; +#X text 31 920 The 'finalize' method is called when the object is deleted +by Pd. You can clean up stuff here if needed. The default implementation +does nothing.; +#X text 31 1620 You can send messages to receivers like this:; +#X text 31 567 where <> should be curly brackets \, but Pd won't print +them in a comment.; +#X text 30 1661 (again the <> represent curly brackets); +#X text 32 1782 Remember to clean up your receivers in object:finalize() +\, or weird things will happen.; +#X obj 13 1823 cnv 15 500 120 empty empty Clocks 20 12 0 14 -203904 +-66577 0; +#X obj 13 1944 cnv 15 500 120 empty empty Miscellaneous_Object_Methods +20 12 0 14 -261234 -66577 0; +#X text 32 1843 You can bind methods to clocks \, for timing based +on Pd's logical clock.; +#X text 32 1886 Remember to clean up your clocks in object:finalize() +\, or weird things will happen.; +#X text 31 1964 Execute a Lua file using Pd's path to find it:; +#X text 31 2001 Report an error to Pd's console:; +#X obj 13 2065 cnv 15 500 120 empty empty Miscellaneous_Functions 20 +12 0 14 -135137 -66577 0; +#X text 31 2088 Print a string to Pd's console:; +#X text 31 2124 Note that pd.post() should not really be used for errors. +; +#X text 31 2145 FIXME: add pd.error() for error messages; +#X obj 9 2198 pdlua; +#X obj 9 30 bng 15 250 50 0 empty empty empty 17 7 0 10 -262144 -1 +-1; +#X text 31 1724 You can bind methods to receivers \, to get messages +from [send receiver] and " \; receiver message".; +#X obj 479 1900 bng 15 250 50 0 empty empty empty 17 7 0 10 -13381 +-4034 -1; +#X obj 48 195 cnv 15 400 20 empty empty empty 20 12 0 14 -204786 -66577 +0; +#X text 57 197 local foo = pd.Class:new():register("foo"); +#X obj 48 368 cnv 15 400 50 empty empty empty 20 12 0 14 -204786 -66577 +0; +#X obj 48 437 cnv 15 400 50 empty empty empty 20 12 0 14 -204786 -66577 +0; +#X text 55 367 function foo:initialize(sel \, atoms); +#X text 56 380 -- code; +#X text 56 394 end; +#X text 56 436 foo.initialize = function (self \, sel \, atoms); +#X text 55 450 -- code; +#X text 56 463 end; +#X obj 48 844 cnv 15 400 50 empty empty empty 20 12 0 14 -204786 -66577 +0; +#X obj 48 679 cnv 15 400 30 empty empty empty 20 12 0 14 -204786 -66577 +0; +#X text 48 551 <"a" \, "b" \, 1 \, 2 \, 3 \, "c">; +#X text 56 677 self.inlets = 1; +#X text 56 693 self.outlets = atoms[1]; +#X text 55 843 function foo:postinitialize(); +#X text 55 857 -- code; +#X text 56 872 end; +#X obj 48 1982 cnv 15 400 20 empty empty empty 20 12 0 14 -204786 -66577 +0; +#X obj 48 2025 cnv 15 400 20 empty empty empty 20 12 0 14 -204786 -66577 +0; +#X obj 48 2105 cnv 15 400 20 empty empty empty 20 12 0 14 -204786 -66577 +0; +#X text 56 1982 self:dofile("filename"); +#X text 56 2025 self:error("message"); +#X text 56 2105 pd.post("a string"); +#X obj 479 1663 bng 15 250 50 0 empty empty empty 17 7 0 10 -4034 -257985 +-1; +#X floatatom 602 1789 5 0 0 0 - - -; +#X msg 514 1614 1000; +#X msg 552 1614 100; +#X text 32 1761 See doc/examples/lreceive.pd_lua for details.; +#X text 32 1682 See doc/examples/lsend.pd_lua for details.; +#X text 32 1871 See doc/examples/ldelay.pd_lua for details.; +#X obj 479 1685 lsend splat-1; +#X obj 514 1667 lsend splat-2; +#X obj 479 1760 lreceive splat- 1 2 3; +#X obj 479 1870 ldelay 1000; +#X text 75 2183 modified from doc/examples/pdlua/lua.txt; +#X text 75 2196 by mrpeach 2011/10/05; +#X text 31 994 Each inlet should have at least one method that will +be called when an item it can handle arrives at that input.; +#X obj 48 1080 cnv 15 400 50 empty empty empty 20 12 0 14 -204786 -66577 +0; +#X text 55 1084 function foo:in_1_float(f); +#X text 54 1097 -- code; +#X text 56 1110 end; +#X obj 48 1153 cnv 15 400 50 empty empty empty 20 12 0 14 -204786 -66577 +0; +#X text 54 1170 -- code; +#X text 56 1183 end; +#X obj 48 1227 cnv 15 400 50 empty empty empty 20 12 0 14 -204786 -66577 +0; +#X text 54 1244 -- code; +#X text 56 1257 end; +#X text 32 1206 A "gimme" method for [foo] accepts any input:; +#X text 55 1231 function foo:in_1(sel \, atoms); +#X obj 48 1428 cnv 15 400 20 empty empty empty 20 12 0 14 -204786 -66577 +0; +#X text 55 1432 self:outlet(2 \, "bang" \, <>); +#X text 29 1451 (as usual <> should be curly brackets); +#X text 31 1403 This will cause the second outlet to emit a bang:; +#X obj 48 1498 cnv 15 400 20 empty empty empty 20 12 0 14 -204786 -66577 +0; +#X text 31 1473 This will cause the second outlet to emit a float: +; +#X text 55 1502 self:outlet(2 \, "float" \, <123>); +#X obj 48 1548 cnv 15 400 40 empty empty empty 20 12 0 14 -204786 -66577 +0; +#X text 31 1523 This will cause the first outlet to emit a list:; +#X text 55 1569 self:outlet(1 \, "list" \, somelist); +#X text 55 1552 self.somelist = <some items in a list>; +#X text 32 1132 A "stop" method for inlet 2 of [foo]:; +#X text 55 1157 function foo:in_2_stop(); +#X text 31 1024 The name of the method is constructed as "in_n_selector" +where n is the inlet number (starting from 1) and selector is a type +such as "float" or "bang" \, or a selector name such as "start". Here +is a float method for [foo] inlet 1:; +#X obj 48 1639 cnv 15 460 20 empty empty empty 20 12 0 14 -204786 -66577 +0; +#X text 55 1639 pd.send("receiver" \, "selector" \, <"a" \, "message" +\, 1 \, 2 \, 3>; +#X obj 48 1301 cnv 15 400 50 empty empty empty 20 12 0 14 -204786 -66577 +0; +#X text 54 1318 -- code; +#X text 56 1331 end; +#X text 32 1280 A method for symbols on any input:; +#X text 55 1305 function foo:in_n_symbol(i \, s); +#X text 31 786 If you need to do things after the Pd object is created +\, but before control is returned to Pd \, (such as registering receivers +or clocks) you can use the 'postinitialize' method:; +#X connect 38 0 37 0; +#X connect 65 0 72 0; +#X connect 67 0 73 0; +#X connect 68 0 73 0; +#X connect 74 0 75 0; +#X connect 74 1 66 0; +#X connect 75 0 40 0; +#X restore 282 90 pd pdlua_HOWTO; +#X obj 282 129 declare -stdpath extra/pdlua/examples; +#X connect 0 0 8 0; +#X connect 4 0 8 0; |