Frameworks association rules
Post here questions and problems related to oXygen frameworks/document types.
			- 
				emmam
- Posts: 16
- Joined: Sat Jul 28, 2012 11:41 am
Frameworks association rules
Hi all
I'm using frameworks for several TEI and epidocs projects so every root is TEI !
How to create an assocation that would give me the relevant framework for each project.
The simpliest way would be to use an attribute on the root element, but I'm not confortable at all with that option.
I also thought about using file names prefixes (something like : "prefix*.*") but doesn't seem to be possible at all and maybe would not accomadate any situation.
May be it would be convenient to have an association option with the files associated with a project or a folder...
What would you advice ?
emmanuelle
			
			
									
									
						I'm using frameworks for several TEI and epidocs projects so every root is TEI !
How to create an assocation that would give me the relevant framework for each project.
The simpliest way would be to use an attribute on the root element, but I'm not confortable at all with that option.
I also thought about using file names prefixes (something like : "prefix*.*") but doesn't seem to be possible at all and maybe would not accomadate any situation.
May be it would be convenient to have an association option with the files associated with a project or a folder...
What would you advice ?
emmanuelle
- 
				Radu
- Posts: 9544
- Joined: Fri Jul 09, 2004 5:18 pm
Re: Frameworks association rules
Hi Emmanuelle,
Here's a possibility:
So in the Oxygen Preferences->"Document Type Association" page you would have multiple "TEI P5-like" document types defined, each with its own functionality, all of them matching the same association rule.
Then from the bottom of the Preferences page you change the page to "Project Options" and then you uncheck/disable the TEI frameworks which should not apply to the current project.
Then you load another project and again for it you pass the page to project options and uncheck in it the TEI frameworks which should not match documents in the current project.
So each time you open a project, it would come with its own list of activated frameworks.
Regards,
Radu
			
			
									
									Here's a possibility:
So in the Oxygen Preferences->"Document Type Association" page you would have multiple "TEI P5-like" document types defined, each with its own functionality, all of them matching the same association rule.
Then from the bottom of the Preferences page you change the page to "Project Options" and then you uncheck/disable the TEI frameworks which should not apply to the current project.
Then you load another project and again for it you pass the page to project options and uncheck in it the TEI frameworks which should not match documents in the current project.
So each time you open a project, it would come with its own list of activated frameworks.
Regards,
Radu
Radu Coravu 
<oXygen/> XML Editor
http://www.oxygenxml.com
						<oXygen/> XML Editor
http://www.oxygenxml.com
- 
				emylonas
- Posts: 10
- Joined: Sat Feb 16, 2013 3:04 am
Re: Frameworks association rules
Radu suggests using the project specific options to disable the frameworks that aren't relevant. This will work well with a group of steady encoders who have been taught to use projects. As a matter of fact, our initial efforts to provide Author mode frameworks consisted of a project file that the students click on and it is set up with all the necessary settings.
However, we would also like to make the framework available to encoders who contribute infrequently, or who may be working on their own. Explaining and setting up projects may not work for them.
In this case, it seems as if the only option is the attribute on the root element.
Is there any other option? I was thinking perhaps of a namespace prefix? What about information from the Oxygen processing instruction?
We can solve our problem for now either with the root element id or the project. Just wondering if there might be something more generalizable.
thank you.
			
			
									
									
						However, we would also like to make the framework available to encoders who contribute infrequently, or who may be working on their own. Explaining and setting up projects may not work for them.
In this case, it seems as if the only option is the attribute on the root element.
Is there any other option? I was thinking perhaps of a namespace prefix? What about information from the Oxygen processing instruction?
We can solve our problem for now either with the root element id or the project. Just wondering if there might be something more generalizable.
thank you.
- 
				Radu
- Posts: 9544
- Joined: Fri Jul 09, 2004 5:18 pm
Re: Frameworks association rules
Hi Elli,
If you edit a document type in the Document Type Association preferences page and try to add a new association rule to it besides the usual fields matching a root name, namespace, attributes and so on you also have a custom Java class matcher.
Basically if you create an extension of the API class ro.sync.ecss.extensions.api.DocumentTypeCustomRuleMatcher and you pack it in a Java JAR library which is added to the "Classpath" tab in the document type configuration dialog, you can refer to that custom implementation from the association rule.
Your custom implementation will receive this callback:
when Oxygen tries to determine if the opened XML document belongs to this particular document type association or not.
One of the parameters is the systemID URL location of the opened XML document. Maybe you can use this information to find out the name of the project folder in which the XML document is located and based on that to take a decision to match or not the document type.
Or using that location of the document you could parse it separately and find a certain processing instruction in it, something like:
Regards,
Radu
			
			
									
									If you edit a document type in the Document Type Association preferences page and try to add a new association rule to it besides the usual fields matching a root name, namespace, attributes and so on you also have a custom Java class matcher.
