aboutsummaryrefslogtreecommitdiff
path: root/externals
diff options
context:
space:
mode:
Diffstat (limited to 'externals')
-rw-r--r--externals/grill/dynext/dynext.vcproj3
-rwxr-xr-xexternals/grill/dynext/readme.txt2
-rw-r--r--externals/grill/dynext/src/main.cpp14
3 files changed, 12 insertions, 7 deletions
diff --git a/externals/grill/dynext/dynext.vcproj b/externals/grill/dynext/dynext.vcproj
index b0346f05..9b1e7eb4 100644
--- a/externals/grill/dynext/dynext.vcproj
+++ b/externals/grill/dynext/dynext.vcproj
@@ -217,9 +217,6 @@
Name="doc"
Filter="">
<File
- RelativePath="make-files.txt">
- </File>
- <File
RelativePath="readme.txt">
</File>
</Filter>
diff --git a/externals/grill/dynext/readme.txt b/externals/grill/dynext/readme.txt
index 9ebae392..213487dc 100755
--- a/externals/grill/dynext/readme.txt
+++ b/externals/grill/dynext/readme.txt
@@ -26,7 +26,7 @@ CHANGES:
0.1.1:
- using aligned memory
- cached several symbols
-- strip .pd extension from abstraction filenames
+- strip .pd extension from abstraction filenames (if stripext attribute is set)
- debug patcher opens on alt-click
0.1.0:
diff --git a/externals/grill/dynext/src/main.cpp b/externals/grill/dynext/src/main.cpp
index 07b3b5e4..362963c5 100644
--- a/externals/grill/dynext/src/main.cpp
+++ b/externals/grill/dynext/src/main.cpp
@@ -11,6 +11,8 @@ WARRANTIES, see the file, "license.txt," in this distribution.
*/
+#define FLEXT_ATTRIBUTES 1
+
#include <flext.h>
#if !defined(FLEXT_VERSION) || (FLEXT_VERSION < 500)
@@ -154,6 +156,7 @@ protected:
int m_inlets,s_inlets,m_outlets,s_outlets;
t_canvas *canvas;
+ bool stripext;
private:
static void setup(t_classid c);
@@ -169,6 +172,8 @@ private:
FLEXT_CALLBACK_V(m_send)
FLEXT_CALLBACK_B(m_vis)
+ FLEXT_ATTRVAR_B(stripext)
+
static const t_symbol *sym_dot,*sym_dynsin,*sym_dynsout,*sym_dynin,*sym_dynout,*sym_dyncanvas;
static const t_symbol *sym_vis,*sym_loadbang,*sym_dsp;
};
@@ -239,6 +244,8 @@ void dyn::setup(t_classid c)
FLEXT_CADDMETHOD_(c,0,"send",m_send);
FLEXT_CADDMETHOD_(c,0,"vis",m_vis);
+ FLEXT_CADDATTR_VAR1(c,"stripext",stripext);
+
// set up symbols
k_obj = MakeSymbol("obj");
k_msg = MakeSymbol("msg");
@@ -285,7 +292,8 @@ In all cases the 1)s have been chosen as the cleaner solution
dyn::dyn(int argc,const t_atom *argv):
root(NULL),
canvas(NULL),
- pxin(NULL),pxout(NULL)
+ pxin(NULL),pxout(NULL),
+ stripext(false)
{
if(argc < 4) {
post("%s - Syntax: dyn~ sig-ins msg-ins sig-outs msg-outs",thisName());
@@ -458,7 +466,7 @@ t_gobj *dyn::New(const t_symbol *kind,int _argc_,const t_atom *_argv_,bool add)
err = "Canvas could not be found";
else {
// convert abstraction filenames
- if(kind == k_obj && argc >= 3 && IsSymbol(argv[2])) {
+ if(stripext && kind == k_obj && argc >= 3 && IsSymbol(argv[2])) {
const char *c = GetString(argv[2]);
int l = strlen(c);
// check end of string for .pd file extension
@@ -472,7 +480,7 @@ t_gobj *dyn::New(const t_symbol *kind,int _argc_,const t_atom *_argv_,bool add)
}
}
- // set selected canvas as current
+ // set selected canvas as current
canvas_setcurrent(glist);
t_gobj *last = GetLast(glist);