Update: 

I’ve found xslutil in 
/applications/xslutility.app/contents/resources/xslutil/bin

However, I’m still not able to execute it. When I enter ‘xslutil’ from the 
above directory, the shell says command not found:

zsh: command not found: xslutil

I’m sure I’m missing something simple, but I don’t understand why I can’t 
launch xslutil from the command line.

Thanks

Dan


> On Jan 21, 2025, at 11:27 AM, [email protected] wrote:
> 
> Hi guys. One more question. I’d like to run xslutil from the command line on 
> MacOS but can’t figure out how to do it.
> 
> I’ve read section 2.5 of the documentation, specifically: 
> 
> Linux/Mac example:
> /opt/xslutil-6_5_0/bin$ xslutil dbToDocx /tmp/help.xml /tmp/help.docx
> 
> 
> I downloaded xslutil_eval-6_5_0.dmg. And with the help you’ve already 
> provided I now have everything working exactly as I’d like with my dita 
> files, ditatoPDF conversion, and a custom stylesheet 
> (file:/Users/danmcintosh/Documents/fo_custom.xsl) using the full XSUtility 
> program.
> 
> I’m now trying to run xslutil from the command line so that I can ultimately 
> run the utility from a shell script to convert numerous XML files at once. 
> Ideally, I’d like to use the custom stylesheet I’ve created when doing this. 
> But I can’t seem to find where MacOS put this directory and executable after 
> installing from the dmg file, so I can't execute xslutil from the command 
> line in the MacOS Terminal at all.
> 
> I guess I’m pretty ignorant about where things go after installing from a dmg 
> file. Any help would be appreciated, as this is the last step I’m trying to 
> accomplish to get a demo up and running.
> 
> 
> 
>> On Jan 20, 2025, at 8:37 AM, Hussein Shafie <[email protected]> wrote:
>> 
>> On 1/20/25 04:57, [email protected] wrote:
>>> I’m currently evaluating the personal edition of XML Editor and XSLUtility. 
>>> Overall, I really enjoy using these products and am considering purchasing 
>>> the xde-usr license and XSLUtility. I really like these products and 
>>> appreciate that I can run them on MacOs (unlike something like Madcap Flare 
>>> or FrameMaker).
>>> I have a question regarding the DITA to PDF transformation using the 
>>> ditatoPDF conversion specification (Apache FOP):
>>> I have a use case where I currently use the outputclass attribute, giving 
>>> it a value like emphasis01, emphasis02, etc. I can then use this class with 
>>> a CSS selector to style specific elements in the HTML output. I can do this 
>>> just by updating the CSS stylesheet, even without using XSLUtility. 
>>> Ideally, I could also use the outputclass when using the ditatoPDF 
>>> transformation in XSLUtility. But I don’t see an attribute set associated 
>>> with the outputclass attribute. (My current workaround is to make use of an 
>>> unused element type in my XML doc—uicontrol—and then I’m doing the custom 
>>> styling in the XSLUtility based on that.)
>> 
>> There are indeed no attribute-sets which are associated with the outputclass 
>> attribute. Note that we don't see how attribute-sets could be used for that.
>> 
>> 
>>> So is there any way to add an “outputclass = <value>” to the XSL 
>>> customization? That would help tremendously and I could simply use the 
>>> outputclass attribute in the XML Editor to set up a few styling things I 
>>> need in both HTML and PDF outputs.
>>> Similarly, it would be nice to have a way to convert a “boolean=yes" or 
>>> “boolean=no" so that I could transform these guys to a “green checkmark” or 
>>> “red checkbox” or some UTF character while doing the conversion.
>>> Is it possible to do either of these things with the current version of 
>>> XSLUtility? I might just be missing something. Or would it be possible to 
>>> add something like this to the conversion options?
>> 
>> Yes. It's certainly possible to achieve all what you want but you'll have to 
>> write custom XSLT templates for that.
>> 
>> Here's how to proceed:
>> 
>> 1) Start XSLUtility and select a DITA document to be converted to PDF. 
>> Choose the ditaToPDF conversion. See attached "1app.png".
>> 
>> 2) Click "Edit" and select the "Transform" tab. See attached 
>> "2edit_transform.png".
>> 
>> 3) Click "Customize" and specify the name of the file which is to contain 
>> your custom XSLT templates. See attached "3customize_fo_xsl.png".
>> 
>> Created ".xsl" file is almost empty and looks like this:
>> ---
>> <?xml version="1.0" encoding="UTF-8"?>
>> <?stylesheet-label ?>
>> <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform";
>>                version="2.0">
>> 
>>   <xsl:import href="xslutil-config:dita/xsl/fo/fo.xsl"/>
>> 
>>   <!-- REDEFINE PARAMETERS AND ATTRIBUTE-SETS HERE -->
>> 
>> </xsl:stylesheet>
>> ---
>> 
>> 4) Once your customization file, e.g. "custom_fo.xsl",  has been created, 
>> click the "file chooser" icon to select it. See attached 
>> "4use_custom_fo_xsl.png".
>> 
>> 5) Now add XSLT templates to your customization file using a text or XML 
>> editor.
>> 
>> First thing to do is declare the "fo" namespace prefix:
>> ---
>> <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform";
>>                xmlns:fo="http://www.w3.org/1999/XSL/Format";
>>                version="2.0">
>> ---
>> 
>> Let's suppose we want to give a specific style (dark red, underlined) to <i> 
>> and <b> elements having @outputclass="emphasis". This may be done as follows:
>> 
>> ---
>>  <xsl:attribute-set name="emphasis_style">
>>    <xsl:attribute name="color">maroon</xsl:attribute>
>>    <xsl:attribute name="text-decoration">underline</xsl:attribute>
>>  </xsl:attribute-set>
>> 
>>  <xsl:template match="b[@outputclass='emphasis']">
>>    <fo:inline xsl:use-attribute-sets="b emphasis_style">
>>      <xsl:call-template name="commonAttributes"/>
>>      <xsl:apply-templates/>
>>    </fo:inline>
>>  </xsl:template>
>> 
>>  <xsl:template match="i[@outputclass='emphasis']">
>>    <fo:inline xsl:use-attribute-sets="i emphasis_style">
>>      <xsl:call-template name="commonAttributes"/>
>>      <xsl:apply-templates/>
>>    </fo:inline>
>>  </xsl:template>
>> ---
>> 
>> Let's suppose we want to render <boolean state="yes"/> and <boolean 
>> state="no"/> as OK/Cancel icons. This may be done as follows:
>> 
>> ---
>>  <xsl:template match="boolean">
>>    <fo:external-graphic content-height="16px">
>>      <xsl:attribute name="src">
>>        <xsl:choose>
>>          <xsl:when test="@state eq 'yes'">
>>            <xsl:value-of 
>> select="'url()'"/>
>>          </xsl:when>
>>          <xsl:otherwise>
>>            <xsl:value-of 
>> select="'url()'"/>
>>          </xsl:otherwise>
>>        </xsl:choose>
>>      </xsl:attribute>
>>    </fo:external-graphic>
>>  </xsl:template>
>> ---
>> 
>> Complete, working (see attached "dita-sample_pdf.png"), "custom_fo.xsl" 
>> attached to this email.
>> 
>> Now the question is: how to write these custom XSLT templates? Answer: by 
>> looking at the corresponding stock templates.
>> 
>> You'll find all stock templates in folder 
>> "XSLUtility_INSTALL_DIR/addon/config/dita/xsl/fo/". For example 
>> "XSLUtility_INSTALL_DIR/addon/config/dita/xsl/fo/typographic.xsl" contains 
>> the stock template for element <b>:
>> 
>> ---
>>  <xsl:attribute-set name="b">
>>    <xsl:attribute name="font-weight">bold</xsl:attribute>
>>  </xsl:attribute-set>
>> 
>>  <xsl:template match="*[contains(@class,' hi-d/b ')]">
>>    <fo:inline xsl:use-attribute-sets="b">
>>      <xsl:call-template name="commonAttributes"/>
>>      <xsl:apply-templates/>
>>    </fo:inline>
>>  </xsl:template>
>> ---
>> 
>> 
>> <1app.png><2edit_transform.png><3customize_fo_xsl.png><4use_custom_fo_xsl.png><custom_fo.xsl><dita_sample_pdf.png>
> 

--
XMLmind FO Converter Support List
[email protected]
http://www.xmlmind.com/mailman/listinfo/xfc-support

Reply via email to