Basically if you create an extension of the API class ro.sync.ecss.extensions.api.DocumentTypeCustomRuleMatcher and you pack it in a Java JAR library which is added to the "Classpath" tab in the document type configuration dialog, you can refer to that custom implementation from the association rule.
Your custom implementation will receive this callback:
Code: Select all
  /**
   * Check if the document type to which this custom rule belongs to 
   * should be used for the given document properties.
   * 
   * @param systemID The system ID of the current file in an URL format with not allowed characters corrected.
   * For example: "file:/C:/path/to/file/file.xml"
   * @param rootNamespace The namespace of the root.
   * @param rootLocalName The root local name.
   * @param doctypePublicID The public id of the specified DTD if any.
   * @param rootAttributes The root attributes. The attributes are DOM level 2 
   * and the namespaces are available for each one.
   * @return <code>true</code> if the document type to which this rule belongs to
   * will be used for the current file.
   */
  boolean matches(
      String systemID, 
      String rootNamespace, 
      String rootLocalName, 
      String doctypePublicID, 
      Attributes rootAttributes);One of the parameters is the systemID URL location of the opened XML document. Maybe you can use this information to find out the name of the project folder in which the XML document is located and based on that to take a decision to match or not the document type.
Or using that location of the document you could parse it separately and find a certain processing instruction in it, something like:
Code: Select all
  public boolean matches(String systemID, String rootNamespace, String rootLocalName,
      String doctypePublicID, Attributes rootAttributes) {
    final boolean[] foundProperPI = new boolean[1]; 
    if(systemID != null) {
      XMLReader xmlReader = PluginWorkspaceProvider.getPluginWorkspace().getXMLUtilAccess().newNonValidatingXMLReader();
      xmlReader.setContentHandler(new ContentHandler() {
        @Override
        public void startPrefixMapping(String prefix, String uri) throws SAXException {
        }
        @Override
        public void startElement(String uri, String localName, String qName, Attributes atts)
            throws SAXException {
          //Break early, do not parse the entire document
          //We are only interested in the PIs before the root
          throw new SAXException();
        }
        @Override
        public void startDocument() throws SAXException {
        }
        @Override
        public void skippedEntity(String name) throws SAXException {
        }
        @Override
        public void setDocumentLocator(Locator locator) {
        }
        @Override
        public void processingInstruction(String target, String data) throws SAXException {
          if("custom".equals(target)) {
            foundProperPI[0] = true;
          }
        }
        @Override
        public void ignorableWhitespace(char[] ch, int start, int length) throws SAXException {
        }
        @Override
        public void endPrefixMapping(String prefix) throws SAXException {
        }
        @Override
        public void endElement(String uri, String localName, String qName) throws SAXException {
        }
        @Override
        public void endDocument() throws SAXException {
        }
        @Override
        public void characters(char[] ch, int start, int length) throws SAXException {
        }
      });
      try {
        xmlReader.parse(systemID);
      } catch (Exception e) {
        //Ignore.
      }
    }
    return foundProperPI[0];
  }Regards,
Radu
Radu Coravu 
<oXygen/> XML Editor
http://www.oxygenxml.com
						<oXygen/> XML Editor
http://www.oxygenxml.com
- 
				dreifsnider
- Posts: 175
- Joined: Thu Aug 30, 2018 10:06 pm
Re: Frameworks association rules
Post by dreifsnider »
Hi,
Apologies for bringing this thread back, but I'm curious if you have any recommendations for how I can extend the ro.sync.ecss.extensions.api.DocumentTypeCustomRuleMatcher class to match on .ditamaps located under a certain directory.
For example, I'd like to be able to match on a .ditamap that is located under a directory called "my-project". Here is a sample structure of this directory:
I'd like to create a custom framework that matches on any ditamap located under the "my-project" directory so I can customize the transformation and validation scenarios, as well as the editor CSS.
Do you have any recommendations for how I can accomplish this? My skills with Java are unfortunately not robust enough to be able to accomplish this on my own.
Thank you!
Daniel
			
			
									
									
						Apologies for bringing this thread back, but I'm curious if you have any recommendations for how I can extend the ro.sync.ecss.extensions.api.DocumentTypeCustomRuleMatcher class to match on .ditamaps located under a certain directory.
For example, I'd like to be able to match on a .ditamap that is located under a directory called "my-project". Here is a sample structure of this directory:
Code: Select all
 - my-project
   - documents
      - user-guide
         - en
            - user-guide.ditamap
         - ja
            - user-guide.ditamap
      - specifications
         - en
            - specifications.ditamap
         - ja
            - specifications.ditamapDo you have any recommendations for how I can accomplish this? My skills with Java are unfortunately not robust enough to be able to accomplish this on my own.
Thank you!
Daniel
- 
				Radu
- Posts: 9544
- Joined: Fri Jul 09, 2004 5:18 pm
Re: Frameworks association rules
Hi Daniel,
On this callback method:
you receive the "systemID" which is an URL-like path pointing to the DITA Map in the form:
So at a minimum you could implement the DocumentTypeCustomRuleMatcher like this:
But for such a simple use case you do not need a DocumentTypeCustomRuleMatcher Java implementation, in the Oxygen Preferences->"Document Type Associations" page if you edit your framework configuration and look at the "Association rules" tab there is an association rule named "File Name", I think setting it to something like */my-project/* should also work.
Regards,
Radu
			
			
									
									On this callback method:
Code: Select all
public boolean matches(String systemID, String rootNamespace, String rootLocalName,  String doctypePublicID, Attributes rootAttributes) Code: Select all
file:/c:/path/to/my.ditamapCode: Select all
  boolean matches(
      String systemID, 
      String rootNamespace, 
      String rootLocalName, 
      String doctypePublicID, 
      Attributes rootAttributes) {
    return systemID != null && systemID.contains("/my-project/");
  }Regards,
Radu
Radu Coravu 
<oXygen/> XML Editor
http://www.oxygenxml.com
						<oXygen/> XML Editor
http://www.oxygenxml.com
- 
				dreifsnider
- Posts: 175
- Joined: Thu Aug 30, 2018 10:06 pm
Re: Frameworks association rules
Post by dreifsnider »
Thank you very much for your reply Radu!
I haven't tried entering a file path with wildcards into the File Name field in the Association Rules tab, as my initial expectation was that it only accepted and acted on the file name. I will try this and report my findings here.
I will also save your example of implementing the DocumentTypeCustomRuleMatcher for future use cases.
Thanks again!
Daniel
			
			
									
									
						I haven't tried entering a file path with wildcards into the File Name field in the Association Rules tab, as my initial expectation was that it only accepted and acted on the file name. I will try this and report my findings here.
I will also save your example of implementing the DocumentTypeCustomRuleMatcher for future use cases.
Thanks again!
Daniel
Return to “SDK-API, Frameworks - Document Types”
			
				Jump to
				
			
		
			
			
	
	- Oxygen XML Editor/Author/Developer
- ↳ Feature Request
- ↳ Common Problems
- ↳ DITA (Editing and Publishing DITA Content)
- ↳ Artificial Intelligence (AI Positron Assistant add-on)
- ↳ SDK-API, Frameworks - Document Types
- ↳ DocBook
- ↳ TEI
- ↳ XHTML
- ↳ Other Issues
- Oxygen XML Web Author
- ↳ Feature Request
- ↳ Common Problems
- Oxygen Content Fusion
- ↳ Feature Request
- ↳ Common Problems
- Oxygen JSON Editor
- ↳ Feature Request
- ↳ Common Problems
- Oxygen PDF Chemistry
- ↳ Feature Request
- ↳ Common Problems
- Oxygen Feedback
- ↳ Feature Request
- ↳ Common Problems
- Oxygen XML WebHelp
- ↳ Feature Request
- ↳ Common Problems
- XML
- ↳ General XML Questions
- ↳ XSLT and FOP
- ↳ XML Schemas
- ↳ XQuery
- NVDL
- ↳ General NVDL Issues
- ↳ oNVDL Related Issues
- XML Services Market
- ↳ Offer a Service