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(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHdpZHRoPSI1MTIiIGhlaWdodD0iNTEyIiB2aWV3Qm94PSIwIDAgNTEyIDUxMiI+CiAgICA8dGl0bGU+Y2hlY2sgaWNvbjwvdGl0bGU+CiAgICA8ZGVzYz5jaGVjayBpY29uIGZyb20gdGhlIEljb25FeHBlcmllbmNlLmNvbSBHLUNvbGxlY3Rpb24uIENvcHlyaWdodCBieSBJTkNPUlMgR21iSCAod3d3LmluY29ycy5jb20pLjwvZGVzYz4KICAgIDxkZWZzPgogICAgICAgIDxsaW5lYXJHcmFkaWVudCB4MT0iNyIgeTE9IjM0LjUiIHgyPSIzODEuNDI3NyIgeTI9IjQzNy4zMjE1IiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgaWQ9ImNvbG9yLTEiPgogICAgICAgICAgICA8c3RvcCBvZmZzZXQ9IjAiIHN0b3AtY29sb3I9IiM3N2RhMjYiLz4KICAgICAgICAgICAgPHN0b3Agb2Zmc2V0PSIxIiBzdG9wLWNvbG9yPSIjNWJhNjFlIi8+CiAgICAgICAgPC9saW5lYXJHcmFkaWVudD4KICAgIDwvZGVmcz4KICAgIDxnIGZpbGw9InVybCgjY29sb3ItMSkiIGZpbGwtcnVsZT0iZXZlbm9kZCIgc3Ryb2tlPSJub25lIiBzdHJva2Utd2lkdGg9IjEiIHN0cm9rZS1saW5lY2FwPSJidXR0IiBzdHJva2UtbGluZWpvaW49Im1pdGVyIiBzdHJva2UtbWl0ZXJsaW1pdD0iMTAiIHN0cm9rZS1kYXNoYXJyYXk9IiIgc3Ryb2tlLWRhc2hvZmZzZXQ9IjAiIGZvbnQtZmFtaWx5PSJub25lIiBmb250LXdlaWdodD0ibm9uZSIgZm9udC1zaXplPSJub25lIiB0ZXh0LWFuY2hvcj0ibm9uZSIgc3R5bGU9Im1peC1ibGVuZC1tb2RlOiBub3JtYWwiPgogICAgICAgIDxwYXRoIGQ9Ik00MzIuNSwzNC41bDc5LDc5bC0zMzQuNSwzMzVsLTE3MCwtMTcwbDc5LjUsLTc5bDkwLjUsOTAuNXoiIGlkPSJjdXJ2ZTAiLz4KICAgIDwvZz4KPC9zdmc+)'"/> >> </xsl:when> >> <xsl:otherwise> >> <xsl:value-of >> select="'url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHdpZHRoPSI1MTIiIGhlaWdodD0iNTEyIiB2aWV3Qm94PSIwIDAgNTEyIDUxMiI+CiAgICA8dGl0bGU+ZGVsZXRlIGljb248L3RpdGxlPgogICAgPGRlc2M+ZGVsZXRlIGljb24gZnJvbSB0aGUgSWNvbkV4cGVyaWVuY2UuY29tIEctQ29sbGVjdGlvbi4gQ29weXJpZ2h0IGJ5IElOQ09SUyBHbWJIICh3d3cuaW5jb3JzLmNvbSkuPC9kZXNjPgogICAgPGRlZnM+CiAgICAgICAgPGxpbmVhckdyYWRpZW50IHgxPSIyOS41IiB5MT0iMjkuNSIgeDI9IjQ0Ni41NTQiIHkyPSI0MTYuNzY1IiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgaWQ9ImNvbG9yLTEiPgogICAgICAgICAgICA8c3RvcCBvZmZzZXQ9IjAiIHN0b3AtY29sb3I9IiNlZjVjNTEiLz4KICAgICAgICAgICAgPHN0b3Agb2Zmc2V0PSIxIiBzdG9wLWNvbG9yPSIjYzQzMTI2Ii8+CiAgICAgICAgPC9saW5lYXJHcmFkaWVudD4KICAgIDwvZGVmcz4KICAgIDxnIGZpbGw9InVybCgjY29sb3ItMSkiIGZpbGwtcnVsZT0ibm9uemVybyIgc3Ryb2tlPSJub25lIiBzdHJva2Utd2lkdGg9IjEiIHN0cm9rZS1saW5lY2FwPSJidXR0IiBzdHJva2UtbGluZWpvaW49Im1pdGVyIiBzdHJva2UtbWl0ZXJsaW1pdD0iMTAiIHN0cm9rZS1kYXNoYXJyYXk9IiIgc3Ryb2tlLWRhc2hvZmZzZXQ9IjAiIGZvbnQtZmFtaWx5PSJub25lIiBmb250LXdlaWdodD0ibm9uZSIgZm9udC1zaXplPSJub25lIiB0ZXh0LWFuY2hvcj0ibm9uZSIgc3R5bGU9Im1peC1ibGVuZC1tb2RlOiBub3JtYWwiPgogICAgICAgIDxwYXRoIGQ9Ik0zOTIsMjkuNWw5MC41LDkwLjVsLTEzNiwxMzZsMTM2LDEzNmwtOTAuNSw5MC41bC0xMzYsLTEzNmwtMTM2LDEzNmwtOTAuNSwtOTAuNWwxMzYsLTEzNmwtMTM2LC0xMzZsOTAuNSwtOTAuNWwxMzYsMTM2eiIgaWQ9ImN1cnZlMCIvPgogICAgPC9nPgo8L3N2Zz4=)'"/> >> </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

