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

