OASIS Mailing List ArchivesView the OASIS mailing list archive below
or browse/search using MarkMail.

 


Help: OASIS Mailing Lists Help | MarkMail Help

 


 

   Re: XSLT Reuse (Was: Even if you're not ... (Was: If you're going to the

[ Lists Home | Date Index | Thread Index ]
  • To: Peter Hunsberger <peter.hunsberger@gmail.com>
  • Subject: Re: XSLT Reuse (Was: Even if you're not ... (Was: If you're going to the W3C meeting in March))
  • From: Alan Gutierrez <alan-xml-dev@engrm.com>
  • Date: Wed, 2 Feb 2005 09:36:41 -0500
  • Cc: Kurt Cagle <kurt.cagle@gmail.com>, Frans Englich <frans.englich@telia.com>, xml-dev@lists.xml.org
  • In-reply-to: <cc159a4a05013107512ac96741@mail.gmail.com>
  • Mail-followup-to: Peter Hunsberger <peter.hunsberger@gmail.com>,Kurt Cagle <kurt.cagle@gmail.com>,Frans Englich <frans.englich@telia.com>, xml-dev@lists.xml.org
  • References: <Pine.LNX.4.44L0.0501271413090.7832-100000@smtp.datapower.com> <6fa681b105012722567ad8b1f6@mail.gmail.com> <41FA3C88.7080901@metalab.unc.edu> <200501281656.56282.frans.englich@telia.com> <6fa681b1050128111742b7c6b@mail.gmail.com> <20050129150217.GB4767@maribor.izzy.net> <cc159a4a05013107512ac96741@mail.gmail.com>
  • User-agent: Mutt/1.4.1i

* Peter Hunsberger <peter.hunsberger@gmail.com> [2005-01-31 10:51]:
> On Sat, 29 Jan 2005 10:02:17 -0500, Alan Gutierrez
> <alan-xml-dev@engrm.com> wrote:
> 
> <snip/>
> 
> >    I'm not sure how to ask the question. Let's say you have a file
> >    that's a project.
> > 
> >    <project>
> >      <source>
> >        <name>main</name>
> >        <dir>src/main</dir>
> >        <category>dist</category>
> >      </source>
> >    </project>
> > 
> >    Project directory:
> > 
> >      /project
> >          /src
> >              /java
> >              /resource
> > 
> >    Use the above to generate an Ant script. I run a transform and I
> >    have javac, junit, javadoc, jar, svn, and distrubute tasks.
> > 
> >    How do I allow a user to plug in a new set of tasks to generate?
> > 
> >    This is a general problem I'm having, how do you create hooks,
> >    callbacks, er, how do you create an XSLT framework?

> One way to do this would be to make it data driven.  In the framework
> class you build some variable that is the master list of tasks and
> some well defined calls to initialize the list and then process it. 
> Any framework class can then modify the list as needed and then pass
> control back.  Eg, in the framework:

> <xsl:variable name="tasks">
>  <javac/><junit/><javadoc/><jar/><svn/><distrubute/>
> </xsl:variable>

> <xsl:template name="init">
>   <xsl:apply-templates select="tasks" mode="process/>
> </xsl:template>

> Then the users of the framework implement "init" with a higher
> priority and call the same modal templates. They add their own task
> specific templates with the same mode as needed.  Of course, with this
> approach you're also likely looking at adding some parameter that is
> the real data to be passed from the main call, to the init and then on
> to the processing tasks....

    This system is building Ant files. I've reduced my Ant needs to
    dependency resolution.

    To start with, if antlr needs javac, it is on the developer to
    know this, and request both task definitions. There is no fancy
    include mechanism that resolves dependencies.

    Then it becomes a matter of sorting out the dependencies. I'd
    like an antlr task, when it generates it's targets, to be able
    to say that javac now dependes on antlr.

    This is something to solve in XSLT.

    My first attempt will be to generate an ant file that looks like
    this:

    <project name="foo" default="java">

      <target name="antlr">
        <dependant>javac</dependant>
        <antlr grammar="src/main/antr/Foo.g"/>
      </target>

      <target name="javac">
        <javac srcdir="src/main/java/**/*.java"
               destdir="var/classes/main/classes"/>
      </target>

    </project>

    Then, and here I'm using a pipelineing approach, I'd run an XSLT
    transform that would make it look like this:

    <project name="foo" default="java">

      <target name="antlr">
        <antlr grammar="src/main/antr/Foo.g"/>
      </target>

      <target name="javac" depends="antlr">
        <javac srcdir="src/main/java/**/*.java"
               destdir="var/classes/main/classes"/>
      </target>

    </project>

    Which ought to be simple enough.

    Basically, the antlr XSLT will add dependencies to the javac task.

    That's about all I think I need to worry about for extensiblity
    in this particular problem.
    
    So maybe one way to solve XSLT reuse is through pipelining and
    the generation of intermediate documents.

-- 
Peter Hunsberger




 

News | XML in Industry | Calendar | XML Registry
Marketplace | Resources | MyXML.org | Sponsors | Privacy Statement

Copyright 2001 XML.org. This site is hosted by OASIS