Mercurial > minori
annotate dep/pugixml/docs/quickstart.html @ 93:d5efb81540b3
statistics: add graph!
also now we have a VERY VERY simple graph widget that probably
sucks and doesn't work half the time :)
| author | Paper <mrpapersonic@gmail.com> | 
|---|---|
| date | Wed, 01 Nov 2023 13:52:34 -0400 | 
| parents | d10b6c6b432e | 
| children | a45edd073f9e | 
| rev | line source | 
|---|---|
| 55 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1 <!DOCTYPE html> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 2 <html lang="en"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 3 <head> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 4 <meta charset="UTF-8"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 5 <meta http-equiv="X-UA-Compatible" content="IE=edge"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 6 <meta name="viewport" content="width=device-width, initial-scale=1.0"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 7 <meta name="generator" content="Asciidoctor 2.0.16"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 8 <meta name="author" content="website, repository"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 9 <title>pugixml 1.13 quick start guide</title> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 10 <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Open+Sans:300,300italic,400,400italic,600,600italic%7CNoto+Serif:400,400italic,700,700italic%7CDroid+Sans+Mono:400,700"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 11 <style> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 12 /*! Asciidoctor default stylesheet | MIT License | https://asciidoctor.org */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 13 /* Uncomment the following line when using as a custom stylesheet */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 14 /* @import "https://fonts.googleapis.com/css?family=Open+Sans:300,300italic,400,400italic,600,600italic%7CNoto+Serif:400,400italic,700,700italic%7CDroid+Sans+Mono:400,700"; */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 15 html{font-family:sans-serif;-webkit-text-size-adjust:100%} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 16 a{background:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 17 a:focus{outline:thin dotted} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 18 a:active,a:hover{outline:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 19 h1{font-size:2em;margin:.67em 0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 20 b,strong{font-weight:bold} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 21 abbr{font-size:.9em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 22 abbr[title]{cursor:help;border-bottom:1px dotted #dddddf;text-decoration:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 23 dfn{font-style:italic} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 24 hr{height:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 25 mark{background:#ff0;color:#000} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 26 code,kbd,pre,samp{font-family:monospace;font-size:1em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 27 pre{white-space:pre-wrap} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 28 q{quotes:"\201C" "\201D" "\2018" "\2019"} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 29 small{font-size:80%} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 30 sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 31 sup{top:-.5em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 32 sub{bottom:-.25em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 33 img{border:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 34 svg:not(:root){overflow:hidden} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 35 figure{margin:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 36 audio,video{display:inline-block} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 37 audio:not([controls]){display:none;height:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 38 fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 39 legend{border:0;padding:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 40 button,input,select,textarea{font-family:inherit;font-size:100%;margin:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 41 button,input{line-height:normal} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 42 button,select{text-transform:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 43 button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 44 button[disabled],html input[disabled]{cursor:default} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 45 input[type=checkbox],input[type=radio]{padding:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 46 button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 47 textarea{overflow:auto;vertical-align:top} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 48 table{border-collapse:collapse;border-spacing:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 49 *,::before,::after{box-sizing:border-box} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 50 html,body{font-size:100%} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 51 body{background:#fff;color:rgba(0,0,0,.8);padding:0;margin:0;font-family:"Noto Serif","DejaVu Serif",serif;line-height:1;position:relative;cursor:auto;-moz-tab-size:4;-o-tab-size:4;tab-size:4;word-wrap:anywhere;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 52 a:hover{cursor:pointer} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 53 img,object,embed{max-width:100%;height:auto} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 54 object,embed{height:100%} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 55 img{-ms-interpolation-mode:bicubic} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 56 .left{float:left!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 57 .right{float:right!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 58 .text-left{text-align:left!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 59 .text-right{text-align:right!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 60 .text-center{text-align:center!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 61 .text-justify{text-align:justify!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 62 .hide{display:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 63 img,object,svg{display:inline-block;vertical-align:middle} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 64 textarea{height:auto;min-height:50px} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 65 select{width:100%} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 66 .subheader,.admonitionblock td.content>.title,.audioblock>.title,.exampleblock>.title,.imageblock>.title,.listingblock>.title,.literalblock>.title,.stemblock>.title,.openblock>.title,.paragraph>.title,.quoteblock>.title,table.tableblock>.title,.verseblock>.title,.videoblock>.title,.dlist>.title,.olist>.title,.ulist>.title,.qlist>.title,.hdlist>.title{line-height:1.45;color:#7a2518;font-weight:400;margin-top:0;margin-bottom:.25em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 67 div,dl,dt,dd,ul,ol,li,h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6,pre,form,p,blockquote,th,td{margin:0;padding:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 68 a{color:#2156a5;text-decoration:underline;line-height:inherit} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 69 a:hover,a:focus{color:#1d4b8f} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 70 a img{border:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 71 p{line-height:1.6;margin-bottom:1.25em;text-rendering:optimizeLegibility} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 72 p aside{font-size:.875em;line-height:1.35;font-style:italic} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 73 h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6{font-family:"Open Sans","DejaVu Sans",sans-serif;font-weight:300;font-style:normal;color:#ba3925;text-rendering:optimizeLegibility;margin-top:1em;margin-bottom:.5em;line-height:1.0125em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 74 h1 small,h2 small,h3 small,#toctitle small,.sidebarblock>.content>.title small,h4 small,h5 small,h6 small{font-size:60%;color:#e99b8f;line-height:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 75 h1{font-size:2.125em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 76 h2{font-size:1.6875em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 77 h3,#toctitle,.sidebarblock>.content>.title{font-size:1.375em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 78 h4,h5{font-size:1.125em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 79 h6{font-size:1em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 80 hr{border:solid #dddddf;border-width:1px 0 0;clear:both;margin:1.25em 0 1.1875em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 81 em,i{font-style:italic;line-height:inherit} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 82 strong,b{font-weight:bold;line-height:inherit} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 83 small{font-size:60%;line-height:inherit} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 84 code{font-family:"Droid Sans Mono","DejaVu Sans Mono",monospace;font-weight:400;color:rgba(0,0,0,.9)} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 85 ul,ol,dl{line-height:1.6;margin-bottom:1.25em;list-style-position:outside;font-family:inherit} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 86 ul,ol{margin-left:1.5em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 87 ul li ul,ul li ol{margin-left:1.25em;margin-bottom:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 88 ul.square li ul,ul.circle li ul,ul.disc li ul{list-style:inherit} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 89 ul.square{list-style-type:square} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 90 ul.circle{list-style-type:circle} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 91 ul.disc{list-style-type:disc} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 92 ol li ul,ol li ol{margin-left:1.25em;margin-bottom:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 93 dl dt{margin-bottom:.3125em;font-weight:bold} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 94 dl dd{margin-bottom:1.25em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 95 blockquote{margin:0 0 1.25em;padding:.5625em 1.25em 0 1.1875em;border-left:1px solid #ddd} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 96 blockquote,blockquote p{line-height:1.6;color:rgba(0,0,0,.85)} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 97 @media screen and (min-width:768px){h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6{line-height:1.2} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 98 h1{font-size:2.75em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 99 h2{font-size:2.3125em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 100 h3,#toctitle,.sidebarblock>.content>.title{font-size:1.6875em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 101 h4{font-size:1.4375em}} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 102 table{background:#fff;margin-bottom:1.25em;border:1px solid #dedede;word-wrap:normal} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 103 table thead,table tfoot{background:#f7f8f7} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 104 table thead tr th,table thead tr td,table tfoot tr th,table tfoot tr td{padding:.5em .625em .625em;font-size:inherit;color:rgba(0,0,0,.8);text-align:left} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 105 table tr th,table tr td{padding:.5625em .625em;font-size:inherit;color:rgba(0,0,0,.8)} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 106 table tr.even,table tr.alt{background:#f8f8f7} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 107 table thead tr th,table tfoot tr th,table tbody tr td,table tr td,table tfoot tr td{line-height:1.6} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 108 h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6{line-height:1.2;word-spacing:-.05em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 109 h1 strong,h2 strong,h3 strong,#toctitle strong,.sidebarblock>.content>.title strong,h4 strong,h5 strong,h6 strong{font-weight:400} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 110 .center{margin-left:auto;margin-right:auto} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 111 .stretch{width:100%} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 112 .clearfix::before,.clearfix::after,.float-group::before,.float-group::after{content:" ";display:table} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 113 .clearfix::after,.float-group::after{clear:both} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 114 :not(pre).nobreak{word-wrap:normal} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 115 :not(pre).nowrap{white-space:nowrap} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 116 :not(pre).pre-wrap{white-space:pre-wrap} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 117 :not(pre):not([class^=L])>code{font-size:.9375em;font-style:normal!important;letter-spacing:0;padding:.1em .5ex;word-spacing:-.15em;background:#f7f7f8;border-radius:4px;line-height:1.45;text-rendering:optimizeSpeed} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 118 pre{color:rgba(0,0,0,.9);font-family:"Droid Sans Mono","DejaVu Sans Mono",monospace;line-height:1.45;text-rendering:optimizeSpeed} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 119 pre code,pre pre{color:inherit;font-size:inherit;line-height:inherit} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 120 pre>code{display:block} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 121 pre.nowrap,pre.nowrap pre{white-space:pre;word-wrap:normal} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 122 em em{font-style:normal} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 123 strong strong{font-weight:400} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 124 .keyseq{color:rgba(51,51,51,.8)} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 125 kbd{font-family:"Droid Sans Mono","DejaVu Sans Mono",monospace;display:inline-block;color:rgba(0,0,0,.8);font-size:.65em;line-height:1.45;background:#f7f7f7;border:1px solid #ccc;border-radius:3px;box-shadow:0 1px 0 rgba(0,0,0,.2),inset 0 0 0 .1em #fff;margin:0 .15em;padding:.2em .5em;vertical-align:middle;position:relative;top:-.1em;white-space:nowrap} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 126 .keyseq kbd:first-child{margin-left:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 127 .keyseq kbd:last-child{margin-right:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 128 .menuseq,.menuref{color:#000} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 129 .menuseq b:not(.caret),.menuref{font-weight:inherit} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 130 .menuseq{word-spacing:-.02em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 131 .menuseq b.caret{font-size:1.25em;line-height:.8} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 132 .menuseq i.caret{font-weight:bold;text-align:center;width:.45em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 133 b.button::before,b.button::after{position:relative;top:-1px;font-weight:400} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 134 b.button::before{content:"[";padding:0 3px 0 2px} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 135 b.button::after{content:"]";padding:0 2px 0 3px} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 136 p a>code:hover{color:rgba(0,0,0,.9)} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 137 #header,#content,#footnotes,#footer{width:100%;margin:0 auto;max-width:62.5em;*zoom:1;position:relative;padding-left:.9375em;padding-right:.9375em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 138 #header::before,#header::after,#content::before,#content::after,#footnotes::before,#footnotes::after,#footer::before,#footer::after{content:" ";display:table} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 139 #header::after,#content::after,#footnotes::after,#footer::after{clear:both} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 140 #content{margin-top:1.25em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 141 #content::before{content:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 142 #header>h1:first-child{color:rgba(0,0,0,.85);margin-top:2.25rem;margin-bottom:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 143 #header>h1:first-child+#toc{margin-top:8px;border-top:1px solid #dddddf} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 144 #header>h1:only-child,body.toc2 #header>h1:nth-last-child(2){border-bottom:1px solid #dddddf;padding-bottom:8px} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 145 #header .details{border-bottom:1px solid #dddddf;line-height:1.45;padding-top:.25em;padding-bottom:.25em;padding-left:.25em;color:rgba(0,0,0,.6);display:flex;flex-flow:row wrap} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 146 #header .details span:first-child{margin-left:-.125em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 147 #header .details span.email a{color:rgba(0,0,0,.85)} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 148 #header .details br{display:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 149 #header .details br+span::before{content:"\00a0\2013\00a0"} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 150 #header .details br+span.author::before{content:"\00a0\22c5\00a0";color:rgba(0,0,0,.85)} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 151 #header .details br+span#revremark::before{content:"\00a0|\00a0"} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 152 #header #revnumber{text-transform:capitalize} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 153 #header #revnumber::after{content:"\00a0"} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 154 #content>h1:first-child:not([class]){color:rgba(0,0,0,.85);border-bottom:1px solid #dddddf;padding-bottom:8px;margin-top:0;padding-top:1rem;margin-bottom:1.25rem} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 155 #toc{border-bottom:1px solid #e7e7e9;padding-bottom:.5em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 156 #toc>ul{margin-left:.125em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 157 #toc ul.sectlevel0>li>a{font-style:italic} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 158 #toc ul.sectlevel0 ul.sectlevel1{margin:.5em 0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 159 #toc ul{font-family:"Open Sans","DejaVu Sans",sans-serif;list-style-type:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 160 #toc li{line-height:1.3334;margin-top:.3334em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 161 #toc a{text-decoration:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 162 #toc a:active{text-decoration:underline} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 163 #toctitle{color:#7a2518;font-size:1.2em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 164 @media screen and (min-width:768px){#toctitle{font-size:1.375em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 165 body.toc2{padding-left:15em;padding-right:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 166 #toc.toc2{margin-top:0!important;background:#f8f8f7;position:fixed;width:15em;left:0;top:0;border-right:1px solid #e7e7e9;border-top-width:0!important;border-bottom-width:0!important;z-index:1000;padding:1.25em 1em;height:100%;overflow:auto} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 167 #toc.toc2 #toctitle{margin-top:0;margin-bottom:.8rem;font-size:1.2em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 168 #toc.toc2>ul{font-size:.9em;margin-bottom:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 169 #toc.toc2 ul ul{margin-left:0;padding-left:1em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 170 #toc.toc2 ul.sectlevel0 ul.sectlevel1{padding-left:0;margin-top:.5em;margin-bottom:.5em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 171 body.toc2.toc-right{padding-left:0;padding-right:15em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 172 body.toc2.toc-right #toc.toc2{border-right-width:0;border-left:1px solid #e7e7e9;left:auto;right:0}} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 173 @media screen and (min-width:1280px){body.toc2{padding-left:20em;padding-right:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 174 #toc.toc2{width:20em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 175 #toc.toc2 #toctitle{font-size:1.375em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 176 #toc.toc2>ul{font-size:.95em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 177 #toc.toc2 ul ul{padding-left:1.25em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 178 body.toc2.toc-right{padding-left:0;padding-right:20em}} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 179 #content #toc{border:1px solid #e0e0dc;margin-bottom:1.25em;padding:1.25em;background:#f8f8f7;border-radius:4px} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 180 #content #toc>:first-child{margin-top:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 181 #content #toc>:last-child{margin-bottom:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 182 #footer{max-width:none;background:rgba(0,0,0,.8);padding:1.25em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 183 #footer-text{color:hsla(0,0%,100%,.8);line-height:1.44} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 184 #content{margin-bottom:.625em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 185 .sect1{padding-bottom:.625em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 186 @media screen and (min-width:768px){#content{margin-bottom:1.25em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 187 .sect1{padding-bottom:1.25em}} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 188 .sect1:last-child{padding-bottom:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 189 .sect1+.sect1{border-top:1px solid #e7e7e9} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 190 #content h1>a.anchor,h2>a.anchor,h3>a.anchor,#toctitle>a.anchor,.sidebarblock>.content>.title>a.anchor,h4>a.anchor,h5>a.anchor,h6>a.anchor{position:absolute;z-index:1001;width:1.5ex;margin-left:-1.5ex;display:block;text-decoration:none!important;visibility:hidden;text-align:center;font-weight:400} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 191 #content h1>a.anchor::before,h2>a.anchor::before,h3>a.anchor::before,#toctitle>a.anchor::before,.sidebarblock>.content>.title>a.anchor::before,h4>a.anchor::before,h5>a.anchor::before,h6>a.anchor::before{content:"\00A7";font-size:.85em;display:block;padding-top:.1em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 192 #content h1:hover>a.anchor,#content h1>a.anchor:hover,h2:hover>a.anchor,h2>a.anchor:hover,h3:hover>a.anchor,#toctitle:hover>a.anchor,.sidebarblock>.content>.title:hover>a.anchor,h3>a.anchor:hover,#toctitle>a.anchor:hover,.sidebarblock>.content>.title>a.anchor:hover,h4:hover>a.anchor,h4>a.anchor:hover,h5:hover>a.anchor,h5>a.anchor:hover,h6:hover>a.anchor,h6>a.anchor:hover{visibility:visible} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 193 #content h1>a.link,h2>a.link,h3>a.link,#toctitle>a.link,.sidebarblock>.content>.title>a.link,h4>a.link,h5>a.link,h6>a.link{color:#ba3925;text-decoration:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 194 #content h1>a.link:hover,h2>a.link:hover,h3>a.link:hover,#toctitle>a.link:hover,.sidebarblock>.content>.title>a.link:hover,h4>a.link:hover,h5>a.link:hover,h6>a.link:hover{color:#a53221} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 195 details,.audioblock,.imageblock,.literalblock,.listingblock,.stemblock,.videoblock{margin-bottom:1.25em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 196 details{margin-left:1.25rem} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 197 details>summary{cursor:pointer;display:block;position:relative;line-height:1.6;margin-bottom:.625rem;-webkit-tap-highlight-color:transparent} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 198 details>summary::before{content:"";border:solid transparent;border-left:solid;border-width:.3em 0 .3em .5em;position:absolute;top:.5em;left:-1.25rem;transform:translateX(15%)} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 199 details[open]>summary::before{border:solid transparent;border-top:solid;border-width:.5em .3em 0;transform:translateY(15%)} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 200 details>summary::after{content:"";width:1.25rem;height:1em;position:absolute;top:.3em;left:-1.25rem} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 201 .admonitionblock td.content>.title,.audioblock>.title,.exampleblock>.title,.imageblock>.title,.listingblock>.title,.literalblock>.title,.stemblock>.title,.openblock>.title,.paragraph>.title,.quoteblock>.title,table.tableblock>.title,.verseblock>.title,.videoblock>.title,.dlist>.title,.olist>.title,.ulist>.title,.qlist>.title,.hdlist>.title{text-rendering:optimizeLegibility;text-align:left;font-family:"Noto Serif","DejaVu Serif",serif;font-size:1rem;font-style:italic} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 202 table.tableblock.fit-content>caption.title{white-space:nowrap;width:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 203 .paragraph.lead>p,#preamble>.sectionbody>[class=paragraph]:first-of-type p{font-size:1.21875em;line-height:1.6;color:rgba(0,0,0,.85)} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 204 .admonitionblock>table{border-collapse:separate;border:0;background:none;width:100%} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 205 .admonitionblock>table td.icon{text-align:center;width:80px} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 206 .admonitionblock>table td.icon img{max-width:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 207 .admonitionblock>table td.icon .title{font-weight:bold;font-family:"Open Sans","DejaVu Sans",sans-serif;text-transform:uppercase} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 208 .admonitionblock>table td.content{padding-left:1.125em;padding-right:1.25em;border-left:1px solid #dddddf;color:rgba(0,0,0,.6);word-wrap:anywhere} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 209 .admonitionblock>table td.content>:last-child>:last-child{margin-bottom:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 210 .exampleblock>.content{border:1px solid #e6e6e6;margin-bottom:1.25em;padding:1.25em;background:#fff;border-radius:4px} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 211 .exampleblock>.content>:first-child{margin-top:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 212 .exampleblock>.content>:last-child{margin-bottom:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 213 .sidebarblock{border:1px solid #dbdbd6;margin-bottom:1.25em;padding:1.25em;background:#f3f3f2;border-radius:4px} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 214 .sidebarblock>:first-child{margin-top:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 215 .sidebarblock>:last-child{margin-bottom:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 216 .sidebarblock>.content>.title{color:#7a2518;margin-top:0;text-align:center} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 217 .exampleblock>.content>:last-child>:last-child,.exampleblock>.content .olist>ol>li:last-child>:last-child,.exampleblock>.content .ulist>ul>li:last-child>:last-child,.exampleblock>.content .qlist>ol>li:last-child>:last-child,.sidebarblock>.content>:last-child>:last-child,.sidebarblock>.content .olist>ol>li:last-child>:last-child,.sidebarblock>.content .ulist>ul>li:last-child>:last-child,.sidebarblock>.content .qlist>ol>li:last-child>:last-child{margin-bottom:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 218 .literalblock pre,.listingblock>.content>pre{border-radius:4px;overflow-x:auto;padding:1em;font-size:.8125em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 219 @media screen and (min-width:768px){.literalblock pre,.listingblock>.content>pre{font-size:.90625em}} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 220 @media screen and (min-width:1280px){.literalblock pre,.listingblock>.content>pre{font-size:1em}} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 221 .literalblock pre,.listingblock>.content>pre:not(.highlight),.listingblock>.content>pre[class=highlight],.listingblock>.content>pre[class^="highlight "]{background:#f7f7f8} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 222 .literalblock.output pre{color:#f7f7f8;background:rgba(0,0,0,.9)} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 223 .listingblock>.content{position:relative} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 224 .listingblock code[data-lang]::before{display:none;content:attr(data-lang);position:absolute;font-size:.75em;top:.425rem;right:.5rem;line-height:1;text-transform:uppercase;color:inherit;opacity:.5} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 225 .listingblock:hover code[data-lang]::before{display:block} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 226 .listingblock.terminal pre .command::before{content:attr(data-prompt);padding-right:.5em;color:inherit;opacity:.5} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 227 .listingblock.terminal pre .command:not([data-prompt])::before{content:"$"} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 228 .listingblock pre.highlightjs{padding:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 229 .listingblock pre.highlightjs>code{padding:1em;border-radius:4px} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 230 .listingblock pre.prettyprint{border-width:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 231 .prettyprint{background:#f7f7f8} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 232 pre.prettyprint .linenums{line-height:1.45;margin-left:2em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 233 pre.prettyprint li{background:none;list-style-type:inherit;padding-left:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 234 pre.prettyprint li code[data-lang]::before{opacity:1} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 235 pre.prettyprint li:not(:first-child) code[data-lang]::before{display:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 236 table.linenotable{border-collapse:separate;border:0;margin-bottom:0;background:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 237 table.linenotable td[class]{color:inherit;vertical-align:top;padding:0;line-height:inherit;white-space:normal} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 238 table.linenotable td.code{padding-left:.75em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 239 table.linenotable td.linenos{border-right:1px solid;opacity:.35;padding-right:.5em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 240 pre.pygments .lineno{border-right:1px solid;opacity:.35;display:inline-block;margin-right:.75em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 241 pre.pygments .lineno::before{content:"";margin-right:-.125em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 242 .quoteblock{margin:0 1em 1.25em 1.5em;display:table} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 243 .quoteblock:not(.excerpt)>.title{margin-left:-1.5em;margin-bottom:.75em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 244 .quoteblock blockquote,.quoteblock p{color:rgba(0,0,0,.85);font-size:1.15rem;line-height:1.75;word-spacing:.1em;letter-spacing:0;font-style:italic;text-align:justify} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 245 .quoteblock blockquote{margin:0;padding:0;border:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 246 .quoteblock blockquote::before{content:"\201c";float:left;font-size:2.75em;font-weight:bold;line-height:.6em;margin-left:-.6em;color:#7a2518;text-shadow:0 1px 2px rgba(0,0,0,.1)} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 247 .quoteblock blockquote>.paragraph:last-child p{margin-bottom:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 248 .quoteblock .attribution{margin-top:.75em;margin-right:.5ex;text-align:right} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 249 .verseblock{margin:0 1em 1.25em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 250 .verseblock pre{font-family:"Open Sans","DejaVu Sans",sans-serif;font-size:1.15rem;color:rgba(0,0,0,.85);font-weight:300;text-rendering:optimizeLegibility} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 251 .verseblock pre strong{font-weight:400} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 252 .verseblock .attribution{margin-top:1.25rem;margin-left:.5ex} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 253 .quoteblock .attribution,.verseblock .attribution{font-size:.9375em;line-height:1.45;font-style:italic} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 254 .quoteblock .attribution br,.verseblock .attribution br{display:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 255 .quoteblock .attribution cite,.verseblock .attribution cite{display:block;letter-spacing:-.025em;color:rgba(0,0,0,.6)} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 256 .quoteblock.abstract blockquote::before,.quoteblock.excerpt blockquote::before,.quoteblock .quoteblock blockquote::before{display:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 257 .quoteblock.abstract blockquote,.quoteblock.abstract p,.quoteblock.excerpt blockquote,.quoteblock.excerpt p,.quoteblock .quoteblock blockquote,.quoteblock .quoteblock p{line-height:1.6;word-spacing:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 258 .quoteblock.abstract{margin:0 1em 1.25em;display:block} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 259 .quoteblock.abstract>.title{margin:0 0 .375em;font-size:1.15em;text-align:center} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 260 .quoteblock.excerpt>blockquote,.quoteblock .quoteblock{padding:0 0 .25em 1em;border-left:.25em solid #dddddf} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 261 .quoteblock.excerpt,.quoteblock .quoteblock{margin-left:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 262 .quoteblock.excerpt blockquote,.quoteblock.excerpt p,.quoteblock .quoteblock blockquote,.quoteblock .quoteblock p{color:inherit;font-size:1.0625rem} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 263 .quoteblock.excerpt .attribution,.quoteblock .quoteblock .attribution{color:inherit;font-size:.85rem;text-align:left;margin-right:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 264 p.tableblock:last-child{margin-bottom:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 265 td.tableblock>.content{margin-bottom:1.25em;word-wrap:anywhere} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 266 td.tableblock>.content>:last-child{margin-bottom:-1.25em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 267 table.tableblock,th.tableblock,td.tableblock{border:0 solid #dedede} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 268 table.grid-all>*>tr>*{border-width:1px} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 269 table.grid-cols>*>tr>*{border-width:0 1px} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 270 table.grid-rows>*>tr>*{border-width:1px 0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 271 table.frame-all{border-width:1px} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 272 table.frame-ends{border-width:1px 0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 273 table.frame-sides{border-width:0 1px} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 274 table.frame-none>colgroup+*>:first-child>*,table.frame-sides>colgroup+*>:first-child>*{border-top-width:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 275 table.frame-none>:last-child>:last-child>*,table.frame-sides>:last-child>:last-child>*{border-bottom-width:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 276 table.frame-none>*>tr>:first-child,table.frame-ends>*>tr>:first-child{border-left-width:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 277 table.frame-none>*>tr>:last-child,table.frame-ends>*>tr>:last-child{border-right-width:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 278 table.stripes-all tr,table.stripes-odd tr:nth-of-type(odd),table.stripes-even tr:nth-of-type(even),table.stripes-hover tr:hover{background:#f8f8f7} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 279 th.halign-left,td.halign-left{text-align:left} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 280 th.halign-right,td.halign-right{text-align:right} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 281 th.halign-center,td.halign-center{text-align:center} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 282 th.valign-top,td.valign-top{vertical-align:top} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 283 th.valign-bottom,td.valign-bottom{vertical-align:bottom} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 284 th.valign-middle,td.valign-middle{vertical-align:middle} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 285 table thead th,table tfoot th{font-weight:bold} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 286 tbody tr th{background:#f7f8f7} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 287 tbody tr th,tbody tr th p,tfoot tr th,tfoot tr th p{color:rgba(0,0,0,.8);font-weight:bold} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 288 p.tableblock>code:only-child{background:none;padding:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 289 p.tableblock{font-size:1em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 290 ol{margin-left:1.75em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 291 ul li ol{margin-left:1.5em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 292 dl dd{margin-left:1.125em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 293 dl dd:last-child,dl dd:last-child>:last-child{margin-bottom:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 294 ol>li p,ul>li p,ul dd,ol dd,.olist .olist,.ulist .ulist,.ulist .olist,.olist .ulist{margin-bottom:.625em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 295 ul.checklist,ul.none,ol.none,ul.no-bullet,ol.no-bullet,ol.unnumbered,ul.unstyled,ol.unstyled{list-style-type:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 296 ul.no-bullet,ol.no-bullet,ol.unnumbered{margin-left:.625em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 297 ul.unstyled,ol.unstyled{margin-left:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 298 ul.checklist>li>p:first-child{margin-left:-1em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 299 ul.checklist>li>p:first-child>.fa-square-o:first-child,ul.checklist>li>p:first-child>.fa-check-square-o:first-child{width:1.25em;font-size:.8em;position:relative;bottom:.125em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 300 ul.checklist>li>p:first-child>input[type=checkbox]:first-child{margin-right:.25em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 301 ul.inline{display:flex;flex-flow:row wrap;list-style:none;margin:0 0 .625em -1.25em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 302 ul.inline>li{margin-left:1.25em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 303 .unstyled dl dt{font-weight:400;font-style:normal} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 304 ol.arabic{list-style-type:decimal} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 305 ol.decimal{list-style-type:decimal-leading-zero} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 306 ol.loweralpha{list-style-type:lower-alpha} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 307 ol.upperalpha{list-style-type:upper-alpha} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 308 ol.lowerroman{list-style-type:lower-roman} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 309 ol.upperroman{list-style-type:upper-roman} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 310 ol.lowergreek{list-style-type:lower-greek} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 311 .hdlist>table,.colist>table{border:0;background:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 312 .hdlist>table>tbody>tr,.colist>table>tbody>tr{background:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 313 td.hdlist1,td.hdlist2{vertical-align:top;padding:0 .625em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 314 td.hdlist1{font-weight:bold;padding-bottom:1.25em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 315 td.hdlist2{word-wrap:anywhere} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 316 .literalblock+.colist,.listingblock+.colist{margin-top:-.5em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 317 .colist td:not([class]):first-child{padding:.4em .75em 0;line-height:1;vertical-align:top} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 318 .colist td:not([class]):first-child img{max-width:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 319 .colist td:not([class]):last-child{padding:.25em 0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 320 .thumb,.th{line-height:0;display:inline-block;border:4px solid #fff;box-shadow:0 0 0 1px #ddd} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 321 .imageblock.left{margin:.25em .625em 1.25em 0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 322 .imageblock.right{margin:.25em 0 1.25em .625em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 323 .imageblock>.title{margin-bottom:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 324 .imageblock.thumb,.imageblock.th{border-width:6px} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 325 .imageblock.thumb>.title,.imageblock.th>.title{padding:0 .125em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 326 .image.left,.image.right{margin-top:.25em;margin-bottom:.25em;display:inline-block;line-height:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 327 .image.left{margin-right:.625em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 328 .image.right{margin-left:.625em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 329 a.image{text-decoration:none;display:inline-block} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 330 a.image object{pointer-events:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 331 sup.footnote,sup.footnoteref{font-size:.875em;position:static;vertical-align:super} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 332 sup.footnote a,sup.footnoteref a{text-decoration:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 333 sup.footnote a:active,sup.footnoteref a:active{text-decoration:underline} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 334 #footnotes{padding-top:.75em;padding-bottom:.75em;margin-bottom:.625em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 335 #footnotes hr{width:20%;min-width:6.25em;margin:-.25em 0 .75em;border-width:1px 0 0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 336 #footnotes .footnote{padding:0 .375em 0 .225em;line-height:1.3334;font-size:.875em;margin-left:1.2em;margin-bottom:.2em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 337 #footnotes .footnote a:first-of-type{font-weight:bold;text-decoration:none;margin-left:-1.05em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 338 #footnotes .footnote:last-of-type{margin-bottom:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 339 #content #footnotes{margin-top:-.625em;margin-bottom:0;padding:.75em 0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 340 .gist .file-data>table{border:0;background:#fff;width:100%;margin-bottom:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 341 .gist .file-data>table td.line-data{width:99%} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 342 div.unbreakable{page-break-inside:avoid} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 343 .big{font-size:larger} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 344 .small{font-size:smaller} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 345 .underline{text-decoration:underline} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 346 .overline{text-decoration:overline} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 347 .line-through{text-decoration:line-through} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 348 .aqua{color:#00bfbf} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 349 .aqua-background{background:#00fafa} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 350 .black{color:#000} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 351 .black-background{background:#000} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 352 .blue{color:#0000bf} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 353 .blue-background{background:#0000fa} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 354 .fuchsia{color:#bf00bf} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 355 .fuchsia-background{background:#fa00fa} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 356 .gray{color:#606060} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 357 .gray-background{background:#7d7d7d} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 358 .green{color:#006000} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 359 .green-background{background:#007d00} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 360 .lime{color:#00bf00} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 361 .lime-background{background:#00fa00} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 362 .maroon{color:#600000} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 363 .maroon-background{background:#7d0000} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 364 .navy{color:#000060} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 365 .navy-background{background:#00007d} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 366 .olive{color:#606000} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 367 .olive-background{background:#7d7d00} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 368 .purple{color:#600060} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 369 .purple-background{background:#7d007d} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 370 .red{color:#bf0000} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 371 .red-background{background:#fa0000} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 372 .silver{color:#909090} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 373 .silver-background{background:#bcbcbc} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 374 .teal{color:#006060} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 375 .teal-background{background:#007d7d} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 376 .white{color:#bfbfbf} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 377 .white-background{background:#fafafa} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 378 .yellow{color:#bfbf00} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 379 .yellow-background{background:#fafa00} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 380 span.icon>.fa{cursor:default} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 381 a span.icon>.fa{cursor:inherit} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 382 .admonitionblock td.icon [class^="fa icon-"]{font-size:2.5em;text-shadow:1px 1px 2px rgba(0,0,0,.5);cursor:default} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 383 .admonitionblock td.icon .icon-note::before{content:"\f05a";color:#19407c} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 384 .admonitionblock td.icon .icon-tip::before{content:"\f0eb";text-shadow:1px 1px 2px rgba(155,155,0,.8);color:#111} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 385 .admonitionblock td.icon .icon-warning::before{content:"\f071";color:#bf6900} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 386 .admonitionblock td.icon .icon-caution::before{content:"\f06d";color:#bf3400} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 387 .admonitionblock td.icon .icon-important::before{content:"\f06a";color:#bf0000} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 388 .conum[data-value]{display:inline-block;color:#fff!important;background:rgba(0,0,0,.8);border-radius:50%;text-align:center;font-size:.75em;width:1.67em;height:1.67em;line-height:1.67em;font-family:"Open Sans","DejaVu Sans",sans-serif;font-style:normal;font-weight:bold} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 389 .conum[data-value] *{color:#fff!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 390 .conum[data-value]+b{display:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 391 .conum[data-value]::after{content:attr(data-value)} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 392 pre .conum[data-value]{position:relative;top:-.125em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 393 b.conum *{color:inherit!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 394 .conum:not([data-value]):empty{display:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 395 dt,th.tableblock,td.content,div.footnote{text-rendering:optimizeLegibility} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 396 h1,h2,p,td.content,span.alt,summary{letter-spacing:-.01em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 397 p strong,td.content strong,div.footnote strong{letter-spacing:-.005em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 398 p,blockquote,dt,td.content,span.alt,summary{font-size:1.0625rem} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 399 p{margin-bottom:1.25rem} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 400 .sidebarblock p,.sidebarblock dt,.sidebarblock td.content,p.tableblock{font-size:1em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 401 .exampleblock>.content{background:#fffef7;border-color:#e0e0dc;box-shadow:0 1px 4px #e0e0dc} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 402 .print-only{display:none!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 403 @page{margin:1.25cm .75cm} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 404 @media print{*{box-shadow:none!important;text-shadow:none!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 405 html{font-size:80%} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 406 a{color:inherit!important;text-decoration:underline!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 407 a.bare,a[href^="#"],a[href^="mailto:"]{text-decoration:none!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 408 a[href^="http:"]:not(.bare)::after,a[href^="https:"]:not(.bare)::after{content:"(" attr(href) ")";display:inline-block;font-size:.875em;padding-left:.25em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 409 abbr[title]{border-bottom:1px dotted} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 410 abbr[title]::after{content:" (" attr(title) ")"} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 411 pre,blockquote,tr,img,object,svg{page-break-inside:avoid} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 412 thead{display:table-header-group} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 413 svg{max-width:100%} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 414 p,blockquote,dt,td.content{font-size:1em;orphans:3;widows:3} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 415 h2,h3,#toctitle,.sidebarblock>.content>.title{page-break-after:avoid} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 416 #header,#content,#footnotes,#footer{max-width:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 417 #toc,.sidebarblock,.exampleblock>.content{background:none!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 418 #toc{border-bottom:1px solid #dddddf!important;padding-bottom:0!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 419 body.book #header{text-align:center} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 420 body.book #header>h1:first-child{border:0!important;margin:2.5em 0 1em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 421 body.book #header .details{border:0!important;display:block;padding:0!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 422 body.book #header .details span:first-child{margin-left:0!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 423 body.book #header .details br{display:block} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 424 body.book #header .details br+span::before{content:none!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 425 body.book #toc{border:0!important;text-align:left!important;padding:0!important;margin:0!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 426 body.book #toc,body.book #preamble,body.book h1.sect0,body.book .sect1>h2{page-break-before:always} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 427 .listingblock code[data-lang]::before{display:block} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 428 #footer{padding:0 .9375em} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 429 .hide-on-print{display:none!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 430 .print-only{display:block!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 431 .hide-for-print{display:none!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 432 .show-for-print{display:inherit!important}} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 433 @media amzn-kf8,print{#header>h1:first-child{margin-top:1.25rem} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 434 .sect1{padding:0!important} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 435 .sect1+.sect1{border:0} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 436 #footer{background:none} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 437 #footer-text{color:rgba(0,0,0,.6);font-size:.9em}} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 438 @media amzn-kf8{#header,#content,#footnotes,#footer{padding:0}} | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 439 </style> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 440 <style> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 441 pre { line-height: 125%; } | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 442 td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 443 span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 444 td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 445 span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 446 pre.pygments .hll { background-color: #ffffcc } | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 447 pre.pygments { background: #f8f8f8; } | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 448 pre.pygments .tok-c { color: #3D7B7B; font-style: italic } /* Comment */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 449 pre.pygments .tok-err { border: 1px solid #FF0000 } /* Error */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 450 pre.pygments .tok-k { color: #008000; font-weight: bold } /* Keyword */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 451 pre.pygments .tok-o { color: #666666 } /* Operator */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 452 pre.pygments .tok-ch { color: #3D7B7B; font-style: italic } /* Comment.Hashbang */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 453 pre.pygments .tok-cm { color: #3D7B7B; font-style: italic } /* Comment.Multiline */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 454 pre.pygments .tok-cp { color: #9C6500 } /* Comment.Preproc */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 455 pre.pygments .tok-cpf { color: #3D7B7B; font-style: italic } /* Comment.PreprocFile */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 456 pre.pygments .tok-c1 { color: #3D7B7B; font-style: italic } /* Comment.Single */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 457 pre.pygments .tok-cs { color: #3D7B7B; font-style: italic } /* Comment.Special */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 458 pre.pygments .tok-gd { color: #A00000 } /* Generic.Deleted */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 459 pre.pygments .tok-ge { font-style: italic } /* Generic.Emph */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 460 pre.pygments .tok-gr { color: #E40000 } /* Generic.Error */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 461 pre.pygments .tok-gh { color: #000080; font-weight: bold } /* Generic.Heading */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 462 pre.pygments .tok-gi { color: #008400 } /* Generic.Inserted */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 463 pre.pygments .tok-go { color: #717171 } /* Generic.Output */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 464 pre.pygments .tok-gp { color: #000080; font-weight: bold } /* Generic.Prompt */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 465 pre.pygments .tok-gs { font-weight: bold } /* Generic.Strong */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 466 pre.pygments .tok-gu { color: #800080; font-weight: bold } /* Generic.Subheading */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 467 pre.pygments .tok-gt { color: #0044DD } /* Generic.Traceback */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 468 pre.pygments .tok-kc { color: #008000; font-weight: bold } /* Keyword.Constant */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 469 pre.pygments .tok-kd { color: #008000; font-weight: bold } /* Keyword.Declaration */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 470 pre.pygments .tok-kn { color: #008000; font-weight: bold } /* Keyword.Namespace */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 471 pre.pygments .tok-kp { color: #008000 } /* Keyword.Pseudo */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 472 pre.pygments .tok-kr { color: #008000; font-weight: bold } /* Keyword.Reserved */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 473 pre.pygments .tok-kt { color: #B00040 } /* Keyword.Type */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 474 pre.pygments .tok-m { color: #666666 } /* Literal.Number */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 475 pre.pygments .tok-s { color: #BA2121 } /* Literal.String */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 476 pre.pygments .tok-na { color: #687822 } /* Name.Attribute */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 477 pre.pygments .tok-nb { color: #008000 } /* Name.Builtin */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 478 pre.pygments .tok-nc { color: #0000FF; font-weight: bold } /* Name.Class */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 479 pre.pygments .tok-no { color: #880000 } /* Name.Constant */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 480 pre.pygments .tok-nd { color: #AA22FF } /* Name.Decorator */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 481 pre.pygments .tok-ni { color: #717171; font-weight: bold } /* Name.Entity */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 482 pre.pygments .tok-ne { color: #CB3F38; font-weight: bold } /* Name.Exception */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 483 pre.pygments .tok-nf { color: #0000FF } /* Name.Function */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 484 pre.pygments .tok-nl { color: #767600 } /* Name.Label */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 485 pre.pygments .tok-nn { color: #0000FF; font-weight: bold } /* Name.Namespace */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 486 pre.pygments .tok-nt { color: #008000; font-weight: bold } /* Name.Tag */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 487 pre.pygments .tok-nv { color: #19177C } /* Name.Variable */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 488 pre.pygments .tok-ow { color: #AA22FF; font-weight: bold } /* Operator.Word */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 489 pre.pygments .tok-w { color: #bbbbbb } /* Text.Whitespace */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 490 pre.pygments .tok-mb { color: #666666 } /* Literal.Number.Bin */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 491 pre.pygments .tok-mf { color: #666666 } /* Literal.Number.Float */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 492 pre.pygments .tok-mh { color: #666666 } /* Literal.Number.Hex */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 493 pre.pygments .tok-mi { color: #666666 } /* Literal.Number.Integer */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 494 pre.pygments .tok-mo { color: #666666 } /* Literal.Number.Oct */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 495 pre.pygments .tok-sa { color: #BA2121 } /* Literal.String.Affix */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 496 pre.pygments .tok-sb { color: #BA2121 } /* Literal.String.Backtick */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 497 pre.pygments .tok-sc { color: #BA2121 } /* Literal.String.Char */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 498 pre.pygments .tok-dl { color: #BA2121 } /* Literal.String.Delimiter */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 499 pre.pygments .tok-sd { color: #BA2121; font-style: italic } /* Literal.String.Doc */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 500 pre.pygments .tok-s2 { color: #BA2121 } /* Literal.String.Double */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 501 pre.pygments .tok-se { color: #AA5D1F; font-weight: bold } /* Literal.String.Escape */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 502 pre.pygments .tok-sh { color: #BA2121 } /* Literal.String.Heredoc */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 503 pre.pygments .tok-si { color: #A45A77; font-weight: bold } /* Literal.String.Interpol */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 504 pre.pygments .tok-sx { color: #008000 } /* Literal.String.Other */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 505 pre.pygments .tok-sr { color: #A45A77 } /* Literal.String.Regex */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 506 pre.pygments .tok-s1 { color: #BA2121 } /* Literal.String.Single */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 507 pre.pygments .tok-ss { color: #19177C } /* Literal.String.Symbol */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 508 pre.pygments .tok-bp { color: #008000 } /* Name.Builtin.Pseudo */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 509 pre.pygments .tok-fm { color: #0000FF } /* Name.Function.Magic */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 510 pre.pygments .tok-vc { color: #19177C } /* Name.Variable.Class */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 511 pre.pygments .tok-vg { color: #19177C } /* Name.Variable.Global */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 512 pre.pygments .tok-vi { color: #19177C } /* Name.Variable.Instance */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 513 pre.pygments .tok-vm { color: #19177C } /* Name.Variable.Magic */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 514 pre.pygments .tok-il { color: #666666 } /* Literal.Number.Integer.Long */ | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 515 </style> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 516 </head> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 517 <body class="article toc2 toc-right"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 518 <div id="header"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 519 <h1>pugixml 1.13 quick start guide</h1> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 520 <div class="details"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 521 <span id="author" class="author">website</span><br> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 522 <span id="email" class="email"><a href="https://pugixml.org" class="bare">https://pugixml.org</a></span><br> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 523 <span id="author2" class="author">repository</span><br> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 524 <span id="email2" class="email"><a href="https://github.com/zeux/pugixml" class="bare">https://github.com/zeux/pugixml</a></span><br> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 525 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 526 <div id="toc" class="toc2"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 527 <div id="toctitle">Table of Contents</div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 528 <ul class="sectlevel1"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 529 <li><a href="#introduction">Introduction</a></li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 530 <li><a href="#install">Installation</a></li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 531 <li><a href="#dom">Document object model</a></li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 532 <li><a href="#loading">Loading document</a></li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 533 <li><a href="#access">Accessing document data</a></li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 534 <li><a href="#modify">Modifying document data</a></li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 535 <li><a href="#saving">Saving document</a></li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 536 <li><a href="#feedback">Feedback</a></li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 537 <li><a href="#license">License</a></li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 538 </ul> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 539 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 540 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 541 <div id="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 542 <div class="sect1"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 543 <h2 id="introduction"><a class="anchor" href="#introduction"></a><a class="link" href="#introduction">Introduction</a></h2> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 544 <div class="sectionbody"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 545 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 546 <p><a href="https://pugixml.org/">pugixml</a> is a light-weight C++ XML processing library. It consists of a DOM-like interface with rich traversal/modification capabilities, an extremely fast XML parser which constructs the DOM tree from an XML file/buffer, and an XPath 1.0 implementation for complex data-driven tree queries. Full Unicode support is also available, with two Unicode interface variants and conversions between different Unicode encodings (which happen automatically during parsing/saving). The library is extremely portable and easy to integrate and use. pugixml is developed and maintained since 2006 and has many users. All code is distributed under the <a href="#license">MIT license</a>, making it completely free to use in both open-source and proprietary applications.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 547 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 548 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 549 <p>pugixml enables very fast, convenient and memory-efficient XML document processing. However, since pugixml has a DOM parser, it can’t process XML documents that do not fit in memory; also the parser is a non-validating one, so if you need DTD/Schema validation, the library is not for you.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 550 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 551 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 552 <p>This is the quick start guide for pugixml, which purpose is to enable you to start using the library quickly. Many important library features are either not described at all or only mentioned briefly; for more complete information you <a href="manual.html">should read the complete manual</a>.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 553 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 554 <div class="admonitionblock note"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 555 <table> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 556 <tr> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 557 <td class="icon"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 558 <div class="title">Note</div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 559 </td> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 560 <td class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 561 No documentation is perfect; neither is this one. If you find errors or omissions, please don’t hesitate to <a href="https://github.com/zeux/pugixml/issues/new">submit an issue or open a pull request</a> with a fix. | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 562 </td> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 563 </tr> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 564 </table> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 565 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 566 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 567 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 568 <div class="sect1"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 569 <h2 id="install"><a class="anchor" href="#install"></a><a class="link" href="#install">Installation</a></h2> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 570 <div class="sectionbody"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 571 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 572 <p>You can download the latest source distribution as an archive:</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 573 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 574 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 575 <p><a href="https://github.com/zeux/pugixml/releases/download/v1.13/pugixml-1.13.zip">pugixml-1.13.zip</a> (Windows line endings) | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 576 / | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 577 <a href="https://github.com/zeux/pugixml/releases/download/v1.13/pugixml-1.13.tar.gz">pugixml-1.13.tar.gz</a> (Unix line endings)</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 578 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 579 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 580 <p>The distribution contains library source, documentation (the guide you’re reading now and the manual) and some code examples. After downloading the distribution, install pugixml by extracting all files from the compressed archive.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 581 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 582 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 583 <p>The complete pugixml source consists of three files - one source file, <code>pugixml.cpp</code>, and two header files, <code>pugixml.hpp</code> and <code>pugiconfig.hpp</code>. <code>pugixml.hpp</code> is the primary header which you need to include in order to use pugixml classes/functions. The rest of this guide assumes that <code>pugixml.hpp</code> is either in the current directory or in one of include directories of your projects, so that <code>#include "pugixml.hpp"</code> can find the header; however you can also use relative path (i.e. <code>#include "../libs/pugixml/src/pugixml.hpp"</code>) or include directory-relative path (i.e. <code>#include <xml/thirdparty/pugixml/src/pugixml.hpp></code>).</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 584 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 585 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 586 <p>The easiest way to build pugixml is to compile the source file, <code>pugixml.cpp</code>, along with the existing library/executable. This process depends on the method of building your application; for example, if you’re using Microsoft Visual Studio <sup class="footnote">[<a id="_footnoteref_1" class="footnote" href="#_footnotedef_1" title="View footnote.">1</a>]</sup>, Apple Xcode, Code::Blocks or any other IDE, just <strong>add <code>pugixml.cpp</code> to one of your projects</strong>. There are other building methods available, including building pugixml as a standalone static/shared library; <a href="manual.html#install.building">read the manual</a> for further information.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 587 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 588 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 589 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 590 <div class="sect1"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 591 <h2 id="dom"><a class="anchor" href="#dom"></a><a class="link" href="#dom">Document object model</a></h2> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 592 <div class="sectionbody"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 593 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 594 <p>pugixml stores XML data in DOM-like way: the entire XML document (both document structure and element data) is stored in memory as a tree. The tree can be loaded from character stream (file, string, C++ I/O stream), then traversed via special API or XPath expressions. The whole tree is mutable: both node structure and node/attribute data can be changed at any time. Finally, the result of document transformations can be saved to a character stream (file, C++ I/O stream or custom transport).</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 595 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 596 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 597 <p>The root of the tree is the document itself, which corresponds to C++ type <code>xml_document</code>. Document has one or more child nodes, which correspond to C++ type <code>xml_node</code>. Nodes have different types; depending on a type, a node can have a collection of child nodes, a collection of attributes, which correspond to C++ type <code>xml_attribute</code>, and some additional data (i.e. name).</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 598 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 599 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 600 <p>The most common node types are:</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 601 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 602 <div class="ulist"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 603 <ul> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 604 <li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 605 <p>Document node (<code>node_document</code>) - this is the root of the tree, which consists of several child nodes. This node corresponds to <code>xml_document</code> class; note that <code>xml_document</code> is a sub-class of <code>xml_node</code>, so the entire node interface is also available.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 606 </li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 607 <li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 608 <p>Element/tag node (<code>node_element</code>) - this is the most common type of node, which represents XML elements. Element nodes have a name, a collection of attributes and a collection of child nodes (both of which may be empty). The attribute is a simple name/value pair.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 609 </li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 610 <li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 611 <p>Plain character data nodes (<code>node_pcdata</code>) represent plain text in XML. PCDATA nodes have a value, but do not have name or children/attributes. Note that <strong>plain character data is not a part of the element node but instead has its own node</strong>; for example, an element node can have several child PCDATA nodes.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 612 </li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 613 </ul> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 614 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 615 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 616 <p>Despite the fact that there are several node types, there are only three C++ types representing the tree (<code>xml_document</code>, <code>xml_node</code>, <code>xml_attribute</code>); some operations on <code>xml_node</code> are only valid for certain node types. They are described below.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 617 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 618 <div class="admonitionblock note"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 619 <table> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 620 <tr> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 621 <td class="icon"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 622 <div class="title">Note</div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 623 </td> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 624 <td class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 625 All pugixml classes and functions are located in <code>pugi</code> namespace; you have to either use explicit name qualification (i.e. <code>pugi::xml_node</code>), or to gain access to relevant symbols via <code>using</code> directive (i.e. <code>using pugi::xml_node;</code> or <code>using namespace pugi;</code>). | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 626 </td> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 627 </tr> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 628 </table> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 629 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 630 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 631 <p><code>xml_document</code> is the owner of the entire document structure; destroying the document destroys the whole tree. The interface of <code>xml_document</code> consists of loading functions, saving functions and the entire interface of <code>xml_node</code>, which allows for document inspection and/or modification. Note that while <code>xml_document</code> is a sub-class of <code>xml_node</code>, <code>xml_node</code> is not a polymorphic type; the inheritance is present only to simplify usage.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 632 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 633 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 634 <p><code>xml_node</code> is the handle to document node; it can point to any node in the document, including document itself. There is a common interface for nodes of all types. Note that <code>xml_node</code> is only a handle to the actual node, not the node itself - you can have several <code>xml_node</code> handles pointing to the same underlying object. Destroying <code>xml_node</code> handle does not destroy the node and does not remove it from the tree.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 635 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 636 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 637 <p>There is a special value of <code>xml_node</code> type, known as null node or empty node. It does not correspond to any node in any document, and thus resembles null pointer. However, all operations are defined on empty nodes; generally the operations don’t do anything and return empty nodes/attributes or empty strings as their result. This is useful for chaining calls; i.e. you can get the grandparent of a node like so: <code>node.parent().parent()</code>; if a node is a null node or it does not have a parent, the first <code>parent()</code> call returns null node; the second <code>parent()</code> call then also returns null node, so you don’t have to check for errors twice. You can test if a handle is null via implicit boolean cast: <code>if (node) { …​ }</code> or <code>if (!node) { …​ }</code>.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 638 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 639 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 640 <p><code>xml_attribute</code> is the handle to an XML attribute; it has the same semantics as <code>xml_node</code>, i.e. there can be several <code>xml_attribute</code> handles pointing to the same underlying object and there is a special null attribute value, which propagates to function results.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 641 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 642 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 643 <p>There are two choices of interface and internal representation when configuring pugixml: you can either choose the UTF-8 (also called char) interface or UTF-16/32 (also called wchar_t) one. The choice is controlled via <code>PUGIXML_WCHAR_MODE</code> define; you can set it via <code>pugiconfig.hpp</code> or via preprocessor options. All tree functions that work with strings work with either C-style null terminated strings or STL strings of the selected character type. <a href="manual.html#dom.unicode">Read the manual</a> for additional information on Unicode interface.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 644 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 645 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 646 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 647 <div class="sect1"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 648 <h2 id="loading"><a class="anchor" href="#loading"></a><a class="link" href="#loading">Loading document</a></h2> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 649 <div class="sectionbody"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 650 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 651 <p>pugixml provides several functions for loading XML data from various places - files, C++ iostreams, memory buffers. All functions use an extremely fast non-validating parser. This parser is not fully W3C conformant - it can load any valid XML document, but does not perform some well-formedness checks. While considerable effort is made to reject invalid XML documents, some validation is not performed because of performance reasons. XML data is always converted to internal character format before parsing. pugixml supports all popular Unicode encodings (UTF-8, UTF-16 (big and little endian), UTF-32 (big and little endian); UCS-2 is naturally supported since it’s a strict subset of UTF-16) and handles all encoding conversions automatically.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 652 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 653 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 654 <p>The most common source of XML data is files; pugixml provides a separate function for loading XML document from file. This function accepts file path as its first argument, and also two optional arguments, which specify parsing options and input data encoding, which are described in the manual.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 655 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 656 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 657 <p>This is an example of loading XML document from file (<a href="samples/load_file.cpp" class="bare">samples/load_file.cpp</a>):</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 658 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 659 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 660 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 661 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_document</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 662 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 663 <span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_parse_result</span><span class="tok-w"> </span><span class="tok-n">result</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">load_file</span><span class="tok-p">(</span><span class="tok-s">"tree.xml"</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 664 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 665 <span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"Load result: "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">result</span><span class="tok-p">.</span><span class="tok-n">description</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">", mesh name: "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">child</span><span class="tok-p">(</span><span class="tok-s">"mesh"</span><span class="tok-p">).</span><span class="tok-n">attribute</span><span class="tok-p">(</span><span class="tok-s">"name"</span><span class="tok-p">).</span><span class="tok-n">value</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">endl</span><span class="tok-p">;</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 666 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 667 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 668 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 669 <p><code>load_file</code>, as well as other loading functions, destroys the existing document tree and then tries to load the new tree from the specified file. The result of the operation is returned in an <code>xml_parse_result</code> object; this object contains the operation status, and the related information (i.e. last successfully parsed position in the input file, if parsing fails).</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 670 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 671 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 672 <p>Parsing result object can be implicitly converted to <code>bool</code>; if you do not want to handle parsing errors thoroughly, you can just check the return value of load functions as if it was a <code>bool</code>: <code>if (doc.load_file("file.xml")) { …​ } else { …​ }</code>. Otherwise you can use the <code>status</code> member to get parsing status, or the <code>description()</code> member function to get the status in a string form.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 673 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 674 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 675 <p>This is an example of handling loading errors (<a href="samples/load_error_handling.cpp" class="bare">samples/load_error_handling.cpp</a>):</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 676 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 677 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 678 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 679 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_document</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 680 <span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_parse_result</span><span class="tok-w"> </span><span class="tok-n">result</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">load_string</span><span class="tok-p">(</span><span class="tok-n">source</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 681 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 682 <span class="tok-k">if</span><span class="tok-w"> </span><span class="tok-p">(</span><span class="tok-n">result</span><span class="tok-p">)</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 683 <span class="tok-p">{</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 684 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"XML ["</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">source</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"] parsed without errors, attr value: ["</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">child</span><span class="tok-p">(</span><span class="tok-s">"node"</span><span class="tok-p">).</span><span class="tok-n">attribute</span><span class="tok-p">(</span><span class="tok-s">"attr"</span><span class="tok-p">).</span><span class="tok-n">value</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"]</span><span class="tok-se">\n\n</span><span class="tok-s">"</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 685 <span class="tok-p">}</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 686 <span class="tok-k">else</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 687 <span class="tok-p">{</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 688 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"XML ["</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">source</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"] parsed with errors, attr value: ["</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">child</span><span class="tok-p">(</span><span class="tok-s">"node"</span><span class="tok-p">).</span><span class="tok-n">attribute</span><span class="tok-p">(</span><span class="tok-s">"attr"</span><span class="tok-p">).</span><span class="tok-n">value</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"]</span><span class="tok-se">\n</span><span class="tok-s">"</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 689 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"Error description: "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">result</span><span class="tok-p">.</span><span class="tok-n">description</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"</span><span class="tok-se">\n</span><span class="tok-s">"</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 690 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"Error offset: "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">result</span><span class="tok-p">.</span><span class="tok-n">offset</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">" (error at [..."</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-p">(</span><span class="tok-n">source</span><span class="tok-w"> </span><span class="tok-o">+</span><span class="tok-w"> </span><span class="tok-n">result</span><span class="tok-p">.</span><span class="tok-n">offset</span><span class="tok-p">)</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"]</span><span class="tok-se">\n\n</span><span class="tok-s">"</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 691 <span class="tok-p">}</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 692 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 693 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 694 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 695 <p>Sometimes XML data should be loaded from some other source than file, i.e. HTTP URL; also you may want to load XML data from file using non-standard functions, i.e. to use your virtual file system facilities or to load XML from gzip-compressed files. These scenarios either require loading document from memory, in which case you should prepare a contiguous memory block with all XML data and to pass it to one of buffer loading functions, or loading document from C++ IOstream, in which case you should provide an object which implements <code>std::istream</code> or <code>std::wistream</code> interface.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 696 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 697 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 698 <p>There are different functions for loading document from memory; they treat the passed buffer as either an immutable one (<code>load_buffer</code>), a mutable buffer which is owned by the caller (<code>load_buffer_inplace</code>), or a mutable buffer which ownership belongs to pugixml (<code>load_buffer_inplace_own</code>). There is also a simple helper function, <code>xml_document::load</code>, for cases when you want to load the XML document from null-terminated character string.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 699 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 700 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 701 <p>This is an example of loading XML document from memory using one of these functions (<a href="samples/load_memory.cpp" class="bare">samples/load_memory.cpp</a>); read the sample code for more examples:</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 702 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 703 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 704 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 705 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-k">const</span><span class="tok-w"> </span><span class="tok-kt">char</span><span class="tok-w"> </span><span class="tok-n">source</span><span class="tok-p">[]</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-s">"<mesh name='sphere'><bounds>0 0 1 1</bounds></mesh>"</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 706 <span class="tok-kt">size_t</span><span class="tok-w"> </span><span class="tok-n">size</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-k">sizeof</span><span class="tok-p">(</span><span class="tok-n">source</span><span class="tok-p">);</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 707 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 708 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 709 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 710 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 711 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-c1">// You can use load_buffer_inplace to load document from mutable memory block; the block's lifetime must exceed that of document</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 712 <span class="tok-kt">char</span><span class="tok-o">*</span><span class="tok-w"> </span><span class="tok-n">buffer</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-k">new</span><span class="tok-w"> </span><span class="tok-kt">char</span><span class="tok-p">[</span><span class="tok-n">size</span><span class="tok-p">];</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 713 <span class="tok-n">memcpy</span><span class="tok-p">(</span><span class="tok-n">buffer</span><span class="tok-p">,</span><span class="tok-w"> </span><span class="tok-n">source</span><span class="tok-p">,</span><span class="tok-w"> </span><span class="tok-n">size</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 714 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 715 <span class="tok-c1">// The block can be allocated by any method; the block is modified during parsing</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 716 <span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_parse_result</span><span class="tok-w"> </span><span class="tok-n">result</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">load_buffer_inplace</span><span class="tok-p">(</span><span class="tok-n">buffer</span><span class="tok-p">,</span><span class="tok-w"> </span><span class="tok-n">size</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 717 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 718 <span class="tok-c1">// You have to destroy the block yourself after the document is no longer used</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 719 <span class="tok-k">delete</span><span class="tok-p">[]</span><span class="tok-w"> </span><span class="tok-n">buffer</span><span class="tok-p">;</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 720 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 721 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 722 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 723 <p>This is a simple example of loading XML document from file using streams (<a href="samples/load_stream.cpp" class="bare">samples/load_stream.cpp</a>); read the sample code for more complex examples involving wide streams and locales:</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 724 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 725 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 726 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 727 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">ifstream</span><span class="tok-w"> </span><span class="tok-nf">stream</span><span class="tok-p">(</span><span class="tok-s">"weekly-utf-8.xml"</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 728 <span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_parse_result</span><span class="tok-w"> </span><span class="tok-n">result</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">load</span><span class="tok-p">(</span><span class="tok-n">stream</span><span class="tok-p">);</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 729 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 730 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 731 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 732 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 733 <div class="sect1"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 734 <h2 id="access"><a class="anchor" href="#access"></a><a class="link" href="#access">Accessing document data</a></h2> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 735 <div class="sectionbody"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 736 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 737 <p>pugixml features an extensive interface for getting various types of data from the document and for traversing the document. You can use various accessors to get node/attribute data, you can traverse the child node/attribute lists via accessors or iterators, you can do depth-first traversals with <code>xml_tree_walker</code> objects, and you can use XPath for complex data-driven queries.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 738 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 739 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 740 <p>You can get node or attribute name via <code>name()</code> accessor, and value via <code>value()</code> accessor. Note that both functions never return null pointers - they either return a string with the relevant content, or an empty string if name/value is absent or if the handle is null. Also there are two notable things for reading values:</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 741 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 742 <div class="ulist"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 743 <ul> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 744 <li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 745 <p>It is common to store data as text contents of some node - i.e. <code><node><description>This is a node</description></node></code>. In this case, <code><description></code> node does not have a value, but instead has a child of type <code>node_pcdata</code> with value <code>"This is a node"</code>. pugixml provides <code>child_value()</code> and <code>text()</code> helper functions to parse such data.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 746 </li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 747 <li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 748 <p>In many cases attribute values have types that are not strings - i.e. an attribute may always contain values that should be treated as integers, despite the fact that they are represented as strings in XML. pugixml provides several accessors that convert attribute value to some other type.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 749 </li> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 750 </ul> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 751 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 752 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 753 <p>This is an example of using these functions (<a href="samples/traverse_base.cpp" class="bare">samples/traverse_base.cpp</a>):</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 754 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 755 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 756 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 757 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-k">for</span><span class="tok-w"> </span><span class="tok-p">(</span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_node</span><span class="tok-w"> </span><span class="tok-n">tool</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">tools</span><span class="tok-p">.</span><span class="tok-n">child</span><span class="tok-p">(</span><span class="tok-s">"Tool"</span><span class="tok-p">);</span><span class="tok-w"> </span><span class="tok-n">tool</span><span class="tok-p">;</span><span class="tok-w"> </span><span class="tok-n">tool</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">tool</span><span class="tok-p">.</span><span class="tok-n">next_sibling</span><span class="tok-p">(</span><span class="tok-s">"Tool"</span><span class="tok-p">))</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 758 <span class="tok-p">{</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 759 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"Tool "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">tool</span><span class="tok-p">.</span><span class="tok-n">attribute</span><span class="tok-p">(</span><span class="tok-s">"Filename"</span><span class="tok-p">).</span><span class="tok-n">value</span><span class="tok-p">();</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 760 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">": AllowRemote "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">tool</span><span class="tok-p">.</span><span class="tok-n">attribute</span><span class="tok-p">(</span><span class="tok-s">"AllowRemote"</span><span class="tok-p">).</span><span class="tok-n">as_bool</span><span class="tok-p">();</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 761 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">", Timeout "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">tool</span><span class="tok-p">.</span><span class="tok-n">attribute</span><span class="tok-p">(</span><span class="tok-s">"Timeout"</span><span class="tok-p">).</span><span class="tok-n">as_int</span><span class="tok-p">();</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 762 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">", Description '"</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">tool</span><span class="tok-p">.</span><span class="tok-n">child_value</span><span class="tok-p">(</span><span class="tok-s">"Description"</span><span class="tok-p">)</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"'</span><span class="tok-se">\n</span><span class="tok-s">"</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 763 <span class="tok-p">}</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 764 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 765 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 766 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 767 <p>Since a lot of document traversal consists of finding the node/attribute with the correct name, there are special functions for that purpose. For example, <code>child("Tool")</code> returns the first node which has the name <code>"Tool"</code>, or null handle if there is no such node. This is an example of using such functions (<a href="samples/traverse_base.cpp" class="bare">samples/traverse_base.cpp</a>):</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 768 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 769 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 770 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 771 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"Tool for *.dae generation: "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">tools</span><span class="tok-p">.</span><span class="tok-n">find_child_by_attribute</span><span class="tok-p">(</span><span class="tok-s">"Tool"</span><span class="tok-p">,</span><span class="tok-w"> </span><span class="tok-s">"OutputFileMasks"</span><span class="tok-p">,</span><span class="tok-w"> </span><span class="tok-s">"*.dae"</span><span class="tok-p">).</span><span class="tok-n">attribute</span><span class="tok-p">(</span><span class="tok-s">"Filename"</span><span class="tok-p">).</span><span class="tok-n">value</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"</span><span class="tok-se">\n</span><span class="tok-s">"</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 772 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 773 <span class="tok-k">for</span><span class="tok-w"> </span><span class="tok-p">(</span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_node</span><span class="tok-w"> </span><span class="tok-n">tool</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">tools</span><span class="tok-p">.</span><span class="tok-n">child</span><span class="tok-p">(</span><span class="tok-s">"Tool"</span><span class="tok-p">);</span><span class="tok-w"> </span><span class="tok-n">tool</span><span class="tok-p">;</span><span class="tok-w"> </span><span class="tok-n">tool</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">tool</span><span class="tok-p">.</span><span class="tok-n">next_sibling</span><span class="tok-p">(</span><span class="tok-s">"Tool"</span><span class="tok-p">))</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 774 <span class="tok-p">{</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 775 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"Tool "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">tool</span><span class="tok-p">.</span><span class="tok-n">attribute</span><span class="tok-p">(</span><span class="tok-s">"Filename"</span><span class="tok-p">).</span><span class="tok-n">value</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"</span><span class="tok-se">\n</span><span class="tok-s">"</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 776 <span class="tok-p">}</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 777 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 778 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 779 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 780 <p>Child node lists and attribute lists are simply double-linked lists; while you can use <code>previous_sibling</code>/<code>next_sibling</code> and other such functions for iteration, pugixml additionally provides node and attribute iterators, so that you can treat nodes as containers of other nodes or attributes. All iterators are bidirectional and support all usual iterator operations. The iterators are invalidated if the node/attribute objects they’re pointing to are removed from the tree; adding nodes/attributes does not invalidate any iterators.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 781 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 782 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 783 <p>Here is an example of using iterators for document traversal (<a href="samples/traverse_iter.cpp" class="bare">samples/traverse_iter.cpp</a>):</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 784 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 785 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 786 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 787 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-k">for</span><span class="tok-w"> </span><span class="tok-p">(</span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_node_iterator</span><span class="tok-w"> </span><span class="tok-n">it</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">tools</span><span class="tok-p">.</span><span class="tok-n">begin</span><span class="tok-p">();</span><span class="tok-w"> </span><span class="tok-n">it</span><span class="tok-w"> </span><span class="tok-o">!=</span><span class="tok-w"> </span><span class="tok-n">tools</span><span class="tok-p">.</span><span class="tok-n">end</span><span class="tok-p">();</span><span class="tok-w"> </span><span class="tok-o">++</span><span class="tok-n">it</span><span class="tok-p">)</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 788 <span class="tok-p">{</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 789 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"Tool:"</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 790 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 791 <span class="tok-w"> </span><span class="tok-k">for</span><span class="tok-w"> </span><span class="tok-p">(</span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_attribute_iterator</span><span class="tok-w"> </span><span class="tok-n">ait</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">it</span><span class="tok-o">-></span><span class="tok-n">attributes_begin</span><span class="tok-p">();</span><span class="tok-w"> </span><span class="tok-n">ait</span><span class="tok-w"> </span><span class="tok-o">!=</span><span class="tok-w"> </span><span class="tok-n">it</span><span class="tok-o">-></span><span class="tok-n">attributes_end</span><span class="tok-p">();</span><span class="tok-w"> </span><span class="tok-o">++</span><span class="tok-n">ait</span><span class="tok-p">)</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 792 <span class="tok-w"> </span><span class="tok-p">{</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 793 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">" "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">ait</span><span class="tok-o">-></span><span class="tok-n">name</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"="</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">ait</span><span class="tok-o">-></span><span class="tok-n">value</span><span class="tok-p">();</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 794 <span class="tok-w"> </span><span class="tok-p">}</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 795 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 796 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">endl</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 797 <span class="tok-p">}</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 798 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 799 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 800 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 801 <p>If your C++ compiler supports range-based for-loop (this is a C++11 feature, at the time of writing it’s supported by Microsoft Visual Studio 11 Beta, GCC 4.6 and Clang 3.0), you can use it to enumerate nodes/attributes. Additional helpers are provided to support this; note that they are also compatible with <a href="http://www.boost.org/libs/foreach/">Boost Foreach</a>, and possibly other pre-C++11 foreach facilities.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 802 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 803 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 804 <p>Here is an example of using C++11 range-based for loop for document traversal (<a href="samples/traverse_rangefor.cpp" class="bare">samples/traverse_rangefor.cpp</a>):</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 805 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 806 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 807 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 808 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-k">for</span><span class="tok-w"> </span><span class="tok-p">(</span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_node</span><span class="tok-w"> </span><span class="tok-n">tool</span><span class="tok-o">:</span><span class="tok-w"> </span><span class="tok-n">tools</span><span class="tok-p">.</span><span class="tok-n">children</span><span class="tok-p">(</span><span class="tok-s">"Tool"</span><span class="tok-p">))</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 809 <span class="tok-p">{</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 810 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"Tool:"</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 811 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 812 <span class="tok-w"> </span><span class="tok-k">for</span><span class="tok-w"> </span><span class="tok-p">(</span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_attribute</span><span class="tok-w"> </span><span class="tok-n">attr</span><span class="tok-o">:</span><span class="tok-w"> </span><span class="tok-n">tool</span><span class="tok-p">.</span><span class="tok-n">attributes</span><span class="tok-p">())</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 813 <span class="tok-w"> </span><span class="tok-p">{</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 814 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">" "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">attr</span><span class="tok-p">.</span><span class="tok-n">name</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"="</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">attr</span><span class="tok-p">.</span><span class="tok-n">value</span><span class="tok-p">();</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 815 <span class="tok-w"> </span><span class="tok-p">}</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 816 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 817 <span class="tok-w"> </span><span class="tok-k">for</span><span class="tok-w"> </span><span class="tok-p">(</span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_node</span><span class="tok-w"> </span><span class="tok-n">child</span><span class="tok-o">:</span><span class="tok-w"> </span><span class="tok-n">tool</span><span class="tok-p">.</span><span class="tok-n">children</span><span class="tok-p">())</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 818 <span class="tok-w"> </span><span class="tok-p">{</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 819 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">", child "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">child</span><span class="tok-p">.</span><span class="tok-n">name</span><span class="tok-p">();</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 820 <span class="tok-w"> </span><span class="tok-p">}</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 821 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 822 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">endl</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 823 <span class="tok-p">}</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 824 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 825 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 826 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 827 <p>The methods described above allow traversal of immediate children of some node; if you want to do a deep tree traversal, you’ll have to do it via a recursive function or some equivalent method. However, pugixml provides a helper for depth-first traversal of a subtree. In order to use it, you have to implement <code>xml_tree_walker</code> interface and to call <code>traverse</code> function.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 828 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 829 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 830 <p>This is an example of traversing tree hierarchy with xml_tree_walker (<a href="samples/traverse_walker.cpp" class="bare">samples/traverse_walker.cpp</a>):</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 831 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 832 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 833 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 834 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-k">struct</span><span class="tok-w"> </span><span class="tok-nc">simple_walker</span><span class="tok-o">:</span><span class="tok-w"> </span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_tree_walker</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 835 <span class="tok-p">{</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 836 <span class="tok-w"> </span><span class="tok-k">virtual</span><span class="tok-w"> </span><span class="tok-kt">bool</span><span class="tok-w"> </span><span class="tok-nf">for_each</span><span class="tok-p">(</span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_node</span><span class="tok-o">&</span><span class="tok-w"> </span><span class="tok-n">node</span><span class="tok-p">)</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 837 <span class="tok-w"> </span><span class="tok-p">{</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 838 <span class="tok-w"> </span><span class="tok-k">for</span><span class="tok-w"> </span><span class="tok-p">(</span><span class="tok-kt">int</span><span class="tok-w"> </span><span class="tok-n">i</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-mi">0</span><span class="tok-p">;</span><span class="tok-w"> </span><span class="tok-n">i</span><span class="tok-w"> </span><span class="tok-o"><</span><span class="tok-w"> </span><span class="tok-n">depth</span><span class="tok-p">();</span><span class="tok-w"> </span><span class="tok-o">++</span><span class="tok-n">i</span><span class="tok-p">)</span><span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">" "</span><span class="tok-p">;</span><span class="tok-w"> </span><span class="tok-c1">// indentation</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 839 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 840 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">node_types</span><span class="tok-p">[</span><span class="tok-n">node</span><span class="tok-p">.</span><span class="tok-n">type</span><span class="tok-p">()]</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">": name='"</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">node</span><span class="tok-p">.</span><span class="tok-n">name</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"', value='"</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">node</span><span class="tok-p">.</span><span class="tok-n">value</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"'</span><span class="tok-se">\n</span><span class="tok-s">"</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 841 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 842 <span class="tok-w"> </span><span class="tok-k">return</span><span class="tok-w"> </span><span class="tok-nb">true</span><span class="tok-p">;</span><span class="tok-w"> </span><span class="tok-c1">// continue traversal</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 843 <span class="tok-w"> </span><span class="tok-p">}</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 844 <span class="tok-p">};</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 845 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 846 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 847 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 848 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 849 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-n">simple_walker</span><span class="tok-w"> </span><span class="tok-n">walker</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 850 <span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">traverse</span><span class="tok-p">(</span><span class="tok-n">walker</span><span class="tok-p">);</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 851 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 852 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 853 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 854 <p>Finally, for complex queries often a higher-level DSL is needed. pugixml provides an implementation of XPath 1.0 language for such queries. The complete description of XPath usage can be found in the manual, but here are some examples:</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 855 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 856 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 857 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 858 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xpath_node_set</span><span class="tok-w"> </span><span class="tok-n">tools</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">select_nodes</span><span class="tok-p">(</span><span class="tok-s">"/Profile/Tools/Tool[@AllowRemote='true' and @DeriveCaptionFrom='lastparam']"</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 859 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 860 <span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"Tools:</span><span class="tok-se">\n</span><span class="tok-s">"</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 861 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 862 <span class="tok-k">for</span><span class="tok-w"> </span><span class="tok-p">(</span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xpath_node_set</span><span class="tok-o">::</span><span class="tok-n">const_iterator</span><span class="tok-w"> </span><span class="tok-n">it</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">tools</span><span class="tok-p">.</span><span class="tok-n">begin</span><span class="tok-p">();</span><span class="tok-w"> </span><span class="tok-n">it</span><span class="tok-w"> </span><span class="tok-o">!=</span><span class="tok-w"> </span><span class="tok-n">tools</span><span class="tok-p">.</span><span class="tok-n">end</span><span class="tok-p">();</span><span class="tok-w"> </span><span class="tok-o">++</span><span class="tok-n">it</span><span class="tok-p">)</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 863 <span class="tok-p">{</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 864 <span class="tok-w"> </span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xpath_node</span><span class="tok-w"> </span><span class="tok-n">node</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-o">*</span><span class="tok-n">it</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 865 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">node</span><span class="tok-p">.</span><span class="tok-n">node</span><span class="tok-p">().</span><span class="tok-n">attribute</span><span class="tok-p">(</span><span class="tok-s">"Filename"</span><span class="tok-p">).</span><span class="tok-n">value</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"</span><span class="tok-se">\n</span><span class="tok-s">"</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 866 <span class="tok-p">}</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 867 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 868 <span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xpath_node</span><span class="tok-w"> </span><span class="tok-n">build_tool</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">select_node</span><span class="tok-p">(</span><span class="tok-s">"//Tool[contains(Description, 'build system')]"</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 869 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 870 <span class="tok-k">if</span><span class="tok-w"> </span><span class="tok-p">(</span><span class="tok-n">build_tool</span><span class="tok-p">)</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 871 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"Build tool: "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">build_tool</span><span class="tok-p">.</span><span class="tok-n">node</span><span class="tok-p">().</span><span class="tok-n">attribute</span><span class="tok-p">(</span><span class="tok-s">"Filename"</span><span class="tok-p">).</span><span class="tok-n">value</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"</span><span class="tok-se">\n</span><span class="tok-s">"</span><span class="tok-p">;</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 872 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 873 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 874 <div class="admonitionblock caution"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 875 <table> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 876 <tr> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 877 <td class="icon"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 878 <div class="title">Caution</div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 879 </td> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 880 <td class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 881 XPath functions throw <code>xpath_exception</code> objects on error; the sample above does not catch these exceptions. | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 882 </td> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 883 </tr> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 884 </table> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 885 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 886 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 887 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 888 <div class="sect1"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 889 <h2 id="modify"><a class="anchor" href="#modify"></a><a class="link" href="#modify">Modifying document data</a></h2> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 890 <div class="sectionbody"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 891 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 892 <p>The document in pugixml is fully mutable: you can completely change the document structure and modify the data of nodes/attributes. All functions take care of memory management and structural integrity themselves, so they always result in structurally valid tree - however, it is possible to create an invalid XML tree (for example, by adding two attributes with the same name or by setting attribute/node name to empty/invalid string). Tree modification is optimized for performance and for memory consumption, so if you have enough memory you can create documents from scratch with pugixml and later save them to file/stream instead of relying on error-prone manual text writing and without too much overhead.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 893 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 894 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 895 <p>All member functions that change node/attribute data or structure are non-constant and thus can not be called on constant handles. However, you can easily convert constant handle to non-constant one by simple assignment: <code>void foo(const pugi::xml_node& n) { pugi::xml_node nc = n; }</code>, so const-correctness here mainly provides additional documentation.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 896 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 897 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 898 <p>As discussed before, nodes can have name and value, both of which are strings. Depending on node type, name or value may be absent. You can use <code>set_name</code> and <code>set_value</code> member functions to set them. Similar functions are available for attributes; however, the <code>set_value</code> function is overloaded for some other types except strings, like floating-point numbers. Also, attribute value can be set using an assignment operator. This is an example of setting node/attribute name and value (<a href="samples/modify_base.cpp" class="bare">samples/modify_base.cpp</a>):</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 899 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 900 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 901 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 902 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_node</span><span class="tok-w"> </span><span class="tok-n">node</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">child</span><span class="tok-p">(</span><span class="tok-s">"node"</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 903 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 904 <span class="tok-c1">// change node name</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 905 <span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">node</span><span class="tok-p">.</span><span class="tok-n">set_name</span><span class="tok-p">(</span><span class="tok-s">"notnode"</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 906 <span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">", new node name: "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">node</span><span class="tok-p">.</span><span class="tok-n">name</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">endl</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 907 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 908 <span class="tok-c1">// change comment text</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 909 <span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">last_child</span><span class="tok-p">().</span><span class="tok-n">set_value</span><span class="tok-p">(</span><span class="tok-s">"useless comment"</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 910 <span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">", new comment text: "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">last_child</span><span class="tok-p">().</span><span class="tok-n">value</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">endl</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 911 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 912 <span class="tok-c1">// we can't change value of the element or name of the comment</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 913 <span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">node</span><span class="tok-p">.</span><span class="tok-n">set_value</span><span class="tok-p">(</span><span class="tok-s">"1"</span><span class="tok-p">)</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">", "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">last_child</span><span class="tok-p">().</span><span class="tok-n">set_name</span><span class="tok-p">(</span><span class="tok-s">"2"</span><span class="tok-p">)</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">endl</span><span class="tok-p">;</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 914 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 915 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 916 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 917 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 918 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_attribute</span><span class="tok-w"> </span><span class="tok-n">attr</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">node</span><span class="tok-p">.</span><span class="tok-n">attribute</span><span class="tok-p">(</span><span class="tok-s">"id"</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 919 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 920 <span class="tok-c1">// change attribute name/value</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 921 <span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">attr</span><span class="tok-p">.</span><span class="tok-n">set_name</span><span class="tok-p">(</span><span class="tok-s">"key"</span><span class="tok-p">)</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">", "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">attr</span><span class="tok-p">.</span><span class="tok-n">set_value</span><span class="tok-p">(</span><span class="tok-s">"345"</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 922 <span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">", new attribute: "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">attr</span><span class="tok-p">.</span><span class="tok-n">name</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"="</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">attr</span><span class="tok-p">.</span><span class="tok-n">value</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">endl</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 923 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 924 <span class="tok-c1">// we can use numbers or booleans</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 925 <span class="tok-n">attr</span><span class="tok-p">.</span><span class="tok-n">set_value</span><span class="tok-p">(</span><span class="tok-mf">1.234</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 926 <span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"new attribute value: "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">attr</span><span class="tok-p">.</span><span class="tok-n">value</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">endl</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 927 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 928 <span class="tok-c1">// we can also use assignment operators for more concise code</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 929 <span class="tok-n">attr</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-nb">true</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 930 <span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"final attribute value: "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">attr</span><span class="tok-p">.</span><span class="tok-n">value</span><span class="tok-p">()</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">endl</span><span class="tok-p">;</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 931 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 932 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 933 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 934 <p>Nodes and attributes do not exist without a document tree, so you can’t create them without adding them to some document. A node or attribute can be created at the end of node/attribute list or before/after some other node. All insertion functions return the handle to newly created object on success, and null handle on failure. Even if the operation fails (for example, if you’re trying to add a child node to PCDATA node), the document remains in consistent state, but the requested node/attribute is not added.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 935 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 936 <div class="admonitionblock caution"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 937 <table> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 938 <tr> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 939 <td class="icon"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 940 <div class="title">Caution</div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 941 </td> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 942 <td class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 943 <code>attribute()</code> and <code>child()</code> functions do not add attributes or nodes to the tree, so code like <code>node.attribute("id") = 123;</code> will not do anything if <code>node</code> does not have an attribute with name <code>"id"</code>. Make sure you’re operating with existing attributes/nodes by adding them if necessary. | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 944 </td> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 945 </tr> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 946 </table> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 947 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 948 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 949 <p>This is an example of adding new attributes/nodes to the document (<a href="samples/modify_add.cpp" class="bare">samples/modify_add.cpp</a>):</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 950 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 951 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 952 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 953 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-c1">// add node with some name</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 954 <span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_node</span><span class="tok-w"> </span><span class="tok-n">node</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">append_child</span><span class="tok-p">(</span><span class="tok-s">"node"</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 955 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 956 <span class="tok-c1">// add description node with text child</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 957 <span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_node</span><span class="tok-w"> </span><span class="tok-n">descr</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">node</span><span class="tok-p">.</span><span class="tok-n">append_child</span><span class="tok-p">(</span><span class="tok-s">"description"</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 958 <span class="tok-n">descr</span><span class="tok-p">.</span><span class="tok-n">append_child</span><span class="tok-p">(</span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">node_pcdata</span><span class="tok-p">).</span><span class="tok-n">set_value</span><span class="tok-p">(</span><span class="tok-s">"Simple node"</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 959 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 960 <span class="tok-c1">// add param node before the description</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 961 <span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_node</span><span class="tok-w"> </span><span class="tok-n">param</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">node</span><span class="tok-p">.</span><span class="tok-n">insert_child_before</span><span class="tok-p">(</span><span class="tok-s">"param"</span><span class="tok-p">,</span><span class="tok-w"> </span><span class="tok-n">descr</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 962 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 963 <span class="tok-c1">// add attributes to param node</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 964 <span class="tok-n">param</span><span class="tok-p">.</span><span class="tok-n">append_attribute</span><span class="tok-p">(</span><span class="tok-s">"name"</span><span class="tok-p">)</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-s">"version"</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 965 <span class="tok-n">param</span><span class="tok-p">.</span><span class="tok-n">append_attribute</span><span class="tok-p">(</span><span class="tok-s">"value"</span><span class="tok-p">)</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-mf">1.1</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 966 <span class="tok-n">param</span><span class="tok-p">.</span><span class="tok-n">insert_attribute_after</span><span class="tok-p">(</span><span class="tok-s">"type"</span><span class="tok-p">,</span><span class="tok-w"> </span><span class="tok-n">param</span><span class="tok-p">.</span><span class="tok-n">attribute</span><span class="tok-p">(</span><span class="tok-s">"name"</span><span class="tok-p">))</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-s">"float"</span><span class="tok-p">;</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 967 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 968 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 969 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 970 <p>If you do not want your document to contain some node or attribute, you can remove it with <code>remove_attribute</code> and <code>remove_child</code> functions. Removing the attribute or node invalidates all handles to the same underlying object, and also invalidates all iterators pointing to the same object. Removing node also invalidates all past-the-end iterators to its attribute or child node list. Be careful to ensure that all such handles and iterators either do not exist or are not used after the attribute/node is removed.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 971 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 972 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 973 <p>This is an example of removing attributes/nodes from the document (<a href="samples/modify_remove.cpp" class="bare">samples/modify_remove.cpp</a>):</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 974 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 975 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 976 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 977 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-c1">// remove description node with the whole subtree</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 978 <span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_node</span><span class="tok-w"> </span><span class="tok-n">node</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">child</span><span class="tok-p">(</span><span class="tok-s">"node"</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 979 <span class="tok-n">node</span><span class="tok-p">.</span><span class="tok-n">remove_child</span><span class="tok-p">(</span><span class="tok-s">"description"</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 980 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 981 <span class="tok-c1">// remove id attribute</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 982 <span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_node</span><span class="tok-w"> </span><span class="tok-n">param</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">node</span><span class="tok-p">.</span><span class="tok-n">child</span><span class="tok-p">(</span><span class="tok-s">"param"</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 983 <span class="tok-n">param</span><span class="tok-p">.</span><span class="tok-n">remove_attribute</span><span class="tok-p">(</span><span class="tok-s">"value"</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 984 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 985 <span class="tok-c1">// we can also remove nodes/attributes by handles</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 986 <span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_attribute</span><span class="tok-w"> </span><span class="tok-n">id</span><span class="tok-w"> </span><span class="tok-o">=</span><span class="tok-w"> </span><span class="tok-n">param</span><span class="tok-p">.</span><span class="tok-n">attribute</span><span class="tok-p">(</span><span class="tok-s">"name"</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 987 <span class="tok-n">param</span><span class="tok-p">.</span><span class="tok-n">remove_attribute</span><span class="tok-p">(</span><span class="tok-n">id</span><span class="tok-p">);</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 988 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 989 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 990 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 991 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 992 <div class="sect1"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 993 <h2 id="saving"><a class="anchor" href="#saving"></a><a class="link" href="#saving">Saving document</a></h2> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 994 <div class="sectionbody"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 995 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 996 <p>Often after creating a new document or loading the existing one and processing it, it is necessary to save the result back to file. Also it is occasionally useful to output the whole document or a subtree to some stream; use cases include debug printing, serialization via network or other text-oriented medium, etc. pugixml provides several functions to output any subtree of the document to a file, stream or another generic transport interface; these functions allow to customize the output format, and also perform necessary encoding conversions.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 997 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 998 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 999 <p>Before writing to the destination the node/attribute data is properly formatted according to the node type; all special XML symbols, such as < and &, are properly escaped. In order to guard against forgotten node/attribute names, empty node/attribute names are printed as <code>":anonymous"</code>. For well-formed output, make sure all node and attribute names are set to meaningful values.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1000 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1001 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1002 <p>If you want to save the whole document to a file, you can use the <code>save_file</code> function, which returns <code>true</code> on success. This is a simple example of saving XML document to file (<a href="samples/save_file.cpp" class="bare">samples/save_file.cpp</a>):</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1003 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1004 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1005 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1006 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-c1">// save document to file</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1007 <span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"Saving result: "</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">save_file</span><span class="tok-p">(</span><span class="tok-s">"save_file_output.xml"</span><span class="tok-p">)</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">endl</span><span class="tok-p">;</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1008 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1009 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1010 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1011 <p>To enhance interoperability pugixml provides functions for saving document to any object which implements C++ <code>std::ostream</code> interface. This allows you to save documents to any standard C++ stream (i.e. file stream) or any third-party compliant implementation (i.e. Boost Iostreams). Most notably, this allows for easy debug output, since you can use <code>std::cout</code> stream as saving target. There are two functions, one works with narrow character streams, another handles wide character ones.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1012 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1013 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1014 <p>This is a simple example of saving XML document to standard output (<a href="samples/save_stream.cpp" class="bare">samples/save_stream.cpp</a>):</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1015 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1016 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1017 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1018 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-c1">// save document to standard output</span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1019 <span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-w"> </span><span class="tok-o"><<</span><span class="tok-w"> </span><span class="tok-s">"Document:</span><span class="tok-se">\n</span><span class="tok-s">"</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1020 <span class="tok-n">doc</span><span class="tok-p">.</span><span class="tok-n">save</span><span class="tok-p">(</span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">cout</span><span class="tok-p">);</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1021 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1022 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1023 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1024 <p>All of the above saving functions are implemented in terms of writer interface. This is a simple interface with a single function, which is called several times during output process with chunks of document data as input. In order to output the document via some custom transport, for example sockets, you should create an object which implements <code>xml_writer_file</code> interface and pass it to <code>xml_document::save</code> function.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1025 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1026 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1027 <p>This is a simple example of custom writer for saving document data to STL string (<a href="samples/save_custom_writer.cpp" class="bare">samples/save_custom_writer.cpp</a>); read the sample code for more complex examples:</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1028 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1029 <div class="listingblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1030 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1031 <pre class="pygments highlight"><code data-lang="c++"><span></span><span class="tok-k">struct</span><span class="tok-w"> </span><span class="tok-nc">xml_string_writer</span><span class="tok-o">:</span><span class="tok-w"> </span><span class="tok-n">pugi</span><span class="tok-o">::</span><span class="tok-n">xml_writer</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1032 <span class="tok-p">{</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1033 <span class="tok-w"> </span><span class="tok-n">std</span><span class="tok-o">::</span><span class="tok-n">string</span><span class="tok-w"> </span><span class="tok-n">result</span><span class="tok-p">;</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1034 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1035 <span class="tok-w"> </span><span class="tok-k">virtual</span><span class="tok-w"> </span><span class="tok-kt">void</span><span class="tok-w"> </span><span class="tok-nf">write</span><span class="tok-p">(</span><span class="tok-k">const</span><span class="tok-w"> </span><span class="tok-kt">void</span><span class="tok-o">*</span><span class="tok-w"> </span><span class="tok-n">data</span><span class="tok-p">,</span><span class="tok-w"> </span><span class="tok-kt">size_t</span><span class="tok-w"> </span><span class="tok-n">size</span><span class="tok-p">)</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1036 <span class="tok-w"> </span><span class="tok-p">{</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1037 <span class="tok-w"> </span><span class="tok-n">result</span><span class="tok-p">.</span><span class="tok-n">append</span><span class="tok-p">(</span><span class="tok-k">static_cast</span><span class="tok-o"><</span><span class="tok-k">const</span><span class="tok-w"> </span><span class="tok-kt">char</span><span class="tok-o">*></span><span class="tok-p">(</span><span class="tok-n">data</span><span class="tok-p">),</span><span class="tok-w"> </span><span class="tok-n">size</span><span class="tok-p">);</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1038 <span class="tok-w"> </span><span class="tok-p">}</span><span class="tok-w"></span> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1039 <span class="tok-p">};</span><span class="tok-w"></span></code></pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1040 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1041 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1042 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1043 <p>While the previously described functions save the whole document to the destination, it is easy to save a single subtree. Instead of calling <code>xml_document::save</code>, just call <code>xml_node::print</code> function on the target node. You can save node contents to C++ IOstream object or custom writer in this way. Saving a subtree slightly differs from saving the whole document; <a href="manual.html#saving.subtree">read the manual</a> for more information.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1044 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1045 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1046 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1047 <div class="sect1"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1048 <h2 id="feedback"><a class="anchor" href="#feedback"></a><a class="link" href="#feedback">Feedback</a></h2> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1049 <div class="sectionbody"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1050 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1051 <p>If you believe you’ve found a bug in pugixml, please file an issue via <a href="https://github.com/zeux/pugixml/issues/new">issue submission form</a>. Be sure to include the relevant information so that the bug can be reproduced: the version of pugixml, compiler version and target architecture, the code that uses pugixml and exhibits the bug, etc. Feature requests and contributions can be filed as issues, too.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1052 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1053 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1054 <p>If filing an issue is not possible due to privacy or other concerns, you can contact pugixml author by e-mail directly: <a href="mailto:arseny.kapoulkine@gmail.com">arseny.kapoulkine@gmail.com</a>.</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1055 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1056 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1057 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1058 <div class="sect1"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1059 <h2 id="license"><a class="anchor" href="#license"></a><a class="link" href="#license">License</a></h2> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1060 <div class="sectionbody"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1061 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1062 <p>The pugixml library is distributed under the MIT license:</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1063 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1064 <div class="literalblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1065 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1066 <pre>Copyright (c) 2006-2022 Arseny Kapoulkine | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1067 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1068 Permission is hereby granted, free of charge, to any person | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1069 obtaining a copy of this software and associated documentation | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1070 files (the "Software"), to deal in the Software without | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1071 restriction, including without limitation the rights to use, | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1072 copy, modify, merge, publish, distribute, sublicense, and/or sell | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1073 copies of the Software, and to permit persons to whom the | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1074 Software is furnished to do so, subject to the following | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1075 conditions: | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1076 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1077 The above copyright notice and this permission notice shall be | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1078 included in all copies or substantial portions of the Software. | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1079 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1080 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1081 EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1082 OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1083 NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1084 HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1085 WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1086 FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1087 OTHER DEALINGS IN THE SOFTWARE.</pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1088 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1089 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1090 <div class="paragraph"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1091 <p>This means that you can freely use pugixml in your applications, both open-source and proprietary. If you use pugixml in a product, it is sufficient to add an acknowledgment like this to the product distribution:</p> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1092 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1093 <div class="literalblock"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1094 <div class="content"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1095 <pre>This software is based on pugixml library (https://pugixml.org). | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1096 pugixml is Copyright (C) 2006-2022 Arseny Kapoulkine.</pre> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1097 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1098 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1099 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1100 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1101 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1102 <div id="footnotes"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1103 <hr> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1104 <div class="footnote" id="_footnotedef_1"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1105 <a href="#_footnoteref_1">1</a>. All trademarks used are properties of their respective owners. | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1106 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1107 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1108 <div id="footer"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1109 <div id="footer-text"> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1110 Last updated 2022-09-02 21:41:39 -0700 | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1111 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1112 </div> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1113 </body> | 
| 
d10b6c6b432e
add xml lib, we will need to use it eventually
 Paper <mrpapersonic@gmail.com> parents: diff
changeset | 1114 </html> | 
