[prev in list] [next in list] [prev in thread] [next in thread] 

List:       vtk-developers
Subject:    Re: [vtk-developers] Proposing vtkObjectMacro
From:       Bill Lorensen <bill.lorensen () gmail ! com>
Date:       2012-09-13 19:22:35
Message-ID: CADZJ4hPmnVGQ_cO7gMd11HCH+F_0Vo-6VuHYiv0B0uWp-vFnPg () mail ! gmail ! com
[Download RAW message or body]

[Attachment #2 (multipart/alternative)]


Since it is a real pain when vtkSetGet.h is changed (at least for old guys
with slow machines),  why not add vtkAbstractClassMacro now?

On Thu, Sep 13, 2012 at 3:12 PM, Kyle Lutz <kyle.lutz@kitware.com> wrote:

> Thanks all for the input.
>
> For now I'd like to keep the discussion targeted at vtkClassMacro(). A
> macro for abstract classes (which VTK has far fewer of) could be added
> later if vtkClassMacro() proves useful. Furthermore, I don't really
> think using a vtkDisableCopy() type macro is the proper way to
> prohibit copying of VTK classes. vtkObjectBase should just declare its
> copy constructor and assignment operator as private a la
> boost::noncopyable (but this is a larger change than I feel
> comfortable making).
>
> I've re-pushed the topic with the constructor and destructor
> declarations removed. Now the documentation looks like this:
>
> // Description:
> // Declares a vtkObject subclass.
> //
> // Notably, performs the following actions:
> //   - invokes the vtkTypeMacro()
> //   - disables its copy constructor and assignment operator
> //   - declares its static *New() method
> #define vtkClassMacro(className, parentClassName)
>
> -kyle
>
> On Thu, Sep 13, 2012 at 11:49 AM, Marcus D. Hanwell
> <marcus.hanwell@kitware.com> wrote:
> > That much wasn't clear to me in the other suggestions. I would like to
> > see a vtkClassMacro and vtkAbstractClassMacro, and thought that was
> > what was being converged on.
> >
> > On Thu, Sep 13, 2012 at 2:44 PM, Utkarsh Ayachit
> > <utkarsh.ayachit@kitware.com> wrote:
> >> I am suggesting the vtkDisableCopy() macro as an alternative to the
> >> vtkClassMacro() since after stripping out the controversial parts for
> >> vtkClassMacro() all that remains is disable copy, vtkTypeMacro() and
> >> New() and frankly, New() is also not always needed since it doens't
> >> work for abstract classes.
> >>
> >>
> >> On Thu, Sep 13, 2012 at 2:40 PM, Marcus D. Hanwell
> >> <marcus.hanwell@kitware.com> wrote:
> >>> Why provide a disable copy macro when it is a requirement of vtkObject
> >>> derived classes? It should just be part of the vtkClassMacro, with
> >>> QObject derived classes they can have copy constructors, and so
> >>> provided an option makes more sense there.
> >>>
> >>> On Thu, Sep 13, 2012 at 2:29 PM, Aashish Chaudhary
> >>> <aashish.chaudhary@kitware.com> wrote:
> >>>> +1 to remove construct and destructor. Also I think like Qt we should
> >>>> provide disable copy macro and use it in vtkClassMacro.
> >>>>
> >>>> Thanks,
> >>>>
> >>>>
> >>>> On Thu, Sep 13, 2012 at 12:39 PM, Cory Quammen <cquammen@cs.unc.edu>
> wrote:
> >>>>>
> >>>>> +1 if you remove the constructors/destructor declarations.
> >>>>>
> >>>>> Cory
> >>>>>
> >>>>> On Thu, Sep 13, 2012 at 11:33 AM, Patchett, John M <
> patchett@lanl.gov>
> >>>>> wrote:
> >>>>> > Though I don't usually involve myself in VTK development, I think
> >>>>> > that obfuscated understandability is part of the reason that I've
> seen
> >>>>> > a large number of otherwise bright developers (students) become
> >>>>> > integration impotent when asked to put their ideas/code in
> >>>>> > VTK/ParaView...
> >>>>> > If a goal is to have contributors, this is a bad idea.
> >>>>> >
> >>>>> >
> >>>>> > --John.
> >>>>> >
> >>>>> >
> >>>>> > On 9/13/12 9:22 AM, "Marcus D. Hanwell" <
> marcus.hanwell@kitware.com>
> >>>>> > wrote:
> >>>>> >
> >>>>> >>On Thu, Sep 13, 2012 at 11:07 AM, Utkarsh Ayachit
> >>>>> >><utkarsh.ayachit@kitware.com> wrote:
> >>>>> >>>> I am in favor of adding the macro, and disagree with Utkarsh in
> that
> >>>>> >>>> we already have the type macro etc and it will remove the need
> for a
> >>>>> >>>> lot of boiler plate code in each class declaration.
> >>>>> >>>
> >>>>> >>> Note  that vtkTypeMacro() doesn't force you to add anything in
> the cxx
> >>>>> >>> file. You can pretty much not know what that macro does and
> you're
> >>>>> >>> okay. Not so with this macro. Also hiding constructor/destructor
> is
> >>>>> >>> really weird to me. Why would you? I don't think I am thrilled by
> >>>>> >>> having to implement function definitions without seeing their
> >>>>> >>> declarations in the header. None of the existing macros do that,
> not
> >>>>> >>> even in Qt, as far as I know. Readability of code is far more
> >>>>> >>> important that saving typing a few more lines, IMHO.
> >>>>> >>>
> >>>>> >>I can see your point with the contructor/desctructor. Even with
> them
> >>>>> >>removed I still think this macro would be very useful.
> >>>>> >>
> >>>>> >>Marcus
> >>>>> >>_______________________________________________
> >>>>> >>Powered by www.kitware.com
> >>>>> >>
> >>>>> >>Visit other Kitware open-source projects at
> >>>>> >>http://www.kitware.com/opensource/opensource.html
> >>>>> >>
> >>>>> >>Follow this link to subscribe/unsubscribe:
> >>>>> >>http://www.vtk.org/mailman/listinfo/vtk-developers
> >>>>> >>
> >>>>> >
> >>>>> > _______________________________________________
> >>>>> > Powered by www.kitware.com
> >>>>> >
> >>>>> > Visit other Kitware open-source projects at
> >>>>> > http://www.kitware.com/opensource/opensource.html
> >>>>> >
> >>>>> > Follow this link to subscribe/unsubscribe:
> >>>>> > http://www.vtk.org/mailman/listinfo/vtk-developers
> >>>>> >
> >>>>>
> >>>>>
> >>>>>
> >>>>> --
> >>>>> Cory Quammen
> >>>>> Research Associate
> >>>>> Department of Computer Science
> >>>>> The University of North Carolina at Chapel Hill
> >>>>> _______________________________________________
> >>>>> Powered by www.kitware.com
> >>>>>
> >>>>> Visit other Kitware open-source projects at
> >>>>> http://www.kitware.com/opensource/opensource.html
> >>>>>
> >>>>> Follow this link to subscribe/unsubscribe:
> >>>>> http://www.vtk.org/mailman/listinfo/vtk-developers
> >>>>>
> >>>>
> >>>>
> >>>>
> >>>> --
> >>>> | Aashish Chaudhary
> >>>> | R&D Engineer
> >>>> | Kitware Inc.
> >>>> | www.kitware.com
> >>>>
> >>>> _______________________________________________
> >>>> Powered by www.kitware.com
> >>>>
> >>>> Visit other Kitware open-source projects at
> >>>> http://www.kitware.com/opensource/opensource.html
> >>>>
> >>>> Follow this link to subscribe/unsubscribe:
> >>>> http://www.vtk.org/mailman/listinfo/vtk-developers
> >>>>
> >>>>
> >>> _______________________________________________
> >>> Powered by www.kitware.com
> >>>
> >>> Visit other Kitware open-source projects at
> http://www.kitware.com/opensource/opensource.html
> >>>
> >>> Follow this link to subscribe/unsubscribe:
> >>> http://www.vtk.org/mailman/listinfo/vtk-developers
> >>>
> > _______________________________________________
> > Powered by www.kitware.com
> >
> > Visit other Kitware open-source projects at
> http://www.kitware.com/opensource/opensource.html
> >
> > Follow this link to subscribe/unsubscribe:
> > http://www.vtk.org/mailman/listinfo/vtk-developers
> >
> _______________________________________________
> Powered by www.kitware.com
>
> Visit other Kitware open-source projects at
> http://www.kitware.com/opensource/opensource.html
>
> Follow this link to subscribe/unsubscribe:
> http://www.vtk.org/mailman/listinfo/vtk-developers
>
>


-- 
Unpaid intern in BillsBasement at noware dot com

[Attachment #5 (text/html)]

Since it is a real pain when vtkSetGet.h is changed (at least for old guys with slow \
machines),  why not add vtkAbstractClassMacro now?<br><br><div class="gmail_quote">On \
Thu, Sep 13, 2012 at 3:12 PM, Kyle Lutz <span dir="ltr">&lt;<a \
href="mailto:kyle.lutz@kitware.com" \
target="_blank">kyle.lutz@kitware.com</a>&gt;</span> wrote:<br> <blockquote \
class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc \
solid;padding-left:1ex">Thanks all for the input.<br> <br>
For now I&#39;d like to keep the discussion targeted at vtkClassMacro(). A<br>
macro for abstract classes (which VTK has far fewer of) could be added<br>
later if vtkClassMacro() proves useful. Furthermore, I don&#39;t really<br>
think using a vtkDisableCopy() type macro is the proper way to<br>
prohibit copying of VTK classes. vtkObjectBase should just declare its<br>
copy constructor and assignment operator as private a la<br>
boost::noncopyable (but this is a larger change than I feel<br>
comfortable making).<br>
<br>
I&#39;ve re-pushed the topic with the constructor and destructor<br>
declarations removed. Now the documentation looks like this:<br>
<div class="im"><br>
// Description:<br>
// Declares a vtkObject subclass.<br>
//<br>
// Notably, performs the following actions:<br>
//   - invokes the vtkTypeMacro()<br>
</div><div class="im">//   - disables its copy constructor and assignment \
operator<br> //   - declares its static *New() method<br>
</div>#define vtkClassMacro(className, parentClassName)<br>
<br>
-kyle<br>
<br>
On Thu, Sep 13, 2012 at 11:49 AM, Marcus D. Hanwell<br>
<div class="HOEnZb"><div class="h5">&lt;<a \
href="mailto:marcus.hanwell@kitware.com">marcus.hanwell@kitware.com</a>&gt; \
wrote:<br> &gt; That much wasn&#39;t clear to me in the other suggestions. I would \
like to<br> &gt; see a vtkClassMacro and vtkAbstractClassMacro, and thought that \
was<br> &gt; what was being converged on.<br>
&gt;<br>
&gt; On Thu, Sep 13, 2012 at 2:44 PM, Utkarsh Ayachit<br>
&gt; &lt;<a href="mailto:utkarsh.ayachit@kitware.com">utkarsh.ayachit@kitware.com</a>&gt; \
wrote:<br> &gt;&gt; I am suggesting the vtkDisableCopy() macro as an alternative to \
the<br> &gt;&gt; vtkClassMacro() since after stripping out the controversial parts \
for<br> &gt;&gt; vtkClassMacro() all that remains is disable copy, vtkTypeMacro() \
and<br> &gt;&gt; New() and frankly, New() is also not always needed since it \
doens&#39;t<br> &gt;&gt; work for abstract classes.<br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt; On Thu, Sep 13, 2012 at 2:40 PM, Marcus D. Hanwell<br>
&gt;&gt; &lt;<a href="mailto:marcus.hanwell@kitware.com">marcus.hanwell@kitware.com</a>&gt; \
wrote:<br> &gt;&gt;&gt; Why provide a disable copy macro when it is a requirement of \
vtkObject<br> &gt;&gt;&gt; derived classes? It should just be part of the \
vtkClassMacro, with<br> &gt;&gt;&gt; QObject derived classes they can have copy \
constructors, and so<br> &gt;&gt;&gt; provided an option makes more sense there.<br>
&gt;&gt;&gt;<br>
&gt;&gt;&gt; On Thu, Sep 13, 2012 at 2:29 PM, Aashish Chaudhary<br>
&gt;&gt;&gt; &lt;<a href="mailto:aashish.chaudhary@kitware.com">aashish.chaudhary@kitware.com</a>&gt; \
wrote:<br> &gt;&gt;&gt;&gt; +1 to remove construct and destructor. Also I think like \
Qt we should<br> &gt;&gt;&gt;&gt; provide disable copy macro and use it in \
vtkClassMacro.<br> &gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; Thanks,<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; On Thu, Sep 13, 2012 at 12:39 PM, Cory Quammen &lt;<a \
href="mailto:cquammen@cs.unc.edu">cquammen@cs.unc.edu</a>&gt; wrote:<br> \
&gt;&gt;&gt;&gt;&gt;<br> &gt;&gt;&gt;&gt;&gt; +1 if you remove the \
constructors/destructor declarations.<br> &gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt; Cory<br>
&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt; On Thu, Sep 13, 2012 at 11:33 AM, Patchett, John M &lt;<a \
href="mailto:patchett@lanl.gov">patchett@lanl.gov</a>&gt;<br> &gt;&gt;&gt;&gt;&gt; \
wrote:<br> &gt;&gt;&gt;&gt;&gt; &gt; Though I don&#39;t usually involve myself in VTK \
development, I think<br> &gt;&gt;&gt;&gt;&gt; &gt; that obfuscated understandability \
is part of the reason that I&#39;ve seen<br> &gt;&gt;&gt;&gt;&gt; &gt; a large number \
of otherwise bright developers (students) become<br> &gt;&gt;&gt;&gt;&gt; &gt; \
integration impotent when asked to put their ideas/code in<br> &gt;&gt;&gt;&gt;&gt; \
&gt; VTK/ParaView...<br> &gt;&gt;&gt;&gt;&gt; &gt; If a goal is to have contributors, \
this is a bad idea.<br> &gt;&gt;&gt;&gt;&gt; &gt;<br>
&gt;&gt;&gt;&gt;&gt; &gt;<br>
&gt;&gt;&gt;&gt;&gt; &gt; --John.<br>
&gt;&gt;&gt;&gt;&gt; &gt;<br>
&gt;&gt;&gt;&gt;&gt; &gt;<br>
&gt;&gt;&gt;&gt;&gt; &gt; On 9/13/12 9:22 AM, &quot;Marcus D. Hanwell&quot; &lt;<a \
href="mailto:marcus.hanwell@kitware.com">marcus.hanwell@kitware.com</a>&gt;<br> \
&gt;&gt;&gt;&gt;&gt; &gt; wrote:<br> &gt;&gt;&gt;&gt;&gt; &gt;<br>
&gt;&gt;&gt;&gt;&gt; &gt;&gt;On Thu, Sep 13, 2012 at 11:07 AM, Utkarsh Ayachit<br>
&gt;&gt;&gt;&gt;&gt; &gt;&gt;&lt;<a \
href="mailto:utkarsh.ayachit@kitware.com">utkarsh.ayachit@kitware.com</a>&gt; \
wrote:<br> &gt;&gt;&gt;&gt;&gt; &gt;&gt;&gt;&gt; I am in favor of adding the macro, \
and disagree with Utkarsh in that<br> &gt;&gt;&gt;&gt;&gt; &gt;&gt;&gt;&gt; we \
already have the type macro etc and it will remove the need for a<br> \
&gt;&gt;&gt;&gt;&gt; &gt;&gt;&gt;&gt; lot of boiler plate code in each class \
declaration.<br> &gt;&gt;&gt;&gt;&gt; &gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt; &gt;&gt;&gt; Note  that vtkTypeMacro() doesn&#39;t force you to \
add anything in the cxx<br> &gt;&gt;&gt;&gt;&gt; &gt;&gt;&gt; file. You can pretty \
much not know what that macro does and you&#39;re<br> &gt;&gt;&gt;&gt;&gt; \
&gt;&gt;&gt; okay. Not so with this macro. Also hiding constructor/destructor is<br> \
&gt;&gt;&gt;&gt;&gt; &gt;&gt;&gt; really weird to me. Why would you? I don&#39;t \
think I am thrilled by<br> &gt;&gt;&gt;&gt;&gt; &gt;&gt;&gt; having to implement \
function definitions without seeing their<br> &gt;&gt;&gt;&gt;&gt; &gt;&gt;&gt; \
declarations in the header. None of the existing macros do that, not<br> \
&gt;&gt;&gt;&gt;&gt; &gt;&gt;&gt; even in Qt, as far as I know. Readability of code \
is far more<br> &gt;&gt;&gt;&gt;&gt; &gt;&gt;&gt; important that saving typing a few \
more lines, IMHO.<br> &gt;&gt;&gt;&gt;&gt; &gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt; &gt;&gt;I can see your point with the contructor/desctructor. \
Even with them<br> &gt;&gt;&gt;&gt;&gt; &gt;&gt;removed I still think this macro \
would be very useful.<br> &gt;&gt;&gt;&gt;&gt; &gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt; &gt;&gt;Marcus<br>
&gt;&gt;&gt;&gt;&gt; &gt;&gt;_______________________________________________<br>
&gt;&gt;&gt;&gt;&gt; &gt;&gt;Powered by <a href="http://www.kitware.com" \
target="_blank">www.kitware.com</a><br> &gt;&gt;&gt;&gt;&gt; &gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt; &gt;&gt;Visit other Kitware open-source projects at<br>
&gt;&gt;&gt;&gt;&gt; &gt;&gt;<a \
href="http://www.kitware.com/opensource/opensource.html" \
target="_blank">http://www.kitware.com/opensource/opensource.html</a><br> \
&gt;&gt;&gt;&gt;&gt; &gt;&gt;<br> &gt;&gt;&gt;&gt;&gt; &gt;&gt;Follow this link to \
subscribe/unsubscribe:<br> &gt;&gt;&gt;&gt;&gt; &gt;&gt;<a \
href="http://www.vtk.org/mailman/listinfo/vtk-developers" \
target="_blank">http://www.vtk.org/mailman/listinfo/vtk-developers</a><br> \
&gt;&gt;&gt;&gt;&gt; &gt;&gt;<br> &gt;&gt;&gt;&gt;&gt; &gt;<br>
&gt;&gt;&gt;&gt;&gt; &gt; _______________________________________________<br>
&gt;&gt;&gt;&gt;&gt; &gt; Powered by <a href="http://www.kitware.com" \
target="_blank">www.kitware.com</a><br> &gt;&gt;&gt;&gt;&gt; &gt;<br>
&gt;&gt;&gt;&gt;&gt; &gt; Visit other Kitware open-source projects at<br>
&gt;&gt;&gt;&gt;&gt; &gt; <a href="http://www.kitware.com/opensource/opensource.html" \
target="_blank">http://www.kitware.com/opensource/opensource.html</a><br> \
&gt;&gt;&gt;&gt;&gt; &gt;<br> &gt;&gt;&gt;&gt;&gt; &gt; Follow this link to \
subscribe/unsubscribe:<br> &gt;&gt;&gt;&gt;&gt; &gt; <a \
href="http://www.vtk.org/mailman/listinfo/vtk-developers" \
target="_blank">http://www.vtk.org/mailman/listinfo/vtk-developers</a><br> \
&gt;&gt;&gt;&gt;&gt; &gt;<br> &gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt; --<br>
&gt;&gt;&gt;&gt;&gt; Cory Quammen<br>
&gt;&gt;&gt;&gt;&gt; Research Associate<br>
&gt;&gt;&gt;&gt;&gt; Department of Computer Science<br>
&gt;&gt;&gt;&gt;&gt; The University of North Carolina at Chapel Hill<br>
&gt;&gt;&gt;&gt;&gt; _______________________________________________<br>
&gt;&gt;&gt;&gt;&gt; Powered by <a href="http://www.kitware.com" \
target="_blank">www.kitware.com</a><br> &gt;&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;&gt; Visit other Kitware open-source projects at<br>
&gt;&gt;&gt;&gt;&gt; <a href="http://www.kitware.com/opensource/opensource.html" \
target="_blank">http://www.kitware.com/opensource/opensource.html</a><br> \
&gt;&gt;&gt;&gt;&gt;<br> &gt;&gt;&gt;&gt;&gt; Follow this link to \
subscribe/unsubscribe:<br> &gt;&gt;&gt;&gt;&gt; <a \
href="http://www.vtk.org/mailman/listinfo/vtk-developers" \
target="_blank">http://www.vtk.org/mailman/listinfo/vtk-developers</a><br> \
&gt;&gt;&gt;&gt;&gt;<br> &gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; --<br>
&gt;&gt;&gt;&gt; | Aashish Chaudhary<br>
&gt;&gt;&gt;&gt; | R&amp;D Engineer<br>
&gt;&gt;&gt;&gt; | Kitware Inc.<br>
&gt;&gt;&gt;&gt; | <a href="http://www.kitware.com" \
target="_blank">www.kitware.com</a><br> &gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; _______________________________________________<br>
&gt;&gt;&gt;&gt; Powered by <a href="http://www.kitware.com" \
target="_blank">www.kitware.com</a><br> &gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt;&gt; Visit other Kitware open-source projects at<br>
&gt;&gt;&gt;&gt; <a href="http://www.kitware.com/opensource/opensource.html" \
target="_blank">http://www.kitware.com/opensource/opensource.html</a><br> \
&gt;&gt;&gt;&gt;<br> &gt;&gt;&gt;&gt; Follow this link to subscribe/unsubscribe:<br>
&gt;&gt;&gt;&gt; <a href="http://www.vtk.org/mailman/listinfo/vtk-developers" \
target="_blank">http://www.vtk.org/mailman/listinfo/vtk-developers</a><br> \
&gt;&gt;&gt;&gt;<br> &gt;&gt;&gt;&gt;<br>
&gt;&gt;&gt; _______________________________________________<br>
&gt;&gt;&gt; Powered by <a href="http://www.kitware.com" \
target="_blank">www.kitware.com</a><br> &gt;&gt;&gt;<br>
&gt;&gt;&gt; Visit other Kitware open-source projects at <a \
href="http://www.kitware.com/opensource/opensource.html" \
target="_blank">http://www.kitware.com/opensource/opensource.html</a><br> \
&gt;&gt;&gt;<br> &gt;&gt;&gt; Follow this link to subscribe/unsubscribe:<br>
&gt;&gt;&gt; <a href="http://www.vtk.org/mailman/listinfo/vtk-developers" \
target="_blank">http://www.vtk.org/mailman/listinfo/vtk-developers</a><br> \
&gt;&gt;&gt;<br> &gt; _______________________________________________<br>
&gt; Powered by <a href="http://www.kitware.com" \
target="_blank">www.kitware.com</a><br> &gt;<br>
&gt; Visit other Kitware open-source projects at <a \
href="http://www.kitware.com/opensource/opensource.html" \
target="_blank">http://www.kitware.com/opensource/opensource.html</a><br> &gt;<br>
&gt; Follow this link to subscribe/unsubscribe:<br>
&gt; <a href="http://www.vtk.org/mailman/listinfo/vtk-developers" \
target="_blank">http://www.vtk.org/mailman/listinfo/vtk-developers</a><br> &gt;<br>
_______________________________________________<br>
Powered by <a href="http://www.kitware.com" target="_blank">www.kitware.com</a><br>
<br>
Visit other Kitware open-source projects at <a \
href="http://www.kitware.com/opensource/opensource.html" \
target="_blank">http://www.kitware.com/opensource/opensource.html</a><br> <br>
Follow this link to subscribe/unsubscribe:<br>
<a href="http://www.vtk.org/mailman/listinfo/vtk-developers" \
target="_blank">http://www.vtk.org/mailman/listinfo/vtk-developers</a><br> <br>
</div></div></blockquote></div><br><br clear="all"><br>-- <br>Unpaid intern in \
BillsBasement at noware dot com<br><br>



_______________________________________________
Powered by www.kitware.com

Visit other Kitware open-source projects at http://www.kitware.com/opensource/opensource.html

Follow this link to subscribe/unsubscribe:
http://www.vtk.org/mailman/listinfo/vtk-developers



[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic