Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 7 Next »

Each template in the theme can have optional meta HTML comment, that is used to configure a category, that is created to match that template in the "Structure & Data" section. The typical comment looks like this:

<!--##
<NAME>Name of the page</NAME>
<DESC>Description of the page</DESC>
<SECTION>Top Category||Sub Category||Sub Sub Category</SECTION>
##-->

The following problems are known due way how processing of this comment is implemented:

  • no validation is made, that it's a valid XML (e.g. placing "&" instead of "&amp;" won't break anything
  • the XML is treated like a regular string and therefore typical XML errors (e.g. pair tag name mismatch) are simply ignored
  • when unknown XML settings are added developer isn't informed about that, which can lead to code working in unexpected ways

Solution

The plan below would allow separate all template comment related logic into one class and allow addition of new settings later if needed.

  1. create the "TemplateCommentParser" class, that: - 0.2h
    1. would accept path to template as constructor argument
    2. the "parse" method would return associative array of results
  2. add support for data types in the class: - 0.5h
    1. "string" - any string
    2. "boolean" - true (when "yes"), false (when "no"), exception otherwise
    3. "integer" - as-as, when a positive integer, exception otherwise
    4. "category_path" - would split value by "||" and trim each each element
  3. define supported settings and their data types as class properties - 0.3h
  4. when template doesn't exist throw an exception - 0.1h
  5. when no meta comment found, then return an empty array - 0.1h
  6. when meta comment found: - 0.3h
    1. if it's one line long, then return an empty array
    2. if it's invalid XML, then throw an exception
    3. when unsupported setting found, then throw an exception
    4. when supported setting found, but it has value unknown format, then throw an exception
  7. return parsing result
  8. delete "kThemesHelper::parseTemplateMetaInfo" in favor of using "TemplateCommentParser::parse" method - 0.5h

Quote: 2h*1.4=3h

Related Discussions

Related Tasks

Error rendering macro 'jira' : Unable to locate Jira server for this macro. It may be due to Application Link configuration.

  • No labels