|  |  | 
|  |  | 
|  |  | 
|  | <!doctype html> | 
|  | <html lang="en" class="no-js"> | 
|  | <head> | 
|  |  | 
|  | <meta charset="utf-8"> | 
|  | <meta name="viewport" content="width=device-width,initial-scale=1"> | 
|  |  | 
|  |  | 
|  |  | 
|  | <link rel="shortcut icon" href="../../../assets/images/favicon.png"> | 
|  | <meta name="generator" content="mkdocs-1.1.2, mkdocs-material-5.4.0"> | 
|  |  | 
|  |  | 
|  |  | 
|  | <title>Scripting HTML Documents using Epsilon - Epsilon</title> | 
|  |  | 
|  |  | 
|  |  | 
|  | <link rel="stylesheet" href="../../../assets/stylesheets/main.fe0cca5b.min.css"> | 
|  |  | 
|  | <link rel="stylesheet" href="../../../assets/stylesheets/palette.a46bcfb3.min.css"> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <meta name="theme-color" content=""> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <link href="https://fonts.gstatic.com" rel="preconnect" crossorigin> | 
|  | <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto:300,400,400i,700%7CRoboto+Mono&display=fallback"> | 
|  | <style>body,input{font-family:"Roboto",-apple-system,BlinkMacSystemFont,Helvetica,Arial,sans-serif}code,kbd,pre{font-family:"Roboto Mono",SFMono-Regular,Consolas,Menlo,monospace}</style> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <link rel="stylesheet" href="../../../assets/stylesheets/mermaid.css"> | 
|  |  | 
|  | <link rel="stylesheet" href="../../../assets/javascript/google-code-prettify/prettify.css"> | 
|  |  | 
|  | <link rel="stylesheet" href="https://unpkg.com/mermaid@8.5.1/dist/mermaid.css"> | 
|  |  | 
|  | <link rel="stylesheet" href="../../../assets/stylesheets/slick.css"> | 
|  |  | 
|  | <link rel="stylesheet" href="../../../assets/stylesheets/slick-theme.css"> | 
|  |  | 
|  | <link rel="stylesheet" href="../../../assets/stylesheets/extra.css"> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <script> | 
|  | window.ga = window.ga || function() { | 
|  | (ga.q = ga.q || []).push(arguments) | 
|  | } | 
|  | ga.l = +new Date | 
|  | /* Setup integration and send page view */ | 
|  | ga("create", "UA-184785655-1", "auto") | 
|  | ga("set", "anonymizeIp", true) | 
|  | ga("send", "pageview") | 
|  | /* Register handler to log search on blur */ | 
|  | document.addEventListener("DOMContentLoaded", () => { | 
|  | if (document.forms.search) { | 
|  | var query = document.forms.search.query | 
|  | query.addEventListener("blur", function() { | 
|  | if (this.value) { | 
|  | var path = document.location.pathname; | 
|  | ga("send", "pageview", path + "?q=" + this.value) | 
|  | } | 
|  | }) | 
|  | } | 
|  | }) | 
|  | </script> | 
|  | <script async src="https://www.google-analytics.com/analytics.js"></script> | 
|  |  | 
|  |  | 
|  |  | 
|  | </head> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <body dir="ltr" data-md-color-scheme="" data-md-color-primary="black" data-md-color-accent="orange"> | 
|  |  | 
|  |  | 
|  | <input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off"> | 
|  | <input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off"> | 
|  | <label class="md-overlay" for="__drawer"></label> | 
|  | <div data-md-component="skip"> | 
|  |  | 
|  |  | 
|  | <a href="#scripting-html-documents-using-epsilon" class="md-skip"> | 
|  | Skip to content | 
|  | </a> | 
|  |  | 
|  | </div> | 
|  | <div data-md-component="announce"> | 
|  |  | 
|  | </div> | 
|  |  | 
|  | <header class="md-header" data-md-component="header"> | 
|  | <nav class="md-header-nav md-grid" aria-label="Header"> | 
|  | <a href="../../.." title="Epsilon" class="md-header-nav__button md-logo" aria-label="Epsilon"> | 
|  |  | 
|  | <img src="../../../assets/images/epsilon-white-background.png" alt="logo"> | 
|  |  | 
|  | </a> | 
|  | <label class="md-header-nav__button md-icon" for="__drawer"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3V6m0 5h18v2H3v-2m0 5h18v2H3v-2z"/></svg> | 
|  | </label> | 
|  | <div class="md-header-nav__title" data-md-component="header-title"> | 
|  |  | 
|  | <div class="md-header-nav__ellipsis"> | 
|  | <span class="md-header-nav__topic md-ellipsis"> | 
|  | Epsilon | 
|  | </span> | 
|  | <span class="md-header-nav__topic md-ellipsis"> | 
|  |  | 
|  | Scripting HTML Documents using Epsilon | 
|  |  | 
|  | </span> | 
|  | </div> | 
|  |  | 
|  | </div> | 
|  |  | 
|  | <label class="md-header-nav__button md-icon" for="__search"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0116 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 019.5 16 6.5 6.5 0 013 9.5 6.5 6.5 0 019.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5z"/></svg> | 
|  | </label> | 
|  |  | 
|  | <div class="md-search" data-md-component="search" role="dialog"> | 
|  | <label class="md-search__overlay" for="__search"></label> | 
|  | <div class="md-search__inner" role="search"> | 
|  | <form class="md-search__form" name="search"> | 
|  | <input type="text" class="md-search__input" name="query" aria-label="Search" placeholder="Search" autocapitalize="off" autocorrect="off" autocomplete="off" spellcheck="false" data-md-component="search-query" data-md-state="active"> | 
|  | <label class="md-search__icon md-icon" for="__search"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0116 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.516 6.516 0 019.5 16 6.5 6.5 0 013 9.5 6.5 6.5 0 019.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5z"/></svg> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg> | 
|  | </label> | 
|  | <button type="reset" class="md-search__icon md-icon" aria-label="Clear" data-md-component="search-reset" tabindex="-1"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12 19 6.41z"/></svg> | 
|  | </button> | 
|  | </form> | 
|  | <div class="md-search__output"> | 
|  | <div class="md-search__scrollwrap" data-md-scrollfix> | 
|  | <div class="md-search-result" data-md-component="search-result"> | 
|  | <div class="md-search-result__meta"> | 
|  | Initializing search | 
|  | </div> | 
|  | <ol class="md-search-result__list"></ol> | 
|  | </div> | 
|  | </div> | 
|  | </div> | 
|  | </div> | 
|  | </div> | 
|  |  | 
|  |  | 
|  | <div class="md-header-nav__source"> | 
|  |  | 
|  | <a href="https://git.eclipse.org/c/epsilon/org.eclipse.epsilon.git/" title="Go to repository" class="md-source"> | 
|  | <div class="md-source__icon md-icon"> | 
|  |  | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M439.55 236.05L244 40.45a28.87 28.87 0 00-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 01-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 000 40.81l195.61 195.6a28.86 28.86 0 0040.8 0l194.69-194.69a28.86 28.86 0 000-40.81z"/></svg> | 
|  | </div> | 
|  | <div class="md-source__repository"> | 
|  | Git repository @ Eclipse | 
|  | </div> | 
|  | </a> | 
|  | </div> | 
|  |  | 
|  | </nav> | 
|  | </header> | 
|  |  | 
|  | <div class="md-container" data-md-component="container"> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <main class="md-main" data-md-component="main"> | 
|  | <div class="md-main__inner md-grid"> | 
|  |  | 
|  |  | 
|  | <div class="md-sidebar md-sidebar--primary" data-md-component="navigation"> | 
|  | <div class="md-sidebar__scrollwrap"> | 
|  | <div class="md-sidebar__inner"> | 
|  | <nav class="md-nav md-nav--primary" aria-label="Navigation" data-md-level="0"> | 
|  | <label class="md-nav__title" for="__drawer"> | 
|  | <a href="../../.." title="Epsilon" class="md-nav__button md-logo" aria-label="Epsilon"> | 
|  |  | 
|  | <img src="../../../assets/images/epsilon-white-background.png" alt="logo"> | 
|  |  | 
|  | </a> | 
|  | Epsilon | 
|  | </label> | 
|  |  | 
|  | <div class="md-nav__source"> | 
|  |  | 
|  | <a href="https://git.eclipse.org/c/epsilon/org.eclipse.epsilon.git/" title="Go to repository" class="md-source"> | 
|  | <div class="md-source__icon md-icon"> | 
|  |  | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M439.55 236.05L244 40.45a28.87 28.87 0 00-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 01-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 000 40.81l195.61 195.6a28.86 28.86 0 0040.8 0l194.69-194.69a28.86 28.86 0 000-40.81z"/></svg> | 
|  | </div> | 
|  | <div class="md-source__repository"> | 
|  | Git repository @ Eclipse | 
|  | </div> | 
|  | </a> | 
|  | </div> | 
|  |  | 
|  | <ul class="md-nav__list" data-md-scrollfix> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../.." title="Home" class="md-nav__link"> | 
|  | Home | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../../download/" title="Download" class="md-nav__link"> | 
|  | Download | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../../getting-started/" title="Getting Started" class="md-nav__link"> | 
|  | Getting Started | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../../live" title="Playground" class="md-nav__link"> | 
|  | Playground | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item md-nav__item--nested"> | 
|  |  | 
|  | <input class="md-nav__toggle md-toggle" data-md-toggle="nav-5" type="checkbox" id="nav-5"> | 
|  |  | 
|  | <label class="md-nav__link" for="nav-5"> | 
|  | Documentation | 
|  | <span class="md-nav__icon md-icon"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M8.59 16.58L13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.42z"/></svg> | 
|  | </span> | 
|  | </label> | 
|  | <nav class="md-nav" aria-label="Documentation" data-md-level="1"> | 
|  | <label class="md-nav__title" for="nav-5"> | 
|  | <span class="md-nav__icon md-icon"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg> | 
|  | </span> | 
|  | Documentation | 
|  | </label> | 
|  | <ul class="md-nav__list" data-md-scrollfix> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../" title="Overview" class="md-nav__link"> | 
|  | Overview | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../emc/" title="Model Connectivity" class="md-nav__link"> | 
|  | Model Connectivity | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item md-nav__item--nested"> | 
|  |  | 
|  | <input class="md-nav__toggle md-toggle" data-md-toggle="nav-5-3" type="checkbox" id="nav-5-3"> | 
|  |  | 
|  | <label class="md-nav__link" for="nav-5-3"> | 
|  | Languages | 
|  | <span class="md-nav__icon md-icon"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M8.59 16.58L13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.42z"/></svg> | 
|  | </span> | 
|  | </label> | 
|  | <nav class="md-nav" aria-label="Languages" data-md-level="2"> | 
|  | <label class="md-nav__title" for="nav-5-3"> | 
|  | <span class="md-nav__icon md-icon"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg> | 
|  | </span> | 
|  | Languages | 
|  | </label> | 
|  | <ul class="md-nav__list" data-md-scrollfix> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../eol/" title="Object Language (EOL)" class="md-nav__link"> | 
|  | Object Language (EOL) | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../egl/" title="Code Generation (EGL)" class="md-nav__link"> | 
|  | Code Generation (EGL) | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../evl/" title="Model Validation (EVL)" class="md-nav__link"> | 
|  | Model Validation (EVL) | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../etl/" title="Model Transformation (ETL)" class="md-nav__link"> | 
|  | Model Transformation (ETL) | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../ecl/" title="Model Comparison (ECL)" class="md-nav__link"> | 
|  | Model Comparison (ECL) | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../eml/" title="Model Merging (EML)" class="md-nav__link"> | 
|  | Model Merging (EML) | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../epl/" title="Pattern Matching (EPL)" class="md-nav__link"> | 
|  | Pattern Matching (EPL) | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../flock/" title="Model Migration (Flock)" class="md-nav__link"> | 
|  | Model Migration (Flock) | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../emg/" title="Model Generation (EMG)" class="md-nav__link"> | 
|  | Model Generation (EMG) | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../eunit/" title="Unit Testing (EUnit)" class="md-nav__link"> | 
|  | Unit Testing (EUnit) | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../pinset/" title="Dataset Extraction (Pinset)" class="md-nav__link"> | 
|  | Dataset Extraction (Pinset) | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../ewl/" title="Wizard Language (EWL)" class="md-nav__link"> | 
|  | Wizard Language (EWL) | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  | </ul> | 
|  | </nav> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item md-nav__item--nested"> | 
|  |  | 
|  | <input class="md-nav__toggle md-toggle" data-md-toggle="nav-5-4" type="checkbox" id="nav-5-4"> | 
|  |  | 
|  | <label class="md-nav__link" for="nav-5-4"> | 
|  | Tools | 
|  | <span class="md-nav__icon md-icon"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M8.59 16.58L13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.42z"/></svg> | 
|  | </span> | 
|  | </label> | 
|  | <nav class="md-nav" aria-label="Tools" data-md-level="2"> | 
|  | <label class="md-nav__title" for="nav-5-4"> | 
|  | <span class="md-nav__icon md-icon"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg> | 
|  | </span> | 
|  | Tools | 
|  | </label> | 
|  | <ul class="md-nav__list" data-md-scrollfix> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../picto/" title="Picto" class="md-nav__link"> | 
|  | Picto | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../flexmi/" title="Flexmi" class="md-nav__link"> | 
|  | Flexmi | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../eugenia/" title="Eugenia" class="md-nav__link"> | 
|  | Eugenia | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../exeed/" title="Exeed" class="md-nav__link"> | 
|  | Exeed | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../modelink/" title="Modelink" class="md-nav__link"> | 
|  | Modelink | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../hutn/" title="HUTN" class="md-nav__link"> | 
|  | HUTN | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../workflow/" title="Workflow (Ant tasks)" class="md-nav__link"> | 
|  | Workflow (Ant tasks) | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  | </ul> | 
|  | </nav> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../" title="Articles" class="md-nav__link"> | 
|  | Articles | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../../examples/" title="Examples" class="md-nav__link"> | 
|  | Examples | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="https://www.youtube.com/epsilondevs" title="Screencasts" class="md-nav__link"> | 
|  | Screencasts | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="https://www.youtube.com/playlist?list=PLRwHao6Ue0YUecg7vEUQTrtySIWwrd_mI" title="Lectures" class="md-nav__link"> | 
|  | Lectures | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item md-nav__item--nested"> | 
|  |  | 
|  | <input class="md-nav__toggle md-toggle" data-md-toggle="nav-5-9" type="checkbox" id="nav-5-9"> | 
|  |  | 
|  | <label class="md-nav__link" for="nav-5-9"> | 
|  | Javadoc | 
|  | <span class="md-nav__icon md-icon"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M8.59 16.58L13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.42z"/></svg> | 
|  | </span> | 
|  | </label> | 
|  | <nav class="md-nav" aria-label="Javadoc" data-md-level="2"> | 
|  | <label class="md-nav__title" for="nav-5-9"> | 
|  | <span class="md-nav__icon md-icon"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg> | 
|  | </span> | 
|  | Javadoc | 
|  | </label> | 
|  | <ul class="md-nav__list" data-md-scrollfix> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="https://download.eclipse.org/epsilon/stable-javadoc/" title="Stable" class="md-nav__link"> | 
|  | Stable | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="https://download.eclipse.org/epsilon/interim-javadoc/" title="Interim" class="md-nav__link"> | 
|  | Interim | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  | </ul> | 
|  | </nav> | 
|  | </li> | 
|  |  | 
|  |  | 
|  | </ul> | 
|  | </nav> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item md-nav__item--nested"> | 
|  |  | 
|  | <input class="md-nav__toggle md-toggle" data-md-toggle="nav-6" type="checkbox" id="nav-6"> | 
|  |  | 
|  | <label class="md-nav__link" for="nav-6"> | 
|  | Issues | 
|  | <span class="md-nav__icon md-icon"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M8.59 16.58L13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.42z"/></svg> | 
|  | </span> | 
|  | </label> | 
|  | <nav class="md-nav" aria-label="Issues" data-md-level="1"> | 
|  | <label class="md-nav__title" for="nav-6"> | 
|  | <span class="md-nav__icon md-icon"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg> | 
|  | </span> | 
|  | Issues | 
|  | </label> | 
|  | <ul class="md-nav__list" data-md-scrollfix> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="https://bugs.eclipse.org/bugs/enter_bug.cgi?product=epsilon" title="Report a new issue" class="md-nav__link"> | 
|  | Report a new issue | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="https://bugs.eclipse.org/bugs/buglist.cgi?product=epsilon&cmdtype=doit&order=Reuse+same+sort+as+last+time&bug_status=UNCONFIRMED&bug_status=NEW&bug_status=ASSIGNED&bug_status=REOPENED&bug_severity=blocker&bug_severity=critical&bug_severity=major&bug_severity=normal&bug_severity=minor&bug_severity=trivial" title="View open bugs" class="md-nav__link"> | 
|  | View open bugs | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="https://bugs.eclipse.org/bugs/buglist.cgi?product=epsilon&cmdtype=doit&order=Reuse+same+sort+as+last+time&bug_status=UNCONFIRMED&bug_status=NEW&bug_status=ASSIGNED&bug_status=REOPENED&bug_severity=enhancement" title="View enhancement requests" class="md-nav__link"> | 
|  | View enhancement requests | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="https://bugs.eclipse.org/bugs/buglist.cgi?bug_status=RESOLVED&list_id=17694438&product=epsilon&query_format=advanced" title="View issues resolved since the last stable release" class="md-nav__link"> | 
|  | View issues resolved since the last stable release | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="https://bugs.eclipse.org/bugs/buglist.cgi?product=epsilon&cmdtype=doit&order=Reuse+same+sort+as+last+time" title="View all issues" class="md-nav__link"> | 
|  | View all issues | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  | </ul> | 
|  | </nav> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item md-nav__item--nested"> | 
|  |  | 
|  | <input class="md-nav__toggle md-toggle" data-md-toggle="nav-7" type="checkbox" id="nav-7"> | 
|  |  | 
|  | <label class="md-nav__link" for="nav-7"> | 
|  | Community | 
|  | <span class="md-nav__icon md-icon"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M8.59 16.58L13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.42z"/></svg> | 
|  | </span> | 
|  | </label> | 
|  | <nav class="md-nav" aria-label="Community" data-md-level="1"> | 
|  | <label class="md-nav__title" for="nav-7"> | 
|  | <span class="md-nav__icon md-icon"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg> | 
|  | </span> | 
|  | Community | 
|  | </label> | 
|  | <ul class="md-nav__list" data-md-scrollfix> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item md-nav__item--nested"> | 
|  |  | 
|  | <input class="md-nav__toggle md-toggle" data-md-toggle="nav-7-1" type="checkbox" id="nav-7-1"> | 
|  |  | 
|  | <label class="md-nav__link" for="nav-7-1"> | 
|  | Who is using Epsilon? | 
|  | <span class="md-nav__icon md-icon"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M8.59 16.58L13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.42z"/></svg> | 
|  | </span> | 
|  | </label> | 
|  | <nav class="md-nav" aria-label="Who is using Epsilon?" data-md-level="2"> | 
|  | <label class="md-nav__title" for="nav-7-1"> | 
|  | <span class="md-nav__icon md-icon"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg> | 
|  | </span> | 
|  | Who is using Epsilon? | 
|  | </label> | 
|  | <ul class="md-nav__list" data-md-scrollfix> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../../users/" title="Industry" class="md-nav__link"> | 
|  | Industry | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../../users/education/" title="Education" class="md-nav__link"> | 
|  | Education | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../../users/open-source/" title="Open-source Projects" class="md-nav__link"> | 
|  | Open-source Projects | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  | </ul> | 
|  | </nav> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="https://projects.eclipse.org/projects/modeling.epsilon/who" title="Who is developing Epsilon?" class="md-nav__link"> | 
|  | Who is developing Epsilon? | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="https://www.eclipse.org/forums/index.php/f/22/" title="Forum" class="md-nav__link"> | 
|  | Forum | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../../professional-services" title="Professional Services" class="md-nav__link"> | 
|  | Professional Services | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item md-nav__item--nested"> | 
|  |  | 
|  | <input class="md-nav__toggle md-toggle" data-md-toggle="nav-7-5" type="checkbox" id="nav-7-5"> | 
|  |  | 
|  | <label class="md-nav__link" for="nav-7-5"> | 
|  | Social Media | 
|  | <span class="md-nav__icon md-icon"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M8.59 16.58L13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.42z"/></svg> | 
|  | </span> | 
|  | </label> | 
|  | <nav class="md-nav" aria-label="Social Media" data-md-level="2"> | 
|  | <label class="md-nav__title" for="nav-7-5"> | 
|  | <span class="md-nav__icon md-icon"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11h12z"/></svg> | 
|  | </span> | 
|  | Social Media | 
|  | </label> | 
|  | <ul class="md-nav__list" data-md-scrollfix> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="https://twitter.com/eclipseepsilon" title="Twitter" class="md-nav__link"> | 
|  | Twitter | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="https://youtube.com/epsilondevs" title="YouTube" class="md-nav__link"> | 
|  | YouTube | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  | </ul> | 
|  | </nav> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../../labs/" title="Epsilon Labs" class="md-nav__link"> | 
|  | Epsilon Labs | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../../faq/" title="Frequently Asked Questions" class="md-nav__link"> | 
|  | Frequently Asked Questions | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  | </ul> | 
|  | </nav> | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="../../../branding/" title="Branding" class="md-nav__link"> | 
|  | Branding | 
|  | </a> | 
|  | </li> | 
|  |  | 
|  |  | 
|  | </ul> | 
|  | </nav> | 
|  | </div> | 
|  | </div> | 
|  | </div> | 
|  |  | 
|  |  | 
|  | <div class="md-sidebar md-sidebar--secondary" data-md-component="toc"> | 
|  | <div class="md-sidebar__scrollwrap"> | 
|  | <div class="md-sidebar__inner"> | 
|  |  | 
|  | <nav class="md-nav md-nav--secondary"> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <label class="md-nav__title" for="__toc">Table of contents</label> | 
|  | <ul class="md-nav__list" data-md-scrollfix> | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="#querying-a-html-document" class="md-nav__link"> | 
|  | Querying a HTML document | 
|  | </a> | 
|  |  | 
|  | </li> | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="#queryingmodifying-html-documents-in-eol" class="md-nav__link"> | 
|  | Querying/modifying HTML documents in EOL | 
|  | </a> | 
|  |  | 
|  | </li> | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="#how-can-i-access-elements-by-tag-name" class="md-nav__link"> | 
|  | How can I access elements by tag name? | 
|  | </a> | 
|  |  | 
|  | <nav class="md-nav" aria-label="How can I access elements by tag name?"> | 
|  | <ul class="md-nav__list"> | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="#how-can-i-get-the-tag-name-of-an-element" class="md-nav__link"> | 
|  | How can I get the tag name of an element? | 
|  | </a> | 
|  |  | 
|  | </li> | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="#how-can-i-getset-the-attributes-of-an-element" class="md-nav__link"> | 
|  | How can I get/set the attributes of an element? | 
|  | </a> | 
|  |  | 
|  | </li> | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="#how-can-i-getset-the-text-of-an-element" class="md-nav__link"> | 
|  | How can I get/set the text of an element? | 
|  | </a> | 
|  |  | 
|  | </li> | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="#how-do-i-get-the-parent-of-an-element" class="md-nav__link"> | 
|  | How do I get the parent of an element? | 
|  | </a> | 
|  |  | 
|  | </li> | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="#how-do-i-get-the-children-of-an-element" class="md-nav__link"> | 
|  | How do I get the children of an element? | 
|  | </a> | 
|  |  | 
|  | </li> | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="#how-do-i-get-child-elements-with-a-specific-tag-name" class="md-nav__link"> | 
|  | How do I get child elements with a specific tag name? | 
|  | </a> | 
|  |  | 
|  | </li> | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="#how-do-i-create-an-element" class="md-nav__link"> | 
|  | How do I create an element? | 
|  | </a> | 
|  |  | 
|  | </li> | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="#how-can-i-add-a-child-to-an-existing-element" class="md-nav__link"> | 
|  | How can I add a child to an existing element? | 
|  | </a> | 
|  |  | 
|  | </li> | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="#bringing-it-all-together" class="md-nav__link"> | 
|  | Bringing it all together | 
|  | </a> | 
|  |  | 
|  | </li> | 
|  |  | 
|  | </ul> | 
|  | </nav> | 
|  |  | 
|  | </li> | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="#adding-a-html-document-to-your-launch-configuration" class="md-nav__link"> | 
|  | Adding a HTML document to your launch configuration | 
|  | </a> | 
|  |  | 
|  | </li> | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="#loading-a-html-document-in-your-ant-buildfile" class="md-nav__link"> | 
|  | Loading a HTML document in your ANT buildfile | 
|  | </a> | 
|  |  | 
|  | </li> | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="#loading-a-html-document-through-java-code" class="md-nav__link"> | 
|  | Loading a HTML document through Java code | 
|  | </a> | 
|  |  | 
|  | </li> | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="#loading-a-remote-html-document-in-gradle" class="md-nav__link"> | 
|  | Loading a remote HTML document in Gradle | 
|  | </a> | 
|  |  | 
|  | </li> | 
|  |  | 
|  | <li class="md-nav__item"> | 
|  | <a href="#additional-resources" class="md-nav__link"> | 
|  | Additional resources | 
|  | </a> | 
|  |  | 
|  | </li> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | </ul> | 
|  |  | 
|  |  | 
|  | </nav> | 
|  | </div> | 
|  | </div> | 
|  | </div> | 
|  |  | 
|  |  | 
|  | <div class="md-content"> | 
|  | <article class="md-content__inner md-typeset"> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <h1 id="scripting-html-documents-using-epsilon">Scripting HTML Documents using Epsilon<a class="headerlink" href="#scripting-html-documents-using-epsilon" title="Permanent link">¶</a></h1> | 
|  | <p>In this article we demonstrate how you can create, query and modify HTML documents in Epsilon programs using the HTML driver. All the examples in this article demonstrate using EOL to script HTML documents. However, it's worth stressing that HTML documents are supported throughout Epsilon. Therefore, you can use Epsilon to (cross-)validate, transform (to other models or to text), compare and merge your HTML documents.</p> | 
|  | <h2 id="querying-a-html-document">Querying a HTML document<a class="headerlink" href="#querying-a-html-document" title="Permanent link">¶</a></h2> | 
|  | <p>We use the following <code>sales.html</code> as a base for demonstrating the EOL syntax for querying HTML documents.</p> | 
|  | <div class="highlight"><pre><span></span><code><span class="p"><</span><span class="nt">html</span><span class="p">></span> | 
|  | <span class="p"><</span><span class="nt">body</span><span class="p">></span> | 
|  | <span class="p"><</span><span class="nt">table</span> <span class="na">border</span><span class="o">=</span><span class="s">"1"</span><span class="p">></span> | 
|  | <span class="p"><</span><span class="nt">thead</span><span class="p">></span> | 
|  | <span class="p"><</span><span class="nt">tr</span><span class="p">></span> | 
|  | <span class="p"><</span><span class="nt">th</span><span class="p">></span>Product id<span class="p"></</span><span class="nt">th</span><span class="p">></span> | 
|  | <span class="p"><</span><span class="nt">th</span><span class="p">></span>Unit price<span class="p"></</span><span class="nt">th</span><span class="p">></span> | 
|  | <span class="p"><</span><span class="nt">th</span><span class="p">></span>Quantity<span class="p"></</span><span class="nt">th</span><span class="p">></span> | 
|  | <span class="p"></</span><span class="nt">tr</span><span class="p">></span> | 
|  | <span class="p"></</span><span class="nt">thead</span><span class="p">></span> | 
|  | <span class="p"><</span><span class="nt">tbody</span><span class="p">></span> | 
|  | <span class="p"><</span><span class="nt">tr</span><span class="p">></span> | 
|  | <span class="p"><</span><span class="nt">td</span><span class="p">></span>P1<span class="p"></</span><span class="nt">td</span><span class="p">></span> | 
|  | <span class="p"><</span><span class="nt">td</span><span class="p">></span>10<span class="p"></</span><span class="nt">td</span><span class="p">></span> | 
|  | <span class="p"><</span><span class="nt">td</span><span class="p">></span>15<span class="p"></</span><span class="nt">td</span><span class="p">></span> | 
|  | <span class="p"></</span><span class="nt">tr</span><span class="p">></span> | 
|  | <span class="p"><</span><span class="nt">tr</span><span class="p">></span> | 
|  | <span class="p"><</span><span class="nt">td</span><span class="p">></span>P2<span class="p"></</span><span class="nt">td</span><span class="p">></span> | 
|  | <span class="p"><</span><span class="nt">td</span><span class="p">></span>8<span class="p"></</span><span class="nt">td</span><span class="p">></span> | 
|  | <span class="p"><</span><span class="nt">td</span><span class="p">></span>12<span class="p"></</span><span class="nt">td</span><span class="p">></span> | 
|  | <span class="p"></</span><span class="nt">tr</span><span class="p">></span> | 
|  | <span class="p"></</span><span class="nt">tbody</span><span class="p">></span> | 
|  | <span class="p"></</span><span class="nt">table</span><span class="p">></span> | 
|  | <span class="p"></</span><span class="nt">body</span><span class="p">></span> | 
|  | <span class="p"></</span><span class="nt">html</span><span class="p">></span> | 
|  | </code></pre></div> | 
|  |  | 
|  | <h2 id="queryingmodifying-html-documents-in-eol">Querying/modifying HTML documents in EOL<a class="headerlink" href="#queryingmodifying-html-documents-in-eol" title="Permanent link">¶</a></h2> | 
|  | <p>The HTML driver uses predefined naming conventions to allow developers to programmatically access and modify HTML documents in a concise way. This section outlines the supported conventions in the form of questions and answers followed by relevant examples.</p> | 
|  | <h2 id="how-can-i-access-elements-by-tag-name">How can I access elements by tag name?<a class="headerlink" href="#how-can-i-access-elements-by-tag-name" title="Permanent link">¶</a></h2> | 
|  | <p>The <code>t_</code> prefix in front of the name of the tag is used to represent a type, instances of which are all the elements with that tag. For instance, <code>t_td.all</code> can be used to get all elements tagged as <code><td></code> (table cells) in the document, <code>t_tr.all</code> to retrieve all <code><tr></code> elements (table rows) etc. Also, if <code>cell</code> is an element with a <code><td></code> tag, then <code>cell.isTypeOf(t_td)</code> shall return true.</p> | 
|  | <pre class="prettyprint lang-eol"><code>// Get all <td> elements | 
|  | var cells = t_td.all; | 
|  |  | 
|  | // Get a random table cell | 
|  | var cell = cells.random(); | 
|  |  | 
|  | // Check if cell is a td | 
|  | // Prints 'true' | 
|  | cell.isTypeOf(t_td).println(); | 
|  |  | 
|  | // Check if cell is a tr | 
|  | // Prints 'false' | 
|  | cell.isTypeOf(t_tr).println();</code></pre> | 
|  |  | 
|  | <h3 id="how-can-i-get-the-tag-name-of-an-element">How can I get the tag name of an element?<a class="headerlink" href="#how-can-i-get-the-tag-name-of-an-element" title="Permanent link">¶</a></h3> | 
|  | <p>You can use the <code>.tagName</code> property for this purpose. For instance, if <code>cell</code> is an element tagged as <code><td></code>, <code>cell.tagName</code> shall return <code>td</code>. The <code>tagName</code> property is read-only.</p> | 
|  | <pre class="prettyprint lang-eol"><code>// Get a random <td> element | 
|  | var cell = t_td.all.random(); | 
|  |  | 
|  | // Print its tag | 
|  | // Prints 'td' | 
|  | cell.tagName.println();</code></pre> | 
|  |  | 
|  | <h3 id="how-can-i-getset-the-attributes-of-an-element">How can I get/set the attributes of an element?<a class="headerlink" href="#how-can-i-getset-the-attributes-of-an-element" title="Permanent link">¶</a></h3> | 
|  | <p>You can use the attribute name as a property of the element object, prefixed by <code>a_</code>. For example, if <code>t</code> is the first table of <code>sales.html</code>, <code>t.a_border</code> will return <code>1</code>. Attribute properties are read/write.</p> | 
|  | <p>In this example, <code>t.a_border</code> will return <code>1</code> as a string. For <code>1</code> to be returned as an integer instead, the <code>i_</code> prefix should be used instead (i.e. <code>t.i_border</code>. The driver also supports the following preffixes: <code>b_</code> for boolean, <code>s_</code> for string (alias of <code>a_</code>) and <code>r_</code> for real values. </p> | 
|  | <pre class="prettyprint lang-eol"><code>// Get the one and only table in the document | 
|  | var table = t_table.all.first(); | 
|  |  | 
|  | // Prints 11 (the border attribute is retrieved as string) | 
|  | (table.a_border + 1).println(); | 
|  |  | 
|  | // Prints 2 (the border attribute is retrieved as integer) | 
|  | (table.i_border + 1).println();</code></pre> | 
|  |  | 
|  | <h3 id="how-can-i-getset-the-text-of-an-element">How can I get/set the text of an element?<a class="headerlink" href="#how-can-i-getset-the-text-of-an-element" title="Permanent link">¶</a></h3> | 
|  | <p>You can use the <code>.text</code> read-write property for this.</p> | 
|  | <pre class="prettyprint lang-eol"><code>for (cell in t_td.all) { | 
|  | cell.text.println(); | 
|  | }</code></pre> | 
|  |  | 
|  | <h3 id="how-do-i-get-the-parent-of-an-element">How do I get the parent of an element?<a class="headerlink" href="#how-do-i-get-the-parent-of-an-element" title="Permanent link">¶</a></h3> | 
|  | <p>You can use the <code>.parentNode</code> read-only property to retrieve the element's immediate parent and the <code>.parents.</code> read-only property to retrieve all the ancestors of the element.</p> | 
|  | <pre class="prettyprint lang-eol"><code>// Get a random cell | 
|  | var cell = t_td.all.random(); | 
|  |  | 
|  | // Print the tag of its parent node | 
|  | // Prints 'tr' | 
|  | cell.parentNode.tagName.println(); | 
|  |  | 
|  | // Print the tags of all its ancestors | 
|  | // Prints 'Sequence {tr, tbody, table, body, html}' | 
|  | cell.parents.tagName.println();</code></pre> | 
|  |  | 
|  | <h3 id="how-do-i-get-the-children-of-an-element">How do I get the children of an element?<a class="headerlink" href="#how-do-i-get-the-children-of-an-element" title="Permanent link">¶</a></h3> | 
|  | <p>You can use the <code>.children</code> read-only property for this.</p> | 
|  | <pre class="prettyprint lang-eol"><code>// Get the <tbody> element | 
|  | var tbody = t_tbody.all.first(); | 
|  |  | 
|  | // Iterate through its children | 
|  | for (tr in tbody.children) { | 
|  | // Print the tag of each child | 
|  | tr.tagName.println(); | 
|  | }</code></pre> | 
|  |  | 
|  | <h3 id="how-do-i-get-child-elements-with-a-specific-tag-name">How do I get child elements with a specific tag name?<a class="headerlink" href="#how-do-i-get-child-elements-with-a-specific-tag-name" title="Permanent link">¶</a></h3> | 
|  | <p>Using what you've learned so far, you can do this using a combination of the <code>.children</code> property and the select/selectOne() operations. However, the driver also supports <code>e_</code> and <code>c_</code>-prefixed shorthand properties for accessing one or a collection of elements with the specified name respectively. <code>e_</code> and <code>c_</code> properties are read-only.</p> | 
|  | <pre class="prettyprint lang-eol"><code>// Get a random tr | 
|  | var row = t_tr.all.random(); | 
|  |  | 
|  | // Get its <td> children using the | 
|  | // .children property | 
|  | var cells = row.children.select(a|a.tagName = "td"); | 
|  |  | 
|  | // Do the same using the shorthand | 
|  | cells = row.c_td; | 
|  |  | 
|  | // Get the first td child of the row | 
|  | row.e_td.text.println();</code></pre> | 
|  |  | 
|  | <h3 id="how-do-i-create-an-element">How do I create an element?<a class="headerlink" href="#how-do-i-create-an-element" title="Permanent link">¶</a></h3> | 
|  | <p>You can use the <code>new</code> operator for this. </p> | 
|  | <pre class="prettyprint lang-eol"><code>// Check how many <tr> are in the document | 
|  | // Prints '3' | 
|  | t_tr.all.size().println(); | 
|  |  | 
|  | // Creates a new tr element | 
|  | var row = new t_tr; | 
|  |  | 
|  | // Check again | 
|  | // Prints '4' | 
|  | t_tr.all.size().println();</code></pre> | 
|  |  | 
|  | <h3 id="how-can-i-add-a-child-to-an-existing-element">How can I add a child to an existing element?<a class="headerlink" href="#how-can-i-add-a-child-to-an-existing-element" title="Permanent link">¶</a></h3> | 
|  | <p>You can use the <code>.appendChild(child)</code> operation for this.</p> | 
|  | <pre class="prettyprint lang-eol"><code>// Create a new row | 
|  | var row = new t_tr; | 
|  |  | 
|  | // Get the tbody element | 
|  | var tbody = t_tbody.all.first(); | 
|  |  | 
|  | // Add the book to the library | 
|  | tbody.appendChild(row);</code></pre> | 
|  |  | 
|  | <h3 id="bringing-it-all-together">Bringing it all together<a class="headerlink" href="#bringing-it-all-together" title="Permanent link">¶</a></h3> | 
|  | <p>The following snippet computes and prints the total sales revenue.</p> | 
|  | <pre class="prettyprint lang-eol"><code>var table = t_table.all.first(); | 
|  |  | 
|  | var sum : Real; | 
|  |  | 
|  | // Iterate only through the rows under tbody | 
|  | for (tr in table.e_tbody.c_tr) { | 
|  | sum = sum + tr.c_td.at(1).getRealValue() * | 
|  | tr.c_td.at(2).getRealValue(); | 
|  | } | 
|  |  | 
|  | // Prints 246.0 | 
|  | sum.println(); | 
|  |  | 
|  | operation t_td getRealValue() { | 
|  | return self.text.asReal(); | 
|  | } | 
|  | </code></pre> | 
|  |  | 
|  | <h2 id="adding-a-html-document-to-your-launch-configuration">Adding a HTML document to your launch configuration<a class="headerlink" href="#adding-a-html-document-to-your-launch-configuration" title="Permanent link">¶</a></h2> | 
|  | <p>To add a HTML document to your Epsilon launch configuration, you need to select "HTML document" from the list of available model types.</p> | 
|  | <p><img alt="" src="select.png" /></p> | 
|  | <p>Then you can configure the details of your document (name, file etc.) in the screen that pops up. To load a HTML document that is not in the Eclipse workspace, untick the "Workspace file" check box and provide a full uri for your document (e.g. <code>http://www.google.com</code> or <code>file:/c:/myhtml.html</code>). </p> | 
|  | <p><img alt="" src="configure.png" /></p> | 
|  | <h2 id="loading-a-html-document-in-your-ant-buildfile">Loading a HTML document in your ANT buildfile<a class="headerlink" href="#loading-a-html-document-in-your-ant-buildfile" title="Permanent link">¶</a></h2> | 
|  | <p>The following ANT build file demonstrates how you can use ANT to load/store and process HTML documents with Epsilon.</p> | 
|  | <div class="highlight"><pre><span></span><code><span class="nt"><project</span> <span class="na">default=</span><span class="s">"main"</span><span class="nt">></span> | 
|  | <span class="nt"><target</span> <span class="na">name=</span><span class="s">"main"</span><span class="nt">></span> | 
|  |  | 
|  | <span class="nt"><epsilon.loadModel</span> <span class="na">name=</span><span class="s">"M"</span> <span class="na">type=</span><span class="s">"HTML"</span><span class="nt">></span> | 
|  | <span class="nt"><parameter</span> <span class="na">name=</span><span class="s">"readOnLoad"</span> <span class="na">value=</span><span class="s">"true"</span><span class="nt">/></span> | 
|  | <span class="nt"><parameter</span> <span class="na">name=</span><span class="s">"storeOnDisposal"</span> <span class="na">value=</span><span class="s">"false"</span><span class="nt">/></span> | 
|  | <span class="nt"><parameter</span> <span class="na">name=</span><span class="s">"file"</span> <span class="na">file=</span><span class="s">"sales.html"</span><span class="nt">/></span> | 
|  | <span class="nt"></epsilon.loadModel></span> | 
|  |  | 
|  | <span class="nt"><epsilon.eol</span> <span class="na">src=</span><span class="s">"sales.eol"</span><span class="nt">></span> | 
|  | <span class="nt"><model</span> <span class="na">ref=</span><span class="s">"M"</span><span class="nt">/></span> | 
|  | <span class="nt"></epsilon.eol></span> | 
|  |  | 
|  | <span class="nt"></target></span> | 
|  | <span class="nt"></project></span> | 
|  | </code></pre></div> | 
|  |  | 
|  | <h2 id="loading-a-html-document-through-java-code">Loading a HTML document through Java code<a class="headerlink" href="#loading-a-html-document-through-java-code" title="Permanent link">¶</a></h2> | 
|  | <p>The following excerpt demonstrates using HTML models using Epsilon's Java API.</p> | 
|  | <div class="highlight"><pre><span></span><code><span class="n">EolModule</span> <span class="n">module</span> <span class="o">=</span> <span class="k">new</span> <span class="n">EolModule</span><span class="o">();</span> | 
|  | <span class="n">module</span><span class="o">.</span><span class="na">parse</span><span class="o">(</span><span class="k">new</span> <span class="n">File</span><span class="o">(</span><span class="s">"..."</span><span class="o">));</span> | 
|  |  | 
|  | <span class="n">HtmlModel</span> <span class="n">model</span> <span class="o">=</span> <span class="k">new</span> <span class="n">HtmlModel</span><span class="o">();</span> | 
|  | <span class="n">model</span><span class="o">.</span><span class="na">setName</span><span class="o">(</span><span class="s">"M"</span><span class="o">);</span> | 
|  | <span class="n">model</span><span class="o">.</span><span class="na">setFile</span><span class="o">(</span><span class="k">new</span> <span class="n">File</span><span class="o">(</span><span class="s">"..."</span><span class="o">));</span> | 
|  | <span class="n">model</span><span class="o">.</span><span class="na">load</span><span class="o">();</span> | 
|  |  | 
|  | <span class="n">module</span><span class="o">.</span><span class="na">getContext</span><span class="o">().</span><span class="na">getModelRepository</span><span class="o">().</span><span class="na">addModel</span><span class="o">(</span><span class="n">model</span><span class="o">);</span> | 
|  | <span class="n">module</span><span class="o">.</span><span class="na">getContext</span><span class="o">().</span><span class="na">setModule</span><span class="o">(</span><span class="n">module</span><span class="o">);</span> | 
|  | <span class="n">module</span><span class="o">.</span><span class="na">execute</span><span class="o">();</span> | 
|  | </code></pre></div> | 
|  |  | 
|  | <h2 id="loading-a-remote-html-document-in-gradle">Loading a remote HTML document in Gradle<a class="headerlink" href="#loading-a-remote-html-document-in-gradle" title="Permanent link">¶</a></h2> | 
|  | <p>The example below shows a standalone Gradle file (<code>build.gradle</code>) that runs a set of EOL queries (<code>queries.eol</code>) against the HTML behind the Epsilon homepage.</p> | 
|  | <div class="tabbed-set" data-tabs="1:2"><input checked="checked" id="__tabbed_1_1" name="__tabbed_1" type="radio" /><label for="__tabbed_1_1">build.gradle</label><div class="tabbed-content"> | 
|  | <div class="highlight"><pre><span></span><code><span class="n">configurations</span> <span class="o">{</span> | 
|  | <span class="n">epsilon</span> | 
|  | <span class="o">}</span> | 
|  |  | 
|  | <span class="n">repositories</span> <span class="o">{</span> | 
|  | <span class="n">maven</span> <span class="o">{</span> | 
|  | <span class="n">url</span> <span class="s2">"https://oss.sonatype.org/content/repositories/snapshots"</span> | 
|  | <span class="o">}</span> | 
|  | <span class="n">mavenCentral</span><span class="o">()</span> | 
|  | <span class="o">}</span> | 
|  |  | 
|  | <span class="n">dependencies</span> <span class="o">{</span> | 
|  | <span class="n">epsilon</span> <span class="s1">'org.eclipse.epsilon:org.eclipse.epsilon.workflow:2.3.0-SNAPSHOT'</span> | 
|  | <span class="n">epsilon</span> <span class="s1">'org.eclipse.epsilon:org.eclipse.epsilon.emc.html:2.3.0-SNAPSHOT'</span> | 
|  | <span class="o">}</span> | 
|  |  | 
|  | <span class="n">task</span> <span class="n">setupEpsilonTasks</span> <span class="o">{</span> | 
|  | <span class="c1">// Set up the core Epsilon tasks</span> | 
|  | <span class="n">ant</span><span class="o">.</span><span class="na">taskdef</span><span class="o">(</span><span class="nl">resource:</span> <span class="s1">'org/eclipse/epsilon/workflow/tasks/tasks.xml'</span><span class="o">,</span> | 
|  | <span class="nl">classpath:</span> <span class="n">configurations</span><span class="o">.</span><span class="na">epsilon</span><span class="o">.</span><span class="na">asPath</span><span class="o">,</span> <span class="nl">loaderref:</span> <span class="s1">'epsilon'</span><span class="o">)</span> | 
|  | <span class="c1">// Set logging level to info so that EOL's println() is not suppressed</span> | 
|  | <span class="n">ant</span><span class="o">.</span><span class="na">lifecycleLogLevel</span> <span class="o">=</span> <span class="s1">'INFO'</span> | 
|  | <span class="o">}</span> | 
|  |  | 
|  | <span class="n">task</span> <span class="n">run</span> <span class="o">{</span> | 
|  | <span class="n">dependsOn</span> <span class="n">tasks</span><span class="o">.</span><span class="na">setupEpsilonTasks</span> | 
|  | <span class="c1">// Load the eclipse.org/epsilon webpage as a HTML model</span> | 
|  | <span class="n">ant</span><span class="o">.</span><span class="s1">'epsilon.loadModel'</span><span class="o">(</span><span class="nl">name:</span> <span class="s1">'HTML'</span><span class="o">,</span> <span class="nl">type:</span> <span class="s1">'HTML'</span><span class="o">,</span> | 
|  | <span class="nl">impl:</span> <span class="s1">'org.eclipse.epsilon.emc.html.HtmlModel'</span><span class="o">,)</span> | 
|  | <span class="o">{</span> <span class="n">parameter</span><span class="o">(</span><span class="nl">name:</span> <span class="s1">'uri'</span><span class="o">,</span> <span class="nl">value:</span> <span class="s1">'https://www.eclipse.org/epsilon/'</span><span class="o">)</span> <span class="o">}</span> | 
|  |  | 
|  | <span class="c1">// Run query.eol against it</span> | 
|  | <span class="n">ant</span><span class="o">.</span><span class="s1">'epsilon.eol'</span><span class="o">(</span><span class="nl">src:</span> <span class="s1">'queries.eol'</span><span class="o">){</span> <span class="n">model</span><span class="o">(</span><span class="nl">ref:</span> <span class="s1">'HTML'</span><span class="o">)</span> <span class="o">}</span> | 
|  | <span class="o">}</span> | 
|  | </code></pre></div> | 
|  |  | 
|  | </div> | 
|  | <input id="__tabbed_1_2" name="__tabbed_1" type="radio" /><label for="__tabbed_1_2">queries.eol</label><div class="tabbed-content"> | 
|  | <pre class="prettyprint lang-eol"><code>// Print the text of all <strong> elements | 
|  | for (s in t_strong.all) { | 
|  | s.text().println(); | 
|  | } | 
|  |  | 
|  | // Print all links that point to external websites | 
|  | for (link in t_a.all) { | 
|  | if (link.a_href.startsWith("http")) { | 
|  | link.a_href.println(); | 
|  | } | 
|  | } | 
|  |  | 
|  | // Print the text of all <li> elements which are | 
|  | // children of the <ul> that's the first sibling | 
|  | // of the "Why Epsilon?" <h2> | 
|  | var whyEpsilon = t_h2.all.selectOne(h2|h2.text.startsWith("Why Epsilon")); | 
|  | var ul = whyEpsilon.nextElementSibling(); | 
|  | for (li in ul.c_li) { | 
|  | li.text.println(); | 
|  | }</code></pre> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | <h2 id="additional-resources">Additional resources<a class="headerlink" href="#additional-resources" title="Permanent link">¶</a></h2> | 
|  | <p>The Epsilon HTML driver leverages the excellent Jsoup HTML parser. In fact, all elements returned via EOL queries are instances of the <code>org.jsoup.nodes.Element</code> class and as such, <a href="https://jsoup.org/apidocs/org/jsoup/nodes/Element.html">all methods of the class</a> can be invoked on them through EOL.</p> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | </article> | 
|  | </div> | 
|  | </div> | 
|  | </main> | 
|  |  | 
|  |  | 
|  | <footer class="md-footer"> | 
|  |  | 
|  | <div class="md-footer-meta md-typeset"> | 
|  | <div class="md-footer-meta__inner md-grid"> | 
|  | <div class="md-footer-copyright"> | 
|  |  | 
|  | <div class="md-footer-copyright__highlight"> | 
|  | Copyright © Eclipse Foundation, Inc. All Rights Reserved. | 
|  | </div> | 
|  |  | 
|  | powered by | 
|  | <a href="https://www.mkdocs.org">MkDocs</a> | 
|  | and | 
|  | <a href="https://squidfunk.github.io/mkdocs-material/">Material for MkDocs</a> | 
|  | </div> | 
|  | <div class="md-footer-copyright epsilon-eclipse-links"> | 
|  | <ul> | 
|  | <li><a href="https://www.eclipse.org/legal/privacy.php">Privacy Policy</a></li> | 
|  | <li><a href="https://www.eclipse.org/legal/termsofuse.php">Terms of Use</a></li> | 
|  | <li><a href="https://www.eclipse.org/legal/copyright.php">Copyright Agent</a></li> | 
|  | </ul> | 
|  | </div> | 
|  |  | 
|  | <div class="md-footer-social"> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <a href="https://twitter.com/eclipseepsilon" target="_blank" rel="noopener" title="twitter.com" class="md-footer-social__link"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path d="M459.37 151.716c.325 4.548.325 9.097.325 13.645 0 138.72-105.583 298.558-298.558 298.558-59.452 0-114.68-17.219-161.137-47.106 8.447.974 16.568 1.299 25.34 1.299 49.055 0 94.213-16.568 130.274-44.832-46.132-.975-84.792-31.188-98.112-72.772 6.498.974 12.995 1.624 19.818 1.624 9.421 0 18.843-1.3 27.614-3.573-48.081-9.747-84.143-51.98-84.143-102.985v-1.299c13.969 7.797 30.214 12.67 47.431 13.319-28.264-18.843-46.781-51.005-46.781-87.391 0-19.492 5.197-37.36 14.294-52.954 51.655 63.675 129.3 105.258 216.365 109.807-1.624-7.797-2.599-15.918-2.599-24.04 0-57.828 46.782-104.934 104.934-104.934 30.213 0 57.502 12.67 76.67 33.137 23.715-4.548 46.456-13.32 66.599-25.34-7.798 24.366-24.366 44.833-46.132 57.827 21.117-2.273 41.584-8.122 60.426-16.243-14.292 20.791-32.161 39.308-52.628 54.253z"/></svg> | 
|  | </a> | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | <a href="https://youtube.com/epsilondevs" target="_blank" rel="noopener" title="youtube.com" class="md-footer-social__link"> | 
|  | <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 576 512"><path d="M549.655 124.083c-6.281-23.65-24.787-42.276-48.284-48.597C458.781 64 288 64 288 64S117.22 64 74.629 75.486c-23.497 6.322-42.003 24.947-48.284 48.597-11.412 42.867-11.412 132.305-11.412 132.305s0 89.438 11.412 132.305c6.281 23.65 24.787 41.5 48.284 47.821C117.22 448 288 448 288 448s170.78 0 213.371-11.486c23.497-6.321 42.003-24.171 48.284-47.821 11.412-42.867 11.412-132.305 11.412-132.305s0-89.438-11.412-132.305zm-317.51 213.508V175.185l142.739 81.205-142.739 81.201z"/></svg> | 
|  | </a> | 
|  |  | 
|  | </div> | 
|  |  | 
|  | </div> | 
|  | </div> | 
|  | </footer> | 
|  |  | 
|  | </div> | 
|  |  | 
|  | <script src="../../../assets/javascripts/vendor.d710d30a.min.js"></script> | 
|  | <script src="../../../assets/javascripts/bundle.b39636ac.min.js"></script><script id="__lang" type="application/json">{"clipboard.copy": "Copy to clipboard", "clipboard.copied": "Copied to clipboard", "search.config.lang": "en", "search.config.pipeline": "trimmer, stopWordFilter", "search.config.separator": "[\\s\\-]+", "search.result.placeholder": "Type to start searching", "search.result.none": "No matching documents", "search.result.one": "1 matching document", "search.result.other": "# matching documents"}</script> | 
|  |  | 
|  | <script> | 
|  | app = initialize({ | 
|  | base: "../../..", | 
|  | features: [], | 
|  | search: Object.assign({ | 
|  | worker: "../../../assets/javascripts/worker/search.a68abb33.min.js" | 
|  | }, typeof search !== "undefined" && search) | 
|  | }) | 
|  | </script> | 
|  |  | 
|  | <script src="https://unpkg.com/mermaid@8.5.1/dist/mermaid.min.js"></script> | 
|  |  | 
|  | <script src="../../../assets/javascript/mermaid.js"></script> | 
|  |  | 
|  | <script src="../../../assets/javascript/jquery.js"></script> | 
|  |  | 
|  | <script src="../../../assets/javascript/slick.min.js"></script> | 
|  |  | 
|  | <script src="../../../assets/javascript/google-code-prettify/prettify.js"></script> | 
|  |  | 
|  | <script src="../../../assets/javascript/google-code-prettify/lang-emfatic.js"></script> | 
|  |  | 
|  | <script src="../../../assets/javascript/google-code-prettify/lang-epsilon.js"></script> | 
|  |  | 
|  | <script src="../../../assets/javascript/google-code-prettify/prettyprint.js"></script> | 
|  |  | 
|  | <script src="../../../assets/javascript/extra.js"></script> | 
|  |  | 
|  | <script src="https://w.appzi.io/w.js?token=jlv6W"></script> | 
|  |  | 
|  |  | 
|  | </body> | 
|  | </html> |