<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1 plus MathML 2.0//EN" "http://www.w3.org/Math/DTD/mathml2/xhtml-math11-f.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><!--This file was converted to xhtml by LibreOffice - see https://cgit.freedesktop.org/libreoffice/core/tree/filter/source/xslt for the code.--><head profile="http://dublincore.org/documents/dcmi-terms/"><meta http-equiv="Content-Type" content="application/xhtml+xml; charset=utf-8"/><title xml:lang="en-US">De Re BASIC!</title><meta name="DCTERMS.title" content="De Re BASIC!" xml:lang="en-US"/><meta name="DCTERMS.language" content="en-US" scheme="DCTERMS.RFC4646"/><meta name="DCTERMS.source" content="http://xml.openoffice.org/odf2xhtml"/><meta name="DCTERMS.creator" content="Paul Laughton"/><meta name="DCTERMS.issued" content="2012-08-24T05:42:00" scheme="DCTERMS.W3CDTF"/><meta name="DCTERMS.contributor" content="Sammartano, Marc (BIC USA)"/><meta name="DCTERMS.modified" content="2019-04-05T23:32:00" scheme="DCTERMS.W3CDTF"/><meta name="DCTERMS.provenance" content="" xml:lang="en-US"/><meta name="DCTERMS.subject" content="," xml:lang="en-US"/><link rel="schema.DC" href="http://purl.org/dc/elements/1.1/" hreflang="en"/><link rel="schema.DCTERMS" href="http://purl.org/dc/terms/" hreflang="en"/><link rel="schema.DCTYPE" href="http://purl.org/dc/dcmitype/" hreflang="en"/><link rel="schema.DCAM" href="http://purl.org/dc/dcam/" hreflang="en"/><style type="text/css">
   @page {  }
   table { border-collapse:collapse; border-spacing:0; empty-cells:show }
   td, th { vertical-align:top; font-size:12pt;}
   h1, h2, h3, h4, h5, h6 { clear:both;}
   ol, ul { margin:0; padding:0;}
   li { list-style: none; margin:0; padding:0;}
   /* "li span.odfLiEnd" - IE 7 issue*/
   li span. { clear: both; line-height:0; width:0; height:0; margin:0; padding:0; }
   span.footnodeNumber { padding-right:1em; }
   span.annotation_style_by_filter { font-size:95%; font-family:Arial; background-color:#fff000;  margin:0; border:0; padding:0;  }
   span.heading_numbering { margin-right: 0.8rem; }* { margin:0;}
   .fr1 { font-size:11pt; font-family:Calibri; text-align:center; vertical-align:top; writing-mode:horizontal-tb; direction:ltr; margin-left:0cm; margin-right:0cm; margin-top:0cm; margin-bottom:0cm; background-color:transparent; padding:0cm; border-style:none; }
   .fr2 { font-size:11pt; font-family:Calibri; vertical-align:top; writing-mode:horizontal-tb; direction:ltr; margin-left:0cm; margin-right:0cm; margin-top:0cm; margin-bottom:0cm; background-color:transparent; padding:0cm; border-style:none; }
   .Code_20_example { font-size:10pt; line-height:100%; margin-bottom:0.423cm; margin-top:0cm; text-align:left ! important; font-family:QuickType II Mono; writing-mode:horizontal-tb; direction:ltr; margin-left:0cm; margin-right:0cm; text-indent:1.27cm; font-weight:bold; }
   .Contents_20_1 { font-size:11pt; line-height:115%; margin-bottom:0.176cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .Contents_20_2 { font-size:11pt; line-height:115%; margin-bottom:0.176cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:0.388cm; margin-right:0cm; text-indent:0cm; }
   .Contents_20_3 { font-size:11pt; line-height:115%; margin-bottom:0.176cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:0.776cm; margin-right:0cm; text-indent:0cm; }
   .Contents_20_4 { font-size:11pt; line-height:115%; margin-bottom:0.176cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:1.164cm; margin-right:0cm; text-indent:0cm; }
   .Contents_20_5 { font-size:11pt; line-height:115%; margin-bottom:0.176cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:1.552cm; margin-right:0cm; text-indent:0cm; }
   .Contents_20_6 { font-size:11pt; line-height:115%; margin-bottom:0.176cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:1.94cm; margin-right:0cm; text-indent:0cm; }
   .Contents_20_7 { font-size:11pt; line-height:115%; margin-bottom:0.176cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:2.328cm; margin-right:0cm; text-indent:0cm; }
   .Contents_20_8 { font-size:11pt; line-height:115%; margin-bottom:0.176cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:2.716cm; margin-right:0cm; text-indent:0cm; }
   .Contents_20_9 { font-size:11pt; line-height:115%; margin-bottom:0.176cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:3.104cm; margin-right:0cm; text-indent:0cm; }
   .Footer { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .Footnote { font-size:10pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .Heading_20_1 { font-size:14pt; line-height:115%; margin-bottom:0.212cm; margin-top:0.635cm; text-align:left ! important; font-family:Cambria; writing-mode:horizontal-tb; direction:ltr; color:#365f91; font-weight:bold; }
   .Heading_20_2 { font-size:13pt; line-height:115%; margin-bottom:0.212cm; margin-top:0.353cm; text-align:left ! important; font-family:Cambria; writing-mode:horizontal-tb; direction:ltr; color:#4f81bd; font-weight:bold; }
   .Heading_20_3 { font-size:12pt; line-height:115%; margin-bottom:0cm; margin-top:0.353cm; text-align:left ! important; font-family:Cambria; writing-mode:horizontal-tb; direction:ltr; color:#4f81bd; font-weight:bold; }
   .Heading_20_4 { font-size:11pt; line-height:115%; margin-bottom:0.106cm; margin-top:0.318cm; text-align:left ! important; font-family:Cambria; writing-mode:horizontal-tb; direction:ltr; color:#4f81bd; font-style:italic; font-weight:bold; }
   .Heading_20_5 { font-size:10pt; line-height:115%; margin-bottom:0cm; margin-top:0.353cm; text-align:left ! important; font-family:Cambria; writing-mode:horizontal-tb; direction:ltr; color:#243f60; }
   .List_20_Paragraph { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:1.27cm; margin-right:0cm; text-indent:0cm; }
   .No_20_Spacing { font-size:11pt; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-top:0cm; margin-bottom:0cm; line-height:100%; text-align:left ! important; }
   .P1 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:center ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P10 { font-size:10pt; font-weight:bold; line-height:100%; margin-bottom:0.423cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:1.27cm; font-family:QuickType II Mono; writing-mode:horizontal-tb; direction:ltr; }
   .P100 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:2.54cm; margin-right:0cm; text-indent:1.27cm; }
   .P101 { font-size:11pt; line-height:100%; margin-bottom:0.353cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P102 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0.212cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P103 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0.212cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P104 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:0cm; margin-right:0cm; text-indent:1.27cm; }
   .P105 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0.212cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:0cm; margin-right:0cm; text-indent:1.27cm; }
   .P106 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:0cm; margin-right:0cm; text-indent:1.27cm; }
   .P107 { font-size:10pt; line-height:115%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Letter Gothic; writing-mode:horizontal-tb; direction:ltr; margin-left:0cm; margin-right:0cm; text-indent:1.27cm; }
   .P108 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0.353cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P109 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P11 { font-size:10pt; font-weight:bold; line-height:100%; margin-bottom:0.423cm; margin-left:5.08cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:1.27cm; font-family:QuickType II Mono; writing-mode:horizontal-tb; direction:ltr; }
   .P110 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:center ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P114 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P118 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P119 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:center ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P12 { font-size:10pt; font-weight:bold; line-height:100%; margin-bottom:0.106cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:QuickType II Mono; writing-mode:horizontal-tb; direction:ltr; }
   .P120 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:center ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; font-weight:bold; }
   .P121 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; font-weight:bold; }
   .P122 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; font-weight:bold; }
   .P124 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:center ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; font-weight:bold; }
   .P125 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:center ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; font-weight:bold; }
   .P127 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; font-weight:normal; }
   .P128 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:center ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; font-weight:normal; }
   .P129 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P13 { font-size:10pt; font-weight:bold; line-height:100%; margin-bottom:0.106cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:QuickType II Mono; writing-mode:horizontal-tb; direction:ltr; }
   .P130 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P131 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:center ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P132 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P133 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Courier New; writing-mode:horizontal-tb; direction:ltr; font-weight:bold; }
   .P134 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Courier New; writing-mode:horizontal-tb; direction:ltr; font-weight:bold; }
   .P135 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P136 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Bell MT; writing-mode:horizontal-tb; direction:ltr; }
   .P137 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; color:#ffffff; font-weight:bold; }
   .P138 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:center ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; color:#ffffff; font-weight:bold; }
   .P139 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:center ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; font-weight:bold; }
   .P14 { font-size:10pt; font-weight:bold; line-height:100%; margin-bottom:0.423cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:QuickType II Mono; writing-mode:horizontal-tb; direction:ltr; }
   .P140 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:center ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P141 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P142 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:center ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P143 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P144 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:2.54cm; margin-right:0cm; text-indent:0cm; }
   .P145 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:2.54cm; margin-right:0cm; text-indent:0cm; }
   .P146 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:1.27cm; margin-right:0cm; text-indent:1.27cm; }
   .P147 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-top:0.353cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P148 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0.212cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:1.27cm; margin-right:1.27cm; text-indent:0cm; }
   .P149 { font-size:11pt; line-height:115%; margin-bottom:0.423cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P15 { font-size:11pt; line-height:115%; margin-bottom:0.176cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P150 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0.212cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:1.27cm; margin-right:0cm; text-indent:-1.27cm; }
   .P151 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:center ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:0.199cm; margin-right:0.199cm; text-indent:0cm; }
   .P152 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0.176cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P153 { font-size:11pt; line-height:115%; margin-bottom:0.212cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P154 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-top:0.212cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P155 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P156 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:0.635cm; margin-right:0cm; text-indent:0cm; }
   .P157 { color:#4f81bd; font-size:12pt; font-style:italic; letter-spacing:0.026cm; line-height:115%; margin-bottom:0.353cm; margin-top:0cm; text-align:center ! important; font-family:Cambria; writing-mode:horizontal-tb; direction:ltr; }
   .P158 { color:#365f91; font-size:14pt; font-weight:bold; line-height:115%; margin-bottom:0.212cm; margin-top:0.635cm; text-align:left ! important; font-family:Cambria; writing-mode:horizontal-tb; direction:ltr; }
   .P159_borderStart { border-left-style:none; border-right-style:none; border-top-style:none; color:#17365d; font-size:26pt; letter-spacing:0.009cm; line-height:100%; margin-top:0cm; padding-left:0cm; padding-right:0cm; padding-top:0cm; text-align:center ! important; font-family:Cambria; writing-mode:horizontal-tb; direction:ltr; padding-bottom:0.529cm;  border-bottom-style:none; }
   .P159 { border-left-style:none; border-right-style:none; color:#17365d; font-size:26pt; letter-spacing:0.009cm; line-height:100%; padding-left:0cm; padding-right:0cm; text-align:center ! important; font-family:Cambria; writing-mode:horizontal-tb; direction:ltr; padding-bottom:0.529cm; padding-top:0cm;  border-top-style:none; border-bottom-style:none; }
   .P159_borderEnd { border-bottom-width:0.0349cm; border-bottom-style:solid; border-bottom-color:#4f81bd; border-left-style:none; border-right-style:none; color:#17365d; font-size:26pt; letter-spacing:0.009cm; line-height:100%; margin-bottom:0.529cm; padding-bottom:0.141cm; padding-left:0cm; padding-right:0cm; text-align:center ! important; font-family:Cambria; writing-mode:horizontal-tb; direction:ltr; padding-top:0cm;  border-top-style:none;}
   .P160_borderStart { border-left-style:none; border-right-style:none; border-top-style:none; color:#17365d; font-size:26pt; letter-spacing:0.009cm; line-height:100%; margin-top:0cm; padding-left:0cm; padding-right:0cm; padding-top:0cm; text-align:center ! important; font-family:Cambria; writing-mode:horizontal-tb; direction:ltr; padding-bottom:0.529cm;  border-bottom-style:none; }
   .P160 { border-left-style:none; border-right-style:none; color:#17365d; font-size:26pt; letter-spacing:0.009cm; line-height:100%; padding-left:0cm; padding-right:0cm; text-align:center ! important; font-family:Cambria; writing-mode:horizontal-tb; direction:ltr; padding-bottom:0.529cm; padding-top:0cm;  border-top-style:none; border-bottom-style:none; }
   .P160_borderEnd { border-bottom-width:0.0349cm; border-bottom-style:solid; border-bottom-color:#4f81bd; border-left-style:none; border-right-style:none; color:#17365d; font-size:26pt; letter-spacing:0.009cm; line-height:100%; margin-bottom:0.529cm; padding-bottom:0.141cm; padding-left:0cm; padding-right:0cm; text-align:center ! important; font-family:Cambria; writing-mode:horizontal-tb; direction:ltr; padding-top:0cm;  border-top-style:none;}
   .P161 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-left:0.388cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:-0.388cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P17 { color:#365f91; font-size:14pt; font-weight:bold; line-height:115%; margin-bottom:0.212cm; margin-top:0.635cm; text-align:left ! important; font-family:Cambria; writing-mode:horizontal-tb; direction:ltr; }
   .P18 { color:#4f81bd; font-size:12pt; font-weight:bold; line-height:115%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Cambria; writing-mode:horizontal-tb; direction:ltr; }
   .P19 { color:#243f60; font-size:10pt; line-height:115%; margin-bottom:0cm; margin-top:0.353cm; text-align:left ! important; font-family:Cambria; writing-mode:horizontal-tb; direction:ltr; margin-left:1.27cm; margin-right:0cm; text-indent:0cm; }
   .P2 { font-size:10pt; font-weight:normal; line-height:100%; margin-bottom:0.423cm; margin-left:0cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:1.27cm; font-family:Letter Gothic; writing-mode:horizontal-tb; direction:ltr; }
   .P20 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P21 { font-size:10pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P22 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P23 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P24 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P25 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P26 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P27 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P28 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P29 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P3 { font-size:10pt; font-weight:normal; line-height:100%; margin-bottom:0.423cm; margin-left:0cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:1.27cm; font-family:Letter Gothic; writing-mode:horizontal-tb; direction:ltr; }
   .P30 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P31 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P32 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P33 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P34 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P35 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P36 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P37 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P38 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P39 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P4 { font-size:10pt; font-weight:bold; line-height:100%; margin-bottom:0.353cm; margin-left:0cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:1.27cm; font-family:QuickType II Mono; writing-mode:horizontal-tb; direction:ltr; }
   .P40 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P41 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P42 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P43 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P44 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P45 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P46 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P47 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P48 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P49 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P5 { font-size:10pt; font-weight:bold; line-height:100%; margin-bottom:0.212cm; margin-left:0cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:1.27cm; font-family:QuickType II Mono; writing-mode:horizontal-tb; direction:ltr; }
   .P50 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P51 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P52 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P53 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P54 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P55 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P56 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P57 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P58 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P59 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P6 { font-size:10pt; font-weight:bold; line-height:100%; margin-bottom:0.423cm; margin-left:6.35cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:1.27cm; font-family:QuickType II Mono; writing-mode:horizontal-tb; direction:ltr; }
   .P60 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P61 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P62 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P63 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P64 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P65 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P66 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P67 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P68 { font-size:11pt; line-height:115%; margin-bottom:0.423cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P69 { font-size:11pt; line-height:115%; margin-bottom:0.423cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P7 { font-size:10pt; font-weight:bold; line-height:100%; margin-bottom:0.423cm; margin-left:0cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:1.27cm; font-family:QuickType II Mono; writing-mode:horizontal-tb; direction:ltr; }
   .P70 { font-size:11pt; line-height:115%; margin-bottom:0.423cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P71 { font-size:11pt; line-height:115%; margin-bottom:0.423cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P72 { font-size:11pt; line-height:115%; margin-bottom:0.423cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P73 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P74 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P75 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P76 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P77 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P78 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P79 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P8 { font-size:10pt; font-weight:bold; line-height:100%; margin-bottom:0cm; margin-left:0cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:1.27cm; font-family:QuickType II Mono; writing-mode:horizontal-tb; direction:ltr; }
   .P80 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0.212cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P81 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:0cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P82 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:0cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P83 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:-0.635cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P84 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-left:1.27cm; margin-right:0cm; margin-top:0.423cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P85 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-left:1.27cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P86 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-left:0.635cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:0cm; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P87 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0.212cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P88 { font-size:26pt; line-height:115%; margin-bottom:0.353cm; margin-top:0cm; text-align:center ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; font-weight:bold; }
   .P89 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P9 { font-size:10pt; font-weight:normal; line-height:100%; margin-bottom:0cm; margin-left:0cm; margin-right:0cm; margin-top:0cm; text-align:left ! important; text-indent:1.27cm; font-family:Letter Gothic; writing-mode:horizontal-tb; direction:ltr; }
   .P90 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0cm; text-align:justify ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P91 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0cm; text-align:center ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P92 { font-size:10pt; line-height:115%; margin-bottom:0.353cm; margin-top:0cm; text-align:left ! important; font-family:Courier New; writing-mode:horizontal-tb; direction:ltr; }
   .P93 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; }
   .P94 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:1.27cm; margin-right:0cm; text-indent:0cm; }
   .P95 { font-size:11pt; line-height:115%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:1.27cm; margin-right:0cm; text-indent:0cm; }
   .P96 { font-size:11pt; line-height:100%; margin-bottom:0cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:1.27cm; margin-right:0cm; text-indent:0cm; }
   .P97 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0.212cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:1.27cm; margin-right:0cm; text-indent:0cm; }
   .P98 { font-size:11pt; line-height:100%; margin-bottom:0.353cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:1.27cm; margin-right:0cm; text-indent:0cm; }
   .P99 { font-size:11pt; line-height:115%; margin-bottom:0.353cm; margin-top:0cm; text-align:left ! important; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-left:2.54cm; margin-right:0cm; text-indent:1.27cm; }
   .Standard { font-size:11pt; font-family:Calibri; writing-mode:horizontal-tb; direction:ltr; margin-top:0cm; margin-bottom:0.353cm; line-height:115%; text-align:left ! important; }
   .Table1 { width:13.018cm; margin-left:1.27cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table10 { width:13.45cm; margin-left:1.337cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table11 { width:14.568cm; margin-top:0cm; margin-bottom:0cm;
               margin-left:auto;margin-right:auto;
           writing-mode:horizontal-tb; direction:ltr; }
   .Table12 { width:13.72cm; margin-top:0cm; margin-bottom:0cm;
               margin-left:auto;margin-right:auto;
           writing-mode:horizontal-tb; direction:ltr; }
   .Table13 { width:15.24cm; margin-left:0.159cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table14 { width:10.582cm; margin-left:1.325cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table15 { width:16.383cm; margin-left:0.318cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table16 { width:16.193cm; margin-left:0.318cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table17 { width:16.193cm; margin-left:0.318cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table18 { width:11.435cm; margin-left:2.381cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table19 { width:12.963cm; margin-left:1.325cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table2 { width:8.414cm; margin-left:1.325cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table20 { width:16.159cm; margin-top:0cm; margin-bottom:0cm;
               margin-left:auto;margin-right:auto;
           writing-mode:horizontal-tb; direction:ltr; }
   .Table21 { width:16.806cm; margin-top:0cm; margin-bottom:0cm;
               margin-left:auto;margin-right:auto;
           writing-mode:horizontal-tb; direction:ltr; }
   .Table22 { width:16.806cm; margin-top:0cm; margin-bottom:0cm;
               margin-left:auto;margin-right:auto;
           writing-mode:horizontal-tb; direction:ltr; }
   .Table23 { width:16.766cm; margin-top:0cm; margin-bottom:0cm;
               margin-left:auto;margin-right:auto;
           writing-mode:horizontal-tb; direction:ltr; }
   .Table24 { width:16.766cm; margin-top:0cm; margin-bottom:0cm;
               margin-left:auto;margin-right:auto;
           writing-mode:horizontal-tb; direction:ltr; }
   .Table25 { width:16.288cm; margin-left:0.064cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table26 { width:14.074cm; margin-left:1.325cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table27 { width:14.074cm; margin-left:1.325cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table28 { width:13.769cm; margin-left:1.312cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table29 { width:12.305cm; margin-left:1.348cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table3 { width:14.709cm; margin-left:1.325cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table30 { width:16.51cm; margin-left:0cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table31 { width:6.826cm; margin-left:1.429cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table32 { width:14.129cm; margin-left:1.429cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table33 { width:16.669cm; margin-left:0cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table34 { width:8.414cm; margin-left:1.325cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table35 { width:8.414cm; margin-left:1.325cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table36 { width:16.362cm; margin-left:0cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table37 { width:8.414cm; margin-left:3.868cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table38 { width:11.714cm; margin-left:1.304cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table39 { width:15.812cm; margin-left:0.064cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table4 { width:16.669cm; margin-left:0cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table40 { width:15.97cm; margin-left:0.064cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table41 { width:13.176cm; margin-left:0.953cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table42 { width:15.589cm; margin-left:0.265cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table43 { width:16.891cm; margin-left:-0.191cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table44 { width:16.891cm; margin-left:-0.191cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table5 { width:16.669cm; margin-left:0cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table6 { width:16.891cm; margin-left:-0.191cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table7 { width:11.144cm; margin-left:2.35cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table8 { width:11.557cm; margin-left:1.302cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table9 { width:16.891cm; margin-left:-0.191cm; margin-top:0cm; margin-bottom:0cm; margin-right:auto;writing-mode:horizontal-tb; direction:ltr; }
   .Table1_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table10_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table11_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table11_A2 { vertical-align:middle; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table12_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table12_A2 { vertical-align:middle; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table13_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#999999; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#999999; border-top-width:0.0176cm; border-top-style:solid; border-top-color:#999999; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#666666; writing-mode:horizontal-tb; direction:ltr; }
   .Table13_A2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table14_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table15_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table16_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table17_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table18_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table19_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table2_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table20_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table20_A2 { vertical-align:middle; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table21_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table21_A2 { vertical-align:middle; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table22_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table22_A2 { vertical-align:middle; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table23_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table23_A2 { vertical-align:middle; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table24_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table24_A2 { vertical-align:middle; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table25_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table26_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table27_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table28_A1 { padding-left:0.203cm; padding-right:0.203cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table29_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#b8cce4; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#b8cce4; border-top-width:0.0176cm; border-top-style:solid; border-top-color:#b8cce4; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#95b3d7; writing-mode:horizontal-tb; direction:ltr; }
   .Table29_A2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#b8cce4; writing-mode:horizontal-tb; direction:ltr; }
   .Table3_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table30_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#999999; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#999999; border-top-width:0.0176cm; border-top-style:solid; border-top-color:#999999; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#666666; writing-mode:horizontal-tb; direction:ltr; }
   .Table30_A2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table31_A1 { background-color:transparent; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0176cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table31_A3 { background-color:transparent; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0176cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0176cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table31_A5 { background-color:transparent; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0176cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table31_B1 { background-color:transparent; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0529cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table32_A1 { background-color:transparent; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0529cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table32_A2 { background-color:transparent; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0176cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table32_A3 { background-color:transparent; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0176cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0176cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table32_A5 { background-color:transparent; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0176cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table32_B2 { background-color:transparent; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0176cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table32_B3 { background-color:transparent; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0176cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0176cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table32_B5 { background-color:transparent; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0176cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table33_A1 { background-color:transparent; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0176cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table33_A3 { background-color:transparent; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0176cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table33_B1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0176cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table33_B2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0176cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table33_B3 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0176cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table33_C1 { background-color:transparent; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0529cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table33_D1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0529cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table33_D2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0176cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table33_D3 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0176cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table34_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table35_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_A12 { vertical-align:middle; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_A2 { vertical-align:middle; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; }
   .Table36_B1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_B10 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_B11 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_B12 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_B13 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_B14 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_B2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_B3 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_B4 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_B5 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_B6 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_B7 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_B8 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_B9 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_C10 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_C11 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_C12 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_C13 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_C14 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_C2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_C3 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_C4 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_C5 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_C6 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_C7 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_C8 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_C9 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0529cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_D10 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_D11 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_D12 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_D13 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_D14 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_D2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_D3 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_D4 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_D5 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_D6 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_D7 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_D8 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_D9 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_E1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_E10 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_E11 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_E12 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_E13 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_E14 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_E2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_E3 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_E4 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_E5 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_E6 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_E7 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_E8 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_E9 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_F10 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_F11 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_F12 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_F13 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_F14 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_F2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_F3 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_F4 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_F5 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_F6 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_F7 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_F8 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_F9 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_G10 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_G11 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_G12 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_G13 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_G14 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_G2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_G3 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_G4 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_G5 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_G6 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_G7 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_G8 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_G9 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_H10 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_H11 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_H12 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_H13 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_H14 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_H2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_H3 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_H4 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_H5 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_H6 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_H7 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_H8 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_H9 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_I10 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_I11 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_I12 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_I13 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_I14 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_I2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0265cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_I3 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_I4 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_I5 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_I6 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_I7 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_I8 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_I9 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0265cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_J10 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_J11 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_J12 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_J13 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_J14 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_J2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0529cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_J3 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_J4 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_J5 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_J6 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_J7 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_J8 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table36_J9 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0265cm; border-left-style:solid; border-left-color:#000000; border-right-width:0.0529cm; border-right-style:solid; border-right-color:#000000; border-top-width:0.0265cm; border-top-style:solid; border-top-color:#000000; border-bottom-width:0.0265cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table37_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table38_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#999999; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#999999; border-top-width:0.0176cm; border-top-style:solid; border-top-color:#999999; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#666666; writing-mode:horizontal-tb; direction:ltr; }
   .Table38_A2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table39_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table4_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table40_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_A1 { background-color:#000000; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0353cm; border-style:solid; border-color:#404040; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_A11 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#000000; border-right-style:none; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_A13 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#000000; border-right-style:none; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_A15 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#000000; border-right-style:none; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_A17 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#000000; border-right-style:none; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_A19 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#000000; border-right-style:none; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_A2 { background-color:#c0c0c0; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#000000; border-right-style:none; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_A21 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#000000; border-right-style:none; border-top-style:none; border-bottom-width:0.0176cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_A3 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#000000; border-right-style:none; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_A5 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#000000; border-right-style:none; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_A7 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#000000; border-right-style:none; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_A9 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#000000; border-right-style:none; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_B11 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_B13 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_B15 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_B17 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_B19 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_B2 { background-color:#c0c0c0; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_B21 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-style:none; border-right-style:none; border-top-style:none; border-bottom-width:0.0176cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_B3 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_B5 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_B7 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_B9 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_C11 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-style:none; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#000000; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_C13 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-style:none; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#000000; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_C15 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-style:none; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#000000; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_C17 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-style:none; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#000000; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_C19 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-style:none; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#000000; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_C2 { background-color:#c0c0c0; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-style:none; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#000000; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_C21 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-style:none; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#000000; border-top-style:none; border-bottom-width:0.0176cm; border-bottom-style:solid; border-bottom-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_C3 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-style:none; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#000000; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_C5 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-style:none; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#000000; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_C7 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-style:none; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#000000; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table41_C9 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-style:none; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#000000; border-top-style:none; border-bottom-style:none; writing-mode:horizontal-tb; direction:ltr; }
   .Table42_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_A1 { vertical-align:bottom; padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-left-width:0.0176cm; border-left-style:solid; border-left-color:#999999; border-right-width:0.0176cm; border-right-style:solid; border-right-color:#999999; border-top-width:0.0176cm; border-top-style:solid; border-top-color:#999999; border-bottom-width:0.0529cm; border-bottom-style:solid; border-bottom-color:#666666; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_A2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_A3 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_A4 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_A5 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_A6 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_A7 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_A8 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_A9 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_B2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_B3 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_B4 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_B5 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_B6 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_B7 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_B8 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_B9 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_C2 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_C3 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_C4 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_C5 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_C6 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_C7 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_C8 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table43_C9 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#999999; writing-mode:horizontal-tb; direction:ltr; }
   .Table44_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0794cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table5_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table6_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table7_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table8_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table9_A1 { padding-left:0.191cm; padding-right:0.191cm; padding-top:0cm; padding-bottom:0cm; border-width:0.0176cm; border-style:solid; border-color:#000000; writing-mode:horizontal-tb; direction:ltr; }
   .Table1_A { width:2.224cm; }
   .Table1_B { width:1.829cm; }
   .Table1_C { width:4.043cm; }
   .Table1_D { width:4.919cm; }
   .Table10_A { width:7.158cm; }
   .Table10_B { width:3.641cm; }
   .Table10_C { width:2.651cm; }
   .Table11_A { width:2.097cm; }
   .Table11_B { width:1.953cm; }
   .Table11_C { width:10.518cm; }
   .Table12_A { width:2.097cm; }
   .Table12_B { width:6.274cm; }
   .Table12_C { width:2.096cm; }
   .Table12_D { width:3.251cm; }
   .Table13_A { width:9.525cm; }
   .Table13_B { width:5.713cm; }
   .Table14_A { width:3.168cm; }
   .Table14_B { width:7.412cm; }
   .Table15_A { width:2.379cm; }
   .Table15_B { width:1.746cm; }
   .Table15_C { width:12.257cm; }
   .Table16_A { width:2.194cm; }
   .Table16_B { width:1.877cm; }
   .Table16_C { width:12.121cm; }
   .Table17_A { width:2.194cm; }
   .Table17_B { width:1.877cm; }
   .Table17_C { width:12.121cm; }
   .Table18_A { width:3.179cm; }
   .Table18_B { width:3.177cm; }
   .Table18_C { width:5.08cm; }
   .Table19_A { width:2.845cm; }
   .Table19_B { width:3.448cm; }
   .Table19_C { width:6.669cm; }
   .Table2_A { width:4.207cm; }
   .Table2_B { width:4.205cm; }
   .Table20_A { width:2.926cm; }
   .Table20_B { width:3.096cm; }
   .Table20_C { width:6.484cm; }
   .Table20_D { width:3.651cm; }
   .Table21_A { width:2.686cm; }
   .Table21_B { width:1.169cm; }
   .Table21_C { width:5.657cm; }
   .Table21_D { width:4.921cm; }
   .Table21_E { width:2.372cm; }
   .Table22_A { width:2.686cm; }
   .Table22_B { width:1.169cm; }
   .Table22_C { width:5.657cm; }
   .Table22_D { width:4.921cm; }
   .Table22_E { width:2.372cm; }
   .Table23_A { width:2.508cm; }
   .Table23_B { width:1.272cm; }
   .Table23_C { width:5.713cm; }
   .Table23_D { width:7.271cm; }
   .Table24_A { width:2.508cm; }
   .Table24_B { width:1.272cm; }
   .Table24_C { width:5.08cm; }
   .Table24_D { width:7.904cm; }
   .Table25_A { width:2.159cm; }
   .Table25_B { width:3.175cm; }
   .Table25_C { width:5.398cm; }
   .Table25_D { width:5.554cm; }
   .Table26_A { width:1.496cm; }
   .Table26_B { width:3.845cm; }
   .Table26_C { width:2.91cm; }
   .Table26_E { width:2.912cm; }
   .Table27_A { width:1.496cm; }
   .Table27_B { width:4.165cm; }
   .Table27_C { width:8.414cm; }
   .Table28_A { width:2.177cm; }
   .Table28_B { width:2.861cm; }
   .Table28_C { width:8.731cm; }
   .Table29_A { width:3.27cm; }
   .Table29_B { width:2.223cm; }
   .Table29_C { width:6.812cm; }
   .Table3_A { width:1.85cm; }
   .Table3_B { width:3.173cm; }
   .Table3_C { width:1.616cm; }
   .Table3_D { width:1.614cm; }
   .Table3_E { width:1.612cm; }
   .Table30_A { width:1.427cm; }
   .Table30_B { width:3.336cm; }
   .Table30_C { width:11.748cm; }
   .Table31_A { width:4.128cm; }
   .Table31_B { width:2.697cm; }
   .Table32_A { width:1.27cm; }
   .Table32_B { width:5.616cm; }
   .Table32_C { width:1.208cm; }
   .Table32_D { width:6.033cm; }
   .Table33_A { width:2.54cm; }
   .Table33_B { width:3.969cm; }
   .Table33_C { width:4.443cm; }
   .Table33_D { width:5.715cm; }
   .Table34_A { width:1.914cm; }
   .Table34_B { width:6.498cm; }
   .Table35_A { width:1.914cm; }
   .Table35_B { width:6.498cm; }
   .Table36_A { width:1.496cm; }
   .Table36_B { width:1.69cm; }
   .Table36_C { width:1.268cm; }
   .Table36_D { width:1.272cm; }
   .Table36_E { width:1.27cm; }
   .Table36_F { width:1.565cm; }
   .Table36_G { width:2.805cm; }
   .Table36_H { width:1.87cm; }
   .Table36_J { width:1.436cm; }
   .Table37_A { width:1.914cm; }
   .Table37_B { width:6.498cm; }
   .Table38_A { width:6.95cm; }
   .Table38_B { width:4.763cm; }
   .Table39_A { width:2.962cm; }
   .Table39_B { width:2.66cm; }
   .Table39_C { width:10.19cm; }
   .Table4_A { width:3.175cm; }
   .Table4_B { width:1.905cm; }
   .Table4_C { width:1.744cm; }
   .Table4_D { width:9.843cm; }
   .Table40_A { width:1.998cm; }
   .Table40_B { width:13.97cm; }
   .Table41_A { width:5.239cm; }
   .Table41_B { width:2.062cm; }
   .Table41_C { width:5.876cm; }
   .Table42_A { width:2.549cm; }
   .Table42_B { width:2.551cm; }
   .Table42_D { width:7.938cm; }
   .Table43_A { width:3.522cm; }
   .Table43_B { width:10.636cm; }
   .Table43_C { width:2.732cm; }
   .Table44_A { width:16.891cm; }
   .Table5_A { width:2.221cm; }
   .Table5_B { width:2.224cm; }
   .Table5_C { width:1.905cm; }
   .Table5_D { width:10.317cm; }
   .Table6_A { width:3.681cm; }
   .Table6_B { width:4.286cm; }
   .Table6_C { width:8.924cm; }
   .Table7_A { width:0.813cm; }
   .Table7_B { width:1.628cm; }
   .Table7_C { width:1.559cm; }
   .Table7_D { width:1.67cm; }
   .Table7_E { width:0.482cm; }
   .Table7_F { width:2.203cm; }
   .Table7_G { width:2.152cm; }
   .Table7_H { width:0.635cm; }
   .Table8_A { width:0.582cm; }
   .Table8_B { width:10.973cm; }
   .Table9_A { width:3.364cm; }
   .Table9_B { width:13.526cm; }
   .Footnote_20_Symbol { vertical-align:super; font-size:58%;}
   .HTML_20_Code { font-family:Courier New; font-size:10pt; }
   .Heading_20_1_20_Char { color:#365f91; font-family:Cambria; font-size:14pt; font-weight:bold; }
   .Heading_20_3_20_Char { color:#4f81bd; font-family:Cambria; font-size:12pt; font-weight:bold; }
   .Internet_20_link { color:#0000ff; text-decoration:underline; }
   .ListLabel_20_1 { font-size:8pt; }
   .ListLabel_20_101 { font-size:8pt; }
   .ListLabel_20_105 { font-size:8pt; }
   .ListLabel_20_109 { font-size:8pt; }
   .ListLabel_20_113 { font-size:8pt; }
   .ListLabel_20_117 { font-size:8pt; }
   .ListLabel_20_12 { font-size:8pt; }
   .ListLabel_20_121 { font-size:8pt; }
   .ListLabel_20_125 { font-size:8pt; }
   .ListLabel_20_129 { font-size:8pt; }
   .ListLabel_20_133 { font-size:8pt; }
   .ListLabel_20_137 { font-size:8pt; }
   .ListLabel_20_141 { font-size:8pt; }
   .ListLabel_20_145 { font-size:8pt; }
   .ListLabel_20_149 { font-size:8pt; }
   .ListLabel_20_22 { font-size:8pt; }
   .ListLabel_20_29 { font-size:8pt; }
   .ListLabel_20_33 { font-size:8pt; }
   .ListLabel_20_37 { font-size:8pt; }
   .ListLabel_20_38 { font-size:8pt; }
   .ListLabel_20_41 { font-size:8pt; }
   .ListLabel_20_45 { font-size:8pt; }
   .ListLabel_20_49 { font-size:8pt; }
   .ListLabel_20_5 { font-size:8pt; }
   .ListLabel_20_53 { font-size:8pt; }
   .ListLabel_20_57 { font-size:8pt; }
   .ListLabel_20_6 { font-size:8pt; }
   .ListLabel_20_61 { font-size:8pt; }
   .ListLabel_20_65 { font-size:8pt; }
   .ListLabel_20_69 { font-size:8pt; }
   .ListLabel_20_73 { font-size:8pt; }
   .ListLabel_20_77 { font-size:8pt; }
   .ListLabel_20_81 { font-size:8pt; }
   .ListLabel_20_85 { font-size:8pt; }
   .ListLabel_20_89 { font-size:8pt; }
   .ListLabel_20_93 { font-size:8pt; }
   .ListLabel_20_97 { font-size:8pt; }
   .ListLabel_20_98 { font-size:8pt; }
   .Subtle_20_Emphasis { color:#808080; font-style:italic; }
   .T1 { font-size:8pt; }
   .T10 { font-family:Letter Gothic; }
   .T11 { font-family:Letter Gothic; font-weight:normal; }
   .T12 { font-family:Letter Gothic; font-weight:normal; }
   .T13 { font-family:Letter Gothic; font-weight:normal; }
   .T15 { font-family:Letter Gothic; font-size:10pt; }
   .T16 { font-family:Letter Gothic; font-size:10pt; font-weight:bold; }
   .T17 { font-style:italic; font-weight:bold; }
   .T18 { font-style:italic; }
   .T19 { font-style:italic; }
   .T2 { font-size:8pt; }
   .T20 { font-style:italic; background-color:#ffffff; }
   .T21 { font-style:italic; background-color:#ffffff; }
   .T22 { font-style:italic; text-decoration:underline; }
   .T23 { font-family:Cambria; font-size:10pt; }
   .T24 { font-family:Cambria; }
   .T25 { font-family:Wingdings; font-size:8pt; font-weight:bold; }
   .T26 { font-family:Wingdings; font-size:8pt; font-weight:normal; }
   .T27 { font-family:Wingdings; font-size:8pt; }
   .T28 { font-family:Wingdings; font-weight:normal; }
   .T29 { vertical-align:sub; font-size:58%;font-weight:bold; }
   .T3 { font-size:18pt; }
   .T30 { font-family:Courier New; }
   .T33 { font-family:Courier New; font-size:10pt; font-weight:bold; }
   .T34 { font-family:Courier New; font-size:10pt; }
   .T35 { vertical-align:super; font-size:58%;background-color:#ffffff; }
   .T36 { font-family:Calibri; }
   .T38 { font-family:Calibri; }
   .T39 { font-family:Calibri; }
   .T4 { display:true; }
   .T40 { font-family:Calibri; font-size:11pt; }
   .T41 { font-family:Calibri; font-weight:normal; }
   .T42 { font-family:Calibri; font-weight:bold; }
   .T43 { font-family:Calibri; font-weight:bold; }
   .T44 { color:#000000; background-color:#ffffff; }
   .T45 { color:#000000; font-family:Consolas; font-size:10pt; }
   .T46 { color:#000000; font-family:Consolas; font-size:10pt; font-weight:bold; }
   .T47 { color:#000000; font-family:Consolas; font-size:9pt; }
   .T49 { font-family:Consolas; font-size:10pt; background-color:#f7f7f7; }
   .T50 { font-family:Consolas; font-size:10pt; }
   .T53 { font-weight:normal; }
   .T58 { font-family:Times New Roman; font-size:10pt; font-weight:bold; }
   .T59 { font-family:QuickType II Mono; font-size:10pt; font-weight:bold; }
   .T60 { font-family:QuickType II Mono; font-size:10pt; font-weight:bold; }
   .T63 { font-family:Cambria; font-size:12pt; }
   .T64 { text-decoration:underline; font-weight:bold; }
   .T65 { color:#7f007f; font-family:Consolas; font-size:10pt; }
   .T66 { color:#2a00ff; font-family:Consolas; font-size:10pt; font-style:italic; }
   .T67 { color:#2a00ff; font-family:Consolas; font-size:9pt; font-style:italic; }
   .T68 { color:#7f0055; font-family:Consolas; font-size:10pt; font-weight:bold; }
   .T69 { color:#7f0055; font-family:Consolas; font-size:9pt; font-weight:bold; }
   .T7 { font-weight:bold; }
   .T70 { color:#008080; font-family:Consolas; font-size:10pt; }
   .T71 { color:#3f7f7f; font-family:Consolas; font-size:10pt; }
   .T8 { background-color:#ffffff; }
   .T9 { background-color:#ffffff; }
   /* ODF styles with no properties representable as CSS */
   .Sect1 .Table1.1 .Table10.1 .Table11.1 .Table11.2 .Table12.1 .Table12.2 .Table13.1 .Table14.1 .Table15.1 .Table16.1 .Table17.1 .Table18.1 .Table19.1 .Table2.1 .Table20.1 .Table20.2 .Table21.1 .Table22.1 .Table23.1 .Table24.1 .Table24.5 .Table25.1 .Table26.1 .Table27.1 .Table28.1 .Table29.1 .Table3.1 .Table30.1 .Table31.1 .Table32.1 .Table33.1 .Table34.1 .Table35.1 .Table36.1 .Table37.1 .Table38.1 .Table39.1 .Table4.1 .Table40.1 .Table41.1 .Table42.1 .Table43.1 .Table44.1 .Table5.1 .Table6.1 .Table7.1 .Table8.1 .Table9.1 .Index_20_Link .ListLabel_20_10 .ListLabel_20_100 .ListLabel_20_102 .ListLabel_20_103 .ListLabel_20_104 .ListLabel_20_106 .ListLabel_20_107 .ListLabel_20_108 .ListLabel_20_11 .ListLabel_20_110 .ListLabel_20_111 .ListLabel_20_112 .ListLabel_20_114 .ListLabel_20_115 .ListLabel_20_116 .ListLabel_20_118 .ListLabel_20_119 .ListLabel_20_120 .ListLabel_20_122 .ListLabel_20_123 .ListLabel_20_124 .ListLabel_20_126 .ListLabel_20_127 .ListLabel_20_128 .ListLabel_20_13 .ListLabel_20_130 .ListLabel_20_131 .ListLabel_20_132 .ListLabel_20_134 .ListLabel_20_135 .ListLabel_20_136 .ListLabel_20_138 .ListLabel_20_139 .ListLabel_20_14 .ListLabel_20_140 .ListLabel_20_142 .ListLabel_20_143 .ListLabel_20_144 .ListLabel_20_146 .ListLabel_20_147 .ListLabel_20_148 .ListLabel_20_15 .ListLabel_20_150 .ListLabel_20_151 .ListLabel_20_152 .ListLabel_20_153 .ListLabel_20_154 .ListLabel_20_155 .ListLabel_20_16 .ListLabel_20_17 .ListLabel_20_18 .ListLabel_20_19 .ListLabel_20_2 .ListLabel_20_20 .ListLabel_20_21 .ListLabel_20_23 .ListLabel_20_24 .ListLabel_20_25 .ListLabel_20_26 .ListLabel_20_27 .ListLabel_20_28 .ListLabel_20_3 .ListLabel_20_30 .ListLabel_20_31 .ListLabel_20_32 .ListLabel_20_34 .ListLabel_20_35 .ListLabel_20_36 .ListLabel_20_39 .ListLabel_20_4 .ListLabel_20_40 .ListLabel_20_42 .ListLabel_20_43 .ListLabel_20_44 .ListLabel_20_46 .ListLabel_20_47 .ListLabel_20_48 .ListLabel_20_50 .ListLabel_20_51 .ListLabel_20_52 .ListLabel_20_54 .ListLabel_20_55 .ListLabel_20_56 .ListLabel_20_58 .ListLabel_20_59 .ListLabel_20_60 .ListLabel_20_62 .ListLabel_20_63 .ListLabel_20_64 .ListLabel_20_66 .ListLabel_20_67 .ListLabel_20_68 .ListLabel_20_7 .ListLabel_20_70 .ListLabel_20_71 .ListLabel_20_72 .ListLabel_20_74 .ListLabel_20_75 .ListLabel_20_76 .ListLabel_20_78 .ListLabel_20_79 .ListLabel_20_8 .ListLabel_20_80 .ListLabel_20_82 .ListLabel_20_83 .ListLabel_20_84 .ListLabel_20_86 .ListLabel_20_87 .ListLabel_20_88 .ListLabel_20_9 .ListLabel_20_90 .ListLabel_20_91 .ListLabel_20_92 .ListLabel_20_94 .ListLabel_20_95 .ListLabel_20_96 .ListLabel_20_99 .T48 .T51 .T52 .T54 .T55 .T56 .T6 .fj9y4  { }
   </style></head><body dir="ltr" style="max-width:21.59cm;margin-top:2.54cm; margin-bottom:0.762cm; margin-left:2.54cm; margin-right:2.54cm; "><!--Next 'div' was a 'text:section'.--><div class="Sect1" id="Section1"><p class="P160_borderStart">De Re BASIC!</p><p class="P159_borderEnd"><span class="T3">Version 1.92</span></p><p class="P157"><span class="Subtle_20_Emphasis">April 6, 2019</span></p><p class="Standard"> </p><p class="Standard"> </p><!--Next 'div' was a 'text:p'.--><div class="P88"><!--Next '
           div' is a draw:frame.
       --><div style="height:10.589cm;width:16.939cm; padding:0;  float:left; position:relative; left:-0.235cm; top:2.394cm; " class="fr2" id="Picture"><img style="height:10.589cm;width:16.939cm;" alt="" src=""/></div></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><p class="P158">Table of Contents</p><p class="P15"><a href="#_Toc5235690" class="Index_20_Link">Changes in this Version</a><a href="#_Toc5235690" class="Index_20_Link"><span class="T4">        24</span></a></p><p class="P15"><a href="#_Toc5235691" class="Index_20_Link">About the Title, De Re BASIC!</a><a href="#_Toc5235691" class="Index_20_Link"><span class="T4">        25</span></a></p><p class="P15"><a href="#_Toc5235692" class="Index_20_Link">About the Cover Art</a><a href="#_Toc5235692" class="Index_20_Link"><span class="T4">        25</span></a></p><p class="P15"><a href="#_Toc5235693" class="Index_20_Link">Credits</a><a href="#_Toc5235693" class="Index_20_Link"><span class="T4">        25</span></a></p><p class="P15"><a href="#_Toc5235694" class="Index_20_Link">Technical Editor</a><a href="#_Toc5235694" class="Index_20_Link"><span class="T4">        25</span></a></p><p class="P15"><a href="#_Toc5235695" class="Index_20_Link">Getting BASIC!</a><a href="#_Toc5235695" class="Index_20_Link"><span class="T4">        25</span></a></p><p class="P15"><a href="#_Toc5235696" class="Index_20_Link">BASIC! Forum</a><a href="#_Toc5235696" class="Index_20_Link"><span class="T4">        25</span></a></p><p class="P15"><a href="#_Toc5235697" class="Index_20_Link">BASIC! Tutorial</a><a href="#_Toc5235697" class="Index_20_Link"><span class="T4">        26</span></a></p><p class="P15"><a href="#_Toc5235698" class="Index_20_Link">BASIC! Operation</a><a href="#_Toc5235698" class="Index_20_Link"><span class="T4">        26</span></a></p><p class="Contents_20_2"><a href="#_Toc5235699" class="Index_20_Link">Permissions</a><a href="#_Toc5235699" class="Index_20_Link"><span class="T4">        26</span></a></p><p class="Contents_20_2"><a href="#_Toc5235700" class="Index_20_Link">Editor</a><a href="#_Toc5235700" class="Index_20_Link"><span class="T4">        27</span></a></p><p class="Contents_20_3"><a href="#_Toc5235701" class="Index_20_Link">Editing the Program</a><a href="#_Toc5235701" class="Index_20_Link"><span class="T4">        27</span></a></p><p class="Contents_20_3"><a href="#_Toc5235702" class="Index_20_Link">Multiple Commands on a Line</a><a href="#_Toc5235702" class="Index_20_Link"><span class="T4">        27</span></a></p><p class="Contents_20_3"><a href="#_Toc5235703" class="Index_20_Link">Line Continuation</a><a href="#_Toc5235703" class="Index_20_Link"><span class="T4">        27</span></a></p><p class="Contents_20_3"><a href="#_Toc5235704" class="Index_20_Link"># - Format Line</a><a href="#_Toc5235704" class="Index_20_Link"><span class="T4">        28</span></a></p><p class="Contents_20_3"><a href="#_Toc5235705" class="Index_20_Link">Menus</a><a href="#_Toc5235705" class="Index_20_Link"><span class="T4">        28</span></a></p><p class="Contents_20_2"><a href="#_Toc5235706" class="Index_20_Link">Run</a><a href="#_Toc5235706" class="Index_20_Link"><span class="T4">        35</span></a></p><p class="Contents_20_3"><a href="#_Toc5235707" class="Index_20_Link">Menu</a><a href="#_Toc5235707" class="Index_20_Link"><span class="T4">        35</span></a></p><p class="Contents_20_2"><a href="#_Toc5235708" class="Index_20_Link">Crashes</a><a href="#_Toc5235708" class="Index_20_Link"><span class="T4">        36</span></a></p><p class="P15"><a href="#_Toc5235709" class="Index_20_Link">A BASIC! Program</a><a href="#_Toc5235709" class="Index_20_Link"><span class="T4">        36</span></a></p><p class="P15"><a href="#_Toc5235710" class="Index_20_Link">Command Description Syntax</a><a href="#_Toc5235710" class="Index_20_Link"><span class="T4">        36</span></a></p><p class="Contents_20_2"><a href="#_Toc5235711" class="Index_20_Link">Upper and Lower Case</a><a href="#_Toc5235711" class="Index_20_Link"><span class="T4">        36</span></a></p><p class="Contents_20_2"><a href="#_Toc5235712" class="Index_20_Link">&lt;nexp&gt;, &lt;sexp&gt; and &lt;lexp&gt;</a><a href="#_Toc5235712" class="Index_20_Link"><span class="T4">        36</span></a></p><p class="Contents_20_2"><a href="#_Toc5235713" class="Index_20_Link">&lt;nvar&gt;, &lt;svar&gt; and &lt;lvar&gt;</a><a href="#_Toc5235713" class="Index_20_Link"><span class="T4">        37</span></a></p><p class="Contents_20_2"><a href="#_Toc5235714" class="Index_20_Link">Array[] and Array$[]</a><a href="#_Toc5235714" class="Index_20_Link"><span class="T4">        37</span></a></p><p class="Contents_20_2"><a href="#_Toc5235715" class="Index_20_Link">Array[{&lt;start&gt;,&lt;length&gt;}] and Array$[{&lt;start&gt;,&lt;length&gt;}]</a><a href="#_Toc5235715" class="Index_20_Link"><span class="T4">        37</span></a></p><p class="Contents_20_2"><a href="#_Toc5235716" class="Index_20_Link">{something}</a><a href="#_Toc5235716" class="Index_20_Link"><span class="T4">        37</span></a></p><p class="Contents_20_2"><a href="#_Toc5235717" class="Index_20_Link">{ A | B |C }</a><a href="#_Toc5235717" class="Index_20_Link"><span class="T4">        37</span></a></p><p class="Contents_20_2"><a href="#_Toc5235718" class="Index_20_Link">X, ...</a><a href="#_Toc5235718" class="Index_20_Link"><span class="T4">        37</span></a></p><p class="Contents_20_2"><a href="#_Toc5235719" class="Index_20_Link">{,n} ...</a><a href="#_Toc5235719" class="Index_20_Link"><span class="T4">        37</span></a></p><p class="Contents_20_2"><a href="#_Toc5235720" class="Index_20_Link">&lt;statement&gt;</a><a href="#_Toc5235720" class="Index_20_Link"><span class="T4">        37</span></a></p><p class="Contents_20_2"><a href="#_Toc5235721" class="Index_20_Link">Optional Parameters</a><a href="#_Toc5235721" class="Index_20_Link"><span class="T4">        37</span></a></p><p class="P15"><a href="#_Toc5235722" class="Index_20_Link">Numbers</a><a href="#_Toc5235722" class="Index_20_Link"><span class="T4">        38</span></a></p><p class="P15"><a href="#_Toc5235723" class="Index_20_Link">Strings</a><a href="#_Toc5235723" class="Index_20_Link"><span class="T4">        38</span></a></p><p class="P15"><a href="#_Toc5235724" class="Index_20_Link">Variables</a><a href="#_Toc5235724" class="Index_20_Link"><span class="T4">        39</span></a></p><p class="Contents_20_2"><a href="#_Toc5235725" class="Index_20_Link">Variable Names</a><a href="#_Toc5235725" class="Index_20_Link"><span class="T4">        39</span></a></p><p class="Contents_20_2"><a href="#_Toc5235726" class="Index_20_Link">Variable Types</a><a href="#_Toc5235726" class="Index_20_Link"><span class="T4">        39</span></a></p><p class="Contents_20_2"><a href="#_Toc5235727" class="Index_20_Link">Scalar and Array Variables</a><a href="#_Toc5235727" class="Index_20_Link"><span class="T4">        40</span></a></p><p class="Contents_20_2"><a href="#_Toc5235728" class="Index_20_Link">Scalars</a><a href="#_Toc5235728" class="Index_20_Link"><span class="T4">        40</span></a></p><p class="Contents_20_2"><a href="#_Toc5235729" class="Index_20_Link">Arrays</a><a href="#_Toc5235729" class="Index_20_Link"><span class="T4">        40</span></a></p><p class="Contents_20_3"><a href="#_Toc5235730" class="Index_20_Link">Array Segments</a><a href="#_Toc5235730" class="Index_20_Link"><span class="T4">        40</span></a></p><p class="Contents_20_3"><a href="#_Toc5235731" class="Index_20_Link">Array Commands</a><a href="#_Toc5235731" class="Index_20_Link"><span class="T4">        41</span></a></p><p class="P15"><a href="#_Toc5235732" class="Index_20_Link">Data Structures and Pointers in BASIC!</a><a href="#_Toc5235732" class="Index_20_Link"><span class="T4">        44</span></a></p><p class="Contents_20_2"><a href="#_Toc5235733" class="Index_20_Link">What is a Pointer</a><a href="#_Toc5235733" class="Index_20_Link"><span class="T4">        44</span></a></p><p class="Contents_20_2"><a href="#_Toc5235734" class="Index_20_Link">Lists</a><a href="#_Toc5235734" class="Index_20_Link"><span class="T4">        45</span></a></p><p class="Contents_20_3"><a href="#_Toc5235735" class="Index_20_Link">List Commands</a><a href="#_Toc5235735" class="Index_20_Link"><span class="T4">        46</span></a></p><p class="Contents_20_2"><a href="#_Toc5235736" class="Index_20_Link">Bundles</a><a href="#_Toc5235736" class="Index_20_Link"><span class="T4">        48</span></a></p><p class="Contents_20_3"><a href="#_Toc5235737" class="Index_20_Link">Bundle Auto-Create</a><a href="#_Toc5235737" class="Index_20_Link"><span class="T4">        48</span></a></p><p class="Contents_20_3"><a href="#_Toc5235738" class="Index_20_Link">Bundle Commands</a><a href="#_Toc5235738" class="Index_20_Link"><span class="T4">        49</span></a></p><p class="Contents_20_2"><a href="#_Toc5235739" class="Index_20_Link">Stacks</a><a href="#_Toc5235739" class="Index_20_Link"><span class="T4">        51</span></a></p><p class="Contents_20_3"><a href="#_Toc5235740" class="Index_20_Link">Stack Commands</a><a href="#_Toc5235740" class="Index_20_Link"><span class="T4">        51</span></a></p><p class="Contents_20_2"><a href="#_Toc5235741" class="Index_20_Link">Queues</a><a href="#_Toc5235741" class="Index_20_Link"><span class="T4">        52</span></a></p><p class="P15"><a href="#_Toc5235742" class="Index_20_Link">Comments</a><a href="#_Toc5235742" class="Index_20_Link"><span class="T4">        52</span></a></p><p class="Contents_20_2"><a href="#_Toc5235743" class="Index_20_Link">! - Single Line Comment</a><a href="#_Toc5235743" class="Index_20_Link"><span class="T4">        52</span></a></p><p class="Contents_20_2"><a href="#_Toc5235744" class="Index_20_Link">Rem - Single Line Comment (legacy)</a><a href="#_Toc5235744" class="Index_20_Link"><span class="T4">        52</span></a></p><p class="Contents_20_2"><a href="#_Toc5235745" class="Index_20_Link">!! - Block Comment</a><a href="#_Toc5235745" class="Index_20_Link"><span class="T4">        53</span></a></p><p class="Contents_20_2"><a href="#_Toc5235746" class="Index_20_Link">% - Middle of Line Comment</a><a href="#_Toc5235746" class="Index_20_Link"><span class="T4">        53</span></a></p><p class="P15"><a href="#_Toc5235747" class="Index_20_Link">Expressions</a><a href="#_Toc5235747" class="Index_20_Link"><span class="T4">        53</span></a></p><p class="Contents_20_2"><a href="#_Toc5235748" class="Index_20_Link">Numeric Expression &lt;nexp&gt;</a><a href="#_Toc5235748" class="Index_20_Link"><span class="T4">        53</span></a></p><p class="Contents_20_3"><a href="#_Toc5235749" class="Index_20_Link">Numeric Operators &lt;noperator&gt;</a><a href="#_Toc5235749" class="Index_20_Link"><span class="T4">        53</span></a></p><p class="Contents_20_3"><a href="#_Toc5235750" class="Index_20_Link">Numeric Expression Examples</a><a href="#_Toc5235750" class="Index_20_Link"><span class="T4">        53</span></a></p><p class="Contents_20_3"><a href="#_Toc5235751" class="Index_20_Link">Pre- and Post-Increment Operators</a><a href="#_Toc5235751" class="Index_20_Link"><span class="T4">        53</span></a></p><p class="Contents_20_2"><a href="#_Toc5235752" class="Index_20_Link">String Expression &lt;sexp&gt;</a><a href="#_Toc5235752" class="Index_20_Link"><span class="T4">        54</span></a></p><p class="Contents_20_2"><a href="#_Toc5235753" class="Index_20_Link">Logical Expression &lt;lexp&gt;</a><a href="#_Toc5235753" class="Index_20_Link"><span class="T4">        54</span></a></p><p class="Contents_20_3"><a href="#_Toc5235754" class="Index_20_Link">Logical Operators</a><a href="#_Toc5235754" class="Index_20_Link"><span class="T4">        54</span></a></p><p class="Contents_20_3"><a href="#_Toc5235755" class="Index_20_Link">Examples of Logical Expressions</a><a href="#_Toc5235755" class="Index_20_Link"><span class="T4">        55</span></a></p><p class="Contents_20_2"><a href="#_Toc5235756" class="Index_20_Link">Parentheses</a><a href="#_Toc5235756" class="Index_20_Link"><span class="T4">        55</span></a></p><p class="P15"><a href="#_Toc5235757" class="Index_20_Link">Assignment Operations</a><a href="#_Toc5235757" class="Index_20_Link"><span class="T4">        55</span></a></p><p class="Contents_20_2"><a href="#_Toc5235758" class="Index_20_Link">Let</a><a href="#_Toc5235758" class="Index_20_Link"><span class="T4">        55</span></a></p><p class="Contents_20_2"><a href="#_Toc5235759" class="Index_20_Link">OpEqual Assignment Operations</a><a href="#_Toc5235759" class="Index_20_Link"><span class="T4">        56</span></a></p><p class="P15"><a href="#_Toc5235760" class="Index_20_Link">Math Functions</a><a href="#_Toc5235760" class="Index_20_Link"><span class="T4">        56</span></a></p><p class="Contents_20_2"><a href="#_Toc5235761" class="Index_20_Link">BOR(&lt;nexp1&gt;, &lt;nexp2&gt;)</a><a href="#_Toc5235761" class="Index_20_Link"><span class="T4">        56</span></a></p><p class="Contents_20_2"><a href="#_Toc5235762" class="Index_20_Link">BAND(&lt;nexp1&gt;, &lt;nexp2&gt;)</a><a href="#_Toc5235762" class="Index_20_Link"><span class="T4">        56</span></a></p><p class="Contents_20_2"><a href="#_Toc5235763" class="Index_20_Link">BXOR(&lt;nexp1&gt;, &lt;nexp2&gt;)</a><a href="#_Toc5235763" class="Index_20_Link"><span class="T4">        57</span></a></p><p class="Contents_20_2"><a href="#_Toc5235764" class="Index_20_Link">BNOT(&lt;nexp&gt;)</a><a href="#_Toc5235764" class="Index_20_Link"><span class="T4">        57</span></a></p><p class="Contents_20_2"><a href="#_Toc5235765" class="Index_20_Link">ABS(&lt;nexp&gt;)</a><a href="#_Toc5235765" class="Index_20_Link"><span class="T4">        57</span></a></p><p class="Contents_20_2"><a href="#_Toc5235766" class="Index_20_Link">SGN(&lt;nexp&gt;)</a><a href="#_Toc5235766" class="Index_20_Link"><span class="T4">        57</span></a></p><p class="Contents_20_2"><a href="#_Toc5235767" class="Index_20_Link">RANDOMIZE({&lt;nexp&gt;})</a><a href="#_Toc5235767" class="Index_20_Link"><span class="T4">        57</span></a></p><p class="Contents_20_2"><a href="#_Toc5235768" class="Index_20_Link">RND()</a><a href="#_Toc5235768" class="Index_20_Link"><span class="T4">        57</span></a></p><p class="Contents_20_2"><a href="#_Toc5235769" class="Index_20_Link">MAX(&lt;nexp&gt;, &lt;nexp&gt;)</a><a href="#_Toc5235769" class="Index_20_Link"><span class="T4">        58</span></a></p><p class="Contents_20_2"><a href="#_Toc5235770" class="Index_20_Link">MIN(&lt;nexp&gt;, &lt;nexp&gt;)</a><a href="#_Toc5235770" class="Index_20_Link"><span class="T4">        58</span></a></p><p class="Contents_20_2"><a href="#_Toc5235771" class="Index_20_Link">CEIL(&lt;nexp&gt;)</a><a href="#_Toc5235771" class="Index_20_Link"><span class="T4">        58</span></a></p><p class="Contents_20_2"><a href="#_Toc5235772" class="Index_20_Link">FLOOR(&lt;nexp&gt;)</a><a href="#_Toc5235772" class="Index_20_Link"><span class="T4">        58</span></a></p><p class="Contents_20_2"><a href="#_Toc5235773" class="Index_20_Link">INT(&lt;nexp&gt;)</a><a href="#_Toc5235773" class="Index_20_Link"><span class="T4">        58</span></a></p><p class="Contents_20_2"><a href="#_Toc5235774" class="Index_20_Link">FRAC(&lt;nexp&gt;)</a><a href="#_Toc5235774" class="Index_20_Link"><span class="T4">        58</span></a></p><p class="Contents_20_2"><a href="#_Toc5235775" class="Index_20_Link">MOD(&lt;nexp1&gt;, &lt;nexp2&gt;)</a><a href="#_Toc5235775" class="Index_20_Link"><span class="T4">        58</span></a></p><p class="Contents_20_2"><a href="#_Toc5235776" class="Index_20_Link">ROUND(&lt;value_nexp&gt;{, &lt;count_nexp&gt;{, &lt;mode_sexp&gt;}})</a><a href="#_Toc5235776" class="Index_20_Link"><span class="T4">        58</span></a></p><p class="Contents_20_2"><a href="#_Toc5235777" class="Index_20_Link">SQR(&lt;nexp&gt;)</a><a href="#_Toc5235777" class="Index_20_Link"><span class="T4">        59</span></a></p><p class="Contents_20_2"><a href="#_Toc5235778" class="Index_20_Link">CBRT(&lt;nexp&gt;)</a><a href="#_Toc5235778" class="Index_20_Link"><span class="T4">        59</span></a></p><p class="Contents_20_2"><a href="#_Toc5235779" class="Index_20_Link">LOG(&lt;nexp&gt;)</a><a href="#_Toc5235779" class="Index_20_Link"><span class="T4">        59</span></a></p><p class="Contents_20_2"><a href="#_Toc5235780" class="Index_20_Link">LOG10(&lt;nexp&gt;)</a><a href="#_Toc5235780" class="Index_20_Link"><span class="T4">        59</span></a></p><p class="Contents_20_2"><a href="#_Toc5235781" class="Index_20_Link">EXP(&lt;nexp&gt;)</a><a href="#_Toc5235781" class="Index_20_Link"><span class="T4">        59</span></a></p><p class="Contents_20_2"><a href="#_Toc5235782" class="Index_20_Link">POW(&lt;nexp1&gt;, &lt;nexp2&gt;)</a><a href="#_Toc5235782" class="Index_20_Link"><span class="T4">        59</span></a></p><p class="Contents_20_2"><a href="#_Toc5235783" class="Index_20_Link">HYPOT(&lt;nexp_x&gt;, &lt;nexp_y)</a><a href="#_Toc5235783" class="Index_20_Link"><span class="T4">        60</span></a></p><p class="Contents_20_2"><a href="#_Toc5235784" class="Index_20_Link">PI()</a><a href="#_Toc5235784" class="Index_20_Link"><span class="T4">        60</span></a></p><p class="Contents_20_2"><a href="#_Toc5235785" class="Index_20_Link">SIN(&lt;nexp&gt;)</a><a href="#_Toc5235785" class="Index_20_Link"><span class="T4">        60</span></a></p><p class="Contents_20_2"><a href="#_Toc5235786" class="Index_20_Link">COS(&lt;nexp&gt;)</a><a href="#_Toc5235786" class="Index_20_Link"><span class="T4">        60</span></a></p><p class="Contents_20_2"><a href="#_Toc5235787" class="Index_20_Link">TAN(&lt;nexp&gt;)</a><a href="#_Toc5235787" class="Index_20_Link"><span class="T4">        60</span></a></p><p class="Contents_20_2"><a href="#_Toc5235788" class="Index_20_Link">SINH(&lt;nexp&gt;)</a><a href="#_Toc5235788" class="Index_20_Link"><span class="T4">        60</span></a></p><p class="Contents_20_2"><a href="#_Toc5235789" class="Index_20_Link">COSH(&lt;nexp&gt;)</a><a href="#_Toc5235789" class="Index_20_Link"><span class="T4">        60</span></a></p><p class="Contents_20_2"><a href="#_Toc5235790" class="Index_20_Link">ASIN(&lt;nexp&gt;)</a><a href="#_Toc5235790" class="Index_20_Link"><span class="T4">        60</span></a></p><p class="Contents_20_2"><a href="#_Toc5235791" class="Index_20_Link">ACOS(&lt;nexp&gt;)</a><a href="#_Toc5235791" class="Index_20_Link"><span class="T4">        60</span></a></p><p class="Contents_20_2"><a href="#_Toc5235792" class="Index_20_Link">ATAN(&lt;nexp&gt;)</a><a href="#_Toc5235792" class="Index_20_Link"><span class="T4">        60</span></a></p><p class="Contents_20_2"><a href="#_Toc5235793" class="Index_20_Link">ATAN2(&lt;nexp_y&gt;, &lt;nexp_x&gt;)</a><a href="#_Toc5235793" class="Index_20_Link"><span class="T4">        60</span></a></p><p class="Contents_20_2"><a href="#_Toc5235794" class="Index_20_Link">TODEGREES(&lt;nexp&gt;)</a><a href="#_Toc5235794" class="Index_20_Link"><span class="T4">        60</span></a></p><p class="Contents_20_2"><a href="#_Toc5235795" class="Index_20_Link">TORADIANS(&lt;nexp&gt;)</a><a href="#_Toc5235795" class="Index_20_Link"><span class="T4">        61</span></a></p><p class="Contents_20_2"><a href="#_Toc5235796" class="Index_20_Link">VAL(&lt;sexp&gt;)</a><a href="#_Toc5235796" class="Index_20_Link"><span class="T4">        61</span></a></p><p class="Contents_20_2"><a href="#_Toc5235797" class="Index_20_Link">IS_NUMBER(&lt;sexp&gt;)</a><a href="#_Toc5235797" class="Index_20_Link"><span class="T4">        61</span></a></p><p class="Contents_20_2"><a href="#_Toc5235798" class="Index_20_Link">LEN(&lt;sexp&gt;)</a><a href="#_Toc5235798" class="Index_20_Link"><span class="T4">        61</span></a></p><p class="Contents_20_2"><a href="#_Toc5235799" class="Index_20_Link">HEX(&lt;sexp&gt;)</a><a href="#_Toc5235799" class="Index_20_Link"><span class="T4">        61</span></a></p><p class="Contents_20_2"><a href="#_Toc5235800" class="Index_20_Link">OCT(&lt;sexp&gt;)</a><a href="#_Toc5235800" class="Index_20_Link"><span class="T4">        61</span></a></p><p class="Contents_20_2"><a href="#_Toc5235801" class="Index_20_Link">BIN(&lt;sexp&gt;)</a><a href="#_Toc5235801" class="Index_20_Link"><span class="T4">        61</span></a></p><p class="Contents_20_2"><a href="#_Toc5235802" class="Index_20_Link">SHIFT(&lt;value_nexp&gt;, &lt;bits_nexp&gt;)</a><a href="#_Toc5235802" class="Index_20_Link"><span class="T4">        62</span></a></p><p class="Contents_20_2"><a href="#_Toc5235803" class="Index_20_Link">ASCII(&lt;sexp&gt;{, &lt;index_nexp&gt;})</a><a href="#_Toc5235803" class="Index_20_Link"><span class="T4">        62</span></a></p><p class="Contents_20_2"><a href="#_Toc5235804" class="Index_20_Link">UCODE(&lt;sexp&gt;{, &lt;index_nexp&gt;})</a><a href="#_Toc5235804" class="Index_20_Link"><span class="T4">        62</span></a></p><p class="Contents_20_2"><a href="#_Toc5235805" class="Index_20_Link"><span class="T6">IS_IN(&lt;sub</span></a><a href="#_Toc5235805" class="Index_20_Link">_sexp&gt;</a><a href="#_Toc5235805" class="Index_20_Link"><span class="T6">, &lt;base</span></a><a href="#_Toc5235805" class="Index_20_Link">_sexp&gt;{, &lt;start_nexp&gt;})</a><a href="#_Toc5235805" class="Index_20_Link"><span class="T4">        62</span></a></p><p class="Contents_20_2"><a href="#_Toc5235806" class="Index_20_Link">STARTS_WITH(&lt;sub_sexp&gt;, &lt;base_sexp&gt;{, &lt;start_nexp&gt;})</a><a href="#_Toc5235806" class="Index_20_Link"><span class="T4">        62</span></a></p><p class="Contents_20_2"><a href="#_Toc5235807" class="Index_20_Link">ENDS_WITH(&lt;sub_sexp&gt;, &lt;base_sexp&gt;)</a><a href="#_Toc5235807" class="Index_20_Link"><span class="T4">        63</span></a></p><p class="Contents_20_2"><a href="#_Toc5235808" class="Index_20_Link">GR_COLLISION(&lt;object_1_nvar&gt;, &lt;object_2_nvar&gt;)</a><a href="#_Toc5235808" class="Index_20_Link"><span class="T4">        63</span></a></p><p class="Contents_20_2"><a href="#_Toc5235809" class="Index_20_Link">BACKGROUND()</a><a href="#_Toc5235809" class="Index_20_Link"><span class="T4">        63</span></a></p><p class="P15"><a href="#_Toc5235810" class="Index_20_Link">Time Functions</a><a href="#_Toc5235810" class="Index_20_Link"><span class="T4">        63</span></a></p><p class="Contents_20_2"><a href="#_Toc5235811" class="Index_20_Link">CLOCK()</a><a href="#_Toc5235811" class="Index_20_Link"><span class="T4">        63</span></a></p><p class="Contents_20_2"><a href="#_Toc5235812" class="Index_20_Link">TIME()</a><a href="#_Toc5235812" class="Index_20_Link"><span class="T4">        63</span></a></p><p class="Contents_20_2"><a href="#_Toc5235813" class="Index_20_Link">TIME(&lt;year_exp&gt;, &lt;month_exp&gt;, &lt;day_exp&gt;, &lt;hour_exp&gt;, &lt;minute_exp&gt;, &lt;second_exp&gt;)</a><a href="#_Toc5235813" class="Index_20_Link"><span class="T4">        64</span></a></p><p class="P15"><a href="#_Toc5235814" class="Index_20_Link">String Functions</a><a href="#_Toc5235814" class="Index_20_Link"><span class="T4">        64</span></a></p><p class="Contents_20_2"><a href="#_Toc5235815" class="Index_20_Link">GETERROR$()</a><a href="#_Toc5235815" class="Index_20_Link"><span class="T4">        64</span></a></p><p class="Contents_20_2"><a href="#_Toc5235816" class="Index_20_Link">CHR$(&lt;nexp&gt;, ...)</a><a href="#_Toc5235816" class="Index_20_Link"><span class="T4">        65</span></a></p><p class="Contents_20_2"><a href="#_Toc5235817" class="Index_20_Link"><span class="T6">LEFT$(&lt;sexp&gt;, </span></a><a href="#_Toc5235817" class="Index_20_Link">&lt;count_nexp&gt;</a><a href="#_Toc5235817" class="Index_20_Link"><span class="T6">)</span></a><a href="#_Toc5235817" class="Index_20_Link"><span class="T4">        65</span></a></p><p class="Contents_20_2"><a href="#_Toc5235818" class="Index_20_Link"><span class="T6">MID$(&lt;sexp&gt;, </span></a><a href="#_Toc5235818" class="Index_20_Link">&lt;start_nexp&gt;{, &lt;count_nexp&gt;}</a><a href="#_Toc5235818" class="Index_20_Link"><span class="T6">)</span></a><a href="#_Toc5235818" class="Index_20_Link"><span class="T4">        65</span></a></p><p class="Contents_20_2"><a href="#_Toc5235819" class="Index_20_Link"><span class="T6">RIGHT$(</span></a><a href="#_Toc5235819" class="Index_20_Link">&lt;sexp&gt;, &lt;count_nexp&gt;</a><a href="#_Toc5235819" class="Index_20_Link"><span class="T6">)</span></a><a href="#_Toc5235819" class="Index_20_Link"><span class="T4">        65</span></a></p><p class="Contents_20_2"><a href="#_Toc5235820" class="Index_20_Link"><span class="T6">REPLACE$(&lt;sexp&gt;, &lt;argument_sexp&gt;, &lt;replace_sexp&gt;)</span></a><a href="#_Toc5235820" class="Index_20_Link"><span class="T4">        66</span></a></p><p class="Contents_20_2"><a href="#_Toc5235821" class="Index_20_Link">TRIM$(&lt;sexp&gt;{, &lt;test_sexp&gt;})</a><a href="#_Toc5235821" class="Index_20_Link"><span class="T4">        66</span></a></p><p class="Contents_20_2"><a href="#_Toc5235822" class="Index_20_Link">LTRIM$(&lt;sexp&gt;{, &lt;test_sexp&gt;})</a><a href="#_Toc5235822" class="Index_20_Link"><span class="T4">        66</span></a></p><p class="Contents_20_2"><a href="#_Toc5235823" class="Index_20_Link">RTRIM$(&lt;sexp&gt;{, &lt;test_sexp&gt;})</a><a href="#_Toc5235823" class="Index_20_Link"><span class="T4">        66</span></a></p><p class="Contents_20_2"><a href="#_Toc5235824" class="Index_20_Link"><span class="T6">WORD$(&lt;source_sexp&gt;, &lt;n_nexp&gt; {, &lt;test_sexp&gt;})</span></a><a href="#_Toc5235824" class="Index_20_Link"><span class="T4">        66</span></a></p><p class="Contents_20_2"><a href="#_Toc5235825" class="Index_20_Link">ENCODE$(&lt;type_sexp&gt;, {&lt;qualifier_sexp&gt;}, &lt;source_sexp&gt;)</a><a href="#_Toc5235825" class="Index_20_Link"><span class="T4">        67</span></a></p><p class="Contents_20_2"><a href="#_Toc5235826" class="Index_20_Link">DECODE$(&lt;type_sexp&gt;, {&lt;qualifier_sexp&gt;}, &lt;source_sexp&gt;)</a><a href="#_Toc5235826" class="Index_20_Link"><span class="T4">        68</span></a></p><p class="Contents_20_2"><a href="#_Toc5235827" class="Index_20_Link">ENCODE$(&lt;charset_sexp&gt;, &lt;source_sexp&gt;)</a><a href="#_Toc5235827" class="Index_20_Link"><span class="T4">        69</span></a></p><p class="Contents_20_2"><a href="#_Toc5235828" class="Index_20_Link">DECODE$(&lt;charset_sexp&gt;, &lt;buffer_sexp&gt;)</a><a href="#_Toc5235828" class="Index_20_Link"><span class="T4">        69</span></a></p><p class="Contents_20_2"><a href="#_Toc5235829" class="Index_20_Link"><span class="T6">STR$(</span></a><a href="#_Toc5235829" class="Index_20_Link">&lt;nexp&gt;</a><a href="#_Toc5235829" class="Index_20_Link"><span class="T6">)</span></a><a href="#_Toc5235829" class="Index_20_Link"><span class="T4">        70</span></a></p><p class="Contents_20_2"><a href="#_Toc5235830" class="Index_20_Link"><span class="T6">LOWER$(</span></a><a href="#_Toc5235830" class="Index_20_Link">&lt;sexp&gt;</a><a href="#_Toc5235830" class="Index_20_Link"><span class="T6">)</span></a><a href="#_Toc5235830" class="Index_20_Link"><span class="T4">        70</span></a></p><p class="Contents_20_2"><a href="#_Toc5235831" class="Index_20_Link"><span class="T6">UPPER$(</span></a><a href="#_Toc5235831" class="Index_20_Link">&lt;sexp&gt;</a><a href="#_Toc5235831" class="Index_20_Link"><span class="T6">)</span></a><a href="#_Toc5235831" class="Index_20_Link"><span class="T4">        70</span></a></p><p class="Contents_20_2"><a href="#_Toc5235832" class="Index_20_Link"><span class="T6">VERSION$()</span></a><a href="#_Toc5235832" class="Index_20_Link"><span class="T4">        70</span></a></p><p class="Contents_20_2"><a href="#_Toc5235833" class="Index_20_Link"><span class="T6">INT$(&lt;nexp&gt;)</span></a><a href="#_Toc5235833" class="Index_20_Link"><span class="T4">        70</span></a></p><p class="Contents_20_2"><a href="#_Toc5235834" class="Index_20_Link"><span class="T6">HEX$(&lt;nexp&gt;)</span></a><a href="#_Toc5235834" class="Index_20_Link"><span class="T4">        70</span></a></p><p class="Contents_20_2"><a href="#_Toc5235835" class="Index_20_Link">OCT$(&lt;nexp&gt;)</a><a href="#_Toc5235835" class="Index_20_Link"><span class="T4">        70</span></a></p><p class="Contents_20_2"><a href="#_Toc5235836" class="Index_20_Link">BIN$(&lt;nexp&gt;)</a><a href="#_Toc5235836" class="Index_20_Link"><span class="T4">        70</span></a></p><p class="Contents_20_2"><a href="#_Toc5235837" class="Index_20_Link">USING$({&lt;locale_sexp&gt;} , &lt;format_sexp&gt; { , &lt;exp&gt;}...)</a><a href="#_Toc5235837" class="Index_20_Link"><span class="T4">        70</span></a></p><p class="Contents_20_3"><a href="#_Toc5235838" class="Index_20_Link">Locale expression</a><a href="#_Toc5235838" class="Index_20_Link"><span class="T4">        71</span></a></p><p class="Contents_20_3"><a href="#_Toc5235839" class="Index_20_Link">Format expression</a><a href="#_Toc5235839" class="Index_20_Link"><span class="T4">        71</span></a></p><p class="Contents_20_3"><a href="#_Toc5235840" class="Index_20_Link">Integer values</a><a href="#_Toc5235840" class="Index_20_Link"><span class="T4">        74</span></a></p><p class="Contents_20_2"><a href="#_Toc5235841" class="Index_20_Link">FORMAT_USING$(&lt;locale_sexp&gt;, &lt;format_sexp&gt; { , &lt;exp&gt;}...)</a><a href="#_Toc5235841" class="Index_20_Link"><span class="T4">        75</span></a></p><p class="Contents_20_2"><a href="#_Toc5235842" class="Index_20_Link"><span class="T6">FORMAT$(</span></a><a href="#_Toc5235842" class="Index_20_Link">&lt;pattern_sexp&gt;</a><a href="#_Toc5235842" class="Index_20_Link"><span class="T6">, </span></a><a href="#_Toc5235842" class="Index_20_Link">&lt;nexp&gt;</a><a href="#_Toc5235842" class="Index_20_Link"><span class="T6">)</span></a><a href="#_Toc5235842" class="Index_20_Link"><span class="T4">        75</span></a></p><p class="Contents_20_3"><a href="#_Toc5235843" class="Index_20_Link">Notes</a><a href="#_Toc5235843" class="Index_20_Link"><span class="T4">        75</span></a></p><p class="Contents_20_3"><a href="#_Toc5235844" class="Index_20_Link">Examples</a><a href="#_Toc5235844" class="Index_20_Link"><span class="T4">        76</span></a></p><p class="P15"><a href="#_Toc5235845" class="Index_20_Link">User-Defined Functions</a><a href="#_Toc5235845" class="Index_20_Link"><span class="T4">        76</span></a></p><p class="Contents_20_2"><a href="#_Toc5235846" class="Index_20_Link">Variable Scope</a><a href="#_Toc5235846" class="Index_20_Link"><span class="T4">        76</span></a></p><p class="Contents_20_2"><a href="#_Toc5235847" class="Index_20_Link">Data Structures in User-Defined Functions</a><a href="#_Toc5235847" class="Index_20_Link"><span class="T4">        77</span></a></p><p class="Contents_20_2"><a href="#_Toc5235848" class="Index_20_Link">Commands</a><a href="#_Toc5235848" class="Index_20_Link"><span class="T4">        77</span></a></p><p class="Contents_20_3"><a href="#_Toc5235849" class="Index_20_Link">Fn.def name|name$( {nvar}|{svar}|Array[]|Array$[], ... {nvar}|{svar}|Array[]|Array$[])</a><a href="#_Toc5235849" class="Index_20_Link"><span class="T4">        77</span></a></p><p class="Contents_20_3"><a href="#_Toc5235850" class="Index_20_Link">Fn.rtn &lt;sexp&gt;|&lt;nexp&gt;</a><a href="#_Toc5235850" class="Index_20_Link"><span class="T4">        78</span></a></p><p class="Contents_20_3"><a href="#_Toc5235851" class="Index_20_Link">Fn.end</a><a href="#_Toc5235851" class="Index_20_Link"><span class="T4">        78</span></a></p><p class="Contents_20_3"><a href="#_Toc5235852" class="Index_20_Link">Call &lt;user_defined_function&gt;</a><a href="#_Toc5235852" class="Index_20_Link"><span class="T4">        78</span></a></p><p class="P15"><a href="#_Toc5235853" class="Index_20_Link">Program Control Commands</a><a href="#_Toc5235853" class="Index_20_Link"><span class="T4">        79</span></a></p><p class="Contents_20_2"><a href="#_Toc5235854" class="Index_20_Link">If / Then / Else / Elseif / Endif</a><a href="#_Toc5235854" class="Index_20_Link"><span class="T4">        79</span></a></p><p class="Contents_20_2"><a href="#_Toc5235855" class="Index_20_Link">If / Then / Else</a><a href="#_Toc5235855" class="Index_20_Link"><span class="T4">        80</span></a></p><p class="Contents_20_2"><a href="#_Toc5235856" class="Index_20_Link">For - To - Step / Next</a><a href="#_Toc5235856" class="Index_20_Link"><span class="T4">        80</span></a></p><p class="Contents_20_2"><a href="#_Toc5235857" class="Index_20_Link">F_N.continue</a><a href="#_Toc5235857" class="Index_20_Link"><span class="T4">        81</span></a></p><p class="Contents_20_2"><a href="#_Toc5235858" class="Index_20_Link">F_N.break</a><a href="#_Toc5235858" class="Index_20_Link"><span class="T4">        81</span></a></p><p class="Contents_20_2"><a href="#_Toc5235859" class="Index_20_Link">While &lt;lexp&gt; / Repeat</a><a href="#_Toc5235859" class="Index_20_Link"><span class="T4">        81</span></a></p><p class="Contents_20_2"><a href="#_Toc5235860" class="Index_20_Link">W_R.continue</a><a href="#_Toc5235860" class="Index_20_Link"><span class="T4">        81</span></a></p><p class="Contents_20_2"><a href="#_Toc5235861" class="Index_20_Link">W_R.break</a><a href="#_Toc5235861" class="Index_20_Link"><span class="T4">        82</span></a></p><p class="Contents_20_2"><a href="#_Toc5235862" class="Index_20_Link">Do / Until &lt;lexp&gt;</a><a href="#_Toc5235862" class="Index_20_Link"><span class="T4">        82</span></a></p><p class="Contents_20_2"><a href="#_Toc5235863" class="Index_20_Link">D_U.continue</a><a href="#_Toc5235863" class="Index_20_Link"><span class="T4">        82</span></a></p><p class="Contents_20_2"><a href="#_Toc5235864" class="Index_20_Link">D_U.break</a><a href="#_Toc5235864" class="Index_20_Link"><span class="T4">        82</span></a></p><p class="Contents_20_2"><a href="#_Toc5235865" class="Index_20_Link">Labels, GOTO, GOSUB, and RETURN: Traditional BASIC</a><a href="#_Toc5235865" class="Index_20_Link"><span class="T4">        82</span></a></p><p class="Contents_20_3"><a href="#_Toc5235866" class="Index_20_Link">Label</a><a href="#_Toc5235866" class="Index_20_Link"><span class="T4">        83</span></a></p><p class="Contents_20_3"><a href="#_Toc5235867" class="Index_20_Link">GoTo &lt;label&gt;</a><a href="#_Toc5235867" class="Index_20_Link"><span class="T4">        83</span></a></p><p class="Contents_20_3"><a href="#_Toc5235868" class="Index_20_Link">GoTo &lt;index_nexp&gt;, &lt;label&gt;...</a><a href="#_Toc5235868" class="Index_20_Link"><span class="T4">        83</span></a></p><p class="Contents_20_3"><a href="#_Toc5235869" class="Index_20_Link">GoSub &lt;label&gt; / Return</a><a href="#_Toc5235869" class="Index_20_Link"><span class="T4">        84</span></a></p><p class="Contents_20_3"><a href="#_Toc5235870" class="Index_20_Link">GoSub &lt;index_nexp&gt;, &lt;label&gt;... / Return</a><a href="#_Toc5235870" class="Index_20_Link"><span class="T4">        84</span></a></p><p class="Contents_20_2"><a href="#_Toc5235871" class="Index_20_Link">Using Source Code from Multiple Files</a><a href="#_Toc5235871" class="Index_20_Link"><span class="T4">        85</span></a></p><p class="Contents_20_3"><a href="#_Toc5235872" class="Index_20_Link">Include FilePath</a><a href="#_Toc5235872" class="Index_20_Link"><span class="T4">        85</span></a></p><p class="Contents_20_3"><a href="#_Toc5235873" class="Index_20_Link">Run &lt;filename_sexp&gt;{, &lt;data_sexp&gt;}</a><a href="#_Toc5235873" class="Index_20_Link"><span class="T4">        85</span></a></p><p class="Contents_20_3"><a href="#_Toc5235874" class="Index_20_Link">Program.info &lt;nexp&gt;|&lt;nvar&gt;</a><a href="#_Toc5235874" class="Index_20_Link"><span class="T4">        86</span></a></p><p class="Contents_20_2"><a href="#_Toc5235875" class="Index_20_Link">Switch Commands</a><a href="#_Toc5235875" class="Index_20_Link"><span class="T4">        87</span></a></p><p class="Contents_20_3"><a href="#_Toc5235876" class="Index_20_Link">Nesting Switch Operations</a><a href="#_Toc5235876" class="Index_20_Link"><span class="T4">        88</span></a></p><p class="Contents_20_3"><a href="#_Toc5235877" class="Index_20_Link">Sw.begin &lt;exp&gt;</a><a href="#_Toc5235877" class="Index_20_Link"><span class="T4">        88</span></a></p><p class="Contents_20_3"><a href="#_Toc5235878" class="Index_20_Link">Sw.case &lt;exp&gt;, ...</a><a href="#_Toc5235878" class="Index_20_Link"><span class="T4">        88</span></a></p><p class="Contents_20_3"><a href="#_Toc5235879" class="Index_20_Link">Sw.case &lt;op&gt;&lt;exp&gt;</a><a href="#_Toc5235879" class="Index_20_Link"><span class="T4">        88</span></a></p><p class="Contents_20_3"><a href="#_Toc5235880" class="Index_20_Link">Sw.break</a><a href="#_Toc5235880" class="Index_20_Link"><span class="T4">        89</span></a></p><p class="Contents_20_3"><a href="#_Toc5235881" class="Index_20_Link">Sw.default</a><a href="#_Toc5235881" class="Index_20_Link"><span class="T4">        89</span></a></p><p class="Contents_20_3"><a href="#_Toc5235882" class="Index_20_Link">Sw.end</a><a href="#_Toc5235882" class="Index_20_Link"><span class="T4">        89</span></a></p><p class="Contents_20_2"><a href="#_Toc5235883" class="Index_20_Link">Interrupt Labels (Event Handlers)</a><a href="#_Toc5235883" class="Index_20_Link"><span class="T4">        89</span></a></p><p class="Contents_20_3"><a href="#_Toc5235884" class="Index_20_Link">All Interrupt Labels</a><a href="#_Toc5235884" class="Index_20_Link"><span class="T4">        90</span></a></p><p class="Contents_20_3"><a href="#_Toc5235885" class="Index_20_Link">OnError:</a><a href="#_Toc5235885" class="Index_20_Link"><span class="T4">        90</span></a></p><p class="Contents_20_3"><a href="#_Toc5235886" class="Index_20_Link">OnConsoleTouch:</a><a href="#_Toc5235886" class="Index_20_Link"><span class="T4">        90</span></a></p><p class="Contents_20_3"><a href="#_Toc5235887" class="Index_20_Link">ConsoleTouch.resume</a><a href="#_Toc5235887" class="Index_20_Link"><span class="T4">        91</span></a></p><p class="Contents_20_3"><a href="#_Toc5235888" class="Index_20_Link">OnBackKey:</a><a href="#_Toc5235888" class="Index_20_Link"><span class="T4">        91</span></a></p><p class="Contents_20_3"><a href="#_Toc5235889" class="Index_20_Link">Back.resume</a><a href="#_Toc5235889" class="Index_20_Link"><span class="T4">        91</span></a></p><p class="Contents_20_3"><a href="#_Toc5235890" class="Index_20_Link">OnMenuKey:</a><a href="#_Toc5235890" class="Index_20_Link"><span class="T4">        91</span></a></p><p class="Contents_20_3"><a href="#_Toc5235891" class="Index_20_Link">MenuKey.resume</a><a href="#_Toc5235891" class="Index_20_Link"><span class="T4">        91</span></a></p><p class="Contents_20_3"><a href="#_Toc5235892" class="Index_20_Link">OnKeyPress:</a><a href="#_Toc5235892" class="Index_20_Link"><span class="T4">        91</span></a></p><p class="Contents_20_3"><a href="#_Toc5235893" class="Index_20_Link">Key.resume</a><a href="#_Toc5235893" class="Index_20_Link"><span class="T4">        91</span></a></p><p class="Contents_20_3"><a href="#_Toc5235894" class="Index_20_Link">OnLowMemory:</a><a href="#_Toc5235894" class="Index_20_Link"><span class="T4">        91</span></a></p><p class="Contents_20_3"><a href="#_Toc5235895" class="Index_20_Link">LowMemory.resume</a><a href="#_Toc5235895" class="Index_20_Link"><span class="T4">        92</span></a></p><p class="Contents_20_2"><a href="#_Toc5235896" class="Index_20_Link">End{ &lt;msg_sexp&gt;}</a><a href="#_Toc5235896" class="Index_20_Link"><span class="T4">        92</span></a></p><p class="Contents_20_2"><a href="#_Toc5235897" class="Index_20_Link">Exit</a><a href="#_Toc5235897" class="Index_20_Link"><span class="T4">        92</span></a></p><p class="P15"><a href="#_Toc5235898" class="Index_20_Link">READ – DATA – RESTORE Commands</a><a href="#_Toc5235898" class="Index_20_Link"><span class="T4">        92</span></a></p><p class="Contents_20_2"><a href="#_Toc5235899" class="Index_20_Link">Read.data &lt;number&gt;|&lt;string&gt;{,&lt;number&gt;|&lt;string&gt;...,&lt;number&gt;|&lt;string&gt;}</a><a href="#_Toc5235899" class="Index_20_Link"><span class="T4">        92</span></a></p><p class="Contents_20_2"><a href="#_Toc5235900" class="Index_20_Link">Read.next &lt;var&gt;, ...</a><a href="#_Toc5235900" class="Index_20_Link"><span class="T4">        92</span></a></p><p class="Contents_20_2"><a href="#_Toc5235901" class="Index_20_Link">Read.from &lt;nexp&gt;</a><a href="#_Toc5235901" class="Index_20_Link"><span class="T4">        92</span></a></p><p class="P15"><a href="#_Toc5235902" class="Index_20_Link">Debug Commands</a><a href="#_Toc5235902" class="Index_20_Link"><span class="T4">        93</span></a></p><p class="Contents_20_2"><a href="#_Toc5235903" class="Index_20_Link">Debug.on</a><a href="#_Toc5235903" class="Index_20_Link"><span class="T4">        93</span></a></p><p class="Contents_20_2"><a href="#_Toc5235904" class="Index_20_Link">Debug.off</a><a href="#_Toc5235904" class="Index_20_Link"><span class="T4">        93</span></a></p><p class="Contents_20_2"><a href="#_Toc5235905" class="Index_20_Link">Debug.echo.on</a><a href="#_Toc5235905" class="Index_20_Link"><span class="T4">        93</span></a></p><p class="Contents_20_2"><a href="#_Toc5235906" class="Index_20_Link">Echo.on</a><a href="#_Toc5235906" class="Index_20_Link"><span class="T4">        93</span></a></p><p class="Contents_20_2"><a href="#_Toc5235907" class="Index_20_Link">Debug.echo.off</a><a href="#_Toc5235907" class="Index_20_Link"><span class="T4">        93</span></a></p><p class="Contents_20_2"><a href="#_Toc5235908" class="Index_20_Link">Echo.off</a><a href="#_Toc5235908" class="Index_20_Link"><span class="T4">        93</span></a></p><p class="Contents_20_2"><a href="#_Toc5235909" class="Index_20_Link">Debug.print</a><a href="#_Toc5235909" class="Index_20_Link"><span class="T4">        93</span></a></p><p class="Contents_20_2"><a href="#_Toc5235910" class="Index_20_Link">Debug.dump.scalars</a><a href="#_Toc5235910" class="Index_20_Link"><span class="T4">        93</span></a></p><p class="Contents_20_2"><a href="#_Toc5235911" class="Index_20_Link">Debug.dump.array Array[]</a><a href="#_Toc5235911" class="Index_20_Link"><span class="T4">        94</span></a></p><p class="Contents_20_2"><a href="#_Toc5235912" class="Index_20_Link">Debug.dump.bundle &lt;bundlePtr_nexp&gt;</a><a href="#_Toc5235912" class="Index_20_Link"><span class="T4">        94</span></a></p><p class="Contents_20_2"><a href="#_Toc5235913" class="Index_20_Link">Debug.dump.list &lt;listPtr_nexp&gt;</a><a href="#_Toc5235913" class="Index_20_Link"><span class="T4">        94</span></a></p><p class="Contents_20_2"><a href="#_Toc5235914" class="Index_20_Link">Debug.dump.stack &lt;stackPtr_nexp&gt;</a><a href="#_Toc5235914" class="Index_20_Link"><span class="T4">        94</span></a></p><p class="Contents_20_2"><a href="#_Toc5235915" class="Index_20_Link">Debug.show.scalars</a><a href="#_Toc5235915" class="Index_20_Link"><span class="T4">        94</span></a></p><p class="Contents_20_2"><a href="#_Toc5235916" class="Index_20_Link">Debug.show.array Array[]</a><a href="#_Toc5235916" class="Index_20_Link"><span class="T4">        94</span></a></p><p class="Contents_20_2"><a href="#_Toc5235917" class="Index_20_Link">Debug.show.bundle &lt;bundlePtr_nexp&gt;</a><a href="#_Toc5235917" class="Index_20_Link"><span class="T4">        94</span></a></p><p class="Contents_20_2"><a href="#_Toc5235918" class="Index_20_Link">Debug.show.list &lt;listPtr_nexp&gt;</a><a href="#_Toc5235918" class="Index_20_Link"><span class="T4">        94</span></a></p><p class="Contents_20_2"><a href="#_Toc5235919" class="Index_20_Link">Debug.show.stack &lt;stackPtr_nexp&gt;</a><a href="#_Toc5235919" class="Index_20_Link"><span class="T4">        95</span></a></p><p class="Contents_20_2"><a href="#_Toc5235920" class="Index_20_Link">Debug.watch var, ...</a><a href="#_Toc5235920" class="Index_20_Link"><span class="T4">        95</span></a></p><p class="Contents_20_2"><a href="#_Toc5235921" class="Index_20_Link">Debug.show.watch</a><a href="#_Toc5235921" class="Index_20_Link"><span class="T4">        95</span></a></p><p class="Contents_20_2"><a href="#_Toc5235922" class="Index_20_Link">Debug.show.program</a><a href="#_Toc5235922" class="Index_20_Link"><span class="T4">        95</span></a></p><p class="Contents_20_2"><a href="#_Toc5235923" class="Index_20_Link">Debug.show</a><a href="#_Toc5235923" class="Index_20_Link"><span class="T4">        95</span></a></p><p class="P15"><a href="#_Toc5235924" class="Index_20_Link">Fonts</a><a href="#_Toc5235924" class="Index_20_Link"><span class="T4">        95</span></a></p><p class="Contents_20_2"><a href="#_Toc5235925" class="Index_20_Link">Font.load &lt;font_ptr_nvar&gt;, &lt;filename_sexp&gt;</a><a href="#_Toc5235925" class="Index_20_Link"><span class="T4">        96</span></a></p><p class="Contents_20_2"><a href="#_Toc5235926" class="Index_20_Link">Font.delete {&lt;font_ptr_nexp&gt;}</a><a href="#_Toc5235926" class="Index_20_Link"><span class="T4">        96</span></a></p><p class="Contents_20_2"><a href="#_Toc5235927" class="Index_20_Link">Font.clear</a><a href="#_Toc5235927" class="Index_20_Link"><span class="T4">        96</span></a></p><p class="P15"><a href="#_Toc5235928" class="Index_20_Link">Console I/O</a><a href="#_Toc5235928" class="Index_20_Link"><span class="T4">        96</span></a></p><p class="Contents_20_2"><a href="#_Toc5235929" class="Index_20_Link">Output Console</a><a href="#_Toc5235929" class="Index_20_Link"><span class="T4">        96</span></a></p><p class="Contents_20_3"><a href="#_Toc5235930" class="Index_20_Link">Print {&lt;exp&gt; {,|;}} ...</a><a href="#_Toc5235930" class="Index_20_Link"><span class="T4">        97</span></a></p><p class="Contents_20_3"><a href="#_Toc5235931" class="Index_20_Link">? {&lt;exp&gt; {,|;}} ...</a><a href="#_Toc5235931" class="Index_20_Link"><span class="T4">        97</span></a></p><p class="Contents_20_3"><a href="#_Toc5235932" class="Index_20_Link">Print with User-Defined Functions</a><a href="#_Toc5235932" class="Index_20_Link"><span class="T4">        97</span></a></p><p class="Contents_20_3"><a href="#_Toc5235933" class="Index_20_Link">Cls</a><a href="#_Toc5235933" class="Index_20_Link"><span class="T4">        98</span></a></p><p class="Contents_20_3"><a href="#_Toc5235934" class="Index_20_Link">Console.front</a><a href="#_Toc5235934" class="Index_20_Link"><span class="T4">        98</span></a></p><p class="Contents_20_3"><a href="#_Toc5235935" class="Index_20_Link">Console.line.count &lt;count_nvar&gt;</a><a href="#_Toc5235935" class="Index_20_Link"><span class="T4">        98</span></a></p><p class="Contents_20_3"><a href="#_Toc5235936" class="Index_20_Link">Console.line.text &lt;line_nexp&gt;, &lt;text_svar&gt;</a><a href="#_Toc5235936" class="Index_20_Link"><span class="T4">        98</span></a></p><p class="Contents_20_3"><a href="#_Toc5235937" class="Index_20_Link">Console.line.touched &lt;line_nvar&gt; {, &lt;press_lvar&gt;}</a><a href="#_Toc5235937" class="Index_20_Link"><span class="T4">        98</span></a></p><p class="Contents_20_3"><a href="#_Toc5235938" class="Index_20_Link">Console.save &lt;filename_sexp&gt;</a><a href="#_Toc5235938" class="Index_20_Link"><span class="T4">        98</span></a></p><p class="Contents_20_3"><a href="#_Toc5235939" class="Index_20_Link">Console.title { &lt;title_sexp&gt;}</a><a href="#_Toc5235939" class="Index_20_Link"><span class="T4">        98</span></a></p><p class="Contents_20_2"><a href="#_Toc5235940" class="Index_20_Link">User Input and Interaction</a><a href="#_Toc5235940" class="Index_20_Link"><span class="T4">        98</span></a></p><p class="Contents_20_3"><a href="#_Toc5235941" class="Index_20_Link">Dialog.message {&lt;title_sexp&gt;}, {&lt;message_sexp&gt;}, &lt;sel_nvar&gt; {, &lt;button1_sexp&gt;{, &lt;button2_sexp&gt;{, &lt;button3_sexp&gt;}}}</a><a href="#_Toc5235941" class="Index_20_Link"><span class="T4">        99</span></a></p><p class="Contents_20_3"><a href="#_Toc5235942" class="Index_20_Link">Dialog.select &lt;sel_nvar&gt;, &lt;Array$[]&gt;|&lt;list_nexp&gt; {,&lt;title_sexp&gt;}</a><a href="#_Toc5235942" class="Index_20_Link"><span class="T4">        100</span></a></p><p class="Contents_20_3"><a href="#_Toc5235943" class="Index_20_Link">Input {&lt;prompt_sexp&gt;}, &lt;result_var&gt;{, {&lt;default_exp&gt;}{, &lt;canceled_nvar&gt;}}</a><a href="#_Toc5235943" class="Index_20_Link"><span class="T4">        100</span></a></p><p class="Contents_20_3"><a href="#_Toc5235944" class="Index_20_Link">Inkey$ &lt;svar&gt;</a><a href="#_Toc5235944" class="Index_20_Link"><span class="T4">        101</span></a></p><p class="Contents_20_3"><a href="#_Toc5235945" class="Index_20_Link">Popup &lt;message_sexp&gt; {{, &lt;x_nexp&gt;}{, &lt;y_nexp&gt;}{, &lt;duration_lexp&gt;}}</a><a href="#_Toc5235945" class="Index_20_Link"><span class="T4">        101</span></a></p><p class="Contents_20_3"><a href="#_Toc5235946" class="Index_20_Link">Select &lt;sel_nvar&gt;, &lt;Array$[]&gt;|&lt;list_nexp&gt; {,&lt;title_sexp&gt; {, &lt;message_sexp&gt; } } {,&lt;press_lvar&gt; }</a><a href="#_Toc5235946" class="Index_20_Link"><span class="T4">        101</span></a></p><p class="Contents_20_3"><a href="#_Toc5235947" class="Index_20_Link"><span class="T6">Text.input &lt;svar&gt;{, { &lt;text_sexp&gt;} , &lt;title_sexp&gt; }</span></a><a href="#_Toc5235947" class="Index_20_Link"><span class="T4">        102</span></a></p><p class="Contents_20_3"><a href="#_Toc5235948" class="Index_20_Link">TGet &lt;result_svar&gt;, &lt;prompt_sexp&gt; {, &lt;title_sexp&gt;}</a><a href="#_Toc5235948" class="Index_20_Link"><span class="T4">        102</span></a></p><p class="Contents_20_3"><a href="#_Toc5235949" class="Index_20_Link">Kb.hide</a><a href="#_Toc5235949" class="Index_20_Link"><span class="T4">        102</span></a></p><p class="Contents_20_3"><a href="#_Toc5235950" class="Index_20_Link">Kb.show</a><a href="#_Toc5235950" class="Index_20_Link"><span class="T4">        103</span></a></p><p class="Contents_20_3"><a href="#_Toc5235951" class="Index_20_Link">Kb.toggle</a><a href="#_Toc5235951" class="Index_20_Link"><span class="T4">        103</span></a></p><p class="Contents_20_3"><a href="#_Toc5235952" class="Index_20_Link">Kb.showing &lt;lvar&gt;</a><a href="#_Toc5235952" class="Index_20_Link"><span class="T4">        103</span></a></p><p class="Contents_20_3"><a href="#_Toc5235953" class="Index_20_Link">OnKbChange:</a><a href="#_Toc5235953" class="Index_20_Link"><span class="T4">        103</span></a></p><p class="Contents_20_3"><a href="#_Toc5235954" class="Index_20_Link">Kb.resume</a><a href="#_Toc5235954" class="Index_20_Link"><span class="T4">        104</span></a></p><p class="Contents_20_3"><a href="#_Toc5235955" class="Index_20_Link">The Soft Keyboard and the BACK Key</a><a href="#_Toc5235955" class="Index_20_Link"><span class="T4">        104</span></a></p><p class="P15"><a href="#_Toc5235956" class="Index_20_Link">Working with Files</a><a href="#_Toc5235956" class="Index_20_Link"><span class="T4">        104</span></a></p><p class="Contents_20_2"><a href="#_Toc5235957" class="Index_20_Link">Paths Explained – a beginner’s guide</a><a href="#_Toc5235957" class="Index_20_Link"><span class="T4">        104</span></a></p><p class="Contents_20_2"><a href="#_Toc5235958" class="Index_20_Link">Paths in BASIC!</a><a href="#_Toc5235958" class="Index_20_Link"><span class="T4">        105</span></a></p><p class="Contents_20_2"><a href="#_Toc5235959" class="Index_20_Link">Paths Outside of BASIC!</a><a href="#_Toc5235959" class="Index_20_Link"><span class="T4">        105</span></a></p><p class="Contents_20_2"><a href="#_Toc5235960" class="Index_20_Link">Paths and Case-sensitivity</a><a href="#_Toc5235960" class="Index_20_Link"><span class="T4">        106</span></a></p><p class="Contents_20_2"><a href="#_Toc5235961" class="Index_20_Link">Mark and Mark Limit</a><a href="#_Toc5235961" class="Index_20_Link"><span class="T4">        106</span></a></p><p class="P15"><a href="#_Toc5235962" class="Index_20_Link">File Commands</a><a href="#_Toc5235962" class="Index_20_Link"><span class="T4">        107</span></a></p><p class="Contents_20_2"><a href="#_Toc5235963" class="Index_20_Link">File.delete &lt;lvar&gt;, &lt;path_sexp&gt;</a><a href="#_Toc5235963" class="Index_20_Link"><span class="T4">        107</span></a></p><p class="Contents_20_2"><a href="#_Toc5235964" class="Index_20_Link">File.dir &lt;path_sexp&gt;, Array$[] {,&lt;dirmark_sexp&gt;}</a><a href="#_Toc5235964" class="Index_20_Link"><span class="T4">        107</span></a></p><p class="Contents_20_2"><a href="#_Toc5235965" class="Index_20_Link">File.exists &lt;lvar&gt;, &lt;path_sexp&gt;</a><a href="#_Toc5235965" class="Index_20_Link"><span class="T4">        107</span></a></p><p class="Contents_20_2"><a href="#_Toc5235966" class="Index_20_Link">File.mkdir &lt;path_sexp&gt;</a><a href="#_Toc5235966" class="Index_20_Link"><span class="T4">        107</span></a></p><p class="Contents_20_2"><a href="#_Toc5235967" class="Index_20_Link">File.rename &lt;old_path_sexp&gt;, &lt;new_path_sexp&gt;</a><a href="#_Toc5235967" class="Index_20_Link"><span class="T4">        108</span></a></p><p class="Contents_20_2"><a href="#_Toc5235968" class="Index_20_Link">File.root &lt;svar&gt;</a><a href="#_Toc5235968" class="Index_20_Link"><span class="T4">        108</span></a></p><p class="Contents_20_2"><a href="#_Toc5235969" class="Index_20_Link">File.size &lt;size_nvar&gt;, &lt;path_sexp&gt;</a><a href="#_Toc5235969" class="Index_20_Link"><span class="T4">        108</span></a></p><p class="Contents_20_2"><a href="#_Toc5235970" class="Index_20_Link">File.type &lt;type_svar&gt;, &lt;path_sexp&gt;</a><a href="#_Toc5235970" class="Index_20_Link"><span class="T4">        108</span></a></p><p class="P15"><a href="#_Toc5235971" class="Index_20_Link">Text File I/O</a><a href="#_Toc5235971" class="Index_20_Link"><span class="T4">        109</span></a></p><p class="Contents_20_2"><a href="#_Toc5235972" class="Index_20_Link">Text.open {r|w|a}, &lt;file_table_nvar&gt;, &lt;path_sexp&gt;</a><a href="#_Toc5235972" class="Index_20_Link"><span class="T4">        109</span></a></p><p class="Contents_20_2"><a href="#_Toc5235973" class="Index_20_Link">Text.close &lt;file_table_nexp&gt;</a><a href="#_Toc5235973" class="Index_20_Link"><span class="T4">        109</span></a></p><p class="Contents_20_2"><a href="#_Toc5235974" class="Index_20_Link">Text.readln &lt;file_table_nexp&gt; {,&lt;svar&gt;}...</a><a href="#_Toc5235974" class="Index_20_Link"><span class="T4">        110</span></a></p><p class="Contents_20_2"><a href="#_Toc5235975" class="Index_20_Link">Text.writeln &lt;file_table_nexp&gt;, &lt;parms same as Print&gt;</a><a href="#_Toc5235975" class="Index_20_Link"><span class="T4">        110</span></a></p><p class="Contents_20_2"><a href="#_Toc5235976" class="Index_20_Link">Text.eof &lt;file_table_nexp&gt;, &lt;lvar&gt;</a><a href="#_Toc5235976" class="Index_20_Link"><span class="T4">        110</span></a></p><p class="Contents_20_2"><a href="#_Toc5235977" class="Index_20_Link">Text.position.get &lt;file_table_nexp&gt;, &lt;position_nvar&gt;</a><a href="#_Toc5235977" class="Index_20_Link"><span class="T4">        111</span></a></p><p class="Contents_20_2"><a href="#_Toc5235978" class="Index_20_Link">Text.position.set &lt;file_table_nexp&gt;, &lt;position_nexp&gt;</a><a href="#_Toc5235978" class="Index_20_Link"><span class="T4">        111</span></a></p><p class="Contents_20_2"><a href="#_Toc5235979" class="Index_20_Link">Text.position.mark {{&lt;file_table_nexp&gt;}{, &lt;marklimit_nexp&gt;}}</a><a href="#_Toc5235979" class="Index_20_Link"><span class="T4">        111</span></a></p><p class="Contents_20_2"><a href="#_Toc5235980" class="Index_20_Link">GrabURL &lt;result_svar&gt;, &lt;url_sexp&gt;{, &lt;timeout_nexp&gt;}</a><a href="#_Toc5235980" class="Index_20_Link"><span class="T4">        111</span></a></p><p class="Contents_20_2"><a href="#_Toc5235981" class="Index_20_Link">GrabFile &lt;result_svar&gt;, &lt;path_sexp&gt;{, &lt;unicode_flag_lexp&gt;}</a><a href="#_Toc5235981" class="Index_20_Link"><span class="T4">        112</span></a></p><p class="P15"><a href="#_Toc5235982" class="Index_20_Link">Byte File I/O</a><a href="#_Toc5235982" class="Index_20_Link"><span class="T4">        112</span></a></p><p class="Contents_20_2"><a href="#_Toc5235983" class="Index_20_Link">Byte.open {r|w|a}, &lt;file_table_nvar&gt;, &lt;path_sexp&gt;</a><a href="#_Toc5235983" class="Index_20_Link"><span class="T4">        112</span></a></p><p class="Contents_20_2"><a href="#_Toc5235984" class="Index_20_Link">Byte.close &lt;file_table_nexp&gt;</a><a href="#_Toc5235984" class="Index_20_Link"><span class="T4">        112</span></a></p><p class="Contents_20_2"><a href="#_Toc5235985" class="Index_20_Link">Byte.read.byte &lt;file_table_nexp&gt; {,&lt;nvar&gt;}...</a><a href="#_Toc5235985" class="Index_20_Link"><span class="T4">        113</span></a></p><p class="Contents_20_2"><a href="#_Toc5235986" class="Index_20_Link">Byte.write.byte &lt;file_table_nexp&gt; {{,&lt;nexp&gt;}...{,&lt;sexp&gt;}}</a><a href="#_Toc5235986" class="Index_20_Link"><span class="T4">        113</span></a></p><p class="Contents_20_2"><a href="#_Toc5235987" class="Index_20_Link">Byte.read.number &lt;file_table_nexp&gt; {,&lt;nvar&gt;...}</a><a href="#_Toc5235987" class="Index_20_Link"><span class="T4">        113</span></a></p><p class="Contents_20_2"><a href="#_Toc5235988" class="Index_20_Link">Byte.write.number &lt;file_table_nexp&gt; {,&lt;nexp&gt;}...</a><a href="#_Toc5235988" class="Index_20_Link"><span class="T4">        114</span></a></p><p class="Contents_20_2"><a href="#_Toc5235989" class="Index_20_Link">Byte.read.buffer &lt;file_table_nexp&gt;, &lt;count_nexp&gt;, &lt;buffer_svar&gt;</a><a href="#_Toc5235989" class="Index_20_Link"><span class="T4">        114</span></a></p><p class="Contents_20_2"><a href="#_Toc5235990" class="Index_20_Link">Byte.write.buffer &lt;file_table_nexp&gt;, &lt;buffer_sexp&gt;</a><a href="#_Toc5235990" class="Index_20_Link"><span class="T4">        114</span></a></p><p class="Contents_20_2"><a href="#_Toc5235991" class="Index_20_Link">Byte.eof &lt;file_table_nexp&gt;, &lt;lvar&gt;</a><a href="#_Toc5235991" class="Index_20_Link"><span class="T4">        114</span></a></p><p class="Contents_20_2"><a href="#_Toc5235992" class="Index_20_Link">Byte.position.get &lt;file_table_nexp&gt;, &lt;position_nvar&gt;</a><a href="#_Toc5235992" class="Index_20_Link"><span class="T4">        115</span></a></p><p class="Contents_20_2"><a href="#_Toc5235993" class="Index_20_Link">Byte.position.set &lt;file_table_nexp&gt;, &lt;position_nexp&gt;</a><a href="#_Toc5235993" class="Index_20_Link"><span class="T4">        115</span></a></p><p class="Contents_20_2"><a href="#_Toc5235994" class="Index_20_Link">Byte.position.mark {{&lt;file_table_nexp&gt;}{, &lt;marklimit_nexp&gt;}}</a><a href="#_Toc5235994" class="Index_20_Link"><span class="T4">        115</span></a></p><p class="Contents_20_2"><a href="#_Toc5235995" class="Index_20_Link">Byte.truncate &lt;file_table_nexp&gt;,&lt;length_nexp&gt;</a><a href="#_Toc5235995" class="Index_20_Link"><span class="T4">        115</span></a></p><p class="Contents_20_2"><a href="#_Toc5235996" class="Index_20_Link">Byte.copy &lt;file_table_nexp&gt;,&lt;output_file_sexp&gt;</a><a href="#_Toc5235996" class="Index_20_Link"><span class="T4">        115</span></a></p><p class="P15"><a href="#_Toc5235997" class="Index_20_Link">ZIP File I/O</a><a href="#_Toc5235997" class="Index_20_Link"><span class="T4">        116</span></a></p><p class="Contents_20_2"><a href="#_Toc5235998" class="Index_20_Link">Zip.count &lt;path_sexp&gt;, &lt;nvar&gt;</a><a href="#_Toc5235998" class="Index_20_Link"><span class="T4">        116</span></a></p><p class="Contents_20_2"><a href="#_Toc5235999" class="Index_20_Link">Zip.dir &lt;path_sexp&gt;, Array$[] {,&lt;dirmark_sexp&gt;}</a><a href="#_Toc5235999" class="Index_20_Link"><span class="T4">        116</span></a></p><p class="Contents_20_2"><a href="#_Toc5236000" class="Index_20_Link">Zip.open {r|w|a}, &lt;file_table_nvar&gt;, &lt;path_sexp&gt;</a><a href="#_Toc5236000" class="Index_20_Link"><span class="T4">        116</span></a></p><p class="Contents_20_2"><a href="#_Toc5236001" class="Index_20_Link">Zip.close &lt;file_table_nexp&gt;</a><a href="#_Toc5236001" class="Index_20_Link"><span class="T4">        117</span></a></p><p class="Contents_20_2"><a href="#_Toc5236002" class="Index_20_Link">Zip.read &lt;file_table_nexp&gt; ,&lt;buffer_svar&gt;, &lt;file_name_sexp&gt;</a><a href="#_Toc5236002" class="Index_20_Link"><span class="T4">        117</span></a></p><p class="Contents_20_2"><a href="#_Toc5236003" class="Index_20_Link">Zip.write &lt;file_table_nexp&gt; ,&lt;buffer_sexp&gt;, &lt;file_name_sexp&gt;</a><a href="#_Toc5236003" class="Index_20_Link"><span class="T4">        117</span></a></p><p class="P15"><a href="#_Toc5236004" class="Index_20_Link">HTML</a><a href="#_Toc5236004" class="Index_20_Link"><span class="T4">        117</span></a></p><p class="Contents_20_2"><a href="#_Toc5236005" class="Index_20_Link">Introduction</a><a href="#_Toc5236005" class="Index_20_Link"><span class="T4">        117</span></a></p><p class="Contents_20_2"><a href="#_Toc5236006" class="Index_20_Link">HTML Commands</a><a href="#_Toc5236006" class="Index_20_Link"><span class="T4">        118</span></a></p><p class="Contents_20_3"><a href="#_Toc5236007" class="Index_20_Link">Html.open {&lt;ShowStatusBar_lexp&gt; {, &lt;Orientation_nexp&gt;}}</a><a href="#_Toc5236007" class="Index_20_Link"><span class="T4">        118</span></a></p><p class="Contents_20_3"><a href="#_Toc5236008" class="Index_20_Link">Html.orientation &lt;nexp&gt;</a><a href="#_Toc5236008" class="Index_20_Link"><span class="T4">        118</span></a></p><p class="Contents_20_3"><a href="#_Toc5236009" class="Index_20_Link">Html.load.url &lt;file_sexp&gt;</a><a href="#_Toc5236009" class="Index_20_Link"><span class="T4">        118</span></a></p><p class="Contents_20_3"><a href="#_Toc5236010" class="Index_20_Link">Html.load.string &lt;html_sexp&gt;</a><a href="#_Toc5236010" class="Index_20_Link"><span class="T4">        119</span></a></p><p class="Contents_20_3"><a href="#_Toc5236011" class="Index_20_Link">Html.post &lt;url_sexp&gt;, &lt;list_nexp&gt;</a><a href="#_Toc5236011" class="Index_20_Link"><span class="T4">        119</span></a></p><p class="Contents_20_3"><a href="#_Toc5236012" class="Index_20_Link">Html.get.datalink &lt;data_svar&gt;</a><a href="#_Toc5236012" class="Index_20_Link"><span class="T4">        119</span></a></p><p class="Contents_20_3"><a href="#_Toc5236013" class="Index_20_Link">Html.go.back</a><a href="#_Toc5236013" class="Index_20_Link"><span class="T4">        120</span></a></p><p class="Contents_20_3"><a href="#_Toc5236014" class="Index_20_Link">Html.go.forward</a><a href="#_Toc5236014" class="Index_20_Link"><span class="T4">        120</span></a></p><p class="Contents_20_3"><a href="#_Toc5236015" class="Index_20_Link">Html.close</a><a href="#_Toc5236015" class="Index_20_Link"><span class="T4">        120</span></a></p><p class="Contents_20_3"><a href="#_Toc5236016" class="Index_20_Link">Html.clear.cache</a><a href="#_Toc5236016" class="Index_20_Link"><span class="T4">        120</span></a></p><p class="Contents_20_3"><a href="#_Toc5236017" class="Index_20_Link">Html.clear.history</a><a href="#_Toc5236017" class="Index_20_Link"><span class="T4">        120</span></a></p><p class="Contents_20_2"><a href="#_Toc5236018" class="Index_20_Link">Related Commands</a><a href="#_Toc5236018" class="Index_20_Link"><span class="T4">        120</span></a></p><p class="Contents_20_3"><a href="#_Toc5236019" class="Index_20_Link">Browse &lt;url_sexp&gt;</a><a href="#_Toc5236019" class="Index_20_Link"><span class="T4">        120</span></a></p><p class="Contents_20_3"><a href="#_Toc5236020" class="Index_20_Link">Http.post &lt;url_sexp&gt;, &lt;list_nexp&gt;, &lt;result_svar&gt;</a><a href="#_Toc5236020" class="Index_20_Link"><span class="T4">        121</span></a></p><p class="P15"><a href="#_Toc5236021" class="Index_20_Link">TCP/IP Sockets</a><a href="#_Toc5236021" class="Index_20_Link"><span class="T4">        121</span></a></p><p class="Contents_20_2"><a href="#_Toc5236022" class="Index_20_Link">TCP/IP Client Socket Commands</a><a href="#_Toc5236022" class="Index_20_Link"><span class="T4">        122</span></a></p><p class="Contents_20_3"><a href="#_Toc5236023" class="Index_20_Link">Socket.client.connect &lt;server_sexp&gt;, &lt;port_nexp&gt; { , &lt;wait_lexp&gt; }</a><a href="#_Toc5236023" class="Index_20_Link"><span class="T4">        122</span></a></p><p class="Contents_20_3"><a href="#_Toc5236024" class="Index_20_Link">Socket.client.status &lt;status_nvar&gt;</a><a href="#_Toc5236024" class="Index_20_Link"><span class="T4">        122</span></a></p><p class="Contents_20_3"><a href="#_Toc5236025" class="Index_20_Link">Socket.client.server.ip &lt;svar&gt;</a><a href="#_Toc5236025" class="Index_20_Link"><span class="T4">        122</span></a></p><p class="Contents_20_3"><a href="#_Toc5236026" class="Index_20_Link">Socket.client.read.line &lt;line_svar&gt;</a><a href="#_Toc5236026" class="Index_20_Link"><span class="T4">        122</span></a></p><p class="Contents_20_3"><a href="#_Toc5236027" class="Index_20_Link">Socket.client.read.ready &lt;nvar&gt;</a><a href="#_Toc5236027" class="Index_20_Link"><span class="T4">        122</span></a></p><p class="Contents_20_3"><a href="#_Toc5236028" class="Index_20_Link">Socket.client.read.file &lt;file_nexp&gt;</a><a href="#_Toc5236028" class="Index_20_Link"><span class="T4">        122</span></a></p><p class="Contents_20_3"><a href="#_Toc5236029" class="Index_20_Link">Socket.client.write.line &lt;line_sexp&gt;</a><a href="#_Toc5236029" class="Index_20_Link"><span class="T4">        123</span></a></p><p class="Contents_20_3"><a href="#_Toc5236030" class="Index_20_Link">Socket.client.write.bytes &lt;sexp&gt;</a><a href="#_Toc5236030" class="Index_20_Link"><span class="T4">        123</span></a></p><p class="Contents_20_3"><a href="#_Toc5236031" class="Index_20_Link">Socket.client.write.file &lt;file_nexp&gt;</a><a href="#_Toc5236031" class="Index_20_Link"><span class="T4">        123</span></a></p><p class="Contents_20_3"><a href="#_Toc5236032" class="Index_20_Link">Socket.client.close</a><a href="#_Toc5236032" class="Index_20_Link"><span class="T4">        123</span></a></p><p class="Contents_20_2"><a href="#_Toc5236033" class="Index_20_Link">TCP/IP Server Socket Commands</a><a href="#_Toc5236033" class="Index_20_Link"><span class="T4">        123</span></a></p><p class="Contents_20_3"><a href="#_Toc5236034" class="Index_20_Link">Socket.myIP &lt;svar&gt;</a><a href="#_Toc5236034" class="Index_20_Link"><span class="T4">        123</span></a></p><p class="Contents_20_3"><a href="#_Toc5236035" class="Index_20_Link">Socket.myIP &lt;array$[]&gt;{, &lt;nvar&gt;}</a><a href="#_Toc5236035" class="Index_20_Link"><span class="T4">        123</span></a></p><p class="Contents_20_3"><a href="#_Toc5236036" class="Index_20_Link">Socket.server.create &lt;port_nexp&gt;</a><a href="#_Toc5236036" class="Index_20_Link"><span class="T4">        124</span></a></p><p class="Contents_20_3"><a href="#_Toc5236037" class="Index_20_Link">Socket.server.connect {&lt;wait_lexp&gt;}</a><a href="#_Toc5236037" class="Index_20_Link"><span class="T4">        124</span></a></p><p class="Contents_20_3"><a href="#_Toc5236038" class="Index_20_Link">Socket.server.status &lt;status_nvar&gt;</a><a href="#_Toc5236038" class="Index_20_Link"><span class="T4">        124</span></a></p><p class="Contents_20_3"><a href="#_Toc5236039" class="Index_20_Link">Socket.server.read.line &lt;svar&gt;</a><a href="#_Toc5236039" class="Index_20_Link"><span class="T4">        124</span></a></p><p class="Contents_20_3"><a href="#_Toc5236040" class="Index_20_Link">Socket.server.read.ready &lt;nvar&gt;</a><a href="#_Toc5236040" class="Index_20_Link"><span class="T4">        124</span></a></p><p class="Contents_20_3"><a href="#_Toc5236041" class="Index_20_Link">Socket.server.write.line &lt;line_sexp&gt;</a><a href="#_Toc5236041" class="Index_20_Link"><span class="T4">        124</span></a></p><p class="Contents_20_3"><a href="#_Toc5236042" class="Index_20_Link">Socket.server.write.bytes &lt;sexp&gt;</a><a href="#_Toc5236042" class="Index_20_Link"><span class="T4">        124</span></a></p><p class="Contents_20_3"><a href="#_Toc5236043" class="Index_20_Link">Socket.server.write.file &lt;file_nexp&gt;</a><a href="#_Toc5236043" class="Index_20_Link"><span class="T4">        125</span></a></p><p class="Contents_20_3"><a href="#_Toc5236044" class="Index_20_Link">Socket.server.read.file &lt;file_nexp&gt;</a><a href="#_Toc5236044" class="Index_20_Link"><span class="T4">        125</span></a></p><p class="Contents_20_3"><a href="#_Toc5236045" class="Index_20_Link">Socket.server.disconnect</a><a href="#_Toc5236045" class="Index_20_Link"><span class="T4">        125</span></a></p><p class="Contents_20_3"><a href="#_Toc5236046" class="Index_20_Link">Socket.server.close</a><a href="#_Toc5236046" class="Index_20_Link"><span class="T4">        125</span></a></p><p class="Contents_20_3"><a href="#_Toc5236047" class="Index_20_Link">Socket.server.client.ip &lt;nvar&gt;</a><a href="#_Toc5236047" class="Index_20_Link"><span class="T4">        125</span></a></p><p class="P15"><a href="#_Toc5236048" class="Index_20_Link">FTP Client</a><a href="#_Toc5236048" class="Index_20_Link"><span class="T4">        125</span></a></p><p class="Contents_20_2"><a href="#_Toc5236049" class="Index_20_Link">Ftp.open &lt;url_sexp&gt;, &lt;port_nexp&gt;, &lt;user_sexp&gt;, &lt;pw_sexp&gt;</a><a href="#_Toc5236049" class="Index_20_Link"><span class="T4">        125</span></a></p><p class="Contents_20_2"><a href="#_Toc5236050" class="Index_20_Link">Ftp.close</a><a href="#_Toc5236050" class="Index_20_Link"><span class="T4">        125</span></a></p><p class="Contents_20_2"><a href="#_Toc5236051" class="Index_20_Link">Ftp.put &lt;source_sexp&gt;, &lt;destination_sexp&gt;</a><a href="#_Toc5236051" class="Index_20_Link"><span class="T4">        125</span></a></p><p class="Contents_20_2"><a href="#_Toc5236052" class="Index_20_Link">Ftp.get &lt;source_sexp&gt;, &lt;destination_sexp&gt;</a><a href="#_Toc5236052" class="Index_20_Link"><span class="T4">        126</span></a></p><p class="Contents_20_2"><a href="#_Toc5236053" class="Index_20_Link">Ftp.dir &lt;list_nvar&gt; {,&lt;dirmark_sexp&gt;}</a><a href="#_Toc5236053" class="Index_20_Link"><span class="T4">        126</span></a></p><p class="Contents_20_2"><a href="#_Toc5236054" class="Index_20_Link">Ftp.cd &lt;new_directory_sexp&gt;</a><a href="#_Toc5236054" class="Index_20_Link"><span class="T4">        126</span></a></p><p class="Contents_20_2"><a href="#_Toc5236055" class="Index_20_Link">Ftp.rename &lt;old_filename_sexp&gt;, &lt;new_filename_sexp&gt;</a><a href="#_Toc5236055" class="Index_20_Link"><span class="T4">        126</span></a></p><p class="Contents_20_2"><a href="#_Toc5236056" class="Index_20_Link">Ftp.delete &lt;filename_sexp&gt;</a><a href="#_Toc5236056" class="Index_20_Link"><span class="T4">        126</span></a></p><p class="Contents_20_2"><a href="#_Toc5236057" class="Index_20_Link">Ftp.rmdir &lt;directory_sexp&gt;</a><a href="#_Toc5236057" class="Index_20_Link"><span class="T4">        127</span></a></p><p class="Contents_20_2"><a href="#_Toc5236058" class="Index_20_Link">Ftp.mkdir &lt;directory_sexp&gt;</a><a href="#_Toc5236058" class="Index_20_Link"><span class="T4">        127</span></a></p><p class="P15"><a href="#_Toc5236059" class="Index_20_Link">Bluetooth</a><a href="#_Toc5236059" class="Index_20_Link"><span class="T4">        127</span></a></p><p class="Contents_20_2"><a href="#_Toc5236060" class="Index_20_Link">Bt.open {0|1}</a><a href="#_Toc5236060" class="Index_20_Link"><span class="T4">        127</span></a></p><p class="Contents_20_2"><a href="#_Toc5236061" class="Index_20_Link">Bt.close</a><a href="#_Toc5236061" class="Index_20_Link"><span class="T4">        128</span></a></p><p class="Contents_20_2"><a href="#_Toc5236062" class="Index_20_Link">Bt.connect {0|1}</a><a href="#_Toc5236062" class="Index_20_Link"><span class="T4">        128</span></a></p><p class="Contents_20_2"><a href="#_Toc5236063" class="Index_20_Link">Bt.disconnect</a><a href="#_Toc5236063" class="Index_20_Link"><span class="T4">        128</span></a></p><p class="Contents_20_2"><a href="#_Toc5236064" class="Index_20_Link">Bt.reconnect</a><a href="#_Toc5236064" class="Index_20_Link"><span class="T4">        128</span></a></p><p class="Contents_20_2"><a href="#_Toc5236065" class="Index_20_Link">Bt.status {{&lt;connect_var&gt;}{, &lt;name_svar&gt;}{, &lt;address_svar&gt;}}</a><a href="#_Toc5236065" class="Index_20_Link"><span class="T4">        128</span></a></p><p class="Contents_20_2"><a href="#_Toc5236066" class="Index_20_Link">Bt.write {&lt;exp&gt; {,|;}} ...</a><a href="#_Toc5236066" class="Index_20_Link"><span class="T4">        129</span></a></p><p class="Contents_20_2"><a href="#_Toc5236067" class="Index_20_Link">Bt.read.ready &lt;nvar&gt;</a><a href="#_Toc5236067" class="Index_20_Link"><span class="T4">        129</span></a></p><p class="Contents_20_2"><a href="#_Toc5236068" class="Index_20_Link">OnBtReadReady:</a><a href="#_Toc5236068" class="Index_20_Link"><span class="T4">        129</span></a></p><p class="Contents_20_3"><a href="#_Toc5236069" class="Index_20_Link">Bt.onReadReady.resume</a><a href="#_Toc5236069" class="Index_20_Link"><span class="T4">        129</span></a></p><p class="Contents_20_2"><a href="#_Toc5236070" class="Index_20_Link">Bt.read.bytes &lt;svar&gt;</a><a href="#_Toc5236070" class="Index_20_Link"><span class="T4">        130</span></a></p><p class="Contents_20_2"><a href="#_Toc5236071" class="Index_20_Link">Bt.device.name &lt;svar&gt;</a><a href="#_Toc5236071" class="Index_20_Link"><span class="T4">        130</span></a></p><p class="Contents_20_2"><a href="#_Toc5236072" class="Index_20_Link">Bt.set.UUID &lt;sexp&gt;</a><a href="#_Toc5236072" class="Index_20_Link"><span class="T4">        130</span></a></p><p class="P15"><a href="#_Toc5236073" class="Index_20_Link">Communication: Phone and Text</a><a href="#_Toc5236073" class="Index_20_Link"><span class="T4">        130</span></a></p><p class="Contents_20_2"><a href="#_Toc5236074" class="Index_20_Link">Email.send &lt;recipient_sexp&gt;, &lt;subject_sexp&gt;, &lt;body_sexp&gt;</a><a href="#_Toc5236074" class="Index_20_Link"><span class="T4">        130</span></a></p><p class="Contents_20_2"><a href="#_Toc5236075" class="Index_20_Link">MyPhoneNumber &lt;svar&gt;</a><a href="#_Toc5236075" class="Index_20_Link"><span class="T4">        130</span></a></p><p class="Contents_20_2"><a href="#_Toc5236076" class="Index_20_Link">Phone.call &lt;sexp&gt;</a><a href="#_Toc5236076" class="Index_20_Link"><span class="T4">        130</span></a></p><p class="Contents_20_2"><a href="#_Toc5236077" class="Index_20_Link">Phone.dial &lt;sexp&gt;</a><a href="#_Toc5236077" class="Index_20_Link"><span class="T4">        131</span></a></p><p class="Contents_20_2"><a href="#_Toc5236078" class="Index_20_Link">Phone.rcv.init</a><a href="#_Toc5236078" class="Index_20_Link"><span class="T4">        131</span></a></p><p class="Contents_20_2"><a href="#_Toc5236079" class="Index_20_Link">Phone.rcv.next &lt;state_nvar&gt;, &lt;number_svar&gt;</a><a href="#_Toc5236079" class="Index_20_Link"><span class="T4">        131</span></a></p><p class="Contents_20_2"><a href="#_Toc5236080" class="Index_20_Link">Note on Sms Commands</a><a href="#_Toc5236080" class="Index_20_Link"><span class="T4">        131</span></a></p><p class="Contents_20_2"><a href="#_Toc5236081" class="Index_20_Link">Sms.send &lt;number_sexp&gt;, &lt;message_sexp&gt;</a><a href="#_Toc5236081" class="Index_20_Link"><span class="T4">        131</span></a></p><p class="Contents_20_2"><a href="#_Toc5236082" class="Index_20_Link">Sms.rcv.init</a><a href="#_Toc5236082" class="Index_20_Link"><span class="T4">        131</span></a></p><p class="Contents_20_2"><a href="#_Toc5236083" class="Index_20_Link">Sms.rcv.next &lt;svar&gt;</a><a href="#_Toc5236083" class="Index_20_Link"><span class="T4">        132</span></a></p><p class="P15"><a href="#_Toc5236084" class="Index_20_Link">Time and Timers</a><a href="#_Toc5236084" class="Index_20_Link"><span class="T4">        132</span></a></p><p class="Contents_20_2"><a href="#_Toc5236085" class="Index_20_Link">Time and TimeZone Commands</a><a href="#_Toc5236085" class="Index_20_Link"><span class="T4">        132</span></a></p><p class="Contents_20_3"><a href="#_Toc5236086" class="Index_20_Link">Time {&lt;time_nexp&gt;,} Year$, Month$, Day$, Hour$, Minute$, Second$, WeekDay, isDST</a><a href="#_Toc5236086" class="Index_20_Link"><span class="T4">        132</span></a></p><p class="Contents_20_3"><a href="#_Toc5236087" class="Index_20_Link">TimeZone.set { &lt;tz_sexp&gt; }</a><a href="#_Toc5236087" class="Index_20_Link"><span class="T4">        133</span></a></p><p class="Contents_20_3"><a href="#_Toc5236088" class="Index_20_Link">TimeZone.get &lt;tz_svar&gt;</a><a href="#_Toc5236088" class="Index_20_Link"><span class="T4">        133</span></a></p><p class="Contents_20_3"><a href="#_Toc5236089" class="Index_20_Link">TimeZone.list &lt;tz_list_pointer_nexp&gt;</a><a href="#_Toc5236089" class="Index_20_Link"><span class="T4">        133</span></a></p><p class="Contents_20_2"><a href="#_Toc5236090" class="Index_20_Link">Timer Interrupt and Commands</a><a href="#_Toc5236090" class="Index_20_Link"><span class="T4">        133</span></a></p><p class="Contents_20_3"><a href="#_Toc5236091" class="Index_20_Link">Timer.set &lt;interval_nexp&gt;</a><a href="#_Toc5236091" class="Index_20_Link"><span class="T4">        134</span></a></p><p class="Contents_20_3"><a href="#_Toc5236092" class="Index_20_Link">OnTimer:</a><a href="#_Toc5236092" class="Index_20_Link"><span class="T4">        134</span></a></p><p class="Contents_20_3"><a href="#_Toc5236093" class="Index_20_Link">Timer.resume</a><a href="#_Toc5236093" class="Index_20_Link"><span class="T4">        134</span></a></p><p class="Contents_20_3"><a href="#_Toc5236094" class="Index_20_Link">Timer.clear</a><a href="#_Toc5236094" class="Index_20_Link"><span class="T4">        134</span></a></p><p class="Contents_20_3"><a href="#_Toc5236095" class="Index_20_Link">Sample Code</a><a href="#_Toc5236095" class="Index_20_Link"><span class="T4">        134</span></a></p><p class="P15"><a href="#_Toc5236096" class="Index_20_Link">Clipboard</a><a href="#_Toc5236096" class="Index_20_Link"><span class="T4">        134</span></a></p><p class="Contents_20_2"><a href="#_Toc5236097" class="Index_20_Link">Clipboard.get &lt;svar&gt;</a><a href="#_Toc5236097" class="Index_20_Link"><span class="T4">        134</span></a></p><p class="Contents_20_2"><a href="#_Toc5236098" class="Index_20_Link">Clipboard.put &lt;sexp&gt;</a><a href="#_Toc5236098" class="Index_20_Link"><span class="T4">        134</span></a></p><p class="P15"><a href="#_Toc5236099" class="Index_20_Link">Encryption</a><a href="#_Toc5236099" class="Index_20_Link"><span class="T4">        134</span></a></p><p class="Contents_20_2"><a href="#_Toc5236100" class="Index_20_Link">Encrypt {&lt;pw_sexp&gt;}, &lt;source_sexp&gt;, &lt;encrypted_svar&gt;</a><a href="#_Toc5236100" class="Index_20_Link"><span class="T4">        134</span></a></p><p class="Contents_20_2"><a href="#_Toc5236101" class="Index_20_Link">Decrypt &lt;pw_sexp&gt;, &lt;encrypted_sexp&gt;, &lt;decrypted_svar&gt;</a><a href="#_Toc5236101" class="Index_20_Link"><span class="T4">        135</span></a></p><p class="P15"><a href="#_Toc5236102" class="Index_20_Link">Ringer</a><a href="#_Toc5236102" class="Index_20_Link"><span class="T4">        135</span></a></p><p class="Contents_20_2"><a href="#_Toc5236103" class="Index_20_Link">Ringer.get.mode &lt;nvar&gt;</a><a href="#_Toc5236103" class="Index_20_Link"><span class="T4">        135</span></a></p><p class="Contents_20_2"><a href="#_Toc5236104" class="Index_20_Link">Ringer.set.mode &lt;nexp&gt;</a><a href="#_Toc5236104" class="Index_20_Link"><span class="T4">        135</span></a></p><p class="Contents_20_2"><a href="#_Toc5236105" class="Index_20_Link">Ringer.get.volume &lt;vol_nvar&gt; { , &lt;max_nvar&gt; }</a><a href="#_Toc5236105" class="Index_20_Link"><span class="T4">        136</span></a></p><p class="Contents_20_2"><a href="#_Toc5236106" class="Index_20_Link">Ringer.set.volume &lt;nexp&gt;</a><a href="#_Toc5236106" class="Index_20_Link"><span class="T4">        136</span></a></p><p class="P15"><a href="#_Toc5236107" class="Index_20_Link">String Operations</a><a href="#_Toc5236107" class="Index_20_Link"><span class="T4">        136</span></a></p><p class="Contents_20_2"><a href="#_Toc5236108" class="Index_20_Link">Join &lt;source_array$[]&gt;, &lt;result_svar&gt; {, &lt;separator_sexp&gt;{, &lt;wrapper_sexp}}</a><a href="#_Toc5236108" class="Index_20_Link"><span class="T4">        136</span></a></p><p class="Contents_20_2"><a href="#_Toc5236109" class="Index_20_Link">Join.all &lt;source_array$[]&gt;, &lt;result_svar&gt; {, &lt;separator_sexp&gt;{, &lt;wrapper_sexp}}</a><a href="#_Toc5236109" class="Index_20_Link"><span class="T4">        136</span></a></p><p class="Contents_20_2"><a href="#_Toc5236110" class="Index_20_Link">Split &lt;result_array$[]&gt;, &lt;sexp&gt; {, &lt;test_sexp&gt;}</a><a href="#_Toc5236110" class="Index_20_Link"><span class="T4">        137</span></a></p><p class="Contents_20_2"><a href="#_Toc5236111" class="Index_20_Link">Split.all &lt;result_array$[]&gt;, &lt;sexp&gt; {, &lt;test_sexp&gt;}</a><a href="#_Toc5236111" class="Index_20_Link"><span class="T4">        137</span></a></p><p class="P15"><a href="#_Toc5236112" class="Index_20_Link">Speech Conversion</a><a href="#_Toc5236112" class="Index_20_Link"><span class="T4">        137</span></a></p><p class="Contents_20_2"><a href="#_Toc5236113" class="Index_20_Link">Text To Speech</a><a href="#_Toc5236113" class="Index_20_Link"><span class="T4">        137</span></a></p><p class="Contents_20_3"><a href="#_Toc5236114" class="Index_20_Link">TTS.init</a><a href="#_Toc5236114" class="Index_20_Link"><span class="T4">        138</span></a></p><p class="Contents_20_3"><a href="#_Toc5236115" class="Index_20_Link">TTS.speak &lt;sexp&gt; {, &lt;wait_lexp&gt;}</a><a href="#_Toc5236115" class="Index_20_Link"><span class="T4">        138</span></a></p><p class="Contents_20_3"><a href="#_Toc5236116" class="Index_20_Link">TTS.speak.toFile &lt;sexp&gt; {, &lt;path_sexp&gt;}</a><a href="#_Toc5236116" class="Index_20_Link"><span class="T4">        138</span></a></p><p class="Contents_20_3"><a href="#_Toc5236117" class="Index_20_Link">TTS.stop</a><a href="#_Toc5236117" class="Index_20_Link"><span class="T4">        138</span></a></p><p class="Contents_20_2"><a href="#_Toc5236118" class="Index_20_Link">Speech To Text (Voice Recognition)</a><a href="#_Toc5236118" class="Index_20_Link"><span class="T4">        138</span></a></p><p class="Contents_20_3"><a href="#_Toc5236119" class="Index_20_Link">STT.listen {&lt;prompt_sexp&gt;}</a><a href="#_Toc5236119" class="Index_20_Link"><span class="T4">        139</span></a></p><p class="Contents_20_3"><a href="#_Toc5236120" class="Index_20_Link">STT.results &lt;string_list_ptr_nexp&gt;</a><a href="#_Toc5236120" class="Index_20_Link"><span class="T4">        139</span></a></p><p class="P15"><a href="#_Toc5236121" class="Index_20_Link">Information About Your Android Device</a><a href="#_Toc5236121" class="Index_20_Link"><span class="T4">        140</span></a></p><p class="Contents_20_2"><a href="#_Toc5236122" class="Index_20_Link">Device Command Overview</a><a href="#_Toc5236122" class="Index_20_Link"><span class="T4">        140</span></a></p><p class="Contents_20_3"><a href="#_Toc5236123" class="Index_20_Link">Device &lt;svar&gt;</a><a href="#_Toc5236123" class="Index_20_Link"><span class="T4">        141</span></a></p><p class="Contents_20_3"><a href="#_Toc5236124" class="Index_20_Link">Device &lt;nexp&gt;|&lt;nvar&gt;</a><a href="#_Toc5236124" class="Index_20_Link"><span class="T4">        142</span></a></p><p class="Contents_20_3"><a href="#_Toc5236125" class="Index_20_Link">Device.Language &lt;svar&gt;</a><a href="#_Toc5236125" class="Index_20_Link"><span class="T4">        142</span></a></p><p class="Contents_20_3"><a href="#_Toc5236126" class="Index_20_Link">Device. Locale &lt;svar&gt;</a><a href="#_Toc5236126" class="Index_20_Link"><span class="T4">        142</span></a></p><p class="Contents_20_2"><a href="#_Toc5236127" class="Index_20_Link">Phone.info &lt;nexp&gt;|&lt;nvar&gt;</a><a href="#_Toc5236127" class="Index_20_Link"><span class="T4">        142</span></a></p><p class="Contents_20_2"><a href="#_Toc5236128" class="Index_20_Link">Screen rotation, size[], realsize[], density</a><a href="#_Toc5236128" class="Index_20_Link"><span class="T4">        143</span></a></p><p class="Contents_20_2"><a href="#_Toc5236129" class="Index_20_Link">Screen.rotation &lt;nvar&gt;</a><a href="#_Toc5236129" class="Index_20_Link"><span class="T4">        144</span></a></p><p class="Contents_20_2"><a href="#_Toc5236130" class="Index_20_Link">Screen.size, size[], realsize[], density</a><a href="#_Toc5236130" class="Index_20_Link"><span class="T4">        144</span></a></p><p class="Contents_20_2"><a href="#_Toc5236131" class="Index_20_Link">WiFi.info {{&lt;SSID_svar&gt;}{, &lt;BSSID_svar&gt;}{, &lt;MAC_svar&gt;}{, &lt;IP_var&gt;}{, &lt;speed_nvar&gt;}}</a><a href="#_Toc5236131" class="Index_20_Link"><span class="T4">        145</span></a></p><p class="P15"><a href="#_Toc5236132" class="Index_20_Link">Running in the Background</a><a href="#_Toc5236132" class="Index_20_Link"><span class="T4">        145</span></a></p><p class="Contents_20_2"><a href="#_Toc5236133" class="Index_20_Link">Home</a><a href="#_Toc5236133" class="Index_20_Link"><span class="T4">        145</span></a></p><p class="Contents_20_2"><a href="#_Toc5236134" class="Index_20_Link">OnBackground:</a><a href="#_Toc5236134" class="Index_20_Link"><span class="T4">        145</span></a></p><p class="Contents_20_3"><a href="#_Toc5236135" class="Index_20_Link">Background.resume</a><a href="#_Toc5236135" class="Index_20_Link"><span class="T4">        145</span></a></p><p class="Contents_20_2"><a href="#_Toc5236136" class="Index_20_Link">WakeLock &lt;code_nexp&gt;{, &lt;flags_nexp&gt;}</a><a href="#_Toc5236136" class="Index_20_Link"><span class="T4">        145</span></a></p><p class="Contents_20_2"><a href="#_Toc5236137" class="Index_20_Link">WifiLock &lt;code_nexp&gt;</a><a href="#_Toc5236137" class="Index_20_Link"><span class="T4">        146</span></a></p><p class="P15"><a href="#_Toc5236138" class="Index_20_Link">Miscellaneous Commands</a><a href="#_Toc5236138" class="Index_20_Link"><span class="T4">        147</span></a></p><p class="Contents_20_2"><a href="#_Toc5236139" class="Index_20_Link">Headset &lt;state_nvar&gt;, &lt;type_svar&gt;, &lt;mic_nvar&gt;</a><a href="#_Toc5236139" class="Index_20_Link"><span class="T4">        147</span></a></p><p class="Contents_20_2"><a href="#_Toc5236140" class="Index_20_Link">Notify &lt;title_sexp&gt;, &lt;subtitle_sexp&gt;, &lt;alert_sexp&gt;, &lt;wait_lexp&gt;</a><a href="#_Toc5236140" class="Index_20_Link"><span class="T4">        147</span></a></p><p class="Contents_20_2"><a href="#_Toc5236141" class="Index_20_Link">Pause &lt;ticks_nexp&gt;</a><a href="#_Toc5236141" class="Index_20_Link"><span class="T4">        148</span></a></p><p class="Contents_20_2"><a href="#_Toc5236142" class="Index_20_Link">Swap &lt;nvar_a&gt;|&lt;svar_a&gt;, &lt;nvar_b&gt;|&lt;svar_b&gt;</a><a href="#_Toc5236142" class="Index_20_Link"><span class="T4">        148</span></a></p><p class="Contents_20_2"><a href="#_Toc5236143" class="Index_20_Link">Tone &lt;frequency_nexp&gt;, &lt;duration_nexp&gt; {, &lt;duration_chk_lexp}</a><a href="#_Toc5236143" class="Index_20_Link"><span class="T4">        148</span></a></p><p class="Contents_20_2"><a href="#_Toc5236144" class="Index_20_Link">Vibrate &lt;pattern_array[{&lt;start&gt;,&lt;length&gt;}]&gt;,&lt;nexp&gt;</a><a href="#_Toc5236144" class="Index_20_Link"><span class="T4">        149</span></a></p><p class="Contents_20_2"><a href="#_Toc5236145" class="Index_20_Link">VolKeys</a><a href="#_Toc5236145" class="Index_20_Link"><span class="T4">        149</span></a></p><p class="Contents_20_3"><a href="#_Toc5236146" class="Index_20_Link">VolKeys.off</a><a href="#_Toc5236146" class="Index_20_Link"><span class="T4">        149</span></a></p><p class="Contents_20_3"><a href="#_Toc5236147" class="Index_20_Link">VolKeys.on</a><a href="#_Toc5236147" class="Index_20_Link"><span class="T4">        149</span></a></p><p class="P15"><a href="#_Toc5236148" class="Index_20_Link">SQLITE</a><a href="#_Toc5236148" class="Index_20_Link"><span class="T4">        150</span></a></p><p class="Contents_20_2"><a href="#_Toc5236149" class="Index_20_Link">Overview</a><a href="#_Toc5236149" class="Index_20_Link"><span class="T4">        150</span></a></p><p class="Contents_20_2"><a href="#_Toc5236150" class="Index_20_Link">SQLITE Commands</a><a href="#_Toc5236150" class="Index_20_Link"><span class="T4">        150</span></a></p><p class="Contents_20_3"><a href="#_Toc5236151" class="Index_20_Link">Sql.open &lt;DB_pointer_nvar&gt;, &lt;DB_name_sexp&gt;</a><a href="#_Toc5236151" class="Index_20_Link"><span class="T4">        150</span></a></p><p class="Contents_20_3"><a href="#_Toc5236152" class="Index_20_Link">Sql.close &lt;DB_pointer_nvar&gt;</a><a href="#_Toc5236152" class="Index_20_Link"><span class="T4">        150</span></a></p><p class="Contents_20_3"><a href="#_Toc5236153" class="Index_20_Link">Sql.new_table &lt;DB_pointer_nvar&gt;, &lt;table_name_sexp&gt;, C1$, C2$, ...,CN$</a><a href="#_Toc5236153" class="Index_20_Link"><span class="T4">        150</span></a></p><p class="Contents_20_3"><a href="#_Toc5236154" class="Index_20_Link">Sql.drop_table &lt;DB_pointer_nvar&gt;, &lt;table_name_sexp&gt;</a><a href="#_Toc5236154" class="Index_20_Link"><span class="T4">        151</span></a></p><p class="Contents_20_3"><a href="#_Toc5236155" class="Index_20_Link">Sql.insert &lt;DB_pointer_nvar&gt;, &lt;table_name_sexp&gt;, C1$, V1$, C2$, V2$, ..., CN$, VN$</a><a href="#_Toc5236155" class="Index_20_Link"><span class="T4">        151</span></a></p><p class="Contents_20_3"><a href="#_Toc5236156" class="Index_20_Link">Sql.query &lt;cursor_nvar&gt;, &lt;DB_pointer_nvar&gt;, &lt;table_name_sexp&gt;, &lt;columns_sexp&gt; {, &lt;where_sexp&gt; {, &lt;order_sexp&gt;} }</a><a href="#_Toc5236156" class="Index_20_Link"><span class="T4">        151</span></a></p><p class="Contents_20_3"><a href="#_Toc5236157" class="Index_20_Link">Sql.query.length &lt;length_nvar&gt;, &lt;cursor_nvar&gt;</a><a href="#_Toc5236157" class="Index_20_Link"><span class="T4">        152</span></a></p><p class="Contents_20_3"><a href="#_Toc5236158" class="Index_20_Link">Sql.query.position &lt;position_nvar&gt;, &lt;cursor_nvar&gt;</a><a href="#_Toc5236158" class="Index_20_Link"><span class="T4">        152</span></a></p><p class="Contents_20_3"><a href="#_Toc5236159" class="Index_20_Link">Sql.next &lt;done_lvar&gt;, &lt;cursor_nvar&gt;{, &lt;cv_svars&gt;}</a><a href="#_Toc5236159" class="Index_20_Link"><span class="T4">        152</span></a></p><p class="Contents_20_3"><a href="#_Toc5236160" class="Index_20_Link">Sql.delete &lt;DB_pointer_nvar&gt;, &lt;table_name_sexp&gt;{,&lt;where_sexp&gt;{,&lt;count_nvar&gt;} }</a><a href="#_Toc5236160" class="Index_20_Link"><span class="T4">        153</span></a></p><p class="Contents_20_3"><a href="#_Toc5236161" class="Index_20_Link">Sql.update &lt;DB_pointer_nvar&gt;, &lt;table_name_sexp&gt;, C1$, V1$, C2$, V2$,...,CN$, VN${: &lt;where_sexp&gt;}</a><a href="#_Toc5236161" class="Index_20_Link"><span class="T4">        153</span></a></p><p class="Contents_20_3"><a href="#_Toc5236162" class="Index_20_Link">Sql.exec &lt;DB_pointer_nvar&gt;, &lt;command_sexp&gt;</a><a href="#_Toc5236162" class="Index_20_Link"><span class="T4">        153</span></a></p><p class="Contents_20_3"><a href="#_Toc5236163" class="Index_20_Link">Sql.raw_query &lt;cursor_nvar&gt;, &lt;DB_pointer_nvar&gt;, &lt;query_sexp&gt;</a><a href="#_Toc5236163" class="Index_20_Link"><span class="T4">        153</span></a></p><p class="P15"><a href="#_Toc5236164" class="Index_20_Link">Graphics</a><a href="#_Toc5236164" class="Index_20_Link"><span class="T4">        154</span></a></p><p class="Contents_20_2"><a href="#_Toc5236165" class="Index_20_Link">Introduction</a><a href="#_Toc5236165" class="Index_20_Link"><span class="T4">        154</span></a></p><p class="Contents_20_3"><a href="#_Toc5236166" class="Index_20_Link">The Graphics Screen and Graphics Mode</a><a href="#_Toc5236166" class="Index_20_Link"><span class="T4">        154</span></a></p><p class="Contents_20_3"><a href="#_Toc5236167" class="Index_20_Link">Display Lists</a><a href="#_Toc5236167" class="Index_20_Link"><span class="T4">        154</span></a></p><p class="Contents_20_3"><a href="#_Toc5236168" class="Index_20_Link">Drawing Coordinates</a><a href="#_Toc5236168" class="Index_20_Link"><span class="T4">        155</span></a></p><p class="Contents_20_3"><a href="#_Toc5236169" class="Index_20_Link">Drawing into Bitmaps</a><a href="#_Toc5236169" class="Index_20_Link"><span class="T4">        155</span></a></p><p class="Contents_20_3"><a href="#_Toc5236170" class="Index_20_Link">Colors</a><a href="#_Toc5236170" class="Index_20_Link"><span class="T4">        155</span></a></p><p class="Contents_20_3"><a href="#_Toc5236171" class="Index_20_Link">Paints</a><a href="#_Toc5236171" class="Index_20_Link"><span class="T4">        156</span></a></p><p class="Contents_20_3"><a href="#_Toc5236172" class="Index_20_Link">Style</a><a href="#_Toc5236172" class="Index_20_Link"><span class="T4">        157</span></a></p><p class="Contents_20_3"><a href="#_Toc5236173" class="Index_20_Link">Hardware-accelerated Graphics</a><a href="#_Toc5236173" class="Index_20_Link"><span class="T4">        158</span></a></p><p class="Contents_20_2"><a href="#_Toc5236174" class="Index_20_Link">Graphics Setup Commands</a><a href="#_Toc5236174" class="Index_20_Link"><span class="T4">        158</span></a></p><p class="Contents_20_3"><a href="#_Toc5236175" class="Index_20_Link">Gr.open {{alpha}{, red}{, green}{, blue}{, &lt;ShowStatusBar_lexp&gt;}{, &lt;Orientation_nexp&gt;}}</a><a href="#_Toc5236175" class="Index_20_Link"><span class="T4">        158</span></a></p><p class="Contents_20_3"><a href="#_Toc5236176" class="Index_20_Link">Gr.color {{alpha}{, red}{, green}{, blue}{, style}{, paint}}</a><a href="#_Toc5236176" class="Index_20_Link"><span class="T4">        158</span></a></p><p class="Contents_20_3"><a href="#_Toc5236177" class="Index_20_Link">Gr.set.antialias {{&lt;lexp&gt;}{,&lt;paint_nexp&gt;}}</a><a href="#_Toc5236177" class="Index_20_Link"><span class="T4">        160</span></a></p><p class="Contents_20_3"><a href="#_Toc5236178" class="Index_20_Link">Gr.set.stroke {{&lt;nexp&gt;}{,&lt;paint_nexp&gt;}}</a><a href="#_Toc5236178" class="Index_20_Link"><span class="T4">        160</span></a></p><p class="Contents_20_3"><a href="#_Toc5236179" class="Index_20_Link">Gr.orientation &lt;nexp&gt;</a><a href="#_Toc5236179" class="Index_20_Link"><span class="T4">        160</span></a></p><p class="Contents_20_3"><a href="#_Toc5236180" class="Index_20_Link">Gr.statusbar {&lt;height_nvar&gt;} {, showing_lvar}</a><a href="#_Toc5236180" class="Index_20_Link"><span class="T4">        160</span></a></p><p class="Contents_20_3"><a href="#_Toc5236181" class="Index_20_Link">Gr.statusbar.show &lt;nexp&gt;</a><a href="#_Toc5236181" class="Index_20_Link"><span class="T4">        161</span></a></p><p class="Contents_20_3"><a href="#_Toc5236182" class="Index_20_Link">Gr.render</a><a href="#_Toc5236182" class="Index_20_Link"><span class="T4">        161</span></a></p><p class="Contents_20_3"><a href="#_Toc5236183" class="Index_20_Link">Gr.screen width, height{, density }</a><a href="#_Toc5236183" class="Index_20_Link"><span class="T4">        161</span></a></p><p class="Contents_20_3"><a href="#_Toc5236184" class="Index_20_Link">Gr.scale x_factor, y_factor</a><a href="#_Toc5236184" class="Index_20_Link"><span class="T4">        161</span></a></p><p class="Contents_20_3"><a href="#_Toc5236185" class="Index_20_Link">Gr.cls</a><a href="#_Toc5236185" class="Index_20_Link"><span class="T4">        162</span></a></p><p class="Contents_20_3"><a href="#_Toc5236186" class="Index_20_Link">Gr.close</a><a href="#_Toc5236186" class="Index_20_Link"><span class="T4">        162</span></a></p><p class="Contents_20_3"><a href="#_Toc5236187" class="Index_20_Link">Gr.front flag</a><a href="#_Toc5236187" class="Index_20_Link"><span class="T4">        162</span></a></p><p class="Contents_20_3"><a href="#_Toc5236188" class="Index_20_Link">Gr.brightness &lt;nexp&gt;</a><a href="#_Toc5236188" class="Index_20_Link"><span class="T4">        162</span></a></p><p class="Contents_20_2"><a href="#_Toc5236189" class="Index_20_Link">Graphical Object Creation Commands</a><a href="#_Toc5236189" class="Index_20_Link"><span class="T4">        162</span></a></p><p class="Contents_20_3"><a href="#_Toc5236190" class="Index_20_Link">Gr.point &lt;obj_nvar&gt;, x, y</a><a href="#_Toc5236190" class="Index_20_Link"><span class="T4">        163</span></a></p><p class="Contents_20_3"><a href="#_Toc5236191" class="Index_20_Link">Gr.line &lt;obj_nvar&gt;, x1, y1, x2, y2</a><a href="#_Toc5236191" class="Index_20_Link"><span class="T4">        163</span></a></p><p class="Contents_20_3"><a href="#_Toc5236192" class="Index_20_Link">Gr.rect &lt;ob_nvar&gt;, left, top, right, bottom</a><a href="#_Toc5236192" class="Index_20_Link"><span class="T4">        163</span></a></p><p class="Contents_20_3"><a href="#_Toc5236193" class="Index_20_Link">Gr.oval &lt;obj_nvar&gt;, left, top, right, bottom</a><a href="#_Toc5236193" class="Index_20_Link"><span class="T4">        163</span></a></p><p class="Contents_20_3"><a href="#_Toc5236194" class="Index_20_Link">Gr.arc &lt;obj_nvar&gt;, left, top, right, bottom, start_angle, sweep_angle, fill_mode</a><a href="#_Toc5236194" class="Index_20_Link"><span class="T4">        164</span></a></p><p class="Contents_20_3"><a href="#_Toc5236195" class="Index_20_Link">Gr.circle &lt;obj_nvar&gt;, x, y, radius</a><a href="#_Toc5236195" class="Index_20_Link"><span class="T4">        164</span></a></p><p class="Contents_20_3"><a href="#_Toc5236196" class="Index_20_Link">Gr.set.pixels &lt;obj_nvar&gt;, pixels[{&lt;start&gt;,&lt;length&gt;}] {,x,y}</a><a href="#_Toc5236196" class="Index_20_Link"><span class="T4">        164</span></a></p><p class="Contents_20_3"><a href="#_Toc5236197" class="Index_20_Link">Gr.poly &lt;obj_nvar&gt;, list_pointer {,x, y}</a><a href="#_Toc5236197" class="Index_20_Link"><span class="T4">        165</span></a></p><p class="Contents_20_2"><a href="#_Toc5236198" class="Index_20_Link">Groups</a><a href="#_Toc5236198" class="Index_20_Link"><span class="T4">        165</span></a></p><p class="Contents_20_3"><a href="#_Toc5236199" class="Index_20_Link">Gr.group &lt;object_number_nvar&gt;{, &lt;obj_nexp&gt;}...</a><a href="#_Toc5236199" class="Index_20_Link"><span class="T4">        166</span></a></p><p class="Contents_20_3"><a href="#_Toc5236200" class="Index_20_Link">Gr.group.list &lt;object_number_nvar&gt;, &lt;list_ptr_nexp&gt;</a><a href="#_Toc5236200" class="Index_20_Link"><span class="T4">        166</span></a></p><p class="Contents_20_3"><a href="#_Toc5236201" class="Index_20_Link">Gr.group.getDL &lt;object_number_nvar&gt;</a><a href="#_Toc5236201" class="Index_20_Link"><span class="T4">        167</span></a></p><p class="Contents_20_3"><a href="#_Toc5236202" class="Index_20_Link">Gr.group.newDL &lt;object_number_nvar&gt;</a><a href="#_Toc5236202" class="Index_20_Link"><span class="T4">        167</span></a></p><p class="Contents_20_2"><a href="#_Toc5236203" class="Index_20_Link">Hide and Show Commands</a><a href="#_Toc5236203" class="Index_20_Link"><span class="T4">        167</span></a></p><p class="Contents_20_3"><a href="#_Toc5236204" class="Index_20_Link">Gr.hide &lt;object_number_nexp&gt;</a><a href="#_Toc5236204" class="Index_20_Link"><span class="T4">        167</span></a></p><p class="Contents_20_3"><a href="#_Toc5236205" class="Index_20_Link">Gr.show &lt;object_number_nexp&gt;</a><a href="#_Toc5236205" class="Index_20_Link"><span class="T4">        167</span></a></p><p class="Contents_20_3"><a href="#_Toc5236206" class="Index_20_Link">Gr.show.toggle &lt;object_number_nexp&gt;</a><a href="#_Toc5236206" class="Index_20_Link"><span class="T4">        167</span></a></p><p class="Contents_20_2"><a href="#_Toc5236207" class="Index_20_Link">Touch Query Commands</a><a href="#_Toc5236207" class="Index_20_Link"><span class="T4">        167</span></a></p><p class="Contents_20_3"><a href="#_Toc5236208" class="Index_20_Link">Gr.touch touched, x, y</a><a href="#_Toc5236208" class="Index_20_Link"><span class="T4">        168</span></a></p><p class="Contents_20_3"><a href="#_Toc5236209" class="Index_20_Link">Gr.bounded.touch touched, left, top, right, bottom</a><a href="#_Toc5236209" class="Index_20_Link"><span class="T4">        168</span></a></p><p class="Contents_20_3"><a href="#_Toc5236210" class="Index_20_Link">Gr.touch2 touched, x, y</a><a href="#_Toc5236210" class="Index_20_Link"><span class="T4">        168</span></a></p><p class="Contents_20_3"><a href="#_Toc5236211" class="Index_20_Link">Gr.bounded.touch2 touched, left, top, right, bottom</a><a href="#_Toc5236211" class="Index_20_Link"><span class="T4">        168</span></a></p><p class="Contents_20_3"><a href="#_Toc5236212" class="Index_20_Link">OnGrTouch:</a><a href="#_Toc5236212" class="Index_20_Link"><span class="T4">        169</span></a></p><p class="Contents_20_3"><a href="#_Toc5236213" class="Index_20_Link">Gr.onGrTouch.resume</a><a href="#_Toc5236213" class="Index_20_Link"><span class="T4">        169</span></a></p><p class="Contents_20_2"><a href="#_Toc5236214" class="Index_20_Link">Text Commands</a><a href="#_Toc5236214" class="Index_20_Link"><span class="T4">        169</span></a></p><p class="Contents_20_3"><a href="#_Toc5236215" class="Index_20_Link">Overview</a><a href="#_Toc5236215" class="Index_20_Link"><span class="T4">        169</span></a></p><p class="Contents_20_3"><a href="#_Toc5236216" class="Index_20_Link">Gr.text.align {{&lt;type_nexp&gt;}{,&lt;paint_nexp&gt;}}</a><a href="#_Toc5236216" class="Index_20_Link"><span class="T4">        169</span></a></p><p class="Contents_20_3"><a href="#_Toc5236217" class="Index_20_Link">Gr.text.bold {{&lt;lexp&gt;}{,&lt;paint_nexp&gt;}}</a><a href="#_Toc5236217" class="Index_20_Link"><span class="T4">        169</span></a></p><p class="Contents_20_3"><a href="#_Toc5236218" class="Index_20_Link">Gr.text.size {{&lt;size_nexp&gt;}{,&lt;paint_nexp&gt;}}</a><a href="#_Toc5236218" class="Index_20_Link"><span class="T4">        170</span></a></p><p class="Contents_20_3"><a href="#_Toc5236219" class="Index_20_Link">Gr.text.skew {{&lt;skew_nexp&gt;}{,&lt;paint_nexp&gt;}}</a><a href="#_Toc5236219" class="Index_20_Link"><span class="T4">        170</span></a></p><p class="Contents_20_3"><a href="#_Toc5236220" class="Index_20_Link">Gr.text.strike {{&lt;lexp&gt;}{,&lt;paint_nexp&gt;}}</a><a href="#_Toc5236220" class="Index_20_Link"><span class="T4">        170</span></a></p><p class="Contents_20_3"><a href="#_Toc5236221" class="Index_20_Link">Gr.text.underline {{&lt;lexp&gt;}{,&lt;paint_nexp&gt;}}</a><a href="#_Toc5236221" class="Index_20_Link"><span class="T4">        170</span></a></p><p class="Contents_20_3"><a href="#_Toc5236222" class="Index_20_Link">Gr.text.setfont {{&lt;font_ptr_nexp&gt;|&lt;font_family_sexp&gt;} {, &lt;style_sexp&gt;} {,&lt;paint_nexp&gt;}}</a><a href="#_Toc5236222" class="Index_20_Link"><span class="T4">        170</span></a></p><p class="Contents_20_3"><a href="#_Toc5236223" class="Index_20_Link">Gr.text.typeface {{&lt;font_nexp&gt;} {, &lt;style_nexp&gt;} {,&lt;paint_nexp&gt;}}</a><a href="#_Toc5236223" class="Index_20_Link"><span class="T4">        171</span></a></p><p class="Contents_20_3"><a href="#_Toc5236224" class="Index_20_Link">Gr.text.height {&lt;height_nvar&gt;} {, &lt;up_nvar&gt;} {, &lt;down_nvar&gt;}</a><a href="#_Toc5236224" class="Index_20_Link"><span class="T4">        172</span></a></p><p class="Contents_20_3"><a href="#_Toc5236225" class="Index_20_Link">Gr.text.width &lt;nvar&gt;, &lt;exp&gt;</a><a href="#_Toc5236225" class="Index_20_Link"><span class="T4">        172</span></a></p><p class="Contents_20_3"><a href="#_Toc5236226" class="Index_20_Link">Gr.get.textbounds &lt;exp&gt;, left, top, right, bottom</a><a href="#_Toc5236226" class="Index_20_Link"><span class="T4">        173</span></a></p><p class="Contents_20_3"><a href="#_Toc5236227" class="Index_20_Link">Gr.text.draw &lt;object_number_nvar&gt;, &lt;x_nexp&gt;, &lt;y_nexp&gt;, &lt;text_object_sexp&gt;</a><a href="#_Toc5236227" class="Index_20_Link"><span class="T4">        174</span></a></p><p class="Contents_20_2"><a href="#_Toc5236228" class="Index_20_Link">Bitmap Commands</a><a href="#_Toc5236228" class="Index_20_Link"><span class="T4">        174</span></a></p><p class="Contents_20_3"><a href="#_Toc5236229" class="Index_20_Link">Overview</a><a href="#_Toc5236229" class="Index_20_Link"><span class="T4">        174</span></a></p><p class="Contents_20_3"><a href="#_Toc5236230" class="Index_20_Link">Gr.bitmap.create &lt;bitmap_ptr_nvar&gt;, width, height</a><a href="#_Toc5236230" class="Index_20_Link"><span class="T4">        175</span></a></p><p class="Contents_20_3"><a href="#_Toc5236231" class="Index_20_Link">Gr.bitmap.load &lt;bitmap_ptr_nvar&gt;, &lt;file_name_sexp&gt;</a><a href="#_Toc5236231" class="Index_20_Link"><span class="T4">        175</span></a></p><p class="Contents_20_3"><a href="#_Toc5236232" class="Index_20_Link">Gr.bitmap.size &lt;bitmap_ptr_nexp&gt;, width, height</a><a href="#_Toc5236232" class="Index_20_Link"><span class="T4">        175</span></a></p><p class="Contents_20_3"><a href="#_Toc5236233" class="Index_20_Link">Gr.bitmap.scale &lt;new_bitmap_ptr_nvar&gt;, &lt;bitmap_ptr_nexp&gt;, width, height {, &lt;smoothing_lexp&gt;}</a><a href="#_Toc5236233" class="Index_20_Link"><span class="T4">        175</span></a></p><p class="Contents_20_3"><a href="#_Toc5236234" class="Index_20_Link">Gr.bitmap.delete &lt;bitmap_ptr_nexp&gt;</a><a href="#_Toc5236234" class="Index_20_Link"><span class="T4">        176</span></a></p><p class="Contents_20_3"><a href="#_Toc5236235" class="Index_20_Link">Gr.bitmap.crop &lt;new_bitmap_ptr_nvar&gt;, &lt;source_bitmap_ptr_nexp&gt;, &lt;x_nexp&gt;, &lt;y_nexp&gt;, &lt;width_nexp&gt;, &lt;height_nexp&gt;</a><a href="#_Toc5236235" class="Index_20_Link"><span class="T4">        176</span></a></p><p class="Contents_20_3"><a href="#_Toc5236236" class="Index_20_Link">Gr.bitmap.save &lt;bitmap_ptr_nvar&gt;, &lt;filename_sexp&gt;{, &lt;quality_nexp&gt;}</a><a href="#_Toc5236236" class="Index_20_Link"><span class="T4">        176</span></a></p><p class="Contents_20_3"><a href="#_Toc5236237" class="Index_20_Link">Gr.bitmap.draw &lt;object_ptr_nvar&gt;, &lt;bitmap_ptr_nexp&gt;, x , y</a><a href="#_Toc5236237" class="Index_20_Link"><span class="T4">        176</span></a></p><p class="Contents_20_3"><a href="#_Toc5236238" class="Index_20_Link">Gr.get.bmpixel &lt;bitmap_ptr_nvar&gt;, x, y, alpha, red, green, blue</a><a href="#_Toc5236238" class="Index_20_Link"><span class="T4">        177</span></a></p><p class="Contents_20_3"><a href="#_Toc5236239" class="Index_20_Link">Gr.bitmap.fill &lt;bitmap_ptr_nexp&gt;, &lt;x_nexp&gt;, &lt;y_nexp&gt;</a><a href="#_Toc5236239" class="Index_20_Link"><span class="T4">        177</span></a></p><p class="Contents_20_3"><a href="#_Toc5236240" class="Index_20_Link">Gr.bitmap.drawinto.start &lt;bitmap_ptr_nexp&gt;</a><a href="#_Toc5236240" class="Index_20_Link"><span class="T4">        177</span></a></p><p class="Contents_20_3"><a href="#_Toc5236241" class="Index_20_Link">Gr.bitmap.drawinto.end</a><a href="#_Toc5236241" class="Index_20_Link"><span class="T4">        177</span></a></p><p class="Contents_20_2"><a href="#_Toc5236242" class="Index_20_Link">Paint Commands</a><a href="#_Toc5236242" class="Index_20_Link"><span class="T4">        177</span></a></p><p class="Contents_20_3"><a href="#_Toc5236243" class="Index_20_Link">Gr.paint.copy {{&lt;src_nexp&gt;}{, &lt;dst_nexp&gt;}}</a><a href="#_Toc5236243" class="Index_20_Link"><span class="T4">        177</span></a></p><p class="Contents_20_3"><a href="#_Toc5236244" class="Index_20_Link">Gr.paint.get &lt;object_ptr_nvar&gt;</a><a href="#_Toc5236244" class="Index_20_Link"><span class="T4">        178</span></a></p><p class="Contents_20_3"><a href="#_Toc5236245" class="Index_20_Link">Gr.paint.reset {&lt;nexp&gt;}</a><a href="#_Toc5236245" class="Index_20_Link"><span class="T4">        178</span></a></p><p class="Contents_20_2"><a href="#_Toc5236246" class="Index_20_Link">Rotate Commands</a><a href="#_Toc5236246" class="Index_20_Link"><span class="T4">        178</span></a></p><p class="Contents_20_3"><a href="#_Toc5236247" class="Index_20_Link">Gr.rotate.start angle, x, y{,&lt;obj_nvar&gt;}</a><a href="#_Toc5236247" class="Index_20_Link"><span class="T4">        178</span></a></p><p class="Contents_20_3"><a href="#_Toc5236248" class="Index_20_Link">Gr.rotate.end {&lt;obj_nvar&gt;}</a><a href="#_Toc5236248" class="Index_20_Link"><span class="T4">        179</span></a></p><p class="Contents_20_2"><a href="#_Toc5236249" class="Index_20_Link">Camera Commands</a><a href="#_Toc5236249" class="Index_20_Link"><span class="T4">        179</span></a></p><p class="Contents_20_3"><a href="#_Toc5236250" class="Index_20_Link">Gr.camera.select 1|2</a><a href="#_Toc5236250" class="Index_20_Link"><span class="T4">        179</span></a></p><p class="Contents_20_3"><a href="#_Toc5236251" class="Index_20_Link">Gr.camera.shoot &lt;bm_ptr_nvar&gt;</a><a href="#_Toc5236251" class="Index_20_Link"><span class="T4">        180</span></a></p><p class="Contents_20_3"><a href="#_Toc5236252" class="Index_20_Link">Gr.camera.autoshoot &lt;bm_ptr_nvar&gt;{, &lt;flash_ mode_nexp&gt; {, focus_mode_nexp} }</a><a href="#_Toc5236252" class="Index_20_Link"><span class="T4">        180</span></a></p><p class="Contents_20_3"><a href="#_Toc5236253" class="Index_20_Link">Gr.camera.manualShoot &lt;bm_ptr_nvar&gt;{, &lt;flash_ mode_nexp&gt; {, focus_mode_nexp} }</a><a href="#_Toc5236253" class="Index_20_Link"><span class="T4">        181</span></a></p><p class="Contents_20_2"><a href="#_Toc5236254" class="Index_20_Link">Other Graphics Commands</a><a href="#_Toc5236254" class="Index_20_Link"><span class="T4">        181</span></a></p><p class="Contents_20_3"><a href="#_Toc5236255" class="Index_20_Link">Gr.screen.to_bitmap &lt;bm_ptr_nvar&gt;</a><a href="#_Toc5236255" class="Index_20_Link"><span class="T4">        181</span></a></p><p class="Contents_20_3"><a href="#_Toc5236256" class="Index_20_Link">Gr.get.pixel x, y, alpha, red, green, blue</a><a href="#_Toc5236256" class="Index_20_Link"><span class="T4">        181</span></a></p><p class="Contents_20_3"><a href="#_Toc5236257" class="Index_20_Link">Gr.save &lt;filename_sexp&gt; {,&lt;quality_nexp&gt;}</a><a href="#_Toc5236257" class="Index_20_Link"><span class="T4">        181</span></a></p><p class="Contents_20_3"><a href="#_Toc5236258" class="Index_20_Link">Gr.get.type &lt;object_ptr_nexp&gt;, &lt;type_svar&gt;</a><a href="#_Toc5236258" class="Index_20_Link"><span class="T4">        181</span></a></p><p class="Contents_20_3"><a href="#_Toc5236259" class="Index_20_Link">Gr.get.params &lt;object_ptr_nexp&gt;, &lt;param_array$[]&gt;</a><a href="#_Toc5236259" class="Index_20_Link"><span class="T4">        182</span></a></p><p class="Contents_20_3"><a href="#_Toc5236260" class="Index_20_Link">Gr.get.position &lt;object_ptr_nexp&gt;, x, y</a><a href="#_Toc5236260" class="Index_20_Link"><span class="T4">        182</span></a></p><p class="Contents_20_3"><a href="#_Toc5236261" class="Index_20_Link">Gr.move &lt;object_ptr_nexp&gt; {{, dx}{, dy}}</a><a href="#_Toc5236261" class="Index_20_Link"><span class="T4">        182</span></a></p><p class="Contents_20_3"><a href="#_Toc5236262" class="Index_20_Link">Gr.get.value &lt;object_ptr_nexp&gt; {, &lt;tag_sexp&gt;, &lt;value_nvar | value_svar&gt;}...</a><a href="#_Toc5236262" class="Index_20_Link"><span class="T4">        182</span></a></p><p class="Contents_20_3"><a href="#_Toc5236263" class="Index_20_Link">Gr.modify &lt;object_ptr_nexp&gt; {, &lt;tag_sexp&gt;, &lt;value_nexp | value_sexp&gt;}...</a><a href="#_Toc5236263" class="Index_20_Link"><span class="T4">        182</span></a></p><p class="Contents_20_3"><a href="#_Toc5236264" class="Index_20_Link">GR_COLLISION(&lt;object_1_nexp&gt;, &lt;object_2_nexp&gt;)</a><a href="#_Toc5236264" class="Index_20_Link"><span class="T4">        184</span></a></p><p class="Contents_20_3"><a href="#_Toc5236265" class="Index_20_Link">Gr.clip &lt;object_ptr_nexp&gt;, &lt;left_nexp&gt;, &lt;top_nexp&gt;, &lt;right_nexp&gt;, &lt;bottom_nexp&gt;{, &lt;RO_nexp&gt;}</a><a href="#_Toc5236265" class="Index_20_Link"><span class="T4">        184</span></a></p><p class="Contents_20_3"><a href="#_Toc5236266" class="Index_20_Link">Gr.newDL &lt;dl_array[{&lt;start&gt;,&lt;length&gt;}]&gt;</a><a href="#_Toc5236266" class="Index_20_Link"><span class="T4">        185</span></a></p><p class="Contents_20_3"><a href="#_Toc5236267" class="Index_20_Link">Gr.getDL &lt;dl_array[]&gt; {, &lt;keep_all_objects_lexp&gt; }</a><a href="#_Toc5236267" class="Index_20_Link"><span class="T4">        185</span></a></p><p class="P15"><a href="#_Toc5236268" class="Index_20_Link">Audio Interface</a><a href="#_Toc5236268" class="Index_20_Link"><span class="T4">        186</span></a></p><p class="Contents_20_2"><a href="#_Toc5236269" class="Index_20_Link">Introduction</a><a href="#_Toc5236269" class="Index_20_Link"><span class="T4">        186</span></a></p><p class="Contents_20_3"><a href="#_Toc5236270" class="Index_20_Link">The Audio Interface</a><a href="#_Toc5236270" class="Index_20_Link"><span class="T4">        186</span></a></p><p class="Contents_20_3"><a href="#_Toc5236271" class="Index_20_Link">Audio File Types</a><a href="#_Toc5236271" class="Index_20_Link"><span class="T4">        186</span></a></p><p class="Contents_20_2"><a href="#_Toc5236272" class="Index_20_Link">Commands</a><a href="#_Toc5236272" class="Index_20_Link"><span class="T4">        186</span></a></p><p class="Contents_20_3"><a href="#_Toc5236273" class="Index_20_Link">Audio.load &lt;aft_nvar&gt;, &lt;filename_sexp&gt;</a><a href="#_Toc5236273" class="Index_20_Link"><span class="T4">        186</span></a></p><p class="Contents_20_3"><a href="#_Toc5236274" class="Index_20_Link">Audio.play &lt;aft_nexp&gt;</a><a href="#_Toc5236274" class="Index_20_Link"><span class="T4">        186</span></a></p><p class="Contents_20_3"><a href="#_Toc5236275" class="Index_20_Link">Audio.stop</a><a href="#_Toc5236275" class="Index_20_Link"><span class="T4">        187</span></a></p><p class="Contents_20_3"><a href="#_Toc5236276" class="Index_20_Link">Audio.pause</a><a href="#_Toc5236276" class="Index_20_Link"><span class="T4">        187</span></a></p><p class="Contents_20_3"><a href="#_Toc5236277" class="Index_20_Link">Audio.loop</a><a href="#_Toc5236277" class="Index_20_Link"><span class="T4">        187</span></a></p><p class="Contents_20_3"><a href="#_Toc5236278" class="Index_20_Link">Audio.volume &lt;left_nexp&gt;, &lt;right_nexp&gt;</a><a href="#_Toc5236278" class="Index_20_Link"><span class="T4">        187</span></a></p><p class="Contents_20_3"><a href="#_Toc5236279" class="Index_20_Link">Audio.position.current &lt;nvar&gt;</a><a href="#_Toc5236279" class="Index_20_Link"><span class="T4">        187</span></a></p><p class="Contents_20_3"><a href="#_Toc5236280" class="Index_20_Link">Audio.position.seek &lt;nexp&gt;</a><a href="#_Toc5236280" class="Index_20_Link"><span class="T4">        188</span></a></p><p class="Contents_20_3"><a href="#_Toc5236281" class="Index_20_Link">Audio.length &lt;length_nvar&gt;, &lt;aft_nexp&gt;</a><a href="#_Toc5236281" class="Index_20_Link"><span class="T4">        188</span></a></p><p class="Contents_20_3"><a href="#_Toc5236282" class="Index_20_Link">Audio.release &lt;aft_nexp&gt;</a><a href="#_Toc5236282" class="Index_20_Link"><span class="T4">        188</span></a></p><p class="Contents_20_3"><a href="#_Toc5236283" class="Index_20_Link">Audio.isdone &lt;lvar&gt;</a><a href="#_Toc5236283" class="Index_20_Link"><span class="T4">        188</span></a></p><p class="Contents_20_3"><a href="#_Toc5236284" class="Index_20_Link">Audio.record.start &lt;fn_svar&gt;</a><a href="#_Toc5236284" class="Index_20_Link"><span class="T4">        188</span></a></p><p class="Contents_20_3"><a href="#_Toc5236285" class="Index_20_Link">Audio.record.stop</a><a href="#_Toc5236285" class="Index_20_Link"><span class="T4">        188</span></a></p><p class="P15"><a href="#_Toc5236286" class="Index_20_Link">SoundPool</a><a href="#_Toc5236286" class="Index_20_Link"><span class="T4">        188</span></a></p><p class="Contents_20_2"><a href="#_Toc5236287" class="Index_20_Link">Introduction</a><a href="#_Toc5236287" class="Index_20_Link"><span class="T4">        188</span></a></p><p class="Contents_20_2"><a href="#_Toc5236288" class="Index_20_Link">Commands</a><a href="#_Toc5236288" class="Index_20_Link"><span class="T4">        189</span></a></p><p class="Contents_20_3"><a href="#_Toc5236289" class="Index_20_Link">Soundpool.open &lt;MaxStreams_nexp&gt;</a><a href="#_Toc5236289" class="Index_20_Link"><span class="T4">        189</span></a></p><p class="Contents_20_3"><a href="#_Toc5236290" class="Index_20_Link">Soundpool.load &lt;soundID_nvar&gt;, &lt;file_path_sexp&gt;</a><a href="#_Toc5236290" class="Index_20_Link"><span class="T4">        189</span></a></p><p class="Contents_20_3"><a href="#_Toc5236291" class="Index_20_Link">Soundpool.unload &lt;soundID_nexp&gt;</a><a href="#_Toc5236291" class="Index_20_Link"><span class="T4">        189</span></a></p><p class="Contents_20_3"><a href="#_Toc5236292" class="Index_20_Link">Soundpool.play &lt;streamID_nvar&gt;, &lt;soundID_nexp&gt;, &lt;rightVolume_nexp&gt;, &lt;leftVolume_nexp&gt;, &lt;priority_nexp&gt;, &lt;loop_nexp&gt;, &lt;rate_nexp&gt;</a><a href="#_Toc5236292" class="Index_20_Link"><span class="T4">        189</span></a></p><p class="Contents_20_3"><a href="#_Toc5236293" class="Index_20_Link">Soundpool.setvolume &lt;streamID_nexp&gt;, &lt;leftVolume_nexp&gt;, &lt;rightVolume_nexp&gt;</a><a href="#_Toc5236293" class="Index_20_Link"><span class="T4">        190</span></a></p><p class="Contents_20_3"><a href="#_Toc5236294" class="Index_20_Link">Soundpool.setrate &lt;streamID_nexp&gt;, &lt;rate_nexp&gt;</a><a href="#_Toc5236294" class="Index_20_Link"><span class="T4">        190</span></a></p><p class="Contents_20_3"><a href="#_Toc5236295" class="Index_20_Link">Soundpool.setpriority &lt;streamID_nexp&gt;, &lt;priority_nexp&gt;</a><a href="#_Toc5236295" class="Index_20_Link"><span class="T4">        190</span></a></p><p class="Contents_20_3"><a href="#_Toc5236296" class="Index_20_Link">Soundpool.pause &lt;streamID_nexp&gt;</a><a href="#_Toc5236296" class="Index_20_Link"><span class="T4">        190</span></a></p><p class="Contents_20_3"><a href="#_Toc5236297" class="Index_20_Link">Soundpool.resume &lt;streamID_nexp&gt;</a><a href="#_Toc5236297" class="Index_20_Link"><span class="T4">        190</span></a></p><p class="Contents_20_3"><a href="#_Toc5236298" class="Index_20_Link">Soundpool.stop &lt;streamID_nexp&gt;</a><a href="#_Toc5236298" class="Index_20_Link"><span class="T4">        190</span></a></p><p class="Contents_20_3"><a href="#_Toc5236299" class="Index_20_Link">Soundpool.release</a><a href="#_Toc5236299" class="Index_20_Link"><span class="T4">        190</span></a></p><p class="P15"><a href="#_Toc5236300" class="Index_20_Link">GPS</a><a href="#_Toc5236300" class="Index_20_Link"><span class="T4">        190</span></a></p><p class="Contents_20_2"><a href="#_Toc5236301" class="Index_20_Link">GPS Control commands</a><a href="#_Toc5236301" class="Index_20_Link"><span class="T4">        191</span></a></p><p class="Contents_20_3"><a href="#_Toc5236302" class="Index_20_Link">Gps.open {{&lt;status_nvar&gt;},{&lt;time_nexp&gt;},{&lt;distance_nexp&gt;}}</a><a href="#_Toc5236302" class="Index_20_Link"><span class="T4">        191</span></a></p><p class="Contents_20_3"><a href="#_Toc5236303" class="Index_20_Link">Gps.close</a><a href="#_Toc5236303" class="Index_20_Link"><span class="T4">        191</span></a></p><p class="Contents_20_3"><a href="#_Toc5236304" class="Index_20_Link">Gps.status {{&lt;status_var&gt;}, {&lt;infix_nvar&gt;},{inview_nvar}, {&lt;sat_list_nexp&gt;}}</a><a href="#_Toc5236304" class="Index_20_Link"><span class="T4">        191</span></a></p><p class="Contents_20_2"><a href="#_Toc5236305" class="Index_20_Link">GPS Location commands</a><a href="#_Toc5236305" class="Index_20_Link"><span class="T4">        193</span></a></p><p class="Contents_20_3"><a href="#_Toc5236306" class="Index_20_Link">Gps.location {{&lt;time_nvar&gt;}, {&lt;prov_svar&gt;}, {&lt;count_nvar}, {&lt;acc_nvar&gt;}, {&lt;lat_nvar&gt;}, {&lt;long_nvar&gt;}, {&lt;alt_nvar&gt;}, {&lt;bear_nvar&gt;}, {&lt;speed_nvar&gt;}}</a><a href="#_Toc5236306" class="Index_20_Link"><span class="T4">        194</span></a></p><p class="Contents_20_3"><a href="#_Toc5236307" class="Index_20_Link">Gps.time &lt;nvar&gt;</a><a href="#_Toc5236307" class="Index_20_Link"><span class="T4">        194</span></a></p><p class="Contents_20_3"><a href="#_Toc5236308" class="Index_20_Link">Gps.provider &lt;svar&gt;</a><a href="#_Toc5236308" class="Index_20_Link"><span class="T4">        194</span></a></p><p class="Contents_20_3"><a href="#_Toc5236309" class="Index_20_Link">Gps.satellites {{&lt;count_nvar&gt;}, {&lt;sat_list_nexp&gt;}}</a><a href="#_Toc5236309" class="Index_20_Link"><span class="T4">        195</span></a></p><p class="Contents_20_3"><a href="#_Toc5236310" class="Index_20_Link">Gps.accuracy &lt;nvar&gt;</a><a href="#_Toc5236310" class="Index_20_Link"><span class="T4">        195</span></a></p><p class="Contents_20_3"><a href="#_Toc5236311" class="Index_20_Link">Gps.latitude &lt;nvar&gt;</a><a href="#_Toc5236311" class="Index_20_Link"><span class="T4">        195</span></a></p><p class="Contents_20_3"><a href="#_Toc5236312" class="Index_20_Link">Gps.longitude &lt;nvar&gt;</a><a href="#_Toc5236312" class="Index_20_Link"><span class="T4">        195</span></a></p><p class="Contents_20_3"><a href="#_Toc5236313" class="Index_20_Link">Gps.altitude &lt;nvar&gt;</a><a href="#_Toc5236313" class="Index_20_Link"><span class="T4">        195</span></a></p><p class="Contents_20_3"><a href="#_Toc5236314" class="Index_20_Link">Gps.bearing &lt;nvar&gt;</a><a href="#_Toc5236314" class="Index_20_Link"><span class="T4">        195</span></a></p><p class="Contents_20_3"><a href="#_Toc5236315" class="Index_20_Link">Gps.speed &lt;nvar&gt;</a><a href="#_Toc5236315" class="Index_20_Link"><span class="T4">        195</span></a></p><p class="P15"><a href="#_Toc5236316" class="Index_20_Link">Sensors</a><a href="#_Toc5236316" class="Index_20_Link"><span class="T4">        195</span></a></p><p class="Contents_20_2"><a href="#_Toc5236317" class="Index_20_Link">Introduction</a><a href="#_Toc5236317" class="Index_20_Link"><span class="T4">        195</span></a></p><p class="Contents_20_2"><a href="#_Toc5236318" class="Index_20_Link">Sensor Commands</a><a href="#_Toc5236318" class="Index_20_Link"><span class="T4">        196</span></a></p><p class="Contents_20_3"><a href="#_Toc5236319" class="Index_20_Link">Sensors.list &lt;sensor_array$[]&gt;</a><a href="#_Toc5236319" class="Index_20_Link"><span class="T4">        196</span></a></p><p class="Contents_20_3"><a href="#_Toc5236320" class="Index_20_Link">Sensors.open &lt;type_nexp&gt;{:&lt;delay_nexp&gt;}{, &lt;type_nexp&gt;{:&lt;delay_nexp&gt;}, ...}</a><a href="#_Toc5236320" class="Index_20_Link"><span class="T4">        196</span></a></p><p class="Contents_20_3"><a href="#_Toc5236321" class="Index_20_Link">Sensors.read sensor_type_nexp, p1_nvar, p2_nvar, p3_nvar</a><a href="#_Toc5236321" class="Index_20_Link"><span class="T4">        197</span></a></p><p class="Contents_20_3"><a href="#_Toc5236322" class="Index_20_Link">Sensors.close</a><a href="#_Toc5236322" class="Index_20_Link"><span class="T4">        197</span></a></p><p class="P15"><a href="#_Toc5236323" class="Index_20_Link">System</a><a href="#_Toc5236323" class="Index_20_Link"><span class="T4">        197</span></a></p><p class="Contents_20_2"><a href="#_Toc5236324" class="Index_20_Link">System Commands</a><a href="#_Toc5236324" class="Index_20_Link"><span class="T4">        198</span></a></p><p class="Contents_20_3"><a href="#_Toc5236325" class="Index_20_Link">System.open</a><a href="#_Toc5236325" class="Index_20_Link"><span class="T4">        198</span></a></p><p class="Contents_20_3"><a href="#_Toc5236326" class="Index_20_Link">System.write &lt;sexp&gt;</a><a href="#_Toc5236326" class="Index_20_Link"><span class="T4">        198</span></a></p><p class="Contents_20_3"><a href="#_Toc5236327" class="Index_20_Link">System.read.ready &lt;nvar&gt;</a><a href="#_Toc5236327" class="Index_20_Link"><span class="T4">        198</span></a></p><p class="Contents_20_3"><a href="#_Toc5236328" class="Index_20_Link">System.read.line &lt;svar&gt;</a><a href="#_Toc5236328" class="Index_20_Link"><span class="T4">        198</span></a></p><p class="Contents_20_3"><a href="#_Toc5236329" class="Index_20_Link">System.close</a><a href="#_Toc5236329" class="Index_20_Link"><span class="T4">        198</span></a></p><p class="Contents_20_2"><a href="#_Toc5236330" class="Index_20_Link">Superuser Commands</a><a href="#_Toc5236330" class="Index_20_Link"><span class="T4">        198</span></a></p><p class="Contents_20_3"><a href="#_Toc5236331" class="Index_20_Link">Su.open</a><a href="#_Toc5236331" class="Index_20_Link"><span class="T4">        198</span></a></p><p class="Contents_20_3"><a href="#_Toc5236332" class="Index_20_Link">Su.write &lt;sexp&gt;</a><a href="#_Toc5236332" class="Index_20_Link"><span class="T4">        198</span></a></p><p class="Contents_20_3"><a href="#_Toc5236333" class="Index_20_Link">Su.read.ready &lt;nvar&gt;</a><a href="#_Toc5236333" class="Index_20_Link"><span class="T4">        198</span></a></p><p class="Contents_20_3"><a href="#_Toc5236334" class="Index_20_Link">Su.read.line &lt;svar&gt;</a><a href="#_Toc5236334" class="Index_20_Link"><span class="T4">        198</span></a></p><p class="Contents_20_3"><a href="#_Toc5236335" class="Index_20_Link">Su.close</a><a href="#_Toc5236335" class="Index_20_Link"><span class="T4">        199</span></a></p><p class="Contents_20_2"><a href="#_Toc5236336" class="Index_20_Link">App Commands</a><a href="#_Toc5236336" class="Index_20_Link"><span class="T4">        199</span></a></p><p class="Contents_20_3"><a href="#_Toc5236337" class="Index_20_Link">App.broadcast &lt;action_sexp&gt;, &lt;data_uri_sexp&gt;, &lt;package_sexp&gt;, &lt;component_sexp&gt;, &lt;mime_type_sexp&gt;, &lt;categories_sexp&gt;, &lt;extras_bptr_nexp&gt;, &lt;flags_nexp&gt;</a><a href="#_Toc5236337" class="Index_20_Link"><span class="T4">        199</span></a></p><p class="Contents_20_3"><a href="#_Toc5236338" class="Index_20_Link">App.start &lt;action_sexp&gt;, &lt;data_uri_sexp&gt;, &lt;package_sexp&gt;, &lt;component_sexp&gt;, &lt;mime_type_sexp&gt;, &lt;categories_sexp&gt;, &lt;extras_bptr_nexp&gt;, &lt;flags_nexp&gt;</a><a href="#_Toc5236338" class="Index_20_Link"><span class="T4">        199</span></a></p><p class="P15"><a href="#_Toc5236339" class="Index_20_Link">Appendix A – Command List</a><a href="#_Toc5236339" class="Index_20_Link"><span class="T4">        201</span></a></p><p class="P15"><a href="#_Toc5236340" class="Index_20_Link">Appendix B – Sample Programs</a><a href="#_Toc5236340" class="Index_20_Link"><span class="T4">        213</span></a></p><p class="P15"><a href="#_Toc5236341" class="Index_20_Link">Appendix C – Launcher Shortcut Tutorial</a><a href="#_Toc5236341" class="Index_20_Link"><span class="T4">        214</span></a></p><p class="Contents_20_2"><a href="#_Toc5236342" class="Index_20_Link">Introduction</a><a href="#_Toc5236342" class="Index_20_Link"><span class="T4">        214</span></a></p><p class="Contents_20_2"><a href="#_Toc5236343" class="Index_20_Link">How to Make a Shortcut Application (older versions of Android—prior to Android 4.0)</a><a href="#_Toc5236343" class="Index_20_Link"><span class="T4">        214</span></a></p><p class="Contents_20_2"><a href="#_Toc5236344" class="Index_20_Link">How to Make a Shortcut Application (newer versions of Android—Android 4.0 and later)</a><a href="#_Toc5236344" class="Index_20_Link"><span class="T4">        215</span></a></p><p class="Contents_20_2"><a href="#_Toc5236345" class="Index_20_Link">What you need to know</a><a href="#_Toc5236345" class="Index_20_Link"><span class="T4">        216</span></a></p><p class="P15"><a href="#_Toc5236346" class="Index_20_Link">Appendix D – Building a Standalone Application</a><a href="#_Toc5236346" class="Index_20_Link"><span class="T4">        217</span></a></p><p class="Contents_20_2"><a href="#_Toc5236347" class="Index_20_Link">Introduction</a><a href="#_Toc5236347" class="Index_20_Link"><span class="T4">        217</span></a></p><p class="Contents_20_2"><a href="#_Toc5236348" class="Index_20_Link">License Information</a><a href="#_Toc5236348" class="Index_20_Link"><span class="T4">        217</span></a></p><p class="Contents_20_2"><a href="#_Toc5236349" class="Index_20_Link">Before You Start</a><a href="#_Toc5236349" class="Index_20_Link"><span class="T4">        217</span></a></p><p class="Contents_20_2"><a href="#_Toc5236350" class="Index_20_Link">Setting Up the Development Environment</a><a href="#_Toc5236350" class="Index_20_Link"><span class="T4">        217</span></a></p><p class="Contents_20_2"><a href="#_Toc5236351" class="Index_20_Link">Download the BASIC! Source Code from the GitHub Repository</a><a href="#_Toc5236351" class="Index_20_Link"><span class="T4">        218</span></a></p><p class="Contents_20_2"><a href="#_Toc5236352" class="Index_20_Link">Download the BASIC! Source Code from the Legacy Archive</a><a href="#_Toc5236352" class="Index_20_Link"><span class="T4">        218</span></a></p><p class="Contents_20_2"><a href="#_Toc5236353" class="Index_20_Link">Create a New Project in Eclipse</a><a href="#_Toc5236353" class="Index_20_Link"><span class="T4">        219</span></a></p><p class="Contents_20_2"><a href="#_Toc5236354" class="Index_20_Link">Rename the Package</a><a href="#_Toc5236354" class="Index_20_Link"><span class="T4">        220</span></a></p><p class="Contents_20_3"><a href="#_Toc5236355" class="Index_20_Link">In Eclipse</a><a href="#_Toc5236355" class="Index_20_Link"><span class="T4">        220</span></a></p><p class="Contents_20_3"><a href="#_Toc5236356" class="Index_20_Link">Other IDEs</a><a href="#_Toc5236356" class="Index_20_Link"><span class="T4">        221</span></a></p><p class="Contents_20_3"><a href="#_Toc5236357" class="Index_20_Link">Renaming complete</a><a href="#_Toc5236357" class="Index_20_Link"><span class="T4">        222</span></a></p><p class="Contents_20_2"><a href="#_Toc5236358" class="Index_20_Link">Modifications to setup.xml</a><a href="#_Toc5236358" class="Index_20_Link"><span class="T4">        222</span></a></p><p class="Contents_20_2"><a href="#_Toc5236359" class="Index_20_Link">Advanced Customization with setup.xml</a><a href="#_Toc5236359" class="Index_20_Link"><span class="T4">        223</span></a></p><p class="Contents_20_2"><a href="#_Toc5236360" class="Index_20_Link">Files and Resources</a><a href="#_Toc5236360" class="Index_20_Link"><span class="T4">        225</span></a></p><p class="Contents_20_2"><a href="#_Toc5236361" class="Index_20_Link">Testing the APK</a><a href="#_Toc5236361" class="Index_20_Link"><span class="T4">        226</span></a></p><p class="Contents_20_2"><a href="#_Toc5236362" class="Index_20_Link">Installing a BASIC! Program into the Application</a><a href="#_Toc5236362" class="Index_20_Link"><span class="T4">        227</span></a></p><p class="Contents_20_2"><a href="#_Toc5236363" class="Index_20_Link">Application Icons</a><a href="#_Toc5236363" class="Index_20_Link"><span class="T4">        228</span></a></p><p class="Contents_20_2"><a href="#_Toc5236364" class="Index_20_Link">Modifications to the AndroidManifest.xml File</a><a href="#_Toc5236364" class="Index_20_Link"><span class="T4">        229</span></a></p><p class="Contents_20_3"><a href="#_Toc5236365" class="Index_20_Link">Setting the Version Number and Version Name</a><a href="#_Toc5236365" class="Index_20_Link"><span class="T4">        230</span></a></p><p class="Contents_20_3"><a href="#_Toc5236366" class="Index_20_Link">Permissions</a><a href="#_Toc5236366" class="Index_20_Link"><span class="T4">        230</span></a></p><p class="Contents_20_3"><a href="#_Toc5236367" class="Index_20_Link">Disable the Shortcut Launcher</a><a href="#_Toc5236367" class="Index_20_Link"><span class="T4">        230</span></a></p><p class="Contents_20_3"><a href="#_Toc5236368" class="Index_20_Link">Launch at device boot</a><a href="#_Toc5236368" class="Index_20_Link"><span class="T4">        231</span></a></p><p class="Contents_20_2"><a href="#_Toc5236369" class="Index_20_Link">Preferences</a><a href="#_Toc5236369" class="Index_20_Link"><span class="T4">        232</span></a></p><p class="Contents_20_2"><a href="#_Toc5236370" class="Index_20_Link">Finished</a><a href="#_Toc5236370" class="Index_20_Link"><span class="T4">        233</span></a></p><p class="P15"><a href="#_Toc5236371" class="Index_20_Link">Appendix E – BASIC! Distribution License</a><a href="#_Toc5236371" class="Index_20_Link"><span class="T4">        234</span></a></p><p class="Contents_20_2"><a href="#_Toc5236372" class="Index_20_Link"><span class="T6">Apache Commons</span></a><a href="#_Toc5236372" class="Index_20_Link"><span class="T4">        245</span></a></p><p class="Standard"> </p><p class="P90"> </p><p class="Standard"> </p><h1 class="P17"><a id="a__Changes_in_this_Version"><span/></a><a id="_Toc5235690"/><a id="Changes"/>Changes in this Version</h1><ul><li><p class="P20" style="margin-left:1.27cm;"><span class="ListLabel_20_5" style="display:block;float:left;min-width:0.635cm;"></span>BASIC! is now compiled for versions of the Android Runtime up to 28 (Android 9, Pie). The effect on this manual is seen in the permissions requested at startup, in the Notify command, and in the SMS commands.<span class="odfLiEnd"/> </p></li><li><p class="P20" style="margin-left:1.27cm;"><span class="ListLabel_20_5" style="display:block;float:left;min-width:0.635cm;"></span>This version of BASIC! uses localizable strings for many of the messages displayed by the Editor and Interpreter. Thanks to Hirokazu Yamazaki for programming localization and providing Japanese translations of the localizable strings.<span class="odfLiEnd"/> </p></li><li><p class="P20" style="margin-left:1.27cm;"><span class="ListLabel_20_5" style="display:block;float:left;min-width:0.635cm;"></span>Due to changes in Google Play Store policies, BASIC! is now distributed in two editions:<span class="odfLiEnd"/> </p><ul><li><p class="P20" style="margin-left:1.27cm;"><span class="ListLabel_20_6" style="display:block;float:left;min-width:0.635cm;">o</span>The Google Play Edition, available on the Play Store, does not support SMS commands.<span class="odfLiEnd"/> </p></li><li><p class="P20" style="margin-left:1.27cm;"><span class="ListLabel_20_6" style="display:block;float:left;min-width:0.635cm;">o</span>The Full Edition does support SMS commands.<span class="odfLiEnd"/> </p></li><li><p class="P21" style="margin-left:1.27cm;"><span class="ListLabel_20_6" style="display:block;float:left;min-width:0.635cm;">o</span><span class="odfLiEnd"/> </p></li></ul></li></ul><h1 class="P17"><a id="a__About_the_Title__De_Re_BASIC!"><span/></a><a id="_Toc5235691"/>About the Title, De Re BASIC!</h1><p class="Standard">"De Re" is Latin for "of the thing" or "about".</p><h1 class="Heading_20_1"><a id="a__About_the_Cover_Art"><span/></a><a id="_Toc5235692"/>About the Cover Art</h1><p class="Standard">Thanks to BASIC! collaborator Nicolas Mougin. The images are screenshots from real BASIC! programs available from the Google Play™ store, or from the excellent collection of shared BASIC! programs available at <a href="http://laughton.com/basic/programs" class="Internet_20_link"><span class="Internet_20_link">http://laughton.com/basic/programs</span></a>.</p><p class="Standard">You can find more information on the BASIC! user forum at <a href="http://rfobasic.freeforums.org/shared-basic-programs-f6.html" class="Internet_20_link"><span class="Internet_20_link">http://rfobasic.freeforums.org/shared-basic-programs-f6.html</span></a>.</p><h1 class="Heading_20_1"><a id="a__Credits"><span/></a><a id="_Toc5235693"/>Credits</h1><p class="Standard">Thanks to Paul Laughton, the original creator of BASIC! and of this document. The first edition was published in 2011. Mr. Laughton placed this document in the Public Domain in 2016.</p><p class="Standard">Thanks also to Mike Leavitt of Lansdowne, VA, USA, for his many contributions and long-time support.</p><h1 class="Heading_20_1"><a id="a__Technical_Editor"><span/></a><a id="_Toc5235694"/>Technical Editor</h1><p class="Standard">The current editor of this manual monitors <a href="https://github.com/RFO-BASIC/De-Re-Basic/issues" class="Internet_20_link"><span class="Internet_20_link">https://github.com/RFO-BASIC/De-Re-Basic/issues</span></a> and the BASIC! user forum at <a href="http://rfobasic.freeforums.org/suggestions-for-improving-the-manual-f9.html" class="Internet_20_link"><span class="Internet_20_link">http://rfobasic.freeforums.org/suggestions-for-improving-the-manual-f9.html</span></a> for corrections and suggestions.</p><h1 class="Heading_20_1"><a id="a__Getting_BASIC!"><span/></a><a id="_Toc5235695"/>Getting BASIC!</h1><p class="Standard">You can get BASIC! for your Android device from the <span class="T7">Google Play™</span> store. The Google Play Edition of BASIC! does not allow use of SMS commands.</p><p class="Standard">If you want to download the installation file (Basic.apk) of either the Full Edition or the Google Play Edition, or to get a previous version, go to <span class="T7">Bintray</span> at <a href="https://bintray.com/rfo-basic/android/RFO-BASIC/" class="Internet_20_link"><span class="Internet_20_link">https://bintray.com/rfo-basic/android/RFO-BASIC/</span></a><span class="Internet_20_link">.</span></p><p class="Standard">This manual is also available from Bintray, in PDF format. BASIC! collaborator Nicolas Mougin keeps the manual in HTML format on his BASIC! website: <a href="http://rfo-basic.com/manual" class="Internet_20_link"><span class="Internet_20_link">http://rfo-basic.com/manual</span></a>. The document source is available from GitHub at <a href="https://github.com/RFO-BASIC/De-Re-Basic" class="Internet_20_link"><span class="Internet_20_link">https://github.com/RFO-BASIC/De-Re-Basic</span></a>.</p><h1 class="Heading_20_1"><a id="a__BASIC!_Forum"><span/></a><a id="_Toc5235696"/>BASIC! Forum</h1><p class="Standard">Join the community of BASIC! users at <a href="http://rfobasic.freeforums.org" class="Internet_20_link"><span class="Internet_20_link">http://rfobasic.freeforums.org</span></a>, where you are always welcome.</p><h1 class="Heading_20_1"><a id="a__BASIC!_Tutorial"><span/></a><a id="_Toc5235697"/>BASIC! Tutorial</h1><p class="Standard">A BASIC! user, Nick Antonaccio, has<span class="T8"> written a tutorial for BASIC! You can find it at </span><a href="http://rfobasic.com" class="Internet_20_link"><span class="Internet_20_link"><span class="T8">http://rfobasic.com</span></span></a><span class="T8">. While it does not demonstrate all of the newer features of BASIC!, it is still a nice way to get started.</span></p><h1 class="Heading_20_1"><a id="a__BASIC!_Operation"><span/></a><a id="_Toc5235698"/>BASIC! Operation</h1><h2 class="Heading_20_2"><a id="a__Permissions"><span/></a><a id="_Toc5235699"/>Permissions</h2><p class="Standard">This application requests many permissions, permissions such as sending and receiving SMS messages, making phone calls, record audio, etc. BASIC! does not exercise any of these permissions on its own, except writing to the SD card. These permissions get exercised by the BASIC! programmer, you. You and only you. You exercise these permissions by means of the programs that you write.</p><p class="Standard">For example, if you write a program that uses the sms.send command then BASIC! will attempt to send an SMS message. BASIC! must have permission to send SMS messages for this command to work. If you never use the sms.send command then BASIC! will never send an SMS message. You are in control.</p><p class="Standard">The source code for BASIC! is available from the BASIC! GitHub repository (<a href="https://github.com/RFO-BASIC/Basic" class="Internet_20_link"><span class="Internet_20_link">https://github.com/RFO-BASIC/Basic</span></a>). Please feel free to examine this source code if you have any doubt about the use of these permissions.</p><p class="Standard">On most versions of Android, when you install BASIC! and run it the first time it will request several permissions. You must grant Storage permission, or the BASIC! Editor will be unable to load and store programs. You do not need to grant any other permission to run the BASIC! Editor and Interpreter. You may choose to deny any of the other permissions, unless you want to write programs using commands that require those permissions.</p><p class="Standard">If you deny any of the permissions, then every time you start BASIC! it will request the permissions again. To prevent repeated requests, when you deny a permission, check the “Don’t ask again” box provided by the system permissions dialog.</p><p class="Standard">If you check “Don’t ask again” and deny a permission, and you later decide you want to grant that permission, you must use the Android Settings app to change the permission’s state.</p><p class="Standard">As of 2018, Google does not allow most programs that read or write SMS messages to be distributed on the Play Store. BASIC! now comes in two editions:</p><ul><li><p class="P22" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>The Google Play Edition, distributed on the Play Store, does not request SMS permissions and does not support reading or writing SMS messages.<span class="odfLiEnd"/> </p></li><li><p class="P22" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>The Full Edition (or Standard Edition), available on <a href="https://bintray.com/rfo-basic/android/RFO-BASIC" class="Internet_20_link"><span class="Internet_20_link">Bintray</span></a> and the BASIC! <a href="http://laughton.com/basic/programs/apks" class="Internet_20_link"><span class="Internet_20_link">file server</span></a>, does request SMS permissions, and, if you grant those permissions, does support reading and writing SMS messages.<span class="odfLiEnd"/> </p></li></ul><p class="Standard"> </p><h2 class="Heading_20_2"><a id="a__Editor"><span/></a><a id="_Toc5235700"/>Editor</h2><h3 class="Heading_20_3"><a id="a__Editing_the_Program"><span/></a><a id="_Toc5235701"/>Editing the Program</h3><p class="Standard">The Editor is where BASIC! programs are written and edited. The operation of the Editor is fairly simple. Tap the screen at the point where you want to edit the program. A cursor will appear. Use the keyboard to edit at the cursor location.</p><p class="Standard">When the Enter key is tapped, the new line will automatically indent to the indent level of the previous line. This feature will not work if the Preference, "Editor AutoIndent," is not checked. This feature also may not work if you are using a software keyboard.</p><p class="Standard">If the program that you are editing has been given a name via Save or Load then that program name will be shown in the title bar.</p><p class="Standard">Some Android devices are shipped with "Settings/Developer Option/Destroy Activities" checked and/or "Settings/Energy/Quick Restart" checked. Both of these setting create problems with loading files into the Editor. It appears as if you have gone through the process of loading the file but nothing appears in the editor. The solution to the problem is to uncheck both of these options. Even better, completely turn off Developer Options unless you know that you have a legitimate development need.</p><p class="Standard">If your Android device does not have a physical keyboard, you will see a virtual keyboard. If you see the virtual keyboard, then you will see different things depending upon the way you are holding the device. If the device is in landscape mode then you will see a dialog box with a chunk of the program in a small text input area. You can scroll the small chunk of text up and down in this area but you will not be able to see very much of the program at any one time. It is probably best not to try to edit a program in landscape mode; hold your device in portrait mode while editing.</p><p class="Standard">On some devices, if you do a long touch on the screen, a dialog box will appear. You can use the selections in the box for selecting, copying, cutting and pasting of text, among other things. Other devices have different procedures for invoking the cut and paste functions.</p><h3 class="Heading_20_3"><a id="a__Multiple_Commands_on_a_Line"><span/></a><a id="_Toc5235702"/>Multiple Commands on a Line</h3><p class="Standard">More than one BASIC! source code statement may be written on one physical line. Separate commands with a colon character "<span class="T7">:</span>".</p><p class="Standard">For example, the following line uses three separate commands to initialize some variables:</p><p class="Code_20_example"><span class="T11">name$="BASIC!" : ver=1.86 : array.load reviews$[], "Great!", "Wow!", "Fantastic!"</span></p><p class="Standard">Note: two commands, <span class="T7">Sensors.open</span> and <span class="T7">SQL.update</span>, use the colon as a sub-parameter separator. If you use multiple-command lines, be careful when using these two commands.</p><h3 class="Heading_20_3"><a id="a__Line_Continuation"><span/></a><a id="_Toc5235703"/>Line Continuation</h3><p class="Standard">A BASIC! source code statement may be written on more than one physical line using the line continuation character "~". If "~" is the last thing on a line, except for optional spaces, tabs, or a '%' comment, the line will be merged with the next line. This behavior is slightly different in the <span class="T7">Array.load</span> and <span class="T7">List.add</span> commands; see the descriptions of those commands for details.</p><p class="Standard">Note: this operation is implemented by a preprocessor that merges the source code lines with continuation characters before the source code is executed. If you have a syntax error in the merged line, it will show as one line in the error message, but it will still be multiple lines in the editor. Only the first physical line will be highlighted, regardless of which line the error is in.</p><p class="Standard">For example, the code line:</p><p class="Code_20_example"><span class="T11">s$ = "The quick brown fox " + verb$ + " over " + count$ + " lazy dogs"</span></p><p class="Standard">could be written as:</p><p class="Code_20_example"><span class="T11">s$ = "The quick brown fox " +~</span></p><p class="Code_20_example"><span class="T11">        verb$ +     ~       % what the fox did</span></p><p class="Code_20_example"><span class="T11">        " over " +  ~</span></p><p class="Code_20_example"><span class="T11">        count$ +    ~       % how many lazy dogs</span></p><p class="Code_20_example"><span class="T11">        " lazy dogs"</span></p><h3 class="Heading_20_3"><a id="a__#_-_Format_Line"><span/></a><a id="_Toc5235704"/># - Format Line</h3><p class="Standard">If a line has the # character at the end of the line, the keywords in that line will be capitalized and the # will be removed.</p><p class="Standard">This feature may not work if you are using a virtual keyboard.</p><p class="Standard">This feature will not work if the Preference option "Editor AutoIndent" is not checked.</p><h3 class="Heading_20_3"><a id="a__Menus"><span/></a><a id="_Toc5235705"/>Menus</h3><p class="Standard">Press the MENU key or touch the Menu icon to access the following menus. On some versions of Android, you will not see all of the menu options. Instead, you will see the first five options and a <span class="T17">More</span> options. Select the <span class="T17">More</span> option to see all of the options listed.</p><h4 class="Heading_20_4"><a id="a__Run"><span/></a>Run</h4><p class="Standard">Run the current program.</p><p class="Standard">If the program has been changed since it was last saved, you will be given an opportunity to save the program before the run is started.</p><p class="Standard">If a run-time error occurs then the offending line will be shown as selected in the editor.</p><h4 class="Heading_20_4"><a id="a__Load"><span/></a>Load</h4><p class="Standard">Load a program file into the editor. The first time you open BASIC! after installing it, if you select <span class="T17">Load</span> it displays the sample programs in the directory <span class="T7">rfo-basic/source/Sample_Programs</span>. (See <span class="T7">Paths Explained</span>, later in this manual.) Otherwise, when you open BASIC! and select <span class="T17">Load</span> it starts in the default source directory <span class="T7">rfo-basic/source</span>. Program files must have the extension <span class="T7">.bas</span>.</p><p class="Standard">BASIC! checks to see if the current program in the Editor has been changed when <span class="T17">Load</span> is tapped. You will be offered the opportunity to save the program if it has been changed. If you choose to save the program, <span class="T17">Load</span> will restart after the save is done.</p><p class="Standard">The "BASIC! Load File" screen shows the path to your current directory followed by sorted lists of the subdirectories and program files in it. Directories are denoted by the <span class="T7">(d)</span> appended to the name. BASIC! programs are shown with the <span class="T7">.bas</span> extension. If there are files in the directory that do not have the <span class="T7">.bas</span> extension, they do not appear in the list.</p><p class="Standard">Tap on a <span class="T7">.bas</span> file to load it into the Editor.</p><p class="No_20_Spacing">You can navigate to any directory on your device for which you have <span class="T7">read</span> permission.</p><ul><li><p class="P23" style="margin-left:1.27cm;"><span class="ListLabel_20_81" style="display:block;float:left;min-width:0.635cm;"></span>Tap on a directory to display its contents.<span class="odfLiEnd"/> </p></li><li><p class="P23" style="margin-left:1.27cm;"><span class="ListLabel_20_81" style="display:block;float:left;min-width:0.635cm;"></span>Tap on the "<span class="T7">..</span>" at the top of list to move up one directory level. The tap has no effect if the current directory is the device root directory "<span class="T7">/</span>".<span class="odfLiEnd"/> </p></li></ul><p class="Standard">You can exit the <span class="T17">Load</span> option without loading a program by tapping the BACK key.</p><p class="Standard">BASIC! remembers the path to the directory you are in when you load a program. Next time you select <span class="T17">Load</span>, it starts in that directory. If you select <span class="T17">Save</span> or <span class="T17">Save and Run</span>, the file is saved in the remembered directory (unless it is Sample_Programs).</p><h4 class="Heading_20_4"><a id="a__Save"><span/></a>Save</h4><p class="Standard">Saves the program currently in the editor.</p><p class="Standard">A dialog box displays the path to the directory where you will save the file and an input area where you can enter the file name. If the current program has a name because it was previously loaded or saved then that name will be in the text input area. Type in the name you want the file saved as and tap <span class="T7">OK</span>. The extension <span class="T7">.bas</span> will be added to file name if is not already there.</p><p class="Standard">If you do not enter a file name, BASIC! uses a default filename, <span class="T7">default.bas</span>.</p><p class="Standard">BASIC! remembers the path to the directory you were in when you last loaded or saved a program. When you <span class="T17">Save</span>, the file name you type is saved in the remembered directory. If the name you type includes subdirectories, BASIC! remembers the new path. The name you type can include "<span class="T7">../</span>". Be careful if you are using a soft keyboard, as it may automatically insert spaces that you don’t want.</p><p class="Standard">You cannot save programs in the sample program directory <span class="T7">source/Sample_Programs</span>. If you load a program from <span class="T7">source/Sample_Programs</span>, change it, and <span class="T17">Save</span> it, the program is saved in <span class="T7">source</span>.</p><p class="Standard">You can exit <span class="T17">Save</span> without saving a file by tapping the BACK key.</p><h4 class="Heading_20_4"><a id="a__Clear"><span/></a>Clear</h4><p class="Standard">Clear the current program in the Editor. You will be offered the opportunity to save the current program if it has been changed.</p><h4 class="Heading_20_4"><a id="a__Search"><span/></a>Search</h4><p class="Standard">Search for strings in the program being edited. Found strings may be replaced with a different string.</p><p class="Standard">The Search view shows a Text Window with the text from the Editor, a <span class="T7">Search For</span> field and a <span class="T7">Replace With</span> field.</p><p class="Standard">If there is a block of text currently selected in the Editor, then that text will be placed into the <span class="T7">Search For</span> field.</p><p class="Standard">The initial location of the search cursor will be at the start of the text regardless of where the cursor was in the Editor text.</p><p class="Standard">Note: The search ignores case. For example, searching for "basic" will find "BASIC" This is because BASIC! converts the whole program to lower case (except characters within quotes) when the program is run.</p><h5 class="Heading_20_5"><a id="a__Next_Button"><span/></a>Next Button</h5><p class="Standard">Start the search for the string in the <span class="T7">Search For</span> field. The search is started at the current cursor location. If the string is found then it will be selected in <span class="T7">Text Window</span>.</p><p class="Standard">If the <span class="T7">Done</span> button is tapped at this point then the Editor will returned to with the found text selected.</p><p class="Standard">If the <span class="T7">Replace</span> button is tapped then the selected text will be replaced.</p><p class="Standard">Pressing the <span class="T7">Next</span> button again will start a new search starting at the end of the selected or replaced text.</p><p class="Standard">If no matching text is found then a "string not found" message is shown. Tapping the <span class="T7">Done</span> button returns to the Editor with the cursor at the end of the program. Alternatively, you could change the <span class="T7">Search For</span> text and start a new search.</p><h5 class="Heading_20_5"><a id="a__Replace_Button"><span/></a>Replace Button</h5><p class="Standard">If <span class="T7">Next</span> has found and selected some text then that text is replaced by the contents of the <span class="T7">Replace With</span> field.</p><p class="Standard">If no text has been found then the message, "Nothing found to replace" will be shown.</p><h5 class="Heading_20_5"><a id="a__Replace_All_Button"><span/></a>Replace All Button</h5><p class="Standard">All occurrences of the <span class="T7">Search For</span> text are replaced with the <span class="T7">Replace With</span> text. <span class="T7">Replace All</span> always starts at the start of the text. The last replaced item will be shown selected in the <span class="T7">Text Window</span>. The number of items replaced will be shown in a message.</p><h5 class="Heading_20_5"><a id="a__Done_Button"><span/></a>Done Button</h5><p class="Standard">Returns to the Editor with the changed text. If there is selected text in the <span class="T7">Text Window</span> then that text will be shown selected in the Editor.</p><h5 class="Heading_20_5"><a id="a__BACK_Key"><span/></a>BACK Key</h5><p class="Standard">Returns to the Editor with the original text unchanged. All changes made during the Search will be undone. Think of the BACK key as UNDO ALL.</p><h4 class="Heading_20_4"><a id="a__Load_and_Run"><span/></a>Load and Run</h4><p class="Standard">Selecting this option is exactly the same as first selecting <span class="T17">Load</span> and then selecting <span class="T17">Run</span>. The selected program is loaded into the Editor and is run immediately.</p><h4 class="Heading_20_4"><a id="a__Save_and_Run"><span/></a>Save and Run</h4><p class="Standard">Selecting this option is a fast way to save and then run. Any changes you have made are saved, overwriting your file, and your program is run immediately. A brief popup notifies you that your file has been changed. If the program you are editing has no name (not previously loaded or saved), the Editor will ask you what name to use.</p><h4 class="Heading_20_4"><a id="a__Format"><span/></a>Format</h4><p class="Standard">Format the program currently in the Editor. The keywords are capitalized. Program lines are indented as appropriate for the program structure. Left- and right-double quotation marks (<span class="T7">“</span> and <span class="T7">”</span>) are replaced by simple ASCII quotation marks (<span class="T7">"</span>).</p><p class="Standard">When copying program text from the Forum or another web site, "non-breaking space" characters, designated <span class="T7">&amp;nbsp</span> in HTML, may be inserted into the program text. Except when they are enclosed in quoted strings, <span class="T7">Format</span> converts these characters to simple ASCII spaces.</p><h4 class="Heading_20_4"><a id="a__Delete"><span/></a>Delete</h4><p class="Standard">Delete files and directories. The command should be used for maintaining files and directories that are used in BASIC! but it can also be used to delete any file or directory on the SD card for which you have the required permissions. <span class="T17">Delete</span> starts in the <span class="T7">rfo-basic</span> directory.</p><p class="Standard">Tapping <span class="T17">Delete</span> presents the "BASIC! Delete File" screen. The screen shows the path to your current directory followed by sorted lists of the directories and files in it. Directories are marked with <span class="T7">(d)</span> appended to the name and appear at the top of the list.</p><p class="Standard">Tapping a file name displays the "Confirm Delete" dialog box. Tap the <span class="T7">Delete</span> button to delete the file. Tap the <span class="T7">No</span> button to dismiss the dialog box and not delete the file.</p><p class="Standard">Tapping a directory name displays the contents of the directory. If the directory is empty the "Confirm Delete" dialog box is shown. Tap the <span class="T7">Delete</span> button to delete the directory. Tap the <span class="T7">No</span> button to dismiss the dialog box and not delete the directory.</p><p class="Standard">Tap the "<span class="T7">..</span>" at the top of the screen to move up one directory level. Tapping the "<span class="T7">..</span>" has no effect if you are in the root directory "<span class="T7">/</span>".</p><p class="Standard">Exit <span class="T17">Delete</span> by tapping the BACK key.</p><h4 class="Heading_20_4"><a id="a__Preferences"><span/></a>Preferences</h4><h5 class="Heading_20_5"><a id="a__Screen_Colors"><span/></a>Screen Colors</h5><p class="Standard">Opens a sub-menu with options for setting the colors of the various screens in BASIC!</p><h5 class="P19"><a id="a__Color_Scheme"><span/></a>Color Scheme</h5><p class="P94">Sets the color scheme of the screens. The schemes are identified by their appearance with the default colors. Choose Black text on a White background, White text on a Black background or White text on a Blue background.</p><h5 class="P19"><a id="a__Custom_Colors"><span/></a>Custom Colors</h5><p class="P94">Check the box to override the Color Scheme setting, allowing you to set your own colors. You can set the Text (foreground) Color, the Background Color, the Line Color, and the Highlight Color. Each color is specified as a single number with 16 hexadecimal digits: four fields of four digits each for Alpha (opacity), Red, Green, and Blue components.</p><h5 class="Heading_20_5"><a id="a__Console_Settings"><span/></a>Console Settings</h5><p class="Standard">Opens a sub-menu with options for settings of the Console and various others screens in BASIC!</p><h5 class="P19"><a id="a__Font_Size"><span/></a>Font Size</h5><p class="P94">Sets the font size (Small, Medium, or Large) to be used with the various screens in BASIC!.</p><h5 class="P19"><a id="a__Typeface"><span/></a>Typeface</h5><p class="P94">Choose the typeface to be used on the Output Console and some other screens:<br/>Monospace, Sans Serif, or Serif.</p><h5 class="P19"><a id="a__Console_Menu"><span/></a>Console Menu</h5><p class="P94">Check the box if the Menu should be visible in the Output Console and TGet screen.</p><h5 class="P19"><a id="a__Console_Lines"><span/></a>Console Lines</h5><p class="P94">Check the box if the text lines in the Output Console should be underlined.</p><h5 class="P19"><a id="a__Empty_Console_Color"><span/></a>Empty Console Color</h5><p class="P94">Choose the background color of the part of the Output Console that has not yet been written. It can match the background color of the text or the color of the lines separating text lines.</p><p class="P94">This setting also applies to the <span class="T7">Select</span> (but not <span class="T7">Dialog.select</span>) command.</p><h5 class="Heading_20_5"><a id="a__Editor_Settings"><span/></a>Editor Settings</h5><p class="Standard">Opens a sub-menu with options for setting properties and features of the Program Editor.</p><h5 class="P19"><a id="a__Editor_Lines"><span/></a>Editor Lines</h5><p class="P94">Check the box if the text lines in the Editor should be underlined.</p><h5 class="P19"><a id="a__Editor_Line_Wrap"><span/></a>Editor Line Wrap</h5><p class="P94">Check the box if long text lines in the Editor should wrap at the edge of the screen. If unchecked, long lines are not wrapped, and the Editor screen may be scrolled horizontally.</p><h5 class="P19"><a id="a__Editor_AutoIndent"><span/></a>Editor AutoIndent</h5><p class="P94">Check the box if you want the Editor to do auto indentation. Enabling auto indentation also enables the formatting of a line that ends with the "#" character.</p><p class="P94">Some devices are not able to do auto indenting properly. In some of those devices the AutoIndent feature may cause the Editor to be unusable. If that happens, turn off AutoIndent.</p><h5 class="Heading_20_5"><a id="a__Menu_Items_on_Action_Bar"><span/></a>Menu Items on Action Bar</h5><p class="Standard">Opens a sub-menu with options for moving some of the Editor menu items to the Action Bar, if there is room for them there. You can select as many as you like, but the number of items moved depends on the device and orientation. These options have no effect on Android devices before Honeycomb (3.0).</p><h5 class="P19"><a id="a__RUN_on_action_bar"><span/></a>RUN on action bar</h5><p class="P94">If checked, the Editor will attempt to move the <span class="T23">Run</span> item from the Menu to the Action Bar.</p><h5 class="P19"><a id="a__LOAD_on_action_bar"><span/></a>LOAD on action bar</h5><p class="P94">If checked, the Editor will attempt to move the <span class="T23">Load</span> item from the Menu to the Action Bar.</p><h5 class="P19"><a id="a__SAVE_on_action_bar"><span/></a>SAVE on action bar</h5><p class="P94">If checked, the Editor will attempt to move the <span class="T23">Save</span> item from the Menu to the Action Bar.</p><h5 class="P19"><a id="a__EXIT_on_action_bar"><span/></a>EXIT on action bar</h5><p class="P94">If checked, the Editor will attempt to move the <span class="T23">Exit</span> item from the Menu to the Action Bar.</p><h5 class="Heading_20_5"><a id="a__Screen_Orientation"><span/></a>Screen Orientation</h5><p class="Standard">Choose to allow the Sensors to determine the orientation of the screens or to set a fixed orientation without regard to the Sensors.</p><p class="Standard">Note: The reverse orientations apply to Android 2.3 or newer.</p><h5 class="Heading_20_5"><a id="a__Graphic_Acceleration"><span/></a>Graphic Acceleration</h5><p class="Standard">Check this box to enable GPU-assisted graphics acceleration on devices since 3.0 (Honeycomb) that support it. It is disabled by default. If you enable this option, test your program carefully. Hardware acceleration can make some of BASIC!’s graphical operations fail.</p><h5 class="Heading_20_5"><a id="a__Base_Drive"><span/></a>Base Drive</h5><p class="Standard">Some Android devices have several external storage devices (and some have no physical external storage devices). BASIC! will use the system-suggested device as its base drive. The <span class="T18">base drive</span> is the device where the BASIC! "rfo-basic" directory (base directory) is located. The <span class="T18">base directory</span> is where BASIC!’s programs and data are stored. (See "Working with Files", later in this manual.)</p><p class="Standard">If your device does have more than one external storage device they will be listed here. If your device has no external storage devices, your one and only choice will be "No external storage". Tap the device you want to use as the base drive and press the BACK key. You will then be given the choice of either immediately restarting BASIC! with the new base drive or waiting and doing the restart yourself.</p><p class="Standard">In this manual, &lt;pref base drive&gt; means the base drive you selected when you set the Base Drive here.</p><p class="Standard">Note: If you have created a Launcher Shortcut (see Appendix C) with files in one base directory but try to execute that shortcut while using a different base directory, the shortcut will fail to execute.</p><h4 class="Heading_20_4"><a id="a__Commands"><span/></a>Commands</h4><p class="Standard">The Commands command presents the list of the BASIC! commands and functions as copied from Appendix A of this document.</p><p class="Standard">Tapping an alpha key will cause the command list to scroll to commands that start with that character. There will be no scrolling if there is no command that starts with that character.</p><p class="Standard">Note: You can hide the virtual keyboard with the BACK key. If you do that, you will not be able to get it back until you invoke the <span class="T17">Commands</span> option again.</p><p class="Standard">Tapping on a particular command causes that command to be copied to the clipboard (not including the page number) and returning to the Editor. You can then paste the command into your BASIC! program.</p><h4 class="Heading_20_4"><a id="a__About"><span/></a>About</h4><p class="Standard">The <span class="T17">About</span> option displays the version of BASIC! that you are using, followed by a set of buttons that connect you to various websites with information about BASIC!. Make sure that you have a connection to the Internet before selecting one of the <span class="T17">About</span> buttons.</p><h5 class="Heading_20_5"><a id="a__BASIC!_Home_Page"><span/></a>BASIC! Home Page</h5><p class="Standard">Opens the BASIC! home page, <a href="http://rfo-basic.com" class="Internet_20_link"><span class="Internet_20_link">http://rfo-basic.com</span></a>.</p><h5 class="Heading_20_5"><a id="a__BASIC!_User_Forum"><span/></a>BASIC! User Forum</h5><p class="Standard">Opens the BASIC! user forum site, <a href="http://rfobasic.freeforums.org" class="Internet_20_link"><span class="Internet_20_link">http://rfobasic.freeforums.org</span></a>.</p><h5 class="Heading_20_5"><a id="a__BASIC!_Users’_Programs"><span/></a>BASIC! Users’ Programs</h5><p class="Standard">Opens a repository of BASIC! programs written by members of the BASIC! user forum, hosted by the founder of BASIC, Paul Laughton. The programs are found at <a href="http://laughton.com/basic/programs" class="Internet_20_link"><span class="Internet_20_link">http://laughton.com/basic/programs</span></a>.</p><h5 class="Heading_20_5"><a id="a__BASIC!_on_Bintray"><span/></a><a id="_BASIC!_on_Bintray"/>BASIC! on Bintray</h5><p class="Standard">Opens the BASIC! page of the binary hosting site Bintray, <a href="https://bintray.com/rfo-basic/android/RFO-BASIC" class="Internet_20_link"><span class="Internet_20_link">https://bintray.com/rfo-basic/android/RFO-BASIC</span></a>. At this site, you can download this manual in PDF format and the Android installable (.apk file) for both the Full Edition and the Google Play Edition of BASIC!. You can also download previous versions and read the release notes for each version.</p><h5 class="Heading_20_5"><a id="a__BASIC!_on_GitHub"><span/></a>BASIC! on GitHub</h5><p class="Standard">Opens the BASIC! page of the software development site GitHub, <a href="https://github.com/RFO-BASIC" class="Internet_20_link"><span class="Internet_20_link">https://github.com/RFO-BASIC</span></a>. At this site you can download the source for every version of BASIC! since v01.69. You can also download the "source" for this manual, as a Microsoft™ Word™ document, for each version.</p><h5 class="Heading_20_5"><a id="a__BASIC!_Open-Source_License"><span/></a>BASIC! Open-Source License</h5><p class="Standard">Displays the GPLv3 license under which BASIC! is distributed. This copy of the license is hosted at <a href="https://www.gnu.org/licenses/gpl-3.0-standalone.html" class="Internet_20_link"><span class="Internet_20_link">https://www.gnu.org/licenses/gpl-3.0-standalone.html</span></a>. This license is reproduced in Appendix E of this manual.</p><h5 class="Heading_20_5"><a id="a__BASIC!_Privacy_Policy"><span/></a>BASIC! Privacy Policy</h5><p class="Standard">Displays the BASIC! Privacy Policy. Installing BASIC! requires several Android permissions, some of which Google considers sensitive. The BASIC! program interpreter does not use any of these permissions. Except for limited use by the Editor, these permissions are requested only to enable your BASIC! programs to use the full power of the Android platform. This is explained in the Privacy Policy, which is hosted at <a href="http://rfo-basic.com/PrivacyPolicy.html" class="Internet_20_link"><span class="Internet_20_link">http://rfo-basic.com/PrivacyPolicy.html</span></a>.</p><h4 class="Heading_20_4"><a id="a__Exit"><span/></a>Exit</h4><p class="Standard">The only way to cleanly exit BASIC! is to use the <span class="T17">Exit</span> option.</p><p class="Standard">Pressing the HOME key while in BASIC! leaves BASIC! in exactly the same state it was in when the HOME key was tapped. If a program was running, it will still be running when BASIC! is re-entered. If you were in the process of deleting, the Delete screen will be shown when BASIC! is re-entered.</p><h2 class="Heading_20_2"><a id="a__Run"><span/></a><a id="_Toc5235706"/>Run</h2><p class="Standard">Selecting <span class="T17">Run</span> from the Editor’s menu starts the program running. However, if the source in the Editor has been changed, then the Save dialog will be displayed. You may choose to save the changed source or continue without saving.</p><p class="Standard">The BASIC! Output Console will be presented as soon as the program starts to run. You will not see anything on this screen unless one of the following situations occur:</p><ul><li><p class="P24" style="margin-left:1.27cm;"><span class="ListLabel_20_1" style="display:block;float:left;min-width:0.635cm;"></span>the program prints something<span class="odfLiEnd"/> </p></li><li><p class="P24" style="margin-left:1.27cm;"><span class="ListLabel_20_1" style="display:block;float:left;min-width:0.635cm;"></span>the <span class="T7">END</span> statement is executed<span class="odfLiEnd"/> </p></li><li><p class="P24" style="margin-left:1.27cm;"><span class="ListLabel_20_1" style="display:block;float:left;min-width:0.635cm;"></span>you are in Echo mode<span class="odfLiEnd"/> </p></li><li><p class="P24" style="margin-left:1.27cm;"><span class="ListLabel_20_1" style="display:block;float:left;min-width:0.635cm;"></span>there is a run-time error<span class="odfLiEnd"/> </p></li></ul><p class="Standard">If the program does not print anything then the only indication you would get that the program has finished is if the program ends with an <span class="T7">End</span> statement.</p><p class="Standard">If the program does not contain any executable statements then the message, "Nothing to execute" will be displayed.</p><p class="Standard">Tapping the BACK key will stop a running program. Tapping the BACK key when the program run has ended will restart the Editor.</p><p class="Standard">If the program ended with a run-time error, the line where the error occurred will be shown selected in the Editor. If the error occurred in an <span class="T7">INCLUDE</span> file then the <span class="T7">INCLUDE</span> statement will be shown selected.</p><p class="Standard">The Editor cursor will remain where it was when the <span class="T17">Run</span> was started if no run-time error occurred.</p><h3 class="Heading_20_3"><a id="a__Menu"><span/></a><a id="_Toc5235707"/>Menu</h3><p class="Standard">Pressing the MENU key or touching the Menu icon while a program is running or after the program is stopped will cause the Run Menu to be displayed. (Except when Graphics is running. See the Graphics section for details.)</p><h4 class="Heading_20_4"><a id="a__Stop"><span/></a>Stop</h4><p class="Standard">If a program is running, the <span class="T17">Stop</span> menu item will be enabled. Tapping <span class="T17">Stop</span> will stop the running program. <span class="T17">Stop</span> will not be enabled if a program is not running.</p><h4 class="Heading_20_4"><a id="a__Editor"><span/></a>Editor</h4><p class="Standard"><span class="T17">Editor</span> will not be enabled if a program is running. If the program has stopped and <span class="T17">Editor</span> is thus enabled then selecting <span class="T17">Editor</span> will cause the Editor to be re-entered. You could also use the BACK key to do this.</p><h2 class="Heading_20_2"><a id="a__Crashes"><span/></a><a id="_Toc5235708"/>Crashes</h2><p class="Standard">BASIC! is a very large and complex program that is constantly under development. From time to time, it will crash. The best way to report a crash is to visit the BASIC! forum.</p><h1 class="Heading_20_1"><a id="a__A_BASIC!_Program"><span/></a><a id="_Toc5235709"/>A BASIC! Program</h1><p class="Standard">A BASIC! program is made up of lines of text. With a few exceptions that will be explained later, each line of text is one or more <span class="T7">statements</span>. If a line has more than one statement they are separated by colon (":") characters.</p><p class="Standard">A statement always consists of a single command, usually followed by one or more parameters that are separated by commas. Here is a simple BASIC! program:</p><p class="Code_20_example"><span class="T11">PRINT "Hello, World!"</span></p><p class="Standard">This program has one statement. The command is <span class="T7">PRINT</span>. It has one parameter, the string constant <span class="T7">"Hello, World!"</span>. (A string constant, or string literal, is a set of characters enclosed in double quotation marks. This, too, will be explained later.)</p><p class="Standard">If you start the BASIC! app, so you are in the Editor, you can type in this one-line program. Then you can select <span class="T7">Run</span> from the Editor’s menu. BASIC! will run your program. When the program is done running, you see the <span class="T7">Console</span>, BASIC!’s, output screen, with <span class="T7">Hello, World!</span> printed at the top.</p><h1 class="Heading_20_1"><a id="a__Command_Description_Syntax"><span/></a><a id="_Toc5235710"/>Command Description Syntax</h1><h2 class="Heading_20_2"><a id="a__Upper_and_Lower_Case"><span/></a><a id="_Toc5235711"/>Upper and Lower Case</h2><p class="Standard">Commands are described using both upper and lower case for ease of reading. BASIC! converts every character (except those between double quotation marks) to lower case when the program is run.</p><h2 class="Heading_20_2"><a id="a___nexp____sexp__and__lexp_"><span/></a><a id="_Toc5235712"/>&lt;nexp&gt;, &lt;sexp&gt; and &lt;lexp&gt;</h2><p class="Standard">These notations denote a numeric expression (&lt;nexp&gt;), a string expression (&lt;sexp&gt;), and a logical expression (&lt;lexp&gt;). An expression can be a variable, a number, a quoted string or a full expression such as (a*x^2 + bx + c).</p><h2 class="Heading_20_2"><a id="a___nvar____svar__and__lvar_"><span/></a><a id="_Toc5235713"/>&lt;nvar&gt;, &lt;svar&gt; and &lt;lvar&gt;</h2><p class="Standard">This notation is used when a variable, not an expression, must be used in the command. Arrays with indices (such as n[1,2] or s$[3,4]) are considered to be the same as &lt;nvar&gt;, &lt;svar&gt; and &lt;lvar&gt;.</p><h2 class="Heading_20_2"><a id="a__Array___and_Array$__"><span/></a><a id="_Toc5235714"/>Array[] and Array$[]</h2><p class="Standard">This notation implies that an array name without indices must be used.</p><h2 class="Heading_20_2"><a id="a__Array_{_start___length_}__and_Array$_{_start___length_}_"><span/></a><a id="_Toc5235715"/>Array[{&lt;start&gt;,&lt;length&gt;}] and Array$[{&lt;start&gt;,&lt;length&gt;}]</h2><p class="Standard">In most contexts, numeric expressions inside the brackets are indices specifying a single array element. In some commands, a pair of numeric expressions specifies a segment of the array. Both the start index and length are numeric expressions, and both are optional. This notation is shorthand for:</p><p class="Code_20_example"><span class="T11">Array [ { {&lt;start_nexp&gt;} {, &lt;length_nexp&gt;} } ]</span></p><p class="Code_20_example"><span class="T11">Array$ [ { {&lt;start_nexp&gt;} {, &lt;length_nexp&gt;} } ]</span></p><h2 class="Heading_20_2"><a id="a__{something}"><span/></a><a id="_Toc5235716"/>{something}</h2><p class="Standard">Indicates something optional.</p><h2 class="Heading_20_2"><a id="a__{_A_|_B_|C_}"><span/></a><a id="_Toc5235717"/>{ A | B |C }</h2><p class="Standard">This notation suggests that a choice of either A, B, or C, must be made. For example:</p><p class="Code_20_example"><span class="T11">Text.open {r|w|a}, fn…</span></p><p class="Standard">Indicate that either "r" or "w" or "a" must be chosen:</p><p class="Code_20_example"><span class="T11">Text.open r, fn…</span></p><p class="Code_20_example"><span class="T11">Text.open w, fn…</span></p><p class="Code_20_example"><span class="T11">Text.open a, fn…</span></p><h2 class="Heading_20_2"><a id="a__X_____"><span/></a><a id="_Toc5235718"/>X, ...</h2><p class="Standard">Indicates a variable-sized list of items separated by commas. At least one item is required.</p><h2 class="Heading_20_2"><a id="a__{_n}____"><span/></a><a id="_Toc5235719"/>{,n} ...</h2><p class="Standard">Indicates an optional list with zero or more items separated by commas.</p><h2 class="Heading_20_2"><a id="a___statement_"><span/></a><a id="_Toc5235720"/>&lt;statement&gt;</h2><p class="Standard">Indicate an executable BASIC! statement. A &lt;statement&gt; is usually a line of code but may occur within other commands such as: <span class="T7">IF</span> &lt;lexp&gt; <span class="T7">THEN</span> &lt;statement&gt;.</p><h2 class="Heading_20_2"><a id="a__Optional_Parameters"><span/></a><a id="_Toc5235721"/>Optional Parameters</h2><p class="Standard">Many statements have optional parameters. If an optional parameter is omitted, the statement assumes a default value or performs a default action.</p><p class="Standard">If an optional parameter is omitted, use a comma to mark its place, so following parameters are handled correctly. However, if there are no following parameters, omit the comma, too. With a few special exceptions (like <span class="T7">Print</span>), no statement can end with a comma.</p><h1 class="Heading_20_1"><a id="a__Numbers"><span/></a><a id="_Toc5235722"/>Numbers</h1><p class="No_20_Spacing">You can type decimal numbers in a BASIC! program:</p><ul><li><p class="P25" style="margin-left:1.27cm;"><span class="ListLabel_20_97" style="display:block;float:left;min-width:0.635cm;"></span>A leading sign ("+" or "-"), a decimal point ("." only), and an exponent (power of 10) are optional.<span class="odfLiEnd"/> </p></li><li><p class="P25" style="margin-left:1.27cm;"><span class="ListLabel_20_97" style="display:block;float:left;min-width:0.635cm;"></span>An exponent is "e" or "E" followed by a number. The number may have a sign but no decimal point.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">If you use a decimal point, it MUST follow a digit. 0.15 is a valid number, but .15 is a syntax error.</p><p class="Standard">Numbers in BASIC! are double-precision floating point (64-bit IEEE 754). This means:</p><ul><li><p class="P68" style="margin-left:1.27cm;"><span class="ListLabel_20_12" style="display:block;float:left;min-width:0.635cm;"></span>A printed number will always have decimal point. For example, 99 will print as "99.0".You can print numbers without decimal points by using the INT$() or FORMAT$() functions. For example, either INT$(99) or FORMAT$("##", 99) will print "99".<span class="odfLiEnd"/> </p></li><li><p class="P68" style="margin-left:1.27cm;"><span class="ListLabel_20_12" style="display:block;float:left;min-width:0.635cm;"></span>A number with more than 7 significant digits will be printed in floating point format. For example, the number 12345678 will be printed as 1.2345678E7. INT$() or FORMAT$() can be used to print large numbers in other than floating point format.<span class="odfLiEnd"/> </p></li><li><p class="P68" style="margin-left:1.27cm;"><span class="ListLabel_20_12" style="display:block;float:left;min-width:0.635cm;"></span>Mathematical operations on decimal values are imprecise. If you are working with currency you should multiply the number by 100 until you need to print it out. When you print it, divide by 100.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">A logical value (false = 0, true &lt;&gt; 0) is a kind of number.</p><p class="Standard">You can use string functions to convert numbers to strings. STR$(), INT$(), HEX$() and a few others do simple conversions. FORMAT$() and USING$() can do more complex formatting.</p><p class="Standard">For the purposes of this documentation, numbers that appear in a BASIC! program are called Numeric Constants.</p><h1 class="Heading_20_1"><a id="a__Strings"><span/></a><a id="_Toc5235723"/>Strings</h1><p class="Standard">Strings in BASIC! are written as any set of characters enclosed in quote (") characters. The quote characters are not part of the string. For example, <span class="T7">"This is a string"</span> is a string of 16 characters.</p><p class="Standard">To include the quote character in a string, you must escape it with a backslash: <span class="T7">\"</span>. For example:</p><p class="Code_20_example"><span class="T11">Print "His name is \"Jimbo\" Jim Giudice."</span></p><p class="Standard">prints: His name is "Jimbo" Jim Giudice.</p><p class="Standard">Newline characters may be inserted into a string with the escape sequence <span class="T7">\n</span>:</p><p class="P5"><span class="T11">Print "Jim\nGiudice"</span></p><p class="Standard">prints:</p><p class="Code_20_example"><span class="T11">Jim</span></p><p class="Code_20_example"><span class="T11">Giudice</span></p><p class="Standard">"\n" can mean different things on different systems. In BASIC!, it is the same as an ASCII LF (line feed) character.</p><p class="Standard">You can use another escape sequence, <span class="T7">\t</span>, to put a TAB character into a string. To embed a backslash, escape it with another backslash: <span class="T7">\\</span>. Other special characters can be inserted using the <span class="T7">CHR$()</span> function.</p><p class="Standard">Strings with numerical characters can be converted to BASIC! numbers using the <span class="T7">VAL(&lt;sexp&gt;)</span> function.</p><p class="Standard">For the purposes of this documentation, strings that appear within a BASIC! program are called String Constants.</p><h1 class="Heading_20_1"><a id="a__Variables"><span/></a><a id="_Toc5235724"/>Variables</h1><p class="Standard">A BASIC! variable is a container for some numeric or string value.</p><h2 class="Heading_20_2"><a id="a__Variable_Names"><span/></a><a id="_Toc5235725"/>Variable Names</h2><p class="Standard">Variable names must start with the characters "a" through "z", "#", "@", or "_". The remaining characters in the variable name may also include the digits, "0" through "9".</p><p class="Standard">A variable name may be as long as needed.</p><p class="Standard">Upper case characters can be used in variable names but they will be converted to lower case characters when the program is run. The variable name "gLoP" is the same as the name "glop" to BASIC!</p><p class="Standard">You should avoid using variable names that start with BASIC! command keywords. Such variables are valid under most conditions, as will be explained later in ths manual, but their use may cause confusion or errors. For example, <span class="T7">Donut = 5</span> is interpreted as <span class="T7">Do Nut=5</span>. BASIC! thus expects this <span class="T7">Do</span> statement to be followed by an <span class="T7">Until</span> statement somewhere before the program ends. A list of BASIC! commands can be found in <span class="T7">Appendix A</span>. See also the <span class="T7">Let</span> command and the <span class="T7">Expressions </span><span class="T25"></span><span class="T7"> Parentheses</span> section.</p><p class="Standard">BASIC! statement labels and the names of user-defined functions, both described later in this manual, follow the same naming rules as BASIC! variables.</p><h2 class="Heading_20_2"><a id="a__Variable_Types"><span/></a><a id="_Toc5235726"/>Variable Types</h2><p class="Standard">There are two types of variables: Variables that hold numbers and variables that hold strings. Variables that hold strings end with the character "$". Variables that hold numbers do not end in "$".</p><p class="Standard"><span class="T7">Age</span>, <span class="T7">amount</span> and <span class="T7">height</span> are all numeric variable names.</p><p class="Standard"><span class="T7">First_Name$</span>, <span class="T7">Street$</span> and <span class="T7">A$</span> are all string variable names.</p><p class="Standard">If you use a numeric variable without assigning it a value, it has the value 0.0. If you use a string variable without assigning it a value, its value is the empty string, "".</p><h2 class="Heading_20_2"><a id="a__Scalar_and_Array_Variables"><span/></a><a id="_Toc5235727"/>Scalar and Array Variables</h2><p class="Standard">There are two classes of variables: Scalars and Arrays.</p><h2 class="Heading_20_2"><a id="a__Scalars"><span/></a><a id="_Toc5235728"/>Scalars</h2><p class="Standard">A scalar is a variable that can hold only one value. When a scalar is created it is assigned a default value. Numeric scalars are initialized to 0.0. String scalars are initialized to an empty, zero-length string, "".</p><p class="Standard">You create a scalar variable just by using its name. You do not need to predeclare scalars.</p><h2 class="Heading_20_2"><a id="a__Arrays"><span/></a><a id="_Toc5235729"/>Arrays</h2><p class="Standard">An array is variable that can hold many values organized in a systematically arranged way. The simplest array is the linear array. It can be thought of as a list of values. The array A[index] is a linear array. It can hold values that can accessed as A[1], A[2],...,A[n]. The number (variable or constant) inside the square brackets is called the index.</p><p class="Standard">If you wanted to keep a list of ten animals, you could use an array called Animals$[] that can be accessed with an index of 1 to 10. For example: Animals$[5] = "Cat"</p><p class="Standard">Arrays can have more than one index or dimension. An array with two dimensions can be thought of as a list of lists. Let’s assume that we wanted to assign a list of three traits to every animal in the list of animals. Such a list for a "Cat" might be "Purrs", "Has four legs" and "Has Tail". We could set up the Traits array to have two dimensions such that Traits$[5,2] = "Has four legs". If someone asked what are the traits of cat, search Animals$[index] until "Cat" is found at index =5. Index=5 can then be used to access Traits[index,[ {1|2|3}].</p><p class="Standard">BASIC! arrays can have any number of dimensions of any size.</p><p class="Standard">BASIC! arrays are "one-based". This means that the first element of an array has an index of "1". Attempting to access an array with an index of "0" (or less than 0) will generate a run-time error.</p><p class="Standard">Before an array can be used, it must be dimensioned using the <span class="T7">DIM</span> command. The <span class="T7">DIM</span> command tells BASIC! how many indices are going to be used and the sizes of the indices. Some BASIC! Commands automatically create a one-dimensional array. Auto-dimensioned array details will be seen in the description of those commands.</p><p class="Standard">Note: It is recommended that the List commands (see below) be used in place of one-dimensional arrays. The List commands provide more versatility than the Array commands.</p><h3 class="Heading_20_3"><a id="a__Array_Segments"><span/></a><a id="_Toc5235730"/>Array Segments</h3><p class="Standard">Some BASIC! Commands take an array as an input parameter. If the array is specified with nothing in the brackets (for example, "Animals$[]"), then the command reads the entire array.</p><p class="Standard">Most of these commands allow you to limit their operation to a segment of the array, using the notation "Array[start, length]", where both "start" and "length" are numeric expressions.</p><p class="Standard">For example, you can write "Animals$[2,3]". Usually that means "the animal at row 2 and column 3 of a two dimensional array called Animals$". When used to specify an array segment, it has a different meaning: "read only the segment of the Animals$ array that starts at index 2 and includes 3 items". Notice that this notation applies only to one-dimensional arrays. In fact, it treats all arrays as one-dimensional, regardless of how they are declared.</p><p class="Standard">Both of the expressions in the "[start, length]" pair are optional. If the "start" value is omitted, the default starting index is 1. If the "length" value is omitted, the default is the length from the starting index to the end of the array. If both are omitted, the default is to use the entire array.</p><h3 class="Heading_20_3"><a id="a__Array_Commands"><span/></a><a id="_Toc5235731"/>Array Commands</h3><p class="Standard">These commands all operate on Arrays. Commands operate on both numeric and string arrays, unless otherwise indicated.</p><h4 class="Heading_20_4"><a id="a__Dim_Array__nexp_{___nexp__}_______{__Array__nexp_{___nexp__}_______}____"><span/></a>Dim Array[&lt;nexp&gt;{, &lt;nexp&gt; } ... ] {, Array[&lt;nexp&gt;{, &lt;nexp&gt; } ... ] } ...</h4><p class="Standard">The <span class="T7">Dim</span> command tells BASIC! how many dimensions an array will have and how big those dimensions are. BASIC! creates the array, reserving and initializing memory for the array data. All elements of a numeric array are initialized to the value 0.0. String array elements are initialized to the empty string, "". If you <span class="T7">Dim</span> an array that already exists, the existing array is destroyed and a new one created.</p><p class="Standard">Multiple arrays can be dimensioned with one <span class="T7">Dim</span> statement. String and numeric arrays can be dimensioned in a single <span class="T7">Dim</span> command.</p><p class="No_20_Spacing">Examples:</p><p class="Code_20_example"><span class="T11">DIM A[15]</span></p><p class="Code_20_example"><span class="T11">DIM B$[2,6,8], C[3,1,7,3], D[8]</span></p><h4 class="Heading_20_4"><a id="a__UnDim_Array__{__Array___}____"><span/></a>UnDim Array[]{, Array[] } ...</h4><p class="Standard">Un-dimensions an array. The array is destroyed, releasing all of the memory it used. Multiple arrays can be destroyed with one <span class="T7">UnDim</span> statement. Each Array[] is specified without any index. This command is exactly the same as <span class="T7">Array.delete</span>.</p><h4 class="Heading_20_4"><a id="a__Array_average__Average_nvar___Array_{_start___length_}_"><span/></a>Array.average &lt;Average_nvar&gt;, Array[{&lt;start&gt;,&lt;length&gt;}]</h4><p class="Standard">Finds the average of the values in a numeric array (Array[]) or array segment (Array[start,length]), and places the result into &lt;Average_nvar&gt;.</p><h4 class="Heading_20_4"><a id="a__Array_copy_SourceArray_{_start___length_}___DestinationArray_{{-}_start_or_extras_}_"><span/></a>Array.copy SourceArray[{&lt;start&gt;,&lt;length&gt;}], DestinationArray[{{-}&lt;start_or_extras&gt;}]</h4><p class="Standard">Copies elements of an existing SourceArray[] to the DestinationArray[]. If the Destination Array exists, some or all of the existing array is overwritten. If the Destination Array does not exist, a new array is created. The arrays may be either numeric or string arrays but they must both be of the same type.</p><p class="Standard">You may copy an entire array (SourceArray[]) or an array segment (SourceArray[&lt;start&gt;,&lt;length&gt;]). Copying stops without error if it reaches the end of either the SourceArray or the DestinationArray.</p><p class="Standard">If &lt;start&gt; is &lt; 1 it is set to 1, the first element of the SourceArray. If &lt;length&gt; is &lt; 0 it is set to 0.</p><p class="Standard">If the Destination Array already exists, the optional &lt;start_or_extras&gt; parameter specifies where to start copying into the Destination Array.</p><p class="Standard">If the Destination Array does not exist, the optional &lt;start_or_extras&gt; parameter specifies how many extra elements to add to the copy. If the parameter is a negative number, these elements are added to the start of the array, otherwise they are added to end of the array.</p><p class="Standard">The extra elements for a new numeric array are initialized to zero. The extra elements for a new string array are initialized to the empty string, "".</p><p class="Standard">See the Sample Program file, f26_array_copy.bas, for working examples of this command.</p><h4 class="Heading_20_4"><a id="a__Array_delete_Array__{__Array__}____"><span/></a>Array.delete Array[]{, Array[]} ...</h4><p class="Standard">Does the same thing as <span class="T7">UnDim</span> Array[].</p><h4 class="Heading_20_4"><a id="a__Array_dims_Source__{__{Dims__}{__NumDims}}"><span/></a>Array.dims Source[]{, {Dims[]}{, NumDims}}</h4><p class="Standard">Provides information about the dimensions of the Source[] array parameter. The Source[] parameter may be a numeric or string array name with nothing in the brackets ("[]"). The array must already exist. The Source[] parameter is required, and both of the other parameters are optional.</p><p class="Standard">The dimensions of the Source[] array are written to the Dims[] array, if you provide one. The Dims[] parameter must be a numeric array name with nothing in the brackets ("[]"). If the Dims[] array exists, it is overwritten. Otherwise a new array is created. The result is always a one-dimensional array.</p><p class="Standard">The number of dimensions of the Source[] array is written to the NumDims parameter, if you provide one. NumDims must be a numeric variable. This value is the length of the Dims[] array.</p><h4 class="Heading_20_4"><a id="a__Array_fill_Array_{_start___length_}____exp_"><span/></a>Array.fill Array[{&lt;start&gt;,&lt;length&gt;}], &lt;exp&gt;</h4><p class="Standard">Fills an existing array or array segment with a value. The types of the array and value must match.</p><h4 class="Heading_20_4"><a id="a__Array_length__length_nvar___Array_{_start___length_}_"><span/></a>Array.length &lt;length_nvar&gt;, Array[{&lt;start&gt;,&lt;length&gt;}]</h4><p class="Standard">Places the number of elements in an entire array (Array[] or Array$[]) or an array segment (Array[start,length] or Array$[start,length]) into &lt;Length_nvar&gt;.</p><h4 class="Heading_20_4"><a id="a__Array_load_Array_____exp______"><span/></a>Array.load Array[], &lt;exp&gt;, ...</h4><p class="Standard">Creates a new array, evaluates the list of expressions "&lt;exp&gt;, ...", and loads values into the new array. Specify the array name with no index(es). The array has one dimension; its size is the same as the number of expressions in the list. If the named array already exists, it is overwritten.</p><p class="Standard">The array may be numeric (Array[]) or string (Array$[]), and the expressions must be the same type as the array.</p><p class="Standard">The list of expressions may be continued onto the next line by ending the line with the "~" character. The "~" character may be used between &lt;exp&gt; parameters, where a comma would normally appear. The "~" itself separates the parameters; the comma is optional.</p><p class="Standard">The "~" character may not be used to split a parameter across multiple lines.</p><p class="Standard">Examples:</p><p class="Code_20_example"><span class="T11">Array.load Numbers[], 2, 4, 8 , n^2, 32</span></p><p class="Code_20_example"><span class="T11">Array.load Hours[], 3, 4,7,0, 99, 3, 66~        % comma not required before ~</span></p><p class="Code_20_example"><span class="T11">37, 66, 43, 83,~                                % comma is allowed before ~</span></p><p class="Code_20_example"><span class="T11">83, n*5, q/2 +j</span></p><p class="Code_20_example"><span class="T11">Array.load Letters$[], "a", "b","c",d$,"e"</span></p><h4 class="Heading_20_4"><a id="a__Array_max__Max_nvar__Array_{_start___length_}_"><span/></a>Array.max &lt;Max_nvar&gt; Array[{&lt;start&gt;,&lt;length&gt;}]</h4><p class="Standard">Finds the maximum value in a numeric array (Array[]) or array segment (Array[start,length]), and places the result into the numeric variable &lt;max_nvar&gt;.</p><h4 class="Heading_20_4"><a id="a__Array_min__Min_nvar___Array_{_start___length_}_"><span/></a>Array.min &lt;Min_nvar&gt;, Array[{&lt;start&gt;,&lt;length&gt;}]</h4><p class="Standard">Finds the minimum value in a numeric array (Array[]) or array segment (Array[start,length]), and places the result into the numeric variable &lt;min_nvar&gt;.</p><h4 class="Heading_20_4"><a id="a__Array_reverse_Array_{_start___length_}_"><span/></a>Array.reverse Array[{&lt;start&gt;,&lt;length&gt;}]</h4><p class="Standard">Reverses the order of values in a numeric or string array (Array[] or Array$[]) or array segement (Array[start,length] or Array$[start,length]).</p><h4 class="Heading_20_4"><a id="a__Array_search_Array_{_start___length_}____value_exp____result_nvar_{__start_nexp_}"><span/></a>Array.search Array[{&lt;start&gt;,&lt;length&gt;}], &lt;value_exp&gt;, &lt;result_nvar&gt;{,&lt;start_nexp&gt;}</h4><p class="Standard">Searches in the numeric or string array (Array[] or Array$[]) or array segment (Array[start,length] or Array$[start,length]) for the specified numeric or string value, which may be an expression. If the value is found in the array, its position will be returned in the result numeric variable &lt;result_nvar&gt;. If the value is not found the result will be zero.</p><p class="Standard">If the optional start expression parameter is present, the search will start at the specified element. The default value is 1.</p><h4 class="Heading_20_4"><a id="a__Array_shuffle_Array_{_start___length_}_}"><span/></a>Array.shuffle Array[{&lt;start&gt;,&lt;length&gt;}]}</h4><p class="Standard">Randomly shuffles the values of the specified array (Array[] or Array$[]) or array segment (Array[start,length] or Array$[start,length]).</p><h4 class="Heading_20_4"><a id="a__Array_sort_Array_{_start___length_}_}"><span/></a>Array.sort Array[{&lt;start&gt;,&lt;length&gt;}]}</h4><p class="Standard">Sorts the values of the specified array (Array[] or Array$[]) or array segment (Array[start,length] or Array$[start,length]) in ascending order.</p><h4 class="Heading_20_4"><a id="a__Array_std_dev__sd_nvar___Array_{_start___length_}_}"><span/></a>Array.std_dev &lt;sd_nvar&gt;, Array[{&lt;start&gt;,&lt;length&gt;}]}</h4><p class="Standard">Finds the standard deviation of the values in a numeric array (Array[]) or array segment (Array[start,length]), and places the result into the numeric variable &lt;sd_nvar&gt;.</p><h4 class="Heading_20_4"><a id="a__Array_sum__sum_nvar___Array_{_start___length_}_"><span/></a>Array.sum &lt;sum_nvar&gt;, Array[{&lt;start&gt;,&lt;length&gt;}]</h4><p class="Standard">Finds the sum of the values in a numeric array (Array[]) or array segment (Array[start,length]), and then places the result into the numeric variable &lt;sum_nvar&gt;.</p><h4 class="Heading_20_4"><a id="a__Array_variance__v_nvar___Array_{_start___length_}_"><span/></a>Array.variance &lt;v_nvar&gt;, Array[{&lt;start&gt;,&lt;length&gt;}]</h4><p class="Standard">Finds the variance of the values in a numeric array (Array[]) or array segment (Array[start,length]), and places the result into the numeric variable &lt;v_nvar&gt;.</p><h1 class="Heading_20_1"><a id="a__Data_Structures_and_Pointers_in_BASIC!"><span/></a><a id="_Toc5235732"/>Data Structures and Pointers in BASIC!</h1><p class="Standard">BASIC! offers commands that facilitate working with Data Structures in ways that are not possible with traditional Basic implementations. These commands provide for the implementation of Lists, Bundles, Stacks and Queues.</p><h2 class="Heading_20_2"><a id="a__What_is_a_Pointer"><span/></a><a id="_Toc5235733"/>What is a Pointer</h2><p class="Standard">The central concept behind the implementation of these commands (and many other BASIC! commands) is the <span class="T18">pointer</span>. A pointer is a numeric value that is an index into a list or table of things.</p><p class="Standard">Do not confuse the pointer with the thing it points to. A pointer to a List is not a List; a pointer to a bitmap is not a bitmap. A pointer is just a number that represents something else.</p><p class="Standard">As an example of pointers think of a file cabinet drawer with folders in it. That file cabinet is maintained by your administrative assistant. You never see the file drawer itself. In the course of your work you will create a new folder into which you put some information. You then give the folder to your assistant to be place into the drawer. The assistant puts a unique number on the folder and gives you a slip of paper with that unique number on it. You can later retrieve that folder by asking your assistant to bring you the folder with that particular number on it.</p><p class="Standard">In BASIC! you create an information object (folder). You then give that information object to BASIC! to put into a virtual drawer. BASIC! will give you a unique number—a pointer—for that information object. You then use that pointer to retrieve that particular information object.</p><p class="Standard">Continuing with the folder analogy, let’s assume that you have folders that contain information about customers. This information could be things such as name, address and phone number. The number that your assistant will give you when filing the folder will become the customer’s customer number. You can retrieve this information about any customer by asking the assistant to bring you the folder with the unique customer number. In BASIC! you would use a Bundle to create that customer information object (folder). The pointer that BASIC! returns when you create the customer Bundle becomes the customer number.</p><p class="Standard">Now let’s assume that a customer orders something. You will want to create a Bundle that contains all the order information. Such bundles are used by the order fulfillment department, the billing department and perhaps even the marketing department (to SPAM the customer about similar products). Each Bundle could contain the item ordered, the price, etc. The Bundle will also need to contain information about the customer. Rather than replicate the customer information you will just create a customer number field that contains the customer number (pointer). The pointer that gets returned when you create the order bundle becomes the Order Number. You can create different lists of bundles for use by different departments.</p><p class="Standard">It would also be nice to have a list of all orders made by a customer in the customer Bundle. You would do this by creating a List of all order numbers for that customer. When you create the customer bundle, you would ask BASIC! to create an empty List. BASIC! will return a pointer to this empty List. You would then place this pointer into the customer record. Later when the customer places an order, you will retrieve that list pointer and add the order number to the List.</p><p class="Standard">You may also want to create several other Lists of order Bundles for other purposes. You may, for example, have one List of orders to be filled, another List of filled orders, another List of returned orders, another List for billing, etc. All of these Lists would simply be lists of order numbers. Each order number would point to the order Bundle which would point to the Customer Bundle.</p><p class="Standard">If you were to actually create such a database in BASIC!, you would probably want to save all these Bundles and Lists onto external storage. Getting that information from the internal data structures to external storage is an exercise left to the user for now.</p><p class="Standard">There are things besides List, Bundle, and Stack data structures that are accessed through pointers. These include bitmaps and graphical objects, described below in the <span class="T7">Graphics</span> section, audio clips, described in <span class="T7">SoundPool</span>, and other things.</p><h2 class="Heading_20_2"><a id="a__Lists"><span/></a><a id="_Toc5235734"/>Lists</h2><p class="Standard">A List is similar to a single-dimension array. The difference is in the way a List is built and used. An array must be dimensioned before being used. The number of elements to be placed in the array must be predetermined. A List starts out empty and grows as needed. Elements can be removed, replaced and inserted anywhere within the list.</p><p class="Standard">There is no fixed limit on the size or number of lists. You are limited only by the memory of your device.</p><p class="Standard">Another important difference is that a List is not a variable type. A numeric pointer is returned when a list is created. All further access to the List is by means of that numeric pointer. One implication of this is that it is easy to make a List of Lists. A List of Lists is nothing more than a numeric list containing numeric pointers to other lists.</p><p class="Standard">Lists may be copied into new Arrays. Arrays may be added to Lists.</p><p class="Standard">All of the List commands are demonstrated in the Sample Program file, f27_list.bas.</p><h3 class="Heading_20_3"><a id="a__List_Commands"><span/></a><a id="_Toc5235735"/>List Commands</h3><h4 class="Heading_20_4"><a id="a__List_create_N|S___pointer_nvar_"><span/></a>List.create N|S, &lt;pointer_nvar&gt;</h4><p class="Standard">Creates a new, empty list of the type specified by the N or S parameter. A list of strings will be created if the parameter is <span class="T7">S</span>. A list of numbers will be created if the parameter is <span class="T7">N</span>. Do not put quotation marks around the N or S.</p><p class="Standard">The pointer to the new list will be returned in the &lt;pointer_nvar&gt; variable.</p><p class="Standard">The newly created list is empty. The size returned for a newly created list is zero.</p><h4 class="Heading_20_4"><a id="a__List_add__pointer_nexp_{___exp_}___"><span/></a>List.add &lt;pointer_nexp&gt;{, &lt;exp&gt;}...</h4><p class="Standard">Adds the values of the expressions &lt;exp&gt;... to specified list. The expressions must all be the same type (numeric or string) as the list.</p><p class="Standard">The list of &lt;exp&gt;s may be continued onto the next line by ending the line with the "~" character. The "~" character may be used between &lt;exp&gt; parameters, where a comma would normally appear. The "~" itself separates the parameters; the comma is optional.</p><p class="Standard">The "~" character may not be used to split a parameter across multiple lines.</p><p class="Standard">Examples:</p><p class="Code_20_example"><span class="T11">List.add Nlist, 2, 4, 8 , n^2, 32</span></p><p class="P2"> </p><p class="Code_20_example"><span class="T11">List.add Hours, 3, 4,7,0, 99, 3, 66~        % comma not required before ~</span></p><p class="Code_20_example"><span class="T11">37, 66, 43, 83,~                                % comma is allowed before ~</span></p><p class="Code_20_example"><span class="T11">83, n*5, q/2 +j</span></p><p class="P2"> </p><p class="Code_20_example"><span class="T11">List.add Name~</span></p><p class="Code_20_example"><span class="T11">"Bill", "Jones"~</span></p><p class="Code_20_example"><span class="T11">"James", "Barnes"~</span></p><p class="Code_20_example"><span class="T11">"Jill", "Hanson"</span></p><h4 class="Heading_20_4"><a id="a__List_add_list__destination_list_pointer_nexp____source_list_pointer_nexp_"><span/></a>List.add.list &lt;destination_list_pointer_nexp&gt;, &lt;source_list_pointer_nexp&gt;</h4><p class="Standard">Appends the elements in the source list to the end of the destination list.</p><p class="Standard">The two lists must be of the same type (string or numeric).</p><h4 class="Heading_20_4"><a id="a__List_add_array__list_pointer_nexp___Array_{_start___length_}_"><span/></a>List.add.array &lt;list_pointer_nexp&gt;, Array[{&lt;start&gt;,&lt;length&gt;}]</h4><p class="Standard">Appends the elements of the specified array (Array[]) or array segment (Array[start,length]) to the end of the specified list.</p><p class="Standard">The Array type must be the same as the list type (string or numeric).</p><h4 class="Heading_20_4"><a id="a__List_replace__pointer_nexp____index_nexp____sexp_|_nexp_"><span/></a>List.replace &lt;pointer_nexp&gt;, &lt;index_nexp&gt;, &lt;sexp&gt;|&lt;nexp&gt;</h4><p class="Standard">The List element specified by &lt;index_nexp&gt; in the list pointed to by &lt;pointer_nexp&gt; is replaced by the value of the string or numeric expression.</p><p class="Standard">The index is one-based. The first element of the list is 1.</p><p class="Standard">The replacement expression type (string or numeric) must match the list type.</p><h4 class="Heading_20_4"><a id="a__List_insert__pointer_nexp____index_nexp____sexp_|_nexp_"><span/></a>List.insert &lt;pointer_nexp&gt;, &lt;index_nexp&gt;, &lt;sexp&gt;|&lt;nexp&gt;</h4><p class="Standard">Inserts the &lt;sexp&gt; or &lt;nexp&gt; value into the list pointed to by &lt;pointer_nexp&gt; at the index point &lt;index_nexp&gt;. If the index point is one more than the current size of the list, the new item is added at the end of the list.</p><p class="Standard">The index is ones based. The first element of the list is 1.</p><p class="Standard">The inserted element type must match the list type (string or numeric).</p><h4 class="Heading_20_4"><a id="a__List_remove__pointer_nexp___index_nexp_"><span/></a>List.remove &lt;pointer_nexp&gt;,&lt;index_nexp&gt;</h4><p class="Standard">Removes the list element specified by &lt;index_nexp&gt; from the list pointed to by &lt;pointer_nexp&gt;.</p><p class="Standard">The index is ones based. The first element of the list is 1.</p><h4 class="Heading_20_4"><a id="a__List_get__pointer_nexp____index_nexp____var_"><span/></a>List.get &lt;pointer_nexp&gt;, &lt;index_nexp&gt;, &lt;var&gt;</h4><p class="Standard">The list element specified by &lt;index_nexp&gt; in the list pointed to by &lt;pointer_nexp&gt; is returned in the specified string or numeric variable &lt;var&gt;.</p><p class="Standard">The index is one-based. The first element of the list is 1.</p><p class="Standard">The return element variable type must match the list type (string or numeric).</p><h4 class="Heading_20_4"><a id="a__List_type__pointer_nexp____svar_"><span/></a>List.type &lt;pointer_nexp&gt;, &lt;svar&gt;</h4><p class="No_20_Spacing">The type of list pointed to by the list pointer is returned in the string variable &lt;svar&gt;.</p><ul><li><p class="P26" style="margin-left:1.27cm;"><span class="ListLabel_20_105" style="display:block;float:left;min-width:0.635cm;"></span>Returns the upper case character "S" if the list is a list of strings.<span class="odfLiEnd"/> </p></li><li><p class="P26" style="margin-left:1.27cm;"><span class="ListLabel_20_105" style="display:block;float:left;min-width:0.635cm;"></span>Returns the upper case character "N" if the list is a list of numbers.<span class="odfLiEnd"/> </p></li></ul><h4 class="Heading_20_4"><a id="a__List_size__pointer_nexp____nvar_"><span/></a>List.size &lt;pointer_nexp&gt;, &lt;nvar&gt;</h4><p class="Standard">The size of the list pointed to by the list pointer is returned in the numeric variable &lt;nvar&gt;.</p><h4 class="Heading_20_4"><a id="a__List_clear__pointer_nexp_"><span/></a>List.clear &lt;pointer_nexp&gt;</h4><p class="Standard">Clears the list pointed to by the list pointer and sets the list’s size to zero.</p><h4 class="Heading_20_4"><a id="a__List_search__pointer_nexp___value|value$___result_nvar_{__start_nexp_}"><span/></a>List.search &lt;pointer_nexp&gt;, value|value$, &lt;result_nvar&gt;{,&lt;start_nexp&gt;}</h4><p class="Standard">Searches the specified list for the specified string or numeric value. The position of the first (left-most) occurrence is returned in the numeric variable &lt;result_nvar&gt;. If the value is not found in the list then the result is zero.</p><p class="Standard">If the optional start expression parameter is present, the search starts at the specified element. The default start position is 1.</p><h4 class="Heading_20_4"><a id="a__List_toArray__pointer_nexp___Array$___|_Array__"><span/></a>List.toArray &lt;pointer_nexp&gt;, Array$[] | Array[]</h4><p class="Standard">Copies the list pointed to by the list pointer into an array. The array type (string or numeric) must be the same as the list type. If the array exists, it is overwritten, otherwise a new array is created. The result is always a one-dimensional array.</p><h2 class="Heading_20_2"><a id="a__Bundles"><span/></a><a id="_Toc5235736"/>Bundles</h2><p class="Standard">A Bundle is a group of values collected together into a single object. A bundle object may contain any number of string and numeric values. There is no fixed limit on the size or number of bundles. You are limited only by the memory of your device.</p><p class="Standard">The values are set and accessed by keys. A key is string that identifies the value. For example, a bundle might contain a person’s first name and last name. The keys for accessing those name strings could be "first_name" and "last_name". An age numeric value could also be placed in the Bundle using an "age" key.</p><p class="Standard">A new, empty bundle is created by using the <span class="T7">Bundle.create</span> command. The command returns a pointer to the empty bundle. Because the bundle is represented by a pointer, bundles can be placed in lists and arrays. Bundles can also be contained in other bundles. This means that the combination of lists and bundles can be used to create arbitrarily complex data structures.</p><p class="Standard">After a bundle is created, keys and values can be added to the bundle using the <span class="T7">Bundle.put</span> command. Those values can be retrieved using the keys in the <span class="T7">Bundle.get</span> command. There are other bundle commands to facilitate the use of bundles.</p><h3 class="Heading_20_3"><a id="a__Bundle_Auto-Create"><span/></a><a id="_Toc5235737"/>Bundle Auto-Create</h3><p class="Standard">Every bundle command except <span class="T7">Bundle.create</span> has a parameter, the &lt;pointer_nexp&gt;, which can point to a bundle. If the expression value points to a bundle, the existing bundle is used. If it does not, and the expression consists only of a single numeric variable, then a new, empty bundle is created, and the variable value is set to point to the new bundle.</p><p class="Standard">That may seem complex, but it isn't, really. If there is a bundle, use it. If there is not, try to create a new one – but BASIC! can't create a new bundle if you don't give it a variable name. BASIC! uses the variable to tell you how to find the new bundle.</p><p class="Code_20_example"><span class="T10">BUNDLE.PUT b,"key1", 1.2                % try to put a value in the bundle pointed to by b</span></p><p class="Code_20_example"><span class="T10">BUNDLE.PUT 10, key2$, value2                % try to put a value in the 10th bundle created</span></p><p class="Code_20_example"><span class="T10">BUNDLE.REMOVE c + d, key$[3],        % try to remove a key/value pair from a bundle</span></p><p class="P6"><span class="T10">% pointed to by c + d</span></p><p class="Standard">In the first example, if the value of <span class="T7">b</span> points to a bundle, the <span class="T7">Bundle.put</span> puts <span class="T7">"key1"</span> and the value 1.2 into that bundle. If <span class="T7">b</span> is a new variable, its value is 0.0, so it does not point to a bundle. In that case, the <span class="T7">Bundle.put</span> creates a new bundle, puts <span class="T7">"key1"</span> and the value 1.2 into the new bundle, and sets <span class="T7">b</span> to point to the new bundle.</p><p class="Standard">In the second example, if there are at least ten bundles, then the <span class="T7">Bundle.put</span> tries to put the key named in the variable <span class="T7">key2$</span> and the value of the variable <span class="T7">value2</span> into bundle 10. If there is no bundle 10, then the command does nothing. It can't create a new variable because you did not provide a variable to return the bundle pointer.</p><p class="Standard">In the third example, the bundle pointer is the value of the expression <span class="T7">c + d</span>. If there is no such bundle, the command does nothing. To create a new bundle, the bundle pointer expression must be a single numeric variable.</p><h3 class="Heading_20_3"><a id="a__Bundle_Commands"><span/></a><a id="_Toc5235738"/>Bundle Commands</h3><h4 class="Heading_20_4"><a id="a__Bundle_create__pointer_nvar_"><span/></a>Bundle.create &lt;pointer_nvar&gt;</h4><p class="Standard">A new, empty bundle is created. The bundle pointer is returned in &lt;pointer_nvar&gt;.</p><p class="Standard">Example:</p><p class="Code_20_example"><span class="T11">BUNDLE.CREATE bptr</span></p><h4 class="Heading_20_4"><a id="a__Bundle_put__pointer_nexp____key_sexp____value_nexp_|_value_sexp_"><span/></a>Bundle.put &lt;pointer_nexp&gt;, &lt;key_sexp&gt;, &lt;value_nexp&gt;|&lt;value_sexp&gt;</h4><p class="Standard">The value expression will be placed into the specified bundle using the specified key. If the bundle does not exist, a new one may be created.</p><p class="Standard">The type of the value will be determined by the type of the value expression.</p><p class="Standard">Example:</p><p class="Code_20_example"><span class="T11">BUNDLE.PUT bptr, "first_name", "Frank"</span></p><p class="Code_20_example"><span class="T11">BUNDLE.PUT bptr,"age", 44</span></p><h4 class="Heading_20_4"><a id="a__Bundle_get__pointer_nexp____key_sexp____nvar_|_svar_"><span/></a>Bundle.get &lt;pointer_nexp&gt;, &lt;key_sexp&gt;, &lt;nvar&gt;|&lt;svar&gt;</h4><p class="Standard">Places the value specified by the key string expression into the specified numeric or string variable. The type (string or numeric) of the destination variable must match the type stored with the key. If the bundle does not exist or does not contain the requested key, the command generates a run-time error.</p><p class="Standard">Example:</p><p class="Code_20_example"><span class="T11">BUNDLE.GET bptr,"first_name", first_name$</span></p><p class="Code_20_example"><span class="T11">BUNDLE.GET bptr,"age", age</span></p><h4 class="Heading_20_4"><a id="a__Bundle_keys__bundle_ptr_nexp____list_ptr_nexp_"><span/></a>Bundle.keys &lt;bundle_ptr_nexp&gt;, &lt;list_ptr_nexp&gt;</h4><p class="Standard">Returns a list of the keys currently in the specified bundle.</p><p class="Standard">The bundle pointer parameter &lt;bundle_ptr_nexp&gt; specifies the bundle from which to get the keys. If the bundle does not exist, a new one may be created.</p><p class="Standard">The list pointer parameter &lt;list_ptr_next&gt; specifies the list into which to write the keys. The previous contents of the list are discarded. If the parameter does not specify a valid string list to reuse, and the parameter is a string variable, a new list is created and a pointer to the list is written to the variable.</p><p class="Standard">The key names in the returned list may be extracted using the various list commands.</p><p class="Standard">Example:</p><p class="Code_20_example"><span class="T11">BUNDLE.KEYS bptr, list</span></p><p class="Code_20_example"><span class="T11">LIST.SIZE list, size</span></p><p class="Code_20_example"><span class="T11">FOR i = 1 TO size</span></p><p class="Code_20_example"><span class="T11">        LIST.GET list, i, key$</span></p><p class="Code_20_example"><span class="T11">        BUNDLE.TYPE bptr, key$, type$</span></p><p class="Code_20_example"><span class="T11">        IF type$ = "S"</span></p><p class="Code_20_example"><span class="T11">                BUNDLE.GET bptr, key$, value$</span></p><p class="Code_20_example"><span class="T11">                PRINT key$, value$</span></p><p class="Code_20_example"><span class="T11">        ELSE</span></p><p class="Code_20_example"><span class="T11">                BUNDLE.GET bptr, key$, value</span></p><p class="Code_20_example"><span class="T11">                PRINT key$, value</span></p><p class="Code_20_example"><span class="T11">        ENDIF</span></p><p class="Code_20_example"><span class="T11">NEXT i</span></p><h4 class="Heading_20_4"><a id="a__Bundle_contain__pointer_nexp____key_sexp_____contains_nvar_"><span/></a>Bundle.contain &lt;pointer_nexp&gt;, &lt;key_sexp&gt; , &lt;contains_nvar&gt;</h4><p class="Standard">If the key specified in the key string expression is contained in the bundle's keys then the "contains" numeric variable will be returned with a non-zero value. The value returned will be zero if the key is not in the bundle. If the bundle does not exist, a new one may be created.</p><h4 class="Heading_20_4"><a id="a__Bundle_type__pointer_nexp____key_sexp____type_svar_"><span/></a>Bundle.type &lt;pointer_nexp&gt;, &lt;key_sexp&gt;, &lt;type_svar&gt;</h4><p class="Standard">Returns the value type (string or numeric) of the specified key in the specified string variable. The &lt;type_svar&gt; will contain an uppercase "N" if the type is numeric. The &lt;type_svar&gt; will contain an uppercase "S" if the type is a string. If the bundle does not exist or does not contain the requested key, the command generates a run-time error.</p><p class="Standard">Example:</p><p class="Code_20_example"><span class="T11">BUNDLE.TYPE bptr, "age", type$</span></p><p class="Code_20_example"><span class="T11">PRINT type$   % will print N</span></p><h4 class="Heading_20_4"><a id="a__Bundle_remove__pointer_nexp____key_sexp_"><span/></a>Bundle.remove &lt;pointer_nexp&gt;, &lt;key_sexp&gt;</h4><p class="Standard">Removes the key named by the string expression &lt;key_sexp&gt;, along with the associated value, from the bundle pointed to by the numeric expression &lt;pointer_nexp&gt;. If the bundle does not contain the key, nothing happens. If the bundle does not exist, a new one may be created.</p><h4 class="Heading_20_4"><a id="a__Bundle_clear__pointer_nexp_"><span/></a>Bundle.clear &lt;pointer_nexp&gt;</h4><p class="Standard">The bundle pointed to by &lt;pointer_nexp&gt; will be cleared of all tags. It will become an empty bundle. If the bundle does not exist, a new one may be created.</p><h2 class="Heading_20_2"><a id="a__Stacks"><span/></a><a id="_Toc5235739"/>Stacks</h2><p class="Standard">Stacks are like a magazine for a gun.</p><!--Next 'div' was a 'text:p'.--><div class="P99"><!--Next '
           span' is a draw:frame.
       --><span style="height:2.252cm;width:2.54cm; padding:0; " class="fr1" id="Picture_2"><img style="height:2.252cm;width:2.54cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><p class="Standard">The last bullet into the magazine is the first bullet out of the magazine. This is also what is true about stacks. The last object placed into the stack is the first object out of the stack. This is called LIFO (Last In First Out).</p><p class="Standard">An example of the use of a stack is the BASIC! Gosub command. When a Gosub command is executed the line number to return to is "pushed" onto a stack. When a return is executed the return line number is "popped" off of the stack. This methodology allows Gosubs to be nested to any level. Any return statement will always return to the line after the last Gosub executed.</p><p class="Standard">A running example of Stacks can be found in the Sample Program file, f29_stack.bas.</p><p class="Standard">There is no fixed limit on the size or number of stacks. You are limited only by the memory of your device.</p><h3 class="Heading_20_3"><a id="a__Stack_Commands"><span/></a><a id="_Toc5235740"/>Stack Commands</h3><h4 class="Heading_20_4"><a id="a__Stack_create_N|S___ptr_nvar_"><span/></a>Stack.create N|S, &lt;ptr_nvar&gt;</h4><p class="Standard">Creates a new stack of the designated type (N=Number, S=String). The stack pointer is in &lt;ptr_nvar&gt;.</p><h4 class="Heading_20_4"><a id="a__Stack_push__ptr_nexp____nexp_|_sexp_"><span/></a>Stack.push &lt;ptr_nexp&gt;, &lt;nexp&gt;|&lt;sexp&gt;</h4><p class="Standard">Pushes the &lt;nexp&gt; or &lt;sexp&gt; onto the top of the stack designated by &lt;ptr_nexp&gt;.</p><p class="Standard">The type of value expression pushed must match the type of the created stack.</p><h4 class="Heading_20_4"><a id="a__Stack_pop__ptr_nexp____nvar_|_svar_"><span/></a>Stack.pop &lt;ptr_nexp&gt;, &lt;nvar&gt;|&lt;svar&gt;</h4><p class="Standard">Pops the top-of-the-stack value designated by &lt;ptr_nexp&gt; and places it into the &lt;nvar&gt; or &lt;svar&gt;.</p><p class="Standard">The type of the value variable must match the type of the created stack.</p><h4 class="Heading_20_4"><a id="a__Stack_peek__ptr_nexp____nvar_|_svar_"><span/></a>Stack.peek &lt;ptr_nexp&gt;, &lt;nvar&gt;|&lt;svar&gt;</h4><p class="Standard">Returns the top-of-stack value of the stack designated by &lt;ptr_nexp&gt; into the &lt;nvar&gt; or &lt;svar&gt;. The value will remain on the top of the stack.</p><p class="Standard">The type of the value variable must match the type of the created stack.</p><h4 class="Heading_20_4"><a id="a__Stack_type__ptr_nexp____svar_"><span/></a>Stack.type &lt;ptr_nexp&gt;, &lt;svar&gt;</h4><p class="Standard">The type (numeric or string) of the stack designated by &lt;ptr_nexp&gt; will be returned in &lt;svar&gt;. If the stack is numeric, the upper case character "N" will be returned. If the stack is a string stack, the upper case character "S" will be returned.</p><h4 class="Heading_20_4"><a id="a__Stack_isEmpty__ptr_nexp____nvar_"><span/></a>Stack.isEmpty &lt;ptr_nexp&gt;, &lt;nvar&gt;</h4><p class="Standard">If the stack designated by &lt;ptr_nexp&gt; is empty the value returned in &lt;nvar&gt; will be 1. If the stack is not empty the value will be 0.</p><h4 class="Heading_20_4"><a id="a__Stack_clear__ptr_nexp_"><span/></a>Stack.clear &lt;ptr_nexp&gt;</h4><p class="Standard">The stack designated by &lt;ptr_nexp&gt; will be cleared.</p><h2 class="Heading_20_2"><a id="a__Queues"><span/></a><a id="_Toc5235741"/>Queues</h2><p class="Standard">A Queue is like the line that forms at your bank. When you arrive, you get in the back of the line or queue. When a teller becomes available the person at the head of the line or queue is removed from the queue to be serviced by the teller. The whole line moves forward by one person. Eventually, you get to the head of the line and will be serviced by the next available teller. A queue is something like a stack except the processing order is First In First Out (FIFO) rather than LIFO.</p><p class="Standard">Using our customer order processing analogy, you could create a queue of order bundles for the order processing department. New order bundles would be placed at the end of the queue. The top-of-the-queue bundle would be removed by the order processing department when it was ready to service a new order.</p><p class="Standard">There are no special commands in BASIC! for Queue operations. If you want to make a queue, create a list.</p><p class="Standard">Use <span class="T7">List.add</span> to add new elements to the end of the queue.</p><p class="Standard">Use <span class="T7">List.get</span> to get the element at the top of the queue and use <span class="T7">List.remove</span> to remove that top of queue element. You should, of course, use <span class="T7">List.size</span> before using <span class="T7">List.get</span> to ensure that there is a queued element remaining</p><h1 class="Heading_20_1"><a id="a__Comments"><span/></a><a id="_Toc5235742"/>Comments</h1><h2 class="Heading_20_2"><a id="a__!_-_Single_Line_Comment"><span/></a><a id="_Toc5235743"/>! - Single Line Comment</h2><p class="Standard">If the first character in a line is the "!" character, BASIC! considers the entire line a comment and ignores it. If the "!" appears elsewhere in the line it does not indicate a comment.</p><h2 class="Heading_20_2"><a id="a__Rem_-_Single_Line_Comment__legacy_"><span/></a><a id="_Toc5235744"/>Rem - Single Line Comment (legacy)</h2><p class="Standard">If the first three characters in a line are "Rem", "REM", or even "rEm", BASIC! considers the entire line a comment and ignores it. If "Rem" appears elsewhere in the line it does not indicate a comment.</p><h2 class="Heading_20_2"><a id="a__!!_-_Block_Comment"><span/></a><a id="_Toc5235745"/>!! - Block Comment</h2><p class="Standard">When a line begins with the "!!" characters, all lines that follow are considered comments and are ignored by BASIC! The Block Comment section ends at the next line that starts with "!!"</p><h2 class="Heading_20_2"><a id="a____-_Middle_of_Line_Comment"><span/></a><a id="_Toc5235746"/>% - Middle of Line Comment</h2><p class="Standard">If the "%" character appears in a line (except within a quoted string) then rest of the line is a comment.</p><h1 class="Heading_20_1"><a id="a__Expressions"><span/></a><a id="_Toc5235747"/>Expressions</h1><h2 class="Heading_20_2"><a id="a__Numeric_Expression__nexp_"><span/></a><a id="_Toc5235748"/>Numeric Expression &lt;nexp&gt;</h2><p class="Standard">A numeric expression consists of one or more numeric variables or numeric constants separated by binary operators and optionally preceded by unary operators. The definition can be stated more completely using this standard formal notation:</p><p class="Standard"><span class="T7">&lt;nexp&gt; := {&lt;numeric variable&gt;|&lt;numeric constant} {&lt;noperator&gt; &lt;nexp&gt;}</span></p><p class="Standard">The next few sections define all of the terms.</p><h3 class="Heading_20_3"><a id="a__Numeric_Operators__noperator_"><span/></a><a id="_Toc5235749"/>Numeric Operators &lt;noperator&gt;</h3><p class="Standard">The numeric operators are listed by precedence. Higher precedence operators are executed before lower precedence operators. Precedence can be changed by using parentheses.</p><ol><li><p class="P73" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">1.</span>Unary +, Unary –<span class="odfLiEnd"/> </p></li><li><p class="P73" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">2.</span>Exponent ^<span class="odfLiEnd"/> </p></li><li><p class="P73" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">3.</span>Multiply *, Divide /<span class="odfLiEnd"/> </p></li><li><p class="P73" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">4.</span>Add +, Subtract –<span class="odfLiEnd"/> </p></li></ol><p class="P102">Note that the comma (',') is not an operator in BASIC!. It is sometimes uses as a separator between expressions; for example, see the <span class="T7">PRINT</span> command.</p><h3 class="Heading_20_3"><a id="a__Numeric_Expression_Examples"><span/></a><a id="_Toc5235750"/>Numeric Expression Examples</h3><p class="Code_20_example"><span class="T11">a</span></p><p class="Code_20_example"><span class="T11">a*b + 4/d – 2*(d^2)</span></p><p class="Code_20_example"><span class="T11">a + b + d + RND()</span></p><p class="Code_20_example"><span class="T11">b + CEIL(d/25) + 5</span></p><h3 class="Heading_20_3"><a id="a__Pre-_and_Post-Increment_Operators"><span/></a><a id="_Toc5235751"/>Pre- and Post-Increment Operators</h3><p class="P95">++x<span> Increments the value of x by 1 before the x value is used</span></p><p class="P95">--y<span> Decrements the value of y by 1 before the y value is used</span></p><p class="P95">x++<span> Increments the value of x by 1 after the x value is used</span></p><p class="P104">y--<span> Decrements the value of y by 1 after the y value is used</span></p><p class="Code_20_example"><span class="T11">a = 5                % creates the variable a and sets it to 5</span></p><p class="Code_20_example"><span class="T11">PRINT --a        % sets a to 4 and prints 4</span></p><p class="Code_20_example"><span class="T11">PRINT a--        % prints 4 and sets a to 3</span></p><p class="Standard">These operations work only on numeric variables. Their action is performed as part of evaluating the variable, so they do not follow normal precedence rules.</p><p class="Standard">Using these operators on a variable makes the variable unavailable for other operations that require a variable. For example, you cannot pass a variable by reference (see <span class="T7">User-Defined functions</span>) if you pre- or post-increment or -decrement it, because you cannot pass an expression by reference. An exception is made to allow implicit assignment (actual or implied <span class="T7">LET</span>).</p><h2 class="Heading_20_2"><a id="a__String_Expression__sexp_"><span/></a><a id="_Toc5235752"/>String Expression &lt;sexp&gt;</h2><p class="Standard">A string expression consists of one or more string variables or string constants separated by '+' operators. The definition can be stated more completely using this standard formal notation:</p><p class="Standard"><span class="T7">&lt;sexp&gt; := {&lt;string variable&gt;|&lt;string constant&gt;} {</span><span class="T29"> </span><span class="T7">+ &lt;sexp&gt;}</span></p><p class="Standard">There is only one string operator: +. This is the concatenation operator. It is used to join two strings:</p><p class="Code_20_example"><span class="T11">PRINT "abc" + "def"        % prints abcdef</span></p><h2 class="Heading_20_2"><a id="a__Logical_Expression__lexp_"><span/></a><a id="_Toc5235753"/>Logical Expression &lt;lexp&gt;</h2><p class="Standard">Logical expressions, or Boolean expressions, produce only two results: false or true. False is represented in BASIC! by the numeric value of zero. Anything that is not zero is true. False = 0. True = not 0.</p><p class="Standard">There are two types of logical expressions: Numeric logical expressions and string logical expressions. Both types produce a numerically-represented values of true or false. Each type consists of one or more variables or constants separated by binary logical operators, formally defined like this:</p><p class="Standard">&lt;slexp&gt; := {&lt;string variable&gt;|&lt;string constant&gt;} &lt;logical operator&gt; {&lt;string variable&gt;|&lt;string constant&gt;}</p><p class="Standard">&lt;nlexp&gt; := {&lt;numeric variable&gt;|&lt;numeric constant&gt;} &lt;logical operator&gt; {&lt;numeric variable&gt;|&lt;numeric constant&gt;}</p><p class="Standard">There is also the unique unary NOT (!) operator. NOT inverts the truth of a logical expression.</p><h3 class="Heading_20_3"><a id="a__Logical_Operators"><span/></a><a id="_Toc5235754"/>Logical Operators</h3><p class="P108">Most of the logical operators are used for comparison. You can compare strings or numbers (&lt;, =, etc.). You can use the other Boolean operators (!, &amp;, |) on numbers but not on strings.</p><p class="Standard">This table shows all of the logical operators. They are listed by precedence with the highest precedence first. All of these operators have <span class="T18">lower</span> precedence than any of the numeric operators or the one string operator. Precedence may be modified by using parentheses.</p><table border="0" cellspacing="0" cellpadding="0" class="Table1"><colgroup><col width="97"/><col width="80"/><col width="177"/><col width="215"/></colgroup><tr class="Table11"><td style="text-align:left;width:2.224cm; " class="Table1_A1"><p class="P110">Precedence</p></td><td style="text-align:left;width:1.829cm; " class="Table1_A1"><p class="P110">Operator</p></td><td style="text-align:left;width:4.043cm; " class="Table1_A1"><p class="P110">Meaning</p></td><td style="text-align:left;width:4.919cm; " class="Table1_A1"><p class="P110">Operands</p></td></tr><tr class="Table11"><td style="text-align:left;width:2.224cm; " class="Table1_A1"><p class="P110">1</p></td><td style="text-align:left;width:1.829cm; " class="Table1_A1"><p class="P110">&lt;</p><p class="P110">&gt;</p><p class="P110">&lt;=</p><p class="P110">&gt;=</p><p class="P110">=</p><p class="P110">&lt;&gt;</p></td><td style="text-align:left;width:4.043cm; " class="Table1_A1"><p class="P114">Less Than</p><p class="P114">Greater Than</p><p class="P114">Less Than or Equal</p><p class="P114">Greater Than or Equal</p><p class="P114">Equal</p><p class="P114">Not Equal</p></td><td style="text-align:left;width:4.919cm; " class="Table1_A1"><p class="P114">Two &lt;nlexp&gt; or two &lt;slexp&gt;</p></td></tr><tr class="Table11"><td style="text-align:left;width:2.224cm; " class="Table1_A1"><p class="P110">2</p></td><td style="text-align:left;width:1.829cm; " class="Table1_A1"><p class="P110">!</p></td><td style="text-align:left;width:4.043cm; " class="Table1_A1"><p class="P114">Unary Not</p></td><td style="text-align:left;width:4.919cm; " class="Table1_A1"><p class="P114">One &lt;nlexp&gt; only</p></td></tr><tr class="Table11"><td style="text-align:left;width:2.224cm; " class="Table1_A1"><p class="P110">3</p></td><td style="text-align:left;width:1.829cm; " class="Table1_A1"><p class="P110">&amp;</p></td><td style="text-align:left;width:4.043cm; " class="Table1_A1"><p class="P114">And</p></td><td style="text-align:left;width:4.919cm; " class="Table1_A1"><p class="P114">Two &lt;nlexp&gt; only</p></td></tr><tr class="Table11"><td style="text-align:left;width:2.224cm; " class="Table1_A1"><p class="P110">4</p></td><td style="text-align:left;width:1.829cm; " class="Table1_A1"><p class="P110">|</p></td><td style="text-align:left;width:4.043cm; " class="Table1_A1"><p class="P114">Or</p></td><td style="text-align:left;width:4.919cm; " class="Table1_A1"><p class="P114">Two &lt;nlexp&gt; only</p></td></tr></table><h3 class="Heading_20_3"><a id="a__Examples_of_Logical_Expressions"><span/></a><a id="_Toc5235755"/>Examples of Logical Expressions</h3><p class="Code_20_example"><span class="T11">1 &lt; 2 (true)</span></p><p class="Code_20_example"><span class="T11">3 &lt;&gt; 4 (true)</span></p><p class="Code_20_example"><span class="T11">"a" &lt; "bcd" (true)</span></p><p class="Code_20_example"><span class="T11">1 &amp; 0 (false)</span></p><p class="Code_20_example"><span class="T11">!(1 &amp; 0) (true)</span></p><h2 class="Heading_20_2"><a id="a__Parentheses"><span/></a><a id="_Toc5235756"/>Parentheses</h2><p class="Standard">Parentheses can be used to override operator precendence.</p><p class="Code_20_example"><span class="T11">a = b * c + d                % the multiplication is done first</span></p><p class="Code_20_example"><span class="T11">a = b * (c + d)        % the addition is done first</span></p><p class="Standard">Parentheses can also be placed around a variable, anywhere except to the left of an = sign. This can be useful in places where BASIC! may mistake part of a variable for a special keyword. For an example, see <span class="T7">Program Control Commands – For - To - Step / Next</span>, below.</p><h1 class="Heading_20_1"><a id="a__Assignment_Operations"><span/></a><a id="_Toc5235757"/>Assignment Operations</h1><p class="Standard">Variables get values by means of assignment statements. Simple assignment statements are of the form:</p><p class="Code_20_example"><span class="T11">&lt;nvar&gt; = &lt;nexp&gt;</span></p><p class="Code_20_example"><span class="T11">&lt;svar&gt; = &lt;sexp&gt;</span></p><p class="Standard">The special form of the statement allows BASIC! to infer the command. The implied command is <span class="T7">LET</span>.</p><h2 class="Heading_20_2"><a id="a__Let"><span/></a><a id="_Toc5235758"/>Let</h2><p class="Standard">The original Basic language used the command, <span class="T7">LET</span>, to denote an assignment operation as in:</p><p class="Code_20_example"><span class="T11">LET &lt;nvar&gt; = &lt;nexp&gt;</span></p><p class="Standard">BASIC! also has the <span class="T7">LET</span> command but it is optional. If you use other programming languages, it may look strange to you, but there are two reasons you might use <span class="T7">LET</span>.</p><p class="Standard">First, you must use <span class="T7">LET</span> if you want to have a variable name start with a BASIC! keyword. Such keywords may not appear at the beginning of a new line. The statement:</p><p class="Code_20_example"><span class="T11">Letter$ = "B"</span></p><p class="Standard">is seen by BASIC! as</p><p class="Code_20_example"><span class="T11">LET ter$ = "B"</span></p><p class="Standard">If you really want to use Letter$ as a variable, you can safely use it by putting it in a <span class="T7">LET</span> statement:</p><p class="Code_20_example"><span class="T11">LET Letter$ = "B"</span></p><p class="Standard">If you do the assignment in a single-line <span class="T7">IF</span> statement, you must also use the <span class="T7">LET</span> command:</p><p class="Code_20_example"><span class="T11">IF 1 &lt; 2 THEN LET letter$ = "B"</span></p><p class="Standard">Second, assignment is faster with the <span class="T7">LET</span> command than without it.</p><h2 class="Heading_20_2"><a id="a__OpEqual_Assignment_Operations"><span/></a><a id="_Toc5235759"/>OpEqual Assignment Operations</h2><p class="Standard">All of the binary arithmetic and logical operators (+, -, *, /, ^, &amp;, |) may be used with the equals sign (=) to make a single "OpEqual" operator. The combined operator works like this:</p><p class="Code_20_example"><span class="T11">var op= expression  is the same as  var = var op (expression)</span></p><p class="Standard"> Here are some examples:</p><p class="Code_20_example"><span class="T11">a += 1                        is the same as                a = a + 1</span></p><p class="Code_20_example"><span class="T11">a$ += "xyz"                is the same as                a$ = a$ + "xyz"</span></p><p class="Code_20_example"><span class="T11">b /= 5 + 3                is the same as                b = b / (5 + 3)</span></p><p class="Code_20_example"><span class="T11">c ^= log(37) + 1        is the same as                c = c ^ (log(37) + 1)</span></p><p class="Code_20_example"><span class="T11">d *= --d + d--                is the same as                d = d * (--d + d--)</span></p><p class="Code_20_example"><span class="T11">m &amp;= (x$ = y$) | (x$ != z$) is the same as        m = m &amp; ((x$ = y$) | (x$ != z$))</span></p><h1 class="Heading_20_1"><a id="a__Math_Functions"><span/></a><a id="_Toc5235760"/>Math Functions</h1><p class="Standard">Math functions act like numeric variables in a &lt;nexp&gt; (or &lt;lexp&gt;).</p><h2 class="Heading_20_2"><a id="a__BOR__nexp1____nexp2__"><span/></a><a id="_Toc5235761"/>BOR(&lt;nexp1&gt;, &lt;nexp2&gt;)</h2><p class="P143">Returns the logical bitwise value of &lt;nexp1&gt; OR &lt;nexp2&gt;. The double-precision floating-point values are converted to 64-bit integers before the operation.</p><p class="Code_20_example"><span class="T11">BOR(1,2) is 3</span></p><h2 class="Heading_20_2"><a id="a__BAND__nexp1____nexp2__"><span/></a><a id="_Toc5235762"/>BAND(&lt;nexp1&gt;, &lt;nexp2&gt;)</h2><p class="P143">Returns the logical bitwise value of &lt;nexp1&gt; AND &lt;nexp2&gt;. The double-precision floating-point values are converted to 64-bit integers before the operation.</p><p class="Code_20_example"><span class="T11">BAND(3,1) is 1</span></p><h2 class="Heading_20_2"><a id="a__BXOR__nexp1____nexp2__"><span/></a><a id="_Toc5235763"/>BXOR(&lt;nexp1&gt;, &lt;nexp2&gt;)</h2><p class="P143">Returns the logical bitwise value of &lt;nexp1&gt; XOR &lt;nexp2&gt;. The double-precision floating-point values are converted to 64-bit integers before the operation.</p><p class="Code_20_example"><span class="T11">BXOR(7,1) is 6</span></p><h2 class="Heading_20_2"><a id="a__BNOT__nexp__"><span/></a><a id="_Toc5235764"/>BNOT(&lt;nexp&gt;)</h2><p class="P143">Returns the bitwise complement value of &lt;nexp&gt;. The double-precision floating-point value is converted to a 64-bit integer before the operation.</p><p class="P7"><span class="T11">BNOT(7) is -8</span></p><p class="Code_20_example"><span class="T11">HEX$(BNOT(HEX("1234"))) is ffffffffffffedcb</span></p><h2 class="Heading_20_2"><a id="a__ABS__nexp__"><span/></a><a id="_Toc5235765"/>ABS(&lt;nexp&gt;)</h2><p class="Standard">Returns the absolute value of &lt;nexp&gt;.</p><h2 class="Heading_20_2"><a id="a__SGN__nexp__"><span/></a><a id="_Toc5235766"/>SGN(&lt;nexp&gt;)</h2><p class="Standard">Returns the signum function of the numerical value of &lt;nexp&gt;, representing its sign.</p><table border="0" cellspacing="0" cellpadding="0" class="Table2"><colgroup><col width="184"/><col width="184"/></colgroup><tr class="Table21"><td style="text-align:left;width:4.207cm; " class="Table2_A1"><p class="P120">When the value is:</p></td><td style="text-align:left;width:4.205cm; " class="Table2_A1"><p class="P120">Return:</p></td></tr><tr class="Table21"><td style="text-align:left;width:4.207cm; " class="Table2_A1"><p class="P110">&gt; 0</p></td><td style="text-align:left;width:4.205cm; " class="Table2_A1"><p class="P110">1</p></td></tr><tr class="Table21"><td style="text-align:left;width:4.207cm; " class="Table2_A1"><p class="P110">= 0</p></td><td style="text-align:left;width:4.205cm; " class="Table2_A1"><p class="P110">0</p></td></tr><tr class="Table21"><td style="text-align:left;width:4.207cm; " class="Table2_A1"><p class="P110">&lt; 0</p></td><td style="text-align:left;width:4.205cm; " class="Table2_A1"><p class="P110">-1</p></td></tr></table><h2 class="Heading_20_2"><a id="a__RANDOMIZE_{_nexp_}_"><span/></a><a id="_Toc5235767"/>RANDOMIZE({&lt;nexp&gt;})</h2><p class="Standard">Creates a pseudo-random number generator for use with the <span class="T7">RND()</span> function. The optional seed parameter &lt;nexp&gt; initializes the generator. Omitting the parameter is the same as specifying 0. If you call <span class="T7">RND()</span> without first calling <span class="T7">RANDOMIZE()</span>, it is the same as if you had executed <span class="T7">RANDOMIZE(0)</span>.</p><p class="Standard">A non-zero seed initializes a predictable series of pseudo-random numbers. That is, for a given non-zero seed value, subsequent <span class="T7">RND()</span> calls will always return the same series of values.</p><p class="Standard">If the seed is 0, the sequence of numbers from <span class="T7">RND()</span> is unpredictable and not reproducible. However, repeated <span class="T7">RANDOMIZE(0)</span> calls do not produce "more random" sequences.</p><p class="Standard">The <span class="T7">RANDOMIZE()</span> function always returns zero.</p><h2 class="Heading_20_2"><a id="a__RND__"><span/></a><a id="_Toc5235768"/>RND()</h2><p class="Standard">Returns a random number generated by the pseudorandom number generator. If a <span class="T7">RANDOMIZE(n)</span> has not been previously executed then a new random generator will be created using <span class="T7">RANDOMIZE(0)</span>.</p><p class="Standard">The random number will be greater than or equal to zero and less than one. (0 &lt;= n &lt; 1).</p><p class="Code_20_example"><span class="T11">d = FLOOR(6 * RND() + 1)                % roll a six-sided die</span></p><h2 class="Heading_20_2"><a id="a__MAX__nexp____nexp__"><span/></a><a id="_Toc5235769"/>MAX(&lt;nexp&gt;, &lt;nexp&gt;)</h2><p class="Standard">Returns the maximum of two numbers as an &lt;nvar&gt;.</p><h2 class="Heading_20_2"><a id="a__MIN__nexp____nexp__"><span/></a><a id="_Toc5235770"/>MIN(&lt;nexp&gt;, &lt;nexp&gt;)</h2><p class="Standard">Returns the minimum of two numbers as an &lt;nvar&gt;.</p><h2 class="Heading_20_2"><a id="a__CEIL__nexp__"><span/></a><a id="_Toc5235771"/>CEIL(&lt;nexp&gt;)</h2><p class="Standard">Rounds up towards positive infinity. 3.X becomes 4 and -3.X becomes -3.</p><h2 class="Heading_20_2"><a id="a__FLOOR__nexp__"><span/></a><a id="_Toc5235772"/>FLOOR(&lt;nexp&gt;)</h2><p class="Standard">Rounds down towards negative infinity. 3.X becomes 3 and -3.X becomes -4.</p><h2 class="Heading_20_2"><a id="a__INT__nexp__"><span/></a><a id="_Toc5235773"/>INT(&lt;nexp&gt;)</h2><p class="Standard">Returns the integer part of &lt;nexp&gt;. 3.X becomes 3 and -3.X becomes -3. This operation may also be called truncation, rounding down, or rounding toward zero.</p><h2 class="Heading_20_2"><a id="a__FRAC__nexp__"><span/></a><a id="_Toc5235774"/>FRAC(&lt;nexp&gt;)</h2><p class="Standard">Returns the fractional part of &lt;nexp&gt;. 3.4 becomes 0.4 and -3.4 becomes -0.4.</p><p class="Standard"><span class="T7">FRAC(n)</span> is equivalent to "n - <span class="T7">INT(n)</span>".</p><h2 class="Heading_20_2"><a id="a__MOD__nexp1____nexp2__"><span/></a><a id="_Toc5235775"/>MOD(&lt;nexp1&gt;, &lt;nexp2&gt;)</h2><p class="Standard">Returns the remainder of &lt;nexp1&gt; divided by &lt;nexp2&gt;. If &lt;nexp2&gt; is 0, the function generates a runtime error.</p><h2 class="Heading_20_2"><a id="a__ROUND__value_nexp_{___count_nexp_{___mode_sexp_}}_"><span/></a><a id="_Toc5235776"/>ROUND(&lt;value_nexp&gt;{, &lt;count_nexp&gt;{, &lt;mode_sexp&gt;}})</h2><p class="Standard">In it simplest form, <span class="T7">ROUND(&lt;value_nexp&gt;)</span>, this function returns the closest whole number to &lt;nexp&gt;. You can use the optional parameters to specify more complex operations.</p><p class="Standard">The &lt;count_nexp&gt; is an optional decimal place count. It sets the number of places to the right of the decimal point. The last digit is rounded. The decimal place count must be &gt;= 0. Omitting the parameter is the same as setting it to zero.</p><p class="Standard">The &lt;mode_sexp&gt; is an optional rounding mode. It is a one- or two-character mnemonic code that tells <span class="T7">ROUND()</span> what kind of rounding to do. It is not case-sensitive. There are seven rounding modes:</p><table border="0" cellspacing="0" cellpadding="0" class="Table3"><colgroup><col width="81"/><col width="139"/><col width="71"/><col width="71"/><col width="70"/><col width="71"/><col width="71"/><col width="70"/></colgroup><tr class="Table31"><td style="text-align:left;width:1.85cm; " class="Table3_A1"><p class="P120">Mode:</p></td><td style="text-align:left;width:3.173cm; " class="Table3_A1"><p class="P120">Meaning:</p></td><td style="text-align:left;width:1.616cm; " class="Table3_A1"><p class="P120">-3.8</p></td><td style="text-align:left;width:1.614cm; " class="Table3_A1"><p class="P120">-3.5</p></td><td style="text-align:left;width:1.612cm; " class="Table3_A1"><p class="P120">-3.1</p></td><td style="text-align:left;width:1.614cm; " class="Table3_A1"><p class="P120">3.1</p></td><td style="text-align:left;width:1.616cm; " class="Table3_A1"><p class="P120">3.5</p></td><td style="text-align:left;width:1.612cm; " class="Table3_A1"><p class="P120">3.8</p></td></tr><tr class="Table31"><td style="text-align:left;width:1.85cm; " class="Table3_A1"><p class="P110">"HD"</p></td><td style="text-align:left;width:3.173cm; " class="Table3_A1"><p class="P110">Half-down</p></td><td style="text-align:left;width:1.616cm; " class="Table3_A1"><p class="P110">-4.0</p></td><td style="text-align:left;width:1.614cm; " class="Table3_A1"><p class="P110">-3.0</p></td><td style="text-align:left;width:1.612cm; " class="Table3_A1"><p class="P110">-3.0</p></td><td style="text-align:left;width:1.614cm; " class="Table3_A1"><p class="P110">3.0</p></td><td style="text-align:left;width:1.616cm; " class="Table3_A1"><p class="P110">3.0</p></td><td style="text-align:left;width:1.612cm; " class="Table3_A1"><p class="P110">4.0</p></td></tr><tr class="Table31"><td style="text-align:left;width:1.85cm; " class="Table3_A1"><p class="P110">"HE"</p></td><td style="text-align:left;width:3.173cm; " class="Table3_A1"><p class="P110">Half-even</p></td><td style="text-align:left;width:1.616cm; " class="Table3_A1"><p class="P110">-4.0</p></td><td style="text-align:left;width:1.614cm; " class="Table3_A1"><p class="P110">-4.0</p></td><td style="text-align:left;width:1.612cm; " class="Table3_A1"><p class="P110">-3.0</p></td><td style="text-align:left;width:1.614cm; " class="Table3_A1"><p class="P110">3.0</p></td><td style="text-align:left;width:1.616cm; " class="Table3_A1"><p class="P110">4.0</p></td><td style="text-align:left;width:1.612cm; " class="Table3_A1"><p class="P110">4.0</p></td></tr><tr class="Table31"><td style="text-align:left;width:1.85cm; " class="Table3_A1"><p class="P110">"HU"</p></td><td style="text-align:left;width:3.173cm; " class="Table3_A1"><p class="P110">Half-up</p></td><td style="text-align:left;width:1.616cm; " class="Table3_A1"><p class="P110">-4.0</p></td><td style="text-align:left;width:1.614cm; " class="Table3_A1"><p class="P110">-4.0</p></td><td style="text-align:left;width:1.612cm; " class="Table3_A1"><p class="P110">-3.0</p></td><td style="text-align:left;width:1.614cm; " class="Table3_A1"><p class="P110">3.0</p></td><td style="text-align:left;width:1.616cm; " class="Table3_A1"><p class="P110">4.0</p></td><td style="text-align:left;width:1.612cm; " class="Table3_A1"><p class="P110">4.0</p></td></tr><tr class="Table31"><td style="text-align:left;width:1.85cm; " class="Table3_A1"><p class="P110">"D"</p></td><td style="text-align:left;width:3.173cm; " class="Table3_A1"><p class="P110">Down</p></td><td style="text-align:left;width:1.616cm; " class="Table3_A1"><p class="P110">-3.0</p></td><td style="text-align:left;width:1.614cm; " class="Table3_A1"><p class="P110">-3.0</p></td><td style="text-align:left;width:1.612cm; " class="Table3_A1"><p class="P110">-3.0</p></td><td style="text-align:left;width:1.614cm; " class="Table3_A1"><p class="P110">3.0</p></td><td style="text-align:left;width:1.616cm; " class="Table3_A1"><p class="P110">3.0</p></td><td style="text-align:left;width:1.612cm; " class="Table3_A1"><p class="P110">3.0</p></td></tr><tr class="Table31"><td style="text-align:left;width:1.85cm; " class="Table3_A1"><p class="P110">"U"</p></td><td style="text-align:left;width:3.173cm; " class="Table3_A1"><p class="P110">Up</p></td><td style="text-align:left;width:1.616cm; " class="Table3_A1"><p class="P110">-4.0</p></td><td style="text-align:left;width:1.614cm; " class="Table3_A1"><p class="P110">-4.0</p></td><td style="text-align:left;width:1.612cm; " class="Table3_A1"><p class="P110">-4.0</p></td><td style="text-align:left;width:1.614cm; " class="Table3_A1"><p class="P110">4.0</p></td><td style="text-align:left;width:1.616cm; " class="Table3_A1"><p class="P110">4.0</p></td><td style="text-align:left;width:1.612cm; " class="Table3_A1"><p class="P110">4.0</p></td></tr><tr class="Table31"><td style="text-align:left;width:1.85cm; " class="Table3_A1"><p class="P110">"F"</p></td><td style="text-align:left;width:3.173cm; " class="Table3_A1"><p class="P110">Floor</p></td><td style="text-align:left;width:1.616cm; " class="Table3_A1"><p class="P110">-4.0</p></td><td style="text-align:left;width:1.614cm; " class="Table3_A1"><p class="P110">-4.0</p></td><td style="text-align:left;width:1.612cm; " class="Table3_A1"><p class="P110">-4.0</p></td><td style="text-align:left;width:1.614cm; " class="Table3_A1"><p class="P110">3.0</p></td><td style="text-align:left;width:1.616cm; " class="Table3_A1"><p class="P110">3.0</p></td><td style="text-align:left;width:1.612cm; " class="Table3_A1"><p class="P110">3.0</p></td></tr><tr class="Table31"><td style="text-align:left;width:1.85cm; " class="Table3_A1"><p class="P110">"C"</p></td><td style="text-align:left;width:3.173cm; " class="Table3_A1"><p class="P110">Ceiling</p></td><td style="text-align:left;width:1.616cm; " class="Table3_A1"><p class="P110">-3.0</p></td><td style="text-align:left;width:1.614cm; " class="Table3_A1"><p class="P110">-3.0</p></td><td style="text-align:left;width:1.612cm; " class="Table3_A1"><p class="P110">-3.0</p></td><td style="text-align:left;width:1.614cm; " class="Table3_A1"><p class="P110">4.0</p></td><td style="text-align:left;width:1.616cm; " class="Table3_A1"><p class="P110">4.0</p></td><td style="text-align:left;width:1.612cm; " class="Table3_A1"><p class="P110">4.0</p></td></tr></table><p class="P97">In this table, "down" means "toward zero" and "up" means "away from zero" (toward ±∞)</p><p class="P97">"Half" refers to behavior when a value is half-way between rounding up and rounding down(x.5 or -x.5). "Half-down" rounds x.5 towards zero and "half-up" rounds x.5 away from zero.</p><p class="P97">"Half-even" is either "half-down" or "half-up", whichever would make the result <span class="T7">even</span>. 4.5 and 3.5 both round to 4.0. "Half-even" is also called "banker’s rounding", because it tends to average out rounding errors.</p><p class="Standard">If you do not provide a &lt;mode_sexp&gt;, <span class="T7">ROUND()</span> adds +0.5 and rounds down (toward zero). This is legacy behavior, copied from earlier versions of BASIC!. <span class="T7">ROUND(n)</span> is NOT the same as <span class="T7">ROUND(n, 0)</span>.</p><p class="Standard"><span class="T7">ROUND()</span> generates a runtime error if &lt;count_nexp&gt; &lt; 0 or &lt;mode_sexp&gt; is not valid.</p><p class="No_20_Spacing">Examples:</p><p class="Code_20_example">pi = ROUND(3.14159) <span> </span><span> </span><span> % pi is 3.0</span></p><p class="Code_20_example">pi = ROUND(3.14159, 2)<span> </span><span> </span><span> % pi is 3.14</span></p><p class="Code_20_example">pi = ROUND(3.14159, , <span class="T30">"U"</span>)<span> </span><span> % pi is 4.0</span></p><p class="Code_20_example">pi = ROUND(3.14159, 4, <span class="T30">"F"</span>)<span> </span><span> % pi is 3.1415</span></p><p class="Code_20_example">negpi = ROUND(-3.14159, 4, <span class="T30">"D"</span>)<span> % negpi is -3.1416</span></p><p class="Standard">Note that <span class="T7">FLOOR(n)</span> is exactly the same as <span class="T7">ROUND(n, 0, "F")</span>, but <span class="T7">FLOOR(n)</span> is a little faster. In the same way, <span class="T7">CEIL(n)</span> is the same as <span class="T7">ROUND(n, 0, "C")</span>, and <span class="T7">INT(n)</span> is the same as <span class="T7">ROUND(n, 0, "D")</span>.</p><h2 class="Heading_20_2"><a id="a__SQR__nexp__"><span/></a><a id="_Toc5235777"/>SQR(&lt;nexp&gt;)</h2><p class="Standard">Returns the closest double-precision floating-point approximation of the positive square root of &lt;nexp&gt;. If the value of &lt;nexp&gt; is negative, the function generates a runtime error.</p><h2 class="Heading_20_2"><a id="a__CBRT__nexp__"><span/></a><a id="_Toc5235778"/>CBRT(&lt;nexp&gt;)</h2><p class="Standard">Returns the closest double-precision floating-point approximation of the cube root of &lt;nexp&gt;.</p><h2 class="Heading_20_2"><a id="a__LOG__nexp__"><span/></a><a id="_Toc5235779"/>LOG(&lt;nexp&gt;)</h2><p class="Standard">Returns the natural logarithm (base e) of &lt;nexp&gt;.</p><h2 class="Heading_20_2"><a id="a__LOG10__nexp__"><span/></a><a id="_Toc5235780"/>LOG10(&lt;nexp&gt;)</h2><p class="Standard"><span class="T8">Returns the base 10 logarithm of the &lt;nexp&gt;.</span></p><h2 class="Heading_20_2"><a id="a__EXP__nexp__"><span/></a><a id="_Toc5235781"/>EXP(&lt;nexp&gt;)</h2><p class="Standard">Returns e raised to the &lt;nexp&gt; power.</p><h2 class="Heading_20_2"><a id="a__POW__nexp1____nexp2__"><span/></a><a id="_Toc5235782"/>POW(&lt;nexp1&gt;, &lt;nexp2&gt;)</h2><p class="Standard">Returns &lt;nexp1&gt; raised to the &lt;nexp2&gt; power.</p><h2 class="Heading_20_2"><a id="a__HYPOT__nexp_x____nexp_y_"><span/></a><a id="_Toc5235783"/>HYPOT(&lt;nexp_x&gt;, &lt;nexp_y)</h2><p class="Standard"><span class="T8">Returns SQR(</span><span class="T20">x</span><span class="T35">2</span><span class="T8">+</span><span class="T20">y</span><span class="T35">2</span><span class="T8">) without intermediate overflow or underflow.</span></p><h2 class="Heading_20_2"><a id="a__PI__"><span/></a><a id="_Toc5235784"/>PI()</h2><p class="Standard">Returns the double-precision floating-point value closest to pi.</p><h2 class="Heading_20_2"><a id="a__SIN__nexp__"><span/></a><a id="_Toc5235785"/>SIN(&lt;nexp&gt;)</h2><p class="Standard">Returns the trigonometric sine of angle &lt;nexp&gt;. The units of the angle are radians.</p><h2 class="Heading_20_2"><a id="a__COS__nexp__"><span/></a><a id="_Toc5235786"/>COS(&lt;nexp&gt;)</h2><p class="Standard">Returns the trigonometric cosine of angle &lt;nexp&gt;. The units of the angle are radians.</p><h2 class="Heading_20_2"><a id="a__TAN__nexp__"><span/></a><a id="_Toc5235787"/>TAN(&lt;nexp&gt;)</h2><p class="Standard">Returns the trigonometric tangent of angle &lt;nexp&gt;. The units of the angle are radians.</p><h2 class="Heading_20_2"><a id="a__SINH__nexp__"><span/></a><a id="_Toc5235788"/>SINH(&lt;nexp&gt;)</h2><p class="Standard"><span class="T36">Returns the trigonometric hyperbolic sine of angle &lt;nexp&gt;.</span> The units of the angle are radians.</p><h2 class="Heading_20_2"><a id="a__COSH__nexp__"><span/></a><a id="_Toc5235789"/>COSH(&lt;nexp&gt;)</h2><p class="Standard"><span class="T36">Returns the trigonometric hyperbolic cosine of angle &lt;nexp&gt;.</span> The units of the angle are radians.</p><h2 class="Heading_20_2"><a id="a__ASIN__nexp__"><span/></a><a id="_Toc5235790"/>ASIN(&lt;nexp&gt;)</h2><p class="Standard">Returns the arc sine of the angle &lt;nexp&gt;, in the range of -pi/2 through pi/2. The units of the angle are radians. If the value of &lt;nexp&gt; is less than -1 or greater than 1, the function generates a runtime error.</p><h2 class="Heading_20_2"><a id="a__ACOS__nexp__"><span/></a><a id="_Toc5235791"/>ACOS(&lt;nexp&gt;)</h2><p class="Standard">Returns the arc cosine of the angle &lt;nexp&gt;, in the range of 0.0 through pi.The units of the angle are radians. If the value of &lt;nexp&gt; is less than -1 or greater than 1, the function generates a runtime error.</p><h2 class="Heading_20_2"><a id="a__ATAN__nexp__"><span/></a><a id="_Toc5235792"/>ATAN(&lt;nexp&gt;)</h2><p class="Standard">Returns the arc tangent of the angle &lt;nexp&gt;, in the range of -pi/2 through pi/2. The units of the angle are radians.</p><h2 class="Heading_20_2"><a id="a__ATAN2__nexp_y____nexp_x__"><span/></a><a id="_Toc5235793"/>ATAN2(&lt;nexp_y&gt;, &lt;nexp_x&gt;)</h2><p class="Standard"><span class="T8">Returns the angle </span><span class="T21">theta</span><span class="T8"> from the conversion of rectangular coordinates (</span><span class="HTML_20_Code"><span class="T44">x</span></span><span class="T8">, </span><span class="HTML_20_Code"><span class="T44">y</span></span><span class="T8">) to polar coordinates (r,</span><span class="T20">theta</span><span class="T8">). (Please note the order of the parameters in this function.)</span></p><h2 class="Heading_20_2"><a id="a__TODEGREES__nexp__"><span/></a><a id="_Toc5235794"/>TODEGREES(&lt;nexp&gt;)</h2><p class="Standard">Converts &lt;nexp&gt; angle measured in radians to an approximately equivalent angle measured in degrees.</p><h2 class="Heading_20_2"><a id="a__TORADIANS__nexp__"><span/></a><a id="_Toc5235795"/>TORADIANS(&lt;nexp&gt;)</h2><p class="Standard">Converts &lt;nexp&gt; angle measured in degrees to an approximately equivalent angle measured in radians.</p><h2 class="Heading_20_2"><a id="a__VAL__sexp__"><span/></a><a id="_Toc5235796"/>VAL(&lt;sexp&gt;)</h2><p class="Standard">Returns the numerical value of the string expression &lt;sexp&gt; interpreted as a signed decimal number. If the string is empty ("") or does not represent a number, the function generates a runtime error.</p><ul><li><p class="P25" style="margin-left:1.27cm;"><span class="ListLabel_20_97" style="display:block;float:left;min-width:0.635cm;"></span>A sign ("+" or "-"), a decimal point ("." only), and an exponent (power of 10) are optional.<span class="odfLiEnd"/> </p></li><li><p class="P25" style="margin-left:1.27cm;"><span class="ListLabel_20_97" style="display:block;float:left;min-width:0.635cm;"></span>An exponent is "e" or "E" followed by a number. The number may have a sign but no decimal point.<span class="odfLiEnd"/> </p></li><li><p class="P25" style="margin-left:1.27cm;"><span class="ListLabel_20_97" style="display:block;float:left;min-width:0.635cm;"></span>The string may have leading and/or trailing spaces, but no spaces between any other characters.<span class="odfLiEnd"/> </p></li></ul><h2 class="Heading_20_2"><a id="a__IS_NUMBER__sexp__"><span/></a><a id="_Toc5235797"/>IS_NUMBER(&lt;sexp&gt;)</h2><p class="No_20_Spacing">Tests a string expression &lt;sexp&gt; in the same way as <span class="T7">VAL()</span> and returns a logical value:</p><ul><li><p class="P27" style="margin-left:1.27cm;"><span class="ListLabel_20_101" style="display:block;float:left;min-width:0.635cm;"></span>TRUE (non-zero) if <span class="T7">VAL()</span> would successfully convert the string to a number<span class="odfLiEnd"/> </p></li><li><p class="P27" style="margin-left:1.27cm;"><span class="ListLabel_20_101" style="display:block;float:left;min-width:0.635cm;"></span>FALSE (0) if <span class="T7">VAL()</span> would generate a run-time error.<br/><span style="margin-left:0cm"/>For example, <span class="T7">VAL("name")</span> generates a run-time error, but <span class="T7">IS_NUMBER("name")</span> returns FALSE.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">If <span class="T7">VAL()</span> would report a syntax error, <span class="T7">IS_NUMBER()</span> reports a syntax error.<br/>For example, <span class="T7">IS_NUMBER()</span>, <span class="T7">IS_NUMBER(num)</span>, and<span class="T7"> IS_NUMBER(5)</span> are syntax errors.</p><h2 class="Heading_20_2"><a id="a__LEN__sexp__"><span/></a><a id="_Toc5235798"/>LEN(&lt;sexp&gt;)</h2><p class="Standard">Returns the length of the &lt;sexp&gt;.</p><h2 class="Heading_20_2"><a id="a__HEX__sexp__"><span/></a><a id="_Toc5235799"/>HEX(&lt;sexp&gt;)</h2><p class="Standard">Returns the numerical value of the string expression &lt;sexp&gt; interpreted as a hexadecimal integer. The characters of the string can be only hexadecimal digits (0-9, a-h, or A-H), with an optional leading sign ("+" or "-"), or the function generates a runtime error.</p><h2 class="Heading_20_2"><a id="a__OCT__sexp__"><span/></a><a id="_Toc5235800"/>OCT(&lt;sexp&gt;)</h2><p class="Standard">Returns the numerical value of the string expression &lt;sexp&gt; interpreted as an octal integer. The characters of the string can be only octal digits (0-7), with an optional leading sign ("+" or "-"), or the function generates a runtime error.</p><h2 class="Heading_20_2"><a id="a__BIN__sexp__"><span/></a><a id="_Toc5235801"/>BIN(&lt;sexp&gt;)</h2><p class="Standard">Returns the numerical value of the string expression &lt;sexp&gt; interpreted as a binary integer. The characters of the string can be only binary digits (0 or 1), with an optional leading sign ("+" or "-"), or the function generates a runtime error.</p><h2 class="Heading_20_2"><a id="a__SHIFT__value_nexp____bits_nexp__"><span/></a><a id="_Toc5235802"/>SHIFT(&lt;value_nexp&gt;, &lt;bits_nexp&gt;)</h2><p class="Standard">Shifts the value &lt;value_nexp&gt; by the bit count &lt;bits_nexp&gt;. If the bit count is &lt; 0, the value will be shifted left. If the bit count is &gt; 0, the bits will be shifted right. The right shift will replicate the sign bit. The double-precision floating-point value are truncated to 64-bit integers before the operation.</p><h2 class="Heading_20_2"><a id="a__ASCII__sexp_{___index_nexp_}_"><span/></a><a id="_Toc5235803"/>ASCII(&lt;sexp&gt;{, &lt;index_nexp&gt;})</h2><p class="Standard">Returns the ASCII value of one character of &lt;sexp&gt;. By default, it is the value of the first character. You can use the optional &lt;index_nexp&gt; to select any character. The index of the first character is 1.</p><p class="Standard">A valid ASCII value is between 0 and 255. If &lt;sexp&gt; is an empty string ("") the value returned will be 256 (one more than the largest 8-bit ASCII value). For non-ASCII Unicode characters, <span class="T7">ASCII()</span> returns invalid values; use <span class="T7">UCODE()</span> instead.</p><h2 class="Heading_20_2"><a id="a__UCODE__sexp_{___index_nexp_}_"><span/></a><a id="_Toc5235804"/>UCODE(&lt;sexp&gt;{, &lt;index_nexp&gt;})</h2><p class="Standard">Returns the Unicode value of one character of &lt;sexp&gt;. By default, it is the value of the first character. You can use the optional &lt;index_nexp&gt; to select any character. The index of the first character is 1.</p><p class="Standard">If &lt;sexp&gt; is an empty string ("") the value returned will be 65536 (one more than the largest 16-bit Unicode value). If the selected character of &lt;sexp&gt; is a valid ASCII character, this function returns the same value as <span class="T7">ASCII()</span>.</p><h2 class="Heading_20_2"><a id="a__IS_IN__sub_sexp____base_sexp_{___start_nexp_}_"><span/></a><a id="_Toc5235805"/><span class="T6">IS_IN(&lt;sub</span>_sexp&gt;<span class="T6">, &lt;base</span>_sexp&gt;{, &lt;start_nexp&gt;})</h2><p class="Standard">Returns the position of an occurrence of the substring &lt;sub_sexp&gt; in the base string &lt;base_sexp&gt;.</p><p class="Standard">If the optional start parameter &lt;start_nexp&gt; is not present then the function starts at the first character and searches forward.</p><p class="Standard">If the start parameter is &gt;= 0, then it is the starting position of a forward (left-to-right) search. The left-most character is position 1. If the parameter is negative, it is the starting position of a reverse (right-to-left) search. The right-most character is position -1.</p><p class="Standard">If the substring is not in the base string, the function returns 0. It can not return a value larger than the length of the base string.</p><h2 class="Heading_20_2"><a id="a__STARTS_WITH__sub_sexp____base_sexp_{___start_nexp_}_"><span/></a><a id="_Toc5235806"/>STARTS_WITH(&lt;sub_sexp&gt;, &lt;base_sexp&gt;{, &lt;start_nexp&gt;})</h2><p class="Standard">Determines if the substring &lt;sub_sexp&gt; exactly matches the part of the base string &lt;base_sexp&gt; that starts at the position &lt;start_nexp&gt;. The &lt;start_nexp&gt; parameter is optional; if it is not present then the default starting position is 1, the first character, so the base string must start with the substring. If present, <span class="T38">&lt;</span>start_nexp&gt; must be &gt;= 1.</p><p class="Standard">The function returns the length of the matching substring. If no match is found, the function returns 0.</p><h2 class="Heading_20_2"><a id="a__ENDS_WITH__sub_sexp____base_sexp__"><span/></a><a id="_Toc5235807"/>ENDS_WITH(&lt;sub_sexp&gt;, &lt;base_sexp&gt;)</h2><p class="Standard">Determines if the substring &lt;sub_sexp&gt; exactly matches the end of the base string &lt;base_sexp&gt;.</p><p class="Standard">If the base string ends with the substring, the function returns the index into the base string where the substring starts. The value will always be &gt;= 1. If no match is found, the function returns 0.</p><h2 class="Heading_20_2"><a id="a__GR_COLLISION__object_1_nvar____object_2_nvar__"><span/></a><a id="_Toc5235808"/>GR_COLLISION(&lt;object_1_nvar&gt;, &lt;object_2_nvar&gt;)</h2><p class="Standard">The variables &lt;object_1_nvar&gt; and &lt;object_2_nvar&gt; are the object pointers returned when the objects were created.</p><p class="Standard">If the boundary boxes of the two objects overlap then the function will return true (not zero). If they do not overlap then the function will return false (zero).</p><p class="Standard">Objects that may be tested for collision are: point, rectangle, bitmap, circle, arc, oval, and text. In the case of a circle, an arc, an oval, or text, the object’s rectangular boundary box is used for collision testing, not the actual drawn object.</p><h2 class="Heading_20_2"><a id="a__BACKGROUND__"><span/></a><a id="_Toc5235809"/>BACKGROUND()</h2><p class="Standard">A running BASIC! program continues to run when the HOME key is tapped. This is called running in the Background. When not in the Background mode, BASIC! is in the Foreground mode. BASIC! exits the Background mode and enters the Foreground mode when the BASIC! icon on the home screen is tapped.</p><p class="Standard">Sometimes a BASIC! programmer wants to know if the program is running in the Background. One reason for this might be to stop music playing while in the Background mode.</p><p class="Standard">The <span class="T7">BACKGROUND()</span> function returns true (1) if the program is running in the background. It returns false (0) if the program is not running in the background.</p><p class="Standard">If you want to be able to detect Background mode while Graphics is open, you must not call <span class="T7">Gr.render</span> while in the Background mode. Doing so will cause the program to stop running until the Foreground mode is re-entered. Use the following code line for all <span class="T7">Gr.render</span> commands:</p><p class="Code_20_example"><span class="T11">IF !BACKGROUND() THEN GR.RENDER</span></p><h1 class="Heading_20_1"><a id="a__Time_Functions"><span/></a><a id="_Toc5235810"/>Time Functions</h1><h2 class="Heading_20_2"><a id="a__CLOCK__"><span/></a><a id="_Toc5235811"/>CLOCK()</h2><p class="Standard">Returns the time in milliseconds since the last boot.</p><h2 class="Heading_20_2"><a id="a__TIME__"><span/></a><a id="_Toc5235812"/>TIME()</h2><p class="Standard">Returns the time in milliseconds since 12:00:00 AM, January 1, 1970, UTC (the "epoch"). The time interval is the same everywhere in the world, so the value is not affected by the <span class="T7">TimeZone</span> command.</p><h2 class="Heading_20_2"><a id="a__TIME__year_exp____month_exp____day_exp____hour_exp____minute_exp____second_exp__"><span/></a><a id="_Toc5235813"/>TIME(&lt;year_exp&gt;, &lt;month_exp&gt;, &lt;day_exp&gt;, &lt;hour_exp&gt;, &lt;minute_exp&gt;, &lt;second_exp&gt;)</h2><p class="Standard">Like <span class="T7">TIME()</span>, except the parameters specify a moment in time. The specification is not complete, as it does not include the timezone. You may specify a timezone with the <span class="T7">TimeZone</span> command. If you do not specify a timezone, your local timezone is used.</p><p class="Standard">The parameter expressions may be either numeric expressions or string expressions. This is an unusual aspect as it isn't allowed anywhere else in BASIC!. If a parameter is a string, then it must evaluate to a number: digits only, one optional decimal point somewhere, optional leading sign, no embedded spaces. If the string parameter does not follow the rules, BASIC! reports a syntax error, like using a string in a place that expects a numeric expression.</p><p class="Standard"><span class="T7">TIME(…)</span> (the function) and <span class="T7">Time</span> (the command) are inverse operations. <span class="T7">TIME(…)</span> can take the first six return parameters of the <span class="T7">Time</span> command directly as input parameters.</p><p class="Standard">With the <span class="T7">USING$()</span> or <span class="T7">FORMAT_USING$()</span> functions, you can express a moment in time as a string in many different ways, formatted for your locale.</p><h1 class="Heading_20_1"><a id="a__String_Functions"><span/></a><a id="_Toc5235814"/>String Functions</h1><h2 class="Heading_20_2"><a id="a__GETERROR$__"><span/></a><a id="_Toc5235815"/>GETERROR$()</h2><p class="Standard">Return information about a possible error condition.</p><p class="Standard">An error that stops your program writes an error message to the Console. If you trap the error with the <span class="T7">OnError:</span> interrupt label, your program does not stop and the error is not printed. You can use <span class="T7">GETERROR$()</span> to retrieve the error message.</p><p class="Standard">Certain commands can report errors without stopping your program. These commands include <span class="T7">App.broadcast</span>, <span class="T7">App.start</span>, <span class="T7">Audio.load</span>, <span class="T7">Byte.open</span>, <span class="T7">Text.open</span>, <span class="T7">Zip.Open</span>, <span class="T7">Encrypt</span>, <span class="T7">Decrypt</span>, <span class="T7">Font.load</span>, <span class="T7">GPS.open</span>, <span class="T7">GrabFile</span>, <span class="T7">GrabURL</span>, <span class="T7">Gr.get.type</span>, the <span class="T7">ENCODE$()</span> and <span class="T7">DECODE$()</span> functions, and any command that can create a bitmap.</p><p class="Standard">When you run one of these commands, you can call <span class="T7">GETERROR$()</span> to retrieve information about the error state. For example, if <span class="T7">Text.open</span> cannot open a file, it sets the file pointer to -1, and writes a <span class="T7">GETERROR$()</span> message such as "&lt;filename&gt; not found". If no error occurred, <span class="T7">GETERROR$()</span> returns the string "No error".</p><p class="Standard">Because there are commands that clear the error message, you should not expect <span class="T7">GETERROR$()</span> to retain its message. Capture the message in a variable as soon as possible, and do not call <span class="T7">GETERROR$()</span> again for the same error.</p><h2 class="Heading_20_2"><a id="a__CHR$__nexp_______"><span/></a><a id="_Toc5235816"/><span class="T48">CHR$</span>(&lt;nexp&gt;, ...)</h2><p class="Standard">Return the character string represented by the values of list of numerical expressions. Each &lt;nexp&gt; is converted to a character. The expressions may have values greater than 255 and thus can be used to generate Unicode characters.</p><p class="Code_20_example"><span class="T11">PRINT CHR$(16*4 + 3)                % Hexadecimal 43 is the character "C". This prints: </span><span class="T39">C</span></p><p class="Code_20_example"><span class="T11">PRINT CHR$(945, 946)                % Decimal for the characters alpha and beta: Prints: </span><span class="T36">αβ</span></p><h2 class="Heading_20_2"><a id="a__LEFT$__sexp____count_nexp__"><span/></a><a id="_Toc5235817"/><span class="T6">LEFT$(&lt;sexp&gt;, </span>&lt;count_nexp&gt;<span class="T6">)</span></h2><p class="Standard">Return the left-most characters of the string &lt;sexp&gt;. The number of characters to return is set by the count parameter, &lt;count_nexp&gt;.</p><ul><li><p class="P28" style="margin-left:1.27cm;"><span class="ListLabel_20_53" style="display:block;float:left;min-width:0.635cm;"></span>If the count is greater than 0, return &lt;count_nexp&gt; characters, counting from the left.<span class="odfLiEnd"/> </p></li><li><p class="P28" style="margin-left:1.27cm;"><span class="ListLabel_20_53" style="display:block;float:left;min-width:0.635cm;"></span>If the count is less than 0, return all but &lt;count_nexp&gt; characters. The number to return is the string length reduced by &lt;count_nexp&gt;: <span class="T7">LEFT$(a$, -2)</span> is the same as <span class="T7">LEFT$(a$, LEN(a$) - 2)</span>.<span class="odfLiEnd"/> </p></li><li><p class="P28" style="margin-left:1.27cm;"><span class="ListLabel_20_53" style="display:block;float:left;min-width:0.635cm;"></span>If the count is 0, return an empty string ("").<span class="odfLiEnd"/> </p></li><li><p class="P28" style="margin-left:1.27cm;"><span class="ListLabel_20_53" style="display:block;float:left;min-width:0.635cm;"></span>If the count is greater than the length of the string, return the entire string.<span class="odfLiEnd"/> </p></li></ul><h2 class="Heading_20_2"><a id="a__MID$__sexp____start_nexp_{___count_nexp_}_"><span/></a><a id="_Toc5235818"/><span class="T6">MID$(&lt;sexp&gt;, </span>&lt;start_nexp&gt;{, &lt;count_nexp&gt;}<span class="T6">)</span></h2><p class="Standard">Return a substring of the string &lt;sexp&gt;, beginning or ending at the start position &lt;start_nexp&gt;. The first character of the string is at position 1. If the start position is 0 or negative, it is set to 1.</p><p class="Standard">The count parameter is optional. If it is omitted, return all of the characters from the start position to the end of the string.</p><p class="Code_20_example"><span class="T12">a$ = MID$("dinner", 2)                % a$ is "inner"</span></p><p class="Standard">Otherwise, the absolute value of the count specifies the length of the returned substring:</p><ul><li><p class="P29" style="margin-left:1.27cm;"><span class="ListLabel_20_57" style="display:block;float:left;min-width:0.635cm;"></span>If the count is greater than 0, begin at &lt;start_nexp&gt; and count characters to the <span class="T7">right</span>.<br/><span style="margin-left:0cm"/>That is, return the substring that <span class="T7">begins</span> at the start position.<br/><span style="margin-left:0cm"/>If the start position is greater than the length of the string, return an empty string ("").<span class="odfLiEnd"/> </p></li><li><p class="P29" style="margin-left:1.27cm;"><span class="ListLabel_20_57" style="display:block;float:left;min-width:0.635cm;"></span>If the count is less than 0, begin at &lt;start_nexp&gt; and count characters to the <span class="T7">left</span>.<br/><span style="margin-left:0cm"/>That is, return the substring that <span class="T7">ends</span> at the start position.<br/><span style="margin-left:0cm"/>If the start position is greater than the length of the string, it is set to the end of the string.<span class="odfLiEnd"/> </p></li><li><p class="P29" style="margin-left:1.27cm;"><span class="ListLabel_20_57" style="display:block;float:left;min-width:0.635cm;"></span>If the count is 0, return an empty string ("").<span class="odfLiEnd"/> </p></li></ul><p class="Code_20_example"><span class="T12">a$ = MID$("dinner", 2, 3)                % a$ is "inn"</span></p><p class="Code_20_example"><span class="T12">a$ = MID$("dinner", 4, -3)                % a$ is "inn"</span></p><p class="Code_20_example"><span class="T12">a$ = MID$("dinner", 3, 0)                % a$ is ""</span></p><h2 class="Heading_20_2"><a id="a__RIGHT$__sexp____count_nexp__"><span/></a><a id="_Toc5235819"/><span class="T6">RIGHT$(</span>&lt;sexp&gt;, &lt;count_nexp&gt;<span class="T6">)</span></h2><p class="Standard">Return the right-most characters of the string &lt;sexp&gt;. The number of characters to return is set by the count parameter, &lt;count_nexp&gt;.</p><ul><li><p class="P29" style="margin-left:1.27cm;"><span class="ListLabel_20_57" style="display:block;float:left;min-width:0.635cm;"></span>If the count is greater than 0, return &lt;count_nexp&gt; characters, counting from the right.<span class="odfLiEnd"/> </p></li><li><p class="P29" style="margin-left:1.27cm;"><span class="ListLabel_20_57" style="display:block;float:left;min-width:0.635cm;"></span>If the count is less than 0, return all but &lt;count_nexp&gt; characters. The number to return is the string length reduced by &lt;count_nexp&gt;: <span class="T7">RIGHT$(a$, -2)</span> is the same as <span class="T7">RIGHT$(a$, LEN(a$) - 2)</span>.<span class="odfLiEnd"/> </p></li><li><p class="P29" style="margin-left:1.27cm;"><span class="ListLabel_20_57" style="display:block;float:left;min-width:0.635cm;"></span>If the count is 0, return an empty string ("").<span class="odfLiEnd"/> </p></li><li><p class="P29" style="margin-left:1.27cm;"><span class="ListLabel_20_57" style="display:block;float:left;min-width:0.635cm;"></span>If the count is greater than the length of the string, return the entire string.<span class="odfLiEnd"/> </p></li></ul><h2 class="Heading_20_2"><a id="a__REPLACE$__sexp____argument_sexp____replace_sexp__"><span/></a><a id="_Toc5235820"/><span class="T6">REPLACE$(&lt;sexp&gt;, &lt;argument_sexp&gt;, &lt;replace_sexp&gt;)</span></h2><p class="Standard">Returns &lt;sexp&gt; with all instances of &lt;argument_sexp&gt; replaced with &lt;replace_sexp&gt;.</p><h2 class="Heading_20_2"><a id="a__TRIM$__sexp_{___test_sexp_}_"><span/></a><a id="_Toc5235821"/><span class="T48">TRIM$</span>(&lt;sexp&gt;{, &lt;test_sexp&gt;})</h2><p class="Standard">Returns &lt;sexp&gt; with leading and trailing occurrences of &lt;test_sexp&gt; removed.</p><p class="Standard">The expression to trim off, &lt;test_sexp&gt;, is optional. If omitted, all leading and trailing whitespace is removed. That is, the default &lt;test_sexp&gt; is the regular expression "\s+", which means "all whitespace". To use this regular expression in a BASIC! string, you must write it "\\s+" (escape the backslash).</p><p class="Standard">As with the <span class="T7">WORD$()</span> function and the <span class="T7">SPLIT</span> command, the &lt;test_exp&gt; is a regular expression. See <span class="T7">Split</span> for a note about Regular Expressions.</p><h2 class="Heading_20_2"><a id="a__LTRIM$__sexp_{___test_sexp_}_"><span/></a><a id="_Toc5235822"/><span class="T48">LTRIM$</span>(&lt;sexp&gt;{, &lt;test_sexp&gt;})</h2><h2 class="Heading_20_2"><a id="a__RTRIM$__sexp_{___test_sexp_}_"><span/></a><a id="_Toc5235823"/><span class="T48">RTRIM$</span>(&lt;sexp&gt;{, &lt;test_sexp&gt;})</h2><p class="Standard">Exactly like <span class="T7">TRIM$()</span>, except that <span class="T7">LTRIM$()</span> trims only the left end of the source string &lt;sexp&gt;, while <span class="T7">RTRIM$()</span> trims only the right end.</p><h2 class="Heading_20_2"><a id="a__WORD$__source_sexp____n_nexp__{___test_sexp_}_"><span/></a><a id="_Toc5235824"/><span class="T6">WORD$(&lt;source_sexp&gt;, &lt;n_nexp&gt; {, &lt;test_sexp&gt;})</span></h2><p class="Standard">This function returns a word from a string. The &lt;source_sexp&gt; string is split into substrings at each location where &lt;test_sexp&gt; occurs. The &lt;n_nexp&gt; parameter specifies which substring to return; numbering starts at 1. The &lt;test_sexp&gt; is removed from the result. The &lt;test_sexp&gt; parameter is an optional Regular Expression; if it is not given, the source string is split on whitespace. Specifically, the default &lt;test_sexp&gt; is "\s+".</p><p class="Standard">Leading and trailing occurrences of &lt;test_sexp&gt; are stripped from &lt;source_sexp&gt; before it is split. If &lt;n_nexp&gt; is less than 1 or greater than the number of substrings found in &lt;source_sexp&gt;, then an empty string ("") is returned. Two adjacent occurrences of &lt;test_sexp&gt; in &lt;source_sexp&gt; result in an empty string; &lt;n_nexp&gt; may select this empty string as the return value.</p><p class="No_20_Spacing">Examples:</p><p class="Code_20_example"><span class="T11">string$ = "The quick brown fox"</span></p><p class="Code_20_example"><span class="T11">result$ = WORD$(string$, 2);                         % result$ is "quick"</span></p><p class="P2"> </p><p class="Code_20_example"><span class="T11">string$ = ":a:b:c:d"</span></p><p class="Code_20_example"><span class="T11">delimiter$ = ":"</span></p><p class="Code_20_example"><span class="T11">SPLIT array$[], string$, delimiter$               % array$[1] is ""</span></p><p class="Code_20_example"><span class="T11">result$ = WORD$(string$, 1, delimiter$)      % result$ is "a", not ""</span></p><p class="Standard">This function is similar to the <span class="T7">Split</span> command. See <span class="T7">Split</span> for a note about Regular Expressions.</p><h2 class="Heading_20_2"><a id="a__ENCODE$__type_sexp___{_qualifier_sexp_}___source_sexp__"><span/></a><a id="_Toc5235825"/>ENCODE$(&lt;type_sexp&gt;, {&lt;qualifier_sexp&gt;}, &lt;source_sexp&gt;)</h2><p class="Standard">Returns the string &lt;source_sexp&gt; encoded in one of several ways, as specified by the &lt;type_sexp&gt;. The &lt;qualifier_sexp&gt; usage depends on the type:</p><table border="0" cellspacing="0" cellpadding="0" class="Table4"><colgroup><col width="139"/><col width="83"/><col width="76"/><col width="430"/></colgroup><tr class="Table41"><td style="text-align:left;width:3.175cm; " class="Table4_A1"><p class="P120">Type</p></td><td style="text-align:left;width:1.905cm; " class="Table4_A1"><p class="P120">Qualifier</p></td><td style="text-align:left;width:1.744cm; " class="Table4_A1"><p class="P120">Default</p></td><td style="text-align:left;width:9.843cm; " class="Table4_A1"><p class="P120">Result</p></td></tr><tr class="Table41"><td style="text-align:left;width:3.175cm; " class="Table4_A1"><p class="P110">"ENCRYPT"</p></td><td style="text-align:left;width:1.905cm; " class="Table4_A1"><p class="P110">password</p></td><td style="text-align:left;width:1.744cm; " class="Table4_A1"><p class="P110">"" (empty)</p></td><td style="text-align:left;width:9.843cm; " class="Table4_A1"><p class="P114">Encrypts the source string using the password parameter. The encryption algorithm is "PBEWithMD5AndDES". This usage of<span class="T7"> ENCODE$()</span> works the same way as the <span class="T7">ENCRYPT</span> command. Use the <span class="T7">DECODE$()</span> function to decrypt.</p></td></tr><tr class="Table41"><td style="text-align:left;width:3.175cm; " class="Table4_A1"><p class="P110">"DECRYPT"</p></td><td style="text-align:left;width:1.905cm; " class="Table4_A1"><p class="P110">password</p></td><td style="text-align:left;width:1.744cm; " class="Table4_A1"><p class="P110">""</p></td><td style="text-align:left;width:9.843cm; " class="Table4_A1"><p class="P114">Same as type "ENCRYPT" (encrypts, does not decrypt).</p></td></tr><tr class="Table41"><td style="text-align:left;width:3.175cm; " class="Table4_A1"><p class="P110">"ENCRYPT_RAW"</p></td><td style="text-align:left;width:1.905cm; " class="Table4_A1"><p class="P110">password</p></td><td style="text-align:left;width:1.744cm; " class="Table4_A1"><p class="P110">""</p></td><td style="text-align:left;width:9.843cm; " class="Table4_A1"><p class="P114">Same as type "ENCRYPT" except the input and output are buffer strings. This is useful for encrypting binary data.</p></td></tr><tr class="Table41"><td style="text-align:left;width:3.175cm; " class="Table4_A1"><p class="P110">"DECRYPT_RAW"</p></td><td style="text-align:left;width:1.905cm; " class="Table4_A1"><p class="P110">password</p></td><td style="text-align:left;width:1.744cm; " class="Table4_A1"><p class="P110">""</p></td><td style="text-align:left;width:9.843cm; " class="Table4_A1"><p class="P114">Same as "ENCRYPT_RAW" (encrypts, does not decrypt).</p></td></tr><tr class="Table41"><td style="text-align:left;width:3.175cm; " class="Table4_A1"><p class="P110">"URL"</p></td><td style="text-align:left;width:1.905cm; " class="Table4_A1"><p class="P110">charset</p></td><td style="text-align:left;width:1.744cm; " class="Table4_A1"><p class="P110">"UTF-8"</p></td><td style="text-align:left;width:9.843cm; " class="Table4_A1"><p class="P130"><span class="T40">Encodes the source string using the format required by HTML </span><a href="http://www.w3.org/TR/html4/interact/forms.html#h-17.13.4.1" class="Internet_20_link"><span class="Internet_20_link"><span class="T49">application/x-www-form-urlencoded</span></span></a><span class="T40">. You should omit the charset parameter.</span></p></td></tr><tr class="Table41"><td style="text-align:left;width:3.175cm; " class="Table4_A1"><p class="P110">"BASE64"</p></td><td style="text-align:left;width:1.905cm; " class="Table4_A1"><p class="P110">charset</p></td><td style="text-align:left;width:1.744cm; " class="Table4_A1"><p class="P110">"UTF-8"</p></td><td style="text-align:left;width:9.843cm; " class="Table4_A1"><p class="P130"><span class="T40">Encodes the source string into the Base64 representation of binary data. See RFCs </span><a href="http://www.ietf.org/rfc/rfc2045.txt" class="Internet_20_link"><span class="Internet_20_link"><span class="T40">2045</span></span></a><span class="T40"> and </span><a href="http://www.ietf.org/rfc/rfc3548.txt" class="Internet_20_link"><span class="Internet_20_link"><span class="T40">3548</span></span></a><span class="T40">. The simplest way to use this function is to omit the charset parameter.</span></p></td></tr></table><p class="P80">The type is required, but see below for the two-parameter form of <span class="T7">ENCODE$()</span> and <span class="T7">DECODE$()</span>.</p><p class="P80">The type IS NOT case-sensitive: "BASE64", "base64", and "Base64" are all the same.</p><p class="P80">The qualifier is optional, but its comma is required.</p><p class="P80">If you supply the qualifier, whether password or charset, it IS case-sensitive.</p><p class="Standard">If the source string cannot be encoded (or encrypted) with the specified charset (or password), the function returns an empty string (""). You can call the <span class="T7">GETERROR$()</span> function to get an error message.</p><p class="Standard">"ENCRYPT", "DECRYPT", and "URL" can be used on any BASIC! string. The string is converted to a byte stream, then the byte stream is encrypted or URL-encoded. The encrypted byte stream is converted to string format using the Base64 representation of binary data (see comment for "BASE64" in the table above. URL-encoded strings do not require this extra step.</p><p class="Standard">"ENCRYPT_RAW" and "DECRYPT_RAW" are intended for use with binary data in a buffer string. A buffer string is a special use of the BASIC! string in which each 16-bit character consists of one byte of 0 and one byte of data. "ENCRYPT_RAW" can encrypt a buffer string or an ASCII text string, but using it on Unicode text will corrupt the string. After encryption, the result is returned in another buffer string.</p><p class="Standard">"BASE64" also converts its string to a byte-stream before encoding it to Base64. The default conversion, using UTF-8, works with any BASIC! string; specifying another character set encoding may corrupt data.</p><p class="Standard">Normally, you would use "BASE64" on binary data in a buffer string. In this case, you may specify any valid charset with no data corruption. The encoding string will change, but it can always be decoded using the same charset.</p><p class="Standard">See the two-parameter form of <span class="T7">ENCODE$()</span>, below, for a partial list of valid charsets.</p><h2 class="Heading_20_2"><a id="a__DECODE$__type_sexp___{_qualifier_sexp_}___source_sexp__"><span/></a><a id="_Toc5235826"/>DECODE$(&lt;type_sexp&gt;, {&lt;qualifier_sexp&gt;}, &lt;source_sexp&gt;)</h2><p class="Standard">Returns the result of decoding a string &lt;source_sexp&gt; that was encoded with ENCODE$(). The &lt;type_sexp&gt;and &lt;qualifier_sexp&gt; describe how the string was encoded. You must use the same type and qualifier that were used to encode the source string, or you may get unpredictable results.</p><table border="0" cellspacing="0" cellpadding="0" class="Table5"><colgroup><col width="97"/><col width="97"/><col width="83"/><col width="451"/></colgroup><tr class="Table51"><td style="text-align:left;width:2.221cm; " class="Table5_A1"><p class="P120">Type</p></td><td style="text-align:left;width:2.224cm; " class="Table5_A1"><p class="P120">Qualifier</p></td><td style="text-align:left;width:1.905cm; " class="Table5_A1"><p class="P120">Default</p></td><td style="text-align:left;width:10.317cm; " class="Table5_A1"><p class="P120">Result</p></td></tr><tr class="Table51"><td style="text-align:left;width:2.221cm; " class="Table5_A1"><p class="P110">"ENCRYPT"</p></td><td style="text-align:left;width:2.224cm; " class="Table5_A1"><p class="P110">password</p></td><td style="text-align:left;width:1.905cm; " class="Table5_A1"><p class="P110">"" (empty)</p></td><td style="text-align:left;width:10.317cm; " class="Table5_A1"><p class="P114">Decrypts the source string using the password parameter. The encryption algorithm is "PBEWithMD5AndDES". This usage of<span class="T7"> DECODE$()</span> works the same way as the <span class="T7">DECRYPT</span> command.</p></td></tr><tr class="Table51"><td style="text-align:left;width:2.221cm; " class="Table5_A1"><p class="P110">"DECRYPT"</p></td><td style="text-align:left;width:2.224cm; " class="Table5_A1"><p class="P110">password</p></td><td style="text-align:left;width:1.905cm; " class="Table5_A1"><p class="P110">""</p></td><td style="text-align:left;width:10.317cm; " class="Table5_A1"><p class="P114">Same as type "ENCRYPT" (decrypts, does not encrypt).</p></td></tr><tr class="Table51"><td style="text-align:left;width:2.221cm; " class="Table5_A1"><p class="P110">"ENCRYPT"</p></td><td style="text-align:left;width:2.224cm; " class="Table5_A1"><p class="P110">password</p></td><td style="text-align:left;width:1.905cm; " class="Table5_A1"><p class="P110">""</p></td><td style="text-align:left;width:10.317cm; " class="Table5_A1"><p class="P114">Same as type "DECRYPT" except the input and output are buffer strings. This is useful for decrypting binary data.</p></td></tr><tr class="Table51"><td style="text-align:left;width:2.221cm; " class="Table5_A1"><p class="P110">"DECRYPT"</p></td><td style="text-align:left;width:2.224cm; " class="Table5_A1"><p class="P110">password</p></td><td style="text-align:left;width:1.905cm; " class="Table5_A1"><p class="P110">""</p></td><td style="text-align:left;width:10.317cm; " class="Table5_A1"><p class="P114">Same as type "ENCRYPT".</p></td></tr><tr class="Table51"><td style="text-align:left;width:2.221cm; " class="Table5_A1"><p class="P110">"URL"</p></td><td style="text-align:left;width:2.224cm; " class="Table5_A1"><p class="P110">charset</p></td><td style="text-align:left;width:1.905cm; " class="Table5_A1"><p class="P110">"UTF-8"</p></td><td style="text-align:left;width:10.317cm; " class="Table5_A1"><p class="P130"><span class="T40">Decodes the source string assumed to be in the format required by HTML </span><a href="http://www.w3.org/TR/html4/interact/forms.html#h-17.13.4.1" class="Internet_20_link"><span class="Internet_20_link"><span class="T49">application/x-www-form-urlencoded</span></span></a><span class="T40">. You should omit the charset parameter.</span></p></td></tr><tr class="Table51"><td style="text-align:left;width:2.221cm; " class="Table5_A1"><p class="P110">"BASE64"</p></td><td style="text-align:left;width:2.224cm; " class="Table5_A1"><p class="P110">charset</p></td><td style="text-align:left;width:1.905cm; " class="Table5_A1"><p class="P110">"UTF-8"</p></td><td style="text-align:left;width:10.317cm; " class="Table5_A1"><p class="P130"><span class="T40">Decodes the source string holding the Base64 representation of binary data. See RFCs </span><a href="http://www.ietf.org/rfc/rfc2045.txt" class="Internet_20_link"><span class="Internet_20_link"><span class="T40">2045</span></span></a><span class="T40"> and </span><a href="http://www.ietf.org/rfc/rfc3548.txt" class="Internet_20_link"><span class="Internet_20_link"><span class="T40">3548</span></span></a><span class="T40">.</span></p></td></tr></table><p class="P80">The type is required, but see below for the two-parameter form of <span class="T7">ENCODE$()</span> and <span class="T7">DECODE$()</span>.</p><p class="P80">The type IS NOT case-sensitive: "BASE64", "base64", and "Base64" are all the same.</p><p class="P80">The qualifier is optional, but its comma is required.</p><p class="P80">If you supply the qualifier, whether password or charset, it IS case-sensitive.</p><p class="Standard">The source string is decoded to a byte stream according to the type. Then the byte stream is converted to a BASIC! string (UTF-16) according to the character encoding (the charset parameter), which describes how to interpret the byte stream. The charset is always UTF-8 for decryption, and defaults to UTF-8 for the other types. The most common usage of this function is to omit the charset.</p><p class="Standard">If the source string was encoded from binary data (with "ENCRYPT_RAW" or "BASE64"), the resulting BASIC! string will be a buffer string. When a string is used as a buffer, one byte of data is written into the lower 8 bits of each 16-bit character, and the upper 8 bits are 0. You can extract the binary data from the string, one byte at a time, using the <span class="T7">ASCII()</span> or <span class="T7">UCODE()</span> functions.</p><p class="Standard">If the source string cannot be decoded (or decrypted) with the specified charset (or password), the function returns an empty string (""). You can call the <span class="T7">GETERROR$()</span> function to get an error message.</p><p class="Standard">See the two-parameter form of <span class="T7">ENCODE$()</span>, below, for a partial list of valid charsets.</p><h2 class="Heading_20_2"><a id="a__ENCODE$__charset_sexp____source_sexp__"><span/></a><a id="_Toc5235827"/>ENCODE$(&lt;charset_sexp&gt;, &lt;source_sexp&gt;)</h2><p class="Standard">Encodes the string &lt;source_sexp&gt; using the character encoding of the &lt;charset_sexp&gt; and returns the result in a buffer string. When a string is used as a buffer, one byte of data is written into the lower 8 bits of each 16-bit character, and the upper 8 bits are 0.</p><p class="Standard">The charset specifies the rules used to convert the source string into a byte stream. The stream is written to a buffer string, one byte per character. The bytes are not reassembled into 16-bit characters.</p><p class="Standard">The charsets "UTF-8", "UTF-16", "UTF-16BE", "UTF-16LE", "US-ASCII", and "ISO-8859-1" are always available. Your device may have additional charsets. The charset names are case-sensitive, but the standard charsets have aliases for convenience. For example, "utf8" is valid.</p><p class="Standard">If the source string cannot be encoded with the specified charset, the function returns an empty string (""). You can call the <span class="T7">GETERROR$()</span> function to get an error message.</p><p class="Standard">If you create a buffer string with <span class="T7">ENCODE$()</span>, you can write the bytes to a file with <span class="T7">Byte.write.buffer</span>.</p><p class="Standard">For encryption and URL- or Base64-encoding, see the three-parameter form of <span class="T7">ENCODE$()</span>, above.</p><h2 class="Heading_20_2"><a id="a__DECODE$__charset_sexp____buffer_sexp__"><span/></a><a id="_Toc5235828"/>DECODE$(&lt;charset_sexp&gt;, &lt;buffer_sexp&gt;)</h2><p class="Standard">Decodes the buffer string &lt;buffer_sexp&gt; that was encoded using the &lt;charset_sexp&gt; and returns the result in a standard BASIC! string. A buffer string is a special use of the BASIC! string in which each 16-bit character consists of one byte of 0 and one byte of data.</p><p class="Standard">If the source string cannot be decoded with the specified charset, the function returns an empty string (""). You can call the <span class="T7">GETERROR$()</span> function to get an error message.</p><p class="Standard">If you attempt to <span class="T7">DECODE$()</span> a string that is not a buffer string, you may get unexpected results. Besides the function <span class="T7">ENCODE$()</span>, the commands <span class="T7">Byte.read.buffer</span> and <span class="T7">BT.read.bytes</span> can write buffer strings. Your program can also build such strings directly, character-by-character.</p><p class="Standard">If you read data from a file with <span class="T7">Byte.read.buffer</span>, you can use <span class="T7">DECODE$()</span> to reassemble the bytes into BASIC! (UTF-16) strings. The charset specifies how the original string was encoded when it was written as bytes to the file.</p><p class="Standard">For example, a binary file may have embedded text strings for names or titles. In order to allow Unicode, the text may be encoded. Let’s say you read 32 bytes of binary data, consisting of 8 bytes of binary and 24 bytes of UTF-8-encoded text:</p><p class="Code_20_example"><span class="fj9y4"><span class="T11">BYTE.READ.BUFFER file, 32, bfr$</span></span></p><p class="Code_20_example"><span class="fj9y4"><span class="T11">namebfr$ = MID$(bfr$, 9)</span></span></p><p class="Code_20_example"><span class="fj9y4"><span class="T11">name$ = DECODE$("UTF-8", namebfr$)</span></span></p><p class="Standard">For encryption and URL- or Base64-decoding, see the three-parameter form of <span class="T7">DECODE$()</span>, above.</p><h2 class="Heading_20_2"><a id="a__STR$__nexp__"><span/></a><a id="_Toc5235829"/><span class="T6">STR$(</span>&lt;nexp&gt;<span class="T6">)</span></h2><p class="Standard">Returns the string representation of &lt;nexp&gt;.</p><h2 class="Heading_20_2"><a id="a__LOWER$__sexp__"><span/></a><a id="_Toc5235830"/><span class="T6">LOWER$(</span>&lt;sexp&gt;<span class="T6">)</span></h2><p class="Standard">Returns &lt;sexp&gt; in all lower case characters.</p><h2 class="Heading_20_2"><a id="a__UPPER$__sexp__"><span/></a><a id="_Toc5235831"/><span class="T6">UPPER$(</span>&lt;sexp&gt;<span class="T6">)</span></h2><p class="Standard">Returns &lt;nexp&gt; in all upper case characters.</p><h2 class="Heading_20_2"><a id="a__VERSION$__"><span/></a><a id="_Toc5235832"/><span class="T6">VERSION$()</span></h2><p class="Standard">Returns the version number of BASIC! as a string.</p><h2 class="Heading_20_2"><a id="a__INT$__nexp__"><span/></a><a id="_Toc5235833"/><span class="T6">INT$(&lt;nexp&gt;)</span></h2><p class="Standard">Returns a string representing the integer part of the numeric expression.</p><h2 class="Heading_20_2"><a id="a__HEX$__nexp__"><span/></a><a id="_Toc5235834"/><span class="T6">HEX$(&lt;nexp&gt;)</span></h2><p class="Standard">Returns a string representing the hexadecimal representation of the numeric expression.</p><h2 class="Heading_20_2"><a id="a__OCT$__nexp__"><span/></a><a id="_Toc5235835"/>OCT$(&lt;nexp&gt;)</h2><p class="Standard">Returns a string representing the octal representation of the numeric expression.</p><h2 class="Heading_20_2"><a id="a__BIN$__nexp__"><span/></a><a id="_Toc5235836"/>BIN$(&lt;nexp&gt;)</h2><p class="Standard">Returns a string representing the binary representation of the numeric expression.</p><h2 class="Heading_20_2"><a id="a__USING$_{_locale_sexp_}____format_sexp__{____exp_}____"><span/></a><a id="_Toc5235837"/>USING$({&lt;locale_sexp&gt;} , &lt;format_sexp&gt; { , &lt;exp&gt;}...)</h2><p class="Standard">Returns a string, using the locale and format expressions to format the expression list.</p><p class="Standard">This function gives BASIC! programs access to the Formatter class of the Android platform. You can find full documentation here: <a href="http://developer.android.com/reference/java/util/Formatter.html" class="Internet_20_link"><span class="Internet_20_link">http://developer.android.com/reference/java/util/Formatter.html</span></a>.</p><p class="Standard">The &lt;locale_sexp&gt; is a string that tells the formatter to use the formatting conventions of a specific language and region or country. For example, "en_US" specifies American English conventions.</p><p class="Standard">The &lt;format_sexp&gt; is a string that contains <span class="T18">format specifiers</span>, like "%d" or "%7.2f," that tell the formatter what to do with the expressions that follow.</p><p class="Standard">The format string is followed by a list of zero or more expressions. Most format specifiers take one argument from the list, in order. If you don’t provide as many arguments as your format string needs, you will get a detailed Java error message.</p><p class="Standard">Each expression must also match the type of the corresponding format specifier. If you try to apply a string format specifier, like "%-7s", to a number, or a floating point specifier, like "%5.2f" to a string, you will get a Java error message.</p><h3 class="Heading_20_3"><a id="a__Locale_expression"><span/></a><a id="_Toc5235838"/>Locale expression</h3><p class="Standard">The <span class="T7">USING$()</span> function can localize the output string based on language and region. The locale specifies the language and region with standardized codes. The &lt;locale_sexp&gt; is a string containing zero or more codes separated by underscores.</p><p class="Standard">The function accepts up to three codes. The first must be a language code, such as "en", "de", or "ja". The second must be a region or country code, such as "FR", "US", or "IN". Some language and country combinations can accept a third code, called the "variant code".</p><p class="Standard">The function also accepts the standard three-letter codes and numeric codes for country or region. For example, "fr_FR", "fr_FRA", and "fr_250" are all equivalent.</p><p class="Standard">If you want to use the default locale of your Android device, make the &lt;locale_exp&gt; an empty string (""), or leave it out altogether. If you leave it out, you must keep the comma: <span class="T7">USING$(, "%f", x)</span></p><p class="Standard">If you make a mistake in the &lt;locale_sexp&gt;, you may get an obscure Java error message, but more likely your locale will be ignored, and your string will be formatted using the default locale of your device.</p><p class="Standard">Android devices do not support all possible locales. If you specify a valid locale that your device does not understand, your string will be formatted using the default locale.</p><h3 class="Heading_20_3"><a id="a__Format_expression"><span/></a><a id="_Toc5235839"/>Format expression</h3><p class="Standard">If you are familiar with the <span class="T18">printf</span> functions of C/C++, Perl, or other languages, you will recognize most of format specifiers of this function. The format expression is exactly the same as format string of the Java <span class="T18">Formatter</span> class, or the <span class="T18">format(String, Object…)</span> method of the Java <span class="T18">String</span>, with two exceptions: Boolean format specifiers are not supported, and hex hash specifiers are limited to numeric and string types.</p><p class="Standard">If you have not programmed in one of those other languages, this will be your introduction to a powerful tool for formatting text.</p><p class="Standard">A format expression is a string with embedded format specifiers. Anything that is not a format specifier is copied literally to the function output string. Each embedded format specifier is replaced with the value of an expression from the list, formatted according to the specifier. For example:</p><p class="Code_20_example"><span class="T11">PRINT USING$("","Pi is approximately %f.", PI())        </span><span class="T26"></span><span class="T11"> function call</span></p><p class="Code_20_example"><span class="T11">Pi is approximately 3.141593.                        </span><span class="T26"></span><span class="T11"> printed output for English locale</span></p><p class="List_20_Paragraph">The &lt;locale_exp&gt; is "", meaning "use my default locale".</p><p class="List_20_Paragraph">The &lt;format_exp&gt;, "Pi is approximately %f", has one format specifier, "%f".</p><p class="List_20_Paragraph">"%f" means, "use the default decimal floating point output format".</p><p class="List_20_Paragraph">The expression list has one item, the math function <span class="T7">PI()</span>.</p><p class="List_20_Paragraph">In the output, "%f" is replaced by the value of the the <span class="T7">PI()</span> function.</p><p class="List_20_Paragraph">Your output may be different if your locale language is not English.</p><h4 class="Heading_20_4"><a id="a__Format_Specifiers"><span/></a>Format Specifiers</h4><p class="Standard">Here is a brief summary of the available format specifiers:</p><table border="0" cellspacing="0" cellpadding="0" class="Table6"><colgroup><col width="161"/><col width="187"/><col width="390"/></colgroup><tr class="Table61"><td style="text-align:left;width:3.681cm; " class="Table6_A1"><p class="P110">For this type of data</p></td><td style="text-align:left;width:4.286cm; " class="Table6_A1"><p class="P110">Use these formats</p></td><td style="text-align:left;width:8.924cm; " class="Table6_A1"><p class="P110">Comments</p></td></tr><tr class="Table61"><td style="text-align:left;width:3.681cm; " class="Table6_A1"><p class="P114">String</p></td><td style="text-align:left;width:4.286cm; " class="Table6_A1"><p class="P114">%s %S</p></td><td style="text-align:left;width:8.924cm; " class="Table6_A1"><p class="P114">%S forces output to upper-case</p></td></tr><tr class="Table61"><td style="text-align:left;width:3.681cm; " class="Table6_A1"><p class="P114">Number</p></td><td style="text-align:left;width:4.286cm; " class="Table6_A1"><p class="P114">%f %e %E %g %G %a %A</p></td><td style="text-align:left;width:8.924cm; " class="Table6_A1"><p class="P114">Standard BASIC! numbers are floating point</p><p class="P114">Use %f for decimal output: "1234.567"</p><p class="P114">Use %e or %E for exponential notation: "1.234e+03"</p><p class="P114">%E writes upper-case: "1.234E+03"</p><p class="P114">%g (%G) lets the system choose %f or %e (%E)</p><p class="P114">%a and %A are "hexadecimal floating point"</p></td></tr><tr class="Table61"><td style="text-align:left;width:3.681cm; " class="Table6_A1"><p class="P114">Integer</p></td><td style="text-align:left;width:4.286cm; " class="Table6_A1"><p class="P114">%d %o %x %X</p></td><td style="text-align:left;width:8.924cm; " class="Table6_A1"><p class="P114">USING$ can use some math functions as integers</p><p class="P114">Use %d for decimal, %o for octal, %x %X for hex</p><p class="P114">%x writes lower-case abcdef, %X writes upper-case</p></td></tr><tr class="Table61"><td style="text-align:left;width:3.681cm; " class="Table6_A1"><p class="P114">Special integer</p></td><td style="text-align:left;width:4.286cm; " class="Table6_A1"><p class="P114">%c %C %t</p></td><td style="text-align:left;width:8.924cm; " class="Table6_A1"><p class="P114">These specifiers can operate on an integer</p><p class="P114">%c %C output a character, %C writes upper-case</p><p class="P114">%t represents a family of time format specifiers</p></td></tr><tr class="Table61"><td style="text-align:left;width:3.681cm; " class="Table6_A1"><p class="P114">None</p></td><td style="text-align:left;width:4.286cm; " class="Table6_A1"><p class="P114">%% %n</p></td><td style="text-align:left;width:8.924cm; " class="Table6_A1"><p class="P114">These specifiers do not read the expression list</p><p class="P114">%% writes a single "%" to the output</p><p class="P114">%n writes a newline, exactly the same as \n</p></td></tr></table><p class="List_20_Paragraph">For more information about %a and %A, see the Android documentation linked above.</p><p class="List_20_Paragraph">Android’s %b and %B are not supported because BASIC! has no Boolean type.</p><p class="List_20_Paragraph">Android’s %h and %H hash code specifiers are limited to strings and numbers in BASIC!.</p><p class="List_20_Paragraph">For an explanation of <span class="T7">USING$()</span> with integer format specifiers, see below.</p><p class="Standard">There is a whole family of time format specifiers: <span class="T7">%t&lt;x&gt;</span> where <span class="T7">&lt;x&gt;</span> is another letter. They operate on an integer, which they interpret as the number of milliseconds since the beginning of January 1, 1970, UTC (the "epoch"). You can apply time format specifiers to the output of the <span class="T7">TIME()</span> functions. Note, however, that the <span class="T7">%t</span> time specifiers use your local timezone, not the <span class="T7">TimeZone.set</span> value.</p><p class="Standard">There are more than 30 time format specifiers. A few examples appear below, but to get the full list you should read the Android documentation linked above.</p><p class="Code_20_example"><span class="T11">PRINT USING$("", "The time is: %tI:%&lt;tM:%&lt;tS %&lt;Tp", time())        % the hard way</span></p><p class="Code_20_example"><span class="T11">PRINT USING$("", "The time is: %tr", time())                        % same thing!</span></p><p class="Code_20_example"><span class="T11">02:27:16 PM                                                </span><span class="T26"></span><span class="T11"> example of printed output</span></p><p class="P2"> </p><p class="Code_20_example"><span class="T11">t = TIME(2001, 2, 3, 4, 5, 6)                % set 2001/02/03 04:05:06, local timezone</span></p><p class="Code_20_example"><span class="T11">PRINT USING$("sv", "%tA", int(t))                % day in Swedish, prints "lördag"</span></p><p class="Code_20_example"><span class="T11">PRINT USING$("es", "%tB", int(t))                % month in Spanish, prints "febrero"</span></p><p class="Code_20_example"><span class="T11">PRINT USING$("", "%tY/%tm/%td", int(t) , int(t), int(t))        % prints "2001/02/03"</span></p><p class="Code_20_example"><span class="T11">PRINT USING$( , "%tY/%&lt;tm/%&lt;td", int(t))                        % prints "2001/02/03"</span></p><p class="Code_20_example"><span class="T11">PRINT USING$("en_GB", "%tH:%&lt;tM:%&lt;tS", int(t))                % prints "04:05:06"</span></p><p class="Code_20_example"><span class="T11">PRINT USING$("in_IN", "%tT", int(t))                        % prints "04:05:06"</span></p><p class="Standard">Note: Date and time are printed for your local timezone, regardless of either the TIMEZONE.SET setting or the locale parameter. Try the same set of examples with <span class="T7">TIMEZONE.SET "UTC"</span>. Unless that is your local timezone, a different hour and perhaps even a different day will be displayed.</p><h4 class="Heading_20_4"><a id="a__Optional_Modifiers"><span/></a>Optional Modifiers</h4><p class="Standard">The format specifiers can be used exactly as shown in the table. They have default settings that control how they behave. You can control the settings yourself, fine-tuning the behavior to suit your needs.</p><p class="Standard">You can modify the format specifiers with <span class="T18">index</span>, <span class="T18">flags</span>, <span class="T18">width</span>, and <span class="T18">precision</span>, as shown in this example:</p><table border="0" cellspacing="0" cellpadding="0" class="Table7"><colgroup><col width="36"/><col width="71"/><col width="68"/><col width="73"/><col width="21"/><col width="96"/><col width="94"/><col width="28"/></colgroup><tr class="Table71"><td colspan="8" style="text-align:left;width:0.813cm; " class="Table7_A1"><p class="P110">"%3$-,15.4f"</p></td></tr><tr class="Table71"><td style="text-align:left;width:0.813cm; " class="Table7_A1"><p class="P110">"%</p></td><td style="text-align:left;width:1.628cm; " class="Table7_A1"><p class="P110">3$</p></td><td style="text-align:left;width:1.559cm; " class="Table7_A1"><p class="P110">-,</p></td><td style="text-align:left;width:1.67cm; " class="Table7_A1"><p class="P110">15</p></td><td style="text-align:left;width:0.482cm; " class="Table7_A1"><p class="P110">.</p></td><td style="text-align:left;width:2.203cm; " class="Table7_A1"><p class="P110">4</p></td><td style="text-align:left;width:2.152cm; " class="Table7_A1"><p class="P110">f</p></td><td style="text-align:left;width:0.635cm; " class="Table7_A1"><p class="P110">"</p></td></tr><tr class="Table71"><td style="text-align:left;width:0.813cm; " class="Table7_A1"><p class="P110"> </p></td><td style="text-align:left;width:1.628cm; " class="Table7_A1"><p class="P110">&lt;index&gt;</p></td><td style="text-align:left;width:1.559cm; " class="Table7_A1"><p class="P110">&lt;flags&gt;</p></td><td style="text-align:left;width:1.67cm; " class="Table7_A1"><p class="P110">&lt;width&gt;</p></td><td style="text-align:left;width:0.482cm; " class="Table7_A1"><p class="P110"> </p></td><td style="text-align:left;width:2.203cm; " class="Table7_A1"><p class="P110">&lt;precision&gt;</p></td><td style="text-align:left;width:2.152cm; " class="Table7_A1"><p class="P110">&lt;specifier&gt;</p></td><td style="text-align:left;width:0.635cm; " class="Table7_A1"><p class="P110"> </p></td></tr></table><h4 class="Heading_20_4"><a id="a__Index"><span/></a>Index</h4><p class="Standard">Normally the format specifiers are applied to the arguments in order. You can change the order with an argument index. An index a number followed by a <span class="T7">$</span> character. The argument index <span class="T7">3$</span> specifies the third argument in the list.</p><p class="Code_20_example"><span class="T11">PRINT USING$("", "%3$s %s %s", "a", "b", "c")        % prints "c a b"</span></p><p class="P143">The special argument index "&lt;" lets you reuse an argument.</p><p class="P7"><span class="T11">PRINT USING$("", "%o %&lt;d %&lt;h", int(64) )                % prints "100 64 40"</span></p><p class="Standard">In the last example, there is only one argument, but three format specifiers. This is not an error because the argument is reused.</p><h4 class="Heading_20_4"><a id="a__Flags"><span/></a>Flags</h4><p class="Standard">There are six flags:</p><table border="0" cellspacing="0" cellpadding="0" class="Table8"><colgroup><col width="25"/><col width="480"/></colgroup><tr class="Table81"><td style="text-align:left;width:0.582cm; " class="Table8_A1"><p class="P114">-</p></td><td style="text-align:left;width:10.973cm; " class="Table8_A1"><p class="P114"> left-justify; if no flag, right-justify</p></td></tr><tr class="Table81"><td style="text-align:left;width:0.582cm; " class="Table8_A1"><p class="P114">+</p></td><td style="text-align:left;width:10.973cm; " class="Table8_A1"><p class="P114"> always show sign; if no flag, show "-" but do not show "+"</p></td></tr><tr class="Table81"><td style="text-align:left;width:0.582cm; " class="Table8_A1"><p class="P114">0</p></td><td style="text-align:left;width:10.973cm; " class="Table8_A1"><p class="P114"> pad numbers with leading zeros; if no flag pad with spaces</p></td></tr><tr class="Table81"><td style="text-align:left;width:0.582cm; " class="Table8_A1"><p class="P114">,</p></td><td style="text-align:left;width:10.973cm; " class="Table8_A1"><p class="P114"> use grouping separators for large numbers</p></td></tr><tr class="Table81"><td style="text-align:left;width:0.582cm; " class="Table8_A1"><p class="P114">(</p></td><td style="text-align:left;width:10.973cm; " class="Table8_A1"><p class="P114"> put parentheses around negative values</p></td></tr><tr class="Table81"><td style="text-align:left;width:0.582cm; " class="Table8_A1"><p class="P114">#</p></td><td style="text-align:left;width:10.973cm; " class="Table8_A1"><p class="P114"> alternate notation (leading 0 for octal, leading 0x for hexadecimal)</p></td></tr></table><h4 class="Heading_20_4"><a id="a__Width"><span/></a>Width</h4><p class="Standard">The <span class="T7">width</span> control sets the minimum number of characters to print. If the value to format is longer than the width setting, the entire value is printed (unless it would exceed the <span class="T7">precision</span> setting). If the value to format is shorter than the <span class="T7">width</span> setting, it is padded to fill the width. By default, it is padded with spaces on the left, but you change this with the "-" and "0" flags.</p><h4 class="Heading_20_4"><a id="a__Precision"><span/></a>Precision</h4><p class="Standard">The <span class="T7">precision</span> control means different things to different data types.</p><p class="Standard">For floating point numbers, <span class="T7">precision</span> specifies the number of characters to print after the decimal point, padding with trailing zeros if needed.</p><p class="Standard">For string values, it specifies the maximum number of characters to print. If <span class="T7">precision</span> is less than <span class="T7">width</span>, only <span class="T7">precision</span> characters are printed.</p><p class="Code_20_example"><span class="T13">"%4s", "foo"        </span><span class="T28"></span><span class="T13"> " foo"</span></p><p class="Code_20_example"><span class="T13">"%-4s", "foo"        </span><span class="T28"></span><span class="T13"> "foo "</span></p><p class="Code_20_example"><span class="T13">"%4.2s", "foo"        </span><span class="T28"></span><span class="T13"> "fo"</span></p><p class="Standard">The <span class="T7">precision</span> control is not valid for other types.</p><p class="Standard">In the example above, <span class="T7">%-,15.4f</span>:</p><p class="List_20_Paragraph">The <span class="T7">flags</span> "-" and "," mean "left-justify the output" and "use a thousands separator".</p><p class="List_20_Paragraph">The <span class="T7">width</span> is 15, meaning the output is to be at least 15 characters wide.</p><p class="List_20_Paragraph">The <span class="T7">precision</span> is 4, so there will be exactly four digits after the decimal point.</p><p class="Standard">The whole format specifier means, "format a floating point number (%f) left-justified ("-") in a space 15 characters wide, with 4 characters after the decimal point, with a thousands separator (",")".</p><p class="Standard">The characters used for the decimal point and the thousands separator depend on the locale:</p><p class="Code_20_example"><span class="T11">"1,234.5678     " for locale "en"</span></p><p class="Code_20_example"><span class="T11">"1 234,5678     " for locale "fr"</span></p><p class="Code_20_example"><span class="T11">"1.234,5678     " for locale "it"</span></p><h3 class="Heading_20_3"><a id="a__Integer_values"><span/></a><a id="_Toc5235840"/>Integer values</h3><p class="Standard">BASIC! has only double-precision floating point numbers. It does not have an integer type. The <span class="T7">USING$()</span> function supports format specifiers ("%d", "%t", "%x") that apply only to integer values.</p><p class="Standard"><span class="T7">USING$()</span> has a special relationship with the math functions that intrinsically produce integer results. BASIC! converts the output of these functions to floating point, for storage in numeric variables, but<span class="T7"> USING$()</span> can get the original integer values. For example:</p><p class="Code_20_example"><span class="T11">PRINT USING$("", "%d", 123)                % ERROR!</span></p><p class="Code_20_example"><span class="T11">PRINT USING$("", "%d", INT(123))        % No error</span></p><p class="Standard">The functions that can produce integer values for <span class="T7">USING$()</span> are:</p><p class="Code_20_example"><span class="T11">INT()    BIN()    OCT()    HEX()</span></p><p class="Code_20_example"><span class="T11">CEIL()   FLOOR()</span></p><p class="Code_20_example"><span class="T11">ASCII()  UCODE()</span></p><p class="Code_20_example"><span class="T11">BAND()   BOR()    BXOR()</span></p><p class="Code_20_example"><span class="T11">SHIFT()  TIME()</span></p><h2 class="Heading_20_2"><a id="a__FORMAT_USING$__locale_sexp____format_sexp__{____exp_}____"><span/></a><a id="_Toc5235841"/>FORMAT_USING$(&lt;locale_sexp&gt;, &lt;format_sexp&gt; { , &lt;exp&gt;}...)</h2><p class="No_20_Spacing">Alias for <span class="T7">USING$()</span>. You can use the two equivalent functions to make your code easier to read. For example:</p><p class="Code_20_example"><span class="T11">string$ = FORMAT_USING("", "pi is not %d", int(pi()))</span></p><p class="Code_20_example"><span class="T11">Print USING$("en_US", "Balance: $%8.2f", balance)</span></p><h2 class="Heading_20_2"><a id="a__FORMAT$__pattern_sexp____nexp__"><span/></a><a id="_Toc5235842"/><span class="T6">FORMAT$(</span>&lt;pattern_sexp&gt;<span class="T6">, </span>&lt;nexp&gt;<span class="T6">)</span></h2><p class="Standard">Returns a string with &lt;nexp&gt; formatted by the pattern &lt;pattern_sexp&gt;.</p><table border="0" cellspacing="0" cellpadding="0" class="Table9"><colgroup><col width="147"/><col width="591"/></colgroup><tr class="Table91"><td style="text-align:left;width:3.364cm; " class="Table9_A1"><p class="P121">Leading Sign</p></td><td style="text-align:left;width:13.526cm; " class="Table9_A1"><p class="P114">A negative (-) character for numbers &lt; 0 or a space for numbers &gt;= 0.<br/>The Sign and the Floating Character together form the <span class="T7">Floating Field</span>.</p></td></tr><tr class="Table91"><td style="text-align:left;width:3.364cm; " class="Table9_A1"><p class="P121">Floating Character</p></td><td style="text-align:left;width:13.526cm; " class="Table9_A1"><p class="P114">If the first character of the pattern is not "#" or "." or "-" then that character becomes a "floating" character. This pattern character is typically a "$".<br/>If no floating character is provided then a space character is used.<br/>See also <span class="T7">Overflow</span>, below.</p></td></tr><tr class="Table91"><td style="text-align:left;width:3.364cm; " class="Table9_A1"><p class="P114"><span class="T7">Decimal Point</span></p></td><td style="text-align:left;width:13.526cm; " class="Table9_A1"><p class="P114">The pattern may have one optional decimal point character (".").<br/>If the pattern has no decimal point, then only the whole number is ouput.<br/>Any digits that would otherwise appear after the decimal point are not output.</p></td></tr><tr class="Table91"><td style="text-align:left;width:3.364cm; " class="Table9_A1"><p class="P114"><span class="T7"># Character</span><br/>(before decimal, or no decimal)</p></td><td style="text-align:left;width:13.526cm; " class="Table9_A1"><p class="P114">Each "#" is replaced by a digit from the number. If there are more "#" characters than digits, then the leading "#" character(s) are replaced by <span class="T7">space</span>(s).</p></td></tr><tr class="Table91"><td style="text-align:left;width:3.364cm; " class="Table9_A1"><p class="P114"><span class="T7"># Character</span><br/>(after decimal point)</p></td><td style="text-align:left;width:13.526cm; " class="Table9_A1"><p class="P114">Each "#" is replaced by a digit from the number. If there are more "#" characters than significant digits, then the trailing "#" character(s) are replaced by <span class="T7">zero</span>(s).<br/>The number of "#" characters after the pattern decimal point specifies the number of decimal digits that will be output.</p></td></tr><tr class="Table91"><td style="text-align:left;width:3.364cm; " class="Table9_A1"><p class="P114"><span class="T7">% Character</span><br/>(before decimal, or no decimal)</p></td><td style="text-align:left;width:13.526cm; " class="Table9_A1"><p class="P114">Each "%" is replaced by a digit from the number. If there are more "%" characters than digits, then the leading "%" character(s) are replaced by <span class="T7">zero</span>(s).</p></td></tr><tr class="Table91"><td style="text-align:left;width:3.364cm; " class="Table9_A1"><p class="P114"><span class="T7">% Character</span><br/>(after decimal)</p></td><td style="text-align:left;width:13.526cm; " class="Table9_A1"><p class="P114">The "%" character is not allowed after the decimal point. This is a syntax error.</p></td></tr><tr class="Table91"><td style="text-align:left;width:3.364cm; " class="Table9_A1"><p class="P121">Non-pattern Characters</p></td><td style="text-align:left;width:13.526cm; " class="Table9_A1"><p class="P114">If any pattern character (other than the first) is not # or %, then that character is copied directly into the output. If the character would appear before the first digit of the number, it is replaced by a space. This feature is usually used for commas.</p></td></tr><tr class="Table91"><td style="text-align:left;width:3.364cm; " class="Table9_A1"><p class="P121">Overflow</p></td><td style="text-align:left;width:13.526cm; " class="Table9_A1"><p class="P114">If the number of digits exceeds the number of # and % characters, then the output has the ** characters inserted in place of the Floating Field.</p></td></tr><tr class="Table91"><td style="text-align:left;width:3.364cm; " class="Table9_A1"><p class="P121">Output Size</p></td><td style="text-align:left;width:13.526cm; " class="Table9_A1"><p class="P114">The number of characters output is always the number of characters in the pattern<br/>plus one for the sign<br/>plus one more for the space if the pattern has no Floating Character.</p></td></tr></table><h3 class="Heading_20_3"><a id="a__Notes"><span/></a><a id="_Toc5235843"/>Notes</h3><p class="Standard">The sign and the floating character together form a <span class="T7">Floating Field</span> two characters wide that always appears just before the first digit of the formatted output. If there are any leading spaces in the formatted output, they are placed before the floating field.</p><p class="Standard">The "#" character generates leading spaces, not leading zeros. "##.###" formats 0.123 as ".123". If you want a leading zero, use a "%". For example "%.###", "#%.###", or "##%" all assure a leading zero.</p><p class="Standard">Be careful mixing # and % characters. Doing so except as just shown can produce unexpected results.</p><p class="Standard">The number of characters output is always the number of characters in the pattern plus the two floating characters.</p><h3 class="Heading_20_3"><a id="a__Examples"><span/></a><a id="_Toc5235844"/>Examples</h3><table border="0" cellspacing="0" cellpadding="0" class="Table10"><colgroup><col width="313"/><col width="159"/><col width="116"/></colgroup><tr class="Table101"><td style="text-align:left;width:7.158cm; " class="Table10_A1"><p class="P110">Function Call</p></td><td style="text-align:left;width:3.641cm; " class="Table10_A1"><p class="P119">Output</p></td><td style="text-align:left;width:2.651cm; " class="Table10_A1"><p class="P110">Width</p></td></tr><tr class="Table101"><td style="text-align:left;width:7.158cm; " class="Table10_A1"><p class="P114">Format$( "##,###,###", 1234567)</p></td><td style="text-align:left;width:3.641cm; " class="Table10_A1"><p class="P133"><span class="T52">   1,234,567</span></p></td><td style="text-align:left;width:2.651cm; " class="Table10_A1"><p class="P114">12 characters</p></td></tr><tr class="Table101"><td style="text-align:left;width:7.158cm; " class="Table10_A1"><p class="P114">Format$( "<span class="T7">%%</span>,<span class="T7">%%%</span>,<span class="T7">%%%</span>.#", 1234567.89)</p></td><td style="text-align:left;width:3.641cm; " class="Table10_A1"><p class="P133"><span class="T52">  01,234,567.8</span></p></td><td style="text-align:left;width:2.651cm; " class="Table10_A1"><p class="P114">14 characters</p></td></tr><tr class="Table101"><td style="text-align:left;width:7.158cm; " class="Table10_A1"><p class="P114">Format$( "$###,###", 123456)</p></td><td style="text-align:left;width:3.641cm; " class="Table10_A1"><p class="P134"> $123,456</p></td><td style="text-align:left;width:2.651cm; " class="Table10_A1"><p class="P135">9 characters</p></td></tr><tr class="Table101"><td style="text-align:left;width:7.158cm; " class="Table10_A1"><p class="P114">Format$( "$###,###", -1234)</p></td><td style="text-align:left;width:3.641cm; " class="Table10_A1"><p class="P133"><span class="T52">  -$1,234</span></p></td><td style="text-align:left;width:2.651cm; " class="Table10_A1"><p class="P114">9 characters</p></td></tr><tr class="Table101"><td style="text-align:left;width:7.158cm; " class="Table10_A1"><p class="P114">Format$( "$###,###", 12)</p></td><td style="text-align:left;width:3.641cm; " class="Table10_A1"><p class="P133"><span class="T52">      $12</span></p></td><td style="text-align:left;width:2.651cm; " class="Table10_A1"><p class="P114">9 characters</p></td></tr><tr class="Table101"><td style="text-align:left;width:7.158cm; " class="Table10_A1"><p class="P114">Format$( "$<span class="T7">%%%</span>,<span class="T7">%%%</span>", -12)</p></td><td style="text-align:left;width:3.641cm; " class="Table10_A1"><p class="P133"><span class="T52">-$000,012</span></p></td><td style="text-align:left;width:2.651cm; " class="Table10_A1"><p class="P114">9 characters</p></td></tr><tr class="Table101"><td style="text-align:left;width:7.158cm; " class="Table10_A1"><p class="P114">Format$( "##.#", 0)</p></td><td style="text-align:left;width:3.641cm; " class="Table10_A1"><p class="P133"><span class="T51"> </span><span class="T52">   .0</span></p></td><td style="text-align:left;width:2.651cm; " class="Table10_A1"><p class="P135">6 characters</p></td></tr><tr class="Table101"><td style="text-align:left;width:7.158cm; " class="Table10_A1"><p class="P114">Format$( "#<span class="T7">%</span>.#", 0)</p></td><td style="text-align:left;width:3.641cm; " class="Table10_A1"><p class="P133"><span class="T52">   0.0</span></p></td><td style="text-align:left;width:2.651cm; " class="Table10_A1"><p class="P135">6 characters</p></td></tr><tr class="Table101"><td style="text-align:left;width:7.158cm; " class="Table10_A1"><p class="P114">Format$( "$###.##", -1234.5)</p></td><td style="text-align:left;width:3.641cm; " class="Table10_A1"><p class="P133"><span class="T51">**</span><span class="T52">234.50</span></p></td><td style="text-align:left;width:2.651cm; " class="Table10_A1"><p class="P114">8 characters</p></td></tr></table><h1 class="Heading_20_1"><a id="a__User-Defined_Functions"><span/></a><a id="_Toc5235845"/>User-Defined Functions</h1><p class="Standard">User-Defined Functions are BASIC! functions like ABS(n), MOD(a,b) and LEFT$(a$,n) except that the operation of the function is defined by the user. User functions should generally be defined at the start of the program and in particular, they should appear before the places where they are called.</p><p class="Standard">User-Defined Functions may call other User-Defined Functions. A function can even recursively call itself.</p><p class="Standard">You may define a function with the same name as a built-in function. The User-Defined Function always overrides the built-in function, and the built-in function is not accessible.</p><p class="Standard">Each time a function is called from another function a certain amount of memory is used for the execution stack. The depth of these nested calls is limited only by the amount of memory that your particular Android device allocates to applications.</p><h2 class="Heading_20_2"><a id="a__Variable_Scope"><span/></a><a id="_Toc5235846"/>Variable Scope</h2><p class="Standard">All variables created while running a User-Defined Function are private to the function. A variable named v$ in the main program is not the same as variable v$ within a function. Furthermore, a variable named v$ in a recursively called function is not the same v$ in the calling function.</p><p class="Standard">A function cannot access variables created outside of the function, except as parameters passed by reference. (See <span class="T7">Fn.def</span>, below, for an explanation of parameters passed by value and by reference.)</p><p class="Standard">All variables created while running a User-Defined Function are destroyed when the function returns. When an array variable is destroyed, its storage is reclaimed. However, when a data structure pointer is destroyed, the data structure is not destroyed (see next section).</p><h2 class="Heading_20_2"><a id="a__Data_Structures_in_User-Defined_Functions"><span/></a><a id="_Toc5235847"/>Data Structures in User-Defined Functions</h2><p class="Standard">Data structures (List, Stack, Bundle, bitmap, graphical object – anything referenced through a pointer) are global in scope. That is, if a variable is used as a pointer to a data structure, it points to the same data structure whether it is used inside or outside of a function. The data structure may have been created in the main program, the same user-defined function, or some other user-defined function.</p><p class="Standard">This means that if you pass a pointer to a bundle, for example, and modify that bundle inside the function, the changes will be retained when the function returns. It also means that a function can modify graphical objects created outside of the function.</p><p class="Standard">Data structures (List, Stack, Bundle, or graphical object) created while running a User-Defined Function are not destroyed when the function returns. Local variables that point to the data structures are lost, but you can return a data structure pointer as the function’s return value or through a parameter passed by reference.</p><h2 class="Heading_20_2"><a id="a__Commands"><span/></a><a id="_Toc5235848"/>Commands</h2><h3 class="Heading_20_3"><a id="a__Fn_def_name|name$__{nvar}|{svar}|Array__|Array$________{nvar}|{svar}|Array__|Array$___"><span/></a><a id="_Toc5235849"/>Fn.def name|name$( {nvar}|{svar}|Array[]|Array$[], ... {nvar}|{svar}|Array[]|Array$[])</h3><p class="Standard">Begins the definition of a function. This command names the function and lists the parameters, if any.</p><p class="Standard">If the function name ends with the $ character then the function will return a string, otherwise it will return a number. The parameter list can contain as many parameters as needed, or none at all. The parameters may be numeric or string, scalar or array.</p><p class="Standard">Your program must execute <span class="T7">Fn.def</span> before it tries to call the named function. Your program must not attempt to create more than one function with the same name, or the same function more than once. However, you may override a built-in function by defining your own function with the same name.</p><p class="Standard">The following are all valid:</p><p class="Code_20_example"><span class="T11">FN.DEF cut$(a$, left, right)</span></p><p class="Code_20_example"><span class="T11">FN.DEF sum(a, b, c, d, e, f, g, h, i, j)</span></p><p class="Code_20_example"><span class="T11">FN.DEF sort(v$[], direction)</span></p><p class="Code_20_example"><span class="T11">FN.DEF pi()                        % Overrides built-in. You can make </span><span class="T41">π</span><span class="T11"> = 3!</span></p><p class="Standard">Parameters create variables visible only inside the function. They can be used like other variables created inside the function (see Variable Scope, above).</p><p class="Standard">There are two types of parameters: call by reference and call by value. Call by value means that the calling variable value (or expression) is copied into the called variable. Changes made to the called variable within the function do not affect the value of the calling variable. Call by reference means that the calling variable value is changed if the called variable value is changed within the function.</p><p class="Standard">Scalar (non-array) function variables can be either call by value or call by reference. Which type the variable will be depends upon how it is called. If the calling variable has the "&amp;" character in front of it, then the variable is call by reference. If there is no "&amp;" in front of the calling variable name then the variable is call by value.</p><p class="Code_20_example"><span class="T11">FN.DEF test(a)</span></p><p class="Code_20_example"><span class="T11">a = 9</span></p><p class="Code_20_example"><span class="T11">FN.RTN a</span></p><p class="Code_20_example"><span class="T11">FN.END</span></p><p class="P2"> </p><p class="Code_20_example"><span class="T11">a =1</span></p><p class="Code_20_example"><span class="T11">PRINT test(a), a  %will print: 9, 1</span></p><p class="Code_20_example"><span class="T11">PRINT test(&amp;a), a %will print: 9, 9</span></p><p class="Standard">Array parameters are always call by reference.</p><p class="Code_20_example"><span class="T11">FN.DEF test(a[])</span></p><p class="Code_20_example"><span class="T11">a[1] = 9</span></p><p class="Code_20_example"><span class="T11">FN.RTN a[1]</span></p><p class="Code_20_example"><span class="T11">FN.END</span></p><p class="P2"> </p><p class="Code_20_example"><span class="T11">DIM a[1]</span></p><p class="Code_20_example"><span class="T11">a[1] = 1</span></p><p class="Code_20_example"><span class="T11">PRINT test(a[]), a[1]  % prints: 9, 9</span></p><p class="Standard">Along with the function’s return value, you can use parameters passed by reference to return information to a function’s caller.</p><h3 class="Heading_20_3"><a id="a__Fn_rtn__sexp_|_nexp_"><span/></a><a id="_Toc5235850"/>Fn.rtn &lt;sexp&gt;|&lt;nexp&gt;</h3><p class="Standard">Causes the function to terminate execution and return the value of the return expression &lt;sexp&gt;|&lt;nexp&gt;. The return expression type, string or number, must match the type of the function name. <span class="T7">Fn.rtn</span> statements may appear anywhere in the program that they are needed.</p><p class="Standard">A function can return only a single scalar value. It cannot return an array. It cannot return a data structure (List, Stack, Bundle, or graphical object), but it can return a pointer to a data structure.</p><p class="Standard">Note: You can also return information to a function’s caller through parameters passed by reference.</p><h3 class="Heading_20_3"><a id="a__Fn_end"><span/></a><a id="_Toc5235851"/>Fn.end</h3><p class="Standard">Ends the definition of a user-defined function. Every function definition must end with <span class="T7">Fn.end</span>.</p><p class="Standard">When your function is running, executing the <span class="T7">Fn.end</span> statement causes the function to terminate and return a default value. If the function type is numeric then the default return value is 0.0. A string function returns the empty string ("").</p><h3 class="Heading_20_3"><a id="a__Call__user_defined_function_"><span/></a><a id="_Toc5235852"/>Call &lt;user_defined_function&gt;</h3><p class="Standard">Executes the user-defined function. Any value returned by the function will be discarded.</p><p class="Standard">The <span class="T7">CALL</span> command keyword is optional. Just as BASIC! can infer the <span class="T7">LET</span> command from a line that starts with a variable, it can infer the <span class="T7">CALL</span> command from a line that starts with a function name.</p><p class="Standard">For example, if you have defined a function like this:</p><p class="Code_20_example"><span class="T11">FN.DEF MyFunction(x, y$, z)</span></p><p class="Code_20_example"><span class="T11">&lt; your code here &gt;</span></p><p class="Code_20_example"><span class="T11">FN.END</span></p><p class="Standard">You can execute the function, ignoring its return value, with either of these statements:</p><p class="Code_20_example"><span class="T11">CALL MyFunction(a, b$, c)</span></p><p class="Code_20_example"><span class="T11">MyFunction(a, b$, c)</span></p><p class="Standard">As with <span class="T7">LET</span>, you must use <span class="T7">CALL</span> if your function name starts with a BASIC! command keyword. It is also a little faster to execute a function with <span class="T7">CALL</span> than to make BASIC! infer the command. See <span class="T7">LET</span>, above, for details.</p><h1 class="Heading_20_1"><a id="a__Program_Control_Commands"><span/></a><a id="_Toc5235853"/>Program Control Commands</h1><h2 class="Heading_20_2"><a id="a__If___Then___Else___Elseif___Endif"><span/></a><a id="_Toc5235854"/>If / Then / Else / Elseif / Endif</h2><p class="Standard">The <span class="T7">If</span> commands provide for the conditional execution of blocks of statements. (Note: the braces { } are not part of the command syntax. They are used only to show parts that are optional.)</p><p class="Code_20_example"><span class="T11">IF &lt;condition&gt; { THEN }</span></p><p class="Code_20_example"><span class="T11">    &lt;statement&gt;</span></p><p class="Code_20_example"><span class="T11">    &lt;statement&gt;</span></p><p class="Code_20_example"><span class="T11">...</span></p><p class="Code_20_example"><span class="T11">    &lt;statement&gt;</span></p><p class="Code_20_example"><span class="T11">{ ELSEIF&lt;condition&gt; { THEN }</span></p><p class="Code_20_example"><span class="T11">    &lt;statement&gt;</span></p><p class="Code_20_example"><span class="T11">    &lt;statement&gt;</span></p><p class="Code_20_example"><span class="T11">...</span></p><p class="Code_20_example"><span class="T11">    &lt;statement&gt; }</span></p><p class="Code_20_example"><span class="T11">{ ELSE</span></p><p class="Code_20_example"><span class="T11">    &lt;statement&gt;</span></p><p class="Code_20_example"><span class="T11">    &lt;statement&gt;</span></p><p class="Code_20_example"><span class="T11">...</span></p><p class="Code_20_example"><span class="T11">    &lt;statement&gt; }</span></p><p class="Code_20_example"><span class="T11">ENDIF</span></p><p class="Standard"><span class="T7">If</span> commands may be nested to any depth. That is, any &lt;statement&gt; in a block may be a full <span class="T7">If</span> command with all of its own &lt;statement&gt; blocks.</p><p class="P109">See the Sample Program file, F04_if_else.bas, for working examples of the <span class="T7">If</span> command.</p><h2 class="Heading_20_2"><a id="a__If___Then___Else"><span/></a><a id="_Toc5235855"/>If / Then / Else</h2><p class="Standard">If your conditional block(s) contain(s) only one statement, you may use a simpler form of the <span class="T7">If</span> command, all one line:</p><p class="Code_20_example"><span class="T11">IF &lt;condition&gt; THEN &lt;statement&gt; { ELSE &lt;statement&gt; }</span></p><p class="Standard">In this form, <span class="T7">Then</span> is required, and there is no <span class="T7">ElseIf</span> or <span class="T7">EndIf</span>.</p><p class="Standard">This form does not nest: neither &lt;statement&gt; may be an <span class="T7">If</span> command.</p><p class="Standard">Because the single statements are not treated as blocks, this is the preferred form if either of the embedded statements is a <span class="T7">Break</span>, <span class="T7">Continue</span>, or <span class="T7">GoTo</span>.</p><p class="Standard">You may replace either &lt;statement&gt; with multiple statements separated by colon (":") characters. If you do this, the set of multiple statements is treated as a block, and the single-line <span class="T7">If/Then/Else</span> becomes an <span class="T7">If/Then/Else/Endif</span>. These two lines are exactly equivalent:</p><p class="Code_20_example"><span class="T11">IF (x &gt; y) THEN x = y : PRINT a$ ELSE y = x : PRINT b$</span></p><p class="Code_20_example"><span class="T11">IF (x &gt; y) : x = y : PRINT a$ : ELSE : y = x : PRINT b$ : ENDIF</span></p><p class="Standard">Please note, if you wish to use colon-separated statements in this form of <span class="T7">If/Then/Else</span>, then you must be careful to put spaces around the keywords <span class="T7">Then</span> and <span class="T7">Else</span>. Spaces are not significant to the BASIC! interpreter, but they are needed by the preprocessor that converts the single-line <span class="T7">If</span> with multi-statement blocks into a multi-line <span class="T7">If</span> with an <span class="T7">EndIf</span>.</p><h2 class="Heading_20_2"><a id="a__For_-_To_-_Step___Next"><span/></a><a id="_Toc5235856"/>For - To - Step / Next</h2><p class="Code_20_example"><span class="T11">FOR &lt;nvar&gt; = &lt;nexp_1&gt; TO &lt;nexp_2&gt; {STEP &lt;nexp_3&gt;}</span></p><p class="Code_20_example"><span class="T11">        &lt;statement&gt;</span></p><p class="Code_20_example"><span class="T11">        ...</span></p><p class="Code_20_example"><span class="T11">        &lt;statement&gt;</span></p><p class="Code_20_example"><span class="T11">NEXT {&lt;nvar&gt;}</span></p><p class="Standard">Initially, &lt;nvar&gt; is assigned the value of &lt;nexp_1&gt; and compared to &lt;nexp_2&gt;. {STEP &lt;nexp_3&gt;} is optional and may be omitted. If omitted then the <span class="T7">Step</span> value is 1.</p><p class="P109">If &lt;nexp_3&gt; is positive then</p><p class="P95">if &lt;nvar&gt;  &lt;=  &lt;nexp_2&gt; then</p><p class="P144">the statements between the <span class="T7">For</span> and <span class="T7">Next</span> are executed.</p><p class="P109"> </p><p class="P109">If &lt;nexp_3&gt; is negative then</p><p class="P95">if &lt;nvar&gt;  &gt;=  &lt;nexp_2&gt; then</p><p class="P145">the statements between the <span class="T7">For</span> and <span class="T7">Next</span> are executed.</p><p class="Standard">When the <span class="T7">Next</span> statement is executed, &lt;nvar&gt; is incremented or decremented by the <span class="T7">Step</span> value and the test is repeated. The &lt;statement&gt;s will be executed as long as the test is true. Each time, &lt;nvar&gt; is compared to the original value of &lt;nexp_2&gt;; &lt;nexp_2&gt; is not re-evaluated with each <span class="T7">Next</span>.</p><p class="Standard">Because the keywords <span class="T7">To</span> and <span class="T7">Step</span> are in the middle of the line with expressions that may include variables, it is possible to confuse BASIC!. Remember that the interpreter does not see any spaces you put between variables and keywords. <span class="T7">FOR a TO m</span> is seen as <span class="T7">foratom</span>. If there is any possibility of confusion, use parentheses to tell BASIC! that a name is a variable:</p><p class="Code_20_example"><span class="T11">FOR WinTop TO WinBot                % ERROR: interpreted as "FOR win TO ptowinbot"</span></p><p class="Code_20_example"><span class="T11">FOR (WinTop) TO WinBot        % interpreted as intended</span></p><p class="Standard"><span class="T7">For-Next</span> loops can be nested to any level. When <span class="T7">For-Next</span> loops are nested, any executed <span class="T7">Next</span> statement will apply to the currently executing <span class="T7">For</span> statement. This is true no matter what the &lt;nvar&gt; coded with the <span class="T7">Next</span> is. For all practical purposes, the &lt;nvar&gt; coded with the <span class="T7">Next</span> should be considered to be nothing more than a comment.</p><p class="Standard">It is possible to exit a <span class="T7">For</span> loop without <span class="T7">Next</span> or <span class="T7">F_N.break</span>. However, this can create subtle logic errors that are hard to debug. If you set debug mode (see the <span class="T7">Debug.on</span> command), then BASIC! can help you find these bugs. When your program ends and debug is on, if your program entered a <span class="T7">For</span> loop and did not leave it cleanly, BASIC! shows a run-time error: "Program ended with FOR without NEXT".</p><h2 class="Heading_20_2"><a id="a__F_N_continue"><span/></a><a id="_Toc5235857"/>F_N.continue</h2><p class="Standard">If this statement is executed within a <span class="T7">For-Next</span> loop, the rest of the current pass of the loop is skipped. The <span class="T7">Next</span> statement executes immediately.</p><h2 class="Heading_20_2"><a id="a__F_N_break"><span/></a><a id="_Toc5235858"/>F_N.break</h2><p class="Standard">If this statement is executed within a <span class="T7">For-Next</span> loop, the rest of the current pass of the loop is skipped and the loop is terminated. The statement immediately following the <span class="T7">Next</span> will be executed.</p><h2 class="Heading_20_2"><a id="a__While__lexp____Repeat"><span/></a><a id="_Toc5235859"/>While &lt;lexp&gt; / Repeat</h2><p class="Code_20_example"><span class="T11">While &lt;lexp&gt;</span></p><p class="Code_20_example"><span class="T11">        &lt;statement&gt;</span></p><p class="Code_20_example"><span class="T11">        …</span></p><p class="Code_20_example"><span class="T11">        &lt;statement&gt;</span></p><p class="Code_20_example"><span class="T11">Repeat</span></p><p class="Standard">The &lt;statement&gt;s between the <span class="T7">While</span> and <span class="T7">Repeat</span> will be executed as long as &lt;lexp&gt; evaluates as true. The &lt;statements&gt;s will not be executed at all if &lt;lexp&gt; starts off false.</p><p class="Standard"><span class="T7">While-Repeat</span> loops may be nested to any level. When <span class="T7">While-Repeat</span> are nested, any executed <span class="T7">Repeat</span> statement will apply to inner most <span class="T7">While</span> loop.</p><h2 class="Heading_20_2"><a id="a__W_R_continue"><span/></a><a id="_Toc5235860"/>W_R.continue</h2><p class="Standard">If this statement is executed within a <span class="T7">While-Repeat</span> loop, the rest of the current pass of the loop is skipped. The <span class="T7">Repeat</span> statement executes immediately.</p><p class="Standard">You can exit a <span class="T7">While</span> loop without <span class="T7">Repeat</span> or <span class="T7">W_R.break</span>. As with <span class="T7">For-Next</span> loops, this can create subtle bugs, and BASIC! can help you find them. If debug is on, and your program is still in a <span class="T7">While</span> loop when it ends, BASIC! shows a run-time error: "Program ended with WHILE without  REPEAT".</p><h2 class="Heading_20_2"><a id="a__W_R_break"><span/></a><a id="_Toc5235861"/>W_R.break</h2><p class="Standard">If this statement is executed within a <span class="T7">While-Repeat</span> loop, the rest of the current pass of the loop is skipped and the loop is terminated. The statement immediately following the <span class="T7">Repeat</span> will be executed.</p><h2 class="Heading_20_2"><a id="a__Do___Until__lexp_"><span/></a><a id="_Toc5235862"/>Do / Until &lt;lexp&gt;</h2><p class="Code_20_example"><span class="T11">Do</span></p><p class="Code_20_example"><span class="T11">        &lt;statement&gt;</span></p><p class="Code_20_example"><span class="T11">        …</span></p><p class="Code_20_example"><span class="T11">        &lt;statement&gt;</span></p><p class="Code_20_example"><span class="T11">Until &lt;lexp&gt;</span></p><p class="P109">The statements between <span class="T7">Do</span> and <span class="T7">Until</span> will be executed until &lt;lexp&gt; is true. The &lt;statement&gt;s will always be executed at least once.</p><p class="P109"><span> </span></p><p class="Standard"><span class="T7">Do-Until</span> loops may be nested to any level. Any encountered <span class="T7">Until</span> statement will apply to the last executed <span class="T7">DO</span> statement.</p><p class="Standard">You can exit a <span class="T7">Do</span> loop without <span class="T7">Until</span> or <span class="T7">D_U.break</span>. As with <span class="T7">For-Next</span> loops, this can create subtle bugs, and BASIC! can help you find them. If debug is on, and your program is still in a <span class="T7">Do</span> loop when it ends, BASIC! shows a run-time error: "Program ended with DO without  UNTIL".</p><h2 class="Heading_20_2"><a id="a__D_U_continue"><span/></a><a id="_Toc5235863"/>D_U.continue</h2><p class="Standard">If this statement is executed within a <span class="T7">Do-Until</span> loop, the rest of the current pass of the loop is skipped. The <span class="T7">Until</span> statement executes immediately.</p><h2 class="Heading_20_2"><a id="a__D_U_break"><span/></a><a id="_Toc5235864"/>D_U.break</h2><p class="Standard">If this statement is executed within a <span class="T7">Do-Until</span> loop, the rest of the current pass of the loop is skipped and the loop is terminated. The statement immediately following the <span class="T7">Until</span> will be executed.</p><h2 class="Heading_20_2"><a id="a__Labels__GOTO__GOSUB__and_RETURN__Traditional_BASIC"><span/></a><a id="_Toc5235865"/>Labels, GOTO, GOSUB, and RETURN: Traditional BASIC</h2><p class="Standard">Before computer scientists invented the looping structures and user-defined functions described above, program flow was controlled by <span class="T7">GOTO</span>, <span class="T7">GOSUB</span>, and <span class="T7">RETURN</span> statements. These statements are present in BASIC!, too, mainly for compatibility with old BASIC dialects.</p><p class="Standard">A <span class="T7">GoTo</span> statement is a one-way jump to another place in your program, identified by a <span class="T7">Label</span>. The program goes to the <span class="T7">Label</span> and continues execution there.</p><p class="Standard">A <span class="T7">GoSub</span> is similar, except that the <span class="T7">Label</span> is the beginning of a "Subroutine". The proram goes to the <span class="T7">Label</span>, and executes there until it reaches a <span class="T7">Return</span> statement. Then it "returns", going back to where it came from: the line after the <span class="T7">GoSub</span> statement.</p><p class="Standard">Extensive use of the <span class="T7">GoTo</span> command in your program should be generally avoided. It can make code hard to read and harder to debug. Instead, you should use structured elements like <span class="T7">Do…Until</span>, <span class="T7">While…Repeat</span>, etc. in conjunction with the <span class="T7">Break</span> and <span class="T7">Continue</span> statements.</p><p class="Standard">It is especially serious to use <span class="T7">GoTo</span> commands inside an <span class="T7">If…Else…Endif</span>, <span class="T7">For…Next</span>, or other structured block, jumping to code outside of the block. Doing this consumes system resources and may corrupt BASIC!’s internal data structures. This practice may lead your program to a run-time error:</p><p class="Code_20_example"><span class="T11">Stack overflow. See manual about use of GOTO.</span></p><h3 class="Heading_20_3"><a id="a__Label"><span/></a><a id="_Toc5235866"/>Label</h3><p class="Standard">A label is a word followed by the colon ":", character. Label names follow the same conventions as variable names, except that a label must not start with a BASIC! command keyword.</p><p class="Standard">You may put a label on a line with other commands. Use two colons: one to signify that the word is a label, and a second to separate the label from the other command(s) on the line.</p><p class="Code_20_example"><span class="T11">Here: : IF ++a &lt; 5 THEN GOTO here ELSE PRINT a</span></p><p class="Standard">This program prints <span class="T15">5.0</span> and then stops.</p><p class="Standard">The colon signifies that the word is a label, but it is not part of the label. Use the colon where the label is defined. Do not use it in the <span class="T7">GoTo</span> or <span class="T7">GoSub</span> that jumps to the label.</p><p class="Standard">For example:</p><p class="Code_20_example"><span class="T11">This_is_a_Label:</span></p><p class="Code_20_example"><span class="T11">@Label#3:</span></p><p class="Code_20_example"><span class="T11">Loop:                % The command "GoTo Loop" jumps to this line</span></p><p class="Code_20_example"><span class="T11">        &lt;statement&gt;</span></p><p class="Code_20_example"><span class="T11">        …</span></p><p class="Code_20_example"><span class="T11">        &lt;statement&gt;</span></p><p class="Code_20_example"><span class="T11">        GoTo Loop</span></p><h3 class="Heading_20_3"><a id="a__GoTo__label_"><span/></a><a id="_Toc5235867"/>GoTo &lt;label&gt;</h3><p class="Standard">The next statement that will be executed will be the statement following &lt;label&gt;.</p><h3 class="Heading_20_3"><a id="a__GoTo__index_nexp____label____"><span/></a><a id="_Toc5235868"/>GoTo &lt;index_nexp&gt;, &lt;label&gt;...</h3><p class="Standard">A "computed GOTO". The index expression is evaluated, rounded to the nearest integer, and used as an index into the list of labels. The program jumps to the statement after the indexed label. If the index does not select any label, the program continues at the statement after the <span class="T7">GoTo</span>.</p><p class="Standard">For examples, see <span class="T7">GoSub</span>.</p><h3 class="Heading_20_3"><a id="a__GoSub__label____Return"><span/></a><a id="_Toc5235869"/>GoSub &lt;label&gt; / Return</h3><p class="Standard">The next statement that will be executed will be the statement following &lt;label&gt;.</p><p class="Standard">The statements following the line beginning with &lt;label&gt; will continue to be executed until a <span class="T7">Return</span> statement is encountered. Execution will then continue at the statement following the <span class="T7">GoSub</span> statement.</p><p class="Standard">Example:</p><p class="Code_20_example"><span class="T11">Message$ = "Have a good day"</span></p><p class="Code_20_example"><span class="T11">GOSUB xPrint</span></p><p class="Code_20_example"><span class="T11">PRINT "Thank you"</span></p><p class="Code_20_example"><span class="T11">&lt;statement&gt;</span></p><p class="Code_20_example"><span class="T11">…</span></p><p class="Code_20_example"><span class="T11">&lt;statement&gt;</span></p><p class="Code_20_example"><span class="T11">END</span></p><p class="Code_20_example"><span class="T11">xPrint:</span></p><p class="Code_20_example"><span class="T11">PRINT Message$</span></p><p class="Code_20_example"><span class="T11">RETURN</span></p><p class="Standard">This will print:</p><p class="Code_20_example"><span class="T11">Have a good day</span></p><p class="Code_20_example"><span class="T11">Thank you</span></p><h3 class="Heading_20_3"><a id="a__GoSub__index_nexp____label_______Return"><span/></a><a id="_Toc5235870"/>GoSub &lt;index_nexp&gt;, &lt;label&gt;... / Return</h3><p class="Standard">A "computed GOSUB". The index expression is evaluated, rounded to the nearest integer, and used as an index into the list of labels. The program jumps to the statement after the indexed label. When the next <span class="T7">Return</span> instruction executes, the program returns to the statement after this <span class="T7">GoSub</span>.</p><p class="Standard">If the index does not select any label, the program continues to the statement after the <span class="T7">GoSub</span>. No subroutine is executed, and no <span class="T7">Return</span> statement is expected.</p><p class="Standard">Example:</p><p class="Code_20_example"><span class="T11">d = FLOOR(6 * RND() + 1)                % roll a six-sided die</span></p><p class="Code_20_example"><span class="T11">GOSUB d, Side1, Side2, Side3, Side4, Side5, Side6</span></p><p class="Code_20_example"><span class="T11">PRINT "Welcome back!"</span></p><p class="Code_20_example"><span class="T11">END</span></p><p class="Code_20_example"><span class="T11">Side1:</span></p><p class="Code_20_example"><span class="T11">&lt;subroutine for side 1&gt;</span></p><p class="Code_20_example"><span class="T11">RETURN</span></p><p class="Code_20_example"><span class="T11">…</span></p><p class="Code_20_example"><span class="T11">Side6:</span></p><p class="Code_20_example"><span class="T11">&lt;subroutine for side 6&gt;</span></p><p class="Code_20_example"><span class="T11">RETURN</span></p><h2 class="Heading_20_2"><a id="a__Using_Source_Code_from_Multiple_Files"><span/></a><a id="_Toc5235871"/>Using Source Code from Multiple Files</h2><h3 class="Heading_20_3"><a id="a__Include_FilePath"><span/></a><a id="_Toc5235872"/>Include FilePath</h3><p class="Standard">Before the program is run, the BASIC! preprocessor replaces any <span class="T7">Include</span> statements with the text from the named file. You can use this to insert another BASIC! program file into your program at this point. The program is not yet running, therefore the File Path cannot be a string expression.</p><p class="Standard">You may include a file only once. If multiple <span class="T7">Include</span> statements name the same file, the preprocessor inserts the contents of the file in place of the first such <span class="T7">Include</span> statement and deletes the others. This prevents Out-Of-Memory crashes caused by an <span class="T7">Include</span> file including itself.</p><p class="P7"><span class="T11">INCLUDE functions/DrawGraph.bas</span></p><p class="Standard">inserts the code from the file "&lt;pref base drive&gt;/rfo-basic/source/functions/DrawGraph.bas" into the program.</p><p class="P143">The File Path may be written without quotation marks, as in the example above, or with quotes:</p><p class="Code_20_example"><span class="T11">INCLUDE "functions/DrawGraph.bas"</span></p><p class="Standard">If present, the quotes prevent the preprocessor from forcing the File Path to lower-case. Normally, this does not change how BASIC! behaves, because the file system on the SD card is case-insensitive. <span class="T7">DrawGraph.bas</span> and <span class="T7">drawgraph.bas</span> both refer to the same file.</p><p class="Standard">However, if you build your program into a standalone Android application (see <span class="T7">Appendix D</span>), you can use virtual files in the Android <span class="T7">assets</span> file system. File names in <span class="T7">assets</span> are case-sensitive, so you may need to use quotes with the <span class="T7">Include</span> File Path.</p><p class="Standard">Because <span class="T7">Include</span> is processed before your program starts running, it is not affected by program logic.</p><p class="Code_20_example"><span class="T11">IF 0</span></p><p class="Code_20_example"><span class="T11">  INCLUDE functions/DrawGraph.bas</span></p><p class="Code_20_example"><span class="T11">ENDIF</span></p><p class="Standard">In this example, the contents of the program file replace the <span class="T7">Include</span> statement in the body of the <span class="T7">If</span>/<span class="T7">Endif</span>, but the statements are never executed because <span class="T7">If 0</span> is always false.</p><p class="Standard">However, an <span class="T7">Include</span> in a single-line <span class="T7">If</span> is ignored:</p><p class="Code_20_example"><span class="T11">IF x THEN INCLUDE functions/DrawGraph.bas ELSE PRINT "bad!"</span></p><p class="Standard">In this example, the file is not inserted in place of the <span class="T7">Include</span> statement.</p><h3 class="Heading_20_3"><a id="a__Run__filename_sexp_{___data_sexp_}"><span/></a><a id="_Toc5235873"/>Run &lt;filename_sexp&gt;{, &lt;data_sexp&gt;}</h3><p class="Standard">This command will terminate the running of the current program and then load and run the BASIC! program named in the filename string expression. The filename is relative to BASIC’s "source/" directory. If the filename is "program.bas" and your &lt;pref base drive&gt; is "/sdcard" (the default), then the file "/sdcard/rfo-basic/source/program.bas" will be executed.</p><p class="Standard">If the filename parameter is omitted, and the currently executing program has a name, then the program restarts. The program does not have a name if you run from the BASIC! Editor without first saving the program; in this case <span class="T7">Run</span> terminates your program with a syntax error.</p><p class="Standard">The optional data string expression provides for the passing of data to the next program. The passed data can be accessed in the next program by referencing the special variable, <span class="T7">##$</span>.</p><p class="Standard"><span class="T7">Run</span> programs can be chained. A program loaded and run by means of the <span class="T7">Run</span> command can also run another program file. This chain can be a long as needed.</p><p class="Standard">When the last program in a <span class="T7">Run</span> chain ends, tapping the BACK key will display the original program in the BASIC! Editor.</p><p class="Standard">When a program ends with an error, the Editor tries to highlight the line where the error occurred. If the program with the error was started by a <span class="T7">Run</span> command, the Editor does not have that program loaded. Any highlighting that may be displayed is meaningless.</p><h3 class="Heading_20_3"><a id="a__Program_info__nexp_|_nvar_"><span/></a><a id="_Toc5235874"/>Program.info &lt;nexp&gt;|&lt;nvar&gt;</h3><p class="Standard">Returns a Bundle that reports information about the currently running program. If you provide a variable that is not a valid Bundle pointer, the command creates a new Bundle and returns the Bundle pointer in your variable. Otherwise it writes into the Bundle your variable or expression points to.</p><p class="Standard">The bundle keys and possible values are in the table below:</p><table border="0" cellspacing="0" cellpadding="0" class="Table11"><colgroup><col width="92"/><col width="85"/><col width="460"/></colgroup><tr class="Table111"><td style="text-align:left;width:2.097cm; " class="Table11_A1"><p class="P120">Key</p></td><td style="text-align:left;width:1.953cm; " class="Table11_A1"><p class="P120">Type</p></td><td style="text-align:left;width:10.518cm; " class="Table11_A1"><p class="P120">Value</p></td></tr><tr class="Table112"><td style="text-align:left;width:2.097cm; " class="Table11_A2"><p class="P120">BasPath</p></td><td style="text-align:left;width:1.953cm; " class="Table11_A2"><p class="P110">String</p></td><td style="text-align:left;width:10.518cm; " class="Table11_A2"><p class="P114">Full path + name of the program currently being executed.</p><p class="P114">The path is relative to BASIC!’s "source/" directory.</p></td></tr><tr class="Table112"><td style="text-align:left;width:2.097cm; " class="Table11_A2"><p class="P120">BasName</p></td><td style="text-align:left;width:1.953cm; " class="Table11_A2"><p class="P110">String</p></td><td style="text-align:left;width:10.518cm; " class="Table11_A2"><p class="P114">Name of the program currently being executed.</p></td></tr><tr class="Table111"><td style="text-align:left;width:2.097cm; " class="Table11_A2"><p class="P120">SysPath</p></td><td style="text-align:left;width:1.953cm; " class="Table11_A2"><p class="P110">String</p></td><td style="text-align:left;width:10.518cm; " class="Table11_A2"><p class="P114">Full path to the BASIC!’s private file storage directory.</p><p class="P114">The path is relative to BASIC!’s "data/" directory.</p></td></tr><tr class="Table111"><td style="text-align:left;width:2.097cm; " class="Table11_A2"><p class="P120">UserApk</p></td><td style="text-align:left;width:1.953cm; " class="Table11_A2"><p class="P110">Numeric</p><p class="P110">(Logical)</p></td><td style="text-align:left;width:10.518cm; " class="Table11_A2"><p class="P114">Returns 1.0 (true) if the current program is being run from a standalone user-built APK (Appendix D).</p><p class="P114">Returns 0.0 (false) if the program is being from from the BASIC! Editor or a Launcher Shortcut (Appendix C).</p></td></tr></table><p class="P81"> </p><p class="P81">For example, assume:</p><ul><li><p class="P83" style="margin-left:1.27cm;"><span class="ListLabel_20_149" style="display:block;float:left;min-width:0.635cm;"></span>You are using the default &lt;pref base drive&gt;<span class="odfLiEnd"/> </p></li><li><p class="P83" style="margin-left:1.27cm;"><span class="ListLabel_20_149" style="display:block;float:left;min-width:0.635cm;"></span>You downloaded a file called "my_program.bas" to the standard Android Download directory.<span class="odfLiEnd"/> </p></li><li><p class="P83" style="margin-left:1.27cm;"><span class="ListLabel_20_149" style="display:block;float:left;min-width:0.635cm;"></span>You used the BASIC! Editor to load and run the downloaded program.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">Then the returned values would be as follows:</p><table border="0" cellspacing="0" cellpadding="0" class="Table12"><colgroup><col width="92"/><col width="274"/><col width="92"/><col width="142"/></colgroup><tr class="Table121"><td style="text-align:left;width:2.097cm; " class="Table12_A1"><p class="P120">Key</p></td><td style="text-align:left;width:6.274cm; " class="Table12_A1"><p class="P120">Value</p></td><td style="text-align:left;width:2.096cm; " class="Table12_A1"><p class="P120">Key</p></td><td style="text-align:left;width:3.251cm; " class="Table12_A1"><p class="P120">Value</p></td></tr><tr class="Table122"><td style="text-align:left;width:2.097cm; " class="Table12_A2"><p class="P120">BasPath</p></td><td style="text-align:left;width:6.274cm; " class="Table12_A1"><p class="P114">../../Download/my_program.bas</p></td><td style="text-align:left;width:2.096cm; " class="Table12_A1"><p class="P114"><span class="T7">BasName</span></p></td><td style="text-align:left;width:3.251cm; " class="Table12_A2"><p class="P114">my_program.bas</p></td></tr><tr class="Table121"><td style="text-align:left;width:2.097cm; " class="Table12_A2"><p class="P120">SysPath</p></td><td style="text-align:left;width:6.274cm; " class="Table12_A1"><p class="P114">../../../../../data/data/com.rfo.basic</p></td><td style="text-align:left;width:2.096cm; " class="Table12_A1"><p class="P121">UserApk</p></td><td style="text-align:left;width:3.251cm; " class="Table12_A2"><p class="P114">0.0</p></td></tr></table><p class="P81"> </p><p class="Standard"><span class="T7">SysPath</span>: BASIC! normally keeps programs and data in its <span class="T18">base directory</span> (see <span class="T7">Working with Files</span>, later in this manual). The base directory is in public storage space. BASIC! programs also have acces to a private storage area. Your program can create a subdirectory within the SysPath directory and store private files there. Note that if you uninstall BASIC!, any files in private storage will be deleted.</p><p class="P81">SysPath is of particular interest to you if you build a BASIC! program as an application in a standalone apk, as described in Appendix D. See <span class="T7">Modifications to the AndroidManifest.xml File </span><span class="T25"></span><span class="T7"> Permissions</span>.</p><h2 class="Heading_20_2"><a id="a__Switch_Commands"><span/></a><a id="_Toc5235875"/>Switch Commands</h2><p class="Standard">The Switch commands may be used to replace nested if-then-else operations.</p><p class="P95"><span class="T15">SW.BEGIN a</span></p><p class="P95"><span class="T15">SW.CASE 1</span></p><p class="P146"><span class="T15">&lt;statement1&gt;</span></p><p class="P146"><span class="T15">…</span></p><p class="P146"><span class="T15">&lt;statement2&gt;</span></p><p class="P146"><span class="T15">SW.BREAK</span></p><p class="P95"><span class="T15">SW.CASE 2, 4</span></p><p class="P146"><span class="T15">&lt;statement3&gt;</span></p><p class="P146"><span class="T15">…</span></p><p class="P146"><span class="T15">&lt;statement4&gt;</span></p><p class="P146"><span class="T15">SW.BREAK</span></p><p class="P95"><span class="T15">SW.CASE &lt; 0</span></p><p class="P146"><span class="T15">&lt;statement5&gt;</span></p><p class="P146"><span class="T15">…</span></p><p class="P146"><span class="T15">&lt;statement6&gt;</span></p><p class="P146"><span class="T15">SW.BREAK</span></p><p class="P95"><span class="T15">SW.DEFAULT</span></p><p class="P95"><span class="T15">        &lt;statement7&gt;</span></p><p class="P95"><span class="T15">SW.END</span></p><p class="P102">The value of the argument of <span class="T7">Sw.begin</span> is compared to the argument of each <span class="T7">Sw.case</span> in order. If any <span class="T7">Sw.case</span> matches the <span class="T7">Sw.begin</span>, the statements following the matching <span class="T7">Sw.case</span> is executed; if no <span class="T7">Sw.case</span> matches, the statements after <span class="T7">Sw.default</span> are executed. Once BASIC! starts to execute the statements of a <span class="T7">Sw.case</span> or <span class="T7">Sw.default</span>, it continues execution until it finds a <span class="T7">Sw.break</span> or the <span class="T7">Sw.end</span>, ignoring any other <span class="T7">Sw.case</span> or <span class="T7">Sw.default</span> it may encounter. <span class="T7">Sw.break</span> causes a jump to the <span class="T7">Sw.end</span>.</p><p class="No_20_Spacing">In the example:</p><ul><li><p class="P30" style="margin-left:1.27cm;"><span class="ListLabel_20_109" style="display:block;float:left;min-width:0.635cm;"></span>if the value of <span class="T7">a</span> is 1, then &lt;statement1&gt; through &lt;statement2&gt; execute<span class="odfLiEnd"/> </p></li><li><p class="P30" style="margin-left:1.27cm;"><span class="ListLabel_20_109" style="display:block;float:left;min-width:0.635cm;"></span>if the value of <span class="T7">a</span> is 2 or 4, then &lt;statement3&gt; through &lt;statement4&gt; execute<span class="odfLiEnd"/> </p></li><li><p class="P30" style="margin-left:1.27cm;"><span class="ListLabel_20_109" style="display:block;float:left;min-width:0.635cm;"></span>if the value of <span class="T7">a</span> is less than 0, then &lt;statement5&gt; through &lt;statement6&gt; execute<span class="odfLiEnd"/> </p></li><li><p class="P30" style="margin-left:1.27cm;"><span class="ListLabel_20_109" style="display:block;float:left;min-width:0.635cm;"></span>if <span class="T7">a</span> has any other value (3, or more than 4) then &lt;statement7&gt; executes.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">A <span class="T7">Sw.begin</span> must be followed by a <span class="T7">Sw.end</span>, and all of the <span class="T7">Sw.case</span> and the <span class="T7">Sw.default</span> (if there is one) for the same switch must appear between them. A set of switch commands is treated as a single unit, just as if BASIC! were compiled.</p><h3 class="Heading_20_3"><a id="a__Nesting_Switch_Operations"><span/></a><a id="_Toc5235876"/>Nesting Switch Operations</h3><p class="Standard">Switches can be nested. The block of statements following a <span class="T7">Sw.case</span> or <span class="T7">Sw.default</span> may include a full set of switch commands. The nested switch begins with another <span class="T7">Sw.begin</span> and ends with another <span class="T7">Sw.end</span>, with its own <span class="T7">Sw.case</span> and <span class="T7">Sw.default</span> statements in between. You can nest other switches inside nested switches, for as many levels as you want.</p><p class="Standard">If you prefer, you may put the inner switch operations in a labeled <span class="T7">Gosub</span> routine or a User-defined Function, and put the <span class="T7">Gosub</span> or function call in the <span class="T7">Sw.case</span> or <span class="T7">Sw.default</span> block. This may make your code easier to read, and it will also make the initial scan of the switch a little faster.</p><h3 class="Heading_20_3"><a id="a__Sw_begin__exp_"><span/></a><a id="_Toc5235877"/>Sw.begin &lt;exp&gt;</h3><p class="Standard">Begins a switch operation. BASIC! scans forward until it reaches a <span class="T7">Sw.end</span>, locating all <span class="T7">Sw.case</span>, <span class="T7">Sw.break</span>, and <span class="T7">Sw.default</span> statements between the <span class="T7">Sw.begin</span> and the <span class="T7">Sw.end</span>.</p><p class="Standard">The numeric or string expression &lt;exp&gt; is evaluated. Its value is then compared to the expression(s) in each <span class="T7">Sw.case</span> statement, in order. BASIC! uses to result of the compares to decide which statement to execute next.</p><table border="0" cellspacing="0" cellpadding="0" class="Table13"><colgroup><col width="416"/><col width="250"/></colgroup><tr class="Table131"><td style="text-align:left;width:9.525cm; " class="Table13_A1"><p class="P122">IF this condition is met:</p></td><td style="text-align:left;width:5.713cm; " class="Table13_A1"><p class="P122">THEN jump to the statement</p></td></tr><tr class="Table131"><td style="text-align:left;width:9.525cm; " class="Table13_A2"><p class="P118"><span class="T53">One or more </span>Sw.Case<span class="T53"> statement(s) match the </span>Sw.Begin</p></td><td style="text-align:left;width:5.713cm; " class="Table13_A2"><p class="P114">after the <span class="T18">first</span> matching <span class="T7">Sw.case</span>.</p></td></tr><tr class="Table131"><td style="text-align:left;width:9.525cm; " class="Table13_A2"><p class="P118"><span class="T53">No </span>Sw.Case<span class="T53"> matches </span>AND<span class="T53"> a </span>Sw.default<span class="T53"> exists</span></p></td><td style="text-align:left;width:5.713cm; " class="Table13_A2"><p class="P114">after the <span class="T7">Sw.default</span>.</p></td></tr><tr class="Table131"><td style="text-align:left;width:9.525cm; " class="Table13_A2"><p class="P122">No Sw.Case matches AND no Sw.default exists</p></td><td style="text-align:left;width:5.713cm; " class="Table13_A2"><p class="P114">after the <span class="T7">Sw.end</span>.</p></td></tr></table><p class="P102">There are two forms of <span class="T7">Sw.case</span>. You may freely mix both forms. Each form defines what it means to "match" <span class="T7">Sw.begin</span>. Only the first matching <span class="T7">Sw.case</span> has any effect.</p><h3 class="Heading_20_3"><a id="a__Sw_case__exp______"><span/></a><a id="_Toc5235878"/>Sw.case &lt;exp&gt;, ...</h3><p class="Standard">This form of <span class="T7">Sw.case</span> provides a list of one or more expressions. A <span class="T7">Sw.case</span> of this form matches the <span class="T7">Sw.begin</span> if the value of at least one of the expressions <span class="T18">exactly equals</span> the value of the <span class="T7">Sw.begin</span> parameter. The type of the <span class="T7">Sw.begin</span> and <span class="T7">Sw.case</span> parameter(s), numeric or string, must match.</p><h3 class="Heading_20_3"><a id="a__Sw_case__op__exp_"><span/></a><a id="_Toc5235879"/>Sw.case &lt;op&gt;&lt;exp&gt;</h3><p class="P109">The first form of <span class="T7">Sw.case</span>, above, matches the <span class="T7">Sw.begin</span> if the value of any of its parameters <span class="T18">equals</span> the value of the <span class="T7">Sw.begin</span> parameter. This second form can take only one expression &lt;exp&gt;, but it lets you specify a different logical operator &lt;op&gt;. You may use any of these comparison operators:</p><p class="Code_20_example"> <span class="T10">&lt;   &lt;=   &gt;   &gt;=   &lt;&gt;</span></p><p class="No_20_Spacing">For example:</p><p class="Code_20_example"><span class="T11">SW.BEGIN a</span></p><p class="Code_20_example"><span class="T11">SW.CASE &lt; b                % This SW.CASE matches if </span><span class="T10">a &lt; b</span></p><p class="No_20_Spacing">The expression &lt;exp&gt; may be arbitrarily complex. The whole expression is evaluated as if written:</p><p class="Code_20_example"><span class="T11">&lt;value of </span><span class="T10">Sw.begin</span><span class="T11"> argument&gt; &lt;op&gt; &lt;exp&gt;</span></p><p class="Standard">Operator precedence is applied as usual.</p><h3 class="Heading_20_3"><a id="a__Sw_break"><span/></a><a id="_Toc5235880"/>Sw.break</h3><p class="Standard">This statement may be used to terminate the block of statements that follows <span class="T7">Sw.case</span> or <span class="T7">Sw.default</span>. The <span class="T7">Sw.break</span> causes BASIC! to jump forward to the <span class="T7">Sw.end</span> statement, skipping everything between.</p><p class="Standard">If no <span class="T7">Sw.break</span> is present in a particular <span class="T7">Sw.case</span> then subsequent <span class="T7">Sw.case</span>s will be executed until a <span class="T7">Sw.break</span> or <span class="T7">Sw.end</span> is encountered.</p><h3 class="Heading_20_3"><a id="a__Sw_default"><span/></a><a id="_Toc5235881"/>Sw.default</h3><p class="Standard">This statements acts like a <span class="T7">Sw.case</span> that matches any value. If any <span class="T7">Sw.case</span> matches the <span class="T7">Sw.begin</span> value, then the <span class="T7">Sw.default</span> is ignored, even if the matching <span class="T7">Sw.case</span> is after the <span class="T7">Sw.default</span>.</p><p class="Standard">A switch is not required to have a <span class="T7">Sw.default</span>, but it must not have more than one. A second <span class="T7">Sw.default</span> in the same switch is a syntax error.</p><h3 class="Heading_20_3"><a id="a__Sw_end"><span/></a><a id="_Toc5235882"/>Sw.end</h3><p class="Standard">The <span class="T7">Sw.end</span> terminates a switch operation. <span class="T7">Sw.end</span> must eventually follow a <span class="T7">Sw.begin</span>.</p><h2 class="Heading_20_2"><a id="a__Interrupt_Labels__Event_Handlers_"><span/></a><a id="_Toc5235883"/>Interrupt Labels (Event Handlers)</h2><p class="Standard">You can perform physical actions that tell your BASIC! program to do something. When you touch the screen or press a key you cause an <span class="T18">event</span>. These events are <span class="T18">asynchronous</span>, that is, they happen at times your program cannot predict. BASIC! detects some events so your program can respond to them.</p><p class="P109">BASIC! handles events as <span class="T18">interrupts</span>. Each event that BASIC! recognizes has a unique <span class="T18">Interrupt Label</span>. When an event occurs, BASIC! looks for the Interrupt Label that matches the event.</p><ul><li><p class="P31" style="margin-left:1.27cm;"><span class="ListLabel_20_121" style="display:block;float:left;min-width:0.635cm;"></span>If you have not written that Interrupt Label into your program, the event is ignored and your program goes on running as if nothing happened.<span class="odfLiEnd"/> </p></li><li><p class="P31" style="margin-left:1.27cm;"><span class="ListLabel_20_121" style="display:block;float:left;min-width:0.635cm;"></span>If you have included the right Interrupt Label for the event, BASIC! jumps to that label and continues execution at the line after the label. This is called trapping the event.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">BASIC! does not necessarily respond to the event as soon as it occurs. The statement that is executing when the event occurs is allowed to complete, then BASIC! jumps to the Interrupt Label.</p><p class="Standard">When you use an Interrupt Label to trap an event, BASIC! executes instructions until it finds a <span class="T18">Resume</span> command that matches the Interrupt Label. During that time, it records other events but it does not respond to them. The block of code between the Interrupt Label and the matching Resume may be called an <span class="T18">Interrupt Service Routine (ISR)</span> or, if you prefer, an <span class="T18">Event Handler</span>.</p><p class="No_20_Spacing">When BASIC! executes the event’s Resume command, it resumes normal execution.</p><ul><li><p class="P32" style="margin-left:1.27cm;"><span class="ListLabel_20_125" style="display:block;float:left;min-width:0.635cm;"></span>BASIC! jumps back to where it was running when the interrupt occurred.<span class="odfLiEnd"/> </p></li><li><p class="P32" style="margin-left:1.27cm;"><span class="ListLabel_20_125" style="display:block;float:left;min-width:0.635cm;"></span>BASIC! again responds to other events, including any that occurred while it was handling an event.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">An Interrupt Label looks and behaves just like any other label in BASIC!. However, you must not execute any of the Resume commands except to finish an event’s handler.</p><h3 class="Heading_20_3"><a id="a__All_Interrupt_Labels"><span/></a><a id="_Toc5235884"/>All Interrupt Labels</h3><p class="P109">BASIC! supports trapping of the following events. These interrupt labels and their Resume commands are described in various parts of this manual.</p><ul><li><p class="P33" style="margin-left:1.27cm;"><span class="ListLabel_20_129" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">OnBackground:</span>        <span class="T7">Background.resume</span><span class="odfLiEnd"/> </p></li><li><p class="P33" style="margin-left:1.27cm;"><span class="ListLabel_20_129" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">OnBackKey:</span>        <span class="T7">Back.resume</span><span class="odfLiEnd"/> </p></li><li><p class="P33" style="margin-left:1.27cm;"><span class="ListLabel_20_129" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">OnBtReadReady:</span>        <span class="T7">Bt.onReadReady.resume</span><span class="odfLiEnd"/> </p></li><li><p class="P33" style="margin-left:1.27cm;"><span class="ListLabel_20_129" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">OnConsoleTouch:</span>        <span class="T7">ConsoleTouch.resume</span><span class="odfLiEnd"/> </p></li><li><p class="P33" style="margin-left:1.27cm;"><span class="ListLabel_20_129" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">OnError:</span>                None (not a true event, see <span class="T7">OnError:</span>, below)<span class="odfLiEnd"/> </p></li><li><p class="P33" style="margin-left:1.27cm;"><span class="ListLabel_20_129" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">OnGrTouch:</span>        <span class="T7">Gr.onGrTouch.resume</span><span class="odfLiEnd"/> </p></li><li><p class="P33" style="margin-left:1.27cm;"><span class="ListLabel_20_129" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">OnKbChange:</span>        <span class="T7">Kb.resume</span><span class="odfLiEnd"/> </p></li><li><p class="P33" style="margin-left:1.27cm;"><span class="ListLabel_20_129" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">OnKeyPress:</span>        <span class="T7">Key.resume</span><span class="odfLiEnd"/> </p></li><li><p class="P33" style="margin-left:1.27cm;"><span class="ListLabel_20_129" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">OnLowMemory:</span>        <span class="T7">LowMemory.resume</span><span class="odfLiEnd"/> </p></li><li><p class="P33" style="margin-left:1.27cm;"><span class="ListLabel_20_129" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">OnMenuKey:</span>        <span class="T7">MenuKey.resume</span><span class="odfLiEnd"/> </p></li><li><p class="P33" style="margin-left:1.27cm;"><span class="ListLabel_20_129" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">OnTimer:</span>                <span class="T7">Timer.resume</span><span class="odfLiEnd"/> </p></li></ul><h3 class="Heading_20_3"><a id="a__OnError_"><span/></a><a id="_Toc5235885"/>OnError:</h3><p class="No_20_Spacing">Special interrupt label that traps a run-time error as if it were an event, except that:</p><ul><li><p class="P34" style="margin-left:1.27cm;"><span class="ListLabel_20_117" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">OnError:</span> has no matching Resume command. You can use <span class="T7">GoTo</span> to jump anywhere in your program.<span class="odfLiEnd"/> </p></li><li><p class="P34" style="margin-left:1.27cm;"><span class="ListLabel_20_117" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">OnError:</span> is not locked out by other interrupts.<span class="odfLiEnd"/> </p></li><li><p class="P34" style="margin-left:1.27cm;"><span class="ListLabel_20_117" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">OnError:</span> does not lock out other interrupts.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">If a BASIC! program does not have an <span class="T7">OnError:</span> label and an error occurs while the program is running, an error message is printed to the Output Console and the program stops running.</p><p class="Standard">If the program does have an <span class="T7">OnError:</span> label, BASIC! does not stop on an error. Instead, it jumps to the <span class="T7">OnError:</span> label (see "Interrupt Labels", above). The error message is not printed, but it can be retrieved by the <span class="T7">GETERROR$()</span> function.</p><p class="Standard">Be careful. An infinite loop will occur if a run-time error occurs within the <span class="T7">OnError:</span> code. You should not place an <span class="T7">OnError:</span> label into your program until the program is fully debugged. Premature use of <span class="T7">OnError:</span> will make the program difficult to debug.</p><h3 class="Heading_20_3"><a id="a__OnConsoleTouch_"><span/></a><a id="_Toc5235886"/>OnConsoleTouch:</h3><p class="Standard"><span class="T36">Interrupt label that traps a t</span>ap on a line printed on the Output Console. BASIC!<span class="T36"> executes the statements following the </span><span class="T42">OnConsoleTouch:</span> label<span class="T36"> until it reaches a </span><span class="T43">ConsoleTouch.resume</span>. Note that you must touch a line written by a <span class="T7">PRINT</span> command, although it may be blank. BASIC! Ignores any touch in the empty area of the screen below the printed lines.</p><p class="Standard">After touching a Console line, you may use the <span class="T7">Console.Line.Touched</span> command to determine what line of text was touched.</p><p class="Standard">This label allows the user to interrupt an executing BASIC! program in Console mode (not in Graphics mode). A common reason for such an interrupt would be to have the program request input via an <span class="T7">INPUT</span> statement. See the Sample File, <span class="T7">f35_bluetooth.bas</span>, for an example of this.</p><p class="Standard">To detect screen touches while in graphics mode, use <span class="T7">OnGrTouch:</span>.</p><h3 class="Heading_20_3"><a id="a__ConsoleTouch_resume"><span/></a><a id="_Toc5235887"/>ConsoleTouch.resume</h3><p class="Standard">Resumes execution at the point in the BASIC! program where the <span class="T7">OnConsoleTouch:</span> interrupt occurred.</p><h3 class="Heading_20_3"><a id="a__OnBackKey_"><span/></a><a id="_Toc5235888"/>OnBackKey:</h3><p class="Standard">Interrupt label that traps the BACK key. BASIC! executes the statements following the <span class="T7">OnBackKey:</span> label until it reaches a <span class="T7">Back.resume</span>. If a BASIC! program does not have an <span class="T7">OnBackKey:</span> label, the BACK key normally halts program execution.</p><p class="Standard">If you trap the BACK key with <span class="T7">OnBackKey:</span>, the BACK key does not stop your program. You should either terminate the run in the <span class="T7">OnBackKey:</span> code or provide another way for the user to tell your program to stop, especially if the program is in Graphics mode where there is no menu. If you do not then there will be no stopping the program (other than using Android Settings or a task killer application).</p><h3 class="Heading_20_3"><a id="a__Back_resume"><span/></a><a id="_Toc5235889"/>Back.resume</h3><p class="Standard">Resumes execution at the point in the BASIC! program where the <span class="T7">OnBackKey:</span> interrupt occurred.</p><h3 class="Heading_20_3"><a id="a__OnMenuKey_"><span/></a><a id="_Toc5235890"/>OnMenuKey:</h3><p class="Standard">Interrupt label that traps the MENU key. BASIC!<span class="T36"> executes</span> the statements following th<span class="T36">e </span><span class="T7">OnMenuKey</span><span class="T42">:</span> label <span class="T36">until it reaches a </span><span class="T7">MenuKey</span><span class="T43">.resume</span>. Note: This interrupt does not work unless your device has a MENU key. Android devices since Honeycomb typically do not have a MENU key.</p><h3 class="Heading_20_3"><a id="a__MenuKey_resume"><span/></a><a id="_Toc5235891"/>MenuKey.resume</h3><p class="Standard">Resumes execution at the point in the BASIC! program where the <span class="T7">OnMenuKey:</span> interrupt occurred.</p><h3 class="Heading_20_3"><a id="a__OnKeyPress_"><span/></a><a id="_Toc5235892"/>OnKeyPress:</h3><p class="Standard">Interrupt label that traps a tap on any key. BASIC! executes the statements following the <span class="T7">OnKeyPress:</span> label until it reaches a <span class="T7">Key.resume</span>.</p><h3 class="Heading_20_3"><a id="a__Key_resume"><span/></a><a id="_Toc5235893"/>Key.resume</h3><p class="Standard">Resumes execution at the point in the BASIC! program where the <span class="T7">OnKeyPress:</span> interrupt occurred.</p><h3 class="Heading_20_3"><a id="a__OnLowMemory_"><span/></a><a id="_Toc5235894"/>OnLowMemory:</h3><p class="Standard">Interrupt label that traps the Android "low memory" warning. BASIC! executes the program lines between the <span class="T7">OnLowMemory:</span> interrupt label and the <span class="T7">LowMemory.resume</span> command.</p><p class="Standard">If Android is running out of memory, it may kill applications running in the background, but first it will broadcast a "low memory" warning to all applications. If you do not have an <span class="T7">OnLowMemory:</span> label in your program, you will see "Warning: Low Memory" printed on the Console. </p><h3 class="Heading_20_3"><a id="a__LowMemory_resume"><span/></a><a id="_Toc5235895"/>LowMemory.resume</h3><p class="Standard">Resumes execution at the point in the BASIC! program where the <span class="T7">OnLowMemory:</span> interrupt occured.</p><h2 class="Heading_20_2"><a id="a__End{__msg_sexp_}"><span/></a><a id="_Toc5235896"/>End{ &lt;msg_sexp&gt;}</h2><p class="Standard">Prints a message and stops the execution of the program. The default message in "END". You can use the optional &lt;msg_sexp&gt; argument to specify a different message. The empty string ("") prints nothing, not even a blank line. The <span class="T7">End</span> statement always stops execution, even if the statement has an error.</p><p class="Standard"><span class="T7">End</span> statements may be placed anywhere in the program.</p><h2 class="Heading_20_2"><a id="a__Exit"><span/></a><a id="_Toc5235897"/>Exit</h2><p class="Standard">Causes BASIC! to stop running and exit to the Android home screen.</p><h1 class="Heading_20_1"><a id="a__READ___DATA___RESTORE_Commands"><span/></a><a id="_Toc5235898"/>READ – DATA – RESTORE Commands</h1><p class="Standard">These commands approximate the <span class="T7">READ</span>, <span class="T7">DATA</span> and <span class="T7">RESTORE</span> commands of Dartmouth Basic.</p><h2 class="Heading_20_2"><a id="a__Read_data__number_|_string_{__number_|_string______number_|_string_}"><span/></a><a id="_Toc5235899"/>Read.data &lt;number&gt;|&lt;string&gt;{,&lt;number&gt;|&lt;string&gt;...,&lt;number&gt;|&lt;string&gt;}</h2><p class="Standard">Provides the data value(s) to be read with <span class="T7">Read.next</span>.</p><p class="Standard"><span class="T7">Read.data</span> statements may appear anywhere in the program. You may have as many <span class="T7">Read.data</span> statements as you need.</p><p class="No_20_Spacing">Example:</p><p class="Code_20_example"><span class="T11">Read.data 1,2,3,"a","b","c"</span></p><p class="Standard"><span class="T7">Read.data</span> is equivalent to the <span class="T7">DATA</span> statement in Dartmouth Basic.</p><h2 class="Heading_20_2"><a id="a__Read_next__var______"><span/></a><a id="_Toc5235900"/>Read.next &lt;var&gt;, ...</h2><p class="Standard">Reads the data pointed to by the internal NEXT pointer into the next variables. The NEXT pointer is initialized to "1" and is incremented by one each time a new value is read. Data values are read in the sequence in which they appeared in the program <span class="T7">Read.data</span> statement(s).</p><p class="Standard">The data type (number or string) of the variable must match the data type pointed by the NEXT pointer.</p><p class="No_20_Spacing">Example:</p><p class="Code_20_example"><span class="T11">Read.next a,b,c,c$</span></p><p class="Code_20_example"><span class="T11">Read.next d$,e$</span></p><p class="P109"><span class="T7">Read.next</span> is equivalent to the <span class="T7">READ</span> statement in Dartmouth Basic</p><h2 class="Heading_20_2"><a id="a__Read_from__nexp_"><span/></a><a id="_Toc5235901"/>Read.from &lt;nexp&gt;</h2><p class="Standard">Sets the internal NEXT pointer to the value of the expression. This command can be set to randomly access the data.</p><p class="Standard">The command <span class="T7">Read.from 1</span> is equivalent to the <span class="T7">RESTORE</span> command in Dartmouth Basic.</p><h1 class="Heading_20_1"><a id="a__Debug_Commands"><span/></a><a id="_Toc5235902"/>Debug Commands</h1><p class="Standard">The debug commands help you debug your program. The <span class="T7">Debug.on</span> command controls execution of all the debug commands. The debug commands are ignored unless the <span class="T7">Debug.on</span> command has been previously executed. This means that you can leave all your debug commands in your program and be assured that they will not execute unless you turn debugging on with <span class="T7">Debug.on</span>.</p><h2 class="Heading_20_2"><a id="a__Debug_on"><span/></a><a id="_Toc5235903"/>Debug.on</h2><p class="Standard">Turns on debug mode. All debug commands will be executed when in the debug mode.</p><p class="Standard"><span class="T7">Debug.on</span> also enables a simple debugging aid built into BASIC!. If debug is on, and your program entered a loop but did not exit the loop cleanly, you will get a run-time error. See the looping commands (<span class="T7">For</span>, <span class="T7">While</span>, and <span class="T7">Do</span>) for details.</p><h2 class="Heading_20_2"><a id="a__Debug_off"><span/></a><a id="_Toc5235904"/>Debug.off</h2><p class="Standard">Turns off debug mode. All debug commands (except <span class="T7">Debug.on</span>) will be ignored. When your program exits, the broken-loop checks are not performed.</p><h2 class="Heading_20_2"><a id="a__Debug_echo_on"><span/></a><a id="_Toc5235905"/>Debug.echo.on</h2><p class="Standard">Turns on Echo mode. Each line of the running BASIC! program is printed before it is executed. This can be of great help in debugging. The last few lines executed are usually the cause of program problems. The Echo mode is turned off by either the <span class="T7">Debug.echo.off</span> or the <span class="T7">Debug.off</span> commands.</p><h2 class="Heading_20_2"><a id="a__Echo_on"><span/></a><a id="_Toc5235906"/>Echo.on</h2><p class="Standard">Same as <span class="T7">Debug.echo.on</span>.</p><h2 class="Heading_20_2"><a id="a__Debug_echo_off"><span/></a><a id="_Toc5235907"/>Debug.echo.off</h2><p class="Standard">Turns off the Echo mode.</p><h2 class="Heading_20_2"><a id="a__Echo_off"><span/></a><a id="_Toc5235908"/>Echo.off</h2><p class="Standard">Same as <span class="T7">Debug.echo.off</span>.</p><h2 class="Heading_20_2"><a id="a__Debug_print"><span/></a><a id="_Toc5235909"/>Debug.print</h2><p class="Standard">This command is exactly the same as the <span class="T7">Print</span> command except that the print will occur only while in the debug mode.</p><h2 class="Heading_20_2"><a id="a__Debug_dump_scalars"><span/></a><a id="_Toc5235910"/>Debug.dump.scalars</h2><p class="Standard">Prints a list of all the Scalar variable names and values. Scalar variables are the variable names that are not Arrays or Functions. Among other things, this command will help expose misspelled variable names.</p><h2 class="Heading_20_2"><a id="a__Debug_dump_array_Array__"><span/></a><a id="_Toc5235911"/>Debug.dump.array Array[]</h2><p class="Standard">Dumps the contents of the specified array. If the array is multidimensional the entire array will be dumped in a linear fashion.</p><h2 class="Heading_20_2"><a id="a__Debug_dump_bundle__bundlePtr_nexp_"><span/></a><a id="_Toc5235912"/>Debug.dump.bundle &lt;bundlePtr_nexp&gt;</h2><p class="Standard">Dumps the Bundle pointed to by the Bundle Pointer numeric expression.</p><h2 class="Heading_20_2"><a id="a__Debug_dump_list__listPtr_nexp_"><span/></a><a id="_Toc5235913"/>Debug.dump.list &lt;listPtr_nexp&gt;</h2><p class="Standard">Dumps the List pointed to by the List Pointer numeric expression.</p><h2 class="Heading_20_2"><a id="a__Debug_dump_stack__stackPtr_nexp_"><span/></a><a id="_Toc5235914"/>Debug.dump.stack &lt;stackPtr_nexp&gt;</h2><p class="Standard">Dumps the Stack pointed to by the Stack Pointer numeric expression.</p><h2 class="Heading_20_2"><a id="a__Debug_show_scalars"><span/></a><a id="_Toc5235915"/>Debug.show.scalars</h2><p class="Standard">Pauses the execution of the program and displays a dialog box. The dialog box prints a list of all the Scalar variable names and values, the line number of the program line just executed and the text of that line. Scalar variables are the variable names that are not Arrays or Functions. Among other things, this command will help expose misspelled variable names.</p><p class="Standard">For a description of the dialog box controls, see the <span class="T7">Debug.show</span> command, below.</p><h2 class="Heading_20_2"><a id="a__Debug_show_array_Array__"><span/></a><a id="_Toc5235916"/>Debug.show.array Array[]</h2><p class="Standard">Pauses the execution of the program and displays a dialog box. The dialog box prints the contents of the specified array, the line number of the program line just executed and the text of that line. If the array is multidimensional the entire array will be displayed in a linear fashion.</p><p class="Standard">For a description of the dialog box controls, see the <span class="T7">Debug.show</span> command, below.</p><h2 class="Heading_20_2"><a id="a__Debug_show_bundle__bundlePtr_nexp_"><span/></a><a id="_Toc5235917"/>Debug.show.bundle &lt;bundlePtr_nexp&gt;</h2><p class="Standard">Pauses the execution of the program and displays a dialog box. The dialog box prints the Bundle pointed to by the Bundle Pointer numeric expression, the line number of the program line just executed and the text of that line.</p><p class="Standard">For a description of the dialog box controls, see the <span class="T7">Debug.show</span> command, below.</p><h2 class="Heading_20_2"><a id="a__Debug_show_list__listPtr_nexp_"><span/></a><a id="_Toc5235918"/>Debug.show.list &lt;listPtr_nexp&gt;</h2><p class="Standard">Pauses the execution of the program and displays a dialog box. The dialog box prints the List pointed to by the List Pointer numeric expression, the line number of the program line just executed and the text of that line.</p><p class="Standard">For a description of the dialog box controls, see the <span class="T7">Debug.show</span> command, below.</p><h2 class="Heading_20_2"><a id="a__Debug_show_stack__stackPtr_nexp_"><span/></a><a id="_Toc5235919"/>Debug.show.stack &lt;stackPtr_nexp&gt;</h2><p class="Standard">Pauses the execution of the program and displays a dialog box. The dialog box prints the Stack pointed to by the Stack Pointer numeric expression, the line number of the program line just executed and the text of that line.</p><p class="Standard">For a description of the dialog box controls, see the <span class="T7">Debug.show</span> command, below.</p><h2 class="Heading_20_2"><a id="a__Debug_watch_var_____"><span/></a><a id="_Toc5235920"/>Debug.watch var, ...</h2><p class="Standard">Gives a list of Scalar variables (not arrays) to be watched. The values of these variables will be shown when the Debug.show.watch command is executed. This command is accumulative, meaning that subsequent calls will add new variables into the watch list.</p><h2 class="Heading_20_2"><a id="a__Debug_show_watch"><span/></a><a id="_Toc5235921"/>Debug.show.watch</h2><p class="Standard">Pauses the execution of the program and displays a dialog box. The dialog box lists the values of the variables being watched, the line number of the program line just executed and the text of that line.</p><p class="Standard">For a description of the dialog box controls, see the <span class="T7">Debug.show</span> command, below.</p><h2 class="Heading_20_2"><a id="a__Debug_show_program"><span/></a><a id="_Toc5235922"/>Debug.show.program</h2><p class="Standard">Pauses the execution of the program and displays a dialog box. The dialog box shows the entire program, with line numbers, as well as a marker pointing to the last line that was executed.</p><p class="Standard">Note: the debugger does not stop on a function call. The first line of the function is executed and the marker points to that line. When a <span class="T7">Fn.rtn</span> or <span class="T7">Fn.end</span> executes, the marker points to the function call.</p><p class="Standard">For a description of the dialog box controls, see the <span class="T7">Debug.show</span> command, below.</p><h2 class="Heading_20_2"><a id="a__Debug_show"><span/></a><a id="_Toc5235923"/>Debug.show</h2><p class="Standard">Pauses the execution of the program and displays a dialog box. The dialog box will contain the result of the last <span class="T7">Debug.show.&lt;command&gt;</span> used or by default <span class="T7">Debug.show.program</span>.</p><p class="P81">There are three buttons in the dialog:</p><p class="List_20_Paragraph">Resume: Resumes execution.</p><p class="List_20_Paragraph">Step: Executes the next line while continuing to display the dialog box.</p><p class="List_20_Paragraph">View Swap: Opens a new dialog that allows you to choose a different Debug View.</p><p class="Standard">The BACK key closes the debug dialog and stops your program.</p><h1 class="Heading_20_1"><a id="a__Fonts"><span/></a><a id="_Toc5235924"/>Fonts</h1><p class="Standard">Your program can use fonts loaded from files.</p><p class="Standard">At present, the only way to use a loaded font is with the <span class="T7">Gr.Text.SetFont</span> command.</p><h2 class="Heading_20_2"><a id="a__Font_load__font_ptr_nvar____filename_sexp_"><span/></a><a id="_Toc5235925"/>Font.load &lt;font_ptr_nvar&gt;, &lt;filename_sexp&gt;</h2><p class="Standard">Loads a font from the file named by the &lt;filename_sexp&gt;. Returns a pointer to the font in the variable &lt;font_ptr_nvar&gt;. This pointer can be used to refer to the loaded font, for example, in a <span class="T7">Gr.Text.SetFont</span> command.</p><p class="Standard">If the font file can not be loaded, the pointer will be set to -1. You can call the <span class="T7">GETERROR$()</span> function to get an error message.</p><h2 class="Heading_20_2"><a id="a__Font_delete_{_font_ptr_nexp_}"><span/></a><a id="_Toc5235926"/>Font.delete {&lt;font_ptr_nexp&gt;}</h2><p class="Standard">Deletes the previously loaded font specified by the font pointer parameter &lt;font_ptr_nexp&gt;. Any variable that points to the deleted font becomes an invalid font pointer. An attempt to use the deleted font is an error. It is not an error to delete the same font again.</p><p class="Standard">If the font pointer is omitted, the command deletes the most-recently loaded font that has not already been deleted. Repeating this operation deletes loaded fonts in last-to-first order. It is not an error to do this when there are no fonts loaded.</p><h2 class="Heading_20_2"><a id="a__Font_clear"><span/></a><a id="_Toc5235927"/>Font.clear</h2><p class="Standard">Clears the font list, deleting all previously loaded fonts. Any variable that points to a font becomes an invalid font pointer. An attempt to use any of the deleted fonts is an error.</p><p class="Standard"><span class="T7">Note:</span> <span class="T7">Font.delete</span> leaves a marker in the font list, so pointers to other fonts will not be affected. That is why you can <span class="T7">Font.delete</span> the same font more than once. <span class="T7">Font.clear</span> clears the entire list, making all font pointer variables invalid. After executing <span class="T7">Font.clear</span>, you can’t <span class="T7">Font.delete</span> any of the cleared fonts.</p><h1 class="Heading_20_1"><a id="a__Console_I_O"><span/></a><a id="_Toc5235928"/>Console I/O</h1><h2 class="Heading_20_2"><a id="a__Output_Console"><span/></a><a id="_Toc5235929"/>Output Console</h2><p class="Standard">BASIC! has three types of output screens: The Output Console, the Graphics Screen, and the HTML Screen. This section deals with the Output Console. See the section on Graphics for information about the Graphics Screen. See the section on HTML for information aobut the HTML screen.</p><p class="Standard">Information is printed to screen using the Print command. BASIC! Run-time error messages are also displayed on this screen.</p><p class="Standard">There is no random access to locations on this screen. Lines are printed one line after the other.</p><p class="Standard">Although no line numbers are displayed, lines are numbered sequentially as they are printed, starting with 1. These line numbers refer to lines of text output, not to locations on the screen.</p><h3 class="P18"><a id="a__Print_{_exp__{_|_}}____"><span/></a><a id="_Toc5235930"/>Print {&lt;exp&gt; {,|;}} ... </h3><h3 class="P18"><a id="a__?_{_exp__{_|_}}____"><span/></a><a id="_Toc5235931"/>? {&lt;exp&gt; {,|;}} ... </h3><p class="Standard">Evaluates the expression(s) &lt;exp&gt; and prints the result(s) to the Output Console. You can use a question mark (<span class="T7">?</span>) in place of the command keyword <span class="T7">Print</span>.</p><p class="Standard">If the comma (<span class="T7">,</span>) separator follows an expression then a comma and a space will be printed after the value of the expression.</p><p class="Standard">If the semicolon (<span class="T7">;</span>) separator is used then nothing will separate the values of the expressions.</p><p class="Standard">If the semicolon is at the end of the line, the output will not be printed until a <span class="T7">Print</span> command without a semicolon at the end is executed.</p><p class="Standard"><span class="T7">Print</span> with no parameters prints a newline.</p><p class="Standard">Examples:</p><p class="P8"><span class="T11">PRINT "New", "Message"                % Prints: New, Message</span></p><p class="P8"><span class="T11">PRINT "New";" Message"                % Prints: New Message</span></p><p class="P8"><span class="T11">PRINT "New" + " Message"                % Prints: New Message</span></p><p class="P9"> </p><p class="P8"><span class="T11">? 100-1; " Luftballons"                % Prints: 99.0 Luftballons</span></p><p class="P8"><span class="T11">? FORMAT$("##", 99); " Luftballons"        % Prints:   99 Luftballons</span></p><p class="P9"> </p><p class="P8"><span class="T11">PRINT "A";"B";"C";                        % Prints: nothing</span></p><p class="P8"><span class="T11">PRINT "D";"E";"F"                        % Prints: ABCDEF</span></p><h3 class="Heading_20_3"><a id="a__Print_with_User-Defined_Functions"><span/></a><a id="_Toc5235932"/>Print with User-Defined Functions</h3><p class="Standard">Note: Some commands, such as <span class="T7">Print</span>, can operate on either strings or numbers. Sometimes it has to try both ways before it knows what to do. First it will try to evaluate an expression as a number. If that fails, it will try to evaluate the same expression as a string.</p><p class="Standard">If this happens, and the expression includes a function, the function will be called twice. If the function has side-effects, such as printing to the console, writing to a file, or changing a global parameter, the side-effect action will also happen twice.</p><p class="Standard">Eventually this problem should be fixed in BASIC!, but until then you should be careful not to call a function, especially a user-defined function, as part of a <span class="T7">Print</span> command. Instead, assign the return value of the function to a variable, and then <span class="T7">Print</span> the variable. An assignment statement always knows what type of expression to evaluate, so it never evaluates twice.</p><p class="Code_20_example"><span class="T11">! Do this:</span></p><p class="Code_20_example"><span class="T11">y = MyFunction(x)</span></p><p class="Code_20_example"><span class="T11">Print y</span></p><p class="Code_20_example"><span class="T11">! NOT this:</span></p><p class="Code_20_example"><span class="T11">Print MyFunction(x)</span></p><h3 class="Heading_20_3"><a id="a__Cls"><span/></a><a id="_Toc5235933"/>Cls</h3><p class="Standard">Clears the Output Console screen.</p><h3 class="Heading_20_3"><a id="a__Console_front"><span/></a><a id="_Toc5235934"/>Console.front</h3><p class="Standard">Brings the Output Console to the front where the user can see it.</p><p class="Standard">If BASIC! is running in the background with no screen visible, this command brings it to the foreground. If you have a different application running in the foreground, it will be pushed to the background.</p><p class="Standard">If BASIC! is running in the foreground, but the Graphics or HTML screen is in the foreground, this command brings the Console to the foreground. BASIC! remains in Graphics or HTML mode.</p><h3 class="Heading_20_3"><a id="a__Console_line_count__count_nvar_"><span/></a><a id="_Toc5235935"/>Console.line.count &lt;count_nvar&gt;</h3><p class="Standard">Sets the return variable &lt;count_nvar&gt; to the number of lines written to the Console. This command waits for any pending Console writes to complete before reporting the count.</p><h3 class="Heading_20_3"><a id="a__Console_line_text__line_nexp____text_svar_"><span/></a><a id="_Toc5235936"/>Console.line.text &lt;line_nexp&gt;, &lt;text_svar&gt;</h3><p class="Standard">The text of the specified line number of the Console is copied to the &lt;text_svar&gt;.</p><h3 class="Heading_20_3"><a id="a__Console_line_touched__line_nvar__{___press_lvar_}"><span/></a><a id="_Toc5235937"/>Console.line.touched &lt;line_nvar&gt; {, &lt;press_lvar&gt;}</h3><p class="Standard">After an <span class="T7">OnConsoleTouch</span> interrupt indicates the user has touched the console, this command returns information about the touch.</p><p class="Standard">The number of the line that the user touched is returned in the &lt;line_nvar&gt;.</p><p class="Standard">If the optional &lt;press_lvar&gt; is present, the type of user touch–a short tap or a long press–is returned in the &lt;press_lvar&gt;. Its value will be 0 (false) if the touch was a short tap. Its value will be 1 (true) if the touch was a long press.</p><h3 class="Heading_20_3"><a id="a__Console_save__filename_sexp_"><span/></a><a id="_Toc5235938"/>Console.save &lt;filename_sexp&gt;</h3><p class="Standard">The current contents of the Console is saved to the text file specified by the filename string expression.</p><h3 class="Heading_20_3"><a id="a__Console_title_{__title_sexp_}"><span/></a><a id="_Toc5235939"/>Console.title { &lt;title_sexp&gt;}</h3><p class="Standard">Changes the title of the console window. If the &lt;title_sexp&gt; parameter is omitted, the title is changed to the default title, "BASIC! Program Output".</p><h2 class="Heading_20_2"><a id="a__User_Input_and_Interaction"><span/></a><a id="_Toc5235940"/>User Input and Interaction</h2><p class="Standard">This set of commands lets you interact with your programs.</p><p class="Standard">At the lowest level, you can use <span class="T7">Inkey$</span> to read raw keystrokes. You control display of the virtual keyboard with <span class="T7">Kb.hide</span>, <span class="T7">Kb.show</span>, and <span class="T7">Kb.toggle</span>.</p><p class="Standard">With the <span class="T7">Select</span> command you present information in a list format that looks very much like the Output Console. If you prefer, you can use <span class="T7">Dialog.Select</span> to present the same information in a new dialog window. Either way, when your program runs, you select an item from the list by tapping a line.</p><p class="Standard">The other commands in this group all pop up new windows.</p><p class="Standard"><span class="T7">Input</span> lets you type a number or a line of text as input to your program. <span class="T7">Dialog.message</span> presents a message with a set of buttons to let you tell your program what to do next.</p><p class="Standard"><span class="T7">Popup</span> is different. It presents information in a small, temporary display. It is not interactive and requires no management in your program. You pop it up and forget it.</p><p class="Standard">The last two commands in this group present another kind of dialog window. The <span class="T7">Text.input</span> command operates on larger blocks of text, and <span class="T7">TGet</span> simulates terminal I/O.</p><h3 class="Heading_20_3"><a id="a__Dialog_message_{_title_sexp_}__{_message_sexp_}___sel_nvar__{___button1_sexp_{___button2_sexp_{___button3_sexp_}}}"><span/></a><a id="_Toc5235941"/>Dialog.message {&lt;title_sexp&gt;}, {&lt;message_sexp&gt;}, &lt;sel_nvar&gt; {, &lt;button1_sexp&gt;{, &lt;button2_sexp&gt;{, &lt;button3_sexp&gt;}}}</h3><p class="Standard">Generates a dialog box with a title, a message, and up to three buttons. When the user taps a button, the number of the selected button is returned in &lt;sel_nvar&gt;. If the user taps the screen outside of the message dialog or presses the BACK key, then the returned value is 0.</p><p class="Standard">The string &lt;title_sexp&gt; becomes the title of the dialog box. The string &lt;message_sexp&gt; is displayed in the body of the dialog, above the buttons. The strings &lt;button1_sexp&gt;, &lt;button2_sexp&gt;, and &lt;button3_sexp&gt; provide the labels on the buttons.</p><p class="Standard">You may have 0, 1, 2, or 3 buttons. On most devices, the buttons are numbered from right-to-left, because Android style guides recommend the positive action on the right and the negative action on the left. Some devices differ. On compliant devices, tapping the right-most button returns 1.</p><p class="Standard">All of the parameters except the selection index variable &lt;sel_nvar&gt; are optional. If any parameter is omitted, the corresponding part of the message dialog is not displayed. Use commas to indicate omitted parameters (see Optional Parameters).</p><p class="Standard">Examples:</p><p class="Code_20_example"><span class="T11">Dialog.Message "Hey, you!", "Is this ok?", ok, "Sure thing!", "Don’t care", "No way!"</span></p><p class="Code_20_example"><span class="T11">Dialog.Message "Continue?", , go, "YES", "NO"</span></p><p class="Code_20_example"><span class="T11">Dialog.Message  , "Continue?", go, "YES", "NO"</span></p><p class="Code_20_example"><span class="T11">Dialog.Message  , , b</span></p><p class="Standard">The first command displays a full dialog with a title, a message, and three buttons.</p><p class="Standard">The second command displays a box with a title and two buttons – note that the <span class="T7">YES</span> button will be on the right and the <span class="T7">NO</span> button on the left. The third displays the same information, but it looks a little different because the text is displayed as the message and not as the title. Note the commas.</p><p class="Standard">The fourth command displays nothing at all. The screen dims and your program waits for a tap or the BACK key with no feedback to tell the user what to do.</p><h3 class="Heading_20_3"><a id="a__Dialog_select__sel_nvar____Array$___|_list_nexp__{__title_sexp_}"><span/></a><a id="_Toc5235942"/>Dialog.select &lt;sel_nvar&gt;, &lt;Array$[]&gt;|&lt;list_nexp&gt; {,&lt;title_sexp&gt;}</h3><p class="Standard">Generates a dialog box with a list of choices for the user. When the user taps a list item, the index of the selected line is returned in the &lt;sel_nvar&gt;. If the user taps the screen outside of the selection dialog or presses the BACK key, then the returned value is 0.</p><p class="Standard">&lt;Array$[]&gt; is a string array that holds the list of items to be selected. The array is specified without an index but must have been previously dimensioned or loaded via Array.load.</p><p class="Standard">As an alternative to an array, a string-type list may be specified in the &lt;list_nexp&gt;.</p><p class="Standard">The &lt;title_sexp&gt; is an optional string expression that will be displayed at the top of the selection dialog. If the parameter is not present, or the expression evaluates to an empty string (""), the dialog box will be displayed with no title.</p><p class="Standard">This command also accepts optional &lt;message_sexp&gt; and &lt;press_lvar&gt; parameters like those described in the <span class="T7">Select</span> command, but they should not be used. The &lt;message_sexp&gt; is ignored and the &lt;press_lvar&gt; will always be set to 0.</p><h3 class="Heading_20_3"><a id="a__Input_{_prompt_sexp_}___result_var_{__{_default_exp_}{___canceled_nvar_}}"><span/></a><a id="_Toc5235943"/>Input {&lt;prompt_sexp&gt;}, &lt;result_var&gt;{, {&lt;default_exp&gt;}{, &lt;canceled_nvar&gt;}}</h3><p class="Standard">Generates a dialog box with an input area and an <span class="T7">OK</span> button. When the user taps the button, the value in the input area is written to the variable &lt;result_var&gt;.</p><p class="Standard">The &lt;prompt_sexp&gt; will become the dialog box title. If the prompt expression is empty ("") or omitted, the dialog box will be drawn without a title area.</p><p class="Standard">If the return variable &lt;result_var&gt; is numeric, the input must be numeric, so the only key taps that will be accepted are 0-9, "+", "-" and ".". If &lt;result_var&gt; is a string variable, the input may be any string.</p><p class="Standard">If a &lt;default_exp&gt; is given then its value will be placed into the input area of the dialog box. The default expression type must match the &lt;result_var&gt; type.</p><p class="Standard">The variable &lt;canceled_nvar&gt; controls what happens if the user cancels the dialog, either by tapping the BACK key or by touching anywhere outside of the dialog box.</p><p class="Standard">If you provide a &lt;canceled_nvar&gt;, its value is set to <span class="T7">false</span> (0) if the user taps the <span class="T7">OK</span> button, and <span class="T7">true</span> (1) if the users cancels the dialog.</p><p class="Standard">If you do not provide a &lt;canceled_nvar&gt;, a canceled dialog is reported as an error. Unless there is an "OnError:" the user will see the messages:</p><p class="Code_20_example"><span class="T11">Input dialog cancelled</span></p><p class="Code_20_example"><span class="T11">Execution halted</span></p><p class="Standard">If there is an "OnError:" label, execution will resume at the statement following the label.</p><p class="Standard">The &lt;result_var&gt; parameter is required. All others are optional. These are all valid:</p><p class="Code_20_example"><span class="T11">INPUT "prompt", result$, "default", isCanceled</span></p><p class="Code_20_example"><span class="T11">INPUT , result$, "default"</span></p><p class="Code_20_example"><span class="T11">INPUT "prompt", result$, , isCanceled</span></p><p class="Code_20_example"><span class="T11">INPUT "prompt", result$</span></p><p class="Code_20_example"><span class="T11">INPUT , result$</span></p><p class="Standard">Note the use of commas as parameter placeholders (see Optional Parameters).</p><h3 class="Heading_20_3"><a id="a__Inkey$__svar_"><span/></a><a id="_Toc5235944"/>Inkey$ &lt;svar&gt;</h3><p class="Standard">Reports key taps for the a-z, 0-9, Space and the D-Pad keys. The key value is returned in &lt;svar&gt;.</p><p class="Standard">The D-Pad keys are reported as "up", "down", "left", "right" and "go". If any key other than those have been tapped, the string "key nn" will be returned. Where nn will be the Android key code for that key.</p><p class="Standard">If no key has been tapped, the "@" character is returned in &lt;svar&gt;.</p><p class="Standard">Rapid key taps are buffered in case they come faster than the BASIC! program can handle them.</p><h3 class="Heading_20_3"><a id="a__Popup__message_sexp__{{___x_nexp_}{___y_nexp_}{___duration_lexp_}}"><span/></a><a id="_Toc5235945"/>Popup &lt;message_sexp&gt; {{, &lt;x_nexp&gt;}{, &lt;y_nexp&gt;}{, &lt;duration_lexp&gt;}}</h3><p class="Standard">Pops up a small message for a limited duration. The message is &lt;message_sexp&gt;.</p><p class="Standard">All of the parameters except the message are optional. If omitted, their default values are 0. Use commas to indicate omitted parameters (see Optional Parameters).</p><p class="Standard">The simplest form of the <span class="T7">Popup</span> command, <span class="T7">Popup "Hello!"</span>, displays the message in the center of the screen for two seconds.</p><p class="Standard">The default location for the Popup is the center of the screen. The optional &lt;x_nexp&gt; and &lt;y_nexp&gt; parameters give a displacement from the center. The values may be negative.</p><p class="Standard">Select the duration of the Popup, either 2 seconds or 4 seconds, with the optional &lt;duration_lexp&gt; "long flag". If the flag is false (the expression evaluates to 0) the message is visible for 2 seconds. If the flag is true (non-zero) the message is visible for 4 seconds. If the flag is omitted the duration is short.</p><h3 class="Heading_20_3"><a id="a__Select__sel_nvar____Array$___|_list_nexp__{__title_sexp__{___message_sexp__}_}_{__press_lvar__}"><span/></a><a id="_Toc5235946"/>Select &lt;sel_nvar&gt;, &lt;Array$[]&gt;|&lt;list_nexp&gt; {,&lt;title_sexp&gt; {, &lt;message_sexp&gt; } } {,&lt;press_lvar&gt; }</h3><p class="Standard">The Select command generates a new screen with a list of choices for the user. When the user taps a screen line, the index of the selected line is returned in the &lt;sel_nvar&gt;. If the user presses the BACK key, then the returned value is 0.</p><p class="Standard">&lt;Array$[]&gt; is a string array that holds the list of items to be selected. The array is specified without an index but must have been previously dimensioned, loaded via Array.load, or created by another command.</p><p class="Standard">As an alternative to an array, a string-type list may be specified in the &lt;list_nexp&gt;.</p><p class="Standard">The &lt;title_sexp&gt; is an optional string expression that is placed into the title bar at the top of the selection screen. If the parameter is not present, the screen displays a default title. If the expression evaluates to an empty string ("") the title is blank.</p><p class="Standard">The &lt;message_sexp&gt; is an optional string expression that is displayed in a short Popup message. If the message is an empty string ("") there is no Popup. If the parameter is absent, the &lt;title_sexp&gt; string is used instead, but if the &lt;title_sexp&gt; is also missing or empty, there is no Popup.</p><p class="Standard">The &lt;press_lvar&gt; is optional. If present, the type of user tap—long or short—is returned in &lt;press_lvar&gt;. The value returned is 0 (false) if the user selected the item with a short tap. The value returned is 1 (true) if the user selected the item with a long press.</p><p class="Standard">Use commas to indicate omitted optional parameters (see Optional Parameters).</p><h3 class="Heading_20_3"><a id="a__Text_input__svar_{__{__text_sexp_}____title_sexp__}"><span/></a><a id="_Toc5235947"/><span class="T6">Text.input &lt;svar&gt;{, { &lt;text_sexp&gt;} , &lt;title_sexp&gt; }</span></h3><p class="Standard">This command is similar to "Input" except that it is used to input and/or edit a large quantity of text. It opens a new window with scroll bars and full text editing capabilities. You may set the title of the new window with the optional &lt;title_sexp&gt; parameter.</p><p class="Standard">If the optional &lt;text_sexp&gt; is present then that text is loaded into the text input window for editing. If &lt;text_sexp&gt; is not present then the text.input text area will be empty. If &lt;title_sexp&gt; is needed but text.input text area is to be initially empty, use two commas to indicate the &lt;sexp&gt; specifies the title and not the initial text.</p><p class="Standard">When done editing, tap the Finish button. The edited text is returned in &lt;svar&gt;.</p><p class="Standard">If you tap the BACK key then all text editing is discarded. &lt;svar&gt; returns the original &lt;sexp&gt; text.</p><p class="Standard">The following example grabs the Sample Program file, <span class="T7">f01_commands.bas</span>, to string s$. It then sends s$ to text.input for editing. The result of the edit is returned in string r$. r$ is then printed to console.</p><p class="Code_20_example"><span class="T11">GRABFILE s$, "../source/ Sample_Programs/f01_commands.bas"</span></p><p class="Code_20_example"><span class="T11">TEXT.INPUT r$,s$</span></p><p class="Code_20_example"><span class="T11">PRINT r$</span></p><p class="Code_20_example"><span class="T11">END</span></p><h3 class="Heading_20_3"><a id="a__TGet__result_svar____prompt_sexp__{___title_sexp_}"><span/></a><a id="_Toc5235948"/>TGet &lt;result_svar&gt;, &lt;prompt_sexp&gt; {, &lt;title_sexp&gt;}</h3><p class="Standard">Simulates a terminal. The current contents of the Output Console is displayed in a new window. The last line displayed starts with the prompt string followed by the cursor. The user types in the input and taps enter. The characters that the user typed in is returned in &lt;result_svar&gt;. The prompt and response are displayed on the Output Console.</p><p class="Standard">You may set the title of the text input window with the optional &lt;title_sexp&gt; parameter.</p><h3 class="Heading_20_3"><a id="a__Kb_hide"><span/></a><a id="_Toc5235949"/>Kb.hide</h3><p class="Standard">Hides the soft keyboard.</p><p class="Standard">If the keyboard is showing, and you have an <span class="T7">OnKbChange:</span> interrupt label, BASIC! will jump to your interrupt label when the keyboard closes.</p><p class="Standard">The soft keyboard is always hidden when your program starts running, regardless of whether it is showing in the Editor.</p><p class="Standard">Note: BASIC! automatically hides the soft keyboard when you change screens. For example, if the keyboard is showing over the Output Console, and you execute <span class="T7">Gr.open</span> to start Graphics Mode, the keyboard is hidden. The keyboard will not be showing when you exit Graphics Mode and return to the Console. Similarly, if you show the keyboard over your Graphics screen and you execute <span class="T7">Gr.close</span> to return to the Console, the keyboard is hidden.</p><p class="Standard">If you have an <span class="T7">OnKbChange:</span> interrupt label, automatically hiding the keyboard does <span class="T7">not</span> trigger a jump to the interrupt label.</p><h3 class="Heading_20_3"><a id="a__Kb_show"><span/></a><a id="_Toc5235950"/>Kb.show</h3><p class="Standard">Shows the soft keyboard.</p><p class="Standard">If the keyboard is not showing, and you have an <span class="T7">OnKbChange:</span> interrupt label, BASIC! will jump to your interrupt label when the keyboard opens.</p><p class="Standard">When the soft keyboard is showing, its keys may be read using the <span class="T7">Inkey$</span> command. The command may not work in devices with hard or slide-out keyboards.</p><p class="Standard">You cannot show the soft keyboard over the Output Console unless you first <span class="T7">Print</span> to the Console.</p><h3 class="Heading_20_3"><a id="a__Kb_toggle"><span/></a><a id="_Toc5235951"/>Kb.toggle</h3><p class="Standard">Toggles the showing or hiding of the soft keyboard. If the keyboard is being shown, it will be hidden. If it is hidden, it will be shown.</p><h3 class="Heading_20_3"><a id="a__Kb_showing__lvar_"><span/></a><a id="_Toc5235952"/>Kb.showing &lt;lvar&gt;</h3><p class="Standard">Reports the visibility of the soft keyboard. If the keyboard is showing, the &lt;lvar&gt; is set to 1.0 (true), otherwise the &lt;lvar&gt; is set to 0.0 (false).</p><p class="Standard">This command reports only the status of the keyboard shown by <span class="T7">Kb.show</span>. For example, the keyboard attached to the <span class="T7">Input</span> command dialog box cannot be controlled by <span class="T7">Kb.show</span> or <span class="T7">Kb.hide</span> and its status is not reported by <span class="T7">Kb.showing</span>.</p><h3 class="Heading_20_3"><a id="a__OnKbChange_"><span/></a><a id="_Toc5235953"/>OnKbChange:</h3><p class="Standard">If you show a soft keyboard with <span class="T7">Kb.show</span>, or close that same keyboard with <span class="T7">Kb.hide</span> or by tapping the BACK key, the change takes some time. The keyboard may open or close a few hundred milliseconds after it is requested. <span class="T7">Kb.show</span> and <span class="T7">Kb.hide</span> block until the change is complete, but your program does not know when you tap the BACK key.</p><p class="Standard">If you have an <span class="T7">OnKbChange:</span> interrupt label in your program, then when the keyboard changes as just described, BASIC! interrupts your program and executes the statements after the interrupt label.</p><p class="Standard">To return control to where the interrupt occurred, execute <span class="T7">Kb.resume</span> in your interrupt handler.</p><p class="Standard">This interrupt occurs only for keyboards you show with <span class="T7">Kb.show</span>. Keyboards attached to other screens, such as <span class="T7">TGet</span> or the <span class="T7">Input</span> dialog box, do not cause <span class="T7">OnKbChange:</span> interrupts.</p><h3 class="Heading_20_3"><a id="a__Kb_resume"><span/></a><a id="_Toc5235954"/>Kb.resume</h3><p class="Standard">Resume program execution at the point where the <span class="T7">OnKbChange:</span> interrupt occurred.</p><p class="Standard">When an interrupt occurs, no other interrupt can occur (except <span class="T7">OnError:</span>) until the corresponding <span class="T7">resume</span> executes.</p><h3 class="Heading_20_3"><a id="a__The_Soft_Keyboard_and_the_BACK_Key"><span/></a><a id="_Toc5235955"/>The Soft Keyboard and the BACK Key</h3><p class="Standard">If you show a soft keyboard with <span class="T7">Kb.show</span>, and you tap the BACK key, the keyboard closes. The current screen (Console or Graphics screen) does not close. BASIC! does not trap the keypress with either <span class="T7">OnBackKey:</span> or <span class="T7">OnKeyPress:</span>. You can use the <span class="T7">OnKbChange:</span> interrupt label to be notified that the keyboard closed.</p><h1 class="Heading_20_1"><a id="a__Working_with_Files"><span/></a><a id="_Toc5235956"/>Working with Files</h1><p class="Standard">Android devices may have several file storage devices. BASIC! uses one of these devices as its <span class="T18">base drive</span>. You can select a different base drive in the <span class="T18">Menu-&gt;Preferences</span> item <span class="T24">Base Drive</span>. In this manual, the notation <span class="T7">&lt;pref base drive&gt;</span> refers to the base drive you selected in Preferences.</p><p class="Standard">BASIC! can work with files anywhere on the base drive, but most file operations are done in BASIC!’s <span class="T18">base directory</span>. Except when you create a standalone apk file (see Appendix D), the base directory is <span class="T7">&lt;pref base drive&gt;/rfo-basic</span>. All file paths are relative to a subdirectory of the base directory.</p><h2 class="Heading_20_2"><a id="a__Paths_Explained___a_beginner’s_guide"><span/></a><a id="_Toc5235957"/>Paths Explained – a beginner’s guide</h2><p class="Standard">A path describes where a file or directory is located relative to another directory.</p><div class="Standard">A file is a container for data. A directory is a container for files and other directories.<span class="Footnote_20_anchor" title="Footnote: This container is called a &quot;directory&quot; because it is a listing of the items it contains. You can also call it a &quot;folder&quot;, and you can say &quot;a folder is a container for files and other folders.&quot; Both expressions mean the same thing."><a href="#ftn1" id="body_ftn1">1</a></span> A directory that is in a directory may have other directories in it, and those directories may contain other directories, and so on. This results in a "tree" of directories and files, called a <span class="T18">file system</span>. A file system organizes data on a storage device, such as a disk or a memory card.</div><p class="Standard"><span class="T7">Absolute paths:</span> A path that is relative to the root directory is called an <span class="T18">absolute path</span>. For example, the absolute path to pictures you take with an Android camera may be "/sdcard/DCIM/Camera". In BASIC!, the <span class="T18">base directory</span> is not a <span class="T18">root directory</span>, so <span class="T18">BASIC! does not use absolute paths</span>.</p><p class="Standard"><span class="T7">Relative paths:</span> A path that is relative to anything except the root directory is called a <span class="T18">relative path</span>. Starting from "/sdcard", the relative path down to Camera is "DCIM/Camera". Use the "../" path notation to go back up:  from Camera, the path to "/sdcard/DCIM" is ".." and to "/sdcard" is "../.." .</p><p class="Standard">The relative path from "/sdcard/DCIM/Camera" to "/sdcard/DCIM/.thumbnails" is "../.thumbnails". With this notation, you can reach any file in the file system.</p><p class="Standard">All paths in BASIC! are relative to a default path that depends on the kind of data you want to use. These default paths are explained in the next section.</p><h2 class="Heading_20_2"><a id="a__Paths_in_BASIC!"><span/></a><a id="_Toc5235958"/>Paths in BASIC!</h2><p class="Standard">BASIC! files are stored in subdirectories of the base directory, "&lt;pref base drive&gt;/rfo-basic/". Files are grouped by type, as follows:</p><ul><li><p class="P74" style="margin-left:1.27cm;"><span class="ListLabel_20_137" style="display:block;float:left;min-width:0.635cm;"></span>BASIC! program files are in <span class="T7">rfo-basic/source/</span><span class="odfLiEnd"/> </p></li><li><p class="P74" style="margin-left:1.27cm;"><span class="ListLabel_20_137" style="display:block;float:left;min-width:0.635cm;"></span>BASIC! data files are in <span class="T7">rfo-basic/data/</span><span class="odfLiEnd"/> </p></li><li><p class="P74" style="margin-left:1.27cm;"><span class="ListLabel_20_137" style="display:block;float:left;min-width:0.635cm;"></span>BASIC! SQLite databases are in <span class="T7">rfo-basic/databases/</span><span class="odfLiEnd"/> </p></li></ul><p class="P109"> </p><p class="Standard">All of the BASIC! file commands assume a certain default path. The default path depends on the type of file each command expects to handle:</p><ul><li><p class="P35" style="margin-left:1.27cm;"><span class="ListLabel_20_141" style="display:block;float:left;min-width:0.635cm;"></span>The <span class="T7">Include</span> and <span class="T7">Run</span> commands expect to load program files, so they look in <span class="T7">rfo-basic/source/</span>.<span class="odfLiEnd"/> </p></li><li><p class="P35" style="margin-left:1.27cm;"><span class="ListLabel_20_141" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">SQLite</span> operations look for database files in <span class="T7">rfo-basic/databases/</span>.<span class="odfLiEnd"/> </p></li><li><p class="P35" style="margin-left:1.27cm;"><span class="ListLabel_20_141" style="display:block;float:left;min-width:0.635cm;"></span>All other file operations look for data files in <span class="T7">rfo-basic/data/</span>.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">If you give a filename to a file command, it looks for that filename in the default directory for commands of that type. If you want to work with a file that is not in that directory, you must specify a relative path to the appropriate directory. BASIC! adds your path to the default path.</p><ul><li><p class="P84" style="margin-left:1.27cm;"><span class="ListLabel_20_22" style="display:block;float:left;min-width:0.635cm;"></span>To read the file "names.txt" in "rfo-basic/data/", the path is "names.txt".<span class="odfLiEnd"/> </p></li><li><p class="P84" style="margin-left:1.27cm;"><span class="ListLabel_20_22" style="display:block;float:left;min-width:0.635cm;"></span>To read the program file "sines.bas" in "rfo-basic/source", the path is "../source/sines.bas".<span class="odfLiEnd"/> </p></li></ul><h2 class="Heading_20_2"><a id="a__Paths_Outside_of_BASIC!"><span/></a><a id="_Toc5235959"/>Paths Outside of BASIC!</h2><p class="Standard">BASIC! runs on an Android device, and its files are part of the Android file system.</p><p class="Standard">You can use relative paths to access files outside of the base directory. To continue the example from the previous section, assume the absolute Android path to the &lt;pref base drive&gt; is "/sdcard":</p><ul><li><p class="P36" style="margin-left:1.27cm;"><span class="ListLabel_20_145" style="display:block;float:left;min-width:0.635cm;"></span>To read the music file "rain.mp3" in "/sdcard/music/", the BASIC! path is "../../music/rain.mp3". The path is relative to the default directory for general data "&lt;pref base drive&gt;/rfo-basic/data/".<span class="odfLiEnd"/> </p></li></ul><p class="Standard">Use care when writing paths that look up from the &lt;pref base drive&gt;. The directory name may not be what you expect, and it may not be the same on all Android devices.</p><p class="Standard">Every file on an Android device has an absolute path. Unfortunately, on most Android devices every file has several absolute paths. The default &lt;pref base drive&gt; can be reached with the absolute Android path "/sdcard". The name "sdcard" is a shortcut (a <span class="T18">symbolic link</span>) that means different things on different devices. "&lt;pref base drive&gt;/rfo-basic/../" may not get to the Android directory "/sdcard", but to something like "/storage/emulated/legacy".</p><p class="Standard">You can use the command <span class="T7">File.root</span> to get the absolute Android path to the BASIC! &lt;pref base drive&gt;.</p><h2 class="Heading_20_2"><a id="a__Paths_and_Case-sensitivity"><span/></a><a id="_Toc5235960"/>Paths and Case-sensitivity</h2><p class="Standard">While the Android file system is normally case-sensitive. However, the FAT file system, often used on SD cards, memory sticks, etc., is case-insensitive. When handling files on these devices, Android – and therefore BASIC! – can not differentiate between names that differ only in case. In your BASIC! program, the two paths "../../music/rain.mp3" and "../../MUSIC/Rain.MP3" will both access the same file.</p><p class="Standard">The rules change if you compile the same BASIC! program into a standalone apk (see Appendix D). The file system inside the apk is case-sensitive. The paths "../../music/rain.mp3" and"../../MUSIC/Rain.MP3" access different files. If the actual path in your build project is "Assets/&lt;project&gt;/MUSIC/Rain.MP3", then using the second path would succeed, but the first path would fail.</p><p class="Standard">To prevent any error, it is good practice to match case exactly in file paths and names.</p><h2 class="Heading_20_2"><a id="a__Mark_and_Mark_Limit"><span/></a><a id="_Toc5235961"/>Mark and Mark Limit</h2><p class="Standard"><span class="T7">Note</span>: This is an advanced file management technique that you will rarely need to use. However, see the note below about Out of Memory errors when reading very large files.</p><p class="Standard">Every file has a mark and a mark limit. The mark is a position, and the mark limit is a size. As you read a file, its data is copied into a buffer. The buffer starts at the mark, and its length is the mark limit. BASIC! uses the buffer to allow you to reposition within the file. You are really repositioning within the buffer.</p><p class="Standard">If you do not mark a file, then the first time you read it or set a position in it, the mark is set at position 1 and the mark limit is set to the size of the file. This allows you to position and read anywhere in the file.</p><p class="Standard">The <span class="T7">Text.position.mark</span> and <span class="T7">Byte.position.mark</span> commands override the default mark and mark limit. You can change the mark and mark limit as often as you like, but there is only one mark in a file.</p><p class="Standard">You cannot set a position before the mark. If you try, the file will be positioned at the mark. You will not be notified that the current position is different from what you requested, but you can use <span class="T7">Text/Byte.position.get</span> to determine the real position. Since the default mark position is 1, you can position anywhere if you never set a mark.</p><p class="Standard">You cannot make the buffer smaller. If you want the buffer to be smaller than the file, you must execute <span class="T7">Text/Byte.position.mark</span> before reading the file or setting a position. The smallest buffer size available is 8096 bytes, but it is not an error to specify a smaller number. Since the default mark limit is the file size, you can position anywhere if you never set a mark limit.</p><p class="Standard">If you read or position past the end of the buffer (more than <span class="T7">marklimit</span> bytes beyond the the mark), the mark is invalid. It is an error to try to move the position backward when the mark is invalid. You will see the error message "<span class="T7">Invalid mark</span>". Since the default buffer is the whole file, you will never see this error if you never set a mark.</p><p class="Standard">There is only one condition that requires you to use this command. <span class="T7">If you open a very large file, the default buffer size may be too large.</span> Reading or positioning to the end of the file may cause an <span class="T7">Out Of Memory</span> error. To avoid this error, your must use <span class="T7">Text.position.mark</span> to reduce the buffer size.</p><h1 class="Heading_20_1"><a id="a__File_Commands"><span/></a><a id="_Toc5235962"/>File Commands</h1><h2 class="Heading_20_2"><a id="a__File_delete__lvar____path_sexp_"><span/></a><a id="_Toc5235963"/>File.delete &lt;lvar&gt;, &lt;path_sexp&gt;</h2><p class="Standard">The file or directory at &lt;path_sexp&gt; will be deleted, if it exists. If the file or directory did not exist before the Delete, the &lt;lvar&gt; will contain zero. If the file or directory did exist and was deleted, the &lt;lvar&gt; will be returned as not zero.</p><p class="Standard">The default path is "&lt;pref base drive&gt;/rfo-basic/data/".</p><h2 class="Heading_20_2"><a id="a__File_dir__path_sexp___Array$___{__dirmark_sexp_}"><span/></a><a id="_Toc5235964"/>File.dir &lt;path_sexp&gt;, Array$[] {,&lt;dirmark_sexp&gt;}</h2><p class="Standard">Returns the names of the files and directories in the path specified by &lt;path_sexp&gt;. The path is relative to "&lt;pref base drive&gt;/rfo-basic/data/".</p><p class="Standard">The names are placed into Array$[]. The array is sorted alphabetically with the directories at the top of the list. If the array exists, it is overwritten, otherwise a new array is created. The result is always a one-dimensional array.</p><p class="Standard">A directory is identified by a marker appended to its name. The default marker is the string "(d)". You can change the marker with the optional directory mark parameter &lt;dirmark_sexp&gt;. If you do not want directories to be marked, set &lt;dirmark_sexp&gt; to an empty string, "".</p><p class="Standard"><span class="T7">Dir</span> is a valid alias for this command.</p><h2 class="Heading_20_2"><a id="a__File_exists__lvar____path_sexp_"><span/></a><a id="_Toc5235965"/>File.exists &lt;lvar&gt;, &lt;path_sexp&gt;</h2><p class="Standard">Reports if the &lt;path_sexp&gt; directory or file exists. If the directory or file does not exist, the &lt;lvar&gt; will contain zero. If the file or directory does exist, the &lt;lvar&gt; will be returned as not zero.</p><p class="Standard">The default path is "&lt;pref base drive&gt;/rfo-basic/data/".</p><h2 class="Heading_20_2"><a id="a__File_mkdir__path_sexp_"><span/></a><a id="_Toc5235966"/>File.mkdir &lt;path_sexp&gt;</h2><p class="Standard">Before you can use a directory, the directory must exist. Use this command to create a directory named by the path string &lt;path_sexp&gt;.</p><p class="P109">The new directory is created relative to the default directory "&lt;pref base drive&gt;/rfo-basic/data/". For example:</p><ul><li><p class="P37" style="margin-left:1.27cm;"><span class="ListLabel_20_69" style="display:block;float:left;min-width:0.635cm;"></span>To create a new directory, "homes", in "&lt;pref base drive&gt;/rfo_basic/data/", use the path "homes/", or simply "homes".<span class="odfLiEnd"/> </p></li><li><p class="P37" style="margin-left:1.27cm;"><span class="ListLabel_20_69" style="display:block;float:left;min-width:0.635cm;"></span>To create a new directory, "icons", in the root directory of the SD card, use "../../icons".<span class="odfLiEnd"/> </p></li></ul><p class="Standard"><span class="T7">Mkdir</span> is a valid alias for this command.</p><h2 class="Heading_20_2"><a id="a__File_rename__old_path_sexp____new_path_sexp_"><span/></a><a id="_Toc5235967"/>File.rename &lt;old_path_sexp&gt;, &lt;new_path_sexp&gt;</h2><p class="Standard">The file or directory at old_path is renamed to new_path. If there is already a file present named &lt;new_path_sexp&gt;, it is silently replaced.</p><p class="Standard">The default path is "&lt;pref base drive&gt;/rfo-basic/data/".</p><p class="Standard">The rename operation can not only change the name of a file or a directory, it can also move the file or directory to another directory.</p><p class="Standard">For example:</p><p class="Code_20_example"><span class="T11">Rename "../../testfile.txt", "testfile1.txt"</span></p><p class="Standard">removes the file, testfile.txt, from "&lt;pref base drive&gt;/", places it into "sdcard/rfo-basic/data/" and also renames it to testfile1.txt.</p><p class="Standard"><span class="T7">Rename</span> is a valid alias for this command.</p><h2 class="Heading_20_2"><a id="a__File_root__svar_"><span/></a><a id="_Toc5235968"/>File.root &lt;svar&gt;</h2><p class="Standard">Returns the canonical path from the file system root to "&lt;pref base drive&gt;/rfo-basic/data", the default data directory, in &lt;svar&gt;. The &lt;pref base drive&gt; is expanded to the full absolute Android path from the file system root, "/".</p><p class="Standard">You cannot use this path in any BASIC! command, as BASIC! paths are relative to a command-dependent default directory. However, you can use it to compute a relative path to parts of the Android file system outside of the BASIC! &lt;pref base drive&gt;.</p><h2 class="Heading_20_2"><a id="a__File_size__size_nvar____path_sexp_"><span/></a><a id="_Toc5235969"/>File.size &lt;size_nvar&gt;, &lt;path_sexp&gt;</h2><p class="Standard">The size, in bytes, of the file at &lt;path_sexp&gt; is returned in &lt;size_nvar&gt;. If there is no file at &lt;path_sexp&gt;, this command generates a run-time error.</p><p class="Standard">The &lt;path_sexp&gt; is appended to the default path, "&lt;pref base drive&gt;/rfo-basic/data/".</p><h2 class="Heading_20_2"><a id="a__File_type__type_svar____path_sexp_"><span/></a><a id="_Toc5235970"/>File.type &lt;type_svar&gt;, &lt;path_sexp&gt;</h2><p class="Standard">Returns a one-character type indicator in &lt;type_svar&gt; for the file at &lt;path_sexp&gt;. The &lt;path_sexp&gt; is appended to the default data path, "&lt;pref base drive&gt;/rfo-basic/data/". The type indicator values are:</p><table border="0" cellspacing="0" cellpadding="0" class="Table14"><colgroup><col width="138"/><col width="324"/></colgroup><tr class="Table141"><td style="text-align:left;width:3.168cm; " class="Table14_A1"><p class="P120">Indicator:</p></td><td style="text-align:left;width:7.412cm; " class="Table14_A1"><p class="P120">Meaning:</p></td></tr><tr class="Table141"><td style="text-align:left;width:3.168cm; " class="Table14_A1"><p class="P110">"d"</p></td><td style="text-align:left;width:7.412cm; " class="Table14_A1"><p class="P110">"directory" – path names a directory</p></td></tr><tr class="Table141"><td style="text-align:left;width:3.168cm; " class="Table14_A1"><p class="P110">"f"</p></td><td style="text-align:left;width:7.412cm; " class="Table14_A1"><p class="P110">"file" – path names a regular file</p></td></tr><tr class="Table141"><td style="text-align:left;width:3.168cm; " class="Table14_A1"><p class="P110">"o"</p></td><td style="text-align:left;width:7.412cm; " class="Table14_A1"><p class="P110">"other" – path names a special file</p></td></tr><tr class="Table141"><td style="text-align:left;width:3.168cm; " class="Table14_A1"><p class="P110">"x"</p></td><td style="text-align:left;width:7.412cm; " class="Table14_A1"><p class="P110">file does not exist</p></td></tr></table><h1 class="Heading_20_1"><a id="a__Text_File_I_O"><span/></a><a id="_Toc5235971"/>Text File I/O</h1><p class="Standard">The text file I/O commands are to be exclusively used for text (.txt) files. Text files are made up of lines of characters that end in CR (Carriage Return) and/or NL (New Line). The text file input and output commands read and write entire lines.</p><p class="Standard">The default path is "&lt;pref base drive&gt;/rfo-basic/data/"</p><h2 class="Heading_20_2"><a id="a__Text_open_{r|w|a}___file_table_nvar____path_sexp_"><span/></a><a id="_Toc5235972"/>Text.open {r|w|a}, &lt;file_table_nvar&gt;, &lt;path_sexp&gt;</h2><p class="Standard">The file specified by the path string expression &lt;path_sexp&gt; is opened. The default path is "&lt;pref base drive&gt;/rfo-basic/data/". The &lt;path_sexp&gt; string is appended to the default path.</p><p class="Standard">The first parameter is a single character that sets the I/O mode for this file:</p><table border="0" cellspacing="0" cellpadding="0" class="Table15"><colgroup><col width="104"/><col width="76"/><col width="536"/></colgroup><tr class="Table151"><td style="text-align:left;width:2.379cm; " class="Table15_A1"><p class="P120">Parameter</p></td><td style="text-align:left;width:1.746cm; " class="Table15_A1"><p class="P120">Mode</p></td><td style="text-align:left;width:12.257cm; " class="Table15_A1"><p class="P120">Notes</p></td></tr><tr class="Table151"><td style="text-align:left;width:2.379cm; " class="Table15_A1"><p class="P110">r</p></td><td style="text-align:left;width:1.746cm; " class="Table15_A1"><p class="P110">read</p></td><td style="text-align:left;width:12.257cm; " class="Table15_A1"><p class="P114">File exists: Reads from the start of the file.<br/>File does not exist: Error (see below).</p></td></tr><tr class="Table151"><td style="text-align:left;width:2.379cm; " class="Table15_A1"><p class="P110">w</p></td><td style="text-align:left;width:1.746cm; " class="Table15_A1"><p class="P110">write</p></td><td style="text-align:left;width:12.257cm; " class="Table15_A1"><p class="P114">File exists: Writes from the start of the file. Writes over any existing data.<br/>File does not exist: Creates a new file. Writes from the start of the file.</p></td></tr><tr class="Table151"><td style="text-align:left;width:2.379cm; " class="Table15_A1"><p class="P110">a</p></td><td style="text-align:left;width:1.746cm; " class="Table15_A1"><p class="P110">append</p></td><td style="text-align:left;width:12.257cm; " class="Table15_A1"><p class="P114">File exists: Writing starts after the last line in the file.<br/>File does not exist: Creates a new file. Writes from the start of the file.</p></td></tr></table><p class="P108">A file table number is placed into the numeric variable &lt;file_table_nvar&gt;. This value is for use in subsequent <span class="T7">Text.readln</span>, <span class="T7">Text.writeln</span>, <span class="T7">Text.eof</span>, <span class="T7">Text.position.*</span>, or <span class="T7">Text.close</span> commands.</p><p class="Standard">If a file being opened for read does not exist then the &lt;file_table_nvar&gt; will be set to -1. The BASIC! programmer can check for this and either create the file or report the error to the user. Information about the error is available from the <span class="T7">GETERROR$()</span> function.</p><p class="Standard">Opening a file for append that does not exist creates an empty file. Finally, opening a file for write that already exists deletes the contents of the file; that is, it replaces the existing file with a new, empty one.</p><h2 class="Heading_20_2"><a id="a__Text_close__file_table_nexp_"><span/></a><a id="_Toc5235973"/>Text.close &lt;file_table_nexp&gt;</h2><p class="Standard">The previously opened file represented by &lt;file_table_nexp&gt; will be closed.</p><p class="Standard">Note: It is essential to close an output file if you have written over 8k bytes to it. If you do not close the file then the file will only contain the first 8k bytes.</p><h2 class="Heading_20_2"><a id="a__Text_readln__file_table_nexp__{__svar_}___"><span/></a><a id="_Toc5235974"/>Text.readln &lt;file_table_nexp&gt; {,&lt;svar&gt;}...</h2><p class="Standard">Read the lines from the specified, previously opened file and write them into the &lt;svar&gt; parameter(s). If &lt;file_table_nexp&gt; is -1, indicating <span class="T7">Text.open</span> failed, or if it is not a valid file table number, then the command throws a run-time error.</p><p class="Standard">After the last line in the file has been read, further attempts to read from the file place the characters "EOF" into the &lt;line_svar&gt; parameter(s). This is indistinguishable from the string "EOF" read as actual data, except that the result of the <span class="T7">Text.eof</span> command will be false after reading real data and true after reading at end-of-file (EOF).</p><p class="Standard">This example reads an entire file and prints each line.</p><p class="Code_20_example"><span class="T11">TEXT.OPEN r, file_number, "testfile.txt"</span></p><p class="Code_20_example"><span class="T11">DO</span></p><p class="Code_20_example"><span class="T11">  TEXT.READLN file_number, line$</span></p><p class="Code_20_example"><span class="T11">  PRINT line$</span></p><p class="Code_20_example"><span class="T11">UNTIL line$ = "EOF"</span></p><p class="Code_20_example"><span class="T11">TEXT.CLOSE file_number</span></p><p class="Standard">The file will not automatically be closed when the end-of-file is read. Subsequent reads from the file will continue to return "EOF".</p><p class="Standard">When you are done reading a file, the <span class="T7">Text.close</span> command should be used to close the file.</p><h2 class="Heading_20_2"><a id="a__Text_writeln__file_table_nexp____parms_same_as_Print_"><span/></a><a id="_Toc5235975"/>Text.writeln &lt;file_table_nexp&gt;, &lt;parms same as Print&gt;</h2><p class="Standard">The parameters that follow the file table pointer are parsed and processed exactly the same as the <span class="T7">Print</span> command parameters. This command is essentially a <span class="T7">Print</span> to a file.</p><p class="Standard">If a parameter line ends with a semicolon, the data is not written to the file. It is stored in a temporary buffer until the next <span class="T7">Text.writeln</span> command that does not end in a semicolon. There is only one temporary buffer no matter how many files you have open. If you want to build partial print lines for more than one file at a time, do not use <span class="T7">Text.writeln</span> commands ending with semicolons. Instead use string variables to store the temporary results.</p><p class="Standard">After the last line has been written to the file, the <span class="T7">Text.close</span> command should be used to close the file.</p><p class="Standard"><span class="T7">Text.writeln</span> with no parameters writes a newline.</p><h2 class="Heading_20_2"><a id="a__Text_eof__file_table_nexp____lvar_"><span/></a><a id="_Toc5235976"/>Text.eof &lt;file_table_nexp&gt;, &lt;lvar&gt;</h2><p class="Standard">Report an opened file’s end-of-file status. If the file is at EOF, the &lt;lvar&gt; is set true (non-zero). If the file or directory is not at EOF, the &lt;lvar&gt; is set false (zero).</p><p class="Standard">A file opened for write or append is always at EOF. A file opened for read is not at EOF until all of the data has been read and then one more read is attempted. That read will have returned the string "EOF". <span class="T7">Text.position.set</span> may also position the file at EOF.</p><h2 class="Heading_20_2"><a id="a__Text_position_get__file_table_nexp____position_nvar_"><span/></a><a id="_Toc5235977"/>Text.position.get &lt;file_table_nexp&gt;, &lt;position_nvar&gt;</h2><p class="Standard">Get the position of the next line to be read or written to the file. The position of the first line in the file is 1. The position is incremented by one for each line read or written. The position information can be used for setting up random file data access.</p><p class="Standard">Note: If a file is opened for append, the position returned will be relative to the end of the file. The position returned for the first line to be written after a file is opened for append will be 1. You will have to add these new positions to the known position of the end of the file when building your random access table.</p><h2 class="Heading_20_2"><a id="a__Text_position_set__file_table_nexp____position_nexp_"><span/></a><a id="_Toc5235978"/>Text.position.set &lt;file_table_nexp&gt;, &lt;position_nexp&gt;</h2><p class="Standard">Sets the position of the next line to read. A position value of 1 will read the first line in the file.</p><p class="Standard">Text.position.set can only be used for files open for text reading.</p><p class="Standard">If the position value is greater than the number of lines in the file, the file will be positioned at the end of file. The position returned for Text.position.get at the EOF will be number of lines plus one in the file.</p><p class="Standard">If you have marked a position in the file, you cannot set a position before the mark. You will not be notified that the position is different from what you requested. See <span class="T7">Text.position.mark</span> for more information.</p><h2 class="Heading_20_2"><a id="a__Text_position_mark_{{_file_table_nexp_}{___marklimit_nexp_}}"><span/></a><a id="_Toc5235979"/>Text.position.mark {{&lt;file_table_nexp&gt;}{, &lt;marklimit_nexp&gt;}}</h2><p class="Standard">Marks the current line of the file, and sets the mark limit to &lt;marklimit_nexp&gt; bytes.</p><p class="Standard">Both parameters are optional. If the file table index &lt;file_table_nexp&gt; is omitted, the default file is the last file opened; you must ensure that the last file opened was a <span class="T7">Text</span> file opened for reading. If the mark limit &lt;marklimit_exp&gt; is omitted, the default value is the file’s current mark limit.</p><p class="Standard">Please read <span class="T7">Working with Files </span><span class="T25"></span><span class="T7"> Mark and Mark Limit</span>, above.</p><h2 class="Heading_20_2"><a id="a__GrabURL__result_svar____url_sexp_{___timeout_nexp_}"><span/></a><a id="_Toc5235980"/>GrabURL &lt;result_svar&gt;, &lt;url_sexp&gt;{, &lt;timeout_nexp&gt;}</h2><p class="Standard">Copies the entire source text of the URL &lt;url_sexp&gt; to the string variable &lt;result_svar&gt;. The URL may specify an Internet resource or a local file. If the URL does not exist or the data cannot be read, the &lt;result_svar&gt; is set to the empty string, "", and you can use the <span class="T7">GETERROR$()</span> function to get more information.</p><p class="Standard">If the optional &lt;timeout_nexp&gt; parameter is non-zero, it specifies a timeout in milliseconds. This is meaningful only if the URL names a resource on a remote host. If the timeout time elapses and host does not connect or does not return any data, <span class="T7">GETERROR$</span> reports a socket timeout.</p><p class="Standard">If the named resource is empty, the &lt;result_svar&gt; is empty, "", and <span class="T7">GETERROR$()</span> returns "No error".</p><p class="Standard">The <span class="T7">Split</span> command can be used to split the &lt;result_svar&gt; into an array of lines.</p><h2 class="Heading_20_2"><a id="a__GrabFile__result_svar____path_sexp_{___unicode_flag_lexp_}"><span/></a><a id="_Toc5235981"/>GrabFile &lt;result_svar&gt;, &lt;path_sexp&gt;{, &lt;unicode_flag_lexp&gt;}</h2><p class="Standard">Copies the entire contents of the file at &lt;path_sexp&gt; to the string variable &lt;result_svar&gt;. By default, <span class="T7">GrabFile</span> assumes that the file contains binary bytes or ASCII characters. If the optional &lt;unicode_flag_lexp&gt; evaluates to true (a non-zero numeric value), <span class="T7">GrabFile</span> can read Unicode text.</p><p class="Standard">If the file does not exist or cannot be opened, the &lt;result_svar&gt; is set to the empty string, "", and you can use the <span class="T7">GETERROR$()</span> function to get more information. If the file is empty, the &lt;result_svar&gt; is an empty string, "", but <span class="T7">GETERROR$()</span> returns "No error".</p><p class="Standard">For text files, either ASCII or Unicode, the <span class="T7">Split</span> command can be used to split the &lt;result_svar&gt; into an array of lines. <span class="T7">GrabFile</span> can also be used grab the contents of a text file for direct use with <span class="T7">Text.input</span>:</p><p class="P7"><span class="T11">GRABFILE text$, "MyJournal.txt"</span></p><p class="Code_20_example"><span class="T11">TEXT.INPUT EditedText$, text$</span></p><h1 class="Heading_20_1"><a id="a__Byte_File_I_O"><span/></a><a id="_Toc5235982"/>Byte File I/O</h1><p class="Standard">Byte file I/O can be used to read and write any type of file (.txt, .jpg, .pdf, .mp3, etc.). Each command reads or writes one byte or a sequence of bytes as binary data.</p><h2 class="Heading_20_2"><a id="a__Byte_open_{r|w|a}___file_table_nvar____path_sexp_"><span/></a><a id="_Toc5235983"/>Byte.open {r|w|a}, &lt;file_table_nvar&gt;, &lt;path_sexp&gt;</h2><p class="Standard">The file specified by the path string expression &lt;path_sexp&gt; is opened. If the path is a URL starting with "http…" then an Internet file is opened. Otherwise, the &lt;path_sexp&gt; string is appended to the default path "&lt;pref base drive&gt;/rfo-basic/data/".</p><p class="Standard">The first parameter is a single character that sets the I/O mode for this file:</p><table border="0" cellspacing="0" cellpadding="0" class="Table16"><colgroup><col width="96"/><col width="82"/><col width="530"/></colgroup><tr class="Table161"><td style="text-align:left;width:2.194cm; " class="Table16_A1"><p class="P120">Parameter</p></td><td style="text-align:left;width:1.877cm; " class="Table16_A1"><p class="P120">Mode</p></td><td style="text-align:left;width:12.121cm; " class="Table16_A1"><p class="P120">Notes</p></td></tr><tr class="Table161"><td style="text-align:left;width:2.194cm; " class="Table16_A1"><p class="P110">r</p></td><td style="text-align:left;width:1.877cm; " class="Table16_A1"><p class="P110">read</p></td><td style="text-align:left;width:12.121cm; " class="Table16_A1"><p class="P114">File exists: Reads from the start of the file.<br/>File does not exist: Error (see below).</p></td></tr><tr class="Table161"><td style="text-align:left;width:2.194cm; " class="Table16_A1"><p class="P110">w</p></td><td style="text-align:left;width:1.877cm; " class="Table16_A1"><p class="P110">write</p></td><td style="text-align:left;width:12.121cm; " class="Table16_A1"><p class="P114">File exists: Writes from the start of the file. Writes over any existing data.<br/>File does not exist: Creates a new file. Writes from the start of the file.</p></td></tr><tr class="Table161"><td style="text-align:left;width:2.194cm; " class="Table16_A1"><p class="P110">a</p></td><td style="text-align:left;width:1.877cm; " class="Table16_A1"><p class="P110">append</p></td><td style="text-align:left;width:12.121cm; " class="Table16_A1"><p class="P114">File exists: Writing starts after the last line in the file.<br/>File does not exist: Creates a new file. Writes from the start of the file.</p></td></tr></table><p class="P108">A file table number is placed into the numeric variable &lt;file_table_nvar&gt;. This value is for use in subsequent <span class="T7">Byte.read.*</span>, <span class="T7">Byte.write</span>.*, <span class="T7">Byte.eof</span>, <span class="T7">Byte.position.*</span>, <span class="T7">Byte.truncate</span>, <span class="T7">Byte.copy</span>, or <span class="T7">Byte.close</span> commands.</p><p class="Standard">If a file being opened for read does not exist then the &lt;file_table_nvar&gt; will be set to -1. The BASIC! program can check for this and either create the file or report the error to the user. Information about the error is available from the <span class="T7">GETERROR$()</span> function.</p><h2 class="Heading_20_2"><a id="a__Byte_close__file_table_nexp_"><span/></a><a id="_Toc5235984"/>Byte.close &lt;file_table_nexp&gt;</h2><p class="Standard">Closes the previously opened file.</p><h2 class="Heading_20_2"><a id="a__Byte_read_byte__file_table_nexp__{__nvar_}___"><span/></a><a id="_Toc5235985"/>Byte.read.byte &lt;file_table_nexp&gt; {,&lt;nvar&gt;}...</h2><p class="Standard">Reads bytes from a file. The &lt;file_table_nexp&gt; parameter is a file table number returned by a previous <span class="T7">Byte.open</span>. If the file number is -1 then the command throws a run-time error.</p><p class="Standard">Places the byte(s) into the &lt;nvar&gt; parameter(s) as positive values, 0 &lt;= byte &lt;= 255. After the last byte in the file has been read, further attempts to read from the file return the value -1. The result of the <span class="T7">Byte.eof</span> command will be false after reading real data and true after reading at end-of-file (EOF).</p><p class="Standard">This example reads a file and prints each byte, and prints "-1" at the end to show that the entire file has been read.</p><p class="Code_20_example"><span class="T11">BYTE.OPEN r, file_number, "testfile.jpg"</span></p><p class="Code_20_example"><span class="T11">DO</span></p><p class="Code_20_example"><span class="T11">    BYTE.READ.BYTE file_number, Byte</span></p><p class="Code_20_example"><span class="T11">    PRINT Byte</span></p><p class="Code_20_example"><span class="T11">UNTIL Byte &lt; 0</span></p><p class="Code_20_example"><span class="T11">BYTE.CLOSE file_number</span></p><h2 class="Heading_20_2"><a id="a__Byte_write_byte__file_table_nexp__{{__nexp_}___{__sexp_}}"><span/></a><a id="_Toc5235986"/>Byte.write.byte &lt;file_table_nexp&gt; {{,&lt;nexp&gt;}...{,&lt;sexp&gt;}}</h2><p class="Standard">Writes bytes to the file specified by the file number parameter &lt;file_table_nexp&gt;. The bytes are written from an optional comma-separated list of numeric expressions, a single optional string expression, or both.</p><ul><li><p class="P38" style="margin-left:1.27cm;"><span class="ListLabel_20_65" style="display:block;float:left;min-width:0.635cm;"></span>Numeric parameters: the command writes the low-order 8 bits of the value of each expression as a single byte.<span class="odfLiEnd"/> </p></li><li><p class="P38" style="margin-left:1.27cm;"><span class="ListLabel_20_65" style="display:block;float:left;min-width:0.635cm;"></span>String parameters: the command writes the entire string to the file. Each character of the string is written as a single byte. See <span class="T7">Byte.write.buffer</span> for more information.<span class="odfLiEnd"/> </p></li><li><p class="P38" style="margin-left:1.27cm;"><span class="ListLabel_20_65" style="display:block;float:left;min-width:0.635cm;"></span>If you have both numeric and string parameters, you may have only one string, and it must be last.<span class="odfLiEnd"/> </p></li><li><p class="P38" style="margin-left:1.27cm;"><span class="ListLabel_20_65" style="display:block;float:left;min-width:0.635cm;"></span>The command accepts a string for backward compatibility. <span class="T7">Byte.write.buffer</span> is preferred.<span class="odfLiEnd"/> </p></li></ul><p class="P109">Examples:</p><p class="Code_20_example"><span class="T11">Byte.open w, f1, "tmp.dat"                % create a file</span></p><p class="Code_20_example"><span class="T11">Byte.write.byte f1, 10                % write one byte</span></p><p class="Code_20_example"><span class="T11">Byte.write.byte f1, 11, 12, 13        % write three bytes</span></p><p class="Code_20_example"><span class="T11">Byte.write.byte f1, "Hello!"                % write six bytes</span></p><p class="Code_20_example"><span class="T11">Byte.write.byte f1, 1,2,3,"abc"        % write six bytes</span></p><p class="Code_20_example"><span class="T11">Byte.write.byte f1, "one", "two"        % syntax error: only one string allowed</span></p><p class="Standard">Note: If the bytes are written from a string expression then the expression is evaluated twice. You should not put calls to user-defined functions in the expression.</p><h2 class="Heading_20_2"><a id="a__Byte_read_number__file_table_nexp__{__nvar____}"><span/></a><a id="_Toc5235987"/>Byte.read.number &lt;file_table_nexp&gt; {,&lt;nvar&gt;...}</h2><p class="Standard">Reads numbers from the file specified by the file number parameter &lt;file_table_nexp&gt; and places them into the numeric variables in the "{,&lt;nvar&gt;}..." parameter list. Each number is a group of 8 bytes.</p><p class="Standard">If the file does not have enough data available for all of the variables, the value of one or more &lt;nvar&gt; will be set to -1. This is indistinguishable from -1 read as actual data, except that the result of the <span class="T7">Byte.eof</span> command will be false for real data and true for EOF.</p><p class="Standard">Normally this command is used only to read values written with <span class="T7">Byte.write.number</span>. You must be sure the file is positioned at the first byte of the eight-byte representation of a number, or you will get unexpected results.</p><h2 class="Heading_20_2"><a id="a__Byte_write_number__file_table_nexp__{__nexp_}___"><span/></a><a id="_Toc5235988"/>Byte.write.number &lt;file_table_nexp&gt; {,&lt;nexp&gt;}...</h2><p class="Standard">Writes the values of the numeric expressions &lt;nexp&gt; to the file specified by the file number parameter &lt;file_table_nexp&gt;. This command always writes 8 bytes for each expression in the parameter list.</p><h2 class="Heading_20_2"><a id="a__Byte_read_buffer__file_table_nexp____count_nexp____buffer_svar_"><span/></a><a id="_Toc5235989"/>Byte.read.buffer &lt;file_table_nexp&gt;, &lt;count_nexp&gt;, &lt;buffer_svar&gt;</h2><p class="Standard">Reads the specified number of bytes (&lt;count_nexp&gt;) into the buffer string variable (&lt;buffer_svar&gt;) from the file. The string length (len(&lt;buffer_svar&gt;)) will be the number of bytes actually read. If the end of file is reached, the string length may be less than the requested count.</p><p class="Standard">A buffer string is a special use of the BASIC! string. Each character of a string is 16 bits. When used as a buffer, one byte of data is written into the lower 8 bits of each 16-bit character. The upper 8 bits are 0. Extract the binary data from the string, one byte at a time, with the <span class="T7">ASCII()</span> or <span class="T7">UCODE()</span> functions.</p><p class="Standard">The format of the buffer string read by this command is compatible with the <span class="T7">DECODE$()</span> function. If you know that part of your data contains an encoded string, you can extract the substring (using a function like <span class="T7">MID$()</span>), then pass the substring to <span class="T7">DECODE$()</span> to convert it to a BASIC! string.</p><h2 class="Heading_20_2"><a id="a__Byte_write_buffer__file_table_nexp____buffer_sexp_"><span/></a><a id="_Toc5235990"/>Byte.write.buffer &lt;file_table_nexp&gt;, &lt;buffer_sexp&gt;</h2><p class="Standard">Writes the entire contents of the string expression to the file. The string is assumed to be a buffer string holding binary data, as described in <span class="T7">Byte.read.buffer</span>. The writer discards the upper 8 bits of each 16-bit character, writing one byte to the file for each character in the string.</p><p class="Standard">The <span class="T7">Byte.read.buffer</span> command and the <span class="T7">ENCODE$()</span> function always create these "buffer strings". You can construct one by using, for example, the <span class="T7">CHR$()</span> function with values less than 256.</p><p class="Standard">If you use only ASCII characters in a string, you can use this function to write the string to a file. The output is the same as if you had written it with <span class="T7">Text.writeln</span>, except that it will have no added newline.</p><h2 class="Heading_20_2"><a id="a__Byte_eof__file_table_nexp____lvar_"><span/></a><a id="_Toc5235991"/>Byte.eof &lt;file_table_nexp&gt;, &lt;lvar&gt;</h2><p class="Standard">Reports an opened file’s end-of-file status. If the file is at EOF, the &lt;lvar&gt; is set true (non-zero). If the file or directory is not at EOF, the &lt;lvar&gt; is set false (zero).</p><p class="Standard">A file opened for write or append is always at EOF. A file opened for read is not at EOF until all of the data has been read and then one more read is attempted. That read will have returned the value -1. <span class="T7">Byte.position.set</span> may also position the file at EOF.</p><h2 class="Heading_20_2"><a id="a__Byte_position_get__file_table_nexp____position_nvar_"><span/></a><a id="_Toc5235992"/>Byte.position.get &lt;file_table_nexp&gt;, &lt;position_nvar&gt;</h2><p class="Standard">Gets the position of the next byte to be read or written. The position of the first byte is 1. The position value will be incremented by 1 for each byte read or written.</p><p class="Standard">The position information can be used for setting up random file data access.</p><p class="Standard">If the file is opened for append, the position returned will be the length of the file plus one.</p><h2 class="Heading_20_2"><a id="a__Byte_position_set__file_table_nexp____position_nexp_"><span/></a><a id="_Toc5235993"/>Byte.position.set &lt;file_table_nexp&gt;, &lt;position_nexp&gt;</h2><p class="Standard">Sets the position of the next byte to be read from the file. If the position value is greater than the position of the last byte of the file, the position will point to the end of file.</p><p class="Standard">This command can only be used on files open for byte read.</p><h2 class="Heading_20_2"><a id="a__Byte_position_mark_{{_file_table_nexp_}{___marklimit_nexp_}}"><span/></a><a id="_Toc5235994"/>Byte.position.mark {{&lt;file_table_nexp&gt;}{, &lt;marklimit_nexp&gt;}}</h2><p class="Standard">Marks the current position in the file, and sets the mark limit to &lt;marklimit_nexp&gt; bytes.</p><p class="Standard">Both parameters are optional. If the file table index &lt;file_table_nexp&gt; is omitted, the default file is the last file opened; you must ensure that the last file opened was a <span class="T7">Byte</span> file opened for reading. If the mark limit &lt;marklimit_exp&gt; is omitted, the default value is the file’s current mark limit.</p><p class="Standard">Please read <span class="T7">Working with Files </span><span class="T25"></span><span class="T7"> Mark and Mark Limit</span>, above.</p><h2 class="Heading_20_2"><a id="a__Byte_truncate__file_table_nexp___length_nexp_"><span/></a><a id="_Toc5235995"/>Byte.truncate &lt;file_table_nexp&gt;,&lt;length_nexp&gt;</h2><p class="Standard">Truncates the file to &lt;length_nexp&gt; bytes and closes the file. Setting the truncate length &lt;length_nexp&gt; larger than the current length (current write position - 1) has no effect.</p><p class="Standard">This command can only be used on files open for byte write or append.</p><h2 class="Heading_20_2"><a id="a__Byte_copy__file_table_nexp___output_file_sexp_"><span/></a><a id="_Toc5235996"/>Byte.copy &lt;file_table_nexp&gt;,&lt;output_file_sexp&gt;</h2><p class="Standard">Copies the previously open input file represented by &lt;file_table_nexp&gt; to the file whose path is specified by &lt;output_file_sexp&gt;. The default path is "&lt;pref base drive&gt;/rfo-basic/data/".</p><p class="Standard">If &lt;file_table_nexp&gt; = -1 then a run-time error will be thrown.</p><p class="Standard">All bytes from the current position of the input file to its end are copied to the to the output file. Both files are then closed.</p><p class="Standard">If you have read from the input file, and you want to copy the whole file, you must reset the file position to 0 with <span class="T7">Byte.position.set</span>. However, if you have changed the file mark with <span class="T7">Byte.position.mark</span>, or if you reading a non-local (internet) file, you can’t reset the file position to 0. Instead, you must close and reopen the file.</p><p class="Standard">You should use <span class="T7">Byte.copy</span> if you are using Byte I/O for the sole purpose of copying. It is thousands (literally) of times faster than using <span class="T7">Byte.read</span>/<span class="T7">Byte.write</span>.</p><h1 class="Heading_20_1"><a id="a__ZIP_File_I_O"><span/></a><a id="_Toc5235997"/>ZIP File I/O</h1><p class="Standard">The ZIP file I/O commands work with compressed files. ZIP is an archive file format that stores multiple directories and files, using a method of lossless data compression to save file space.</p><p class="Standard">Use <span class="T7">Zip.dir</span> to get an array containing the names of all of the directories and files in an archive. Use the file names with <span class="T7">Zip.read</span> to extract files from the archive. <span class="T7">Zip.read</span> can not extract a directory. Use <span class="T7">Zip.write</span> to put files in a new archive. You can overwrite an existing ZIP file, but you cannot replace or add entries.</p><h2 class="Heading_20_2"><a id="a__Zip_count__path_sexp____nvar_"><span/></a><a id="_Toc5235998"/>Zip.count &lt;path_sexp&gt;, &lt;nvar&gt;</h2><p class="Standard">Returns the number of entries inside the ZIP file located at &lt;path_sexp&gt;. The path is relative to "&lt;pref base drive&gt;/rfo-basic/data/".</p><p class="Standard">The count is returned in the &lt;nvar&gt;. If the ZIP file does not exist, the returned count is 0.</p><h2 class="Heading_20_2"><a id="a__Zip_dir__path_sexp___Array$___{__dirmark_sexp_}"><span/></a><a id="_Toc5235999"/>Zip.dir &lt;path_sexp&gt;, Array$[] {,&lt;dirmark_sexp&gt;}</h2><p class="Standard">Returns the names of the files and directories inside the ZIP file located at &lt;path_sexp&gt;. The path is relative to "&lt;pref base drive&gt;/rfo-basic/data/".</p><p class="Standard">The names are placed into Array$[]. The array is sorted alphabetically with the directories at the top of the list. If the array exists, it is overwritten, otherwise a new array is created. The result is always a one-dimensional array.</p><p class="Standard">A directory is identified by a marker appended to its name. The default marker is the string "(d)". You can change the marker with the optional directory mark parameter &lt;dirmark_sexp&gt;. If you do not want directories to be marked, set &lt;dirmark_sexp&gt; to an empty string, "".</p><h2 class="Heading_20_2"><a id="a__Zip_open_{r|w|a}___file_table_nvar____path_sexp_"><span/></a><a id="_Toc5236000"/>Zip.open {r|w|a}, &lt;file_table_nvar&gt;, &lt;path_sexp&gt;</h2><p class="Standard">The ZIP file specified by the path string expression &lt;path_sexp&gt; is opened. The path is relative to "&lt;pref base drive&gt;/rfo-basic/data/".</p><p class="Standard">The first parameter is a single character that sets the I/O mode for this file:</p><table border="0" cellspacing="0" cellpadding="0" class="Table17"><colgroup><col width="96"/><col width="82"/><col width="530"/></colgroup><tr class="Table171"><td style="text-align:left;width:2.194cm; " class="Table17_A1"><p class="P120">Parameter</p></td><td style="text-align:left;width:1.877cm; " class="Table17_A1"><p class="P120">Mode</p></td><td style="text-align:left;width:12.121cm; " class="Table17_A1"><p class="P120">Notes</p></td></tr><tr class="Table171"><td style="text-align:left;width:2.194cm; " class="Table17_A1"><p class="P110">r</p></td><td style="text-align:left;width:1.877cm; " class="Table17_A1"><p class="P110">read</p></td><td style="text-align:left;width:12.121cm; " class="Table17_A1"><p class="P114">File exists: Reads from the start of the file.<br/>File does not exist: Error (see below).</p></td></tr><tr class="Table171"><td style="text-align:left;width:2.194cm; " class="Table17_A1"><p class="P110">w</p></td><td style="text-align:left;width:1.877cm; " class="Table17_A1"><p class="P110">write</p></td><td style="text-align:left;width:12.121cm; " class="Table17_A1"><p class="P114">File exists: Writes from the start of the file. Writes over any existing data.<br/>File does not exist: Creates a new file. Writes from the start of the file.</p></td></tr></table><p class="P108">Note: unlike <span class="T7">Text.open</span> and <span class="T7">Byte.open</span>, <span class="T7">Zip.open</span> does not support append mode.</p><p class="Standard">A file table number is placed into the numeric variable &lt;file_table_nvar&gt;. This value is for use in subsequent <span class="T7">Zip.read</span>, <span class="T7">Zip.write</span>, or <span class="T7">Zip.close</span> commands.</p><p class="Standard">If there was an error opening the ZIP file, &lt;file_table_nvar&gt; is set to -1 with details available from the <span class="T7">GETERROR$()</span> function.</p><h2 class="Heading_20_2"><a id="a__Zip_close__file_table_nexp_"><span/></a><a id="_Toc5236001"/>Zip.close &lt;file_table_nexp&gt;</h2><p class="Standard">Closes the previously opened ZIP file.</p><h2 class="Heading_20_2"><a id="a__Zip_read__file_table_nexp____buffer_svar____file_name_sexp_"><span/></a><a id="_Toc5236002"/>Zip.read &lt;file_table_nexp&gt; ,&lt;buffer_svar&gt;, &lt;file_name_sexp&gt;</h2><p class="Standard">Reads the content of the file &lt;file_name_sexp&gt; from inside a ZIP file and puts the result byte(s) inside the buffer string variable &lt;buffer_svar&gt;.</p><p class="Standard">The &lt;file_table_nexp&gt; parameter is a file table number returned by a previous <span class="T7">Zip.open</span> command. If the file number is -1 then the command throws a run-time error.</p><p class="Standard">If the file &lt;file_name_sexp&gt; is not found in the ZIP, &lt;buffer_svar&gt; is set to "EOF".</p><p class="Standard">If the user tries to read the content of a zipped directory, instead of a zipped file, then the command throws a run-time error. To read the contents of a zipped directory, use <span class="T7">Zip.dir</span>.</p><h2 class="Heading_20_2"><a id="a__Zip_write__file_table_nexp____buffer_sexp____file_name_sexp_"><span/></a><a id="_Toc5236003"/>Zip.write &lt;file_table_nexp&gt; ,&lt;buffer_sexp&gt;, &lt;file_name_sexp&gt;</h2><p class="Standard">Writes the entire contents of the string expression &lt;buffer_sexp&gt; into a ZIP, as a file named &lt;file_name_sexp&gt;. The ZIP is in a file previously opened with <span class="T7">Zip.open</span>.</p><p class="Standard">The string &lt;buffer_sexp&gt; is assumed to be a buffer string holding binary data, typically a string coming from reading a local file with <span class="T7">Byte.read.buffer</span>.</p><h1 class="Heading_20_1"><a id="a__HTML"><span/></a><a id="_Toc5236004"/>HTML</h1><h2 class="Heading_20_2"><a id="a__Introduction"><span/></a><a id="_Toc5236005"/>Introduction</h2><p class="Standard">The BASIC! HTML package is designed to allow the BASIC! programmer to create user interfaces using HTML and JavaScript. The interface provides for interaction between the HTML engine and BASIC!. The HTML programmer can use JavaScript to send messages to BASIC!. The HTML engine will also report user events such as the BACK key, hyperlink transfers, downloads, form data and errors.</p><p class="Standard">The demo program, <span class="T7">f37_html_demo.bas</span>, combined with the HTML demo files, <span class="T7">htmlDemo1.html</span> and <span class="T7">htmlDemo2.html</span>, illustrate the various commands and possibilities. The content of all three files are listed in the <span class="T7">Appendix B</span> of this document. They are also delivered with the BASIC! apk. It is highly recommended that all three files be carefully studied to fully understand this interface.</p><p class="Standard">Another demo program, <span class="T7">f38_html_edit.bas</span>, can be used to edit html files. To use the program, run it and enter the html file name without the html extension. The program will add the extension ".html".</p><p class="Standard"><span class="T7">Caution</span>: Forum users have reported problems in HTML mode with commands that use a new window or screen to interact with the user (<span class="T7">Input</span>, <span class="T7">Select</span> and others), or when using the BACK key to try to control actions outside of the HTML WebView.</p><h2 class="Heading_20_2"><a id="a__HTML_Commands"><span/></a><a id="_Toc5236006"/>HTML Commands</h2><h3 class="Heading_20_3"><a id="a__Html_open_{_ShowStatusBar_lexp__{___Orientation_nexp_}}"><span/></a><a id="_Toc5236007"/>Html.open {&lt;ShowStatusBar_lexp&gt; {, &lt;Orientation_nexp&gt;}}</h3><p class="Standard">This command must be executed before using the HTML interface.</p><p class="Standard">The Status Bar will be shown on the Web Screen if the &lt;ShowStatusBar_lexp&gt; is true (not zero). If the &lt;ShowStatusBar_lexp&gt; is not present, the Status Bar will not be shown.</p><p class="Standard">The orientation upon opening the HTML screen will be determined by the &lt;Orientation_nexp&gt; value. &lt;Orientation_nexp&gt; values are the same as values for the Html.orientation command (see below). If the &lt;Orientation_nexp&gt; is not present, the default orientation is determined by the orientation of the device.</p><p class="Standard">Both &lt;ShowStatusBar_lexp&gt; and &lt;Orientation_nexp&gt; are optional; however, a &lt;ShowStatusBar_lexp&gt; must be present in order to specify an &lt;Orientation_nexp&gt;.</p><p class="Standard">Executing a second HTML.OPEN before executing HTML.CLOSE will generate a run-time error.</p><h3 class="Heading_20_3"><a id="a__Html_orientation__nexp_"><span/></a><a id="_Toc5236008"/>Html.orientation &lt;nexp&gt;</h3><p class="No_20_Spacing">The value of the &lt;nexp&gt; sets the orientation of screen as follows:</p><p class="List_20_Paragraph">-1 = Orientation depends upon the sensors.</p><p class="List_20_Paragraph"> 0 = Orientation is forced to Landscape.</p><p class="List_20_Paragraph"> 1 = Orientation is forced to Portrait.</p><p class="List_20_Paragraph"> 2 = Orientation is forced to Reverse Landscape.</p><p class="List_20_Paragraph"> 3 = Orientation is forced to Reverse Portrait.</p><h3 class="Heading_20_3"><a id="a__Html_load_url__file_sexp_"><span/></a><a id="_Toc5236009"/>Html.load.url &lt;file_sexp&gt;</h3><p class="Standard">Loads and displays the file specified in the string &lt;file_sexp&gt;. The file may reside on the Internet or on your Android device. In either case, the entire URL must be specified.</p><p class="Standard">The command:</p><p class="Code_20_example"><span class="T11">HTML.LOAD.URL "http://laughton.com/basic/"</span></p><p class="Standard">will load and display the BASIC! home page.</p><p class="Standard">The command:</p><p class="Code_20_example"><span class="T11">HTML.LOAD.URL "htmlDemo1.html"</span></p><p class="Standard">will load and display the html file "htmlDemo1.html" residing in BASIC!'s default "data" directory, as set by your "Base Drive" preference. You may also use a fully-qualified pathname. With the default "Base Drive" setting, this command loads the same file:</p><p class="Code_20_example"><span class="T11">HTML.LOAD.URL "file:///sdcard/rfo-basic/data/htmlDemo1.html"</span></p><p class="Standard">When you tap the BACK key on the originally-loaded page, the HTML viewer will be closed and the BASIC! output console will be displayed. If the page that was originally loaded links to another page and then the BACK key is tapped, it will be up to the BASIC! programmer to decide what to do.</p><h3 class="Heading_20_3"><a id="a__Html_load_string__html_sexp_"><span/></a><a id="_Toc5236010"/>Html.load.string &lt;html_sexp&gt;</h3><p class="Standard">Loads and displays the HTML contained in the string expression. The base page for this HTML will be:</p><p class="Code_20_example"><span class="T11">&lt;pref base drive&gt;/rfo-basic/data/</span></p><h3 class="Heading_20_3"><a id="a__Html_post__url_sexp____list_nexp_"><span/></a><a id="_Toc5236011"/>Html.post &lt;url_sexp&gt;, &lt;list_nexp&gt;</h3><p class="Standard">Execute a Post command to an Internet location.</p><p class="Standard">&lt;url_sexp&gt; is a string expression giving the url that will accept the Post.</p><p class="Standard">&lt;list_nexp&gt; is a pointer to a string list which contains the Name/Value pairs needed for the Post.</p><h3 class="Heading_20_3"><a id="a__Html_get_datalink__data_svar_"><span/></a><a id="_Toc5236012"/>Html.get.datalink &lt;data_svar&gt;</h3><p class="P109">A datalink provides a method for sending a message from an HTML program to the BASIC! programmer. There are two parts to a datalink in an HTML file:</p><ol><li><p class="P39" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">1.</span>The JavaScript that defines the datalink function<span class="odfLiEnd"/> </p></li><li><p class="P39" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">2.</span>The HTML code that calls the datalink function.<span class="odfLiEnd"/> </p></li></ol><p class="Standard">The BASIC! Program requires a mechanism for communicating with a website's HTML code.</p><p class="P109"><span class="T7">Html.get.datalink</span> gets the next datalink string from the datalink buffer. If there is no data available then the returned data will be an empty string (""). You should program a loop waiting for data:</p><p class="Code_20_example"><span class="T11">DO</span></p><p class="Code_20_example"><span class="T11">  HTML.GET.DATALINK data$</span></p><p class="Code_20_example"><span class="T11">UNTIL data$ &lt;&gt; ""</span></p><p class="Standard">The returned data string will always start with a specific set of four characters—three alphabetic characters followed by a colon (":"). These four characters identify the return datalink data type. Most of the type codes are followed by some sort of data. The codes are:</p><p class="P94"><span class="T7">BAK:</span> The user has tapped the BACK key. The data is either "1" or "0".</p><p class="P94">If the data is "0" then the user tapped BACK in the start screen. Going back is not possible therefore HTML has been closed.</p><p class="P94">If the data is "1" then going back is possible. The BASIC! programmer should issue the command <span class="T7">Html.go.back</span> if going back is desired.</p><p class="P94"><span class="T7">LNK:</span> The user has tapped a hyperlink. The linked-to url is returned. The transfer to the new url has not been done. The BASIC! programmer must execute an <span class="T7">Html.load.url</span> with the returned url (or some other url) for a transfer to occur.</p><p class="P94"><span class="T7">ERR:</span> Some sort of fatal error has occurred. The error condition will be returned. This error code always closes the html engine. The BASIC! output console will be displayed.</p><p class="P94"><span class="T7">FOR:</span> The user has tapped the Submit button on a form with action=’FORM’ The form name/value pairs are returned.</p><p class="P94"><span class="T7">DNL:</span> The user has clicked a link that requires a download. The download url is supplied. It is up to the BASIC! programmer to do the download.</p><p class="P94"><span class="T7">DAT:</span> The user has performed some action that has caused some JavaScript code to send data to BASIC! by means of the datalink. The JavaScript function for sending the data is:</p><p class="P10"><span class="T11">&lt;script type="text/javascript"&gt;</span></p><p class="P10"><span class="T11">    function doDataLink(data) {</span></p><p class="P10"><span class="T11">        Android.dataLink(data);</span></p><p class="P10"><span class="T11">    }</span></p><p class="P10"><span class="T11">&lt;/script&gt;</span></p><h3 class="Heading_20_3"><a id="a__Html_go_back"><span/></a><a id="_Toc5236013"/>Html.go.back</h3><p class="Standard">Go back one HTML screen, if possible.</p><h3 class="Heading_20_3"><a id="a__Html_go_forward"><span/></a><a id="_Toc5236014"/>Html.go.forward</h3><p class="Standard">Go forward one HTML screen, if possible.</p><h3 class="Heading_20_3"><a id="a__Html_close"><span/></a><a id="_Toc5236015"/>Html.close</h3><p class="Standard">Closes the HTML engine and display.</p><h3 class="Heading_20_3"><a id="a__Html_clear_cache"><span/></a><a id="_Toc5236016"/>Html.clear.cache</h3><p class="Standard">Clears the HTML cache.</p><h3 class="Heading_20_3"><a id="a__Html_clear_history"><span/></a><a id="_Toc5236017"/>Html.clear.history</h3><p class="Standard">Clears the HTML history.</p><h2 class="Heading_20_2"><a id="a__Related_Commands"><span/></a><a id="_Toc5236018"/>Related Commands</h2><h3 class="Heading_20_3"><a id="a__Browse__url_sexp_"><span/></a><a id="_Toc5236019"/>Browse &lt;url_sexp&gt;</h3><p class="Standard">If &lt;url_sexp&gt; starts with "http…" then the internet site specified by &lt;url_sexp&gt; will be opened and displayed.</p><p class="Standard">If &lt;url_sexp&gt; starts with "<a href="file:///C:/sdcard/" class="Internet_20_link"><span class="Internet_20_link">file:///sdcard/...</span></a> " then the file will be open be opened by the application, ThinkFree Mobile. The file types that the free version of ThinkFree Mobile can open are ".txt, .doc, .xls, .rtf".</p><p class="Standard">If your Android device does not already have ThinkFree Mobile Viewer on it, you can find it in the apps section of the Google Play Store. There is also a paid "pro" version that manages additional file types.</p><p class="Standard">Note: You can also use the HTML commands to display (and interact with) web pages located on your device or on the web.</p><h3 class="Heading_20_3"><a id="a__Http_post__url_sexp____list_nexp____result_svar_"><span/></a><a id="_Toc5236020"/>Http.post &lt;url_sexp&gt;, &lt;list_nexp&gt;, &lt;result_svar&gt;</h3><p class="Standard">Execute a Post command to an Internet location.</p><p class="Standard">&lt;url_sexp&gt; contains the url ("http://....") that will accept the Post.</p><p class="Standard">&lt;list_nexp&gt; is a pointer to a string list which contains the Name/Value pairs needed for the Post.</p><p class="Standard">&lt;result_svar&gt; is where the Post response will be placed.</p><h1 class="Heading_20_1"><a id="a__TCP_IP_Sockets"><span/></a><a id="_Toc5236021"/>TCP/IP Sockets</h1><p class="Standard">TCP/IP Sockets provide for the transfer of information from one point on the Internet to another. There are two genders of TCP/IP Sockets: Servers and Clients. Clients must talk to Servers. Servers must talk to Clients. Clients cannot talk to Clients. Servers cannot talk to Servers.</p><p class="Standard">Every Client and Server pair have an agreed-upon protocol. This protocol determines who speaks first and the meaning and sequence of the messages that flow between them.</p><p class="Standard">Most people who use a TCP/IP Socket will use a Client Socket to exchange messages with an existing Server with a predefined protocol. One simple example of this is the Sample Program file, <span class="T7">f31_socket_time.bas</span>. This program uses a TCP/IP client socket to get the current time from one of the many time servers in the USA.</p><p class="Standard">A TCP/IP Server can be set up in BASIC!; however, there are difficulties. The capabilities of individual wireless networks vary. Some wireless networks allow servers. Most do not. Servers can usually be run on WiFi or Ethernet Local Area Networks (LAN).</p><p class="Standard">If you want to set up a Server, the way most likely to work is to establish the Server inside a LAN. You will need to provide Port tunneling (forwarding) from the LAN’s external Internal IP to the device’s LAN IP. You must to be able to program (setup) the LAN router in order to do this.</p><p class="Standard">Clients, whether running inside the Server’s LAN or from the Internet, should connect to the LAN’s external IP address using the pre-established, tunneled Port. This external or WAN IP can be found using:</p><p class="Code_20_example"><span class="T11">Graburl ip$, "</span><a href="http://icanhazip.com" class="Internet_20_link"><span class="Internet_20_link"><span class="T11">http://icanhazip.com</span></span></a><span class="T11">"</span></p><p class="Standard">This is not the same IP that would be obtained by executing <span class="T7">Socket.myIP</span> on the server device.</p><p class="Standard">Note: The specified IPs do not have to be in the numeric form. They can be in the name form.</p><p class="Standard">The Sample Program, <span class="T7">f32_tcp_ip_sockets.bas</span>, demonstrates the socket commands for a Server working in conjunction with a Client. You will need two Android devices to run this program.</p><h2 class="Heading_20_2"><a id="a__TCP_IP_Client_Socket_Commands"><span/></a><a id="_Toc5236022"/>TCP/IP Client Socket Commands</h2><h3 class="Heading_20_3"><a id="a__Socket_client_connect__server_sexp____port_nexp__{____wait_lexp__}"><span/></a><a id="_Toc5236023"/>Socket.client.connect &lt;server_sexp&gt;, &lt;port_nexp&gt; { , &lt;wait_lexp&gt; }</h3><p class="Standard">Create a Client TCP/IP socket and attempt to connect to the Server whose Host Name or IP Address is specified by the Server string expression using the Port specified by Port numeric expression.</p><p class="Standard">The optional "wait" parameter determines if this command waits until a connection is made with the Server. If the parameter is absent or true (non-zero), the command will not return until the connection has been made or an error is detected. If the Server does not respond, the command should time out after a couple of minutes, but this is not certain.</p><p class="Standard">If the parameter is false (zero), the command completes immediately. Use <span class="T7">Socket.server.status</span> to determine when the connection is made. If you monitor the socket status, you can set your own time-out policy. You must use the <span class="T7">Socket.client.close</span> command to stop a connection attempt that has not completed.</p><h3 class="Heading_20_3"><a id="a__Socket_client_status__status_nvar_"><span/></a><a id="_Toc5236024"/>Socket.client.status &lt;status_nvar&gt;</h3><p class="P109">Get the current client socket connection status and place the value in the numeric variable &lt;status_nvar&gt;.</p><p class="List_20_Paragraph">0 = Nothing going on</p><p class="List_20_Paragraph">2 = Connecting</p><p class="List_20_Paragraph">3 = Connected</p><h3 class="Heading_20_3"><a id="a__Socket_client_server_ip__svar_"><span/></a><a id="_Toc5236025"/>Socket.client.server.ip &lt;svar&gt;</h3><p class="Standard">Return the IP of the server that this client is connected to in the string variable.</p><h3 class="Heading_20_3"><a id="a__Socket_client_read_line__line_svar_"><span/></a><a id="_Toc5236026"/>Socket.client.read.line &lt;line_svar&gt;</h3><p class="Standard">Read a line from the previously-connected Server and place the line into the line string variable. The command does not return until the Server sends a line. To avoid an infinite delay waiting for the Server to send a line, the <span class="T7">Socket.client.read.ready</span> command can be repeatedly executed with timeouts.</p><h3 class="Heading_20_3"><a id="a__Socket_client_read_ready__nvar_"><span/></a><a id="_Toc5236027"/>Socket.client.read.ready &lt;nvar&gt;</h3><p class="Standard">If the previously created Client socket has not received a line for reading by <span class="T7">Socket.client.read.line</span> then set the return variable &lt;nvar&gt; to zero. Otherwise return a non-zero value.</p><p class="Standard">The <span class="T7">Socket.client.read.line command</span> does not return until a line has been received from the Server. This command can be used to allow your program to time out if a line has not been received within a pre-determined time span. You can be sure that <span class="T7">Socket.client.read.line</span> will return with a line of data if <span class="T7">Socket.client.read.ready</span> returns a non-zero value.</p><h3 class="Heading_20_3"><a id="a__Socket_client_read_file__file_nexp_"><span/></a><a id="_Toc5236028"/>Socket.client.read.file &lt;file_nexp&gt;</h3><p class="Standard">Read file data transmitted by the Server and write it to a file. The &lt;file_nexp&gt; is the file index of a file opened for write by <span class="T7">Byte.open write</span> command. For example:</p><p class="Code_20_example"><span class="T11">Byte.open w, fw, "image.jpg"</span></p><p class="Code_20_example"><span class="T11">Socket.client.read.file fw</span></p><p class="Code_20_example"><span class="T11">Byte.close fw</span></p><h3 class="Heading_20_3"><a id="a__Socket_client_write_line__line_sexp_"><span/></a><a id="_Toc5236029"/>Socket.client.write.line &lt;line_sexp&gt;</h3><p class="Standard">Send the string expression &lt;line_sexp&gt; to the previously-connected Server as UTF-16 characters. End of line characters will be added to the end of the line.</p><h3 class="Heading_20_3"><a id="a__Socket_client_write_bytes__sexp_"><span/></a><a id="_Toc5236030"/>Socket.client.write.bytes &lt;sexp&gt;</h3><p class="Standard">Send the string expression, &lt;sexp&gt;, to the previously-connected Server as 8-bit bytes. Each character of the string is sent as a single byte. The string is not encoded. No end-of-line characters are added by BASIC!. If you need a CR or LF character, you must make it part of the string. Note that if <span class="T7">Socket.server.read.line</span> is used to receive these bytes, the <span class="T7">read.line</span> command will not return until it receives a LF (10, 0x0A) character.</p><h3 class="Heading_20_3"><a id="a__Socket_client_write_file__file_nexp_"><span/></a><a id="_Toc5236031"/>Socket.client.write.file &lt;file_nexp&gt;</h3><p class="Standard">Transmit a file to the Server. The &lt;file_nexp&gt; is the file index of a file opened for read by <span class="T7">Byte.open</span>. Example:</p><p class="Code_20_example"><span class="T11">Byte.open r, fr, "image.jpg"</span></p><p class="Code_20_example"><span class="T11">Socket.client.write.file fr</span></p><p class="Code_20_example"><span class="T11">Byte.close fr</span></p><h3 class="Heading_20_3"><a id="a__Socket_client_close"><span/></a><a id="_Toc5236032"/>Socket.client.close</h3><p class="Standard">Closes an open client side connection.</p><h2 class="Heading_20_2"><a id="a__TCP_IP_Server_Socket_Commands"><span/></a><a id="_Toc5236033"/>TCP/IP Server Socket Commands</h2><h3 class="Heading_20_3"><a id="a__Socket_myIP__svar_"><span/></a><a id="_Toc5236034"/>Socket.myIP &lt;svar&gt;</h3><p class="Standard">Returns the IP of the device in string variable &lt;svar&gt;. If the device has no active IP address, the returned value is the empty string "".</p><p class="Standard">If the device is on a WiFi or Ethernet LAN then the IP returned is the device’s LAN IP.</p><p class="Standard">Note: The external or WAN IP can be found using:</p><p class="Code_20_example"><span class="T11">Graburl ip$, "</span><a href="http://icanhazip.com" class="Internet_20_link"><span class="Internet_20_link"><span class="T11">http://icanhazip.com</span></span></a><span class="T11">"</span></p><h3 class="Heading_20_3"><a id="a__Socket_myIP__array$___{___nvar_}"><span/></a><a id="_Toc5236035"/>Socket.myIP &lt;array$[]&gt;{, &lt;nvar&gt;}</h3><p class="Standard">Returns all active IP addresses of the device in the string array &lt;array$[]&gt;. If you provide the optional address-count variable &lt;nvar&gt;, it is set to the number of active IP addresses.</p><p class="Standard">If the device has no active IP address, the array has a single element, the empty string "", and the address-count in &lt;nvar&gt; is 0. In this case only, the address-count is not the same as the array length.</p><p class="Standard">Most devices usually have zero or one IP address. It is possible to have more than one. For example, after enabling a WiFi connection, there may still be an active cellular data connection. Normally this connection shuts down after a short time, but in some cases it may remain open.</p><h3 class="Heading_20_3"><a id="a__Socket_server_create__port_nexp_"><span/></a><a id="_Toc5236036"/>Socket.server.create &lt;port_nexp&gt;</h3><p class="Standard">Establish a Server that will listen to the Port specified by the numeric expression, &lt;port_nexp&gt;.</p><h3 class="Heading_20_3"><a id="a__Socket_server_connect_{_wait_lexp_}"><span/></a><a id="_Toc5236037"/>Socket.server.connect {&lt;wait_lexp&gt;}</h3><p class="Standard">Direct the previously created Server to accept a connection from the next client in the queue.</p><p class="Standard">The optional "wait" parameter determines if the command waits until a connection is made with a client. If the parameter is absent or true (non-zero), the command waits for the connection. If the parameter is false (zero), the command completes immediately. Use <span class="T7">Socket.server.status</span> to determine when the connection is made.</p><p class="Standard">In general, it is safer to set the parameter to false (don't wait) and explicitly monitor the connection's status, since it can avoid a problem if the program exits with no connection made. You must use the <span class="T7">Socket.server.close</span> command to stop a connection attempt that has not completed.</p><h3 class="Heading_20_3"><a id="a__Socket_server_status__status_nvar_"><span/></a><a id="_Toc5236038"/>Socket.server.status &lt;status_nvar&gt;</h3><p class="P109">Get the current server socket connection status and place the value in the numeric variable &lt;status_nvar&gt;.</p><p class="List_20_Paragraph">- 1 = Server socket not created</p><p class="List_20_Paragraph">  0 = Nothing going on</p><p class="List_20_Paragraph">  1 = Listening</p><p class="List_20_Paragraph">  3 = Connected</p><h3 class="Heading_20_3"><a id="a__Socket_server_read_line__svar_"><span/></a><a id="_Toc5236039"/>Socket.server.read.line &lt;svar&gt;</h3><p class="Standard">Read a line sent from the previously-connected Client and place the line into the string variable &lt;svar&gt;. The command does not return until the Client sends a line. To avoid an infinite delay waiting for the Client to send a line, the <span class="T7">Socket.server.read.ready</span> command can be repeatedly executed with timeouts.</p><h3 class="Heading_20_3"><a id="a__Socket_server_read_ready__nvar_"><span/></a><a id="_Toc5236040"/>Socket.server.read.ready &lt;nvar&gt;</h3><p class="Standard">If the previously-connected Client socket has not sent a line for reading by <span class="T7">Socket.server.read.line</span> then set the return variable &lt;nvar&gt; to zero. Otherwise return a non-zero value.</p><p class="Standard">The <span class="T7">Socket.server.read.line</span> command does not return until a line has been received from the Client. This command can be used to allow your program to time out if a line has not been received within a pre-determined time span. You can be sure that <span class="T7">Socket.server.read.line</span> will return with a line of data if  returns a non-zero value.</p><h3 class="Heading_20_3"><a id="a__Socket_server_write_line__line_sexp_"><span/></a><a id="_Toc5236041"/>Socket.server.write.line &lt;line_sexp&gt;</h3><p class="Standard">Send the string expression &lt;line_sexp&gt; to the previously-connected Client as UTF-16 characters. End of line characters will be added to the end of the line.</p><h3 class="Heading_20_3"><a id="a__Socket_server_write_bytes__sexp_"><span/></a><a id="_Toc5236042"/>Socket.server.write.bytes &lt;sexp&gt;</h3><p class="Standard">Send the string expression, &lt;sexp&gt;, to the previously-connected Client as 8-bit bytes. Each character of the string is sent as a single byte. The string is not encoded. No end of line characters are added by BASIC!. If you need a CR or LF character, you must make it part of the string. Note that if <span class="T7">Socket.client.read.line</span> is used to receive these bytes, the <span class="T7">read.line</span> command will not return until it receives a LF (10, 0x0A) character.</p><h3 class="Heading_20_3"><a id="a__Socket_server_write_file__file_nexp_"><span/></a><a id="_Toc5236043"/>Socket.server.write.file &lt;file_nexp&gt;</h3><p class="Standard">Transmit a file to the Client. The &lt;file_nexp&gt; is the file index of a file opened for read by <span class="T7">Byte.open</span>. Example:</p><p class="Code_20_example"><span class="T11">Byte.open r, fr, "image.jpg"</span></p><p class="Code_20_example"><span class="T11">Socket.server.write.file fr</span></p><p class="Code_20_example"><span class="T11">Byte.close fr</span></p><h3 class="Heading_20_3"><a id="a__Socket_server_read_file__file_nexp_"><span/></a><a id="_Toc5236044"/>Socket.server.read.file &lt;file_nexp&gt;</h3><p class="Standard">Read file data transmitted by the Client and write it to a file. The &lt;file_nexp&gt; is the file index of a file opened for write by <span class="T7">Byte.open</span>. Example:</p><p class="Code_20_example"><span class="T11">Byte.open w, fw, "image.jpg"</span></p><p class="Code_20_example"><span class="T11">Socket.server.read.file fw</span></p><p class="Code_20_example"><span class="T11">Byte.close fw</span></p><h3 class="Heading_20_3"><a id="a__Socket_server_disconnect"><span/></a><a id="_Toc5236045"/>Socket.server.disconnect</h3><p class="Standard">Close the connection with the previously-connected Client. A new <span class="T7">Socket.server.connect</span> can then be executed to connect to the next client in the queue.</p><h3 class="Heading_20_3"><a id="a__Socket_server_close"><span/></a><a id="_Toc5236046"/>Socket.server.close</h3><p class="Standard">Close the previously created Server. Any currently connected client will be disconnected.</p><h3 class="Heading_20_3"><a id="a__Socket_server_client_ip__nvar_"><span/></a><a id="_Toc5236047"/>Socket.server.client.ip &lt;nvar&gt;</h3><p class="Standard">Return the IP of the Client currently connected to the Server.</p><h1 class="Heading_20_1"><a id="a__FTP_Client"><span/></a><a id="_Toc5236048"/>FTP Client</h1><p class="Standard">These FTP commands implement a FTP Client</p><h2 class="Heading_20_2"><a id="a__Ftp_open__url_sexp____port_nexp____user_sexp____pw_sexp_"><span/></a><a id="_Toc5236049"/>Ftp.open &lt;url_sexp&gt;, &lt;port_nexp&gt;, &lt;user_sexp&gt;, &lt;pw_sexp&gt;</h2><p class="Standard">Connects to the specified url and port. Logs onto the server using the specified user name and password. For example:</p><p class="Code_20_example"><a href="ftp://ftp.open" class="Default_20_Style">ftp.open</a> "<a href="ftp://ftp.laughton.com" class="Default_20_Style">ftp.laughton.com</a>", 21, "basic", "basic"</p><h2 class="Heading_20_2"><a id="a__Ftp_close"><span/></a><a id="_Toc5236050"/>Ftp.close</h2><p class="Standard">Disconnects from the FTP server.</p><h2 class="Heading_20_2"><a id="a__Ftp_put__source_sexp____destination_sexp_"><span/></a><a id="_Toc5236051"/><a href="ftp://ftp.put" class="Default_20_Style">Ftp.put</a> &lt;source_sexp&gt;, &lt;destination_sexp&gt;</h2><p class="Standard">Uploads specified source file to the specified destination file on connected ftp server.</p><p class="Standard">The source file is relative to the directory, "&lt;pref base drive&gt;/rfo-basic/data/" If you want to upload a BASIC! source file, the file name string would be: "../source/xxxx.bas".</p><p class="Standard">The destination file is relative to the current working directory on the server. If you want to upload to a subdirectory of the current working directory, specify the path to that directory. For example, if there is a subdirectory named "etc" then the filename, "/etc/name" would upload the file into that subdirectory.</p><h2 class="Heading_20_2"><a id="a__Ftp_get__source_sexp____destination_sexp_"><span/></a><a id="_Toc5236052"/><a href="ftp://ftp.get" class="Default_20_Style">Ftp.get</a> &lt;source_sexp&gt;, &lt;destination_sexp&gt;</h2><p class="Standard">The source file on the connected ftp server is downloaded to the specified destination file on the Android device.</p><p class="Standard">You can specify a subdirectory in the server source file string.</p><p class="Standard">The destination file path is relative to "&lt;pref base drive&gt;/rfo-basic/data/" If you want to download a BASIC! source file, the path would be, "../source/xxx.bas".</p><h2 class="Heading_20_2"><a id="a__Ftp_dir__list_nvar__{__dirmark_sexp_}"><span/></a><a id="_Toc5236053"/><a href="ftp://ftp.dir" class="Default_20_Style">Ftp.dir</a> &lt;list_nvar&gt; {,&lt;dirmark_sexp&gt;}</h2><p class="Standard">Creates a list of the names of the files and directories in the current working directory and places it in a BASIC! List data structure. A pointer to the new List is returned in the variable &lt;list_nvar&gt;.</p><p class="Standard">A directory is identified by a marker appended to its name. The default marker is the string "(d)". You can change the marker with the optional directory mark parameter &lt;dirmark_sexp&gt;. If you do not want directories to be marked, set &lt;dirmark_sexp&gt; to an empty string, "".</p><p class="Standard">The following code can be used to print the file names in that list:</p><p class="Code_20_example">ftp.dir file_list</p><p class="Code_20_example">list.size file_list,size</p><p class="Code_20_example"> </p><p class="Code_20_example">for i = 1 to size</p><p class="Code_20_example"><span> list.get file_list,i,name$</span></p><p class="Code_20_example"><span> print name$</span></p><p class="Code_20_example">next i</p><h2 class="Heading_20_2"><a id="a__Ftp_cd__new_directory_sexp_"><span/></a><a id="_Toc5236054"/><a href="ftp://ftp.cd" class="Default_20_Style">Ftp.cd</a> &lt;new_directory_sexp&gt;</h2><p class="Standard">Changes the current working directory to the specified new directory.</p><h2 class="Heading_20_2"><a id="a__Ftp_rename__old_filename_sexp____new_filename_sexp_"><span/></a><a id="_Toc5236055"/><a href="ftp://ftp.rename" class="Default_20_Style">Ftp.rename</a> &lt;old_filename_sexp&gt;, &lt;new_filename_sexp&gt;</h2><p class="Standard">Renames the specified old filename to the specified new file name.</p><h2 class="Heading_20_2"><a id="a__Ftp_delete__filename_sexp_"><span/></a><a id="_Toc5236056"/><a href="ftp://ftp.delete" class="Default_20_Style">Ftp.delete</a> &lt;filename_sexp&gt;</h2><p class="Standard">Deletes the specified file.</p><h2 class="Heading_20_2"><a id="a__Ftp_rmdir__directory_sexp_"><span/></a><a id="_Toc5236057"/><a href="ftp://ftp.rmdir" class="Default_20_Style">Ftp.rmdir</a> &lt;directory_sexp&gt;</h2><p class="Standard">Removes (deletes) the specified directory if and only if that directory is empty.</p><h2 class="Heading_20_2"><a id="a__Ftp_mkdir__directory_sexp_"><span/></a><a id="_Toc5236058"/><a href="ftp://ftp.mkdir" class="Default_20_Style">Ftp.mkdir</a> &lt;directory_sexp&gt;</h2><p class="Standard">Creates a new directory of the specified name.</p><h1 class="Heading_20_1"><a id="a__Bluetooth"><span/></a><a id="_Toc5236059"/>Bluetooth</h1><p class="Standard">BASIC! implements Bluetooth in a manner which allows the transfer of data bytes between an Android device and some other device (which may or may not be another Android device).</p><p class="Standard">Before attempting to execute any BASIC! Bluetooth commands, you should use the Android "Settings" Application to enable Bluetooth and pair with any device(s) with which you plan to communicate.</p><p class="Standard">When Bluetooth is opened using the <span class="T7">Bt.open</span> command, the device goes into the Listen Mode. While in this mode it waits for a device to attempt to connect.</p><p class="Standard">For an active attempt to make a Bluetooth connection, you can use the Connect Mode by successfully executing the <span class="T7">Bt.connect</span> command. Upon executing the <span class="T7">Bt.connect</span> command the person running the program is given a list of paired Bluetooth devices and asked. When the user selects a device, BASIC! attempts to connect to it.</p><p class="Standard">You should monitor the state of the Bluetooth using the <span class="T7">Bt.status</span> command. This command will report states of Listening, Connecting and Connected. Once you receive a "Connected" report, you can proceed to read bytes and write bytes to the connected device.</p><p class="Standard">You can write bytes to a connected device using the <span class="T7">Bt.write</span> command.</p><p class="Standard">Data is read from the connected device using the <span class="T7">Bt.read.bytes</span> command; however, before executing <span class="T7">Bt.read.bytes</span>, you need to find out if there is data to be read. You do this using the <span class="T7">Bt.read.ready</span> command.</p><p class="Standard">Once connected, you should continue to monitor the status (using <span class="T7">Bt.status</span>) to ensure that the connected device remains connected.</p><p class="Standard">When you are done with a particular connection or with Bluetooth in general, execute <span class="T7">Bt.close</span>.</p><p class="Standard">The sample program, f35_bluetooth, is a working example of Bluetooth using two Android devices in a "chat" type application.</p><h2 class="Heading_20_2"><a id="a__Bt_open_{0|1}"><span/></a><a id="_Toc5236060"/>Bt.open {0|1}</h2><p class="Standard">Opens Bluetooth in Listen Mode. If you do not have Bluetooth enabled (using the Android Settings Application) then the person running the program will be asked whether Bluetooth should be enabled. After <span class="T7">Bt.open</span> is successfully executed, the code will listen for a device that wants to connect.</p><p class="Standard">The optional parameter determines if BT will listen for a secure or insecure connection. If no parameter is given or if the parameter is 1, then a secure connection request will be listened for. Otherwise, an insecure connection will be listened for. It is not possible to listen for either a secure or insecure connection with one <span class="T7">Bt.open</span> command because the Android API requires declaring a specific secure/insecure open.</p><p class="Standard">If <span class="T7">Bt.open</span> is used in graphics mode (after <span class="T7">Gr.open</span>), you will need to insert a <span class="T7">Pause 500</span> statement after the <span class="T7">Bt.open</span> statement.</p><h2 class="Heading_20_2"><a id="a__Bt_close"><span/></a><a id="_Toc5236061"/>Bt.close</h2><p class="Standard">Closes any previously opened Bluetooth connection. Bluetooth will automatically be closed when the program execution ends.</p><h2 class="Heading_20_2"><a id="a__Bt_connect_{0|1}"><span/></a><a id="_Toc5236062"/>Bt.connect {0|1}</h2><p class="Standard">Commands BASIC! to connect to a particular device. Executing this command will cause a list of paired devices to be displayed. When one of these devices is selected the <span class="T7">Bt.status</span> will become "Connecting" until the device has connected.</p><p class="Standard">The optional parameter determines if BT will seek a secure or insecure connection. If no parameter is given or if the parameter is 1, then a secure connection will be requested. Otherwise, an insecure connection will be requested.</p><h2 class="Heading_20_2"><a id="a__Bt_disconnect"><span/></a><a id="_Toc5236063"/>Bt.disconnect</h2><p class="Standard">Disconnects from the connected Bluetooth device and goes into the Listen status. This avoids having to use <span class="T7">Bt.close</span> + <span class="T7">Bt.open</span> to disconnect and wait for a new connection.</p><h2 class="Heading_20_2"><a id="a__Bt_reconnect"><span/></a><a id="_Toc5236064"/>Bt.reconnect</h2><p class="Standard">This command will attempt to reconnect to a device that was previously connected (during this Run) with <span class="T7">Bt.connect</span> or a prior <span class="T7">Bt.reconnect</span>. The command cannot be used to reconnect to a device that was connected following a <span class="T7">Bt.open</span> or <span class="T7">Bt.disconnect</span> command (i.e. from the <span class="T7">Listening</span> status).</p><p class="Standard">You should monitor the Bluetooth status for <span class="T7">Connected</span> (3) after executing <span class="T7">Bt.reconnect</span>.</p><h2 class="Heading_20_2"><a id="a__Bt_status_{{_connect_var_}{___name_svar_}{___address_svar_}}"><span/></a><a id="_Toc5236065"/>Bt.status {{&lt;connect_var&gt;}{, &lt;name_svar&gt;}{, &lt;address_svar&gt;}}</h2><p class="Standard">Gets the current Bluetooth status and places the information in the return variables. The available data are the current connection status (in &lt;connect_var&gt;), and the friendly name and MAC address of your Bluetooth hardware (in &lt;name_svar&gt; and &lt;address_svar&gt;).</p><p class="Standard">All parameters are optional; use commas to indicate omitted parameters (see Optional Parameters).</p><p class="Standard">If the connection status variable &lt;connect_var&gt; is present, it may be either a numeric variable or a string variable. The table shows the possible return values of each type:</p><table border="0" cellspacing="0" cellpadding="0" class="Table18"><colgroup><col width="139"/><col width="139"/><col width="222"/></colgroup><tr class="Table181"><td style="text-align:left;width:3.179cm; " class="Table18_A1"><p class="P120">Numeric Value</p></td><td style="text-align:left;width:3.177cm; " class="Table18_A1"><p class="P120">String Value</p></td><td style="text-align:left;width:5.08cm; " class="Table18_A1"><p class="P120">Meaning</p></td></tr><tr class="Table181"><td style="text-align:left;width:3.179cm; " class="Table18_A1"><p class="P110">-1</p></td><td style="text-align:left;width:3.177cm; " class="Table18_A1"><p class="P110">Not enabled</p></td><td style="text-align:left;width:5.08cm; " class="Table18_A1"><p class="P114">Bluetooth not enabled</p></td></tr><tr class="Table181"><td style="text-align:left;width:3.179cm; " class="Table18_A1"><p class="P110">0</p></td><td style="text-align:left;width:3.177cm; " class="Table18_A1"><p class="P110">Idle</p></td><td style="text-align:left;width:5.08cm; " class="Table18_A1"><p class="P114">Nothing going on</p></td></tr><tr class="Table181"><td style="text-align:left;width:3.179cm; " class="Table18_A1"><p class="P110">1</p></td><td style="text-align:left;width:3.177cm; " class="Table18_A1"><p class="P110">Listening</p></td><td style="text-align:left;width:5.08cm; " class="Table18_A1"><p class="P114">Listening for connection</p></td></tr><tr class="Table181"><td style="text-align:left;width:3.179cm; " class="Table18_A1"><p class="P110">2</p></td><td style="text-align:left;width:3.177cm; " class="Table18_A1"><p class="P110">Connecting</p></td><td style="text-align:left;width:5.08cm; " class="Table18_A1"><p class="P114">Connecting to another device</p></td></tr><tr class="Table181"><td style="text-align:left;width:3.179cm; " class="Table18_A1"><p class="P110">3</p></td><td style="text-align:left;width:3.177cm; " class="Table18_A1"><p class="P110">Connected</p></td><td style="text-align:left;width:5.08cm; " class="Table18_A1"><p class="P114">Connected to another device</p></td></tr></table><p class="P108">If the device name string variable &lt;name_svar&gt; is present, it is set to the friendly device name. If your device has no Bluetooth radio, the string will be empty.</p><p class="Standard">If the address string variable &lt;address_svar&gt; is present, it is set to the MAC address of your Bluetooth hardware, represented as a string of six hex numbers separated by colons: "00:11:22:AA:BB:CC".</p><h2 class="Heading_20_2"><a id="a__Bt_write_{_exp__{_|_}}____"><span/></a><a id="_Toc5236066"/>Bt.write {&lt;exp&gt; {,|;}} ...</h2><p class="Standard">Writes data to the Bluetooth connection.</p><p class="Standard">If the comma (,) separator is used then a comma will be printed between the values of the expressions.</p><p class="Standard">If the semicolon (;) separator is used then nothing will separate the values of the expressions.</p><p class="Standard">If the semicolon is at the end of the line, the output will be transmitted immediately, with no newline character(s) added.</p><p class="Standard">The parameters are the same as the <span class="T7">Print</span> parameters. This command is essentially a <span class="T7">Print</span> to the Bluetooth connection, with two differences:</p><ul><li><p class="P40" style="margin-left:1.27cm;"><span class="ListLabel_20_61" style="display:block;float:left;min-width:0.635cm;"></span>Only one byte is transmitted for each character; the upper byte is discarded. Binary data and ASCII text are sent correctly, but Unicode characters may not be.<span class="odfLiEnd"/> </p></li><li><p class="P40" style="margin-left:1.27cm;"><span class="ListLabel_20_61" style="display:block;float:left;min-width:0.635cm;"></span>A line that ends with a semicolon is sent immediately, with no newline character(s) added.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">This command with no parameters sends a newline character to the Bluetooth connection.</p><h2 class="Heading_20_2"><a id="a__Bt_read_ready__nvar_"><span/></a><a id="_Toc5236067"/>Bt.read.ready &lt;nvar&gt;</h2><p class="Standard">Reports in the numeric variable the number of messages ready to be read. If the value is greater than zero then the messages should be read until the queue is empty.</p><h2 class="Heading_20_2"><a id="a__OnBtReadReady_"><span/></a><a id="_Toc5236068"/>OnBtReadReady:</h2><p class="Standard">Interrupt label that traps the arrival of a message received on the Bluetooth channel (see "Interrupt Labels"). If a Bluetooth message is ready (<span class="T7">Bt.read.ready</span> would return a non-zero value) BASIC! executes the statements after the <span class="T7">OnBtReady:</span> label, where you can read and handle the message. When done, execute the <span class="T7">Bt.onReadReady.Resume</span> command to resume the interrupted program.</p><h3 class="Heading_20_3"><a id="a__Bt_onReadReady_resume"><span/></a><a id="_Toc5236069"/>Bt.onReadReady.resume</h3><p class="Standard">Resumes execution at the point in the program where it was interrupted by the Bluetooth Read Ready event.</p><h2 class="Heading_20_2"><a id="a__Bt_read_bytes__svar_"><span/></a><a id="_Toc5236070"/>Bt.read.bytes &lt;svar&gt;</h2><p class="Standard">The next available message is placed into the specified string variable. If there is no message then the string variable will be returned with an empty string ("").</p><p class="Standard">Each message byte is placed in one character of the string; the upper byte of each character is 0. This is similar to <span class="T7">Byte.read.buffer</span>, which reads binary data from a file into a buffer string.</p><h2 class="Heading_20_2"><a id="a__Bt_device_name__svar_"><span/></a><a id="_Toc5236071"/>Bt.device.name &lt;svar&gt;</h2><p class="Standard">Returns the name of the connected device in the string variable. A run-time error will be generated if no device (Status &lt;&gt; 3) is connected.</p><h2 class="Heading_20_2"><a id="a__Bt_set_UUID__sexp_"><span/></a><a id="_Toc5236072"/>Bt.set.UUID &lt;sexp&gt;</h2><p class="Standard"><span class="T54">A Universally Unique Identifier (UUID) is a standardized 128-bit format for a string ID used to uniquely identify information. The point of a UUID is that it's big enough that you can select any random 128-bit number and it won't clash with any other number selected similarly. In this case, it's used to uniquely identify your application's Bluetooth service. To get a UUID to use with your application, you can use one of the many random UUID generators on the web.</span></p><p class="Standard"><span class="T54">Many devices have common UUIDs for their particular application. The default BASIC! UUID is the standard Serial Port Profile (SPP) UUID: "00001101-0000-1000-8000-00805F9B34FB".</span></p><p class="Standard"><span class="T54">You can change the default UUID using this command.</span></p><p class="Standard"><span class="T54">Some information about 16 bit and 128 bit UUIDs can be found at:</span></p><p class="P94"><a href="http://farwestab.wordpress.com/2011/02/05/some-tips-on-android-and-bluetooth/" class="Internet_20_link"><span class="Internet_20_link">http://farwestab.wordpress.com/2011/02/05/some-tips-on-android-and-bluetooth/</span></a></p><h1 class="Heading_20_1"><a id="a__Communication__Phone_and_Text"><span/></a><a id="_Toc5236073"/>Communication: Phone and Text</h1><h2 class="Heading_20_2"><a id="a__Email_send__recipient_sexp____subject_sexp____body_sexp_"><span/></a><a id="_Toc5236074"/>Email.send &lt;recipient_sexp&gt;, &lt;subject_sexp&gt;, &lt;body_sexp&gt;</h2><p class="Standard">The email message in the Body string expression will be sent to the named recipient with the named subject heading.</p><h2 class="Heading_20_2"><a id="a__MyPhoneNumber__svar_"><span/></a><a id="_Toc5236075"/>MyPhoneNumber &lt;svar&gt;</h2><p class="Standard">The phone number of the Android device will be returned in the string variable. If the device is not connected to a cellular network, the returned value will be uncertain.</p><h2 class="Heading_20_2"><a id="a__Phone_call__sexp_"><span/></a><a id="_Toc5236076"/>Phone.call &lt;sexp&gt;</h2><p class="Standard">The phone number contained in the string expression will be called. Your device must be connected to a cellular network to make phone calls.</p><h2 class="Heading_20_2"><a id="a__Phone_dial__sexp_"><span/></a><a id="_Toc5236077"/>Phone.dial &lt;sexp&gt;</h2><p class="Standard">Open the phone dialer app. The phone number contained in the string expression will be displayed in the dialer. Alphabetic characters in the string will be converted to digits, as if the corresponding key of a phone pad had been touched.</p><h2 class="Heading_20_2"><a id="a__Phone_rcv_init"><span/></a><a id="_Toc5236078"/>Phone.rcv.init</h2><p class="Standard">Prepare to detect the state of your phone. If you want to detect phone calls using <span class="T7">Phone.rcv.next</span>, or you want <span class="T7">Phone.info</span> to attempt to report signal strength, you must first run this command.</p><p class="Standard"><span class="T7">Phone.rcv.init</span> starts a background "listener" task that detects changes in the phone state. There is no command to disable this listener, but it is stopped when your program exits.</p><h2 class="Heading_20_2"><a id="a__Phone_rcv_next__state_nvar____number_svar_"><span/></a><a id="_Toc5236079"/>Phone.rcv.next &lt;state_nvar&gt;, &lt;number_svar&gt;</h2><p class="Standard">The state of the phone will be returned in the state numeric value. A phone number may be returned in the string variable.</p><p class="Standard">State = 0. The phone is idle. The phone number will be an empty string.</p><p class="Standard">State = 1. The phone is ringing. The phone number will be in the string.</p><p class="Standard">State = 2. The phone is off hook. If there is no phone number (an empty string) then an outgoing call is being made. If there is a phone number then an incoming phone call is in progress.</p><p class="Standard">States 1 and 2 will be continuously reported as long the phone is ringing or the phone remains off hook.</p><h2 class="Heading_20_2"><a id="a__Note_on_Sms_Commands"><span/></a><a id="_Toc5236080"/>Note on Sms Commands</h2><p class="Standard">SMS commands send and receive text messages. The commands in this group require SMS permission. From Android 6 (Marshmallow) on, permissions may be controlled by the Android device user. If the user denies SMS permission, BASIC! cannot execute any SMS command. Trying to run an SMS command terminates your program with an error message stating that SMS permissions must be granted.</p><p class="Standard">The BASIC! Google Play Edition cannot be granted SMS permission, so it cannot run SMS commands. To write programs that read or write SMS messages, you must download the BASIC! Full Edition.</p><h2 class="Heading_20_2"><a id="a__Sms_send__number_sexp____message_sexp_"><span/></a><a id="_Toc5236081"/>Sms.send &lt;number_sexp&gt;, &lt;message_sexp&gt;</h2><p class="Standard">The SMS message in the string expression &lt;message_sexp&gt; will be sent to number in the string expression &lt;number_sexp&gt;. This command does not provide any feedback about the sending of the message. The device must be connected to a cellular network to send an SMS message.</p><h2 class="Heading_20_2"><a id="a__Sms_rcv_init"><span/></a><a id="_Toc5236082"/>Sms.rcv.init</h2><p class="Standard">Prepare to intercept received SMS using the sms.rcv.next command.</p><h2 class="Heading_20_2"><a id="a__Sms_rcv_next__svar_"><span/></a><a id="_Toc5236083"/>Sms.rcv.next &lt;svar&gt;</h2><p class="Standard">Read the next received SMS message from received SMS message queue in the string variable.</p><p class="Standard">The returned string will contain "@" if there is no SMS message in the queue.</p><p class="Standard">The sms.rcv.init command must be called before the first sms.rcv.next command is executed.</p><p class="Standard">Example:</p><p class="Code_20_example"><span class="T11">SMS.RCV.INIT</span></p><p class="Code_20_example"><span class="T11">DO</span></p><p class="P10"><span class="T11">DO % Loop until SMS received</span></p><p class="P10"><span class="T11">  PAUSE 5000 % Sleep of 5 seconds</span></p><p class="P10"><span class="T11">  SMS.RCV.NEXT m$ % Try to get a new message</span></p><p class="P10"><span class="T11">UNTIL m$ &lt;&gt; "@" % "@" indicates no new message</span></p><p class="P10"><span class="T11">PRINT m$ % Print the new message</span></p><p class="Code_20_example"><span class="T11">UNTIL 0   % Loop forever</span></p><h1 class="Heading_20_1"><a id="a__Time_and_Timers"><span/></a><a id="_Toc5236084"/>Time and Timers</h1><h2 class="Heading_20_2"><a id="a__Time_and_TimeZone_Commands"><span/></a><a id="_Toc5236085"/>Time and TimeZone Commands</h2><p class="Standard">The <span class="T7">TimeZone</span> commands allow you to manage the timezone used by the <span class="T7">Time</span> command and the <span class="T7">TIME(…)</span> function. They do not affect the no-parameter <span class="T7">TIME()</span> function. They affect only your BASIC! program, not any other time-related operation on your device.</p><p class="Standard">See also the time functions <span class="T7">CLOCK()</span> and <span class="T7">TIME()</span>.</p><h3 class="Heading_20_3"><a id="a__Time_{_time_nexp__}_Year$__Month$__Day$__Hour$__Minute$__Second$__WeekDay__isDST"><span/></a><a id="_Toc5236086"/>Time {&lt;time_nexp&gt;,} Year$, Month$, Day$, Hour$, Minute$, Second$, WeekDay, isDST</h3><p class="Standard">Returns the current (default) or specified date, time, weekday, and Daylight Saving Time flag in the variables.</p><p class="Standard">You can use the optional first parameter (&lt;time_nexp&gt;) to specify what time to return in the variables. It is a numeric expression number of milliseconds from 12:00:00 AM, January 1, 1970, UTC, as returned by the <span class="T7">TIME()</span> functions. It may be negative, indicating a time before that date.</p><p class="Standard">The day/date and time are returned as two-digit numeric strings with a leading zero when needed, except Year$ which is four characters.</p><p class="Standard">The WeekDay is a number from 1 to 7, where 1 means Sunday. You can use it to index an array of day names in your language of choice.</p><p class="P109">The isDST flag is</p><p class="P109">    1 if the current or specified time is in Daylight Saving Time in the current timezone</p><p class="P109">    0 if the time is not in Daylight Saving Time (is Standard Time)</p><p class="Standard">   -1 if the system can't tell if the time is in DST</p><p class="Standard">The current timezone is your local timezone unless you change it with the <span class="T7">TimeZone</span> commands.</p><p class="Standard">All of the return variables are optional. That is, you can omit any of them, but if you want to return only some of them, you need to retain their position by including commas for the omitted return variables. For example:</p><p class="Code_20_example"><span class="T11">t = TIME(2001, 2, 3, 4, 5, 6)</span></p><p class="Code_20_example"><span class="T11">Time t, Y$, M$, D$        % sets only the year, month, and day</span></p><p class="Code_20_example"><span class="T11">Time t, Y$, M$, D$,,,, W  % adds the day of the week (7, Saturday)</span></p><p class="Standard">To do the same with the current time, leave out both the first parameter and its comma:</p><p class="Code_20_example"><span class="T11">Time ,, day$,,,, wkday    % returns the today's day and weekday</span></p><h3 class="Heading_20_3"><a id="a__TimeZone_set_{__tz_sexp__}"><span/></a><a id="_Toc5236087"/>TimeZone.set { &lt;tz_sexp&gt; }</h3><p class="Standard">Sets the timezone for your program. If you don't specify a timezone, it is set to the default for your device, which is based on where you are. If you specify a timezone your device does not recognize, it is set to "GMT". (In Android, GMT is exactly the same as UTC).</p><h3 class="Heading_20_3"><a id="a__TimeZone_get__tz_svar_"><span/></a><a id="_Toc5236088"/>TimeZone.get &lt;tz_svar&gt;</h3><p class="Standard">Returns the current timezone in the string variable. This is the default timezone for your device and location, unless you have changed it with TimeZone.set.</p><h3 class="Heading_20_3"><a id="a__TimeZone_list__tz_list_pointer_nexp_"><span/></a><a id="_Toc5236089"/>TimeZone.list &lt;tz_list_pointer_nexp&gt;</h3><p class="Standard">While timezones are defined by international standards, the only ones that matter to your program are those recognized by your device. This command returns all valid timezone strings, putting them in the list that &lt;tz_list_pointer_nexp&gt; points at. The previous contents of the list are discarded. If the pointer does not specify a valid string list, and the expression is a numeric variable, a new list is created and the variable is set to point to the new list.</p><h2 class="Heading_20_2"><a id="a__Timer_Interrupt_and_Commands"><span/></a><a id="_Toc5236090"/>Timer Interrupt and Commands</h2><p class="Standard">You can set a timer that will interrupt the execution of your program at some set time interval. When the timer expires, BASIC! jumps to the statements following the <span class="T7">OnTimer:</span> label. When you have done whatever you need to do to handle this Timer event, you use the <span class="T7">Timer.resume</span> command to resume execution of the program at the point where the timer interrupt occurred.</p><p class="Standard">The timer cannot interrupt an executing command. When the timer expires, the current command is allowed to complete. Then the timer interrupt code after the <span class="T7">OnTimer:</span> label executes. If the current command takes a long time to finish, it may appear that your timer is late.</p><p class="Standard">The timer cannot interrupt another interrupt. If the timer expires while any interrupt event handler is running, the <span class="T7">OnTimer:</span> interrupt will be delayed. If the timer expires while the <span class="T7">OnTimer:</span> interrupt handler is running, the timer event will be lost. The <span class="T7">OnTimer:</span> interrupt code must exit by running <span class="T7">Timer.resume</span>, or the timer interrupt can occur only once.</p><h3 class="Heading_20_3"><a id="a__Timer_set__interval_nexp_"><span/></a><a id="_Toc5236091"/>Timer.set &lt;interval_nexp&gt;</h3><p class="Standard">Sets a timer that will repeatedly interrupt program execution after the specified time interval. The interval time units are milliseconds. The program must also contain an <span class="T7">OnTimer:</span> label.</p><h3 class="Heading_20_3"><a id="a__OnTimer_"><span/></a><a id="_Toc5236092"/>OnTimer:</h3><p class="Standard">Interrupt label for the timer interrupt. (See "Interrupt Labels" and "Timer Interrupts and Commands".)</p><h3 class="Heading_20_3"><a id="a__Timer_resume"><span/></a><a id="_Toc5236093"/>Timer.resume</h3><p class="Standard">Resumes execution at the point in the BASIC! program where the <span class="T7">OnTimer:</span> interrupt occurred.</p><h3 class="Heading_20_3"><a id="a__Timer_clear"><span/></a><a id="_Toc5236094"/>Timer.clear</h3><p class="Standard">Clears the repeating timer. No further timer interrupts will occur.</p><h3 class="Heading_20_3"><a id="a__Sample_Code"><span/></a><a id="_Toc5236095"/>Sample Code</h3><p class="Code_20_example"><span class="T12">n=0</span></p><p class="Code_20_example"><span class="T12">TIMER.SET 2000</span></p><p class="P3"> </p><p class="Code_20_example"><span class="T12">DO</span></p><p class="Code_20_example"><span class="T12">UNTIL n=4</span></p><p class="Code_20_example"><span class="T12">TIMER.CLEAR</span></p><p class="Code_20_example"><span class="T12">PRINT "Timer cleared. No further interrupts."</span></p><p class="Code_20_example"><span class="T12">DO</span></p><p class="Code_20_example"><span class="T12">UNTIL 0</span></p><p class="P3"> </p><p class="Code_20_example"><span class="T12">ONTIMER:</span></p><p class="Code_20_example"><span class="T12">n = n + 1</span></p><p class="Code_20_example"><span class="T12">PRINT n*2; " seconds"</span></p><p class="Code_20_example"><span class="T12">TIMER.RESUME</span></p><h1 class="Heading_20_1"><a id="a__Clipboard"><span/></a><a id="_Toc5236096"/>Clipboard</h1><h2 class="Heading_20_2"><a id="a__Clipboard_get__svar_"><span/></a><a id="_Toc5236097"/>Clipboard.get &lt;svar&gt;</h2><p class="Standard">Copies the current contents of the clipboard into &lt;svar&gt;</p><h2 class="Heading_20_2"><a id="a__Clipboard_put__sexp_"><span/></a><a id="_Toc5236098"/>Clipboard.put &lt;sexp&gt;</h2><p class="Standard">Places &lt;sexp&gt; into the clipboard.</p><h1 class="Heading_20_1"><a id="a__Encryption"><span/></a><a id="_Toc5236099"/>Encryption</h1><p class="Standard">Encrypts and decrypts a string using a supplied password. The encryption algorithm used is "PBEWithMD5AndDES".</p><h2 class="Heading_20_2"><a id="a__Encrypt_{_pw_sexp_}___source_sexp____encrypted_svar_"><span/></a><a id="_Toc5236100"/>Encrypt {&lt;pw_sexp&gt;}, &lt;source_sexp&gt;, &lt;encrypted_svar&gt;</h2><p class="Standard">Encrypts the string &lt;source_sexp&gt; using the password &lt;pw_sexp&gt;. The result is placed into the variable &lt;encrypted_svar&gt;.</p><p class="Standard">The password parameter is optional, but its comma is required. Omitting the password is the same as using an empty string, "".</p><p class="Standard">If the source string cannot be encrypted, the result is an empty string (""). You can call the <span class="T7">GETERROR$()</span> function to get an error message.</p><p class="Standard">This command is the same as <span class="T7">ENCODE$("ENCRYPT", &lt;pw_sexp&gt;, &lt;source_sexp&gt;)</span>.</p><h2 class="Heading_20_2"><a id="a__Decrypt__pw_sexp____encrypted_sexp____decrypted_svar_"><span/></a><a id="_Toc5236101"/>Decrypt &lt;pw_sexp&gt;, &lt;encrypted_sexp&gt;, &lt;decrypted_svar&gt;</h2><p class="Standard">Decrypts the encrypted string &lt;encrypted_sexp&gt; using the password &lt;pw_sexp&gt;. The result is placed in &lt;decrypted_svar&gt;.</p><p class="Standard">The password parameter is optional, but its comma is required. Omitting the password is the same as using an empty string, "".</p><p class="Standard">If the source string cannot be decoded with the specified password, the result is an empty string (""). You can call the <span class="T7">GETERROR$()</span> function to get an error message.</p><p class="Standard">This command is the same as <span class="T7">DECODE$("ENCRYPT", &lt;pw_sexp&gt;, &lt;source_sexp&gt;)</span>.</p><h1 class="Heading_20_1"><a id="a__Ringer"><span/></a><a id="_Toc5236102"/>Ringer</h1><p class="Standard">Android devices support three ringtone modes:</p><table border="0" cellspacing="0" cellpadding="0" class="Table19"><colgroup><col width="124"/><col width="151"/><col width="291"/></colgroup><tr class="Table191"><td style="text-align:left;width:2.845cm; " class="Table19_A1"><p class="P120">Value:</p></td><td style="text-align:left;width:3.448cm; " class="Table19_A1"><p class="P120">Meaning:</p></td><td style="text-align:left;width:6.669cm; " class="Table19_A1"><p class="P120">Behavior</p></td></tr><tr class="Table191"><td style="text-align:left;width:2.845cm; " class="Table19_A1"><p class="P110">0</p></td><td style="text-align:left;width:3.448cm; " class="Table19_A1"><p class="P110">Silent</p></td><td style="text-align:left;width:6.669cm; " class="Table19_A1"><p class="P110">Ringer is silent and does not vibrate</p></td></tr><tr class="Table191"><td style="text-align:left;width:2.845cm; " class="Table19_A1"><p class="P110">1</p></td><td style="text-align:left;width:3.448cm; " class="Table19_A1"><p class="P110">Vibrate</p></td><td style="text-align:left;width:6.669cm; " class="Table19_A1"><p class="P110">Ringer is silent but vibrates</p></td></tr><tr class="Table191"><td style="text-align:left;width:2.845cm; " class="Table19_A1"><p class="P110">2</p></td><td style="text-align:left;width:3.448cm; " class="Table19_A1"><p class="P110">Normal</p></td><td style="text-align:left;width:6.669cm; " class="Table19_A1"><p class="P110">Ringer may be audible and may vibrate</p></td></tr></table><p class="P102">"Normal" behavior depends on other device settings set by the user.</p><p class="P102">Ringer volume is an integer number from zero to a device-dependent maximum. If the volume is zero the ringer is silent.</p><p class="P102">NOTE: These are system settings. Any change you make persists after your program ends. You may want to record the original settings and change them back when the program exits.</p><h2 class="Heading_20_2"><a id="a__Ringer_get_mode__nvar_"><span/></a><a id="_Toc5236103"/>Ringer.get.mode &lt;nvar&gt;</h2><p class="Standard">Returns the current ringtone mode in the numeric variable.</p><h2 class="Heading_20_2"><a id="a__Ringer_set_mode__nexp_"><span/></a><a id="_Toc5236104"/>Ringer.set.mode &lt;nexp&gt;</h2><p class="Standard">Changes the ringtone mode to the specified value. If the value is not a valid mode, the device mode is not changed.</p><h2 class="Heading_20_2"><a id="a__Ringer_get_volume__vol_nvar__{____max_nvar__}"><span/></a><a id="_Toc5236105"/>Ringer.get.volume &lt;vol_nvar&gt; { , &lt;max_nvar&gt; }</h2><p class="Standard">Returns the ringer volume level in the numeric variable. Returns the maximum volume settting in &lt;max_nvar&gt;, if &lt;max_nvar&gt; is present.</p><h2 class="Heading_20_2"><a id="a__Ringer_set_volume__nexp_"><span/></a><a id="_Toc5236106"/>Ringer.set.volume &lt;nexp&gt;</h2><p class="Standard">Changes the ringer volume to the specified value. If the value is less than zero, volume is set to zero. If the value is greater than the device-specific maximum, the volume is set to the maximum level.</p><h1 class="Heading_20_1"><a id="a__String_Operations"><span/></a><a id="_Toc5236107"/>String Operations</h1><p class="Standard"><span class="T7">Split</span> and <span class="T7">Join</span> are complementary operations. <span class="T7">Split</span> separates a string into parts and put the parts in an array. <span class="T7">Join</span> builds a string by combining the elements of an array.</p><p class="Standard">See also the various String Functions.</p><h2 class="Heading_20_2"><a id="a__Join__source_array$______result_svar__{___separator_sexp_{___wrapper_sexp}}"><span/></a><a id="_Toc5236108"/>Join &lt;source_array$[]&gt;, &lt;result_svar&gt; {, &lt;separator_sexp&gt;{, &lt;wrapper_sexp}}</h2><h2 class="Heading_20_2"><a id="a__Join_all__source_array$______result_svar__{___separator_sexp_{___wrapper_sexp}}"><span/></a><a id="_Toc5236109"/>Join.all &lt;source_array$[]&gt;, &lt;result_svar&gt; {, &lt;separator_sexp&gt;{, &lt;wrapper_sexp}}</h2><p class="Standard">The elements of the &lt;source_array$[]&gt; are joined together as a single string in the &lt;result_svar&gt;. By default, the source elements are joined with nothing between them or around them.</p><p class="Standard">You may specify optional modifiers that add characters to the string. Copies of the separator string &lt;separator_sexp&gt; are written between source elements. Copies of the wrapper string &lt;wrapper_sexp&gt; are placed before and after the rest of the result string.</p><p class="Standard">The <span class="T7">Join</span> command omits any empty source elements. The <span class="T7">Join.all</span> command includes all source elements in the result string, even if they are empty. There is no difference between the two commands unless you specify a non-empty separator string. <span class="T7">Join.all</span> places copies of the separator between all of the elements, including the empty ones.</p><p class="Standard">An example of an operation that uses both separators and wrappers is a CSV string, for "comma-separated values".</p><p class="Code_20_example"><span class="T11">InnerPlanets$ = "Mercury Venus Earth Mars"</span></p><p class="Code_20_example"><span class="T11">SPLIT IP$[], InnerPlanets$</span></p><p class="Code_20_example"><span class="T11">JOIN IP$[], PlanetsCSV$, "\",\"", "\""</span></p><p class="Code_20_example"><span class="T11">PRINT PlanetsCSV$</span></p><p class="Standard">This prints the string <span class="T16">"Mercury","Venus","Earth","Mars"</span> (including all of the quotes). The separator puts the <span class="T16">","</span> between planet names, and the wrapper puts the <span class="T16">"</span> at the beginning and end of the string.</p><h2 class="Heading_20_2"><a id="a__Split__result_array$______sexp__{___test_sexp_}"><span/></a><a id="_Toc5236110"/>Split &lt;result_array$[]&gt;, &lt;sexp&gt; {, &lt;test_sexp&gt;}</h2><h2 class="Heading_20_2"><a id="a__Split_all__result_array$______sexp__{___test_sexp_}"><span/></a><a id="_Toc5236111"/>Split.all &lt;result_array$[]&gt;, &lt;sexp&gt; {, &lt;test_sexp&gt;}</h2><p class="Standard">Splits the source string &lt;sexp&gt; into multiple strings and place them into &lt;result_array$[]&gt;. The array is specified without an index. If the array exists, it is overwritten. Otherwise a new array is created. The result is always a one-dimensional array.</p><p class="Standard">The string is split at each location where &lt;test_sexp&gt; occurs. The &lt;test_sexp&gt; occurrences are removed from the result strings. The &lt;text_sexp&gt; parameter is optional; if it is not given, the string is split on whitespace. Omitting the parameter is equivalent to specifying "\\s+".</p><p class="Standard">If the beginning of the source string matches the test string, the first element of the result array will be an empty string. This differs from the <span class="T7">WORD$()</span> function, which strips leading and trailing occurrences of the test string from the source string before splitting.</p><p class="Standard">Two adjacent occurrences of the test expression in the source expression result in an empty element somewhere in the result array. The <span class="T7">Split</span> command discards these empty strings if they occur at the end of the result array. To keep these trailing empty strings, use the <span class="T7">Split.all</span> command.</p><p class="No_20_Spacing">Example:</p><p class="Code_20_example"><span class="T11">string$ = "a:b:c:d"</span></p><p class="Code_20_example"><span class="T11">delimiter$ = ":"</span></p><p class="Code_20_example"><span class="T11">SPLIT result$[], string$, delimiter$</span></p><p class="P2"> </p><p class="Code_20_example"><span class="T11">ARRAY.LENGTH length, result$[]</span></p><p class="Code_20_example"><span class="T11">FOR i = 1 TO length</span></p><p class="Code_20_example"><span class="T11">PRINT result$[i] + " ";</span></p><p class="Code_20_example"><span class="T11">NEXT i</span></p><p class="Code_20_example"><span class="T11">PRINT ""</span></p><p class="Standard">Prints: <span class="T15">a b c d</span></p><p class="Standard">Note: The &lt;test_sexp&gt; is actually a Regular Expression. If you are not getting the results that you expect from the &lt;test_sexp&gt; then you should examine the rules for Regular Expressions at:</p><p class="P94"><a href="http://developer.android.com/reference/java/util/regex/Pattern.html" class="Internet_20_link"><span class="Internet_20_link">http://developer.android.com/reference/java/util/regex/Pattern.html</span></a></p><h1 class="Heading_20_1"><a id="a__Speech_Conversion"><span/></a><a id="_Toc5236112"/>Speech Conversion</h1><h2 class="Heading_20_2"><a id="a__Text_To_Speech"><span/></a><a id="_Toc5236113"/>Text To Speech</h2><p class="Standard">Your program can synthesize speech from text, either for immediate playback with the <span class="T7">TTS.speak</span> command or to create a sound file with <span class="T7">TTS.speak.toFile</span>.</p><p class="Standard">Your device may come with the text-to-speech engine already enabled and configured, or you may need to set it up yourself in the Android Settings application. The details vary between different devices and versions of Android. Typically, the menu navigation looks like one of these:</p><p class="P95">Settings <span class="T27"></span> Voice input &amp; output <span class="T27"></span> Text-to-speech settings</p><p class="P94">Settings <span class="T27"></span> Language &amp; input <span class="T27"></span> Text-to-speech output</p><p class="Standard">Unless you set an output language in the text-to-speech settings, the speech generated will be spoken in the current default language of the device. The menu path for setting the default language usually looks like one of these:</p><p class="P95">Settings <span class="T27"></span> Language and keyboard <span class="T27"></span> Select language</p><p class="P94">Settings <span class="T27"></span> Language &amp; input <span class="T27"></span> Language</p><p class="Standard">Most speech engines limit the number of characters they are able to speak. The limit is not the same for all devices or all speech engines, but it is typically around 4000 characters. If you exceed the limit, most engines fail silently: you don’t get an error message, but you don’t get any speech output, either. </p><h3 class="Heading_20_3"><a id="a__TTS_init"><span/></a><a id="_Toc5236114"/>TTS.init</h3><p class="Standard">This command must be executed before speaking.</p><h3 class="Heading_20_3"><a id="a__TTS_speak__sexp__{___wait_lexp_}"><span/></a><a id="_Toc5236115"/>TTS.speak &lt;sexp&gt; {, &lt;wait_lexp&gt;}</h3><p class="Standard">Speaks the string expression. The statement does not return until the string has been fully spoken, unless the optional "wait" parameter is present and evaluates to false (numeric 0). Spoken expressions cannot overlap. A second <span class="T7">TTS.speak</span> (or a <span class="T7">TTS.speak.toFile</span>) will wait for the speech from an earlier <span class="T7">TTSts.speak</span> to finish, even if the "wait" flag was false.</p><h3 class="Heading_20_3"><a id="a__TTS_speak_toFile__sexp__{___path_sexp_}"><span/></a><a id="_Toc5236116"/>TTS.speak.toFile &lt;sexp&gt; {, &lt;path_sexp&gt;}</h3><p class="Standard">Converts the string expression to speech and writes it into a wav file. You can specify the name and location of the file with the optional "path" parameter. The default path is "&lt;pref base drive&gt;/rfo-basic/data/tts.wav". The statement does not return until the speech synthesis is complete, but there is no guarantee the file-write is finished. If a previous <span class="T7">TTS.speak</span> is still speaking, this statement will not start until that speech completes.</p><h3 class="Heading_20_3"><a id="a__TTS_stop"><span/></a><a id="_Toc5236117"/>TTS.stop</h3><p class="Standard">Waits for any outstanding speech to finish, then releases Android's text-to-speech engine. Following <span class="T7">TTS.stop</span>, if you want to run <span class="T7">TTS.speak</span> or <span class="T7">TTS.speak.toFile</span> again, you will have to run <span class="T7">TTS.init</span> again.</p><h2 class="Heading_20_2"><a id="a__Speech_To_Text__Voice_Recognition_"><span/></a><a id="_Toc5236118"/>Speech To Text (Voice Recognition)</h2><p class="Standard">The Voice Recognition function on Android uses Google Servers to perform the recognition. This means that you must be connected to the Internet and logged into your Google account for this feature to work.</p><p class="Standard">There are two commands for Speech to Text: <span class="T7">STT.listen</span> and <span class="T7">STT.results</span>.</p><p class="Standard"><span class="T7">STT.listen</span> starts the voice recognition process with a dialog box. <span class="T7">STT.results</span> reports the interpretation of the voice with a list of strings.</p><p class="Standard">The Speech to Text procedures are different for Graphics Mode, HTML mode and simple Console Output mode.</p><h3 class="Heading_20_3"><a id="a__STT_listen_{_prompt_sexp_}"><span/></a><a id="_Toc5236119"/>STT.listen {&lt;prompt_sexp&gt;}</h3><p class="Standard">Start the voice recognize process by displaying a "Speak Now" dialog box. The optional prompt string expression &lt;prompt_sexp&gt; sets the dialog box’s prompt. If you do not provide the prompt parameter, the default prompt "BASIC! Speech To Text" is used.</p><p class="Standard">Begin speaking when the dialog box appers.</p><p class="Standard">The recognition will stop when there is a pause in the speaking.</p><p class="Standard"><span class="T7">STT.results</span> should be executed next.</p><p class="Standard">Note: <span class="T7">STT.listen</span> is <span class="T22">not</span> to be used in HTML mode.</p><p class="Standard"><a id="_Toc5236120"/><span class="Heading_20_3_20_Char">STT.results &lt;string_list_ptr_nexp&gt;</span></p><p class="Standard">The command must not be executed until after a <span class="T7">STT.listen</span> is executed (unless in HTML mode).</p><p class="Standard">The recognizer returns several variations of what it thinks it heard as a list of strings. The first string in the list is the best guess.</p><p class="Standard">The strings are written into the list that &lt;string_list_ptr_nexp&gt; points to. The previous contents of the list are discarded. If the pointer does not specify a valid string list, and the expression is a numeric variable, a new list is created and the variable is set to point to the new list.</p><h4 class="Heading_20_4"><a id="a__Console_Mode"><span/></a>Console Mode</h4><p class="Standard">The following code illustrates the command in Output Console (not HTML mode and not Graphics mode):</p><p class="Code_20_example"><span class="T12">PRINT "Starting Recognizer"</span></p><p class="Code_20_example"><span class="T12">STT.LISTEN</span></p><p class="Code_20_example"><span class="T12">STT.RESULTS theList</span></p><p class="Code_20_example"><span class="T12">LIST.SIZE theList, theSize</span></p><p class="Code_20_example"><span class="T12">FOR k = 1 TO theSize</span></p><p class="Code_20_example"><span class="T12">        LIST.GET theList, k, theText$</span></p><p class="Code_20_example"><span class="T12">        PRINT theText$</span></p><p class="Code_20_example"><span class="T12">NEXT k</span></p><p class="Code_20_example"><span class="T12">END</span></p><h4 class="Heading_20_4"><a id="a__Graphics_Mode"><span/></a><span class="T55">Graphics Mode</span></h4><p class="Standard">This command sequence is to be used in graphics mode. Graphics mode exists after <span class="T7">Gr.open</span> and before <span class="T7">Gr.close</span>. (Note: Graphics mode is temporarily exited after <span class="T7">Gr.front 0</span>. Use the Console Mode if you have called <span class="T7">Gr.front 0</span>).</p><p class="Standard">The primary difference is that <span class="T7">Gr.render</span> <span class="T22">must</span> be called after <span class="T7">STT.listen</span> and before <span class="T7">STT.results</span>.</p><p class="Code_20_example"><span class="T11">PRINT "Starting Recognizer"</span></p><p class="Code_20_example"><span class="T11">STT.LISTEN</span></p><p class="Code_20_example"><span class="T11">GR.RENDER</span></p><p class="Code_20_example"><span class="T11">STT.RESULTS theList</span></p><p class="Code_20_example"><span class="T11">LIST.SIZE theList, theSize</span></p><p class="Code_20_example"><span class="T11">FOR k =1 TO theSize</span></p><p class="P10"><span class="T11">LIST.GET theList, k, theText$</span></p><p class="P10"><span class="T11">PRINT theText$</span></p><p class="Code_20_example"><span class="T11">NEXT k</span></p><p class="Code_20_example"><span class="T11">END</span></p><h4 class="Heading_20_4"><a id="a__HTML_Mode"><span/></a><span class="T55">HTML Mode</span></h4><p class="Standard">This command sequence is used while in HTML mode. HTML mode exists after <span class="T7">HTML.open</span> and before <span class="T7">HTML.close</span>.</p><p class="Standard">The primary difference is that the <span class="T7">STT.listen</span> command is <span class="T18">not</span> used in HTML mode. The <span class="T7">STT.listen</span> function is performed by means of an HTML datalink sending back the string "STT". The sending of "STT" by means of the datalink causes the Speak Now dialog box to be displayed.</p><p class="Standard">When the datalink "STT" string is received by the BASIC! program, the <span class="T7">STT.results</span> command can be executed normally as it will contain the recognized text.</p><p class="Standard">The sample file, f37_html_demo.bas, along with the associated html file, htmlDemo1.html (located in "rfo-basic/data/") demonstrates the use of voice recognition in HTML mode.</p><h1 class="Heading_20_1"><a id="a__Information_About_Your_Android_Device"><span/></a><a id="_Toc5236121"/>Informat<span class="Heading_20_1_20_Char">i</span>on About Your Android Device</h1><h2 class="Heading_20_2"><a id="a__Device_Command_Overview"><span/></a><a id="_Toc5236122"/>Device Command Overview</h2><p class="Standard">You can get information about your Android device with the <span class="T7">Device</span> command:</p><ul><li><p class="P41" style="margin-left:1.27cm;"><span class="ListLabel_20_29" style="display:block;float:left;min-width:0.635cm;"></span>The Device Brand, Device Model, Device Type, and OS<span class="odfLiEnd"/> </p></li><li><p class="P41" style="margin-left:1.27cm;"><span class="ListLabel_20_29" style="display:block;float:left;min-width:0.635cm;"></span>The Language and Locale<span class="odfLiEnd"/> </p></li><li><p class="P41" style="margin-left:1.27cm;"><span class="ListLabel_20_29" style="display:block;float:left;min-width:0.635cm;"></span>The PhoneType, PhoneNumber, and DeviceID<span class="odfLiEnd"/> </p></li><li><p class="P41" style="margin-left:1.27cm;"><span class="ListLabel_20_29" style="display:block;float:left;min-width:0.635cm;"></span>The SN, MCC/MNC, and Network Provider stored on the SIM, if there is one.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">The <span class="T7">Device</span> command has two forms that differ only in the type of the parameter, which determines the format of the returned data. Both forms return the same information, as shown in this table:</p><table border="0" cellspacing="0" cellpadding="0" class="Table20"><colgroup><col width="128"/><col width="135"/><col width="283"/><col width="160"/></colgroup><tr class="Table201"><td style="text-align:left;width:2.926cm; " class="Table20_A1"><p class="P120">Key</p></td><td style="text-align:left;width:3.096cm; " class="Table20_A1"><p class="P120">Values</p></td><td style="text-align:left;width:6.484cm; " class="Table20_A1"><p class="P120">Meaning</p></td><td style="text-align:left;width:3.651cm; " class="Table20_A1"><p class="P110"><span class="T7">Example</span><br/>(from emulator)</p></td></tr><tr class="Table202"><td style="text-align:left;width:2.926cm; " class="Table20_A2"><p class="P120">Brand</p></td><td style="text-align:left;width:3.096cm; " class="Table20_A2"><p class="P110">Any string</p></td><td style="text-align:left;width:6.484cm; " class="Table20_A2"><p class="P114">Brand name assigned by device manufacturer</p></td><td style="text-align:left;width:3.651cm; " class="Table20_A2"><p class="P110">generic</p></td></tr><tr class="Table202"><td style="text-align:left;width:2.926cm; " class="Table20_A2"><p class="P120">Model</p></td><td style="text-align:left;width:3.096cm; " class="Table20_A2"><p class="P110">Any string</p></td><td style="text-align:left;width:6.484cm; " class="Table20_A2"><p class="P114">Model identifier assigned by device manufacturer</p></td><td style="text-align:left;width:3.651cm; " class="Table20_A2"><p class="P110">sdk</p></td></tr><tr class="Table201"><td style="text-align:left;width:2.926cm; " class="Table20_A2"><p class="P120">Device</p></td><td style="text-align:left;width:3.096cm; " class="Table20_A2"><p class="P110">Any string</p></td><td style="text-align:left;width:6.484cm; " class="Table20_A2"><p class="P114">Device identifier assigned by device manufacturer</p></td><td style="text-align:left;width:3.651cm; " class="Table20_A2"><p class="P110">generic</p></td></tr><tr class="Table201"><td style="text-align:left;width:2.926cm; " class="Table20_A2"><p class="P120">Product</p></td><td style="text-align:left;width:3.096cm; " class="Table20_A2"><p class="P110">Any string</p></td><td style="text-align:left;width:6.484cm; " class="Table20_A2"><p class="P114">Product identifier assigned by device manufacturer</p></td><td style="text-align:left;width:3.651cm; " class="Table20_A2"><p class="P110">sdk</p></td></tr><tr class="Table201"><td style="text-align:left;width:2.926cm; " class="Table20_A2"><p class="P120">OS</p></td><td style="text-align:left;width:3.096cm; " class="Table20_A2"><p class="P110">OS Version</p></td><td style="text-align:left;width:6.484cm; " class="Table20_A2"><p class="P114">Android operating system version number</p></td><td style="text-align:left;width:3.651cm; " class="Table20_A2"><p class="P110">4.1.2</p></td></tr><tr class="Table201"><td style="text-align:left;width:2.926cm; " class="Table20_A2"><p class="P120">Language</p></td><td style="text-align:left;width:3.096cm; " class="Table20_A2"><p class="P110">Language name</p></td><td style="text-align:left;width:6.484cm; " class="Table20_A2"><p class="P114">Default language of this device</p></td><td style="text-align:left;width:3.651cm; " class="Table20_A2"><p class="P110">English</p></td></tr><tr class="Table201"><td style="text-align:left;width:2.926cm; " class="Table20_A2"><p class="P120">Locale</p></td><td style="text-align:left;width:3.096cm; " class="Table20_A2"><p class="P110">Locale code</p></td><td style="text-align:left;width:6.484cm; " class="Table20_A2"><p class="P114">Default locale code, typically language and country</p></td><td style="text-align:left;width:3.651cm; " class="Table20_A2"><p class="P110">en_US</p></td></tr><tr class="Table201"><td style="text-align:left;width:2.926cm; " class="Table20_A2"><p class="P120">PhoneType</p></td><td style="text-align:left;width:3.096cm; " class="Table20_A2"><p class="P110"><span class="T7">GSM</span>, <span class="T7">CDMA</span>, <span class="T7">SIP</span>, or <span class="T7">None</span></p></td><td style="text-align:left;width:6.484cm; " class="Table20_A2"><p class="P114">Type of phone radio in this device</p></td><td style="text-align:left;width:3.651cm; " class="Table20_A2"><p class="P110">GSM</p></td></tr><tr class="Table201"><td style="text-align:left;width:2.926cm; " class="Table20_A2"><p class="P120">PhoneNumber</p></td><td style="text-align:left;width:3.096cm; " class="Table20_A2"><p class="P110">String of digits</p></td><td style="text-align:left;width:6.484cm; " class="Table20_A2"><p class="P114">Phone number registered to this device, if any</p></td><td style="text-align:left;width:3.651cm; " class="Table20_A2"><p class="P110">15555215554</p></td></tr><tr class="Table201"><td style="text-align:left;width:2.926cm; " class="Table20_A2"><p class="P120">DeviceID</p></td><td style="text-align:left;width:3.096cm; " class="Table20_A2"><p class="P110">String of digits</p></td><td style="text-align:left;width:6.484cm; " class="Table20_A2"><p class="P114">The unique device ID, such as the IMEI</p></td><td style="text-align:left;width:3.651cm; " class="Table20_A2"><p class="P110">000000000000000</p></td></tr><tr class="Table201"><td style="text-align:left;width:2.926cm; " class="Table20_A2"><p class="P120">SIM SN</p></td><td style="text-align:left;width:3.096cm; " class="Table20_A2"><p class="P110">String of digits or <span class="T7">Not available</span></p></td><td style="text-align:left;width:6.484cm; " class="Table20_A2"><p class="P114">Serial number of the SIM card,<br/>if one is present and it is accessible</p></td><td style="text-align:left;width:3.651cm; " class="Table20_A2"><p class="P110">89014103211118510720</p></td></tr><tr class="Table201"><td style="text-align:left;width:2.926cm; " class="Table20_A2"><p class="P120">SIM MCC/MNC</p></td><td style="text-align:left;width:3.096cm; " class="Table20_A2"><p class="P110">String of digits or <span class="T7">Not available</span></p></td><td style="text-align:left;width:6.484cm; " class="Table20_A2"><p class="P114">The "numeric name" of the provider of the SIM, if present and accessible</p></td><td style="text-align:left;width:3.651cm; " class="Table20_A2"><p class="P110">310260</p></td></tr><tr class="Table201"><td style="text-align:left;width:2.926cm; " class="Table20_A2"><p class="P120">SIM Provider</p></td><td style="text-align:left;width:3.096cm; " class="Table20_A2"><p class="P110">Name string or <span class="T7">Not available</span></p></td><td style="text-align:left;width:6.484cm; " class="Table20_A2"><p class="P114">The name of the provider of the SIM, if present and accessible</p></td><td style="text-align:left;width:3.651cm; " class="Table20_A2"><p class="P110">Android</p></td></tr></table><p class="P102"><span class="T56">The last six items access your device’s telephony system and SIM card. If your device has no telephone, or BASIC! does not have permission to access them, the fields are set to neutral values: "None", "Not available", or a string of "0" characters.</span></p><p class="Standard">In addition, there are convenience commands to retrieve only the Locale or the Language.</p><p class="Standard">The information returned by <span class="T7">Device</span> is static. To get dynamic information, use the <span class="T7">Phone.Info</span> command.</p><h3 class="Heading_20_3"><a id="a__Device__svar_"><span/></a><a id="_Toc5236123"/>Device &lt;svar&gt; </h3><p class="Standard">Returns information about your Android device in the string variable &lt;svar&gt;. Each item has this form:</p><p class="Code_20_example"><span class="T11">key = value</span></p><p class="Standard">The names <span class="T10">key</span> and <span class="T10">value</span> refer to the first two columns of the table in the <span class="T7">Device</span> overview above. The items are placed in a single string, separated by newline characters. Formatted this way, if you <span class="T7">Print</span> the string it is displayed with one item on each line. You can separate the individual items with <span class="T7">Split</span>:</p><p class="Code_20_example"><span class="T11">DEVICE info$                                % all info in one string</span></p><p class="Code_20_example"><span class="T11">SPLIT info$[], info$, "</span><a href="./../..//n" class="Internet_20_link"><span class="Internet_20_link"><span class="T11">\\n</span></span></a><span class="T11">"                % each array element is one item, "&lt;k&gt; = &lt;v&gt;"</span></p><p class="Code_20_example"><span class="T11">SPLIT lang_line$[], info$[6], " = "        % split the Language item, two-element array</span></p><p class="Code_20_example"><span class="T11">lang$ = lang_line$[2]                        % lang$ is the language name, like "English"</span></p><h3 class="Heading_20_3"><a id="a__Device__nexp_|_nvar_"><span/></a><a id="_Toc5236124"/>Device &lt;nexp&gt;|&lt;nvar&gt;</h3><p class="Standard">Returns information about your Android device in a Bundle. If you provide a variable that is not a valid Bundle pointer, the command creates a new Bundle and returns the Bundle pointer in your variable. Otherwise it writes into the Bundle your variable or expression points to.</p><p class="Standard">The Bundle keys are shown in the first column of the table in the <span class="T7">Device</span> overview above.</p><p class="Code_20_example"><span class="T11">DEVICE info                                % all info in a Bundle</span></p><p class="Code_20_example"><span class="T11">BUNDLE.GET info, "Language", lang$        % lang$ is the language name, like "English"</span></p><h3 class="Heading_20_3"><a id="a__Device_Language__svar_"><span/></a><a id="_Toc5236125"/>Device.Language &lt;svar&gt;</h3><p class="Standard">Returns the default language of the device as a human-readable string value in string variable &lt;svar&gt;.</p><p class="Standard">This convenience shortcut returns the same value as the "Language" key of the Bundle returned by the numeric form of the <span class="T7">Device</span> command.</p><h3 class="Heading_20_3"><a id="a__Device__Locale__svar_"><span/></a><a id="_Toc5236126"/>Device. Locale &lt;svar&gt;</h3><p class="Standard">Returns the default locale code of the device in standard Locale format, typically including the language and country codes.</p><p class="Standard">This convenience shortcut returns the same value as the "Locale" key of the Bundle returned by the numeric form of the <span class="T7">Device</span> command.</p><h2 class="Heading_20_2"><a id="a__Phone_info__nexp_|_nvar_"><span/></a><a id="_Toc5236127"/>Phone.info &lt;nexp&gt;|&lt;nvar&gt;</h2><p class="Standard">Returns information about the telephony radio in your Android device, if it has one. The information is placed in a Bundle. If you provide a variable that is not a valid Bundle pointer, the command creates a new Bundle and returns the Bundle pointer in your variable. Otherwise it writes into the Bundle your variable or expression points to.</p><p class="P143">The Bundle keys and possible values are in the table below. Each entry’s type is either N (Numeric) or S (String).</p><table border="0" cellspacing="0" cellpadding="0" class="Table21"><colgroup><col width="117"/><col width="51"/><col width="247"/><col width="215"/><col width="104"/></colgroup><tr class="Table211"><td style="text-align:left;width:2.686cm; " class="Table21_A1"><p class="P139">Key</p></td><td style="text-align:left;width:1.169cm; " class="Table21_A1"><p class="P139">Type</p></td><td style="text-align:left;width:5.657cm; " class="Table21_A1"><p class="P139">Values</p></td><td style="text-align:left;width:4.921cm; " class="Table21_A1"><p class="P139">Meaning</p></td><td style="text-align:left;width:2.372cm; " class="Table21_A1"><p class="P140"><span class="T7">Example</span></p></td></tr><tr class="Table211"><td style="text-align:left;width:2.686cm; " class="Table21_A2"><p class="P139">PhoneType</p></td><td style="text-align:left;width:1.169cm; " class="Table21_A2"><p class="P140">S</p></td><td style="text-align:left;width:5.657cm; " class="Table21_A2"><p class="P140"><span class="T7">GSM</span>, <span class="T7">CDMA</span>, <span class="T7">SIP</span>, or <span class="T7">None</span></p></td><td style="text-align:left;width:4.921cm; " class="Table21_A2"><p class="P141">Type of phone radio in this device</p></td><td style="text-align:left;width:2.372cm; " class="Table21_A2"><p class="P140">GSM</p></td></tr><tr class="Table211"><td style="text-align:left;width:2.686cm; " class="Table21_A2"><p class="P139">NetworkType</p></td><td style="text-align:left;width:1.169cm; " class="Table21_A2"><p class="P140">S</p></td><td style="text-align:left;width:5.657cm; " class="Table21_A2"><p class="P140"><span class="T7">GPRS</span>, <span class="T7">EDGE</span>, <span class="T7">UMTS</span>, <span class="T7">CDMA</span>, <span class="T7">EVDOrev0</span>, <span class="T7">EVDOrevA</span>,</p><p class="P140"><span class="T7">1xRTT</span>, <span class="T7">HSDPA</span>, <span class="T7">HSUPA</span>, <span class="T7">HSPA</span>, <span class="T7">iDen</span>, <span class="T7">EDVOrevB</span>, <span class="T7">LTE</span>, <span class="T7">EHRPD</span>, <span class="T7">HSPAP+</span>, or <span class="T7">Unknown</span></p></td><td style="text-align:left;width:4.921cm; " class="Table21_A2"><p class="P141">Network type of the current data connection</p></td><td style="text-align:left;width:2.372cm; " class="Table21_A2"><p class="P140">LTE</p></td></tr></table><p class="P102">The <span class="T7">PhoneType</span> is the same as that returned by the <span class="T7">Device</span> command. It is static.</p><p class="P103">If the <span class="T7">PhoneType</span> is <span class="T7">GSM</span> and the phone is registered to a network, the <span class="T7">Phone.info</span> command also returns the following items in the Bundle:</p><table border="0" cellspacing="0" cellpadding="0" class="Table22"><colgroup><col width="117"/><col width="51"/><col width="247"/><col width="215"/><col width="104"/></colgroup><tr class="Table221"><td style="text-align:left;width:2.686cm; " class="Table22_A1"><p class="P139">Key</p></td><td style="text-align:left;width:1.169cm; " class="Table22_A1"><p class="P139">Type</p></td><td style="text-align:left;width:5.657cm; " class="Table22_A1"><p class="P139">Values</p></td><td style="text-align:left;width:4.921cm; " class="Table22_A1"><p class="P139">Meaning</p></td><td style="text-align:left;width:2.372cm; " class="Table22_A1"><p class="P140"><span class="T7">Example</span></p></td></tr><tr class="Table221"><td style="text-align:left;width:2.686cm; " class="Table22_A2"><p class="P139">CID</p></td><td style="text-align:left;width:1.169cm; " class="Table22_A2"><p class="P140">N</p></td><td style="text-align:left;width:5.657cm; " class="Table22_A2"><p class="P140">A positive number<br/>or -1 if CID is unknown</p></td><td style="text-align:left;width:4.921cm; " class="Table22_A2"><p class="P141">GSM Cell ID</p></td><td style="text-align:left;width:2.372cm; " class="Table22_A2"><p class="P140">342298497</p></td></tr><tr class="Table221"><td style="text-align:left;width:2.686cm; " class="Table22_A2"><p class="P139">LAC</p></td><td style="text-align:left;width:1.169cm; " class="Table22_A2"><p class="P140">N</p></td><td style="text-align:left;width:5.657cm; " class="Table22_A2"><p class="P140">A positive number<br/>or -1 if LAC is unknown</p></td><td style="text-align:left;width:4.921cm; " class="Table22_A2"><p class="P141">GSM Location Area Code</p></td><td style="text-align:left;width:2.372cm; " class="Table22_A2"><p class="P140">11090</p></td></tr><tr class="Table221"><td style="text-align:left;width:2.686cm; " class="Table22_A2"><p class="P139">MCC/MNC</p></td><td style="text-align:left;width:1.169cm; " class="Table22_A2"><p class="P140">S</p></td><td style="text-align:left;width:5.657cm; " class="Table22_A2"><p class="P140">String of 5 or 6 decimal digits</p></td><td style="text-align:left;width:4.921cm; " class="Table22_A2"><p class="P141">The "numeric name" of the registered network operator</p></td><td style="text-align:left;width:2.372cm; " class="Table22_A2"><p class="P140">310260</p></td></tr><tr class="Table221"><td style="text-align:left;width:2.686cm; " class="Table22_A2"><p class="P139">Operator</p></td><td style="text-align:left;width:1.169cm; " class="Table22_A2"><p class="P140">N</p></td><td style="text-align:left;width:5.657cm; " class="Table22_A2"><p class="P140">A name string</p></td><td style="text-align:left;width:4.921cm; " class="Table22_A2"><p class="P141">The name of the operator of the registered network</p></td><td style="text-align:left;width:2.372cm; " class="Table22_A2"><p class="P140">T-Mobile</p></td></tr></table><p class="P102">The "numeric name" is made up of the Mobile Country Code (MCC) and Mobile Network Code (MNC).</p><p class="P103">If the <span class="T7">PhoneType</span> is <span class="T7">CDMA</span> and the phone is registered to a network, the <span class="T7">Phone.info</span> command also returns the following items in the Bundle:</p><table border="0" cellspacing="0" cellpadding="0" class="Table23"><colgroup><col width="110"/><col width="56"/><col width="250"/><col width="318"/></colgroup><tr class="Table231"><td style="text-align:left;width:2.508cm; " class="Table23_A1"><p class="P139">Key</p></td><td style="text-align:left;width:1.272cm; " class="Table23_A1"><p class="P139">Type</p></td><td style="text-align:left;width:5.713cm; " class="Table23_A1"><p class="P139">Values</p></td><td style="text-align:left;width:7.271cm; " class="Table23_A1"><p class="P139">Meaning</p></td></tr><tr class="Table231"><td style="text-align:left;width:2.508cm; " class="Table23_A2"><p class="P139">BaseID</p></td><td style="text-align:left;width:1.272cm; " class="Table23_A2"><p class="P140">N</p></td><td style="text-align:left;width:5.713cm; " class="Table23_A2"><p class="P140">A positive number<br/>or -1 if BaseID is unknown</p></td><td style="text-align:left;width:7.271cm; " class="Table23_A2"><p class="P141">CDMA base station identification number</p></td></tr><tr class="Table231"><td style="text-align:left;width:2.508cm; " class="Table23_A2"><p class="P139">NetworkID</p></td><td style="text-align:left;width:1.272cm; " class="Table23_A2"><p class="P140">N</p></td><td style="text-align:left;width:5.713cm; " class="Table23_A2"><p class="P140">A positive number<br/>or -1 if NetworkID is unknown</p></td><td style="text-align:left;width:7.271cm; " class="Table23_A2"><p class="P141">CDMA network identification number</p></td></tr><tr class="Table231"><td style="text-align:left;width:2.508cm; " class="Table23_A2"><p class="P120">SystemID</p></td><td style="text-align:left;width:1.272cm; " class="Table23_A2"><p class="P110">N</p></td><td style="text-align:left;width:5.713cm; " class="Table23_A2"><p class="P110">A positive number<br/>or -1 if SystemID is unknown</p></td><td style="text-align:left;width:7.271cm; " class="Table23_A2"><p class="P114">CDMA system identification number</p></td></tr></table><p class="Standard"> </p><p class="Standard">If your program has executed <span class="T7">Phone.rcv.init</span>, then <span class="T7">Phone.info</span> may be able to report the strength of the signal connecting your phone to the cell tower. If the signal strength is available, <span class="T7">Phone.info</span> will try to report it in one or two of the following bundle keys (the first three are mutually exclusive):</p><table border="0" cellspacing="0" cellpadding="0" class="Table24"><colgroup><col width="110"/><col width="56"/><col width="222"/><col width="345"/></colgroup><tr class="Table241"><td style="text-align:left;width:2.508cm; " class="Table24_A1"><p class="P139">Key</p></td><td style="text-align:left;width:1.272cm; " class="Table24_A1"><p class="P139">Type</p></td><td style="text-align:left;width:5.08cm; " class="Table24_A1"><p class="P139">Values</p></td><td style="text-align:left;width:7.904cm; " class="Table24_A1"><p class="P139">Meaning</p></td></tr><tr class="Table241"><td style="text-align:left;width:2.508cm; " class="Table24_A2"><p class="P139">SignalLevel</p></td><td style="text-align:left;width:1.272cm; " class="Table24_A2"><p class="P140">N</p></td><td style="text-align:left;width:5.08cm; " class="Table24_A2"><p class="P140">A positive number 0 - 4</p></td><td style="text-align:left;width:7.904cm; " class="Table24_A2"><p class="P141">General measure of signal quality as shown in status bar. Higher is better.</p></td></tr><tr class="Table241"><td style="text-align:left;width:2.508cm; " class="Table24_A2"><p class="P139">GsmSignal</p></td><td style="text-align:left;width:1.272cm; " class="Table24_A2"><p class="P140">N</p></td><td style="text-align:left;width:5.08cm; " class="Table24_A2"><p class="P140">A positive number, 0 - 31<br/>or 99 if unknown</p></td><td style="text-align:left;width:7.904cm; " class="Table24_A2"><p class="P141">"SignalLevel" unavailable, phone type is GSM,<br/>get GSM level instead.</p></td></tr><tr class="Table241"><td style="text-align:left;width:2.508cm; " class="Table24_A2"><p class="P120">CdmaDbm</p></td><td style="text-align:left;width:1.272cm; " class="Table24_A2"><p class="P110">N</p></td><td style="text-align:left;width:5.08cm; " class="Table24_A2"><p class="P110">A negative number, typically<br/>-90 (strong) to -105 (weak)</p></td><td style="text-align:left;width:7.904cm; " class="Table24_A2"><p class="P114">"SignalLevel" unavailable, phone type is CDMA, get raw power level in dBm instead.</p></td></tr><tr class="Table245"><td style="text-align:left;width:2.508cm; " class="Table24_A2"><p class="P120">SignalASU</p></td><td style="text-align:left;width:1.272cm; " class="Table24_A2"><p class="P110">N</p></td><td style="text-align:left;width:5.08cm; " class="Table24_A2"><p class="P110">0 - 31, 99 (most)<br/>0 - 97, 99 (LTE)</p></td><td style="text-align:left;width:7.904cm; " class="Table24_A2"><p class="P114">"Arbitrary Strength Units",<br/>range depends on network type.</p></td></tr></table><p class="P102">This information is not available on some Android devices, depending on the device manufacturer and your wireless carrier.</p><h2 class="Heading_20_2"><a id="a__Screen_rotation__size____realsize____density"><span/></a><a id="_Toc5236128"/>Screen rotation, size[], realsize[], density</h2><p class="No_20_Spacing">Returns information about your screen.</p><ul><li><p class="P42" style="margin-left:1.27cm;"><span class="ListLabel_20_93" style="display:block;float:left;min-width:0.635cm;"></span>Provide numeric variables to get the rotation and density of the screen.<span class="odfLiEnd"/> </p></li><li><p class="P42" style="margin-left:1.27cm;"><span class="ListLabel_20_93" style="display:block;float:left;min-width:0.635cm;"></span>Provide numeric array variables to get the "application size" and "real size" of the screen.<br/><span style="margin-left:0cm"/>A size is returned as two values, width first and height second, in a two-element array. If the array exists, it is overwritten. Otherwise a new array is created.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">All parameters are optional. Use commas to indicate omitted parameters (see Optional Parameters).</p><p class="Standard"><span class="T7">rotation</span>: The current orientation of your screen relative to the "natural" orientation of your device. The natural orientation may be portrait or landscape, as defined by the manufacturer. The return value is a number from 0 to 3. Multiply by 90 to get the rotation in degrees clockwise.</p><p class="Standard"><span class="T7">size[]</span>: The size of the screen in pixels available for applications. This excludes system decorations. The width and height values reflect the current screen orientation.</p><p class="Standard"><span class="T7">realsize[]</span>: The current real size of the screen in pixels, including system decorations. NOTE: this value is available only on devices running Android version 4.2 or later. On other devices, the values will be the same as in the <span class="T7">size[]</span> array parameter.</p><p class="Standard"><span class="T7">density</span>: A standardized Android density value in dots per inch (dpi), usually 120, 160, or 240 dpi. This is not necessarily the real physical density of the screen. This value never changes.</p><h2 class="Heading_20_2"><a id="a__Screen_rotation__nvar_"><span/></a><a id="_Toc5236129"/>Screen.rotation &lt;nvar&gt;</h2><p class="Standard">Returns a number in the &lt;nvar&gt; parameter representing the current orientation of your screen relative to the "natural" orientation of your device. The natural orientation may be portrait or landscape, as defined by the manufacturer. The return value is a number from 0 to 3. Multiply by 90 to get the rotation in degrees clockwise. </p><h2 class="Heading_20_2"><a id="a__Screen_size__size____realsize____density"><span/></a><a id="_Toc5236130"/>Screen.size, size[], realsize[], density</h2><p class="No_20_Spacing">Returns information about the size and density of your screen.</p><ul><li><p class="P42" style="margin-left:1.27cm;"><span class="ListLabel_20_93" style="display:block;float:left;min-width:0.635cm;"></span>You may provide numeric array variables to get the "application size" and "real size" of the screen.<br/><span style="margin-left:0cm"/>A size is returned as two values, width first and height second, in a two-element array. If the array exists, it is overwritten. Otherwise a new array is created.<span class="odfLiEnd"/> </p></li><li><p class="P42" style="margin-left:1.27cm;"><span class="ListLabel_20_93" style="display:block;float:left;min-width:0.635cm;"></span>Provide a simple numeric variable to get the density of the screen.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">All parameters are optional. Use commas to indicate omitted parameters (see Optional Parameters).</p><p class="Standard"><span class="T7">size[]</span>: The size of the screen in pixels available for applications. This excludes system decorations. The width and height values reflect the current screen orientation.</p><p class="Standard"><span class="T7">realsize[]</span>: The current real size of the screen in pixels, including system decorations. NOTE: this value is available only on devices running Android version 4.2 or later. On other devices, the values will be the same as in the <span class="T7">size[]</span> array parameter.</p><p class="Standard"><span class="T7">density</span>: A standardized Android density value in dots per inch (dpi), usually 120, 160, or 240 dpi. This is not necessarily the real physical density of the screen. This value never changes.</p><p class="Standard">If your program is running in Graphics mode, "<span class="T7">SCREEN.SIZE xy[], , dens</span>" returns the same values as "<span class="T7">GR.SCREEN x, y, dens</span>". Unlike <span class="T7">Gr.screen</span>, <span class="T7">Screen.size</span> also works in Console and HTML modes.</p><h2 class="Heading_20_2"><a id="a__WiFi_info_{{_SSID_svar_}{___BSSID_svar_}{___MAC_svar_}{___IP_var_}{___speed_nvar_}}"><span/></a><a id="_Toc5236131"/>WiFi.info {{&lt;SSID_svar&gt;}{, &lt;BSSID_svar&gt;}{, &lt;MAC_svar&gt;}{, &lt;IP_var&gt;}{, &lt;speed_nvar&gt;}}</h2><p class="Standard">Gets information about the current Wi-Fi connection and places it in the return variables.</p><p class="Standard">All of the parameters are optional; use commas to indicate omitted parameters (see Optional Parameters). The table shows the available data:</p><table border="0" cellspacing="0" cellpadding="0" class="Table25"><colgroup><col width="94"/><col width="139"/><col width="236"/><col width="243"/></colgroup><tr class="Table251"><td style="text-align:left;width:2.159cm; " class="Table25_A1"><p class="P120">Variable</p></td><td style="text-align:left;width:3.175cm; " class="Table25_A1"><p class="P120">Type</p></td><td style="text-align:left;width:5.398cm; " class="Table25_A1"><p class="P120">Returned Data</p></td><td style="text-align:left;width:5.554cm; " class="Table25_A1"><p class="P120">Format</p></td></tr><tr class="Table251"><td style="text-align:left;width:2.159cm; " class="Table25_A1"><p class="P110">SSID</p></td><td style="text-align:left;width:3.175cm; " class="Table25_A1"><p class="P110">String</p></td><td style="text-align:left;width:5.398cm; " class="Table25_A1"><p class="P114">SSID of current 802.11 network</p></td><td style="text-align:left;width:5.554cm; " class="Table25_A1"><p class="P114">"name" or hex digits (see below)</p></td></tr><tr class="Table251"><td style="text-align:left;width:2.159cm; " class="Table25_A1"><p class="P110">BSSID</p></td><td style="text-align:left;width:3.175cm; " class="Table25_A1"><p class="P110">String</p></td><td style="text-align:left;width:5.398cm; " class="Table25_A1"><p class="P114">BSSID of current access point</p></td><td style="text-align:left;width:5.554cm; " class="Table25_A1"><p class="P114">xx:xx:xx:xx:xx:xx  (MAC address)</p></td></tr><tr class="Table251"><td style="text-align:left;width:2.159cm; " class="Table25_A1"><p class="P110">MAC</p></td><td style="text-align:left;width:3.175cm; " class="Table25_A1"><p class="P110">String</p></td><td style="text-align:left;width:5.398cm; " class="Table25_A1"><p class="P114">MAC address of your WiFi</p></td><td style="text-align:left;width:5.554cm; " class="Table25_A1"><p class="P114">xx:xx:xx:xx:xx:xx</p></td></tr><tr class="Table251"><td style="text-align:left;width:2.159cm; " class="Table25_A1"><p class="P110">IP</p></td><td style="text-align:left;width:3.175cm; " class="Table25_A1"><p class="P110">Numeric or String</p></td><td style="text-align:left;width:5.398cm; " class="Table25_A1"><p class="P114">IP address of your WiFi</p></td><td style="text-align:left;width:5.554cm; " class="Table25_A1"><p class="P114">Number or octets (see below)</p></td></tr><tr class="Table251"><td style="text-align:left;width:2.159cm; " class="Table25_A1"><p class="P110">speed</p></td><td style="text-align:left;width:3.175cm; " class="Table25_A1"><p class="P110">Numeric</p></td><td style="text-align:left;width:5.398cm; " class="Table25_A1"><p class="P114">Current link speed in Mbps</p></td><td style="text-align:left;width:5.554cm; " class="Table25_A1"><p class="P114">Number</p></td></tr></table><p class="P147">Format notes:</p><ul><li><p class="P43" style="margin-left:1.27cm;"><span class="ListLabel_20_41" style="display:block;float:left;min-width:0.635cm;"></span>SSID: If the network is named, the name is returned, surrounded by double quotes. Otherwise the returned name is a string of hex digits.<span class="odfLiEnd"/> </p></li><li><p class="P43" style="margin-left:1.27cm;"><span class="ListLabel_20_41" style="display:block;float:left;min-width:0.635cm;"></span>IP: If you provide a numeric variable, your Wi-Fi IP address is returned as a single number. If you provide a string variable, the number is converted to a standard four-octet string. For example, the string format 10.70.13.143 is the same IP address as the number -1887287798 (hex 8f82460a).<span class="odfLiEnd"/> </p></li></ul><h1 class="Heading_20_1"><a id="a__Running_in_the_Background"><span/></a><a id="_Toc5236132"/>Running in the Background</h1><h2 class="Heading_20_2"><a id="a__Home"><span/></a><a id="_Toc5236133"/>Home</h2><p class="Standard">The <span class="T7">HOME</span> command does exactly what tapping the HOME key would do. The Home Screen is displayed while the BASIC! program continues to run in the background.</p><h2 class="Heading_20_2"><a id="a__OnBackground_"><span/></a><a id="_Toc5236134"/>OnBackground:</h2><p class="Standard">Interrupt label that traps changes in the Background/Foreground state (see "Interrupt Labels"). BASIC! executes the statements following the <span class="T7">OnBackground:</span> label until it reaches a <span class="T7">Background.resume</span> command. The <span class="T7">Background()</span> function should be used to determine the new state.</p><h3 class="Heading_20_3"><a id="a__Background_resume"><span/></a><a id="_Toc5236135"/>Background.resume</h3><p class="Standard">Resumes execution at the point in the BASIC! program where the <span class="T7">OnBackground:</span> interrupt occurred.</p><h2 class="Heading_20_2"><a id="a__WakeLock__code_nexp_{___flags_nexp_}"><span/></a><a id="_Toc5236136"/>WakeLock &lt;code_nexp&gt;{, &lt;flags_nexp&gt;}</h2><p class="Standard">The <span class="T7">WakeLock</span> command modifies the system screen timeout function. The Code parameter &lt;code_nexp&gt; may be one of five values. Values 1 through 4 modify the screen timeout in various ways. Code value 5 releases the WakeLock and restores the system screen timeout function.</p><table border="0" cellspacing="0" cellpadding="0" class="Table26"><colgroup><col width="65"/><col width="168"/><col width="127"/><col width="127"/><col width="127"/></colgroup><tr class="Table261"><td style="text-align:left;width:1.496cm; " class="Table26_A1"><p class="P120">Code</p></td><td style="text-align:left;width:3.845cm; " class="Table26_A1"><p class="P120">WakeLock Type</p></td><td style="text-align:left;width:2.91cm; " class="Table26_A1"><p class="P120">CPU</p></td><td style="text-align:left;width:2.91cm; " class="Table26_A1"><p class="P120">Screen</p></td><td style="text-align:left;width:2.912cm; " class="Table26_A1"><p class="P120">Keyboard Light</p></td></tr><tr class="Table261"><td style="text-align:left;width:1.496cm; " class="Table26_A1"><p class="P131"><a href="http://developer.android.com/reference/android/os/PowerManager.html#PARTIAL_WAKE_LOCK" class="Internet_20_link"><span class="Internet_20_link"><span class="T33">1</span></span></a></p></td><td style="text-align:left;width:3.845cm; " class="Table26_A1"><p class="P110">Partial WakeLock</p></td><td style="text-align:left;width:2.91cm; " class="Table26_A1"><p class="P110">On*</p></td><td style="text-align:left;width:2.91cm; " class="Table26_A1"><p class="P110">Off</p></td><td style="text-align:left;width:2.912cm; " class="Table26_A1"><p class="P110">Off</p></td></tr><tr class="Table261"><td style="text-align:left;width:1.496cm; " class="Table26_A1"><p class="P131"><a href="http://developer.android.com/reference/android/os/PowerManager.html#SCREEN_DIM_WAKE_LOCK" class="Internet_20_link"><span class="Internet_20_link"><span class="T33">2</span></span></a></p></td><td style="text-align:left;width:3.845cm; " class="Table26_A1"><p class="P110">Screen Dim</p></td><td style="text-align:left;width:2.91cm; " class="Table26_A1"><p class="P110">On</p></td><td style="text-align:left;width:2.91cm; " class="Table26_A1"><p class="P110">Dim</p></td><td style="text-align:left;width:2.912cm; " class="Table26_A1"><p class="P110">Off</p></td></tr><tr class="Table261"><td style="text-align:left;width:1.496cm; " class="Table26_A1"><p class="P131"><a href="http://developer.android.com/reference/android/os/PowerManager.html#SCREEN_BRIGHT_WAKE_LOCK" class="Internet_20_link"><span class="Internet_20_link"><span class="T33">3</span></span></a></p></td><td style="text-align:left;width:3.845cm; " class="Table26_A1"><p class="P110">Screen Bright</p></td><td style="text-align:left;width:2.91cm; " class="Table26_A1"><p class="P110">On</p></td><td style="text-align:left;width:2.91cm; " class="Table26_A1"><p class="P110">Bright</p></td><td style="text-align:left;width:2.912cm; " class="Table26_A1"><p class="P110">Off</p></td></tr><tr class="Table261"><td style="text-align:left;width:1.496cm; " class="Table26_A1"><p class="P131"><a href="http://developer.android.com/reference/android/os/PowerManager.html#FULL_WAKE_LOCK" class="Internet_20_link"><span class="Internet_20_link"><span class="T33">4</span></span></a></p></td><td style="text-align:left;width:3.845cm; " class="Table26_A1"><p class="P110">Full WakeLock</p></td><td style="text-align:left;width:2.91cm; " class="Table26_A1"><p class="P110">On</p></td><td style="text-align:left;width:2.91cm; " class="Table26_A1"><p class="P110">Bright</p></td><td style="text-align:left;width:2.912cm; " class="Table26_A1"><p class="P110">Bright</p></td></tr><tr class="Table261"><td style="text-align:left;width:1.496cm; " class="Table26_A1"><p class="P110">5</p></td><td style="text-align:left;width:3.845cm; " class="Table26_A1"><p class="P110">No WakeLock</p></td><td style="text-align:left;width:2.91cm; " class="Table26_A1"><p class="P110">Off</p></td><td style="text-align:left;width:2.91cm; " class="Table26_A1"><p class="P110">Off</p></td><td style="text-align:left;width:2.912cm; " class="Table26_A1"><p class="P110">Off</p></td></tr></table><p class="P148">* <span class="T19">If you hold a partial WakeLock, the CPU will continue to run, regardless of any timers and even after the user taps the power button. In all other WakeLocks, the CPU will run, but the user can still put the device to sleep using the power button.</span></p><p class="Standard">You can use the optional Flags parameter &lt;flags_nexp&gt; to change the screen behavior, as shown in the table below. If the WakeLock Type is Partial WakeLock (Code 1), the Flags parameter is ignored.</p><table border="0" cellspacing="0" cellpadding="0" class="Table27"><colgroup><col width="65"/><col width="182"/><col width="368"/></colgroup><tr class="Table271"><td style="text-align:left;width:1.496cm; " class="Table27_A1"><p class="P120">Value</p></td><td style="text-align:left;width:4.165cm; " class="Table27_A1"><p class="P120">Flag(s) Set</p></td><td style="text-align:left;width:8.414cm; " class="Table27_A1"><p class="P120">Meaning</p></td></tr><tr class="Table271"><td style="text-align:left;width:1.496cm; " class="Table27_A1"><p class="P131"><a href="http://developer.android.com/reference/android/os/PowerManager.html#ACQUIRE_CAUSES_WAKEUP" class="Internet_20_link"><span class="Internet_20_link"><span class="T33">1</span></span></a></p></td><td style="text-align:left;width:4.165cm; " class="Table27_A1"><p class="P110">Acquire causes wakeup</p></td><td style="text-align:left;width:8.414cm; " class="Table27_A1"><p class="P114">Turn screen on when wakelock is acquired.</p></td></tr><tr class="Table271"><td style="text-align:left;width:1.496cm; " class="Table27_A1"><p class="P131"><a href="http://developer.android.com/reference/android/os/PowerManager.html#ON_AFTER_RELEASE" class="Internet_20_link"><span class="Internet_20_link"><span class="T33">2</span></span></a></p></td><td style="text-align:left;width:4.165cm; " class="Table27_A1"><p class="P110">On after release</p></td><td style="text-align:left;width:8.414cm; " class="Table27_A1"><p class="P114">Reset screen timeout when wakelock is released.</p></td></tr><tr class="Table271"><td style="text-align:left;width:1.496cm; " class="Table27_A1"><p class="P110">3</p></td><td style="text-align:left;width:4.165cm; " class="Table27_A1"><p class="P110">Both</p></td><td style="text-align:left;width:8.414cm; " class="Table27_A1"><p class="P110"> </p></td></tr><tr class="Table271"><td style="text-align:left;width:1.496cm; " class="Table27_A1"><p class="P110">Other</p></td><td style="text-align:left;width:4.165cm; " class="Table27_A1"><p class="P110">Neither</p></td><td style="text-align:left;width:8.414cm; " class="Table27_A1"><p class="P110"> </p></td></tr></table><p class="Standard"> </p><p class="Standard">Use the WakeLock only when you really need it. Acquiring a WakeLock increases power usage and decreases battery life. The WakeLock is always released when the program stops running.</p><p class="Standard">One of the common uses for <span class="T7">WakeLock</span> would be in a music player that needs to keep the music playing after the system screen timeout interval. Implementing this requires that BASIC! be kept running. One way to do this is to put BASIC! into an infinite loop:</p><p class="Code_20_example"><span class="T11">Audio.load n,"B5b.mp3"</span></p><p class="Code_20_example"><span class="T11">Audio.play n</span></p><p class="Code_20_example"><span class="T11">WakeLock 1</span></p><p class="Code_20_example"><span class="T11">Do</span></p><p class="Code_20_example"><span class="T11">  Pause 30000</span></p><p class="Code_20_example"><span class="T11">Until 0</span></p><p class="Standard">The screen will turn off when the system screen timeout expires but the music will continue to play.</p><h2 class="Heading_20_2"><a id="a__WifiLock__code_nexp_"><span/></a><a id="_Toc5236137"/>WifiLock &lt;code_nexp&gt;</h2><p class="Standard">The <span class="T7">WifiLock</span> command allows your program to keep the WiFi connection awake when a time-out would normally turn it off. The &lt;code_nexp&gt; may be one of four values. Values 1 through 3 acquire a WifiLock, changing the way WiFi behaves when the screen turns off. Code value 4 releases the WifiLock and restores the normal timeout behavior.</p><table border="0" cellspacing="0" cellpadding="0" class="Table28"><colgroup><col width="95"/><col width="125"/><col width="382"/></colgroup><tr class="Table281"><td style="text-align:left;width:2.177cm; " class="Table28_A1"><p class="P120">Code:</p></td><td style="text-align:left;width:2.861cm; " class="Table28_A1"><p class="P120">WiFiLock Type</p></td><td style="text-align:left;width:8.731cm; " class="Table28_A1"><p class="P120">WiFi Operation When Screen is Off</p></td></tr><tr class="Table281"><td style="text-align:left;width:2.177cm; " class="Table28_A1"><p class="P131"><a href="http://developer.android.com/reference/android/net/wifi/WifiManager.html#WIFI_MODE_SCAN_ONLY" class="Internet_20_link"><span class="Internet_20_link"><span class="T33">1</span></span></a></p></td><td style="text-align:left;width:2.861cm; " class="Table28_A1"><p class="P110">Scan Only</p></td><td style="text-align:left;width:8.731cm; " class="Table28_A1"><p class="P110">WiFi kept active, but only operation is initiating scan and reporting scan results</p></td></tr><tr class="Table281"><td style="text-align:left;width:2.177cm; " class="Table28_A1"><p class="P131"><a href="http://developer.android.com/reference/android/net/wifi/WifiManager.html#WIFI_MODE_FULL" class="Internet_20_link"><span class="Internet_20_link"><span class="T33">2</span></span></a></p></td><td style="text-align:left;width:2.861cm; " class="Table28_A1"><p class="P110">Full</p></td><td style="text-align:left;width:8.731cm; " class="Table28_A1"><p class="P110">WiFi behaves normally</p></td></tr><tr class="Table281"><td style="text-align:left;width:2.177cm; " class="Table28_A1"><p class="P131"><a href="http://developer.android.com/reference/android/net/wifi/WifiManager.html#WIFI_MODE_FULL_HIGH_PERF" class="Internet_20_link"><span class="Internet_20_link"><span class="T33">3</span></span></a></p></td><td style="text-align:left;width:2.861cm; " class="Table28_A1"><p class="P110">Full High-Performance</p></td><td style="text-align:left;width:8.731cm; " class="Table28_A1"><p class="P110">WiFi operates at high performance with minimum packet loss and low latency*</p></td></tr><tr class="Table281"><td style="text-align:left;width:2.177cm; " class="Table28_A1"><p class="P110">4</p></td><td style="text-align:left;width:2.861cm; " class="Table28_A1"><p class="P110">No WiFiLock</p></td><td style="text-align:left;width:8.731cm; " class="Table28_A1"><p class="P110">WiFi turns off (may be settable on some devices)</p></td></tr></table><p class="P148">*Full Hi-Perf mode is not available on all Android devices. Devices running Android 3.0.x or earlier, and devices without the necessary hardware, will run in Full mode instead.</p><p class="Standard">Use <span class="T7">WifiLock</span> only when you really need it. Acquiring a WifiLock increases power usage and decreases battery life. The WifiLock is always released when the program stops running.</p><h1 class="Heading_20_1"><a id="a__Miscellaneous_Commands"><span/></a><a id="_Toc5236138"/>Miscellaneous Commands</h1><h2 class="Heading_20_2"><a id="a__Headset__state_nvar____type_svar____mic_nvar_"><span/></a><a id="_Toc5236139"/>Headset &lt;state_nvar&gt;, &lt;type_svar&gt;, &lt;mic_nvar&gt;</h2><p class="P109">Reports if there is a headset plugged into your device, and returns data about the headset. The parameters are all names of variables that receive the data:</p><ul><li><p class="P44" style="margin-left:1.27cm;"><span class="ListLabel_20_113" style="display:block;float:left;min-width:0.635cm;"></span>&lt;state_nvar&gt;:        1.0 if a headset is plugged in, 0.0 if no headset is plugged in, and -1.0 if unknown.<span class="odfLiEnd"/> </p></li><li><p class="P44" style="margin-left:1.27cm;"><span class="ListLabel_20_113" style="display:block;float:left;min-width:0.635cm;"></span>&lt;type_svar&gt;:        A string describing the device type of the last headset known to your device.<span class="odfLiEnd"/> </p></li><li><p class="P44" style="margin-left:1.27cm;"><span class="ListLabel_20_113" style="display:block;float:left;min-width:0.635cm;"></span>&lt;mic_nvar&gt;:        1.0 if the headset has a microphone, 0.0 if the headset does not have a microphone, and -1.0 if unknown.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">If you plug in or unplug a headset, new information becomes available. Your program must run the <span class="T7">Headset</span> command again to get the update.</p><h2 class="Heading_20_2"><a id="a__Notify__title_sexp____subtitle_sexp____alert_sexp____wait_lexp_"><span/></a><a id="_Toc5236140"/>Notify &lt;title_sexp&gt;, &lt;subtitle_sexp&gt;, &lt;alert_sexp&gt;, &lt;wait_lexp&gt;</h2><p class="Standard">This command will cause a Notify object to be placed in the Notify (Status) bar. The Notify object displays the BASIC! app icon and, in some versions of Android, the &lt;alert_sexp&gt; text. The user taps the Notify object to open the notification window. Your program’s notification displays the &lt;title_sexp&gt; and &lt;subtitle_sexp&gt; text. In some versions of Android, the &lt;alert_sexp&gt; text is displayed after the title and subtitle text.</p><p class="Standard">The code snippet and screenshots shown below demonstrate the placement of the parameter strings.</p><p class="Standard">If &lt;wait_lexp&gt; is not zero (true), then the execution of the BASIC! program will be suspended until the user taps the Notify object. If the value is zero (false), the BASIC! program will continue executing.</p><p class="Standard">The Notify object will be removed when the user taps the object, or when the program exits.</p><p class="Code_20_example"><span class="T11">Print "Executing Notify"</span></p><p class="Code_20_example"><span class="T11">Notify "BASIC! Notify", "Tap to resume running program",~</span></p><p class="Code_20_example"><span class="T11">"BASIC! Notify Alert", 1</span></p><p class="Code_20_example"><span class="T11">! Execution is suspended and waiting for user to tap the Notify Object</span></p><p class="Code_20_example"><span class="T11">Print "Notified"</span></p><!--Next 'div' was a 'text:p'.--><div class="P100"><!--Next '
           span' is a draw:frame.
       --><span style="height:3.404cm;width:5.674cm; padding:0; " class="fr1" id="Picture_14"><img style="height:3.404cm;width:5.674cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><!--Next 'div' was a 'text:p'.--><div class="P100"><!--Next '
           span' is a draw:frame.
       --><span style="height:3.344cm;width:5.576cm; padding:0; " class="fr1" id="Picture_15"><img style="height:3.344cm;width:5.576cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><p class="Standard">Note: the icon that appears in the Notify object will be the icon for the application in user-built apk.</p><h2 class="Heading_20_2"><a id="a__Pause__ticks_nexp_"><span/></a><a id="_Toc5236141"/>Pause &lt;ticks_nexp&gt;</h2><p class="Standard">Stops the execution of the BASIC! program for &lt;ticks_nexp&gt; milliseconds. One millisecond = 1/1000 of a second. Pause 1000 will pause the program for one second. A pause can not be interrupted.</p><p class="Standard">An infinite loop can be a very useful construct in your programs. For example, you may use it to wait for the user to tap a control on the screen. A tight spin loop keeps BASIC! very busy doing nothing. A <span class="T7">Pause</span>, even a short one, reduces the load on the CPU and the drain on the battery. Depending on your application, you may want to add a <span class="T7">Pause</span> to the loop to conserve battery power:</p><p class="Code_20_example"><span class="T11">DO : PAUSE 50 : UNTIL x &lt;&gt; 0</span></p><h2 class="Heading_20_2"><a id="a__Swap__nvar_a_|_svar_a____nvar_b_|_svar_b_"><span/></a><a id="_Toc5236142"/>Swap &lt;nvar_a&gt;|&lt;svar_a&gt;, &lt;nvar_b&gt;|&lt;svar_b&gt;</h2><p class="Standard">The values and in "a" and "b" numeric or string variables are swapped.</p><h2 class="Heading_20_2"><a id="a__Tone__frequency_nexp____duration_nexp__{___duration_chk_lexp}"><span/></a><a id="_Toc5236143"/>Tone &lt;frequency_nexp&gt;, &lt;duration_nexp&gt; {, &lt;duration_chk_lexp}</h2><p class="Standard">Plays a tone of the specified frequency in hertz (cycles per second) for the specified duration in milliseconds.</p><p class="Standard">The duration produced does not exactly match the specified duration. If you need to get an exact duration, experiment.</p><p class="Standard">Each Android device has a minimum tone duration. By default, if you specify a duration less than this minimum, you get a run-time error message giving the minimum for your device. However, you can suppress the check by setting the optional duration check flag &lt;duration_chk_lexp&gt; to 0 (false). If you do this, the result you get depends on your device. You will not get a run-time error message, but you may or may not get the tone you expect.</p><h2 class="Heading_20_2"><a id="a__Vibrate__pattern_array_{_start___length_}____nexp_"><span/></a><a id="_Toc5236144"/>Vibrate &lt;pattern_array[{&lt;start&gt;,&lt;length&gt;}]&gt;,&lt;nexp&gt;</h2><p class="Standard">The vibrate command causes the device to vibrate in the specified pattern. The pattern is held in a numeric array (pattern_array[]) or array segment (pattern_array[start,length]).</p><p class="Standard">The pattern is of the form: pause-time, on-time, …, pause-time, on-time. The values for pause-time and on-time are durations in milliseconds. The pattern may be of any length. There must be at least two values to get a single buzz because the first value is a pause.</p><p class="P109">If &lt;nexp&gt; = -1 then the pattern will play once and not repeat.</p><p class="P109">If &lt;nexp&gt; =  0 then the pattern will continue to play over and over again until the program ends.</p><p class="Standard">If &lt;nexp&gt; &gt;  0 then the pattern play will be cancelled.</p><p class="Standard">See the sample program, <span class="T7">f21_sos.bas</span>, for an example of <span class="T7">Vibrate</span>.</p><h2 class="Heading_20_2"><a id="a__VolKeys"><span/></a><a id="_Toc5236145"/>VolKeys</h2><p class="Standard">Certain keys and buttons have special meaning to your Android device. By default, BASIC! propagates these special keycodes to the Android system, even if your program detects them. So, for example, when you press the "Volume Up" button, your program can catch it (see <span class="T7">INKEY$</span>), but you still see the Volume Control window open on your screen, and your audio gets louder.</p><p class="Standard">The <span class="T7">VolKeys.off</span> and <span class="T7">VolKeys.on</span> commands let you control this behavior for five keys. These keys may be on the Android device or on a headset plugged into the device.</p><table border="0" cellspacing="0" cellpadding="0" class="Table29"><colgroup><col width="143"/><col width="97"/><col width="298"/></colgroup><tr class="Table291"><td style="text-align:left;width:3.27cm; " class="Table29_A1"><p class="P124">Key Name<br/>(Android docs)</p></td><td style="text-align:left;width:2.223cm; " class="Table29_A1"><p class="P125">Key Code<br/>(decimal)</p></td><td style="text-align:left;width:6.812cm; " class="Table29_A1"><p class="P124">Usual Action</p></td></tr><tr class="Table291"><td style="text-align:left;width:3.27cm; " class="Table29_A2"><p class="P127">VOLUME_UP</p></td><td style="text-align:left;width:2.223cm; " class="Table29_A2"><p class="P110">24</p></td><td style="text-align:left;width:6.812cm; " class="Table29_A2"><p class="P114">Increase speaker volume</p></td></tr><tr class="Table291"><td style="text-align:left;width:3.27cm; " class="Table29_A2"><p class="P127">VOLUME_DOWN</p></td><td style="text-align:left;width:2.223cm; " class="Table29_A2"><p class="P110">25</p></td><td style="text-align:left;width:6.812cm; " class="Table29_A2"><p class="P114">Decrease speaker volume</p></td></tr><tr class="Table291"><td style="text-align:left;width:3.27cm; " class="Table29_A2"><p class="P127">VOLUME_MUTE</p></td><td style="text-align:left;width:2.223cm; " class="Table29_A2"><p class="P110">164</p></td><td style="text-align:left;width:6.812cm; " class="Table29_A2"><p class="P114">Mute the speaker (Android 3.0 or later)</p></td></tr><tr class="Table291"><td style="text-align:left;width:3.27cm; " class="Table29_A2"><p class="P127">MUTE</p></td><td style="text-align:left;width:2.223cm; " class="Table29_A2"><p class="P110">91</p></td><td style="text-align:left;width:6.812cm; " class="Table29_A2"><p class="P114">Mute the microphone</p></td></tr><tr class="Table291"><td style="text-align:left;width:3.27cm; " class="Table29_A2"><p class="P127">HEADSETHOOK</p></td><td style="text-align:left;width:2.223cm; " class="Table29_A2"><p class="P110">79</p></td><td style="text-align:left;width:6.812cm; " class="Table29_A2"><p class="P114">Hang up a call, stop media playback</p></td></tr></table><h3 class="Heading_20_3"><a id="a__VolKeys_off"><span/></a><a id="_Toc5236146"/>VolKeys.off</h3><p class="Standard">Disables the usual action of the keys listed in the VolKeys table, above. Your program can still detect these keypresses, but BASIC! does not pass the events on to the Android system.</p><h3 class="Heading_20_3"><a id="a__VolKeys_on"><span/></a><a id="_Toc5236147"/>VolKeys.on</h3><p class="Standard">Enables the usual action of the keys listed in the VolKeys table, above. This is the default setting when your BASIC! program starts.</p><h1 class="Heading_20_1"><a id="a__SQLITE"><span/></a><a id="_Toc5236148"/>SQLITE</h1><h2 class="Heading_20_2"><a id="a__Overview"><span/></a><a id="_Toc5236149"/>Overview</h2><p class="P149">The Android operating system provides the ability to create, maintain and access SQLite databases. SQLite implements a <a href="http://www.sqlite.org/selfcontained.html" class="Internet_20_link"><span class="Internet_20_link">self-contained</span></a>, <a href="http://www.sqlite.org/serverless.html" class="Internet_20_link"><span class="Internet_20_link">serverless</span></a>, <a href="http://www.sqlite.org/zeroconf.html" class="Internet_20_link"><span class="Internet_20_link">zero-configuration</span></a>, <a href="http://www.sqlite.org/transactional.html" class="Internet_20_link"><span class="Internet_20_link">transactional</span></a> SQL database engine. SQLite is the <a href="http://www.sqlite.org/mostdeployed.html" class="Internet_20_link"><span class="Internet_20_link">most widely deployed</span></a> SQL database engine in the world. The full details about SQLite can be found at the <a href="http://www.sqlite.org/" class="Internet_20_link"><span class="Internet_20_link">SQLite Home Page</span></a><span class="Internet_20_link"> (</span><a href="http://www.sqlite.org/" class="Internet_20_link"><span class="Internet_20_link">http://www.sqlite.org/</span></a><span class="Internet_20_link">)</span>.</p><p class="P149">An excellent online tutorial on SQL can be found at <a href="http://www.w3schools.com/sql/default.asp" class="Internet_20_link"><span class="Internet_20_link">www.w3schools.com</span></a><span class="Internet_20_link"> (http://www.w3schools.com/sql/default.asp)</span>.</p><p class="P149">Database files will be created on the base drive (usually the SD card) in the directory, "&lt;pref base drive&gt;/rfo-basic/databases/ ".</p><h2 class="Heading_20_2"><a id="a__SQLITE_Commands"><span/></a><a id="_Toc5236150"/>SQLITE Commands</h2><h3 class="Heading_20_3"><a id="a__Sql_open__DB_pointer_nvar____DB_name_sexp_"><span/></a><a id="_Toc5236151"/>Sql.open &lt;DB_pointer_nvar&gt;, &lt;DB_name_sexp&gt;</h3><p class="Standard">Opens a database for access. If the database does not exist, it will be created.</p><p class="Standard">&lt;DB_pointer_nvar&gt; is a pointer to the newly opened database. This value will be set by the sql.open command operation. &lt;DB_pointer_nvar&gt; is used in subsequent database commands and should not be altered.</p><p class="Standard">&lt;DB_name_sexp&gt; is the filename used to hold this database. The base reference directory is "&lt;pref base drive&gt;/com.rfo.basic/databases/". If &lt;DB_name_sexp&gt; = ":memory:" then a temporary database will be created in memory.</p><p class="Standard">Note: You may have more than one database opened at same time. Each opened database must have its own, distinct pointer.</p><h3 class="Heading_20_3"><a id="a__Sql_close__DB_pointer_nvar_"><span/></a><a id="_Toc5236152"/>Sql.close &lt;DB_pointer_nvar&gt;</h3><p class="P149">Closes a previously opened database. &lt;DB_pointer_nvar&gt; will be set to zero. The variable may then be reused in another sql.open command. You should always close an opened database when you are done with it. Not closing a database can reduce the amount of memory available on your Android device.</p><h3 class="Heading_20_3"><a id="a__Sql_new_table__DB_pointer_nvar____table_name_sexp___C1$__C2$______CN$"><span/></a><a id="_Toc5236153"/>Sql.new_table &lt;DB_pointer_nvar&gt;, &lt;table_name_sexp&gt;, C1$, C2$, ...,CN$</h3><p class="P149">A single database may contain many tables. A table is made of rows of data. A row of data consists of columns of values. Each value column has a column name associated with it.</p><p class="P149">This command creates a new table with the name &lt;table_name_sexp&gt; in the referenced opened database. The column names for that table are defined by the following: C1$, C2$, ..., CN$. At least one column name is required. You may create as many column names as you need.</p><p class="P149">BASIC! always adds a Row Index Column named "_id" to every table. The value in this Row Index Column is automatically incremented by one for each new row inserted. This gives each row in the table a unique identifier. This identifier can be used to connect information in one table to another table. For example, the _id value for customer information in a customer table can be used to link specific orders to specific customers in an outstanding order database.</p><h3 class="Heading_20_3"><a id="a__Sql_drop_table__DB_pointer_nvar____table_name_sexp_"><span/></a><a id="_Toc5236154"/>Sql.drop_table &lt;DB_pointer_nvar&gt;, &lt;table_name_sexp&gt;</h3><p class="P149">The table named &lt;table_name_sexp&gt; in the opened database pointed to by &lt;DB_pointer_nvar&gt; will be dropped from the database if the table exists.</p><h3 class="Heading_20_3"><a id="a__Sql_insert__DB_pointer_nvar____table_name_sexp___C1$__V1$__C2$__V2$_______CN$__VN$"><span/></a><a id="_Toc5236155"/>Sql.insert &lt;DB_pointer_nvar&gt;, &lt;table_name_sexp&gt;, C1$, V1$, C2$, V2$, ..., CN$, VN$</h3><p class="Standard">Inserts a new row of data columns and values into a table in a previously opened database.</p><p class="Standard">The &lt;table_name_sexp&gt; is the name of the table into which the data is to be inserted. All newly inserted rows are inserted after the last, existing row of the table.</p><p class="Standard">C1$, V1$, C2$, V2$, ..., CN$, VN$: The column name and value pairs for the new row. These parameters must be in pairs. The column names must match the column names used to create the table. Note that the values are all strings. When you need a numeric value for a column, use the BASIC! STR$(n) to convert the number into a string. You can also use the BASIC! FORMAT$(pattern$, N) to create a formatted number for a value. (The Values-as-strings requirement is a BASIC! SQL Interface requirement, not a SQLite requirement. While SQLite, itself, stores all values as strings, it provides transparent conversions to other data types. I have chosen not to complicate the interface with access to these SQLite conversions since BASIC! provides its own conversion capabilities.)</p><h3 class="Heading_20_3"><a id="a__Sql_query__cursor_nvar____DB_pointer_nvar____table_name_sexp____columns_sexp__{___where_sexp__{___order_sexp_}_}"><span/></a><a id="_Toc5236156"/>Sql.query &lt;cursor_nvar&gt;, &lt;DB_pointer_nvar&gt;, &lt;table_name_sexp&gt;, &lt;columns_sexp&gt; {, &lt;where_sexp&gt; {, &lt;order_sexp&gt;} }</h3><p class="Standard">Queries a table of a previously-opened database for some specific data. The command returns a Cursor named &lt;Cursor_nvar&gt; to be used in stepping through Query results.</p><p class="Standard">The &lt;columns_sexp&gt; is a string expression with a list of the names of the columns to be returned. The column names must be separated by commas. An example is Columns$ = "First_name, Last_name, Sex, Age". If you want to get the automatically incremented Row Index Column then include the "_id" column name in your column list. Columns may be listed in any order. The column order used in the query will be the order in which the rows are returned.</p><p class="Standard">The optional &lt;where_sexp&gt; is an SQL expression string used to select which rows to return. In general, an SQL expression is of the form &lt;Column Name&gt; &lt;operator&gt; &lt;Value&gt;. For example, Where$ = "First_name = 'John' " Note that the Value must be contained in single quotes. Full details about the SQL expressions can be found <a href="http://www.sqlite.org/lang_expr.html" class="Internet_20_link"><span class="Internet_20_link">here</span></a>. If the Where parameter is omitted, all rows will be returned.</p><p class="Standard">The optional &lt;order_sexp&gt; specifies the order in which the rows are to be returned. It identifies the column upon which the output rows are to be sorted. It also specifies whether the rows are to be sorted in ascending (ASC) or descending (DESC) order. For example, Order$ = "Last_Name ASC" would return the rows sorted by Last_Name from A to Z. If the Order parameter is omitted, the rows are not sorted.</p><p class="Standard">If the Order parameter is present, the Where parameter must be present. If you want to return all rows, just set Where$ = ""</p><h3 class="Heading_20_3"><a id="a__Sql_query_length__length_nvar____cursor_nvar_"><span/></a><a id="_Toc5236157"/>Sql.query.length &lt;length_nvar&gt;, &lt;cursor_nvar&gt;</h3><p class="Standard">Report the number of records returned by a previous Query command, Given the Cursor returned by a Query, the command writes the number of records into &lt;length_nvar&gt;. This command cannot be used after all of the data has been read.</p><h3 class="Heading_20_3"><a id="a__Sql_query_position__position_nvar____cursor_nvar_"><span/></a><a id="_Toc5236158"/>Sql.query.position &lt;position_nvar&gt;, &lt;cursor_nvar&gt;</h3><p class="Standard">Report the record number most recently read using the Cursor of a Query command. Given the Cursor returned by a Query, the command writes the position of the Cursor into &lt;Position_nvar&gt;. Before the first Next command, the Position is 0. It is incremented by each Next command. A Next command after the last row is read sets its Done variable to true and resets the Cursor to 0. The Cursor can no longer be used, and this command can no longer be used with that Cursor.</p><h3 class="Heading_20_3"><a id="a__Sql_next__done_lvar____cursor_nvar_{___cv_svars_}"><span/></a><a id="_Toc5236159"/>Sql.next &lt;done_lvar&gt;, &lt;cursor_nvar&gt;{, &lt;cv_svars&gt;}</h3><p class="Standard">Using the Cursor generated by a previous Query command (<span class="T7">Sql.query</span> or <span class="T7">Sql.raw_query</span>), step to the next row of data returned by the Query and retrieve the data.</p><p class="Standard">&lt;done_lvar&gt; is a Boolean variable that signals when the last row of the Query data has been read.</p><p class="Standard">&lt;cursor_nvar&gt; is a numeric variable that holds the Cursor pointer returned by a Query command. You may have more than one Cursor open at a time.</p><p class="Standard">&lt;cv_svars&gt; is an optional set of column value string variables that return data from the database to your program. The Cursor carries the values from the table columns listed in the Query. <span class="T7">Sql.next</span> retrieves one row from the Cursor as string values and writes them into the &lt;cv_svars&gt;. If any of your columns are numeric, you can use the BASIC! <span class="T7">VAL(</span>str$<span class="T7">)</span> function to convert the strings to numbers.</p><p class="Standard">When this command reads a row of data, it sets the Done flag &lt;done_lvar&gt; to false (0.0). If it finds no data to read, it changes the Done flag to true (1.0) and resets the cursor variable &lt;cursor_nvar&gt; to zero. The Cursor can no longer be used for <span class="T7">Sql.next</span> operations. The cursor variable may be used with another Cursor from a different Query.</p><p class="Standard">In its simplest form, &lt;cv_svars&gt; is a comma-separated list of string variable names. Each variable receives the data of one column. If there are more variables than columns, the excess variables are left unchanged. If there are more columns than variables, the excess data are discarded.</p><p class="Code_20_example"><span class="T11">SQL.NEXT done, cursor, cv1$, cv2$, cv3$        % get data from up to three columns</span></p><p class="Standard">The last (or only) variable may be a string array name with no index(es):</p><p class="Code_20_example"><span class="T11">SQL.NEXT done, cursor, cv$[]                        % get data from ALL available columns</span></p><p class="Standard">The data from any column(s) that are not written to string variables are written into the array. If no column data are written to the array, the array has one element, an empty string "". If the variable names an array that already exists, it is overwritten.</p><p class="Standard">If the last (or only) &lt;cv_svars&gt; variable is an array, you may also add (after another comma) a numeric variable &lt;ncol_nvar&gt;. This variable receives the total number of columns in the cursor. Note that this is not necessarily the same as the size of the array.</p><p class="Code_20_example"><span class="T11">SQL.NEXT done, cursor, cv$[], nCols                % report number of columns available</span></p><p class="Standard">The full specification for this command, including the optional array and column count, is as follows:</p><p class="Code_20_example"><span class="T11">Sql.next &lt;done_lvar&gt;, &lt;cursor_nvar&gt; {, svar}... {, array$[] {, &lt;ncol_nvar&gt;}}</span></p><h3 class="Heading_20_3"><a id="a__Sql_delete__DB_pointer_nvar____table_name_sexp_{__where_sexp_{__count_nvar_}_}"><span/></a><a id="_Toc5236160"/>Sql.delete &lt;DB_pointer_nvar&gt;, &lt;table_name_sexp&gt;{,&lt;where_sexp&gt;{,&lt;count_nvar&gt;} }</h3><p class="P149">From the named table of a previously opened database, delete rows selected by the conditions established by the Where string expression. The Count variable reports the number of rows deleted.</p><p class="P149">The formation of the Where string is exactly the same as described in the <span class="T7">Sql.query</span> command. Both Where and Count are optional. If the Where string is omitted all rows are deleted, and the Count variable must be omitted, too.</p><h3 class="Heading_20_3"><a id="a__Sql_update__DB_pointer_nvar____table_name_sexp___C1$__V1$__C2$__V2$_____CN$__VN${___where_sexp_}"><span/></a><a id="_Toc5236161"/>Sql.update &lt;DB_pointer_nvar&gt;, &lt;table_name_sexp&gt;, C1$, V1$, C2$, V2$,...,CN$, VN${: &lt;where_sexp&gt;}</h3><p class="Standard">In the named table of a previously opened database, change column values in specific rows selected by the Where$ parameter &lt;where_sexp&gt;. The C$,V$ parameters must be in pairs. The colon character terminates the C$,V$ list and must precede the Where$ in this command. The Where$ parameter and preceding colon are optional.</p><p class="Standard">BASIC! also uses the colon character to separate multiple commands on a single line. The use of a colon in this command conflicts with that feature. Use caution when using both together.</p><p class="Standard">If you put a colon on a line after this command, the preprocessor <span class="T7">always</span> assumes the colon is part of the command and not a command separator. If you are not certain of the outcome, the safest action is to put the <span class="T7">Sql.update</span> command on a line by itself, or at the end of a multi-command line.</p><h3 class="Heading_20_3"><a id="a__Sql_exec__DB_pointer_nvar____command_sexp_"><span/></a><a id="_Toc5236162"/>Sql.exec &lt;DB_pointer_nvar&gt;, &lt;command_sexp&gt;</h3><p class="Standard">Execute ANY non-query SQL command string ("CREATE TABLE", "DELETE", "INSERT", etc.) using a previously opened database.</p><h3 class="Heading_20_3"><a id="a__Sql_raw_query__cursor_nvar____DB_pointer_nvar____query_sexp_"><span/></a><a id="_Toc5236163"/>Sql.raw_query &lt;cursor_nvar&gt;, &lt;DB_pointer_nvar&gt;, &lt;query_sexp&gt;</h3><p class="Standard">Execute ANY SQL Query command using a previously opened database and return a Cursor for the results.</p><h1 class="Heading_20_1"><a id="a__Graphics"><span/></a><a id="_Toc5236164"/>Graphics</h1><h2 class="Heading_20_2"><a id="a__Introduction"><span/></a><a id="_Toc5236165"/>Introduction</h2><h3 class="Heading_20_3"><a id="a__The_Graphics_Screen_and_Graphics_Mode"><span/></a><a id="_Toc5236166"/>The Graphics Screen and Graphics Mode</h3><p class="Standard">Graphics are displayed on a new screen that is different from the BASIC! Text Output Screen. The Text Output Screen still exists and can still be written to. You can be returned to the text screen using the BACK key or by having the program execute the <span class="T7">Gr.front</span> command.</p><p class="Standard">The <span class="T7">Gr.open</span> command opens the graphics screen and puts BASIC! into the graphics mode. BASIC! must be in graphics mode before any other graphics commands can be executed. Attempting to execute any graphics command when not in the graphics mode will result in a run-time error. The <span class="T7">Gr.</span>close command closes the graphics screen and turns off graphics mode. The graphics mode automatically turns off when the BACK key or MENU key is tapped. BASIC! will continue to run after the BACK key or MENU key is tapped when in graphics mode but the Output Console will be shown.</p><p class="Standard">The BASIC! Output Console is hidden when the graphics screen is being displayed. No run-time error messages will be observable. A haptic feedback alert signals a run-time error. This haptic feedback will be a distinct, short buzz. Tap the BACK key to close the Graphics Screen upon feeling this alert. The error messages can then read from the BASIC! Output Console.</p><p class="Standard">Use the <span class="T7">Gr.front</span> command to swap the front-most screen between the Output Console and the graphics screen.</p><p class="Standard">Commands that use a new window or screen to interact with the user (<span class="T7">Input</span>, <span class="T7">Select</span> and others) may be used in graphics mode.</p><p class="Standard">When your program ends, the graphics screen will be closed. If you want to keep the graphics screen showing, use a long pause or an infinite loop to keep the program from ending:</p><p class="Code_20_example"><span class="T11">! Stay running to keep the graphics screen showing</span></p><p class="Code_20_example"><span class="T11">do</span></p><p class="Code_20_example"><span class="T11">until 0</span></p><p class="Standard">Depending on your application, you may want to add a <span class="T7">Pause</span> to the loop to conserve battery power. Tap the BACK key to break out of the infinite loop. The BACK key ends your program unless you trap it with the <span class="T7">OnBackKey:</span> interrupt label.</p><h3 class="Heading_20_3"><a id="a__Display_Lists"><span/></a><a id="_Toc5236167"/>Display Lists</h3><p class="Standard">Each command that draws a graphical object (line, circle, text, etc.) places that object on a list called the Object List. The command returns the object's Object Number. This Object Number, or Object Pointer, is the object’s position in the Object List. This Object Number can be used to change the object on the fly. You can change the parameters of any object in the Object List with the <span class="T7">Gr.modify</span> command. This feature allows you easily to create animations without the overhead of having to recreate every object in the Object List.</p><p class="Standard">To draw graphical objects on the graphics screen, BASIC! uses a Display List. The Display List contains pointers to graphical objects on the Object List. Each time a graphical object is added to the Object List, its Object Number is also added to the Display List. Objects are drawn on the screen in the order in which they appear in the Display List. The Display List objects are not visible on the screen until the <span class="T7">Gr.render</span> command is called.</p><p class="Standard">You may use the <span class="T7">Gr.NewDL</span> command to replace the current Display List with a custom display list array. This custom display list array may contain some or all of the Object Numbers in the Object List.</p><p class="Standard">One use for custom display lists is to change the Z order of the objects. In other words you can use this feature to change which objects will be drawn on top of other objects.</p><p class="Standard">See the Sample Program file, f24_newdl, for a working example of <span class="T7">Gr.NewDL</span>.</p><h3 class="Heading_20_3"><a id="a__Drawing_Coordinates"><span/></a><a id="_Toc5236168"/>Drawing Coordinates</h3><p class="Standard">The size and location of an object drawn on the screen are specified in pixels. The coordinates of the pixel at the upper-left corner of the screen are x = 0 (horizontal position) and y = 0 (vertical position). Coordinate values increase from left to right and from top to bottom of the screen.</p><p class="Standard">Coordinates are measured with respect to the physical screen, not to anything on it. If you choose to show the Android Status Bar, anything you draw at the top of the screen is covered by the Status Bar.</p><h3 class="Heading_20_3"><a id="a__Drawing_into_Bitmaps"><span/></a><a id="_Toc5236169"/>Drawing into Bitmaps</h3><p class="Standard">You can draw into bitmaps in addition to drawing directly to the screen. You notify BASIC! that you want to start drawing into a bitmap instead of the screen with the <span class="T7">Gr.bitmap.drawinto.start</span> command. This puts BASIC! into the draw-into-bitmap mode. All draw commands issued while in this mode will draw directly into the bitmap. The objects drawn in this mode will not be placed into the Object List. The Object Number returned by a draw command while in this mode is invalid and should not be used for any purpose including <span class="T7">Gr.modify</span>.</p><p class="Standard">The draw-into-bitmap mode is ended by the <span class="T7">Gr.bitmap.drawinto.end</span> command. Subsequent draw commands will place the objects on the Object List and object numbers in the Display List for rendering on the screen. If you wish to display the drawn-into bitmap on the screen, issue a <span class="T7">Gr.bitmap.draw</span> command for that bitmap. The drawn-into bitmap may be drawn at any time before, during or after the draw-into process.</p><h3 class="Heading_20_3"><a id="a__Colors"><span/></a><a id="_Toc5236170"/>Colors</h3><p class="Standard">BASIC! colors consist of a mixture of Red, Green, and Blue. Each component has a numerical value ranging from 0 to 255. Black occurs when all three values are zero. White occurs when all three values are 255. Solid Red occurs with a Redvalue of 255 while Blue and Green are zero.</p><p class="Standard">Colors also have what is called an Alpha Channel. The Alpha Channel describes the level of opaqueness of the color. An Alpha value of 255 is totally opaque. No object of any color can show through an object with an Alpha value of 255. An Alpha value of zero renders the object invisible.</p><h3 class="Heading_20_3"><a id="a__Paints"><span/></a><a id="_Toc5236171"/>Paints</h3><p class="Standard">BASIC! holds drawing information such as color, font size, style and so forth, in Paint objects. The Paint objects are stored in a Paint List. The last created Paint object (the "Current Paint") is associated with a graphical object when a draw command is executed. The Paint tells the renderer (see <span class="T7">Gr.render</span>) how to draw the graphical object. The same Paint may be attached to many graphical objects so they will all be drawn with the same color, style, etc.</p><h4 class="Heading_20_4"><a id="a__Basic_usage"><span/></a>Basic usage</h4><p class="Standard">You can ignore Paints. This can keep your graphics programming simpler.</p><p class="Standard">Each command that changes a drawing setting (<span class="T7">Gr.color</span>, <span class="T7">Gr.text.size</span>, etc.) affects everything you draw from that point on, until you execute another such command.</p><h4 class="Heading_20_4"><a id="a__Advanced_usage"><span/></a>Advanced usage</h4><p class="Standard">You can control the Paint objects used to draw graphical objects. The extra complexity allows you to create special effects that are not otherwise possible. To use these effects, you must understand the Paint List and the Current Paint.</p><p class="Standard">Each command that changes a drawing setting (<span class="T7">Gr.color</span>, <span class="T7">Gr.text.size</span>, etc.) creates or modifies a Paint. Each of these commands has an optional "Paint pointer" parameter. If you don’t specify which Paint to use, the command first copies the Current Paint and then modifies it to make a new Paint, which then becomes the Current Paint. If you do specify which Paint to use, the command modifies only the specified Paint, leaving the Current Paint unchanged.</p><p class="Standard">The Current Paint is always the last Paint on the Paint List.If you specify the Paint object, the pointer values -1 and 0 are special.</p><p class="Standard">Paint pointer value -1 means the Current Paint. Using -1 is the same as omitting the Paint pointer parameter.</p><p class="Standard">Paint pointer value 0 refers to a "working Paint". You can change it as often as you like without generating a new Paint. Paint 0 can not be attached to a graphical object. To make it useful, you must copy it (<span class="T7">Gr.paint.copy</span>) to another location in the Paint List, or to the Current Paint.</p><p class="Standard">You can get a pointer to the current Paint with the <span class="T7">Gr.paint.get</span> command. You can get a pointer to the Paint associated with any graphical object by using the "paint" tag with <span class="T7">Gr.get.value</span> command. You can assign that Paint to any other graphical object by using the "paint" tag with <span class="T7">Gr.modify</span> command.</p><p class="Standard">Paints can not be individually deleted. You may delete all Paint objects, along with all graphics objects, with <span class="T7">Gr.cls</span>.</p><p class="Standard">The commands <span class="T7">Gr.paint.copy</span> and <span class="T7">Gr.paint.reset</span> operate directly on Paint objects.</p><h3 class="Heading_20_3"><a id="a__Style"><span/></a><a id="_Toc5236172"/>Style</h3><p class="Standard">Most graphics objects are made up of two parts: an outline and the center. There is a subtle but important difference in the rules governing how each part is drawn. The two parts are controlled by the style setting of the Paint object, set by the style parameter of the <span class="T7">Gr.color</span> command.</p><p class="Standard">Note: Gr.Point and Gr.Line are not affected by style. Only the STROKE part (outline) is drawn. </p><h4 class="Heading_20_4"><a id="a__STROKE"><span/></a>STROKE</h4><p class="P109">If you specify STROKE (style 0), only the outline is drawn. The center of the shape is not colored. The width of the outline is controlled by the stroke weight setting of the Paint, set by the <span class="T7">Gr.stroke</span> command. If the stroke weight is 0 or 1 (they behave the same way), the outline is drawn exactly on the coordinates you provide. For example, if the shape is a rectangle:</p><p class="List_20_Paragraph"><span class="T7">left</span>: The left-most edge. All pixels with x-coordinate <span class="T7">left</span> are colored.</p><p class="List_20_Paragraph"><span class="T7">top</span>: The upper-most edge. All pixels with y-coordinate <span class="T7">top</span> are colored.</p><p class="List_20_Paragraph"><span class="T7">right</span>: The right-most edge. All pixels with x-coord <span class="T7">right</span> are colored.</p><p class="List_20_Paragraph"><span class="T7">bottom</span>: The lower-most edge. All pixels with y-coord <span class="T7">bottom</span> are colored.</p><p class="Standard">This is probably what you expect.</p><p class="Standard">When you increase the stroke weight, the lines get wider, but the centers of the lines do not change. Additional lines of pixels are colored on both sides of the outline. Increasing the stroke weight generally increases the area of the shape, making it larger than the dimensions you specify.</p><p class="Standard">This may not be what you expect. In some drawing systems, increasing the line width grows the line inward only, toward the center of the shape, so the shape does not get any bigger.</p><h4 class="Heading_20_4"><a id="a__FILL"><span/></a>FILL</h4><p class="P109">If you specify FILL (style 1), the center of the shape is filled as if it had an outline. That is, the center of the object is colored, but the pixels colored by STROKE may be left uncolored. The area that is colored depends on the coordinates of the shape. For example, consider a rectangle:</p><p class="List_20_Paragraph"><span class="T7">left</span>: The left-most edge. All pixels with x-coordinate <span class="T7">left</span> are colored.</p><p class="List_20_Paragraph"><span class="T7">top</span>: The upper-most edge. All pixels with y-coordinate <span class="T7">top</span> are colored.</p><p class="List_20_Paragraph"><span class="T7">right</span>: One more than the right-most edge. All pixels with x-coord <span class="T7">right - 1</span> are colored.</p><p class="List_20_Paragraph"><span class="T7">bottom</span>: One more than the lower-most edge. Pixels with y-coord <span class="T7">bottom - 1</span> are colored.</p><p class="Standard"><span class="T7">left</span> and <span class="T7">top</span> values are "inclusive": pixels with x-coodinate <span class="T7">left</span> are colored. Pixels with y-coordinate <span class="T7">top</span> are colored.</p><p class="Standard"><span class="T7">right</span> and <span class="T7">bottom</span> values are "exclusive": pixels with x-coodinate <span class="T7">right</span> are <span class="T7">not</span> colored. Pixels with y-coordinate <span class="T7">bottom</span> are <span class="T7">not</span> colored.</p><p class="Standard">This is not what most people expect, but it is consistent with many operations in Java programming.</p><h4 class="Heading_20_4"><a id="a__STROKE_and_FILL"><span/></a>STROKE and FILL</h4><p class="Standard">If you specify STROKE_AND_FILL (style 2), both parts of the shape are drawn and superimposed. That is, the outline is drawn as described in STROKE, above, and the object is filled in as described in FILL. Because both parts are the same color, and there are never uncolored pixels beween the STROKE lines and the FILL area, the effect is to draw a single solid shape. Note that increasing the stroke weight generally makes the shape bigger than the dimensions you specify.</p><h3 class="Heading_20_3"><a id="a__Hardware-accelerated_Graphics"><span/></a><a id="_Toc5236173"/>Hardware-accelerated Graphics</h3><p class="Standard">Many Android devices since 3.0 (Honeycomb) support hardware acceleration of some graphical operations. An app that can use the hardware Graphics Processor (GPU) may run significantly faster than one that cannot use the GPU. Some of BASIC!’s graphical operations do not work with hardware-acceleration, so it is disabled by default. You can turn it on with the <span class="T7">Graphic Acceleration</span> item of the <span class="T7">Editor-&gt;Menu-&gt;Preferences</span> screen.</p><p class="Standard">If you enable accelerated graphics, test your app thoroughly, comparing it to what you see with acceleration off. If you see blurring, missing objects, or other problems, leave acceleration disabled.</p><h2 class="Heading_20_2"><a id="a__Graphics_Setup_Commands"><span/></a><a id="_Toc5236174"/>Graphics Setup Commands</h2><h3 class="Heading_20_3"><a id="a__Gr_open_{{alpha}{__red}{__green}{__blue}{___ShowStatusBar_lexp_}{___Orientation_nexp_}}"><span/></a><a id="_Toc5236175"/>Gr.open {{alpha}{, red}{, green}{, blue}{, &lt;ShowStatusBar_lexp&gt;}{, &lt;Orientation_nexp&gt;}}</h3><p class="Standard">Opens the Graphics Screen and puts BASIC! into Graphics Mode. The color values become the background color of the graphics screen. The default color is opaque white (255,255,255,255).</p><p class="Standard">All parameters are optional; use commas to indicate omitted parameters (see Optional Parameters).</p><p class="Standard">Each of the four color components is a numeric expression with a value from 0 through 255. If a value is outside of this range, only the last eight bits of the value are used; for example, 257 and 1025 are the same as 1. If any color parameter is omitted, it is set to 255.</p><p class="Standard">The Status Bar will be shown on the graphics screen if the &lt;ShowStatusBar_lexp&gt; is true (not zero). If the &lt;ShowStatusBar_lexp&gt; is not present, the Status Bar will not be shown.</p><p class="Standard">The orientation upon opening graphics will be determined by the &lt;Orientation_nexp&gt; value. &lt;Orientation_nexp&gt; values are the same as values for the <span class="T7">Gr.orientation</span> command (see below). If the &lt;Orientation_nexp&gt; is not present, the default orientation is Landscape.</p><h3 class="Heading_20_3"><a id="a__Gr_color_{{alpha}{__red}{__green}{__blue}{__style}{__paint}}"><span/></a><a id="_Toc5236176"/>Gr.color {{alpha}{, red}{, green}{, blue}{, style}{, paint}} </h3><p class="P109">Sets the color and style for drawing objects. There are two ways to use this command.</p><ul><li><p class="P45" style="margin-left:1.27cm;"><span class="ListLabel_20_73" style="display:block;float:left;min-width:0.635cm;"></span><span class="T18">Basic usage</span>: ignore the optional &lt;paint&gt; parameter. The new color and style will be used for whatever graphical objects are subsequently drawn until the next <span class="T7">Gr.color</span> command is executed.<span class="odfLiEnd"/> </p></li><li><p class="P45" style="margin-left:1.27cm;"><span class="ListLabel_20_73" style="display:block;float:left;min-width:0.635cm;"></span><span class="T18">Advanced usage</span>: The "basic usage" of this command always creates a new Paint. If you prefer, you can use the &lt;paint&gt; parameter to specify an existing Paint. The <span class="T7">Gr.color</span> command sets the color and style of that Paint, changing the appearance of any graphical object to which it is attached. The current Paint is not changed. See "Paints <span class="T18">Advanced Usage</span>" above and the example below.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">All of the parameters are optional. If a color component or the style is omitted, that component is left unchanged. For example, <span class="T7">Gr.color ,,0</span> sets only green to 0, leaving alpha, red, blue, and style as they were. Use commas to indicate omitted parameters (see Optional Parameters).</p><p class="Standard">Each of the four color components (alpha, red, green, blue) is a numeric expression with a value from 0 through 255. If a value is outside of this range, only the last eight bits of the value are used; for example, 257 and 1025 are both the same as 1.</p><p class="Standard">The style parameter, is a numeric expression that determines the stroking and filling of objects. The effect of this parameter is explained in detail in the "Style" sections, see above. The possible values for &lt;style_nexp&gt; are shown in this table:</p><table border="0" cellspacing="0" cellpadding="0" class="Table30"><colgroup><col width="62"/><col width="146"/><col width="513"/></colgroup><tr class="Table301"><td style="text-align:left;width:1.427cm; " class="Table30_A1"><p class="P124">Value</p></td><td style="text-align:left;width:3.336cm; " class="Table30_A1"><p class="P124">Meaning</p></td><td style="text-align:left;width:11.748cm; " class="Table30_A1"><p class="P124">Description</p></td></tr><tr class="Table301"><td style="text-align:left;width:1.427cm; " class="Table30_A2"><p class="P128">0</p></td><td style="text-align:left;width:3.336cm; " class="Table30_A2"><p class="P114">STROKE</p></td><td style="text-align:left;width:11.748cm; " class="Table30_A2"><p class="P114">Geometry and text drawn with this style will be stroked (outlined), respecting the stroke-related fields on the paint.</p></td></tr><tr class="Table301"><td style="text-align:left;width:1.427cm; " class="Table30_A2"><p class="P128">1</p></td><td style="text-align:left;width:3.336cm; " class="Table30_A2"><p class="P114">FILL</p></td><td style="text-align:left;width:11.748cm; " class="Table30_A2"><p class="P114">Geometry and text drawn with this style will be filled, ignoring all stroke-related settings in the paint.</p></td></tr><tr class="Table301"><td style="text-align:left;width:1.427cm; " class="Table30_A2"><p class="P128">2</p></td><td style="text-align:left;width:3.336cm; " class="Table30_A2"><p class="P114">STROKE_AND_FILL</p></td><td style="text-align:left;width:11.748cm; " class="Table30_A2"><p class="P114">Geometry and text drawn with this style will be filled and stroked at the same time, respecting the stroke-related fields on the paint.</p></td></tr></table><p class="P109"> </p><p class="Standard">If you specify a value other than -1, 0, 1, or 2, then the style is set to 2. If you specify a style of -1, the style is left unchanged, just as if the style parameter were omitted. If you never set a style, the default value is 1, FILL.</p><p class="Standard">You can change the stroke weight with commands such as <span class="T7">Gr.set.stroke</span> (see below) and the various text style commands.</p><p class="No_20_Spacing">Example:</p><p class="Code_20_example"><span class="T11">GR.OPEN</span></p><p class="Code_20_example"><span class="T11">! basic usage</span></p><p class="Code_20_example"><span class="T11">GR.COLOR ,0,0,255,2                        % opaque blue, stroke and fill</span></p><p class="Code_20_example"><span class="T11">GR.RECT r1, 50,50,100,100                % draw two squares</span></p><p class="Code_20_example"><span class="T11">GR.RECT r2, 100,100,150,150</span></p><p class="Code_20_example"><span class="T11">GR.COLOR 128,255,0,0                        % half-transparent red</span></p><p class="Code_20_example"><span class="T11">GR.RECT r3, 75,75,125,125                % draw an overlapping square</span></p><p class="Code_20_example"><span class="T11">GR.RENDER : PAUSE 2000</span></p><p class="Code_20_example"><span class="T11">! advanced usage</span></p><p class="Code_20_example"><span class="T11">GR.GET.VALUE r1, "paint", p                % get index of first Paint</span></p><p class="Code_20_example"><span class="T11">GR.COLOR 255,0,255,0,,p                % change that Paint’s color to opaque green</span></p><p class="Code_20_example"><span class="T11">GR.RENDER : PAUSE 2000                % both r1 and r2 change</span></p><p class="Code_20_example"><span class="T11">GR.RECT r4, 125,125,175,175                % use current Paint, unchanged</span></p><p class="Code_20_example"><span class="T11">GR.RENDER : PAUSE 2000                % still draws half-transparent red</span></p><p class="Code_20_example"><span class="T11">GR.CLOSE : END</span></p><h3 class="Heading_20_3"><a id="a__Gr_set_antialias_{{_lexp_}{__paint_nexp_}}"><span/></a><a id="_Toc5236177"/>Gr.set.antialias {{&lt;lexp&gt;}{,&lt;paint_nexp&gt;}}</h3><p class="No_20_Spacing">Turns antialiasing on or off on objects drawn after this command is issued:</p><ul><li><p class="P46" style="margin-left:1.27cm;"><span class="ListLabel_20_77" style="display:block;float:left;min-width:0.635cm;"></span>If the value of the antialias setting parameter &lt;lexp&gt; is false (0), AntiAlias is turned off.<span class="odfLiEnd"/> </p></li><li><p class="P46" style="margin-left:1.27cm;"><span class="ListLabel_20_77" style="display:block;float:left;min-width:0.635cm;"></span>If the parameter value is true (not zero), AntiAlias is turned on.<span class="odfLiEnd"/> </p></li><li><p class="P46" style="margin-left:1.27cm;"><span class="ListLabel_20_77" style="display:block;float:left;min-width:0.635cm;"></span>If the parameter is omitted, the AntiAlias setting is toggled.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">AntiAlias should generally be on. It is on by default.</p><p class="Standard">AntiAlias must be off to draw single-pixel pixels and single-pixel-wide horizontal and vertical lines.</p><p class="Standard">You may use the optional Paint pointer parameter &lt;paint_nexp&gt; to specify a Paint object to modify. Normally this parameter is omitted. See <span class="T7">Gr.color</span>, <span class="T18">Advanced usage</span> for more information.</p><h3 class="Heading_20_3"><a id="a__Gr_set_stroke_{{_nexp_}{__paint_nexp_}}"><span/></a><a id="_Toc5236178"/>Gr.set.stroke {{&lt;nexp&gt;}{,&lt;paint_nexp&gt;}}</h3><p class="Standard">Sets the line width of objects drawn after this command is issued. The &lt;nexp&gt; value must be &gt;=0. Zero produces the thinnest line and is the default stroke value.</p><p class="Standard">The thinnest horizontal lines and vertical lines will be two pixels wide if AntiAlias is on. Turn AntiAlias off to draw single-pixel-wide horizontal and vertical lines.</p><p class="Standard">Pixels drawn by the <span class="T7">Gr.set.pixels</span> command will be drawn as a 2x2 matrix if AntiAlias is on. To draw single-pixel pixels, set AntiAlias off and set the stroke = 0.</p><p class="Standard">You may use the optional Paint pointer parameter &lt;paint_nexp&gt; to specify a Paint object to modify. Normally this parameter is omitted. See <span class="T7">Gr.color</span>, <span class="T18">Advanced usage</span> for more information.</p><h3 class="Heading_20_3"><a id="a__Gr_orientation__nexp_"><span/></a><a id="_Toc5236179"/>Gr.orientation &lt;nexp&gt;</h3><p class="No_20_Spacing">The value of the &lt;nexp&gt; sets the orientation of screen as follows:</p><p class="List_20_Paragraph">-1 = Orientation depends upon the sensors.</p><p class="List_20_Paragraph"> 0 = Orientation is forced to Landscape.</p><p class="List_20_Paragraph"> 1 = Orientation is forced to Portrait.</p><p class="List_20_Paragraph"> 2 = Orientation is forced to Reverse Landscape.</p><p class="List_20_Paragraph"> 3 = Orientation is forced to Reverse Portrait.</p><p class="Standard">You can monitor changes in orientation by reading the screen width and height using the the <span class="T7">Gr.screen</span> or <span class="T7">Screen</span> commands.</p><h3 class="Heading_20_3"><a id="a__Gr_statusbar_{_height_nvar_}_{__showing_lvar}"><span/></a><a id="_Toc5236180"/>Gr.statusbar {&lt;height_nvar&gt;} {, showing_lvar} </h3><p class="Standard">Returns information about the Status Bar. If the <span class="T7">height</span> variable &lt;height_nvar&gt; is present, it is set to the nominal height of the Status Bar. If the <span class="T7">showing</span> flag &lt;showing_lvar&gt; is present, it is set to <span class="T7">0</span> (false, not showing) or <span class="T7">1</span> (true, showing) based on on how Graphics Mode was opened.</p><p class="Standard">The parameters are both optional. If you omit the first parameter but use the second, you must keep the comma.</p><h3 class="Heading_20_3"><a id="a__Gr_statusbar_show__nexp_"><span/></a><a id="_Toc5236181"/>Gr.statusbar.show &lt;nexp&gt;</h3><p class="Standard">This command has been deprecated. To show the status bar on the graphics screen, use the optional fifth parameter in <span class="T7">Gr.open</span>.</p><h3 class="Heading_20_3"><a id="a__Gr_render"><span/></a><a id="_Toc5236182"/>Gr.render</h3><p class="Standard">This command displays all the objects that are listed in the current working Display List. It is not necessary to have a <span class="T7">Pause</span> command after a <span class="T7">Gr.render</span>. The <span class="T7">Gr.render</span> command will not complete until the contents of the Display List have been fully displayed.</p><p class="P93"><span class="T7">Gr.render</span> always waits until the next screen refresh. Most Android devices refresh the screen 60 times per second; your device may be faster or slower. Therefore, if you execute two consecutive <span class="T7">Gr.render</span> commands, there will be a delay of 16.7 milliseconds (on most devices) between the two commands.</p><p class="P93">For smooth animation, try to avoid doing more than 16.7 ms of work between <span class="T7">Gr.render</span> commands, to achieve the maximum refresh rate. This is not a lot of time for a BASIC! program, so you may have to settle for a lower frame rate. However, there is no benefit to trying to render more often than 16.7 ms.</p><p class="Standard">If BASIC! is running in the background (see <span class="T7">Background()</span> function and <span class="T7">Home</span> command), <span class="T7">Gr.render</span> will not execute. It will pause your program until you return BASIC! to the foreground.</p><h3 class="Heading_20_3"><a id="a__Gr_screen_width__height{__density_}"><span/></a><a id="_Toc5236183"/>Gr.screen width, height{, density }</h3><p class="Standard">Returns the screen's width and height, and optionally its density, in the numeric variables. The density, in dots per inch (dpi), is a standardized Android density value (usually 120, 160, or 240 dpi), and not necessarily the real physical density of the screen.</p><p class="Standard">If a <span class="T7">Gr.orientation</span> command changes the orientation, the width and height values from a previous <span class="T7">Gr.screen</span> command are invalid.</p><p class="Standard">Android’s orientation-change animation takes time. You may need to wait for a second or so after <span class="T7">Gr.open</span> or <span class="T7">Gr.orientation</span> before executing <span class="T7">Gr.screen</span>, otherwise the width and height values may be set before the orientation change is complete.</p><p class="Standard"><span class="T7">Gr.screen</span> returns a subset of the information returned by the newer <span class="T7">Screen</span> command.</p><h3 class="Heading_20_3"><a id="a__Gr_scale_x_factor__y_factor"><span/></a><a id="_Toc5236184"/>Gr.scale x_factor, y_factor</h3><p class="Standard">Scale all drawing commands by the numeric x and y scale factors. This command is provided to allow you to draw in a device-independent manner and then scale the drawing to the actual size of the screen that your program is running on. For example:</p><p class="Code_20_example"><span class="T11">! Set the device independent sizes</span></p><p class="Code_20_example"><span class="T11">di_height = 480</span></p><p class="Code_20_example"><span class="T11">di_width = 800</span></p><p class="P2"> </p><p class="Code_20_example"><span class="T11">! Get the actual width and height</span></p><p class="Code_20_example"><span class="T11">gr.open                % defaults: white, no status bar, landscape</span></p><p class="Code_20_example"><span class="T11">gr.screen actual_w, actual_h</span></p><p class="P2"> </p><p class="Code_20_example"><span class="T11">! Calculate the scale factors</span></p><p class="Code_20_example"><span class="T11">scale_width = actual_w /di_width</span></p><p class="Code_20_example"><span class="T11">scale_height = actual_h /di_height</span></p><p class="P2"> </p><p class="Code_20_example"><span class="T11">! Set the scale</span></p><p class="Code_20_example"><span class="T11">gr.scale scale_width, scale_height</span></p><p class="Standard">Now, start drawing based upon di_height and di_width. The drawings will be scaled to fit the device running the program.</p><h3 class="Heading_20_3"><a id="a__Gr_cls"><span/></a><a id="_Toc5236185"/>Gr.cls</h3><p class="Standard">Clears the graphics screen. Deletes all previously drawn objects; all existing object references are invalid. Deletes all existing Paints and resets all <span class="T7">Gr.color</span> or <span class="T7">Gr.text</span> {size|align|bold|strike|underline|skew} settings. Disposes of the current Object List and Display List and creates a new Initial Display List.</p><p class="Standard">Note: bitmaps are not deleted. They will not be drawn because no graphical objects point to them, but the bitmaps still exist. Variables that point to them remain valid.</p><p class="Standard">The <span class="T7">Gr.render</span> command must be called to make the cleared screen visible to the user.</p><h3 class="Heading_20_3"><a id="a__Gr_close"><span/></a><a id="_Toc5236186"/>Gr.close</h3><p class="Standard">Closes the opened graphics mode. The program will continue to run. The graphics screen will be removed. The text output screen will be displayed.</p><h3 class="Heading_20_3"><a id="a__Gr_front_flag"><span/></a><a id="_Toc5236187"/>Gr.front flag</h3><p class="Standard">Determines whether the graphics screen or the Output Console will be the front-most screen. If flag = 0, the Output Console will be the front-most screen and seen by the user. If flag &lt;&gt; 0, the graphics screen will be the front-most screen and seen by the user.</p><p class="Standard">One use for this command is to display the Output Console to the user while in graphics mode. Use <span class="T7">Gr.front 0</span> to show text output and <span class="T7">Gr.front 1</span> to switch back to the graphics screen.</p><p class="Standard">Note: When the Output Console is in front of the graphics screen, you can still draw (but not render) onto the graphics screen. The <span class="T7">Gr.front 1</span> must be executed before any <span class="T7">Gr.render</span>.</p><p class="Standard">Print commands will continue to print to the Output Console even while the graphic screen is in front.</p><h3 class="Heading_20_3"><a id="a__Gr_brightness__nexp_"><span/></a><a id="_Toc5236188"/>Gr.brightness &lt;nexp&gt;</h3><p class="Standard">Sets the brightness of the graphics screen. The value of the numeric expression should be between 0.01 (darkest) and 1.00 (brightest).</p><h2 class="Heading_20_2"><a id="a__Graphical_Object_Creation_Commands"><span/></a><a id="_Toc5236189"/>Graphical Object Creation Commands</h2><p class="Standard">These commands create graphical objects and add them to the Object List, also adding their Object Numbers to the Display List. You create each object with parameters that describe what to draw and where. Once it is created, you can read back its parameters by name with the <span class="T7">Gr.get.value</span> command. You can change any parameter with the <span class="T7">Gr.modify</span> command. The parameters you can modify are listed with each command's description. Along with the parameters listed with each command, every graphical object has two other modifiable parameters, "paint" and "alpha". See the <span class="T7">Gr.modify</span> and <span class="T7">Gr.paint.get</span> command descriptions for more details.</p><p class="Standard">There are three commands that create graphical objects that are not in this section: <span class="T7">Gr.text.draw</span>, <span class="T7">Gr.bitmap.draw</span>, and <span class="T7">Gr.clip</span>.</p><h3 class="Heading_20_3"><a id="a__Gr_point__obj_nvar___x__y"><span/></a><a id="_Toc5236190"/><a id="_Gr.point_&lt;object_number_nvar&gt;,_x,"/>Gr.point &lt;obj_nvar&gt;, x, y</h3><p class="Standard">Creates a point object. The point will be located at (x,y). The &lt;obj_nvar&gt; returns the Object List object number for this point. This object will not be visible until the <span class="T7">Gr.render</span> command is called.</p><p class="Standard">The appearance of the point object is affected by the current stroke weight and the AntiAlias setting. The object is rendered as a square, centered on (x,y) and as big as the current stroke. If AntiAlias is on, it will blur the point, making it larger and dimmer. To color a single pixel, use <span class="T7">Gr.set.stroke 0</span> and <span class="T7">Gr.set.antialias 0</span>.</p><p class="Standard">The <span class="T7">Gr.modify</span> parameters for <span class="T7">Gr.point</span> are: "x" and "y".</p><h3 class="Heading_20_3"><a id="a__Gr_line__obj_nvar___x1__y1__x2__y2"><span/></a><a id="_Toc5236191"/><a id="_Gr.line_&lt;object_number_nvar&gt;,_x1,"/>Gr.line &lt;obj_nvar&gt;, x1, y1, x2, y2</h3><p class="Standard">Creates a line object. The line will start at (x1,y1) and end at (x2,y2). The &lt;obj_nvar&gt; returns the Object List object number for this line. This object will not be visible until the <span class="T7">Gr.render</span> command is called.</p><p class="Standard">The thinnest horizontal lines and vertical lines are drawn with <span class="T7">Gr.set.stroke 0</span>. These lines will be two pixels wide if AntiAlias is on. Turn AntiAlias off to draw single-pixel wide horizontal and vertical lines.</p><p class="Standard">The <span class="T7">Gr.modify</span> parameters for <span class="T7">Gr.line</span> are: "x1", "y1", "x2" and "y2".</p><h3 class="Heading_20_3"><a id="a__Gr_rect__ob_nvar___left__top__right__bottom"><span/></a><a id="_Toc5236192"/><a id="_Gr.rect_&lt;object_number_nvar&gt;,_left,"/>Gr.rect &lt;ob_nvar&gt;, left, top, right, bottom</h3><p class="Standard">Creates a rectangle object. The rectangle will be located within the bounds of the parameters. The rectangle will or will not be filled depending upon the <span class="T7">Gr.color</span> style parameter. The &lt;obj_nvar&gt; returns the Object List object number for this rectangle. This object will not be visible until the <span class="T7">Gr.render</span> command is called.</p><p class="Standard">The <span class="T7">Gr.modify</span> parameters for <span class="T7">Gr.rect</span> are: "left", "top", "right" and "bottom".</p><h3 class="Heading_20_3"><a id="a__Gr_oval__obj_nvar___left__top__right__bottom"><span/></a><a id="_Toc5236193"/><a id="_Gr.oval_&lt;object_number_nvar&gt;,_left,"/>Gr.oval &lt;obj_nvar&gt;, left, top, right, bottom</h3><p class="Standard">Creates an oval-shaped object. The oval will be located within the bounds of the parameters. The oval will or will not be filled depending upon the <span class="T7">Gr.color</span> style parameter. The &lt;obj_nvar&gt; returns the Object List object number for this oval. This object will not be visible until the <span class="T7">Gr.render</span> command is called.</p><p class="Standard">The <span class="T7">Gr.modify</span> parameters for <span class="T7">Gr.oval</span> are: "left", "top", "right" and "bottom".</p><h3 class="Heading_20_3"><a id="a__Gr_arc__obj_nvar___left__top__right__bottom__start_angle__sweep_angle__fill_mode"><span/></a><a id="_Toc5236194"/><a id="_Gr.arc_&lt;object_number_nvar&gt;,_left,"/>Gr.arc &lt;obj_nvar&gt;, left, top, right, bottom, start_angle, sweep_angle, fill_mode</h3><p class="Standard">Creates an arc-shaped object. The arc will be created within the rectangle described by the parameters. It will start at the specified start_angle and sweep clockwise through the specified sweep_angle. The angle values are in degrees.</p><p class="P109">The effect of the fill_mode parameter depends on the <span class="T7">Gr.color</span> style parameter:</p><ul><li><p class="P47" style="margin-left:1.27cm;"><span class="ListLabel_20_45" style="display:block;float:left;min-width:0.635cm;"></span>Style 0, fill_mode false: Only the arc is drawn.<span class="odfLiEnd"/> </p></li><li><p class="P47" style="margin-left:1.27cm;"><span class="ListLabel_20_45" style="display:block;float:left;min-width:0.635cm;"></span>Style 0, fill_mode true: The arc is drawn with lines connecting each endpoint to the center of the bounding rectangle. The resulting closed figure is not filled.<span class="odfLiEnd"/> </p></li><li><p class="P47" style="margin-left:1.27cm;"><span class="ListLabel_20_45" style="display:block;float:left;min-width:0.635cm;"></span>Style non-0, fill_mode false: The endpoints of the arc are connected by a single straight line. The resulting figure is filled.<span class="odfLiEnd"/> </p></li><li><p class="P47" style="margin-left:1.27cm;"><span class="ListLabel_20_45" style="display:block;float:left;min-width:0.635cm;"></span>Style non-0, fill_mode true: The arc is drawn with lines connecting each endpoint to the center of the bounding rectangle. The resulting closed figure is filled.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">The &lt;obj_nvar&gt; returns the Object List object number for this arc. This object will not be visible until the <span class="T7">Gr.render</span> command is called.</p><p class="Standard">The <span class="T7">Gr.modify</span> parameters for <span class="T7">Gr.arc</span> are: "left", "top", "right", "bottom", "start_angle", "sweep_angle" and "fill_mode". The value for "fill_mode" is either false (0) or true (not 0).</p><h3 class="Heading_20_3"><a id="a__Gr_circle__obj_nvar___x__y__radius"><span/></a><a id="_Toc5236195"/><a id="_Gr.circle_&lt;object_number_nvar&gt;,_x,"/>Gr.circle &lt;obj_nvar&gt;, x, y, radius</h3><p class="Standard">Creates a circle object. The circle will be created with the given radius around the designated center (x,y) coordinates. The circle will or will not be filled depending upon the <span class="T7">Gr.color</span> style parameter. The &lt;obj_nvar&gt; returns the Object List object number for this circle. This object will not be visible until the <span class="T7">Gr.render</span> command is called.</p><p class="Standard">The <span class="T7">Gr.modify</span> parameters for <span class="T7">Gr.circle</span> are "x", "y", and "radius".</p><h3 class="Heading_20_3"><a id="a__Gr_set_pixels__obj_nvar___pixels_{_start___length_}__{_x_y}"><span/></a><a id="_Toc5236196"/><a id="_Gr.set.pixels_&lt;object_number_nvar&gt;,"/>Gr.set.pixels &lt;obj_nvar&gt;, pixels[{&lt;start&gt;,&lt;length&gt;}] {,x,y}</h3><p class="Standard">Inserts an array of pixel points into the Object List. The array (pixels[]) or array segment (pixels[start,length]) contains pairs of x and y coordinates for each pixel. The pixels[] array or array segment may be any size but must have an even number of elements.</p><p class="Standard">If the optional x,y expression pair is present, the values will be added to each of the x and y coordinates of the array. This provides the ability to move the pixel array around the screen. The default values for the x,y pair is 0,0. Negative values for the x,y pair are valid.</p><p class="Standard">Pixels will be drawn as 2x2 matrix pixels if AntiAlias is on and the stroke = 0. To draw single-pixel pixels, set AntiAlias off and set the stroke = 0. AntiAlias in on by default.</p><p class="Standard">The &lt;obj_nvar&gt; returns the Object List object number for the object. The pixels will not be visible until the <span class="T7">Gr.render</span> command is called.</p><p class="Standard">The <span class="T7">Gr.modify</span> parameters for this command are "x" and "y".</p><p class="Standard">In addition to modify, the individual elements of the pixel array can be changed on the fly. For example:</p><p class="Code_20_example"><span class="T11">Pixels[3] = 120</span></p><p class="Code_20_example"><span class="T11">Pixels[4] = 200</span></p><p class="Standard">will cause the second pixel to be located at x = 120, y = 200 at the next rendering.</p><h3 class="Heading_20_3"><a id="a__Gr_poly__obj_nvar___list_pointer_{_x__y}"><span/></a><a id="_Toc5236197"/><a id="_Gr.poly_&lt;object_number_nvar&gt;,_list_"/>Gr.poly &lt;obj_nvar&gt;, list_pointer {,x, y}</h3><p class="Standard">Creates an object that draws a closed polygon of any number of sides. The &lt;obj_nvar&gt; returns the Object List object number for this polygon. This object will not be visible until the next <span class="T7">Gr.render</span>.</p><p class="Standard">The list_pointer is an expression that points to a List data structure. The list contains x,y coordinate pairs. The first coordinate pair defines the point at which the polygon drawing starts. Each subsequent coordinate pair defines a line drawn from the previous coordinate pair to this coordinate pair. A final line drawn from the last point back to the first closes the polygon.</p><p class="Standard">If the optional x,y expression pair is present, the values will be added to each of the x and y coordinates of the list. This provides the ability to move the polygon array around the screen. The default x,y pair is 0,0. Negative values for x and y are valid.</p><p class="Standard">The polygon line width, line color, alpha and fill are determined by previous <span class="T7">Gr.color</span> and <span class="T7">Gr.set.stroke</span> commands just like any other drawn object. These attributes are owned by the <span class="T7">poly</span> object, not by the list. If you use the same list in different <span class="T7">Gr.poly</span> commands, the color, stroke, etc., may be different.</p><p class="Standard">You can change the polygon (add, delete, or move points) by directly manipulating the list with <span class="T7">List</span> commands. You can change to a different list of points using <span class="T7">Gr.Modify</span> with "list" as the tag parameter. Changes are not visible until the <span class="T7">Gr.render</span> command is called.</p><p class="Standard">When you create a polygon with <span class="T7">Gr.poly</span> or attach a new list with <span class="T7">Gr.modify</span>, the list must have an even number of values and at least two coordinate pairs (four values). These rules are enforced with run-time errors. The rules cannot be enforced when you modify the list with <span class="T7">List</span> commands. Instead, if you have an odd number of coordinates, the last is ignored. If you have only one point, <span class="T7">Gr.render</span> draws nothing.</p><p class="Standard">The <span class="T7">Gr.modify</span> parameters are "x", "y" and "list".</p><p class="Standard">See the Sample Program file, f30_poly, for working examples of <span class="T7">Gr.poly</span>.</p><h2 class="Heading_20_2"><a id="a__Groups"><span/></a><a id="_Toc5236198"/>Groups</h2><p class="Standard">You can put graphical objects into groups. A group is a list of graphical objects. When you perform certain operation on a group, the operation is performed on each object in the group.</p><p class="Standard">You group graphical objects by creating a Group Object on the Display List. You use the group by putting its object number in a graphics command where you would use any other graphical object number.</p><p class="Standard">In this version of BASIC!, you can use a Group Object in these commands:</p><ul><li><p class="P48" style="margin-left:1.27cm;"><span class="ListLabel_20_49" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">Gr.move</span>: moves all of the objects by the same x and y amounts<span class="odfLiEnd"/> </p></li><li><p class="P48" style="margin-left:1.27cm;"><span class="ListLabel_20_49" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">Gr.hide</span>: hides all of the objects<span class="odfLiEnd"/> </p></li><li><p class="P48" style="margin-left:1.27cm;"><span class="ListLabel_20_49" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">Gr.show</span>: shows (unhides) all of the objects<span class="odfLiEnd"/> </p></li><li><p class="P48" style="margin-left:1.27cm;"><span class="ListLabel_20_49" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">Gr.show.toggle</span>: any objects that are showing will be hidden, and any objects that are hidden will be shown.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">You use graphics commands to act on the objects in the group’s list. You use the <span class="T7">List</span> commands to act on the list: add objects, count the objects, clear the list, and so on.</p><p class="Standard">Try running this example. Watch as the top circle moves to the right, then the top two, and finally the top three, as circles are added one-by-one to the list attached to the group.</p><p class="Code_20_example"><span class="T11">GR.OPEN ,,,,,1 : GR.COLOR ,255,0,0,2</span></p><p class="Code_20_example"><span class="T11">GR.CIRCLE c1,100,100,40 : GR.CIRCLE c2,100,200,40</span></p><p class="Code_20_example"><span class="T11">GR.CIRCLE c3,100,300,40 : GR.CIRCLE c4,100,400,40</span></p><p class="Code_20_example"><span class="T11">GR.RENDER : PAUSE 1000                % draw four red circles</span></p><p class="P2"> </p><p class="Code_20_example"><span class="T11">GR.GROUP g, c1                                % create a group with one circle</span></p><p class="Code_20_example"><span class="T11">GR.GET.VALUE g, "list", gList        % get the group’s list of objects</span></p><p class="Code_20_example"><span class="T11">GR.MOVE g, 0, 50                        % move whole group 0 up/down, 50 right</span></p><p class="Code_20_example"><span class="T11">GR.RENDER : PAUSE 1000                % only one circle moves</span></p><p class="P2"> </p><p class="Code_20_example"><span class="T11">LIST.ADD gList, c2                        % add another circle to the group’s list</span></p><p class="Code_20_example"><span class="T11">GR.MOVE g, 0, 50</span></p><p class="Code_20_example"><span class="T11">GR.RENDER : PAUSE 1000                % two circles move</span></p><p class="P2"> </p><p class="Code_20_example"><span class="T11">LIST.ADD gList, c2                        % add another circle to the group’s list</span></p><p class="Code_20_example"><span class="T11">GR.MOVE g, 0, 50                        % three circles move</span></p><p class="Code_20_example"><span class="T11">GR.RENDER : PAUSE 1000</span></p><p class="P2"> </p><p class="Code_20_example"><span class="T11">GR.CLOSE : END</span></p><h3 class="Heading_20_3"><a id="a__Gr_group__object_number_nvar_{___obj_nexp_}___"><span/></a><a id="_Toc5236199"/><a id="_Gr.group_&lt;object_number_nvar&gt;,_{"/>Gr.group &lt;object_number_nvar&gt;{, &lt;obj_nexp&gt;}...</h3><p class="Standard">Creates a group of graphical objects. All of the numeric expressions &lt;obj_nexp&gt; must evaluate to valid graphical object numbers. The object numbers are put in a list and attached to the group.</p><p class="Standard">The &lt;object_number_nvar&gt; returns the Object List object number for the group.</p><p class="Standard">The <span class="T7">Gr.modify</span> parameter is "list".</p><h3 class="Heading_20_3"><a id="a__Gr_group_list__object_number_nvar____list_ptr_nexp_"><span/></a><a id="_Toc5236200"/>Gr.group.list &lt;object_number_nvar&gt;, &lt;list_ptr_nexp&gt;</h3><p class="Standard">Creates a group from a list of graphical objects. The List is assumed to contain valid graphical object numbers, but it is not checked. The list is simply attached to the group.</p><p class="Standard">The list pointer parameter &lt;list_ptr_nexp&gt; is optional. If you provide an expression that evaluates to a valid List pointer, the List that the pointer addresses supplies the graphical objects that are put in the group. Otherwise, the group is empty. If you provide a numeric variable that does not already point to a list, the variable is set to point to the group’s empty list.</p><p class="Standard">The &lt;object_number_nvar&gt; returns the Object List object number for the group.</p><p class="Standard">The <span class="T7">Gr.modify</span> parameter is "list".</p><h3 class="Heading_20_3"><a id="a__Gr_group_getDL__object_number_nvar_"><span/></a><a id="_Toc5236201"/>Gr.group.getDL &lt;object_number_nvar&gt;</h3><p class="Standard">Creates a group from the current Display List. The Display List is copied to a new list that is attached to the group.</p><p class="Standard">The &lt;object_number_nvar&gt; returns the Object List object number for the group.</p><p class="Standard">The <span class="T7">Gr.modify</span> parameter is "list".</p><h3 class="Heading_20_3"><a id="a__Gr_group_newDL__object_number_nvar_"><span/></a><a id="_Toc5236202"/>Gr.group.newDL &lt;object_number_nvar&gt;</h3><p class="Standard">Replaces the existing Display List with a new list read from the specified group.</p><p class="Standard">The &lt;object_number_nvar&gt; returns the Object List object number for the group.</p><p class="Standard">The <span class="T7">Gr.modify</span> parameter is "list".</p><h2 class="Heading_20_2"><a id="a__Hide_and_Show_Commands"><span/></a><a id="_Toc5236203"/>Hide and Show Commands</h2><h3 class="Heading_20_3"><a id="a__Gr_hide__object_number_nexp_"><span/></a><a id="_Toc5236204"/>Gr.hide &lt;object_number_nexp&gt;</h3><p class="Standard">Hides the object with the specified Object Number. If the Object is a Group, all of the Graphical Objects in the Group are hidden. This change will not be visible until the <span class="T7">Gr.render</span> command is called.</p><h3 class="Heading_20_3"><a id="a__Gr_show__object_number_nexp_"><span/></a><a id="_Toc5236205"/>Gr.show &lt;object_number_nexp&gt;</h3><p class="Standard">Shows (unhides) the object with the specified Object Number. If the Object is a Group, all of the Graphical Objects in the Group are shown. This change will not be visible until the <span class="T7">Gr.render</span> command is called.</p><h3 class="Heading_20_3"><a id="a__Gr_show_toggle__object_number_nexp_"><span/></a><a id="_Toc5236206"/>Gr.show.toggle &lt;object_number_nexp&gt;</h3><p class="Standard">Toggles visibility of the object with the specified Object Number. If it is hidden, it will be shown. If it is shown, it will be hidden. If the Object is a Group, all of the Graphical Objects in the Group are toggled. This change will not be visible until the <span class="T7">Gr.render</span> command is called.</p><h2 class="Heading_20_2"><a id="a__Touch_Query_Commands"><span/></a><a id="_Toc5236207"/>Touch Query Commands</h2><p class="Standard">If the user touches the screen and then moves the finger without lifting the finger from the screen, the motion can be tracked by repeatedly calling on the touch query commands. This will allow you to program the dragging of graphical objects around the screen. The Sample Program, f23_breakout.bas, illustrates this with the code that moves the paddle.</p><p class="Standard">The OnGrTouch: label can be used optionally to interrupt your program when a new touch is detected.</p><p class="Standard">The touch commands report on one- or two-finger touches on the screen. If the two fingers cross each other on the x-axis then touch and touch2 will swap.</p><h3 class="Heading_20_3"><a id="a__Gr_touch_touched__x__y"><span/></a><a id="_Toc5236208"/>Gr.touch touched, x, y</h3><p class="Standard">Tests for a touch on the graphics screen. If the screen is being touched, Touched is returned as true (not 0) with the (x,y) coordinates of the touch. If the screen is not currently touched, Touched returns false (0) with the (x,y) coordinates of the last previous touch. If the screen has never been touched, the x and y variables are left unchanged. The command continues to return true as long as the screen remains touched.</p><p class="No_20_Spacing">If you want to detect a single short tap, after detecting the touch, you should loop until touched is false.</p><p class="Code_20_example"><span class="T11">DO</span></p><p class="Code_20_example"><span class="T11">GR.TOUCH touched, x, y</span></p><p class="Code_20_example"><span class="T11">UNTIL touched</span></p><p class="P2"> </p><p class="Code_20_example"><span class="T11">! Touch detected, now wait for</span></p><p class="Code_20_example"><span class="T11">! finger lifted</span></p><p class="Code_20_example"><span class="T11">DO</span></p><p class="Code_20_example"><span class="T11">GR.TOUCH touched, x, y</span></p><p class="Code_20_example"><span class="T11">UNTIL !touched</span></p><p class="Standard">The returned values are relative to the actual screen size. If you have scaled the screen then you need to similarly scale the returned parameters. If the parameters that you used in <span class="T7">Gr.scale</span> were scale_x and scale_y (<span class="T7">Gr.scale scale_x, scale_y</span>) then divide the returned x and y by those same values.</p><p class="Code_20_example"><span class="T11">GR.TOUCH touched, x, y</span></p><p class="Code_20_example"><span class="T11">Xscaled = x / scale_x</span></p><p class="Code_20_example"><span class="T11">Yscaled = y / scale_y</span></p><h3 class="Heading_20_3"><a id="a__Gr_bounded_touch_touched__left__top__right__bottom"><span/></a><a id="_Toc5236209"/>Gr.bounded.touch touched, left, top, right, bottom</h3><p class="Standard">The Touched parameter will be returned true (not zero) if the user has touched the screen within the rectangle defined by the left, top, right, bottom parameters. If the screen has not been touched or has been touched outside of the bounding rectangle, the touched parameter will be return as false (zero). The command will continue to return true as long as the screen remains touched and the touch is within the bounding rectangle.</p><p class="Standard">The bounding rectangle parameters are for the actual screen size. If you have scaled the screen then you need to similarly scale the bounding rectangle parameters. If the parameters that you used in <span class="T7">Gr.scale</span> were scale_x and scale_y (<span class="T7">Gr.scale scale_x, scale_y</span>) then divide left and right by scale_x and divide top and bottom by scale_y.</p><h3 class="Heading_20_3"><a id="a__Gr_touch2_touched__x__y"><span/></a><a id="_Toc5236210"/>Gr.touch2 touched, x, y</h3><p class="Standard">The same as <span class="T7">Gr.touch</span> except that it reports on second simultaneous touch of the screen.</p><h3 class="Heading_20_3"><a id="a__Gr_bounded_touch2_touched__left__top__right__bottom"><span/></a><a id="_Toc5236211"/>Gr.bounded.touch2 touched, left, top, right, bottom</h3><p class="Standard">The same as <span class="T7">Gr.bounded.touch</span> except that it reports on second simultaneous touch of the screen.</p><h3 class="Heading_20_3"><a id="a__OnGrTouch_"><span/></a><a id="_Toc5236212"/>OnGrTouch:</h3><p class="Standard">Interrupt label that traps any touch on the Graphics screen (see "Interrupt Labels"). BASIC! executes the statements following the <span class="T7">OnGrTouch:</span> label until it reaches a <span class="T7">Gr.onGrTouch.resume</span> command.</p><p class="Standard">To detect touches on the Output Console (not in Graphics mode), use <span class="T7">OnConsoleTouch:</span>.</p><h3 class="Heading_20_3"><a id="a__Gr_onGrTouch_resume"><span/></a><a id="_Toc5236213"/>Gr.onGrTouch.resume</h3><p class="Standard">Resumes execution at the point in the BASIC! program where the <span class="T7">OnGrTouch:</span> interrupt occurred.</p><h2 class="Heading_20_2"><a id="a__Text_Commands"><span/></a><a id="_Toc5236214"/>Text Commands</h2><h3 class="Heading_20_3"><a id="a__Overview"><span/></a><a id="_Toc5236215"/>Overview</h3><p class="Standard"><span class="T7">Gr.text.draw</span> is the only <span class="T7">text</span> command that creates a graphical object. The other <span class="T7">text</span> commands set attributes of text yet to be drawn or report measurements of text.</p><p class="Standard">Each command that sets a text attribute (the <span class="T7">Gr.text.align</span>, <span class="T7">bold</span>, <span class="T7">size</span>, <span class="T7">skew</span>, <span class="T7">strike</span>, and <span class="T7">underline</span> commands, as well as <span class="T7">Gr.text.setfont</span> and <span class="T7">typeface</span>) has an optional "Paint pointer" parameter that may be used to specify a Paint object to modify. Normally this parameter is omitted, and the command sets a text attribute for all text objects drawn after the command is executed. For using the Paint pointer, see "Paints <span class="T18">Advanced Usage</span>", above.</p><p class="Standard"><span class="T7">Gr.text.height</span> returns information about how text would be drawn. It does not measure a drawn text object, but uses information from the current Paint.</p><p class="Standard"><span class="T7">Gr.text.width</span> and <span class="T7">Gr.get.textbounds</span> commands can return information about how text would be drawn or how a text object was actually drawn. If used to measure the text of a string expression, they use information from the current Paint. If used to measure the text of a text object that was already drawn, they use information from the text object.</p><h3 class="Heading_20_3"><a id="a__Gr_text_align_{{_type_nexp_}{__paint_nexp_}}"><span/></a><a id="_Toc5236216"/>Gr.text.align {{&lt;type_nexp&gt;}{,&lt;paint_nexp&gt;}}</h3><p class="Standard">Align the text relative to the (x,y) coordinates given in the <span class="T7">Gr.text.draw</span> command.<br/>type values: 1 = Left, 2 = Center, 3 = Right.</p><p class="Standard">You may use the optional Paint pointer parameter &lt;paint_nexp&gt; to specify a Paint object to modify. Normally this parameter is omitted. See <span class="T7">Gr.color</span>, <span class="T18">Advanced usage</span> for more information.</p><h3 class="Heading_20_3"><a id="a__Gr_text_bold_{{_lexp_}{__paint_nexp_}}"><span/></a><a id="_Toc5236217"/>Gr.text.bold {{&lt;lexp&gt;}{,&lt;paint_nexp&gt;}}</h3><p class="No_20_Spacing">Turns bold on or off on text objects drawn after this command is issued:</p><ul><li><p class="P46" style="margin-left:1.27cm;"><span class="ListLabel_20_77" style="display:block;float:left;min-width:0.635cm;"></span>If the value of the bold parameter &lt;lexp&gt; is false (0), text bold is turned off.<span class="odfLiEnd"/> </p></li><li><p class="P46" style="margin-left:1.27cm;"><span class="ListLabel_20_77" style="display:block;float:left;min-width:0.635cm;"></span>If the parameter value is true (not zero), makes text appear bold.<span class="odfLiEnd"/> </p></li><li><p class="P46" style="margin-left:1.27cm;"><span class="ListLabel_20_77" style="display:block;float:left;min-width:0.635cm;"></span>If the parameter is omitted, the bold setting is toggled.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">If the color fill parameter is 0, only the outline of the bold text will be shown. If fill &lt;&gt;0, the text outline will be filled.</p><p class="Standard">This is a "fake bold", simulated by graphical techniques. It may not look the same as text drawn after setting "Bold" style with <span class="T7">Gr.text.setfont</span> or <span class="T7">Gr.text.typeface</span>.</p><p class="Standard">You may use the optional Paint pointer parameter &lt;paint_nexp&gt; to specify a Paint object to modify. Normally this parameter is omitted. See <span class="T7">Gr.color</span>, <span class="T18">Advanced usage</span> for more information.</p><h3 class="Heading_20_3"><a id="a__Gr_text_size_{{_size_nexp_}{__paint_nexp_}}"><span/></a><a id="_Toc5236218"/>Gr.text.size {{&lt;size_nexp&gt;}{,&lt;paint_nexp&gt;}}</h3><p class="Standard">Specifies the size of the text in pixels. The size &lt;nexp&gt; sets the nominal height of the characters. This height is large enough to include the top of characters with ascenders, like "h", and the bottom of characters with descenders, like "y". Character width is scaled proportionately to the height.</p><p class="Standard">You may use the optional Paint pointer parameter &lt;paint_nexp&gt; to specify a Paint object to modify. Normally this parameter is omitted. See <span class="T7">Gr.color</span>, <span class="T18">Advanced usage</span> for more information.</p><h3 class="Heading_20_3"><a id="a__Gr_text_skew_{{_skew_nexp_}{__paint_nexp_}}"><span/></a><a id="_Toc5236219"/>Gr.text.skew {{&lt;skew_nexp&gt;}{,&lt;paint_nexp&gt;}}</h3><p class="Standard">Skews the text to give an italic effect. Negative values of &lt;nexp&gt; skew the bottom of the text left. This makes the text lean forward. Positive values do the opposite. Traditional italics can be best imitated with &lt;nexp&gt; = -0.25.</p><p class="Standard">You may use the optional Paint pointer parameter &lt;paint_nexp&gt; to specify a Paint object to modify. Normally this parameter is omitted. See <span class="T7">Gr.color</span>, <span class="T18">Advanced usage</span> for more information.</p><h3 class="Heading_20_3"><a id="a__Gr_text_strike_{{_lexp_}{__paint_nexp_}}"><span/></a><a id="_Toc5236220"/>Gr.text.strike {{&lt;lexp&gt;}{,&lt;paint_nexp&gt;}}</h3><p class="No_20_Spacing">Turns overstrike on or off on text objects drawn after this command is issued:</p><ul><li><p class="P46" style="margin-left:1.27cm;"><span class="ListLabel_20_77" style="display:block;float:left;min-width:0.635cm;"></span>If the value of the strike parameter &lt;lexp&gt; is false (0), text strike is turned off.<span class="odfLiEnd"/> </p></li><li><p class="P46" style="margin-left:1.27cm;"><span class="ListLabel_20_77" style="display:block;float:left;min-width:0.635cm;"></span>If the parameter value is true (not zero), text will be drawn with a strike-through line.<span class="odfLiEnd"/> </p></li><li><p class="P46" style="margin-left:1.27cm;"><span class="ListLabel_20_77" style="display:block;float:left;min-width:0.635cm;"></span>If the parameter is omitted, the bold setting is toggled.<span class="odfLiEnd"/> </p></li></ul><p class="Standard"> You may use the optional Paint pointer parameter &lt;paint_nexp&gt; to specify a Paint object to modify. Normally this parameter is omitted. See <span class="T7">Gr.color</span>, <span class="T18">Advanced usage</span> for more information.</p><h3 class="Heading_20_3"><a id="a__Gr_text_underline_{{_lexp_}{__paint_nexp_}}"><span/></a><a id="_Toc5236221"/>Gr.text.underline {{&lt;lexp&gt;}{,&lt;paint_nexp&gt;}}</h3><p class="No_20_Spacing">Turns underlining on or off on text objects drawn after this command is issued:</p><ul><li><p class="P46" style="margin-left:1.27cm;"><span class="ListLabel_20_77" style="display:block;float:left;min-width:0.635cm;"></span>If the value of the underline parameter &lt;lexp&gt; is false (0), text underlining is turned off.<span class="odfLiEnd"/> </p></li><li><p class="P46" style="margin-left:1.27cm;"><span class="ListLabel_20_77" style="display:block;float:left;min-width:0.635cm;"></span>If the parameter value is true (not zero), drawn text will be underlined.<span class="odfLiEnd"/> </p></li><li><p class="P46" style="margin-left:1.27cm;"><span class="ListLabel_20_77" style="display:block;float:left;min-width:0.635cm;"></span>If the parameter is omitted, the underline setting is toggled.<span class="odfLiEnd"/> </p></li></ul><p class="Standard"> You may use the optional Paint pointer parameter &lt;paint_nexp&gt; to specify a Paint object to modify. Normally this parameter is omitted. See <span class="T7">Gr.color</span>, <span class="T18">Advanced usage</span> for more information.</p><h3 class="Heading_20_3"><a id="a__Gr_text_setfont_{{_font_ptr_nexp_|_font_family_sexp_}_{___style_sexp_}_{__paint_nexp_}}"><span/></a><a id="_Toc5236222"/>Gr.text.setfont {{&lt;font_ptr_nexp&gt;|&lt;font_family_sexp&gt;} {, &lt;style_sexp&gt;} {,&lt;paint_nexp&gt;}}</h3><p class="Standard">Set the text font, specifying typeface and style. Both of these parameters are optional. This command is similar to the older <span class="T7">Gr.text.typeface</span>, but it is more flexible.</p><p class="Standard">If the font parameter is a numerical expression &lt;font_ptr_nexp&gt;, it must be a font pointer value returned by the <span class="T7">Font.load</span> command. You cannot modify the style of a font once it is loaded, so the the style parameter &lt;style_sexp&gt; is ignored.</p><p class="Standard">If the font parameter is a string expression &lt;font_family_sexp&gt;, it must specify one of the font families available on your Android device. If your device does not recognize the string, the font is set to the system default font typeface. On most systems, the default is <span class="T7">"sans serif"</span>.</p><p class="Standard">The standard font families are <span class="T7">"monospace"</span>, <span class="T7">"serif"</span>, and <span class="T7">"sans serif"</span>. Some more recent versions of Android also support <span class="T7">"sans-serif"</span>, <span class="T7">"sans-serif-light"</span>, <span class="T7">"sans-serif-condensed"</span>, and <span class="T7">"sans-serif-thin"</span>. The font family names are not case-sensitive: "Serif" or "SERIF" works as well as "serif".</p><p class="Standard">If you omit the font parameter, the command sets the most recently loaded font (see <span class="T7">Font.load</span>). If you have deleted fonts (see <span class="T7">Font.delete</span>), the command sets the most recently loaded font that has not been deleted. If you have not loaded any fonts, or if you have cleared them (see <span class="T7">Font.clear</span>), the command sets the default font family.</p><p class="Standard">If you specify a font family, you can use the style parameter &lt;style_sexp&gt; to change the font’s appearance. The parameter value must be one of the style strings shown in the table below. You may use either the full style name or an abbreviation as shown. The parameter is not case-senstive: "BOLD", "bold", "Bold", and "bOlD" are all the same. If you use any other string, or if you omit the style parameter, the style is set to <span class="T7">"NORMAL"</span>.</p><table border="0" cellspacing="0" cellpadding="0" class="Table31"><colgroup><col width="180"/><col width="118"/></colgroup><tr class="Table311"><td style="text-align:left;width:4.128cm; " class="Table31_A1"><p class="P140">Style Name</p></td><td style="text-align:left;width:2.697cm; " class="Table31_B1"><p class="P140">Abbreviation</p></td></tr><tr class="Table311"><td style="text-align:left;width:4.128cm; " class="Table31_A1"><p class="P140">"NORMAL"</p></td><td style="text-align:left;width:2.697cm; " class="Table31_A1"><p class="P140">"N"</p></td></tr><tr class="Table311"><td style="text-align:left;width:4.128cm; " class="Table31_A3"><p class="P140">"BOLD"</p></td><td style="text-align:left;width:2.697cm; " class="Table31_A3"><p class="P140">"B"</p></td></tr><tr class="Table311"><td style="text-align:left;width:4.128cm; " class="Table31_A3"><p class="P140">"ITALIC"</p></td><td style="text-align:left;width:2.697cm; " class="Table31_A3"><p class="P140">"I"</p></td></tr><tr class="Table311"><td style="text-align:left;width:4.128cm; " class="Table31_A5"><p class="P110">"BOLD_ITALIC"</p></td><td style="text-align:left;width:2.697cm; " class="Table31_A5"><p class="P110">"BI"</p></td></tr></table><p class="P102"><span class="T7">Notes:</span> The <span class="T7">"monospace"</span> font family always displays as <span class="T7">"normal"</span>, regardless of the style parameter. Some devices do not support all of the styles.</p><p class="P102">You may use the optional Paint pointer parameter &lt;paint_nexp&gt; to specify a Paint object to modify. Normally this parameter is omitted. See <span class="T7">Gr.color</span>, <span class="T18">Advanced usage</span> for more information.</p><h3 class="Heading_20_3"><a id="a__Gr_text_typeface_{{_font_nexp_}_{___style_nexp_}_{__paint_nexp_}}"><span/></a><a id="_Toc5236223"/>Gr.text.typeface {{&lt;font_nexp&gt;} {, &lt;style_nexp&gt;} {,&lt;paint_nexp&gt;}}</h3><p class="Standard">Set the text typeface and style. Both of these parameters are optional. The default value if you omit either parameter is 1. All valid values and their meanings are shown in this table:</p><table border="0" cellspacing="0" cellpadding="0" class="Table32"><colgroup><col width="56"/><col width="245"/><col width="53"/><col width="264"/></colgroup><tr class="Table321"><td colspan="2" style="text-align:left;width:1.27cm; " class="Table32_A1"><p class="P114">The values for &lt;font_nexp&gt; are:</p></td><td colspan="2" style="text-align:left;width:1.208cm; " class="Table32_A1"><p class="P114">The values for &lt;style_nexp&gt; are:</p></td></tr><tr class="Table321"><td style="text-align:left;width:1.27cm; " class="Table32_A2"><p class="P110">1</p></td><td style="text-align:left;width:5.616cm; " class="Table32_B2"><p class="P114">Default font</p></td><td style="text-align:left;width:1.208cm; " class="Table32_A2"><p class="P110">1</p></td><td style="text-align:left;width:6.033cm; " class="Table32_B2"><p class="P114">Normal (not bold or italic)</p></td></tr><tr class="Table321"><td style="text-align:left;width:1.27cm; " class="Table32_A3"><p class="P110">2</p></td><td style="text-align:left;width:5.616cm; " class="Table32_B3"><p class="P114">Monospace font</p></td><td style="text-align:left;width:1.208cm; " class="Table32_A3"><p class="P110">2</p></td><td style="text-align:left;width:6.033cm; " class="Table32_B3"><p class="P114">Bold</p></td></tr><tr class="Table321"><td style="text-align:left;width:1.27cm; " class="Table32_A3"><p class="P110">3</p></td><td style="text-align:left;width:5.616cm; " class="Table32_B3"><p class="P114">Sans-serif font</p></td><td style="text-align:left;width:1.208cm; " class="Table32_A3"><p class="P110">3</p></td><td style="text-align:left;width:6.033cm; " class="Table32_B3"><p class="P114">Italic</p></td></tr><tr class="Table321"><td style="text-align:left;width:1.27cm; " class="Table32_A5"><p class="P110">4</p></td><td style="text-align:left;width:5.616cm; " class="Table32_B5"><p class="P114">Serif font</p></td><td style="text-align:left;width:1.208cm; " class="Table32_A5"><p class="P110">4</p></td><td style="text-align:left;width:6.033cm; " class="Table32_B5"><p class="P114">Bold and italic</p></td></tr></table><p class="P102">This command is similar to the newer <span class="T7">Gr.text.setfont</span>, except that it is limited to the four typefaces listed in the table. It cannot specify fonts loaded by the <span class="T7">Font.load</span> command.</p><p class="Standard"><span class="T7">Notes:</span> The "Monospace" font (font 2) always displays as "Normal" (style 1), regardless of the style parameter. Some devices do not support all of the styles.</p><p class="Standard">You may use the optional Paint pointer parameter &lt;paint_nexp&gt; to specify a Paint object to modify. Normally this parameter is omitted. See <span class="T7">Gr.color</span>, <span class="T18">Advanced usage</span> for more information.</p><h3 class="Heading_20_3"><a id="a__Gr_text_height_{_height_nvar_}_{___up_nvar_}_{___down_nvar_}"><span/></a><a id="_Toc5236224"/>Gr.text.height {&lt;height_nvar&gt;} {, &lt;up_nvar&gt;} {, &lt;down_nvar&gt;}</h3><p class="Standard">Returns height information for the current font and text size. All of the parameters are optional; use commas to indicate omitted parameters (see Optional Parameters).</p><p class="Standard">If the <span class="T7">height</span> variable &lt;height_nvar&gt; is present, it is set to the height in pixels of the space that will be used to print most text in most languages. This is the value you set with <span class="T7">Gr.text.size</span>. In typeface terminology, it is the "ascent" plus the "descent". The space contains the ascenders of letters like "h" and the descenders of letters like "y".</p><p class="Standard">Some letters, such as the Polish letter "<span class="T9">Ż</span>", may not fit in this space. The position of a line high enough to contain all possible characters is returned in the <span class="T7">up</span> variable &lt;up_nvar&gt;, if it is present.</p><p class="Standard">If the <span class="T7">down</span> variable &lt;down_nvar&gt; is present, it is set to the "descent" value. This position is low enough to contain the lowest part of all possible characters, such as the tail of a "y".</p><p class="Standard"><span class="T7">Gr.text.draw</span> positions text so the the body of the characters sit on a line called the baseline. The <span class="T7">down</span> and <span class="T7">up</span> values are reported as offsets from this baseline. The <span class="T7">up</span> value is negative, because it defines a position above the baseline. The <span class="T7">down</span> value is positive, because its position is below the baseline. The <span class="T7">height</span> value is not an offset, so it is always positive. <span class="T7">down</span> - <span class="T7">up</span> is always larger than <span class="T7">height</span>.</p><p class="Standard">Sometimes you want to know the real screen positions of the top and bottom of the area where your text will be drawn, independent of the actual text you will draw there. The bottom of this area is the <span class="T7">y</span> coordinate of <span class="T7">Gr.text.draw</span> plus the <span class="T7">down</span> value of <span class="T7">Gr.text.height</span>. For most applications, the top of the text area is the bottom position minus the <span class="T7">height</span> value of <span class="T7">Gr.text.height</span>, so <span class="T7">y</span> + <span class="T7">down</span> - <span class="T7">height</span>. For some applications (such as a Polish text field), you may need the extra height you get with <span class="T7">y</span> + <span class="T7">up</span>.</p><p class="P7"><span class="T11">GR.TEXT.SIZE 40</span></p><p class="Code_20_example"><span class="T11">GR.TEXT.HEIGHT ht, up, dn        % ht is 40</span></p><p class="Code_20_example"><span class="T11">GR.TEXT.DRAW t, x, y, "Hello, World!"</span></p><p class="Code_20_example"><span class="T11">txtBottom = y + dn</span></p><p class="Code_20_example"><span class="T11">txtTop = txtBottom - ht        % good for most applications</span></p><p class="Code_20_example"><span class="T11">txtTop = y + up                % high enough for all possible text (up is negative)</span></p><h3 class="Heading_20_3"><a id="a__Gr_text_width__nvar____exp_"><span/></a><a id="_Toc5236225"/>Gr.text.width &lt;nvar&gt;, &lt;exp&gt;</h3><p class="Standard">Returns the pixel width of a string (from &lt;exp&gt;) in the variable &lt;nvar&gt;.</p><ul><li><p class="P49" style="margin-left:1.27cm;"><span class="ListLabel_20_85" style="display:block;float:left;min-width:0.635cm;"></span>If the parameter &lt;exp&gt; is a string expression, the return value is the width of the string as if it were displayed on the screen using the latest text attribute settings: the typeface, size, and style as set by the <span class="T7">Gr.text.*</span> commands (or default values if you did not set them).<span class="odfLiEnd"/> </p></li><li><p class="P49" style="margin-left:1.27cm;"><span class="ListLabel_20_85" style="display:block;float:left;min-width:0.635cm;"></span>If the parameter &lt;exp&gt; is a numeric expression, its value must be a text object number from <span class="T7">Gr.text.draw</span>, or you will get a run-time error. The return value is the width of the text of the object as it would be displayed on the screen by <span class="T7">Gr.render</span>.<span class="odfLiEnd"/> </p></li></ul><p class="P109"><span class="T7">Advanced usage:</span> To calculate dimensions, both <span class="T7">Gr.text.width</span> and <span class="T7">Gr.get.textbounds</span> (below) use a text string and a set of text attributes. The text attributes are kept in a Paint object. The source of the string and the Paint depends on the type of the &lt;exp&gt; parameter:</p><table border="0" cellspacing="0" cellpadding="0" class="Table33"><colgroup><col width="111"/><col width="173"/><col width="194"/><col width="250"/></colgroup><tr class="Table331"><td style="text-align:left;width:2.54cm; " class="Table33_A1"><p class="P140">If &lt;exp&gt; is a</p></td><td style="text-align:left;width:3.969cm; " class="Table33_B1"><p class="P140">value of &lt;exp&gt; is</p></td><td style="text-align:left;width:4.443cm; " class="Table33_C1"><p class="P140">source of text string is</p></td><td style="text-align:left;width:5.715cm; " class="Table33_D1"><p class="P140">Source of text attributes is</p></td></tr><tr class="Table331"><td style="text-align:left;width:2.54cm; " class="Table33_A1"><p class="P140">string expression</p></td><td style="text-align:left;width:3.969cm; " class="Table33_B2"><p class="P140">the string to measure</p></td><td style="text-align:left;width:4.443cm; " class="Table33_A1"><p class="P140">value of &lt;exp&gt;</p></td><td style="text-align:left;width:5.715cm; " class="Table33_D2"><p class="P140">Current Paint (most recent <span class="T7">Gr.text.*</span> settings)</p></td></tr><tr class="Table331"><td style="text-align:left;width:2.54cm; " class="Table33_A3"><p class="P110">numeric expression</p></td><td style="text-align:left;width:3.969cm; " class="Table33_B3"><p class="P110">a text object number from <span class="T7">Gr.text.draw</span></p></td><td style="text-align:left;width:4.443cm; " class="Table33_A3"><p class="P110">string from <span class="T7">Gr.text.draw</span> (kept in text object)</p></td><td style="text-align:left;width:5.715cm; " class="Table33_D3"><p class="P110">Paint attached to the text object (see <span class="T7">Note</span>, below)</p></td></tr></table><p class="P150"><span class="T7">Note:        Gr.text.draw</span> attaches a Paint to the text object using the text attributes that are current at that time. This is the Paint <span class="T7">Gr.render</span> uses to display the text on the screen. If you modify this Paint, the changes are reflected in values returned by <span class="T7">Gr.text.width</span> and <span class="T7">Gr.get.textbounds</span>, and also shown on the screen with the next <span class="T7">Gr.render.</span></p><h3 class="Heading_20_3"><a id="a__Gr_get_textbounds__exp___left__top__right__bottom"><span/></a><a id="_Toc5236226"/>Gr.get.textbounds &lt;exp&gt;, left, top, right, bottom</h3><p class="Standard">Gets the boundary rectangle of a string  as it would be drawn on the screen. The returned coordinate values give you the dimensions of the bounding rectangle but not its location.</p><p class="Standard">The parameter &lt;exp&gt; follows the same rules as <span class="T7">Gr.text.width</span> (see above) to get a text string and the text attributes (typeface, size, and style) used to measure the string.</p><p class="Standard">The coordinates of the rectangle are reported as if <span class="T7">Gr.text.draw</span> positioned your text at <span class="T7">0,0</span>. You get the actual boundaries of a text object by adding the textbounds offsets to the actual <span class="T7">x,y</span> coordinates of the <span class="T7">Gr.text.draw</span> command.</p><p class="Standard">In typeface terminology, the coordinate values are offsets from the beginning of the baseline of the text (see <span class="T7">Gr.text.draw</span> and <span class="T7">Gr.text.height</span> for more explanation of the lines that define where text is drawn). This is why the value returned for "top" is always a negative number.</p><p class="Standard">If this is confusing, try running this example:</p><p class="P7"><span class="T11">GR.OPEN ,,,,,-1</span></p><p class="Code_20_example"><span class="T11">GR.COLOR 255,255,0,0,0</span></p><p class="Code_20_example"><span class="T11">GR.TEXT.SIZE 40</span></p><p class="Code_20_example"><span class="T11">GR.TEXT.ALIGN 1</span></p><p class="Code_20_example"><span class="T11">s$ = "This is only a test"</span></p><p class="Code_20_example"><span class="T11">GR.GET.TEXTBOUNDS s$,l,t,r,b</span></p><p class="Code_20_example"><span class="T11">PRINT l,t,r,b</span></p><p class="Code_20_example"><span class="T11">x=10 : y=50</span></p><p class="Code_20_example"><span class="T11">GR.RECT rct,l+x,t+y,r+x,b+y</span></p><p class="Code_20_example"><span class="T11">GR.TEXT.DRAW txt,x,y,s$</span></p><p class="Code_20_example"><span class="T11">GR.RENDER</span></p><p class="Code_20_example"><span class="T11">PAUSE 5000</span></p><h3 class="Heading_20_3"><a id="a__Gr_text_draw__object_number_nvar____x_nexp____y_nexp____text_object_sexp_"><span/></a><a id="_Toc5236227"/><a id="_Gr.text.draw_&lt;object_number_nvar&gt;,_"/>Gr.text.draw &lt;object_number_nvar&gt;, &lt;x_nexp&gt;, &lt;y_nexp&gt;, &lt;text_object_sexp&gt;</h3><p class="Standard">Creates and inserts a text object (&lt;text_object_sexp&gt;) into the Display List. The text object will use the latest color and text preparatory commands. The &lt;object_number_nvar&gt; returns the Display List object number for this text. This object will not be visible until the <span class="T7">Gr.render</span> command is called.</p><p class="Standard"><span class="T7">Gr.text.draw</span> positions the text so the the bodies of the characters sit on a line called the baseline. The tails of letters like "y" hang below the baseline.The <span class="T7">y</span> value &lt;y_nexp&gt; sets the location of this baseline.</p><p class="Standard">The <span class="T7">Gr.text.height</span> command tells you the locations of the various lines used to draw text. The <span class="T7">Gr.text.width</span> command tells you width of the space in which a specific string will be drawn. The <span class="T7">Gr.get.textbounds</span> command tells you the locations of the left-, top-, right-, and bottom-most pixels actually drawn for a specific text string.</p><p class="Standard">The <span class="T7">Gr.modify</span> parameters for <span class="T7">Gr.text.draw</span> are "x", "y", and "text". The value for "text" is a string representing the new text.</p><h2 class="Heading_20_2"><a id="a__Bitmap_Commands"><span/></a><a id="_Toc5236228"/>Bitmap Commands</h2><h3 class="Heading_20_3"><a id="a__Overview"><span/></a><a id="_Toc5236229"/>Overview</h3><p class="Standard">When a bitmap is created, it is added to a list of bitmaps. Commands that create bitmaps return a pointer to the bitmap. The pointer is an index into the bitmap list. Your program works with the bitmap through the bitmap pointer.</p><p class="Standard">If you want to draw the bitmap on the screen, you must add a graphical object to the Object List. The <span class="T7">Gr.bitmap.draw</span> command creates a graphical object that holds a pointer to the bitmap. Do not confuse the bitmap with the graphical object. You cannot use the Object Number to access the bitmap, and you cannot use the bitmap pointer to modify the graphical object.</p><p class="Standard">Android devices limit the amount of memory available to your program. Bitmaps may use large blocks of memory, and so may exceed the application memory limit. If a command that creates a bitmap exceeds the limit, the bitmap is not created, and the command returns -1, an invalid bitmap pointer. Your program should test the bitmap pointer to find out if the bitmap was created. If the bitmap pointer is -1, you can call the <span class="T7">GETERROR$()</span> function to get information about the error.</p><p class="Standard">If a command exceeds the memory limit, but BASIC! does not catch the out-of-memory condition, your program terminates with an error message displayed on the Console screen. If you return the Editor, a line will be highlighted near the one that exceeded the memory limit. It may not be exactly the right line.</p><p class="Standard">Bitmaps use four bytes of memory for each pixel. The amount of memory used depends only on the width and height of the bitmap. The bitmap is not compressed. When you load a bitmap from a file, the file is usually in a compressed format, so the bitmap will usually be larger than the file.</p><h3 class="Heading_20_3"><a id="a__Gr_bitmap_create__bitmap_ptr_nvar___width__height"><span/></a><a id="_Toc5236230"/>Gr.bitmap.create &lt;bitmap_ptr_nvar&gt;, width, height</h3><p class="Standard">Creates an empty bitmap of the specified width and height. The specified width and height may be greater than the size of the screen, if needed.</p><p class="Standard">Returns a pointer to the created bitmap in the &lt;bitmap_ptr_nvar&gt; variable for use with the other <span class="T7">Gr.bitmap</span> commands. If there is not enough memory available to create the bitmap, the returned bitmap pointer is -1. Call <span class="T7">GETERROR$()</span> for information about the failure.</p><h3 class="Heading_20_3"><a id="a__Gr_bitmap_load__bitmap_ptr_nvar____file_name_sexp_"><span/></a><a id="_Toc5236231"/>Gr.bitmap.load &lt;bitmap_ptr_nvar&gt;, &lt;file_name_sexp&gt;</h3><p class="P109">Creates a bitmap from the file specified in the file_name string expression. Returns a pointer to the created bitmap for use with other <span class="T7">Gr.bitmap</span> commands. If no bitmap is created, the returned bitmap pointer is -1. Call <span class="T7">GETERROR$()</span> for information about the failure. Some of the possible causes are:</p><ul><li><p class="P50" style="margin-left:1.27cm;"><span class="ListLabel_20_89" style="display:block;float:left;min-width:0.635cm;"></span>The file or resource does not exist.<span class="odfLiEnd"/> </p></li><li><p class="P50" style="margin-left:1.27cm;"><span class="ListLabel_20_89" style="display:block;float:left;min-width:0.635cm;"></span>There is not enough memory available to create the bitmap.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">Bitmap image files are assumed to be located in the "&lt;pref base drive&gt;/rfo-basic/data/" directory.</p><p class="Standard">Note: You may include path fields in the file name. For example, "../../Cougar.jpg" would cause BASIC! to look for Cougar.jpg in the top level directory of the base drive, usually the SD card. "images/Kitty.png" would cause BASIC! to look in the images(d) sub-directory of the "/sdcard/rfo-basic/data/" ("/sdcard/rfo-basic/data/images/Kitty.png").</p><p class="Standard">Note: Bitmaps loaded with this command cannot be changed with the <span class="T7">Gr.bitmap.drawinto</span> command. To draw into an image loaded from a file, first create an empty bitmap then draw the loaded bitmap into the empty bitmap.</p><h3 class="Heading_20_3"><a id="a__Gr_bitmap_size__bitmap_ptr_nexp___width__height"><span/></a><a id="_Toc5236232"/>Gr.bitmap.size &lt;bitmap_ptr_nexp&gt;, width, height</h3><p class="Standard">Return the pixel width and height of the bitmap pointed to by &lt;bitmap_ptr_nexp&gt; into the width and height variables.</p><h3 class="Heading_20_3"><a id="a__Gr_bitmap_scale__new_bitmap_ptr_nvar____bitmap_ptr_nexp___width__height_{___smoothing_lexp_}"><span/></a><a id="_Toc5236233"/>Gr.bitmap.scale &lt;new_bitmap_ptr_nvar&gt;, &lt;bitmap_ptr_nexp&gt;, width, height {, &lt;smoothing_lexp&gt;}</h3><p class="Standard">Scales a previously loaded bitmap (&lt;bitmap_ptr_nexp&gt;) to the specified width and height and creates a new bitmap &lt;new_bitmap_ptr_nvar&gt;. The old bitmap still exists; it is not deleted. If there is not enough memory available to create the new bitmap, the returned bitmap pointer is -1. Call <span class="T7">GETERROR$()</span> for information about the failure.</p><p class="Standard">Negative values for width and height will cause the image to be flipped left to right or upside down.</p><p class="Standard">Neither the width value nor the height value may be zero.</p><p class="Standard">Use the optional smoothing logical expression (&lt;smoothing_lexp&gt;) to request that the scaled image not be smoothed. If the expression is false (zero) then the image will not be smoothed. If the optional parameter is true (not zero) or not specified then the image will be smoothed.</p><h3 class="Heading_20_3"><a id="a__Gr_bitmap_delete__bitmap_ptr_nexp_"><span/></a><a id="_Toc5236234"/>Gr.bitmap.delete &lt;bitmap_ptr_nexp&gt;</h3><p class="Standard">Deletes an existing bitmap. The bitmap's memory is returned to the system.</p><p class="Standard">This does not destroy any graphical object that points to the bitmap. If you do not <span class="T7">Gr.hide</span> such objects, or remove them from the Display List, you will get a run-time error from the next <span class="T7">Gr.render</span> command.</p><h3 class="Heading_20_3"><a id="a__Gr_bitmap_crop__new_bitmap_ptr_nvar____source_bitmap_ptr_nexp____x_nexp____y_nexp____width_nexp____height_nexp_"><span/></a><a id="_Toc5236235"/>Gr.bitmap.crop &lt;new_bitmap_ptr_nvar&gt;, &lt;source_bitmap_ptr_nexp&gt;, &lt;x_nexp&gt;, &lt;y_nexp&gt;, &lt;width_nexp&gt;, &lt;height_nexp&gt;</h3><p class="Standard">Creates a cropped copy of an existing source bitmap specified by &lt;source_bitmap_ptr_nexp&gt;. The source bitmap is unaffected; a rectangular section is copied into a new bitmap. A pointer to the new bitmap is returned in &lt;new_bitmap_nvar&gt;. If there is not enough memory available to create the new bitmap, the returned bitmap pointer is -1. Call <span class="T7">GETERROR$()</span> for information about the failure.</p><p class="Standard">The &lt;x_nexp&gt;, &lt;y_nexp&gt; pair specifies the point within the source bitmap that the crop is to start at. The &lt;width_nexp&gt;, &lt;height_nexp&gt; pair defines the size of the rectangular region to crop.</p><!--Next 'div' was a 'text:p'.--><div class="P91"><!--Next '
           span' is a draw:frame.
       --><span style="height:5.08cm;width:6.459cm; padding:0; " class="fr1" id="Picture_21"><img style="height:5.08cm;width:6.459cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><h3 class="Heading_20_3"><a id="a__Gr_bitmap_save__bitmap_ptr_nvar____filename_sexp_{___quality_nexp_}"><span/></a><a id="_Toc5236236"/>Gr.bitmap.save &lt;bitmap_ptr_nvar&gt;, &lt;filename_sexp&gt;{, &lt;quality_nexp&gt;}</h3><p class="Standard">Saves the specified bitmap to a file. The default path is "&lt;pref base drive&gt;/rfo-basic/data/".</p><p class="Standard">The file will be saved as a JPEG file if the filename ends in ".jpg".</p><p class="Standard">The file will be saved as a PNG file if the filename ends in anything else (including ".png").</p><h3 class="Heading_20_3"><a id="a__Gr_bitmap_draw__object_ptr_nvar____bitmap_ptr_nexp___x___y"><span/></a><a id="_Toc5236237"/><a id="_Gr.bitmap.draw_&lt;object_ptr_nvar&gt;,_&lt;"/>Gr.bitmap.draw &lt;object_ptr_nvar&gt;, &lt;bitmap_ptr_nexp&gt;, x , y</h3><p class="Standard">Creates a graphical object that contains a bitmap and inserts the object into the Object List. The bitmap is specified by the bitmap pointer &lt;bitmap_ptr_nexp&gt;. The bitmap will be drawn with its upper left corner at the provided (x,y) coordinates. The command returns the Object List object number of the graphical object in the &lt;object_ptr_nvar&gt; variable. This object will not be visible until the <span class="T7">Gr.render</span> command is called.</p><p class="Standard">The alpha value of the latest <span class="T7">Gr.color</span> will determine the transparency of the bitmap.</p><p class="Standard">The <span class="T7">Gr.modify</span> parameters for <span class="T7">Gr.bitmap.draw</span> are "bitmap", "x" and "y".</p><h3 class="Heading_20_3"><a id="a__Gr_get_bmpixel__bitmap_ptr_nvar___x__y__alpha__red__green__blue"><span/></a><a id="_Toc5236238"/>Gr.get.bmpixel &lt;bitmap_ptr_nvar&gt;, x, y, alpha, red, green, blue</h3><p class="Standard">Return the color data for the pixel of the specified bitmap at the specified x, y coordinate. The x and y values must not exceed the length or width of the bitmap.</p><h3 class="Heading_20_3"><a id="a__Gr_bitmap_fill__bitmap_ptr_nexp____x_nexp____y_nexp_"><span/></a><a id="_Toc5236239"/>Gr.bitmap.fill &lt;bitmap_ptr_nexp&gt;, &lt;x_nexp&gt;, &lt;y_nexp&gt;</h3><p class="Standard">Change all of the points in an area of a bitmap to the current drawing color. The bitmap pointer parameter &lt;bitmap_ptr_nexp&gt; must specify an existing bitmap. The x and y parameters &lt;x_nexp&gt; and &lt;y_nexp&gt; must specify a point (x,y) in the bitmap. The area to color is a set of connected pixels all the same color. The area may be any shape, and the point (x,y) may be any point in the area.</p><p class="Standard">This command reads actual bitmap pixel colors, so it is affected by the antialiasing setting. If antialiasing is on, the pixels at the edge of the colored area may not be re-colored correctly.</p><h3 class="Heading_20_3"><a id="a__Gr_bitmap_drawinto_start__bitmap_ptr_nexp_"><span/></a><a id="_Toc5236240"/>Gr.bitmap.drawinto.start &lt;bitmap_ptr_nexp&gt;</h3><p class="Standard">Put BASIC! into the draw-into-bitmap mode.</p><p class="Standard">All draw commands issued while in this mode draw directly into the bitmap. The objects drawn in this mode are not placed into the display list. The object number returned by the draw commands while in this mode is invalid and should not be used for any purpose including <span class="T7">Gr.modify</span>.</p><p class="Standard">Note: Bitmaps loaded with the <span class="T7">Gr.bitmap.load</span> command cannot be changed with <span class="T7">Gr.bitmap.drawinto</span>. To draw into an image loaded from a file, first create an empty bitmap then draw the loaded bitmap into the empty bitmap.</p><h3 class="Heading_20_3"><a id="a__Gr_bitmap_drawinto_end"><span/></a><a id="_Toc5236241"/>Gr.bitmap.drawinto.end</h3><p class="Standard">End the draw-into-bitmap mode.Subsequent draw commands will place the objects into the display list for rendering on the screen. If you wish to display the drawn-into bitmap on the screen, issue a <span class="T7">Bitmap.draw</span> command for that bitmap.</p><h2 class="Heading_20_2"><a id="a__Paint_Commands"><span/></a><a id="_Toc5236242"/>Paint Commands</h2><h3 class="Heading_20_3"><a id="a__Gr_paint_copy_{{_src_nexp_}{___dst_nexp_}}"><span/></a><a id="_Toc5236243"/>Gr.paint.copy {{&lt;src_nexp&gt;}{, &lt;dst_nexp&gt;}}</h3><p class="Standard">Copy the Paint object at the source pointer &lt;src_nexp&gt; to the destination pointer &lt;dst_next&gt;.</p><p class="Standard">Both parameters are optional. If you wish to specify a destination, you must include a comma, whether or not you specify a source. If either parameter is omitted, or if its value is -1, the current Paint is used.</p><p class="Standard">The Paint already at the destination pointer is replaced. If the destination is the current Paint, a newly-created paint becomes the current Paint.</p><p class="No_20_Spacing">This command has four forms, depending on which parameters are present:</p><p class="Code_20_example"><span class="T11">GR.PAINT.COPY                % Duplicate the current Paint</span></p><p class="Code_20_example"><span class="T11">GR.PAINT.COPY m        % Copy Paint m to the current Paint</span></p><p class="Code_20_example"><span class="T11">GR.PAINT.COPY , n        % Overwrite Paint n so it is the same as the current Paint</span></p><p class="Code_20_example"><span class="T11">GR.PAINT.COPY m, n        % Overwrite Paint n so it is the same as Paint m</span></p><h3 class="Heading_20_3"><a id="a__Gr_paint_get__object_ptr_nvar_"><span/></a><a id="_Toc5236244"/>Gr.paint.get &lt;object_ptr_nvar&gt;</h3><p class="Standard">Gets a pointer (&lt;object_ptr_nvar&gt;) to the last created Paint object. For information about Paint objects, see the section Graphics <span class="T27"></span> Introduction <span class="T27"></span> Paints, above.</p><p class="Standard">This pointer can be used to change the Paint object associated with a draw object by means of the <span class="T7">Gr.modify</span> command. The <span class="T7">Gr.modify</span> parameter is "paint".</p><p class="Standard">If you want to modify any of the paint characteristics of an object then you will need to create a current Paint object with those parameters changed. For example:</p><p class="Code_20_example"><span class="T11">GR.COLOR 255,0,255,0,0</span></p><p class="Code_20_example"><span class="T11">GR.TEXT.SIZE 20</span></p><p class="Code_20_example"><span class="T11">GR.TEXT.ALIGN 2</span></p><p class="Code_20_example"><span class="T11">GR.PAINT.GET the_paint</span></p><p class="Code_20_example"><span class="T11">GR.MODIFY shot, "paint", the_paint</span></p><p class="Standard">changes the current text size and alignment as well as the color.</p><h3 class="Heading_20_3"><a id="a__Gr_paint_reset_{_nexp_}"><span/></a><a id="_Toc5236245"/>Gr.paint.reset {&lt;nexp&gt;}</h3><p class="No_20_Spacing">Force the specified Paint to default settings:</p><p class="List_20_Paragraph">Color opaque black (255, 0, 0, 0)</p><p class="List_20_Paragraph">Antialias ON</p><p class="List_20_Paragraph">Style FILL (0)</p><p class="List_20_Paragraph">Minimum stroke width (0.0)</p><p class="Standard">The parameter is optional. If the parameter is omitted or set to -1, a new current Paint is created with default settings.</p><h2 class="Heading_20_2"><a id="a__Rotate_Commands"><span/></a><a id="_Toc5236246"/>Rotate Commands</h2><p class="Standard">These commands put graphics objects on the Display List like the GR drawing commands, but they don’t draw anything. Instead they work as markers in the list. When the renderer sees the start marker, it temporarily rotates its coordinate system. The end marker tells the renderer to restore the coordinate system to normal.</p><p class="Standard">The effect is to rotate or move any objects drawn after <span class="T7">Gr.rotate.start</span> and before <span class="T7">Gr.rotate.end</span>.</p><p class="Standard">As with any graphics object, the rotate parameters may be changed with <span class="T7">Gr.modify</span>. At the next <span class="T7">Gr.render</span>, the rotated objects will be redrawn in their new positions.</p><h3 class="Heading_20_3"><a id="a__Gr_rotate_start_angle__x__y{__obj_nvar_}"><span/></a><a id="_Toc5236247"/><a id="_Gr.rotate.start_angle,_x,"/>Gr.rotate.start angle, x, y{,&lt;obj_nvar&gt;}</h3><p class="Standard">Any objects drawn between the <span class="T7">Gr.rotate.start</span> and <span class="T7">Gr.rotate.end</span> will be rotated at the specified angle, in degrees, around the specified (x,y) point. If the angle is positive, objects are rotated clockwise.</p><p class="Standard">The optional &lt;obj_nvar&gt; will contain the Object list object number of the <span class="T7">Gr.rotate.start</span> object. If you are going to use rotated objects in the array for <span class="T7">Gr.NewDl</span> then you will need to include the <span class="T7">Gr.rotate.start</span> and <span class="T7">Gr.rotate.end</span> objects.</p><p class="Standard">The <span class="T7">Gr.modify</span> parameters for <span class="T7">Gr.rotate.start</span> are "angle", "x" and "y".</p><p class="Standard"><span class="T7">Gr.rotate.start</span> must be eventually followed by <span class="T7">Gr.rotate.end</span> or you will not get the expected results.</p><h3 class="Heading_20_3"><a id="a__Gr_rotate_end_{_obj_nvar_}"><span/></a><a id="_Toc5236248"/>Gr.rotate.end {&lt;obj_nvar&gt;}</h3><p class="Standard">Ends the rotated drawing of objects. Objects created after this command will not be rotated.</p><p class="Standard">The optional &lt;obj_nvar&gt; will contain the Object list object number of the <span class="T7">Gr.rotate.end</span> object. If you are going to use rotated objects in the array for <span class="T7">Gr.NewDl</span> then you will need to include the <span class="T7">Gr.rotate.start</span> and <span class="T7">Gr.rotate.end</span> objects.</p><h2 class="Heading_20_2"><a id="a__Camera_Commands"><span/></a><a id="_Toc5236249"/>Camera Commands</h2><p class="Standard">There are three ways to use the camera from BASIC!:</p><ol><li><p class="P51" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">1)</span>The device’s built in Camera User Interface can be used to capture an image. This method provides access to all the image-capture features that you get when you execute the device’s Camera application. The difference is the image bitmap is returned to BASIC! for manipulation by BASIC! The <span class="T7">Gr.camera.shoot</span> command implements this mode.<span class="odfLiEnd"/> </p></li><li><p class="P51" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">2)</span>A picture can be taken automatically when the command is executed. This mode allows for untended, time-sequenced image capture. The command provides for the setting the flash to on, off and auto. The <span class="T7">Gr.camera.autoshoot</span> command implements this mode.<span class="odfLiEnd"/> </p></li><li><p class="P51" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">3)</span>The third mode is the <span class="T7">Gr.camera.manualshoot</span> command which is much like the autoshoot mode. The difference is that a live preview is provided and the image is not captured until the screen is touched.<span class="odfLiEnd"/> </p></li></ol><p class="Standard">All pictures are taken at full camera resolution and stored with 100% jpg quality as "&lt;pref base drive&gt;/rfo-basic/data/image.png".</p><p class="Standard">All of these commands also return pointers to bitmaps. The bitmaps produced are scaled down by a factor of 4. You may end up generating several other bitmaps from these returned bitmaps. For example, you many need to scale the returned bitmap to get it to fit onto your screen. Any bitmaps that you are not going to draw and render should be deleted using <span class="T7">Gr.bitmap.delete</span> to avoid out-of-memory situations.</p><p class="Standard">The Sample Program, f33_camera.bas, demonstrates all the modes of camera operations. It also provides examples of scaling the returned image to fit the screen, writing text on the image and deleting obsolete bitmaps.</p><p class="Standard">The Sample Program, f34_remote_camera.bas, demonstrates remote image capture using two different Android devices.</p><h3 class="Heading_20_3"><a id="a__Gr_camera_select_1|2"><span/></a><a id="_Toc5236250"/>Gr.camera.select 1|2</h3><p class="Standard">Selects the Back (1) or Front(2) camera in devices with two cameras. The default camera is the back (opposite the screen) camera.</p><p class="Standard">If only one exists camera exists, then the default will be that camera. For example, if the device (such as the Nexus 7) only has a Front Camera then it will be the default camera. If the device does not have any installed camera apps, then there will be a run-time error message, "This device does not have a camera." In addition, a run-time error message will be shown if the device does not have the type of camera (front or back) selected.</p><h3 class="Heading_20_3"><a id="a__Gr_camera_shoot__bm_ptr_nvar_"><span/></a><a id="_Toc5236251"/>Gr.camera.shoot &lt;bm_ptr_nvar&gt;</h3><p class="Standard">The command calls the device’s built in camera user interface to take a picture. The image is returned to BASIC! as a bitmap pointed to by the bm_ptr numeric variable. If the camera interface does not, for some reason, take a picture, bm_ptr will be returned with a zero value.</p><p class="Standard">Many of the device camera interfaces will also store the captured images somewhere else in memory with a date coded filename. These images can be found with the gallery application. BASIC! is not able to prevent these extraneous files from being created.</p><p class="Standard">Note: Some devices like the Nexus 7 do not come with a built in camera interface. If you have installed an aftermarket camera application then it will be called when executing this command. You can take pictures with the Nexus 7 (or similar devices) using the other commands even if you do not have camera application installed. If the device does not have any installed camera apps, then there will be a run-time error message, "This device does not have a camera."</p><h3 class="Heading_20_3"><a id="a__Gr_camera_autoshoot__bm_ptr_nvar_{___flash__mode_nexp__{__focus_mode_nexp}_}"><span/></a><a id="_Toc5236252"/>Gr.camera.autoshoot &lt;bm_ptr_nvar&gt;{, &lt;flash_ mode_nexp&gt; {, focus_mode_nexp} }</h3><p class="Standard">An image is captured as soon as the command is executed. No user interaction is required. This command can be used for untended, time-sequence image captures.</p><p class="Standard">The optional flash_mode numeric expression specifies the flash operation:</p><table border="0" cellspacing="0" cellpadding="0" class="Table34"><colgroup><col width="84"/><col width="284"/></colgroup><tr class="Table341"><td style="text-align:left;width:1.914cm; " class="Table34_A1"><p class="P120">0</p></td><td style="text-align:left;width:6.498cm; " class="Table34_A1"><p class="P120">Auto Flash</p></td></tr><tr class="Table341"><td style="text-align:left;width:1.914cm; " class="Table34_A1"><p class="P120">1</p></td><td style="text-align:left;width:6.498cm; " class="Table34_A1"><p class="P120">Flash On</p></td></tr><tr class="Table341"><td style="text-align:left;width:1.914cm; " class="Table34_A1"><p class="P120">2</p></td><td style="text-align:left;width:6.498cm; " class="Table34_A1"><p class="P120">Flash Off</p></td></tr><tr class="Table341"><td style="text-align:left;width:1.914cm; " class="Table34_A1"><p class="P120">3</p></td><td style="text-align:left;width:6.498cm; " class="Table34_A1"><p class="P120">Torch</p></td></tr><tr class="Table341"><td style="text-align:left;width:1.914cm; " class="Table34_A1"><p class="P120">4</p></td><td style="text-align:left;width:6.498cm; " class="Table34_A1"><p class="P120">Red-eye</p></td></tr></table><p class="P105">The default, if no parameter is given, is Auto Flash.</p><p class="Standard">The optional focus_mode numeric expression specifies the camera focus:</p><table border="0" cellspacing="0" cellpadding="0" class="Table35"><colgroup><col width="84"/><col width="284"/></colgroup><tr class="Table351"><td style="text-align:left;width:1.914cm; " class="Table35_A1"><p class="P120">0</p></td><td style="text-align:left;width:6.498cm; " class="Table35_A1"><p class="P120">Auto Focus</p></td></tr><tr class="Table351"><td style="text-align:left;width:1.914cm; " class="Table35_A1"><p class="P120">1</p></td><td style="text-align:left;width:6.498cm; " class="Table35_A1"><p class="P120">Fixed Focus</p></td></tr><tr class="Table351"><td style="text-align:left;width:1.914cm; " class="Table35_A1"><p class="P120">2</p></td><td style="text-align:left;width:6.498cm; " class="Table35_A1"><p class="P120">Focus at Infinity</p></td></tr><tr class="Table351"><td style="text-align:left;width:1.914cm; " class="Table35_A1"><p class="P120">3</p></td><td style="text-align:left;width:6.498cm; " class="Table35_A1"><p class="P120">Macro Focus (close-up)</p></td></tr></table><p class="P105">The default, if no parameter is given, is Auto Focus.</p><p class="Standard">If you want to specify a focus mode, you must also specify a flash mode.</p><p class="P109">The command also stores the captured image into the file, "&lt;pref base drive&gt;/rfo-basic/data/image.png".</p><h3 class="Heading_20_3"><a id="a__Gr_camera_manualShoot__bm_ptr_nvar_{___flash__mode_nexp__{__focus_mode_nexp}_}"><span/></a><a id="_Toc5236253"/>Gr.camera.manualShoot &lt;bm_ptr_nvar&gt;{, &lt;flash_ mode_nexp&gt; {, focus_mode_nexp} }</h3><p class="Standard">This command is much like <span class="T7">Gr.camera.autoshoot</span> except that a live preview is shown on the screen. The image will not be captured until the user taps the screen.</p><h2 class="Heading_20_2"><a id="a__Other_Graphics_Commands"><span/></a><a id="_Toc5236254"/>Other Graphics Commands</h2><h3 class="Heading_20_3"><a id="a__Gr_screen_to_bitmap__bm_ptr_nvar_"><span/></a><a id="_Toc5236255"/>Gr.screen.to_bitmap &lt;bm_ptr_nvar&gt;</h3><p class="Standard">The current contents of the screen will be placed into a bitmap. The pointer to the bitmap will be returned in the bm_ptr variable. If there is not enough memory available to create the bitmap, the returned bitmap pointer is -1. Call <span class="T7">GETERROR$()</span> for information about the failure.</p><p class="Standard">Please note the idiosyncratic underscore in the command.</p><h3 class="Heading_20_3"><a id="a__Gr_get_pixel_x__y__alpha__red__green__blue"><span/></a><a id="_Toc5236256"/>Gr.get.pixel x, y, alpha, red, green, blue</h3><p class="Standard">Returns the color data for the screen pixel at the specified x, y coordinate. The x and y values must not exceed the width and height of the screen and must not be less than zero.</p><p class="Standard">To get a pixel from the screen, BASIC! must first create a bitmap from the screen. If there is not enough memory available to create the bitmap, you will get an "out-of-memory" run-time error.</p><h3 class="Heading_20_3"><a id="a__Gr_save__filename_sexp__{__quality_nexp_}"><span/></a><a id="_Toc5236257"/>Gr.save &lt;filename_sexp&gt; {,&lt;quality_nexp&gt;}</h3><p class="Standard">Saves the current screen to a file. The default path is "&lt;pref base drive&gt;/rfo-basic/data/".</p><p class="Standard">The file will be saved as a JPEG file if the filename ends in ".jpg".</p><p class="Standard">The file will be saved as a PNG file if the filename ends in anything else (including ".png").</p><p class="Standard">The optional &lt;quality_nexp&gt; is used to specify the quality of a saved JPEG file. The value may range from 0 (bad) to 100 (very good). The default value is 50. The quality parameter has no effect on PNG files which are always saved at the highest quality level.</p><p class="Standard">Note: The size of the JPEG file depends on the quality. Lower quality values produce smaller files.</p><h3 class="Heading_20_3"><a id="a__Gr_get_type__object_ptr_nexp____type_svar_"><span/></a><a id="_Toc5236258"/>Gr.get.type &lt;object_ptr_nexp&gt;, &lt;type_svar&gt;</h3><p class="Standard">Get the type of the specified display list object. The type is a string that matches the name of the command that created the object: "point", "circle", "rect", etc. For a complete list of types, see the table in <span class="T7">Gr.Modify</span>.</p><p class="Standard">If the &lt;object_ptr_nexp&gt; parameter does not specify a valid display list object, the returned type is the empty string, "". You can call the <span class="T7">GETERROR$()</span> function to get information about the error.</p><h3 class="Heading_20_3"><a id="a__Gr_get_params__object_ptr_nexp____param_array$___"><span/></a><a id="_Toc5236259"/>Gr.get.params &lt;object_ptr_nexp&gt;, &lt;param_array$[]&gt;</h3><p class="Standard">Get the modifiable parameters of the specified display list object. The parameter strings are returned in the &lt;param_array$[]&gt; in no particular order. The array is specified without an index. If the array exists, it is overwritten. Otherwise a new array is created. The result is always a one-dimensional array.</p><p class="Standard">For a complete list of parameters, see the table in <span class="T7">Gr.Modify</span>.</p><h3 class="Heading_20_3"><a id="a__Gr_get_position__object_ptr_nexp___x__y"><span/></a><a id="_Toc5236260"/>Gr.get.position &lt;object_ptr_nexp&gt;, x, y</h3><p class="Standard">Get the current x,y position of the specified display list object. If the object was specified with rectangle parameters (left, top, right, bottom) then left is returned in x and top is returned in y. For Line objects, the x1 and y1 parameters are returned.</p><h3 class="Heading_20_3"><a id="a__Gr_move__object_ptr_nexp__{{__dx}{__dy}}"><span/></a><a id="_Toc5236261"/>Gr.move &lt;object_ptr_nexp&gt; {{, dx}{, dy}}</h3><p class="Standard">Moves the graphics object by the amounts dx and dy. If the object is a group, all of the graphical objects in the group are moved. The dx and dy parameters are optional. If omitted they default to 0.</p><h3 class="Heading_20_3"><a id="a__Gr_get_value__object_ptr_nexp__{___tag_sexp____value_nvar_|_value_svar_}___"><span/></a><a id="_Toc5236262"/>Gr.get.value &lt;object_ptr_nexp&gt; {, &lt;tag_sexp&gt;, &lt;value_nvar | value_svar&gt;}...</h3><p class="Standard">The value of the parameter named &lt;tag_sexp&gt; ("left", "radius", etc.) in the Display List object &lt;object_ptr_nvar&gt; is returned in the variable &lt;value_nvar&gt; or &lt;value_svar&gt;. This command can return values from only one object at a time, but you may list as many tag/variable pairs as you want.</p><p class="Standard">Most parameters are numeric. Only the <span class="T7">Gr.text.draw</span> "text" parameter is returned in a string var. The parameters for each object are given with descriptions of the commands in this manual. For a complete list of parameters, see the table in <span class="T7">Gr.Modify</span>.</p><h3 class="Heading_20_3"><a id="a__Gr_modify__object_ptr_nexp__{___tag_sexp____value_nexp_|_value_sexp_}___"><span/></a><a id="_Toc5236263"/>Gr.modify &lt;object_ptr_nexp&gt; {, &lt;tag_sexp&gt;, &lt;value_nexp | value_sexp&gt;}...</h3><p class="Standard">The value of the parameter named &lt;tag_sexp&gt; in the Display List object &lt;object_ptr_nvar&gt; is changed to the value of the expression &lt;value_nexp&gt; or &lt;value_sexp&gt;. This command can change only one object at a time, but you may list as many tag/value pairs as you want.</p><p class="Standard">With this command, you can change any of the parameters of any object in the Display List. The parameters you can change are given with the descriptions of the commands in this manual. In addition there are two general purpose parameters, "paint" and "alpha" (see below for details).You must provide parameter names that are valid for the specified object.</p><p class="Standard">The results of <span class="T7">Gr.modify</span> commands will not be observed until a <span class="T7">Gr.render</span> command executes.</p><table border="0" cellspacing="0" cellpadding="0" class="Table36"><colgroup><col width="65"/><col width="74"/><col width="55"/><col width="56"/><col width="56"/><col width="68"/><col width="123"/><col width="82"/><col width="74"/><col width="63"/></colgroup><tr class="Table361"><td style="text-align:left;width:1.496cm; " class="Table36_A1"><p class="P140"> </p></td><td style="text-align:left;width:1.69cm; " class="Table36_B1"><p class="P140">TYPE</p></td><td colspan="2" style="text-align:left;width:1.268cm; " class="Table36_A1"><p class="P140">POSITION 1</p><p class="P140">(numeric)</p></td><td colspan="2" style="text-align:left;width:1.27cm; " class="Table36_E1"><p class="P140">POSITION 2</p><p class="P140">(numeric)</p></td><td style="text-align:left;width:2.805cm; " class="Table36_E1"><p class="P140">ANGLE/RADIUS</p><p class="P140">(numeric)</p></td><td style="text-align:left;width:1.87cm; " class="Table36_E1"><p class="P140">UNIQUE</p><p class="P140">(various)</p></td><td style="text-align:left;width:1.69cm; " class="Table36_E1"><p class="P140">PAINT</p><p class="P140">(list ptr)</p></td><td style="text-align:left;width:1.436cm; " class="Table36_B1"><p class="P140">ALPHA</p><p class="P140">(num)</p></td></tr><tr class="Table361"><td rowspan="10" style="text-align:left;width:1.496cm; " class="Table36_A2"><p class="P151">SHAPES and OBJECTS</p></td><td style="text-align:left;width:1.69cm; " class="Table36_B2"><p class="P142"><a href="#_Gr.arc_&lt;object_number_nvar&gt;,_left," class="Internet_20_link"><span class="Internet_20_link"><span class="T40">arc</span></span></a></p></td><td style="text-align:left;width:1.268cm; " class="Table36_C2"><p class="P140">left</p></td><td style="text-align:left;width:1.272cm; " class="Table36_D2"><p class="P140">top</p></td><td style="text-align:left;width:1.27cm; " class="Table36_E2"><p class="P140">right</p></td><td style="text-align:left;width:1.565cm; " class="Table36_F2"><p class="P140">bottom</p></td><td style="text-align:left;width:2.805cm; " class="Table36_G2"><p class="P140">start_angle</p><p class="P140">sweep_angle</p></td><td style="text-align:left;width:1.87cm; " class="Table36_H2"><p class="P140">fill_mode</p></td><td style="text-align:left;width:1.69cm; " class="Table36_I2"><p class="P140">paint</p></td><td style="text-align:left;width:1.436cm; " class="Table36_J2"><p class="P140">alpha</p></td></tr><tr class="Table361"><td style="text-align:left;width:1.69cm; " class="Table36_B3"><p class="P142"><a href="#_Gr.bitmap.draw_&lt;object_ptr_nvar&gt;,_&lt;" class="Internet_20_link"><span class="Internet_20_link"><span class="T40">bitmap</span></span></a></p></td><td style="text-align:left;width:1.268cm; " class="Table36_C3"><p class="P140">x</p></td><td style="text-align:left;width:1.272cm; " class="Table36_D3"><p class="P140">y</p></td><td style="text-align:left;width:1.27cm; " class="Table36_E3"><p class="P140"> </p></td><td style="text-align:left;width:1.565cm; " class="Table36_F3"><p class="P140"> </p></td><td style="text-align:left;width:2.805cm; " class="Table36_G3"><p class="P140"> </p></td><td style="text-align:left;width:1.87cm; " class="Table36_H3"><p class="P140">bitmap</p></td><td style="text-align:left;width:1.69cm; " class="Table36_I3"><p class="P140">paint</p></td><td style="text-align:left;width:1.436cm; " class="Table36_J3"><p class="P140">alpha</p></td></tr><tr class="Table361"><td style="text-align:left;width:1.69cm; " class="Table36_B4"><p class="P142"><a href="#_Gr.circle_&lt;object_number_nvar&gt;,_x," class="Internet_20_link"><span class="Internet_20_link"><span class="T40">circle</span></span></a></p></td><td style="text-align:left;width:1.268cm; " class="Table36_C4"><p class="P140">x</p></td><td style="text-align:left;width:1.272cm; " class="Table36_D4"><p class="P140">y</p></td><td style="text-align:left;width:1.27cm; " class="Table36_E4"><p class="P140"> </p></td><td style="text-align:left;width:1.565cm; " class="Table36_F4"><p class="P140"> </p></td><td style="text-align:left;width:2.805cm; " class="Table36_G4"><p class="P140">radius</p></td><td style="text-align:left;width:1.87cm; " class="Table36_H4"><p class="P140"> </p></td><td style="text-align:left;width:1.69cm; " class="Table36_I4"><p class="P140">paint</p></td><td style="text-align:left;width:1.436cm; " class="Table36_J4"><p class="P140">alpha</p></td></tr><tr class="Table361"><td style="text-align:left;width:1.69cm; " class="Table36_B5"><p class="P142"><a href="#_Gr.line_&lt;object_number_nvar&gt;,_x1," class="Internet_20_link"><span class="Internet_20_link"><span class="T40">line</span></span></a></p></td><td style="text-align:left;width:1.268cm; " class="Table36_C5"><p class="P140">x1</p></td><td style="text-align:left;width:1.272cm; " class="Table36_D5"><p class="P140">y1</p></td><td style="text-align:left;width:1.27cm; " class="Table36_E5"><p class="P140">x2</p></td><td style="text-align:left;width:1.565cm; " class="Table36_F5"><p class="P140">y2</p></td><td style="text-align:left;width:2.805cm; " class="Table36_G5"><p class="P140"> </p></td><td style="text-align:left;width:1.87cm; " class="Table36_H5"><p class="P140"> </p></td><td style="text-align:left;width:1.69cm; " class="Table36_I5"><p class="P140">paint</p></td><td style="text-align:left;width:1.436cm; " class="Table36_J5"><p class="P140">alpha</p></td></tr><tr class="Table361"><td style="text-align:left;width:1.69cm; " class="Table36_B6"><p class="P142"><a href="#_Gr.oval_&lt;object_number_nvar&gt;,_left," class="Internet_20_link"><span class="Internet_20_link"><span class="T40">oval</span></span></a></p></td><td style="text-align:left;width:1.268cm; " class="Table36_C6"><p class="P140">left</p></td><td style="text-align:left;width:1.272cm; " class="Table36_D6"><p class="P140">top</p></td><td style="text-align:left;width:1.27cm; " class="Table36_E6"><p class="P140">right</p></td><td style="text-align:left;width:1.565cm; " class="Table36_F6"><p class="P140">bottom</p></td><td style="text-align:left;width:2.805cm; " class="Table36_G6"><p class="P140"> </p></td><td style="text-align:left;width:1.87cm; " class="Table36_H6"><p class="P140"> </p></td><td style="text-align:left;width:1.69cm; " class="Table36_I6"><p class="P140">paint</p></td><td style="text-align:left;width:1.436cm; " class="Table36_J6"><p class="P140">alpha</p></td></tr><tr class="Table361"><td style="text-align:left;width:1.69cm; " class="Table36_B7"><p class="P142"><a href="#_Gr.set.pixels_&lt;object_number_nvar&gt;," class="Internet_20_link"><span class="Internet_20_link"><span class="T40">pixels</span></span></a></p></td><td style="text-align:left;width:1.268cm; " class="Table36_C7"><p class="P140">x</p></td><td style="text-align:left;width:1.272cm; " class="Table36_D7"><p class="P140">y</p></td><td style="text-align:left;width:1.27cm; " class="Table36_E7"><p class="P140"> </p></td><td style="text-align:left;width:1.565cm; " class="Table36_F7"><p class="P140"> </p></td><td style="text-align:left;width:2.805cm; " class="Table36_G7"><p class="P140"> </p></td><td style="text-align:left;width:1.87cm; " class="Table36_H7"><p class="P140"> </p></td><td style="text-align:left;width:1.69cm; " class="Table36_I7"><p class="P140">paint</p></td><td style="text-align:left;width:1.436cm; " class="Table36_J7"><p class="P140">alpha</p></td></tr><tr class="Table361"><td style="text-align:left;width:1.69cm; " class="Table36_B8"><p class="P142"><a href="#_Gr.point_&lt;object_number_nvar&gt;,_x," class="Internet_20_link"><span class="Internet_20_link"><span class="T40">point</span></span></a></p></td><td style="text-align:left;width:1.268cm; " class="Table36_C8"><p class="P140">x</p></td><td style="text-align:left;width:1.272cm; " class="Table36_D8"><p class="P140">y</p></td><td style="text-align:left;width:1.27cm; " class="Table36_E8"><p class="P140"> </p></td><td style="text-align:left;width:1.565cm; " class="Table36_F8"><p class="P140"> </p></td><td style="text-align:left;width:2.805cm; " class="Table36_G8"><p class="P140"> </p></td><td style="text-align:left;width:1.87cm; " class="Table36_H8"><p class="P140"> </p></td><td style="text-align:left;width:1.69cm; " class="Table36_I8"><p class="P140">paint</p></td><td style="text-align:left;width:1.436cm; " class="Table36_J8"><p class="P140">alpha</p></td></tr><tr class="Table361"><td style="text-align:left;width:1.69cm; " class="Table36_B9"><p class="P142"><a href="#_Gr.poly_&lt;object_number_nvar&gt;,_list_" class="Internet_20_link"><span class="Internet_20_link"><span class="T40">poly</span></span></a></p></td><td style="text-align:left;width:1.268cm; " class="Table36_C9"><p class="P140">x</p></td><td style="text-align:left;width:1.272cm; " class="Table36_D9"><p class="P140">y</p></td><td style="text-align:left;width:1.27cm; " class="Table36_E9"><p class="P140"> </p></td><td style="text-align:left;width:1.565cm; " class="Table36_F9"><p class="P140"> </p></td><td style="text-align:left;width:2.805cm; " class="Table36_G9"><p class="P140"> </p></td><td style="text-align:left;width:1.87cm; " class="Table36_H9"><p class="P140">list</p></td><td style="text-align:left;width:1.69cm; " class="Table36_I9"><p class="P140">paint</p></td><td style="text-align:left;width:1.436cm; " class="Table36_J9"><p class="P140">alpha</p></td></tr><tr class="Table361"><td style="text-align:left;width:1.69cm; " class="Table36_B10"><p class="P142"><a href="#_Gr.rect_&lt;object_number_nvar&gt;,_left," class="Internet_20_link"><span class="Internet_20_link"><span class="T40">rect</span></span></a></p></td><td style="text-align:left;width:1.268cm; " class="Table36_C10"><p class="P140">left</p></td><td style="text-align:left;width:1.272cm; " class="Table36_D10"><p class="P140">top</p></td><td style="text-align:left;width:1.27cm; " class="Table36_E10"><p class="P140">right</p></td><td style="text-align:left;width:1.565cm; " class="Table36_F10"><p class="P140">bottom</p></td><td style="text-align:left;width:2.805cm; " class="Table36_G10"><p class="P140"> </p></td><td style="text-align:left;width:1.87cm; " class="Table36_H10"><p class="P140"> </p></td><td style="text-align:left;width:1.69cm; " class="Table36_I10"><p class="P140">paint</p></td><td style="text-align:left;width:1.436cm; " class="Table36_J10"><p class="P140">alpha</p></td></tr><tr class="Table361"><td style="text-align:left;width:1.69cm; " class="Table36_B11"><p class="P142"><a href="#_Gr.text.draw_&lt;object_number_nvar&gt;,_" class="Internet_20_link"><span class="Internet_20_link"><span class="T40">text</span></span></a></p></td><td style="text-align:left;width:1.268cm; " class="Table36_C11"><p class="P140">x</p></td><td style="text-align:left;width:1.272cm; " class="Table36_D11"><p class="P140">y</p></td><td style="text-align:left;width:1.27cm; " class="Table36_E11"><p class="P140"> </p></td><td style="text-align:left;width:1.565cm; " class="Table36_F11"><p class="P140"> </p></td><td style="text-align:left;width:2.805cm; " class="Table36_G11"><p class="P140"> </p></td><td style="text-align:left;width:1.87cm; " class="Table36_H11"><p class="P140">text</p></td><td style="text-align:left;width:1.69cm; " class="Table36_I11"><p class="P140">paint</p></td><td style="text-align:left;width:1.436cm; " class="Table36_J11"><p class="P140">alpha</p></td></tr><tr class="Table361"><td rowspan="3" style="text-align:left;width:1.496cm; " class="Table36_A12"><p class="P140">MODI-FIERS</p></td><td style="text-align:left;width:1.69cm; " class="Table36_B12"><p class="P142"><a href="#_Gr.clip_&lt;object_ptr_nvar&gt;,_" class="Internet_20_link"><span class="Internet_20_link"><span class="T40">clip</span></span></a></p></td><td style="text-align:left;width:1.268cm; " class="Table36_C12"><p class="P140">left</p></td><td style="text-align:left;width:1.272cm; " class="Table36_D12"><p class="P140">top</p></td><td style="text-align:left;width:1.27cm; " class="Table36_E12"><p class="P140">right</p></td><td style="text-align:left;width:1.565cm; " class="Table36_F12"><p class="P140">bottom</p></td><td style="text-align:left;width:2.805cm; " class="Table36_G12"><p class="P140"> </p></td><td style="text-align:left;width:1.87cm; " class="Table36_H12"><p class="P140">RO</p></td><td style="text-align:left;width:1.69cm; " class="Table36_I12"><p class="P140">paint</p></td><td style="text-align:left;width:1.436cm; " class="Table36_J12"><p class="P140">alpha</p></td></tr><tr class="Table361"><td style="text-align:left;width:1.69cm; " class="Table36_B13"><p class="P142"><a href="#_Gr.group_&lt;object_number_nvar&gt;,_{" class="Internet_20_link"><span class="Internet_20_link"><span class="T40">group</span></span></a></p></td><td style="text-align:left;width:1.268cm; " class="Table36_C13"><p class="P140"> </p></td><td style="text-align:left;width:1.272cm; " class="Table36_D13"><p class="P140"> </p></td><td style="text-align:left;width:1.27cm; " class="Table36_E13"><p class="P140"> </p></td><td style="text-align:left;width:1.565cm; " class="Table36_F13"><p class="P140"> </p></td><td style="text-align:left;width:2.805cm; " class="Table36_G13"><p class="P140"> </p></td><td style="text-align:left;width:1.87cm; " class="Table36_H13"><p class="P140">list</p></td><td style="text-align:left;width:1.69cm; " class="Table36_I13"><p class="P140">paint</p></td><td style="text-align:left;width:1.436cm; " class="Table36_J13"><p class="P140">alpha</p></td></tr><tr class="Table361"><td style="text-align:left;width:1.69cm; " class="Table36_B14"><p class="P142"><a href="#_Gr.rotate.start_angle,_x," class="Internet_20_link"><span class="Internet_20_link"><span class="T40">rotate</span></span></a></p></td><td style="text-align:left;width:1.268cm; " class="Table36_C14"><p class="P140">x</p></td><td style="text-align:left;width:1.272cm; " class="Table36_D14"><p class="P140">y</p></td><td style="text-align:left;width:1.27cm; " class="Table36_E14"><p class="P140"> </p></td><td style="text-align:left;width:1.565cm; " class="Table36_F14"><p class="P140"> </p></td><td style="text-align:left;width:2.805cm; " class="Table36_G14"><p class="P140">angle</p></td><td style="text-align:left;width:1.87cm; " class="Table36_H14"><p class="P140"> </p></td><td style="text-align:left;width:1.69cm; " class="Table36_I14"><p class="P140">paint</p></td><td style="text-align:left;width:1.436cm; " class="Table36_J14"><p class="P140">alpha</p></td></tr></table><p class="P82"><span class="T7">TABLE NOTES:</span></p><ul><li><p class="P85" style="margin-left:1.27cm;"><span class="ListLabel_20_33" style="display:block;float:left;min-width:0.635cm;"></span>The <span class="T7">TYPE</span> column shows the string returned by <span class="T7">Gr.get.type</span> for each graphical object type.<span class="odfLiEnd"/> </p></li><li><p class="P85" style="margin-left:1.27cm;"><span class="ListLabel_20_33" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">Gr.get.position</span> returns the values in the <span class="T7">POSITION 1</span> columns.<span class="odfLiEnd"/> </p></li><li><p class="P85" style="margin-left:1.27cm;"><span class="ListLabel_20_33" style="display:block;float:left;min-width:0.635cm;"></span>All table entries are <span class="T7">Gr.modify</span> tags (strings). Values of all the tags are numeric except for <span class="T7">"text"</span>.<span class="odfLiEnd"/> </p></li><li><p class="P85" style="margin-left:1.27cm;"><span class="ListLabel_20_33" style="display:block;float:left;min-width:0.635cm;"></span>The values of tags in the <span class="T7">UNIQUE</span> column are either strings (<span class="T7">"text"</span>) or numbers with special interpretations. <span class="T7">"fill_mode"</span> is a logical value. <span class="T7">"list"</span> is a pointer to a list of point coordinates. <span class="T7">"RO"</span> is a Region Operator as explained in <span class="T7">Gr.clip</span>.<span class="odfLiEnd"/> </p></li><li><p class="P85" style="margin-left:1.27cm;"><span class="ListLabel_20_33" style="display:block;float:left;min-width:0.635cm;"></span><span class="T7">"alpha"</span> is an integer value from 0 to 256, with 256 interpreted specially. See <span class="T7">General Purpose Parameters</span>, below.<span class="odfLiEnd"/> </p></li><li><p class="P52" style="margin-left:1.27cm;"><span class="ListLabel_20_33" style="display:block;float:left;min-width:0.635cm;"></span>You can modify the <span class="T7">Gr.set.pixels</span> point-coordinates array directly. There is no <span class="T7">Gr.modify</span> tag.<span class="odfLiEnd"/> </p></li></ul><p class="Standard">For example, suppose a bitmap object was created with <span class="T58">Gr.bitmap.draw BM_ptr, galaxy_ptr, 400, 120</span>.</p><p class="Standard">Executing <span class="T59">gr.modify BM_ptr, "x", 420 </span>would move the bitmap from x =400 to x = 420.<br/>Executing <span class="T60">gr.modify BM_ptr, "y", 200</span> would move the bitmap from y = 120 to y = 200.<br/>Executing <span class="T60">gr.modify BM_ptr, </span><span class="T59">"x", 420, </span><span class="T60">"y", 200</span> would change both x and y at the same time.<br/>Executing <span class="T60">gr.modify BM_ptr, "bitmap", Saturn_ptr</span> would change the bitmap of an image of a (preloaded) Galaxy to the image of a (preloaded) Saturn.</p><h4 class="Heading_20_4"><a id="a__General_Purpose_Parameters"><span/></a>General Purpose Parameters</h4><p class="Standard">When you create a graphical object, all the graphics settings (color, stroke, text settings, and so forth) are captured in a Paint object. You can use the "paint" parameter to replace the Paint object, changing any graphics setting you want to. See the <span class="T7">Gr.paint.get</span> command description (below) for more details.</p><p class="Standard">Normally, graphical objects get their alpha channel value (transparency) from the latest <span class="T7">Gr.color</span> command. You can change the "alpha" parameter to any value from 0 to 255. Setting alpha to 256 tells BASIC! to use the alpha from the latest color value.</p><p class="Standard">For example, you can make an object slowly appear and disappear, just by changing its alpha with <span class="T7">Gr.modify</span>.</p><p class="P106"><span class="T15">Do</span></p><p class="P146"><span class="T15">For a = 1 to 255 step 10</span></p><p class="P100"><span class="T15">gr.modify object,"alpha",a</span></p><p class="P100"><span class="T15">gr.render</span></p><p class="P100"><span class="T15">pause 250</span></p><p class="P146"><span class="T15">next a</span></p><p class="P107"> </p><p class="P146"><span class="T15">For a = 255 to 1 step -10</span></p><p class="P100"><span class="T15">gr.modify object,"alpha",a</span></p><p class="P100"><span class="T15">gr.render</span></p><p class="P100"><span class="T15">pause 250</span></p><p class="P146"><span class="T15">next a</span></p><p class="P95"><span class="T15">until 0</span></p><h3 class="Heading_20_3"><a id="a__GR_COLLISION__object_1_nexp____object_2_nexp__"><span/></a><a id="_Toc5236264"/>GR_COLLISION(&lt;object_1_nexp&gt;, &lt;object_2_nexp&gt;)</h3><p class="Standard">GR_COLLISION() is a function, not a command. The variables &lt;object_1_nvar&gt; and &lt;object_2_nvar&gt; are the object pointers returned when the objects were created.</p><p class="Standard">If the boundary boxes of the two objects overlap then the function will return true (not zero). If they do not overlap then the function will return false (zero).</p><p class="Standard">Objects that may be tested for collision are: rectangle, bitmap, circle, arc, oval, and text. In the case of a circle, an arc, an oval, or text, the object’s rectangular boundary box is used for collision testing, not the actual drawn object.</p><h3 class="Heading_20_3"><a id="a__Gr_clip__object_ptr_nexp____left_nexp____top_nexp____right_nexp____bottom_nexp_{___RO_nexp_}"><span/></a><a id="_Toc5236265"/><a id="_Gr.clip_&lt;object_ptr_nvar&gt;,_"/>Gr.clip &lt;object_ptr_nexp&gt;, &lt;left_nexp&gt;, &lt;top_nexp&gt;, &lt;right_nexp&gt;, &lt;bottom_nexp&gt;{, &lt;RO_nexp&gt;}</h3><p class="Standard">Objects that are drawn after this command is issued will be drawn only within the bounds (clipped) of the clip rectangle specified by the "left, top, right, bottom" numeric expressions.</p><p class="P109">The final parameter is the Region Operator, &lt;RO_nexp&gt;. The Region Operator prescribes how this clip will interact with everything else you are drawing on the screen or bitmap. If you issue more than one <span class="T7">Gr.clip</span> command, the RO prescribes the interaction between the current <span class="T7">Gr.clip</span> rectangle and the previous one. The RO values are:</p><table border="0" cellspacing="0" cellpadding="0" class="Table37"><colgroup><col width="84"/><col width="284"/></colgroup><tr class="Table371"><td style="text-align:left;width:1.914cm; " class="Table37_A1"><p class="P120">0</p></td><td style="text-align:left;width:6.498cm; " class="Table37_A1"><p class="P120">Intersect</p></td></tr><tr class="Table371"><td style="text-align:left;width:1.914cm; " class="Table37_A1"><p class="P120">1</p></td><td style="text-align:left;width:6.498cm; " class="Table37_A1"><p class="P120">Difference</p></td></tr><tr class="Table371"><td style="text-align:left;width:1.914cm; " class="Table37_A1"><p class="P120">2</p></td><td style="text-align:left;width:6.498cm; " class="Table37_A1"><p class="P120">Replace</p></td></tr><tr class="Table371"><td style="text-align:left;width:1.914cm; " class="Table37_A1"><p class="P120">3</p></td><td style="text-align:left;width:6.498cm; " class="Table37_A1"><p class="P120">Reverse Difference</p></td></tr><tr class="Table371"><td style="text-align:left;width:1.914cm; " class="Table37_A1"><p class="P120">4</p></td><td style="text-align:left;width:6.498cm; " class="Table37_A1"><p class="P120">Union</p></td></tr><tr class="Table371"><td style="text-align:left;width:1.914cm; " class="Table37_A1"><p class="P120">5</p></td><td style="text-align:left;width:6.498cm; " class="Table37_A1"><p class="P120">XOR</p></td></tr></table><p class="P152">The Region Operator parameter is optional. If it is omitted, the default action is <span class="T7">Intersect</span>.</p><p class="Standard">Examples:</p><!--Next 'div' was a 'text:p'.--><div class="Standard"><!--Next '
           span' is a draw:frame.
       --><span style="height:2.54cm;width:4.233cm; padding:0; " class="fr1" id="Picture_22"><img style="height:2.54cm;width:4.233cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><p class="Standard"><span class="T7">        Original                        Clip 1                               Clip 2</span></p><p class="P143"><span class="T7">Clip 2 applied to Clip 1 with RO parameter on Clip 2</span></p><!--Next 'div' was a 'text:p'.--><div class="Standard"><!--Next '
           span' is a draw:frame.
       --><span style="height:2.54cm;width:4.233cm; padding:0; " class="fr1" id="Picture_25"><img style="height:2.54cm;width:4.233cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><p class="Standard"><span class="T7">        0 = Intersect                1 = Difference                        2 = Replace</span></p><!--Next 'div' was a 'text:p'.--><div class="Standard"><!--Next '
           span' is a draw:frame.
       --><span style="height:2.54cm;width:4.233cm; padding:0; " class="fr1" id="Picture_31"><img style="height:2.54cm;width:4.233cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><p class="Standard"><span class="T7">  3 = Reverse Difference                      4 = Union                           5 = XOR</span></p><p class="Standard"><span class="T7">Gr.clip</span> is a display list object. It can be modified with <span class="T7">Gr.modify</span>. The modify parameters are "left", "top", "right", "bottom", and "RO".</p><p class="Standard">The <span class="T7">Gr.show</span> and <span class="T7">Gr.hide</span> commands can be used with the <span class="T7">Gr.clip</span> object.</p><h3 class="Heading_20_3"><a id="a__Gr_newDL__dl_array_{_start___length_}__"><span/></a><a id="_Toc5236266"/>Gr.newDL &lt;dl_array[{&lt;start&gt;,&lt;length&gt;}]&gt;</h3><p class="Standard">Replaces the existing display list with a new display list read from a numeric array (dl_array[]) or array segment (dl_array[start,length]) of object numbers. Zero values in the array will be treated as null objects in the display list. Null objects will not be drawn nor will they cause run-time errors.</p><p class="Standard">See the Display List subtopic in this chapter for a complete explanation.</p><p class="Standard">See the Sample Program file, f24_newdl, for a working example of this command.</p><h3 class="Heading_20_3"><a id="a__Gr_getDL__dl_array____{___keep_all_objects_lexp__}"><span/></a><a id="_Toc5236267"/>Gr.getDL &lt;dl_array[]&gt; {, &lt;keep_all_objects_lexp&gt; }</h3><p class="Standard">Writes the current Display List into the numeric array &lt;dl_array[]&gt;. The array is specified without an index. If the array exists, it is overwritten. Otherwise a new array is created. The result is always a one-dimensional array. If the Display List is empty, the array will have one entry that does not display anything.</p><p class="Standard">By default, objects hidden with <span class="T7">Gr.hide</span> are not included in the returned array. To get all objects, including hidden objects, set the optional keep_all_objects flag to true (any non-zero value).</p><h1 class="Heading_20_1"><a id="a__Audio_Interface"><span/></a><a id="_Toc5236268"/>Audio Interface</h1><h2 class="Heading_20_2"><a id="a__Introduction"><span/></a><a id="_Toc5236269"/>Introduction</h2><h3 class="Heading_20_3"><a id="a__The_Audio_Interface"><span/></a><a id="_Toc5236270"/>The Audio Interface</h3><p class="Standard">BASIC! uses the Android Media Player interface for playing music files. This interface is not the most stable part of Android. It sometimes gets confused about what it is doing. This can lead to random "Forced Close" events. While these events are rare, they do occur.</p><h3 class="Heading_20_3"><a id="a__Audio_File_Types"><span/></a><a id="_Toc5236271"/>Audio File Types</h3><p class="Standard">The file types you can play depend on your device and the version of Android it runs. For a current list check the <a href="https://developer.android.com/guide/appendix/media-formats.html" class="Internet_20_link"><span class="Internet_20_link">Android documentation</span></a>. Here is a partial summary:</p><table border="0" cellspacing="0" cellpadding="0" class="Table38"><colgroup><col width="304"/><col width="208"/></colgroup><tr class="Table381"><td style="text-align:left;width:6.95cm; " class="Table38_A1"><p class="P124">Audio File Type</p></td><td style="text-align:left;width:4.763cm; " class="Table38_A1"><p class="P124">Played by Android Version</p></td></tr><tr class="Table381"><td style="text-align:left;width:6.95cm; " class="Table38_A2"><p class="P127">AAC  AMR  MIDI  MP3  OGG  WAV  WMA</p></td><td style="text-align:left;width:4.763cm; " class="Table38_A2"><p class="P110">all</p></td></tr><tr class="Table381"><td style="text-align:left;width:6.95cm; " class="Table38_A2"><p class="P127">FLAC</p></td><td style="text-align:left;width:4.763cm; " class="Table38_A2"><p class="P110">3.1+</p></td></tr><tr class="Table381"><td style="text-align:left;width:6.95cm; " class="Table38_A2"><p class="P127">AAC-ELD</p></td><td style="text-align:left;width:4.763cm; " class="Table38_A2"><p class="P110">4.1+</p></td></tr><tr class="Table381"><td style="text-align:left;width:6.95cm; " class="Table38_A2"><p class="P127">MKV</p></td><td style="text-align:left;width:4.763cm; " class="Table38_A2"><p class="P110">5.0+</p></td></tr></table><p class="Standard"> </p><h2 class="Heading_20_2"><a id="a__Commands"><span/></a><a id="_Toc5236272"/>Commands</h2><p class="Standard">Audio files must be loaded into the Audio File Table (AFT) before they can be played. Each audio file in the AFT has a unique index which is returned by the audio.load command.</p><h3 class="Heading_20_3"><a id="a__Audio_load__aft_nvar____filename_sexp_"><span/></a><a id="_Toc5236273"/>Audio.load &lt;aft_nvar&gt;, &lt;filename_sexp&gt;</h3><p class="Standard">Loads a music file or internet stream into the Audio File Table. The AFT index is returned in &lt;aft_nvar&gt;. If the file or stream can’t be loaded, the &lt;aft_nvar&gt; is set to 0. Your program should test the AFT index to find out if the audio was loaded. If the AFT index is 0, you can call the <span class="T7">GETERROR$()</span> function to get information about the error. If you use index 0 in another <span class="T7">Audio</span> command you will get a run-time error.</p><p class="No_20_Spacing">To load a music file, specify an optional path and a filename. For example:</p><p class="P81">"Blue Danube Waltz.mp3" would access "&lt;pref base drive&gt;/rfo-basic/data/Blue Danube Waltz.mp3".</p><p class="P81">"../../Music/Blue Danube Waltz.mp3" would access "&lt;pref base drive&gt;/Music/Blue Danube Waltz.mp3".</p><p class="Standard">To load an internet stream, specify a full URL.</p><h3 class="Heading_20_3"><a id="a__Audio_play__aft_nexp_"><span/></a><a id="_Toc5236274"/>Audio.play &lt;aft_nexp&gt;</h3><p class="Standard">Selects the file from the Audio File Table pointed to by &lt;aft_nexp&gt; and begins to play it. There must not be an audio file already playing when this command is executed. If there is a file playing, execute audio.stop first.</p><p class="Standard">The music stops playing when the program stops running. To simply start a music file playing and keep it playing, keep the program running. This infinite loop will accomplish that:</p><p class="Code_20_example"><span class="T11">Audio.load ptr, "my_music.mp3"</span></p><p class="Code_20_example"><span class="T11">Audio.play ptr</span></p><p class="Code_20_example"><span class="T11">Do</span></p><p class="Code_20_example"><span class="T11">Pause 5000</span></p><p class="P4"><span class="T11">Until 0</span></p><h3 class="Heading_20_3"><a id="a__Audio_stop"><span/></a><a id="_Toc5236275"/>Audio.stop</h3><p class="Standard">Audio.stop terminates the currently-playing music file. The command will ignored is no file is playing. It is best to precede each audio.play command with an audio.stop command.</p><h3 class="Heading_20_3"><a id="a__Audio_pause"><span/></a><a id="_Toc5236276"/>Audio.pause</h3><p class="Standard">Pause is like stop except that the next audio.play for this file will resume the play at the point where the play was paused.</p><h3 class="Heading_20_3"><a id="a__Audio_loop"><span/></a><a id="_Toc5236277"/>Audio.loop</h3><p class="Standard">When the currently playing file reaches the end of file, the file will restart playing from the beginning of the file. There must be a currently playing file when this command is executed.</p><h3 class="Heading_20_3"><a id="a__Audio_volume__left_nexp____right_nexp_"><span/></a><a id="_Toc5236278"/>Audio.volume &lt;left_nexp&gt;, &lt;right_nexp&gt;</h3><p class="Standard">Changes the volume of the left and right stereo channels. There must be a currently playing file when this command is executed.</p><p class="Standard">The values should range between 0.0 (lowest) to 1.0 (highest). The human ear perceives the level of sound changes on a logarithmic scale. The ear perceives a 10db change as twice as loud. A 20db change would be four times as loud.</p><p class="Standard">A 1 db change would be about 0.89. One way to implement a volume control would be set up a volume table with 1db level changes. The following code creates a 16 step table.</p><p class="Code_20_example"><span class="T11">dim volume[16]</span></p><p class="Code_20_example"><span class="T11">x =1</span></p><p class="Code_20_example"><span class="T11">volume [1] = x</span></p><p class="Code_20_example"><span class="T11">for i = 2 to 16</span></p><p class="P10"><span class="T11">x = x * 0.89</span></p><p class="P10"><span class="T11">volume [i] = x</span></p><p class="Code_20_example"><span class="T11">next i</span></p><p class="Standard">Your code can select volume values from the table for use in the audio.volume command. The loudest volume would be volume[1].</p><h3 class="Heading_20_3"><a id="a__Audio_position_current__nvar_"><span/></a><a id="_Toc5236279"/>Audio.position.current &lt;nvar&gt;</h3><p class="Standard">The current position in milliseconds of the currently playing file will be returned in &lt;nvar&gt;.</p><h3 class="Heading_20_3"><a id="a__Audio_position_seek__nexp_"><span/></a><a id="_Toc5236280"/>Audio.position.seek &lt;nexp&gt;</h3><p class="Standard">Moves the playing position of the currently playing file to &lt;nexp&gt; expressed in milliseconds.</p><h3 class="Heading_20_3"><a id="a__Audio_length__length_nvar____aft_nexp_"><span/></a><a id="_Toc5236281"/>Audio.length &lt;length_nvar&gt;, &lt;aft_nexp&gt;</h3><p class="Standard">Returns the total length of the file in the Audio File Table pointed to by &lt;aft_nexp&gt;. The length in milliseconds will be returned in &lt;length_nvar&gt;.</p><h3 class="Heading_20_3"><a id="a__Audio_release__aft_nexp_"><span/></a><a id="_Toc5236282"/>Audio.release &lt;aft_nexp&gt;</h3><p class="Standard">Releases the resources used by the file in the Audio File Table pointed to by &lt;aft_nexp&gt;. The file must not be currently playing. The specified file will no longer be able to be played.</p><h3 class="Heading_20_3"><a id="a__Audio_isdone__lvar_"><span/></a><a id="_Toc5236283"/>Audio.isdone &lt;lvar&gt;</h3><p class="Standard">If the current playing file is still playing then &lt;lvar&gt; will be set to zero otherwise it will be set to one. This can be used to determine when to start playing the next file in a play list.</p><p class="Code_20_example"><span class="T11">Audio.play f[x]</span></p><p class="Code_20_example"><span class="T11">Do</span></p><p class="P10"><span class="T11">Audio.isdone isdone</span></p><p class="P10"><span class="T11">Pause 1000</span></p><p class="Code_20_example"><span class="T11">Until isdone</span></p><h3 class="Heading_20_3"><a id="a__Audio_record_start__fn_svar_"><span/></a><a id="_Toc5236284"/>Audio.record.start &lt;fn_svar&gt;</h3><p class="Standard">Start audio recording using the microphone as the audio source. The recording will be saved to the specified file. The file must have the extension .3GP. Recording will continue until the audio.record.stop command is issued.</p><h3 class="Heading_20_3"><a id="a__Audio_record_stop"><span/></a><a id="_Toc5236285"/>Audio.record.stop</h3><p class="Standard">Stops the previously started audio recording.</p><h1 class="Heading_20_1"><a id="a__SoundPool"><span/></a><a id="_Toc5236286"/>SoundPool</h1><h2 class="Heading_20_2"><a id="a__Introduction"><span/></a><a id="_Toc5236287"/>Introduction</h2><p class="Standard">A SoundPool is a collection of short sound bites that are preloaded and ready for instantaneous play. SoundPool sound bites can be played while other sounds are playing, either while other sound bites are playing or over a currently playing sound file being played my means of Audio.play. In a game, the Audio.play file would be the background music while the SoundPool sound bites would be the game sounds (Bang, Pow, Screech, etc).</p><p class="Standard">A SoundPool is opened using the SoundPool.open command. After the SoundPool is opened, sound bites will be loaded into memory from files using the SoundPool.load command. Loaded sound bites can be played over and over again using the SoundPool.play command.</p><p class="Standard">A playing sound is called a sound stream. Individual sound streams can be paused (SoundPool.pause), individually or as a group, resumed (SoundPool.resume) and stopped (SoundPool.stop). Other stream parameters (priority, volume and rate) can be changed on the fly.</p><p class="Standard">The SoundPool.release command closes the SoundPool. A new SoundPool can then be opened for a different phase of the game. SoundPool.release is automatically called when the program run is terminated.</p><h2 class="Heading_20_2"><a id="a__Commands"><span/></a><a id="_Toc5236288"/>Commands</h2><h3 class="Heading_20_3"><a id="a__Soundpool_open__MaxStreams_nexp_"><span/></a><a id="_Toc5236289"/>Soundpool.open &lt;MaxStreams_nexp&gt;</h3><p class="Standard">The MaxStreams expression specifies the number of Soundpool streams that can be played at once. If the number of streams to be played exceeds this value, the lowest priority streams will be terminated.</p><p class="Standard">Note: A stream playing via audio.play is not counted as a Soundpool stream.</p><h3 class="Heading_20_3"><a id="a__Soundpool_load__soundID_nvar____file_path_sexp_"><span/></a><a id="_Toc5236290"/>Soundpool.load &lt;soundID_nvar&gt;, &lt;file_path_sexp&gt;</h3><p class="Standard">The file specified in &lt;file_path_sexp&gt; is loaded. Its sound ID is returned in &lt;soundID_nvar&gt;. The sound ID is used to play the sound and also to unload the sound. The sound ID will be returned as zero if the file was not loaded for some reason.</p><p class="Standard">The default file path is "sdcard/rfo-basic/data/"</p><p class="Standard">Note: It can take a few hundred milliseconds for the sound to be loaded. Insert a "Pause 500" statement after the load if you want to play the sound immediately following the load command.</p><h3 class="Heading_20_3"><a id="a__Soundpool_unload__soundID_nexp_"><span/></a><a id="_Toc5236291"/>Soundpool.unload &lt;soundID_nexp&gt;</h3><p class="Standard">The specified loaded sound is unloaded.</p><h3 class="Heading_20_3"><a id="a__Soundpool_play__streamID_nvar____soundID_nexp____rightVolume_nexp____leftVolume_nexp____priority_nexp____loop_nexp____rate_nexp_"><span/></a><a id="_Toc5236292"/>Soundpool.play &lt;streamID_nvar&gt;, &lt;soundID_nexp&gt;, &lt;rightVolume_nexp&gt;, &lt;leftVolume_nexp&gt;, &lt;priority_nexp&gt;, &lt;loop_nexp&gt;, &lt;rate_nexp&gt;</h3><p class="Standard">Starts the specified sound ID playing.</p><p class="Standard">The stream ID is returned in &lt;streamID_nvar&gt;. If the stream was not started, the value returned will be zero. The stream ID is used to pause, resume and stop the stream. It is also used in the stream modification commands (Soundpool.setrate, Soundpool.setvolume, Soundpool.setpriority and Soundpool.setloop).</p><p class="Standard">The left and right volume values must be in the range of 0 to 0.99 with zero being silent.</p><p class="Standard">The priority is a positive value or zero. The lowest priority is zero.</p><p class="Standard">The loop value of -1 will loop the playing stream forever. Values other than -1 specify the number of times the stream will be replayed. A value of 1 will play the stream twice.</p><p class="Standard">The rate value changes the playback rate of the playing stream. The normal rate is 1. The minimum rate (slow) is 0.5. The maximum rate (fast) is 1.85.</p><h3 class="Heading_20_3"><a id="a__Soundpool_setvolume__streamID_nexp____leftVolume_nexp____rightVolume_nexp_"><span/></a><a id="_Toc5236293"/>Soundpool.setvolume &lt;streamID_nexp&gt;, &lt;leftVolume_nexp&gt;, &lt;rightVolume_nexp&gt;</h3><p class="Standard">Changes the volume of a playing stream.</p><p class="Standard">The left and right volume values must be in the range of 0 to 0.99 with zero being silent.</p><h3 class="Heading_20_3"><a id="a__Soundpool_setrate__streamID_nexp____rate_nexp_"><span/></a><a id="_Toc5236294"/>Soundpool.setrate &lt;streamID_nexp&gt;, &lt;rate_nexp&gt;</h3><p class="Standard">Changes the playback rate of the playing stream.</p><p class="Standard">The normal rate is 1. The minimum rate (slow) is 0.5. The maximum rate (fast) is 1.85.</p><h3 class="Heading_20_3"><a id="a__Soundpool_setpriority__streamID_nexp____priority_nexp_"><span/></a><a id="_Toc5236295"/>Soundpool.setpriority &lt;streamID_nexp&gt;, &lt;priority_nexp&gt;</h3><p class="Standard">Changes the priority of a playing stream.</p><p class="Standard">The lowest priority is zero.</p><h3 class="Heading_20_3"><a id="a__Soundpool_pause__streamID_nexp_"><span/></a><a id="_Toc5236296"/>Soundpool.pause &lt;streamID_nexp&gt;</h3><p class="Standard">Pauses the playing of the specified stream. If the stream ID is zero, all streams will be paused.</p><h3 class="Heading_20_3"><a id="a__Soundpool_resume__streamID_nexp_"><span/></a><a id="_Toc5236297"/>Soundpool.resume &lt;streamID_nexp&gt;</h3><p class="Standard">Resumes the playing of the specified stream. If the stream ID is zero, all streams will be resumed.</p><h3 class="Heading_20_3"><a id="a__Soundpool_stop__streamID_nexp_"><span/></a><a id="_Toc5236298"/>Soundpool.stop &lt;streamID_nexp&gt;</h3><p class="Standard">Stops the playing of the specified stream.</p><h3 class="Heading_20_3"><a id="a__Soundpool_release"><span/></a><a id="_Toc5236299"/>Soundpool.release</h3><p class="Standard">Closes the SoundPool and releases all resources. Soundpool.open can be called to open a new SoundPool.</p><h1 class="Heading_20_1"><a id="a__GPS"><span/></a><a id="_Toc5236300"/>GPS</h1><p class="Standard">These commands provide access to the raw location data reported by an Android device's GPS hardware. Before attempting to use these commands, make sure that you have GPS turned on in the Android Settings Application.</p><p class="Standard">The Sample Program file, f15_gps.bas is a running example of the use of the GPS commands.</p><p class="Standard">There are two kinds of data reports: GPS status and location data. They are not reported at the same time, so there is no guarantee that overlapping information matches. For example, the location data report includes a count of the satellites used in the most recent location fix. The same information can be derived from the GPS status report. If number of detected satellites changes between reports, the two numbers do not agree.</p><h2 class="Heading_20_2"><a id="a__GPS_Control_commands"><span/></a><a id="_Toc5236301"/>GPS Control commands</h2><h3 class="Heading_20_3"><a id="a__Gps_open_{{_status_nvar_}_{_time_nexp_}_{_distance_nexp_}}"><span/></a><a id="_Toc5236302"/>Gps.open {{&lt;status_nvar&gt;},{&lt;time_nexp&gt;},{&lt;distance_nexp&gt;}}</h3><p class="P149">Connects to the GPS hardware and starts it reporting location information. This command must be issued before using any of the other GPS commands.</p><p class="P149">The three parameters are all optional; use commas to indicate missing parameters. The parameters are available for advanced usage. The most common way to use this command is simply <span class="T7">GPS.open</span>.</p><p class="P149">If you provide a status return variable &lt;status_nvar&gt;, it is set to 1.0 (TRUE) if the open succeeds, or 0.0 (FALSE) if the open fails. If the open fails, you may get information about the failure from the <span class="T7">GETERROR$()</span> function.</p><p class="P149">The time interval expression &lt;time_nexp&gt; sets the minimum time between location updates. The time is in milleseconds. If you do not set an interval, it defaults to the minimum value allowed by your Android device. This is typically one second. Note: to reduce battery usage, Android recommends a minimum interval of five minutes.</p><p class="P149">If you provide a distance parameter &lt;distance_nexp&gt;, it is a numerical expression that sets the minimum distance between location updates, in meters. That is, your program will not be informed of location changes until your device has moved at least as far as the minimum distance setting. If you do not set a distance, any location change that can be detected will be reported.</p><p class="P149">This command attempts to get an initial "last known location". If the GPS hardware does not report a last known location, BASIC! tries to get one from the network location service. If neither source can provide one, the location information is left empty. If you use GPS commands to get location information before the GPS hardware starts reporting current location information, you will get this "last known location" data. The last known location may be stale, hours or days old, and so may not be useful.</p><h3 class="Heading_20_3"><a id="a__Gps_close"><span/></a><a id="_Toc5236303"/>Gps.close</h3><p class="P149">Disconnects from the GPS hardware and stops the location reports. GPS is automatically closed when you stop your BASIC! program. GPS is not turned off if you tap the HOME key while your GPS program is running.</p><h3 class="Heading_20_3"><a id="a__Gps_status_{{_status_var_}__{_infix_nvar_}_{inview_nvar}__{_sat_list_nexp_}}"><span/></a><a id="_Toc5236304"/>Gps.status {{&lt;status_var&gt;}, {&lt;infix_nvar&gt;},{inview_nvar}, {&lt;sat_list_nexp&gt;}}</h3><p class="Standard">Returns the data from a GPS status report. The parameters are all optional; use commas to indicate omitted parameters (see Optional Parameters).</p><p class="Standard">This kind of report contains the type of the last GPS event and a list of the satellites that were detected by the GPS hardware when that event occurred. As a convenience, this command analyzes the satellite list to report how many satellites were detected ("in view") and how many of those were used in the last location fix ("in fix").</p><p class="Standard">The GPS status report is not timestamped, and the first event reported to your program may be stale. Do not rely on the data from the first status report alone to determine when the GPS hardware gets a current location fix..</p><p class="Standard"><span class="T7">&lt;status_var&gt;</span>: If provided, this variable returns the type of last GPS event that occurred. If you provide a numeric variable, the event type is reported as a number. If it is a string variable, the event type is reported as an English-language event name.</p><table border="0" cellspacing="0" cellpadding="0" class="Table39"><colgroup><col width="129"/><col width="116"/><col width="445"/></colgroup><tr class="Table391"><td style="text-align:left;width:2.962cm; " class="Table39_A1"><p class="P120">Event Number</p></td><td style="text-align:left;width:2.66cm; " class="Table39_A1"><p class="P110"><span class="T7">Event Name</span></p></td><td style="text-align:left;width:10.19cm; " class="Table39_A1"><p class="P120">Meaning</p></td></tr><tr class="Table391"><td style="text-align:left;width:2.962cm; " class="Table39_A1"><p class="P120">1</p></td><td style="text-align:left;width:2.66cm; " class="Table39_A1"><p class="P114">Started</p></td><td style="text-align:left;width:10.19cm; " class="Table39_A1"><p class="P114">The GPS system has been started, no location fixed yet</p></td></tr><tr class="Table391"><td style="text-align:left;width:2.962cm; " class="Table39_A1"><p class="P120">2</p></td><td style="text-align:left;width:2.66cm; " class="Table39_A1"><p class="P114">Stopped</p></td><td style="text-align:left;width:10.19cm; " class="Table39_A1"><p class="P114">The GPS system has been stopped</p></td></tr><tr class="Table391"><td style="text-align:left;width:2.962cm; " class="Table39_A1"><p class="P120">3</p></td><td style="text-align:left;width:2.66cm; " class="Table39_A1"><p class="P114">First Fix</p></td><td style="text-align:left;width:10.19cm; " class="Table39_A1"><p class="P114">The GPS system has received its first location fix since starting</p></td></tr><tr class="Table391"><td style="text-align:left;width:2.962cm; " class="Table39_A1"><p class="P120">4</p></td><td style="text-align:left;width:2.66cm; " class="Table39_A1"><p class="P114">Updated</p></td><td style="text-align:left;width:10.19cm; " class="Table39_A1"><p class="P114">The GPS system has updated its location data</p></td></tr></table><p class="No_20_Spacing"> </p><p class="Standard"><span class="T7">&lt;infix_nvar&gt;</span>: If provided, this numeric variable returns the number of satellites used in the last location fix. This is the number of satellites in the satellite list describe below whose "infix" value is TRUE (non-zero). If the status report could not get a satellite list the number is unknown, so the variable is set to -1.</p><p class="Standard"><span class="T7">&lt;inview_nvar&gt;</span>: If provided, this numeric variable returns the number of satellites detected by the GPS hardware. This is the number of satellites in the satellite list described below that have current data. It is not necessarily the size of the list. If the status report could not get a satellite list the number is unknown, so the variable is set to -1.</p><p class="Standard"><span class="T7">&lt;sat_list_nexp&gt;</span>: If provided, the value of this numeric expression is used as a list pointer. If the value is not a valid numeric list pointer, and the numeric expression is a single numeric variable, then a new list is created and the numeric variable is set to point to the new list.</p><p class="Standard">The satellite list is a list of bundle pointers. When the GPS system reports GPS status, it provides data collected from the satellites it can detect. The data from each satellite is put in a bundle. The satellite list has pointers to all of the satellite data bundles. You can use these pointers with any <span class="T7">Bundle</span> command, just like any other bundle pointer.</p><p class="Standard">If you provide an existing list, any bundles already in the list are cleared, except for the identifying pseudo-random number (PRN). Anything else in the list is discarded. Then the new satellite data is written into the satellite bundle. This is done so that a satellite that is lost and then regained will be remembered in the satellite bundle, but its stale data will not be kept.</p><p class="Standard">The number of satellite bundles with complete data matches the value of the <span class="T7">&lt;inview_var&gt;</span>. These bundles are listed first. Any cleared bundles for satellites not currently visible are at the end of the list.</p><p class="Standard">Each satellite bundle has five key/value pairs. All values are numeric. The value of "infix" is interpreted as logical (Boolean).</p><table border="0" cellspacing="0" cellpadding="0" class="Table40"><colgroup><col width="87"/><col width="611"/></colgroup><tr class="Table401"><td style="text-align:left;width:1.998cm; " class="Table40_A1"><p class="P120">KEY</p></td><td style="text-align:left;width:13.97cm; " class="Table40_A1"><p class="P110"><span class="T7">VALUE</span></p></td></tr><tr class="Table401"><td style="text-align:left;width:1.998cm; " class="Table40_A1"><p class="P121">prn</p></td><td style="text-align:left;width:13.97cm; " class="Table40_A1"><p class="P114">Pseudo-Random Number assigned to the satellite for identification</p></td></tr><tr class="Table401"><td style="text-align:left;width:1.998cm; " class="Table40_A1"><p class="P121">elevation</p></td><td style="text-align:left;width:13.97cm; " class="Table40_A1"><p class="P114">Elevation in degrees</p></td></tr><tr class="Table401"><td style="text-align:left;width:1.998cm; " class="Table40_A1"><p class="P121">azimuth</p></td><td style="text-align:left;width:13.97cm; " class="Table40_A1"><p class="P114">Azimuth in degrees</p></td></tr><tr class="Table401"><td style="text-align:left;width:1.998cm; " class="Table40_A1"><p class="P121">snr</p></td><td style="text-align:left;width:13.97cm; " class="Table40_A1"><p class="P114">Signal-to-noise ratio: a measure of signal strength</p></td></tr><tr class="Table401"><td style="text-align:left;width:1.998cm; " class="Table40_A1"><p class="P121">infix</p></td><td style="text-align:left;width:13.97cm; " class="Table40_A1"><p class="P114">TRUE (non-zero) if the satellite’s data was used in the last location fix, else FALSE (0.0)</p></td></tr></table><p class="P108">This is the only GPS command that returns information from both kinds of GPS data. The satellite count returned in &lt;count_nvar&gt; comes from the location data report, and the satellite list returned in the satellite list comes from the GPS status report. If nothing changes between reports, the number of satellites with infix set TRUE is the same as the satellite count value, but this condition cannot be guaranteed.</p><p class="Standard">The satellite count value is also returned by the <span class="T7">GPS.location</span> command. The satellite list is also returned or updated by the <span class="T7">GPS.status</span> command. This command, <span class="T7">GPS.satellites</span>, is retained for backward-compatibility and for convenience.</p><p class="Standard">For example, let’s say the most recent GPS status report had data from three satellites with PRNs 4, 7, and 29.</p><p class="Code_20_example"><span class="T11">GPS.OPEN sts</span></p><p class="Code_20_example"><span class="T11">GPS.STATUS , , inView, sats</span></p><p class="Code_20_example"><span class="T11">DEBUG.DUMP.LIST sats                        % may print 7.0, 29.0, 4.0</span></p><p class="Standard">Assume appropriate delays after the <span class="T7">GPS.open</span> and that <span class="T7">DEBUG</span> is enabled. Another GPS status report may report data from satellites 4, 7, and 8. Then the list dump might show 7.0, 4.0, 8.0, 29.0. The order is unpredictable, except that 29.0 will be last, because it is not currently visible. In both cases, the value of inView is 3.0.</p><p class="Standard"><span class="T7">Debug.dump.bundle</span> of the satellite bundle with PRN 4 might show this:</p><p class="Code_20_example"><span class="T11">Dumping Bundle 11</span></p><p class="Code_20_example"><span class="T11">prn: 4.0</span></p><p class="Code_20_example"><span class="T11">snr: 17.0</span></p><p class="Code_20_example"><span class="T11">infix: 0.0</span></p><p class="Code_20_example"><span class="T11">elevation: 25.0</span></p><p class="Code_20_example"><span class="T11">azimuth: 312.0</span></p><h2 class="Heading_20_2"><a id="a__GPS_Location_commands"><span/></a><a id="_Toc5236305"/>GPS Location commands</h2><p class="Standard">These commands report the values returned by the most recent GPS location report. The <span class="T7">Gps.satellites</span> command also returns the list of satellites contained in a GPS status report.</p><p class="No_20_Spacing">A location report contains:</p><ul><li><p class="P53" style="margin-left:1.27cm;"><span class="ListLabel_20_37" style="display:block;float:left;min-width:0.635cm;"></span>the location provider<span class="odfLiEnd"/> </p></li><li><p class="P53" style="margin-left:1.27cm;"><span class="ListLabel_20_37" style="display:block;float:left;min-width:0.635cm;"></span>the number of satellites used to generate the data in the report<span class="odfLiEnd"/> </p></li><li><p class="P53" style="margin-left:1.27cm;"><span class="ListLabel_20_37" style="display:block;float:left;min-width:0.635cm;"></span>the time when the data was reported<span class="odfLiEnd"/> </p></li><li><p class="P53" style="margin-left:1.27cm;"><span class="ListLabel_20_37" style="display:block;float:left;min-width:0.635cm;"></span>an estimate of the accuracty of the location components<span class="odfLiEnd"/> </p></li><li><p class="P53" style="margin-left:1.27cm;"><span class="ListLabel_20_37" style="display:block;float:left;min-width:0.635cm;"></span>the location components:<span class="odfLiEnd"/> </p><ul><li><p class="P53" style="margin-left:1.27cm;"><span class="ListLabel_20_38" style="display:block;float:left;min-width:0.635cm;">o</span>latitude<span class="odfLiEnd"/> </p></li><li><p class="P53" style="margin-left:1.27cm;"><span class="ListLabel_20_38" style="display:block;float:left;min-width:0.635cm;">o</span>longitude<span class="odfLiEnd"/> </p></li><li><p class="P53" style="margin-left:1.27cm;"><span class="ListLabel_20_38" style="display:block;float:left;min-width:0.635cm;">o</span>altitude<span class="odfLiEnd"/> </p></li><li><p class="P53" style="margin-left:1.27cm;"><span class="ListLabel_20_38" style="display:block;float:left;min-width:0.635cm;">o</span>bearing<span class="odfLiEnd"/> </p></li><li><p class="P53" style="margin-left:1.27cm;"><span class="ListLabel_20_38" style="display:block;float:left;min-width:0.635cm;">o</span>speed<span class="odfLiEnd"/> </p></li></ul></li></ul><p class="Standard">There are individual commands available to read each element of a location report. If you use separate GPS commands to read different components of the location data, you don’t know if the different components came from the same location report. To be certain of consistent data, get all of the location components from a single <span class="T7">Gps.location</span> command.</p><h3 class="Heading_20_3"><a id="a__Gps_location_{{_time_nvar_}__{_prov_svar_}__{_count_nvar}__{_acc_nvar_}__{_lat_nvar_}__{_long_nvar_}__{_alt_nvar_}__{_bear_nvar_}__{_speed_nvar_}}"><span/></a><a id="_Toc5236306"/>Gps.location {{&lt;time_nvar&gt;}, {&lt;prov_svar&gt;}, {&lt;count_nvar}, {&lt;acc_nvar&gt;}, {&lt;lat_nvar&gt;}, {&lt;long_nvar&gt;}, {&lt;alt_nvar&gt;}, {&lt;bear_nvar&gt;}, {&lt;speed_nvar&gt;}}</h3><p class="Standard">Returns the data from a single GPS location report. It returns all of the data provided by all of the individual GPS location component commands below, except that it does not return the satellite list of the <span class="T7">Gps.satellites</span> command.</p><p class="Standard">The parameters are all optional; use commas to indicate missing parameters (see Optional Parameters). All of the parameters are variable names, so if any parameter is not provided, the corresponding data is not returned.</p><p class="No_20_Spacing">The parameters are:</p><p class="List_20_Paragraph"><span class="T7">&lt;time_nvar&gt;</span>: time of the location fix, in milliseconds since the epoch, as reported by <span class="T7">Gps.time</span>.</p><p class="List_20_Paragraph"><span class="T7">&lt;prov_svar&gt;</span>: the location provider, as reported by <span class="T7">Gps.provider</span>.</p><p class="List_20_Paragraph"><span class="T7">&lt;count_nvar&gt;</span>: the number of satellites used to generate the location fix, as reported by <span class="T7">Gps.satellites</span>.</p><p class="List_20_Paragraph"><span class="T7">&lt;acc_nvar&gt;</span>: an estimate of the accuracy of the location fix, in meters, as reported by <span class="T7">Gps.accuracy</span>.</p><p class="List_20_Paragraph"><span class="T7">&lt;lat_nvar&gt;</span>: current latitude, in decimal degrees, as reported by <span class="T7">Gps.latitude</span>.</p><p class="List_20_Paragraph"><span class="T7">&lt;long_nvar&gt;</span>: current longitude, in decimal degrees, as reported by <span class="T7">Gps.longitude</span>.</p><p class="List_20_Paragraph"><span class="T7">&lt;alt_nvar&gt;</span>: current altitude, in meters, as reported by <span class="T7">Gps.altitude</span>.</p><p class="List_20_Paragraph"><span class="T7">&lt;bear_nvar&gt;</span>: current bearing, in compass degrees, as reported by <span class="T7">Gps.bearing</span>.</p><p class="List_20_Paragraph"><span class="T7">&lt;speed_nvar&gt;</span>: current speed, in meters per second, as reported by <span class="T7">Gps.speed</span>.</p><h3 class="Heading_20_3"><a id="a__Gps_time__nvar_"><span/></a><a id="_Toc5236307"/>Gps.time &lt;nvar&gt;</h3><p class="Standard">Returns the time of the last GPS fix in milliseconds since "the epoch", January 1, 1970, UTC.</p><h3 class="Heading_20_3"><a id="a__Gps_provider__svar_"><span/></a><a id="_Toc5236308"/>Gps.provider &lt;svar&gt;</h3><p class="P149">Returns the name of the location provider in &lt;svar&gt;. Normally this is "<span class="T7">gps</span>". The first time you read location data, you get the last known location, which may come from either the GPS hardware or the network location service. If it came from the network, this command returns "<span class="T7">network</span>". If neither provider reported a last known location, the provider &lt;svar&gt; is the empty string, "".</p><h3 class="Heading_20_3"><a id="a__Gps_satellites_{{_count_nvar_}__{_sat_list_nexp_}}"><span/></a><a id="_Toc5236309"/>Gps.satellites {{&lt;count_nvar&gt;}, {&lt;sat_list_nexp&gt;}}</h3><p class="Standard">Returns the number of satellites used for the last GPS fix and a list of the satellites known to the GPS hardware.</p><p class="Standard">Both parameters are optional. If you omit &lt;count_nvar&gt; but use &lt;sat_list_nexp&gt;, keep the comma.</p><p class="Standard">If you provide a numeric variable &lt;count_nvar&gt;, it is set to the number of satellites used for the most recent location data. If the location report did not provide a satellite count, &lt;count_nvar&gt; is set to -1.</p><p class="Standard">For a description of the satellite list pointer expression &lt;sat_list_nexp&gt;, see the &lt;sat_list_nexp&gt; parameter of the <span class="T7">Gps.status</span> command, above.</p><h3 class="Heading_20_3"><a id="a__Gps_accuracy__nvar_"><span/></a><a id="_Toc5236310"/>Gps.accuracy &lt;nvar&gt;</h3><p class="P149">Returns the accuracy level in &lt;nvar&gt;. If non-zero, this is an estimate of the uncertainty in the reported location, measured in meters. A value of zero means the location is unknown.</p><h3 class="Heading_20_3"><a id="a__Gps_latitude__nvar_"><span/></a><a id="_Toc5236311"/>Gps.latitude &lt;nvar&gt;</h3><p class="P149">Returns the latitude in decimal degrees in &lt;nvar&gt;.</p><h3 class="Heading_20_3"><a id="a__Gps_longitude__nvar_"><span/></a><a id="_Toc5236312"/>Gps.longitude &lt;nvar&gt;</h3><p class="P149">Returns the longitude in decimal degrees in &lt;nvar&gt;.</p><h3 class="Heading_20_3"><a id="a__Gps_altitude__nvar_"><span/></a><a id="_Toc5236313"/>Gps.altitude &lt;nvar&gt;</h3><p class="P149">Returns the altitude in meters in &lt;nvar&gt;.</p><h3 class="Heading_20_3"><a id="a__Gps_bearing__nvar_"><span/></a><a id="_Toc5236314"/>Gps.bearing &lt;nvar&gt;</h3><p class="P149">Returns the bearing in compass degrees in &lt;nvar&gt;.</p><h3 class="Heading_20_3"><a id="a__Gps_speed__nvar_"><span/></a><a id="_Toc5236315"/>Gps.speed &lt;nvar&gt;</h3><p class="P149">Returns the speed in meters per second in &lt;nvar&gt;.</p><h1 class="Heading_20_1"><a id="a__Sensors"><span/></a><a id="_Toc5236316"/>Sensors</h1><h2 class="Heading_20_2"><a id="a__Introduction"><span/></a><a id="_Toc5236317"/>Introduction</h2><p class="Standard">Android devices can have several types of Sensors. Currently, Android's pre-defined Sensors are:</p><table border="0" cellspacing="0" cellpadding="0" class="Table41"><colgroup><col width="229"/><col width="90"/><col width="257"/></colgroup><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A1"><p class="P137">Name of Sensor</p></td><td style="text-align:left;width:2.062cm; " class="Table41_A1"><p class="P138">Type</p></td><td style="text-align:left;width:5.876cm; " class="Table41_A1"><p class="P138">Notes</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A2"><p class="P127">Accelerometer</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B2"><p class="P110">1</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C2"><p class="P114">As of API 3 (Cupcake)</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A3"><p class="P127">Magnetic Field</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B3"><p class="P110">2</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C3"><p class="P114">As of API 3</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A2"><p class="P127">Orientation</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B2"><p class="P110">3</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C2"><p class="P114">As of API 3, deprecated API 8</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A5"><p class="P127">Gyroscope</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B5"><p class="P110">4</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C5"><p class="P114">As of API 3</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A2"><p class="P127">Light</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B2"><p class="P110">5</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C2"><p class="P114">As of API 3</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A7"><p class="P127">Pressure</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B7"><p class="P110">6</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C7"><p class="P114">As of API 3</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A2"><p class="P127">Temperature</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B2"><p class="P110">7</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C2"><p class="P114">As of API 3, deprecated API 14</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A9"><p class="P127">Proximity</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B9"><p class="P110">8</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C9"><p class="P114">As of API 3</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A2"><p class="P127">Gravity</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B2"><p class="P110">9</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C2"><p class="P114">As of API 9 (Gingerbread)</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A11"><p class="P127">Linear Acceleration</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B11"><p class="P110">10</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C11"><p class="P114">As of API 9</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A2"><p class="P127">Rotation Vector</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B2"><p class="P110">11</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C2"><p class="P114">As of API 9</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A13"><p class="P127">Relative Humidity</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B13"><p class="P110">12</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C13"><p class="P114">As of API 14 (Ice Cream Sandwich)</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A2"><p class="P127">Ambient Temperature</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B2"><p class="P110">13</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C2"><p class="P114">As of API 14</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A15"><p class="P127">Uncalibrated Magnetic Field</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B15"><p class="P110">14</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C15"><p class="P114">As of API 18 (Jellybean MR2)</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A2"><p class="P127">Game Rotation Vector</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B2"><p class="P110">15</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C2"><p class="P114">As of API 18</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A17"><p class="P127">Uncalibrated Gyroscope</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B17"><p class="P110">16</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C17"><p class="P114">As of API 18</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A2"><p class="P127">Significant Motion</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B2"><p class="P110">17</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C2"><p class="P114">As of API 18</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A19"><p class="P127">Step Detector</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B19"><p class="P110">18</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C19"><p class="P114">As of API 19 (KitKat)</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A2"><p class="P127">Step Counter</p></td><td style="text-align:left;width:2.062cm; " class="Table41_B2"><p class="P110">19</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C2"><p class="P114">As of API 19</p></td></tr><tr class="Table411"><td style="text-align:left;width:5.239cm; " class="Table41_A21"><p class="P118"><span class="T53">Geomagnetic Rotation Vector</span></p></td><td style="text-align:left;width:2.062cm; " class="Table41_B21"><p class="P110">20</p></td><td style="text-align:left;width:5.876cm; " class="Table41_C21"><p class="P114">As of API 19</p></td></tr></table><p class="P153"> </p><p class="Standard">Some details about (most) of these sensors can be found at <a href="http://developer.android.com/reference/android/hardware/SensorEvent.html" class="Internet_20_link"><span class="Internet_20_link">Android's Sensor Event</span></a> (<a href="http://developer.android.com/reference/android/hardware/SensorEvent.html" class="Internet_20_link"><span class="Internet_20_link">http://developer.android.com/reference/android/hardware/SensorEvent.html</span></a>) web page.</p><p class="Standard">Not all Android devices have all of these Sensors. Some Android devices may have none of these sensors. The BASIC! command, sensors.list, can be used to provide an inventory of the sensors available on a particular device.</p><p class="Standard">Some newer devices may have sensors that are not currently supported by BASIC! Those sensors will be reported as "Unknown, Type = NN" where NN is the sensor type number.</p><h2 class="Heading_20_2"><a id="a__Sensor_Commands"><span/></a><a id="_Toc5236318"/>Sensor Commands</h2><h3 class="Heading_20_3"><a id="a__Sensors_list__sensor_array$___"><span/></a><a id="_Toc5236319"/>Sensors.list &lt;sensor_array$[]&gt;</h3><p class="Standard">Writes information about the sensors available on the Android device into the &lt;sensor_array$[]&gt; parameter. If the array exists, it is overwritten. Otherwise a new array is created. The result is always a one-dimensional array.</p><p class="Standard">The array elements contain the names and types of the available sensors. For example, one element may be "Gyroscope, Type = 4". The following program snippet prints the elements of the sensor list.</p><p class="Code_20_example"><span class="T11">SENSORS.LIST sensorarray$[]</span></p><p class="Code_20_example"><span class="T11">ARRAY.LENGTH size, sensorarray$[]</span></p><p class="Code_20_example"><span class="T11">FOR index = 1 TO size</span></p><p class="Code_20_example"><span class="T11">    PRINT sensorarray$[ index ]</span></p><p class="Code_20_example"><span class="T11">NEXT index</span></p><p class="Code_20_example"><span class="T11">END</span></p><h3 class="Heading_20_3"><a id="a__Sensors_open__type_nexp_{__delay_nexp_}{___type_nexp_{__delay_nexp_}_____}"><span/></a><a id="_Toc5236320"/>Sensors.open &lt;type_nexp&gt;{:&lt;delay_nexp&gt;}{, &lt;type_nexp&gt;{:&lt;delay_nexp&gt;}, ...}</h3><p class="Standard">Opens a list of sensors for reading. The parameter list is the type numbers of the sensors to be opened, followed optionally by a colon (':') and a number (0, 1, 2, or 3) that specifies the delay in sampling the sensor. 3 is the default (slowest).</p><p class="Standard">This table gives a general idea of what the rate values mean. The delay values are only "suggestions" to the sensors, which may alter the real delays, and do not apply to all sensors. Faster settings use more battery. </p><table border="0" cellspacing="0" cellpadding="0" class="Table42"><colgroup><col width="111"/><col width="111"/><col width="111"/><col width="347"/></colgroup><tr class="Table421"><td style="text-align:left;width:2.549cm; " class="Table42_A1"><p class="P110">Value</p></td><td style="text-align:left;width:2.551cm; " class="Table42_A1"><p class="P110">Name</p></td><td style="text-align:left;width:2.551cm; " class="Table42_A1"><p class="P110">Typical Delay</p></td><td style="text-align:left;width:7.938cm; " class="Table42_A1"><p class="P110">Typical Usage</p></td></tr><tr class="Table421"><td style="text-align:left;width:2.549cm; " class="Table42_A1"><p class="P110">3</p></td><td style="text-align:left;width:2.551cm; " class="Table42_A1"><p class="P110">Normal</p></td><td style="text-align:left;width:2.551cm; " class="Table42_A1"><p class="P110">200 ms</p></td><td style="text-align:left;width:7.938cm; " class="Table42_A1"><p class="P114">Default: suitable for screen orientation changes</p></td></tr><tr class="Table421"><td style="text-align:left;width:2.549cm; " class="Table42_A1"><p class="P110">2</p></td><td style="text-align:left;width:2.551cm; " class="Table42_A1"><p class="P110">UI</p></td><td style="text-align:left;width:2.551cm; " class="Table42_A1"><p class="P110">60 ms</p></td><td style="text-align:left;width:7.938cm; " class="Table42_A1"><p class="P114">Rate suitable for the user interface</p></td></tr><tr class="Table421"><td style="text-align:left;width:2.549cm; " class="Table42_A1"><p class="P110">1</p></td><td style="text-align:left;width:2.551cm; " class="Table42_A1"><p class="P110">Game</p></td><td style="text-align:left;width:2.551cm; " class="Table42_A1"><p class="P110">20 ms</p></td><td style="text-align:left;width:7.938cm; " class="Table42_A1"><p class="P114">Rate suitable for game play</p></td></tr><tr class="Table421"><td style="text-align:left;width:2.549cm; " class="Table42_A1"><p class="P110">0</p></td><td style="text-align:left;width:2.551cm; " class="Table42_A1"><p class="P110">Fastest</p></td><td style="text-align:left;width:2.551cm; " class="Table42_A1"><p class="P110">0 ms</p></td><td style="text-align:left;width:7.938cm; " class="Table42_A1"><p class="P114">Sample as fast as possible</p></td></tr></table><p class="P87">Example:</p><p class="Code_20_example"><span class="T11">SENSORS.OPEN 1:1, 3                % Monitor the Acceleration sensor at Game rate</span></p><p class="P11"><span class="T11">% and the Orientation sensor at Normal rate.</span></p><p class="Standard">This command must be executed before issuing any <span class="T7">Sensors.read</span> commands. You should only open the sensors that you actually want to read. Each sensor opened increases battery drain and the background CPU usage.</p><p class="Standard">BASIC! uses the colon character to separate multiple commands on a single line. The use of colon in this command conflicts with that feature, so you must use caution when using both features together.</p><p class="Standard">If you put any colons on a line after this command, the preprocessor <span class="T7">always</span> assumes the colons are part of the command and not command separators. The <span class="T7">Sensors.open</span> command <span class="T7">must</span> be either on a line by itself or placed last on a multi-command line.</p><h3 class="Heading_20_3"><a id="a__Sensors_read_sensor_type_nexp__p1_nvar__p2_nvar__p3_nvar"><span/></a><a id="_Toc5236321"/>Sensors.read sensor_type_nexp, p1_nvar, p2_nvar, p3_nvar </h3><p class="Standard">This command returns that latest values from the sensors specified by the "sensor_type" parameters. The values are returned are placed into the p1, p2 and p3 parameters. The meaning of these parameters depends upon the sensor being read. Not all sensors return all three parameter values. In those cases, the unused parameter values will be set to zero. See <a href="http://developer.android.com/reference/android/hardware/SensorEvent.html" class="Internet_20_link"><span class="Internet_20_link">Android's Sensor Event</span></a> web page for the meaning of these parameters.</p><h3 class="Heading_20_3"><a id="a__Sensors_close"><span/></a><a id="_Toc5236322"/>Sensors.close</h3><p class="P149">Closes the previously opened sensors. The sensors' hardware will be turned off preventing battery drain. Sensors are automatically closed when the program run is stopped via the BACK key or Menu-&gt;Stop.</p><h1 class="Heading_20_1"><a id="a__System"><span/></a><a id="_Toc5236323"/>System</h1><p class="Standard">The <span class="T7">System</span> commands provide for the execution of System commands on non-rooted devices.</p><p class="Standard">The <span class="T7">SU</span> commands provide for the execution of Superuser commands on rooted devices. See the Sample Program, f36_superuser.bas, for an example using these commands.</p><p class="Standard">The <span class="T7">App</span> commands provide for sending messages through the Android system to other applications on your Android device.</p><p class="Standard">The <span class="T7">App</span> commands are not related to <span class="T7">System</span> or <span class="T7">SU</span>, but they are typically used to replace commands of the form <span class="T7">System.write "am start &lt;parameter-list&gt;"</span> or <span class="T7">System.write "am broadcast &lt;parameter-list&gt;"</span>.</p><h2 class="Heading_20_2"><a id="a__System_Commands"><span/></a><a id="_Toc5236324"/>System Commands</h2><h3 class="Heading_20_3"><a id="a__System_open"><span/></a><a id="_Toc5236325"/>System.open</h3><p class="Standard">Opens a shell to execute system commands. The working directory is set to "<span class="T7">rfo-basic</span>". If the working directory does not exist, it is created. If you open a command shell with either Su.open or System.open, you can't open another one of either type without first closing the open one.</p><h3 class="Heading_20_3"><a id="a__System_write__sexp_"><span/></a><a id="_Toc5236326"/>System.write &lt;sexp&gt;</h3><p class="Standard">Executes a System command.</p><h3 class="Heading_20_3"><a id="a__System_read_ready__nvar_"><span/></a><a id="_Toc5236327"/>System.read.ready &lt;nvar&gt;</h3><p class="Standard">Tests for responses from a System.write command. If the result is non-zero, then response lines are available.</p><p class="Standard">Not all System commands return a response. If there is no response returned after a few seconds then it should be assumed that there will be no response.</p><h3 class="Heading_20_3"><a id="a__System_read_line__svar_"><span/></a><a id="_Toc5236328"/>System.read.line &lt;svar&gt;</h3><p class="Standard">Places the next available response line into the string variable.</p><h3 class="Heading_20_3"><a id="a__System_close"><span/></a><a id="_Toc5236329"/>System.close</h3><p class="Standard">Exits the System Shell mode.</p><h2 class="Heading_20_2"><a id="a__Superuser_Commands"><span/></a><a id="_Toc5236330"/>Superuser Commands</h2><h3 class="Heading_20_3"><a id="a__Su_open"><span/></a><a id="_Toc5236331"/>Su.open</h3><p class="Standard">Requests Superuser permission. If granted, opens a shell to execute system commands. The working directory is set to /. If you open a command shell with either Su.open or System.open, you can't open another one of either type without first closing the open one.</p><h3 class="Heading_20_3"><a id="a__Su_write__sexp_"><span/></a><a id="_Toc5236332"/>Su.write &lt;sexp&gt;</h3><p class="Standard">Executes a Superuser command.</p><h3 class="Heading_20_3"><a id="a__Su_read_ready__nvar_"><span/></a><a id="_Toc5236333"/>Su.read.ready &lt;nvar&gt;</h3><p class="Standard">Tests for responses from a Su.write command. If the result is non-zero, then response lines are available.</p><p class="Standard">Not all Superuser commands return a response. If there is no response returned after a few seconds then it should be assumed that there will be no response.</p><h3 class="Heading_20_3"><a id="a__Su_read_line__svar_"><span/></a><a id="_Toc5236334"/>Su.read.line &lt;svar&gt;</h3><p class="Standard">Places the next available response line into the string variable.</p><h3 class="Heading_20_3"><a id="a__Su_close"><span/></a><a id="_Toc5236335"/>Su.close</h3><p class="Standard">Exits the Superuser mode.</p><h2 class="Heading_20_2"><a id="a__App_Commands"><span/></a><a id="_Toc5236336"/>App Commands</h2><h3 class="Heading_20_3"><a id="a__App_broadcast__action_sexp____data_uri_sexp____package_sexp____component_sexp____mime_type_sexp____categories_sexp____extras_bptr_nexp____flags_nexp_"><span/></a><a id="_Toc5236337"/>App.broadcast &lt;action_sexp&gt;, &lt;data_uri_sexp&gt;, &lt;package_sexp&gt;, &lt;component_sexp&gt;, &lt;mime_type_sexp&gt;, &lt;categories_sexp&gt;, &lt;extras_bptr_nexp&gt;, &lt;flags_nexp&gt; </h3><p class="Standard">Creates a system message and broadcasts it to other applications on your device. The message is called an Intent. The Intent will be received by any application that has the right Intent Filter.</p><p class="Standard">All of the parameters are optional; use commas to indicate omitted parameters (see Optional Parameters). See <span class="T7">App.start</span>, below, for parameter definitions.</p><p class="Standard">If there is no app that can receive your broadcast, the broadcast is ignored. You can detect this condition only by calling the <span class="T7">GETERROR$()</span> function. If an app is available to receive the broadcast, <span class="T7">GETERROR$()</span> returns "No error".</p><h3 class="Heading_20_3"><a id="a__App_start__action_sexp____data_uri_sexp____package_sexp____component_sexp____mime_type_sexp____categories_sexp____extras_bptr_nexp____flags_nexp_"><span/></a><a id="_Toc5236338"/>App.start &lt;action_sexp&gt;, &lt;data_uri_sexp&gt;, &lt;package_sexp&gt;, &lt;component_sexp&gt;, &lt;mime_type_sexp&gt;, &lt;categories_sexp&gt;, &lt;extras_bptr_nexp&gt;, &lt;flags_nexp&gt; </h3><p class="Standard">Sends a message to the system, called an Intent, requesting a specific application or type of application to start. If more than one app can handle the request, the system puts up a chooser for you.</p><p class="Standard">If there is no app that can handle the request, the Intent is ignored. You can detect this condition only by calling the <span class="T7">GETERROR$()</span> function. If an app is available to launch, <span class="T7">GETERROR$()</span> returns "No error".</p><p class="Standard">All of the parameters are optional. Use commas to indicate omitted parameters (see Optional Parameters). You will almost never need to use all of the parameters in one command.</p><p class="Standard">The first six parameters are string expressions: action, data URI, package name, component name, MIME type, and a list of categories separated by commas (the commas are part of the string expression).</p><p class="Standard">The last two parameters are numeric expressions. One is a pointer to a bundle that contains "extras" that are attached to the message. The other is a single number representing one or more flag values.</p><p class="Standard">For parameter values, consult the documentation of the Android system and the app you want to start.</p><table border="0" cellspacing="0" cellpadding="0" class="Table43"><colgroup><col width="154"/><col width="465"/><col width="119"/></colgroup><tr class="Table431"><td style="text-align:left;width:3.522cm; " class="Table43_A1"><p class="P124">Parameter</p></td><td style="text-align:left;width:10.636cm; " class="Table43_A1"><p class="P124">Meaning</p></td><td style="text-align:left;width:2.732cm; " class="Table43_A1"><p class="P124">am Command Equivalent</p></td></tr><tr class="Table431"><td style="text-align:left;width:3.522cm; " class="Table43_A2"><p class="P127">action</p></td><td style="text-align:left;width:10.636cm; " class="Table43_B2"><p class="P114">An Action defined by Android or by the target application</p></td><td style="text-align:left;width:2.732cm; " class="Table43_C2"><p class="P114">-a</p></td></tr><tr class="Table431"><td style="text-align:left;width:3.522cm; " class="Table43_A3"><p class="P127">data URI</p></td><td style="text-align:left;width:10.636cm; " class="Table43_B3"><p class="P114">Data or path to data; BASIC! URI-encodes this string</p></td><td style="text-align:left;width:2.732cm; " class="Table43_C3"><p class="P114">-d</p></td></tr><tr class="Table431"><td style="text-align:left;width:3.522cm; " class="Table43_A4"><p class="P127">package name</p></td><td style="text-align:left;width:10.636cm; " class="Table43_B4"><p class="P114">Name of the target application’s package (sometimes called ID)</p></td><td style="text-align:left;width:2.732cm; " class="Table43_C4"><p class="P114">-n [Note 2]</p></td></tr><tr class="Table431"><td style="text-align:left;width:3.522cm; " class="Table43_A5"><p class="P127">component name</p></td><td style="text-align:left;width:10.636cm; " class="Table43_B5"><p class="P114">Name of a component within the target application</p></td><td style="text-align:left;width:2.732cm; " class="Table43_C5"><p class="P114">-n [Note 2]</p></td></tr><tr class="Table431"><td style="text-align:left;width:3.522cm; " class="Table43_A6"><p class="P127">MIME type</p></td><td style="text-align:left;width:10.636cm; " class="Table43_B6"><p class="P114">MIME-type of the data, may be used without a data URI</p></td><td style="text-align:left;width:2.732cm; " class="Table43_C6"><p class="P114">-t</p></td></tr><tr class="Table431"><td style="text-align:left;width:3.522cm; " class="Table43_A7"><p class="P127">categories</p></td><td style="text-align:left;width:10.636cm; " class="Table43_B7"><p class="P114">Comma-separated list of Intent categories</p></td><td style="text-align:left;width:2.732cm; " class="Table43_C7"><p class="P114">-c [Note 3]</p></td></tr><tr class="Table431"><td style="text-align:left;width:3.522cm; " class="Table43_A8"><p class="P127">"extras" bundle ptr</p></td><td style="text-align:left;width:10.636cm; " class="Table43_B8"><p class="P114">Pointer to an existing bundle containing <span class="T7">"</span>extras<span class="T7">"</span> values</p></td><td style="text-align:left;width:2.732cm; " class="Table43_C8"><p class="P114">-e [Note 4]</p></td></tr><tr class="Table431"><td style="text-align:left;width:3.522cm; " class="Table43_A9"><p class="P127">flags</p></td><td style="text-align:left;width:10.636cm; " class="Table43_B9"><p class="P114">Sum of numeric values of one or more flags</p></td><td style="text-align:left;width:2.732cm; " class="Table43_C9"><p class="P114">-f</p></td></tr></table><p class="P154">Notes:</p><ol><li><p class="P75" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">1.</span>You must use string or numeric values, not Android-defined constants, for actions, types, categories, and flags. For example, you can use the string <span class="T7">"android.intent.action.MAIN"</span>, but you can not use the Android symbol <span class="T7">ACTION_MAIN</span>.<span class="odfLiEnd"/> </p></li><li><p class="P75" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">2.</span>If you specify a component name, you must also specify the package name, even though the package name is often part of the component name. For example, these are equivalent:<span class="odfLiEnd"/> </p></li></ol><p class="P12"><span class="T11">SYSTEM.WRITE "am -n com.android.calculator2.Calculator"</span></p><p class="P13"><span class="T11">APP.START , , "com.android.calculator2", "com.android.calculator2.Calculator"</span></p><p class="P86">Usually you can use this pattern:</p><p class="P12"><span class="T11">pkg$ = "com.android.calculator2" : comp$ = pkg$ + ".Calculator"</span></p><p class="P13"><span class="T11">APP.START , , pkg$, comp$</span></p><ol><li><p class="P79" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">3.</span>A categories parameter may contain several categories separated by commas, for example:<span class="odfLiEnd"/> </p></li></ol><p class="P14"><span class="T11">cats$ = "android.intent.category.BROWSABLE, android.intent.category.MONKEY"</span></p><p class="P13"><span class="T11">cats$ = cat1$ + "," + cat2$ + "," + cat3$</span></p><ol><li><p class="P54" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">4.</span>You must create and populate the "extras" bundle before passing its pointer to an <span class="T7">App</span> command. Presently only string extras and float extras are supported (the BASIC! data types).<span class="odfLiEnd"/> </p></li><li><p class="P54" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">5.</span>When your program uses an Intent to start another app, the second app can use another Intent to return results. BASIC! does not yet support this return path. Your program can retrieve data that another app leaves in a file or in the clipboard, but it cannot yet retrieve data from a return Intent.<span class="odfLiEnd"/> </p></li></ol><p class="Standard"> </p><h1 class="P17"><a id="a__Appendix_A___Command_List"><span/></a><a id="_Toc5236339"/><a id="AppendixA"/><a id="_GoBack"/>Appendix A – Command List</h1><p class="P161">! - Single Line Comment, 52</p><p class="P161">!! - Block Comment, 53</p><p class="P161"># - Format Line, 28</p><p class="P161">% - Middle of Line Comment, 53</p><p class="P161">? {&lt;exp&gt; {,|;}} ..., 97</p><p class="P161">ABS(&lt;nexp&gt;), 57</p><p class="P161">ACOS(&lt;nexp&gt;), 60</p><p class="P161">App.broadcast &lt;action_sexp&gt;, &lt;data_uri_sexp&gt;, &lt;package_sexp&gt;, &lt;component_sexp&gt;, &lt;mime_type_sexp&gt;, &lt;categories_sexp&gt;, &lt;extras_bptr_nexp&gt;, &lt;flags_nexp&gt;, 199</p><p class="P161">App.start &lt;action_sexp&gt;, &lt;data_uri_sexp&gt;, &lt;package_sexp&gt;, &lt;component_sexp&gt;, &lt;mime_type_sexp&gt;, &lt;categories_sexp&gt;, &lt;extras_bptr_nexp&gt;, &lt;flags_nexp&gt;, 199</p><p class="P161">Array.average &lt;Average_nvar&gt;, Array[{&lt;start&gt;,&lt;length&gt;}], 41</p><p class="P161">Array.copy SourceArray$[{&lt;start&gt;,&lt;length&gt;}], DestinationArray$[{{-}&lt;start_or_extras&gt;}], 41</p><p class="P161">Array.copy SourceArray[{&lt;start&gt;,&lt;length&gt;}], DestinationArray[{{-}&lt;start_or_extras&gt;}], 41</p><p class="P161">Array.delete Array[], Array$[] ..., 42</p><p class="P161">Array.dims Source[]{, {Dims[]}{, NumDims}}, 42</p><p class="P161">Array.fill Array$[{&lt;start&gt;,&lt;length&gt;}], &lt;sexp&gt;, 42</p><p class="P161">Array.fill Array[{&lt;start&gt;,&lt;length&gt;}], &lt;nexp&gt;, 42</p><p class="P161">Array.length n, Array$[{&lt;start&gt;,&lt;length&gt;}], 42</p><p class="P161">Array.length n, Array[{&lt;start&gt;,&lt;length&gt;}], 42</p><p class="P161">Array.load Array$[], &lt;sexp&gt;, ..., 42</p><p class="P161">Array.load Array[], &lt;nexp&gt;, ..., 42</p><p class="P161">Array.max &lt;max_nvar&gt; Array[{&lt;start&gt;,&lt;length&gt;}], 43</p><p class="P161">Array.min &lt;min_nvar&gt;, Array[{&lt;start&gt;,&lt;length&gt;}], 43</p><p class="P161">Array.reverse Array$[{&lt;start&gt;,&lt;length&gt;}], 43</p><p class="P161">Array.reverse Array[{&lt;start&gt;,&lt;length&gt;}], 43</p><p class="P161">Array.search Array$[{&lt;start&gt;,&lt;length&gt;}], &lt;value_sexp&gt;, &lt;result_nvar&gt;{,&lt;start_nexp&gt;}, 43</p><p class="P161">Array.search Array[{&lt;start&gt;,&lt;length&gt;}], &lt;value_nexp&gt;, &lt;result_nvar&gt;{,&lt;start_nexp&gt;}, 43</p><p class="P161">Array.shuffle Array[{&lt;start&gt;,&lt;length&gt;}], 43</p><p class="P161">Array.sort Array[{&lt;start&gt;,&lt;length&gt;}], 43</p><p class="P161">Array.std_dev &lt;sd_nvar&gt;, Array[{&lt;start&gt;,&lt;length&gt;}], 43</p><p class="P161">Array.sum &lt;sum_nvar&gt;, Array[{&lt;start&gt;,&lt;length&gt;}], 44</p><p class="P161">Array.variance &lt;v_nvar&gt;, Array[{&lt;start&gt;,&lt;length&gt;}], 44</p><p class="P161">ASCII(&lt;sexp&gt;{, &lt;index_nexp&gt;}), 62</p><p class="P161">ASIN(&lt;nexp&gt;), 60</p><p class="P161">ATAN(&lt;nexp&gt;), 60</p><p class="P161">ATAN2(&lt;nexp_y&gt;, &lt;nexp_x&gt;), 60</p><p class="P161">Audio.isdone &lt;lvar&gt;, 188</p><p class="P161">Audio.length &lt;length_nvar&gt;, &lt;aft_nexp&gt;, 188</p><p class="P161">Audio.load &lt;aft_nvar&gt;, &lt;filename_sexp&gt;, 186</p><p class="P161">Audio.loop, 187</p><p class="P161">Audio.pause, 187</p><p class="P161">Audio.play &lt;aft_nexp&gt;, 186</p><p class="P161">Audio.position.current &lt;nvar&gt;, 187</p><p class="P161">Audio.position.seek &lt;nexp&gt;, 188</p><p class="P161">Audio.record.start &lt;fn_svar&gt;, 188</p><p class="P161">Audio.record.stop, 188</p><p class="P161">Audio.release &lt;aft_nexp&gt;, 188</p><p class="P161">Audio.stop, 187</p><p class="P161">Audio.volume &lt;left_nexp&gt;, &lt;right_nexp&gt;, 187</p><p class="P161">Back.resume, 91</p><p class="P161">BACKGROUND(), 63</p><p class="P161">Background.resume, 145</p><p class="P161">BAND(&lt;nexp1&gt;, &lt;nexp2&gt;), 56</p><p class="P161">BIN$(&lt;nexp&gt;), 70</p><p class="P161">BIN(&lt;sexp&gt;), 61</p><p class="P161">BNOT(&lt;nexp&gt;, 57</p><p class="P161">BOR(&lt;nexp1&gt;, &lt;nexp2&gt;), 56</p><p class="P161">Browse &lt;url_sexp&gt;, 120</p><p class="P161">Bt.close, 128</p><p class="P161">Bt.connect {0|1}, 128</p><p class="P161">Bt.device.name &lt;svar&gt;, 130</p><p class="P161">Bt.disconnect, 128</p><p class="P161">Bt.onReadReady.resume, 129</p><p class="P161">Bt.open {0|1}, 127</p><p class="P161">Bt.read.bytes &lt;svar&gt;, 130</p><p class="P161">Bt.read.ready &lt;nvar&gt;, 129</p><p class="P161">Bt.reconnect, 128</p><p class="P161">Bt.set.UUID &lt;sexp&gt;, 130</p><p class="P161">Bt.status {{&lt;connect_var&gt;}{, &lt;name_svar&gt;}{, &lt;address_svar&gt;}}, 128</p><p class="P161">Bt.write {&lt;exp&gt; {,|;}} ..., 129</p><p class="P161">Bundle.clear &lt;pointer_nexp&gt;, 50</p><p class="P161">Bundle.contain &lt;pointer_nexp&gt;, &lt;key_sexp&gt; , &lt;contains_nvar&gt;, 50</p><p class="P161">Bundle.create &lt;pointer_nvar&gt;, 49</p><p class="P161">Bundle.get &lt;pointer_nexp&gt;, &lt;key_sexp&gt;, &lt;nvar&gt;|&lt;svar&gt;, 49</p><p class="P161">Bundle.keys &lt;bundle_ptr_nexp&gt;, &lt;list_ptr_nexp&gt;, 49</p><p class="P161">Bundle.put &lt;pointer_nexp&gt;, &lt;key_sexp&gt;, &lt;value_nexp&gt;|&lt;value_sexp&gt;, 49</p><p class="P161">Bundle.remove &lt;pointer_nexp&gt;, &lt;key_sexp&gt;, 50</p><p class="P161">Bundle.type &lt;pointer_nexp&gt;, &lt;key_sexp&gt;, &lt;type_svar&gt;, 50</p><p class="P161">BXOR(&lt;nexp1&gt;, &lt;nexp2&gt;), 57</p><p class="P161">Byte.close &lt;file_table_nexp&gt;, 112</p><p class="P161">Byte.copy &lt;file_table_nexp&gt;,&lt;output_file_sexp&gt;, 115</p><p class="P161">Byte.eof &lt;file_table_nexp&gt;, &lt;lvar&gt;, 114</p><p class="P161">Byte.open {r|w|a}, &lt;file_table_nvar&gt;, &lt;path_sexp&gt;, 112</p><p class="P161">Byte.position.get &lt;file_table_nexp&gt;, &lt;position_nexp&gt;, 115</p><p class="P161">Byte.position.mark {{&lt;file_table_nexp&gt;}{, &lt;marklimit_nexp&gt;}}, 115</p><p class="P161">Byte.position.set &lt;file_table_nexp&gt;, &lt;position_nexp&gt;, 115</p><p class="P161">Byte.read.buffer &lt;file_table_nexp&gt;, &lt;count_nexp&gt;, &lt;buffer_svar&gt;, 114</p><p class="P161">Byte.read.byte &lt;file_table_nexp&gt; {,&lt;nvar&gt;}..., 113</p><p class="P161">Byte.read.number &lt;file_table_nexp&gt; {,&lt;nvar&gt;...}, 113</p><p class="P161">Byte.truncate &lt;file_table_nexp&gt;,&lt;length_nexp&gt;, 115</p><p class="P161">Byte.write.buffer &lt;file_table_nexp&gt;, &lt;sexp&gt;, 114</p><p class="P161">Byte.write.byte &lt;file_table_nexp&gt; {{,&lt;nexp&gt;}...{,&lt;sexp&gt;}}, 113</p><p class="P161">Byte.write.number &lt;file_table_nexp&gt; {,&lt;nexp&gt;}..., 114</p><p class="P161">Call &lt;user_defined_function&gt;, 78</p><p class="P161">CBRT(&lt;nexp&gt;), 59</p><p class="P161">CEIL(&lt;nexp&gt;), 58</p><p class="P161">CHR$(&lt;nexp&gt;, ...), 65</p><p class="P161">Clipboard.get &lt;svar&gt;, 134</p><p class="P161">Clipboard.put &lt;sexp&gt;, 134</p><p class="P161">CLOCK(), 63</p><p class="P161">Cls, 98</p><p class="P161">Console.front, 98</p><p class="P161">Console.line.count &lt;count_nvar &gt;, 98</p><p class="P161">Console.line.text &lt;line_nexp&gt;, &lt;text_svar&gt;, 98</p><p class="P161">Console.line.touched &lt;line_nvar&gt; {, &lt;press_lvar&gt;}, 98</p><p class="P161">Console.save &lt;filename_sexp&gt;, 98</p><p class="P161">Console.title { &lt;title_sexp&gt;}, 98</p><p class="P161">ConsoleTouch.resume, 91</p><p class="P161">COS(&lt;nexp&gt;), 60</p><p class="P161">COSH(&lt;nexp&gt;), 60</p><p class="P161">D_U.break, 82</p><p class="P161">D_U.continue, 82</p><p class="P161">Debug.dump.array Array[], 94</p><p class="P161">Debug.dump.bundle &lt;bundlePtr_nexp&gt;, 94</p><p class="P161">Debug.dump.list &lt;listPtr_nexp&gt;, 94</p><p class="P161">Debug.dump.scalars, 93</p><p class="P161">Debug.dump.stack &lt;stackPtr_nexp&gt;, 94</p><p class="P161">Debug.echo.off, 93</p><p class="P161">Debug.echo.on, 93</p><p class="P161">Debug.off, 93</p><p class="P161">Debug.on, 93</p><p class="P161">Debug.print, 93</p><p class="P161">Debug.show, 95</p><p class="P161">Debug.show.array Array[], 94</p><p class="P161">Debug.show.bundle &lt;bundlePtr_nexp&gt;, 94</p><p class="P161">Debug.show.list &lt;listPtr_nexp&gt;, 94</p><p class="P161">Debug.show.program, 95</p><p class="P161">Debug.show.scalars, 94</p><p class="P161">Debug.show.stack &lt;stackPtr_nexp&gt;, 95</p><p class="P161">Debug.show.watch, 95</p><p class="P161">Debug.watch var, ..., 95</p><p class="P161">DECODE$(&lt;charset_sexp&gt;, &lt;buffer_sexp&gt;), 69</p><p class="P161">DECODE$(&lt;type_sexp&gt;, {&lt;qualifier_sexp&gt;}, &lt;source_sexp&gt;), 68</p><p class="P161">Decrypt &lt;pw_sexp&gt;, &lt;encrypted_svar&gt;, &lt;decrypted_svar&gt;, 135</p><p class="P161">Device &lt;nexp&gt;|&lt;nvar&gt;, 142</p><p class="P161">Device &lt;svar&gt;, 141</p><p class="P161">Device.Language &lt;svar&gt;, 142</p><p class="P161">Device.Locale &lt;svar&gt;, 142</p><p class="P161">Dialog.message {&lt;title_sexp&gt;}, {&lt;message_sexp&gt;}, &lt;sel_nvar&gt; {, &lt;button1_sexp&gt;{, &lt;button2_sexp&gt;{, &lt;button3_sexp&gt;}}}, 99</p><p class="P161">Dialog.select &lt;sel_nvar&gt;, &lt; Array$[]&gt;|&lt;list_nexp&gt;, {,&lt;title_sexp&gt;}, 100</p><p class="P161">Dim Array [n, n, ...], Array$[n, n, ...] ..., 41</p><p class="P161">Do / Until &lt;lexp&gt;, 82</p><p class="P161">Echo.off, 93</p><p class="P161">Echo.on, 93</p><p class="P161">Email.send &lt;recipient_sexp&gt;, &lt;subject_sexp&gt;, &lt;body_sexp&gt;, 130</p><p class="P161">ENCODE$(&lt;charset_sexp&gt;, &lt;source_sexp&gt;), 69</p><p class="P161">ENCODE$(&lt;type_sexp&gt;, {&lt;qualifier_sexp&gt;}, &lt;source_sexp&gt;), 67</p><p class="P161">Encrypt {&lt;pw_sexp&gt;}, &lt;source_sexp&gt;, &lt;encrypted_svar&gt;, 134</p><p class="P161">End{ &lt;msg_sexp&gt;}, 92</p><p class="P161">ENDS_WITH(&lt;sub_sexp&gt;, &lt;base_sexp&gt;), 63</p><p class="P161">Exit, 92</p><p class="P161">EXP(&lt;nexp&gt;), 59</p><p class="P161">F_N.break, 81</p><p class="P161">F_N.continue, 81</p><p class="P161">File.delete &lt;lvar&gt;, &lt;path_sexp&gt;, 107</p><p class="P161">File.dir &lt;path_sexp&gt;, Array$[] {, &lt;dirmark_sexp&gt;}, 107</p><p class="P161">File.exists &lt;lvar&gt;, &lt;path_sexp&gt;, 107</p><p class="P161">File.mkdir &lt;path_sexp&gt;, 107</p><p class="P161">File.rename &lt;old_path_sexp&gt;, &lt;new_path_sexp&gt;, 108</p><p class="P161">File.root &lt;svar&gt;, 108</p><p class="P161">File.size &lt;size_nvar&gt;, &lt;path_sexp&gt;, 108</p><p class="P161">File.type &lt;type_svar&gt;, &lt;path_sexp&gt;, 108</p><p class="P161">FLOOR(&lt;nexp&gt;), 58</p><p class="P161">Fn.def name|name$( {nvar}|{svar}|Array[]|Array$[], ... {nvar}|{svar}|Array[]|Array$[]), 77</p><p class="P161">Fn.end, 78</p><p class="P161">Fn.rtn &lt;sexp&gt;|&lt;nexp&gt;, 78</p><p class="P161">Font.clear, 96</p><p class="P161">Font.delete {&lt;font_ptr_nexp&gt;}, 96</p><p class="P161">Font.load &lt;font_ptr_nvar&gt;, &lt;filename_sexp&gt;, 96</p><p class="P161">For &lt;nvar&gt; = &lt;nexp&gt; To &lt;nexp&gt; {Step &lt;nexp&gt;} / Next, 80</p><p class="P161"><span class="T6">FORMAT$(</span>&lt;pattern_sexp&gt;<span class="T6">, </span>&lt;nexp&gt;<span class="T6">)</span>, 75</p><p class="P161">FORMAT_USING$(&lt;locale_sexp&gt;, &lt;format_sexp&gt; { , &lt;exp&gt;}...), 75</p><p class="P161">FRAC(&lt;nexp&gt;), 58</p><p class="P161">Ftp.cd &lt;new_directory_sexp&gt;, 126</p><p class="P161">Ftp.close, 125</p><p class="P161">Ftp.delete &lt;filename_sexp&gt;, 126</p><p class="P161">Ftp.dir &lt;list_nvar&gt;, 126</p><p class="P161">Ftp.get &lt;source_sexp&gt;, &lt;destination_sexp&gt;, 126</p><p class="P161">Ftp.mkdir &lt;directory_sexp&gt;, 127</p><p class="P161">Ftp.open &lt;url_sexp&gt;, &lt;port_nexp&gt;, &lt;user_sexp&gt;, &lt;pw_sexp&gt;, 125</p><p class="P161">Ftp.put &lt;source_sexp&gt;, &lt;destination_sexp&gt;, 125</p><p class="P161">Ftp.rename &lt;old_filename_sexp&gt;, &lt;new_filename_sexp&gt;, 126</p><p class="P161">Ftp.rmdir &lt;directory_sexp&gt;, 127</p><p class="P161">GETERROR$(), 64</p><p class="P161">GoSub &lt;index_nexp&gt;, &lt;label&gt;... / Return, 84</p><p class="P161">GoSub &lt;label&gt; / Return, 84</p><p class="P161">GoTo &lt;index_nexp&gt;, &lt;label&gt;..., 83</p><p class="P161">GoTo &lt;label&gt;, 83</p><p class="P161">Gps.accuracy &lt;nvar&gt;, 195</p><p class="P161">Gps.altitude &lt;nvar&gt;, 195</p><p class="P161">Gps.bearing &lt;nvar&gt;, 195</p><p class="P161">Gps.close, 191</p><p class="P161">Gps.latitude &lt;nvar&gt;, 195</p><p class="P161">Gps.location {{&lt;time_nvar&gt;}, {&lt;prov_svar&gt;}, {&lt;count_nvar}, {&lt;acc_nvar&gt;}, {&lt;lat_nvar&gt;}, {&lt;long_nvar&gt;}, {&lt;alt_nvar&gt;}, {&lt;bear_nvar&gt;}, {&lt;speed_nvar&gt;}}, 194</p><p class="P161">Gps.longitude &lt;nvar&gt;, 195</p><p class="P161">Gps.open {{&lt;status_nvar&gt;},{&lt;time_nexp&gt;},{&lt;distance_nexp&gt;}}, 191</p><p class="P161">Gps.provider &lt;svar&gt;, 194</p><p class="P161">Gps.satellites {{&lt;count_nvar&gt;}, {&lt;sat_list_nexp&gt;}}, 195</p><p class="P161">Gps.speed &lt;nvar&gt;, 195</p><p class="P161">Gps.status {{&lt;status_var&gt;}, {&lt;infix_nvar&gt;},{inview_nvar}, {&lt;sat_list_nexp&gt;}}, 191</p><p class="P161">Gps.time &lt;nvar&gt;, 194</p><p class="P161">Gr.arc &lt;obj_nvar&gt;, left, top, right, bottom, start_angle, sweep_angle, fill_mode, 164</p><p class="P161">Gr.bitmap.create &lt;bitmap_ptr_nvar&gt;, width, height, 175</p><p class="P161">Gr.bitmap.crop &lt;new_bitmap_ptr_nvar&gt;, &lt;source_bitmap_ptr_nexp&gt;, &lt;x_nexp&gt;, &lt;y_nexp&gt;, &lt;width_nexp&gt;, &lt;height_nexp&gt;, 176</p><p class="P161">Gr.bitmap.delete &lt;bitmap_ptr_nexp&gt;, 176</p><p class="P161">Gr.bitmap.draw &lt;object_ptr_nvar&gt;, &lt;bitmap_ptr_nexp&gt;, x , y, 176</p><p class="P161">Gr.bitmap.drawinto.end, 177</p><p class="P161">Gr.bitmap.drawinto.start &lt;bitmap_ptr_nexp&gt;, 177</p><p class="P161">Gr.bitmap.fill &lt;bitmap_ptr_nexp&gt;, &lt;x_nexp&gt;, &lt;y_nexp&gt;, 177</p><p class="P161">Gr.bitmap.load &lt;bitmap_ptr_nvar&gt;, &lt;file_name_sexp&gt;, 175</p><p class="P161">Gr.bitmap.save &lt;bitmap_ptr_nvar&gt;, &lt;filename_sexp&gt;{, &lt;quality_nexp&gt;}, 176</p><p class="P161">Gr.bitmap.scale &lt;new_bitmap_ptr_nvar&gt;, &lt;bitmap_ptr_nexp&gt;, width, height {, &lt;smoothing_lexp&gt; }, 175</p><p class="P161">Gr.bitmap.size &lt;bitmap_ptr_nexp&gt;, width, height, 175</p><p class="P161">Gr.bounded.touch touched, left, top, right, bottom, 168</p><p class="P161">Gr.bounded.touch2 touched, left, top, right, bottom, 168</p><p class="P161">Gr.brightness &lt;nexp&gt;, 162</p><p class="P161">Gr.camera.autoshoot &lt;bm_ptr_nvar&gt;{, &lt;flash_ mode_nexp&gt; {, focus_mode_nexp} }, 180</p><p class="P161">Gr.camera.manualShoot &lt;bm_ptr_nvar&gt;{, &lt;flash_ mode_nexp&gt; {, focus_mode_nexp} }, 181</p><p class="P161">Gr.camera.select 1|2, 179</p><p class="P161">Gr.camera.shoot &lt;bm_ptr_nvar&gt;, 180</p><p class="P161">Gr.circle &lt;obj_nvar&gt;, x, y, radius, 164</p><p class="P161">Gr.clip &lt;object__ptr_nexp&gt;, &lt;left_nexp&gt;,&lt;top_nexp&gt;, &lt;right_nexp&gt;, &lt;bottom_nexp&gt;{, &lt;RO_nexp&gt;}, 184</p><p class="P161">Gr.close, 162</p><p class="P161">Gr.cls, 162</p><p class="P161">Gr.color {{alpha}{, red}{, green}{, blue}{, style}{, paint}}, 158</p><p class="P161">Gr.front flag, 162</p><p class="P161">Gr.get.bmpixel &lt;bitmap_ptr_nvar&gt;, x, y, alpha, red, green, blue, 177</p><p class="P161">Gr.get.params &lt;object_ptr_nexp&gt;, &lt;param_array$[]&gt;, 182</p><p class="P161">Gr.get.pixel x, y, alpha, red, green, blue, 181</p><p class="P161">Gr.get.position &lt;object_ptr_nexp&gt;, x, y, 182</p><p class="P161">Gr.get.textbounds &lt;exp&gt;, left, top, right, bottom, 173</p><p class="P161">Gr.get.type &lt;object_ptr_nexp&gt;, &lt;type_svar&gt;, 181</p><p class="P161">Gr.get.value &lt;object_ptr_nexp&gt; {, &lt;tag_sexp&gt;, &lt;value_nvar | value_svar&gt;}..., 182</p><p class="P161">Gr.getDL &lt;dl_array[]&gt; {, &lt;keep_all_objects_lexp&gt; }, 185</p><p class="P161">Gr.group &lt;object_number_nvar&gt;{, &lt;obj_nexp&gt;}..., 166</p><p class="P161">Gr.group.getDL &lt;object_number_nvar&gt;, 167</p><p class="P161">Gr.group.list &lt;object_number_nvar&gt;, &lt;list_ptr_nexp&gt;, 166</p><p class="P161">Gr.group.newDL &lt;object_number_nvar&gt;, 167</p><p class="P161">Gr.hide &lt;object_number_nexp&gt;, 167</p><p class="P161">Gr.line &lt;obj_nvar&gt;, x1, y1, x2, y2, 163</p><p class="P161">Gr.modify &lt;object_ptr_nexp&gt; {, &lt;tag_sexp&gt;, &lt;value_nexp | value_sexp&gt;}..., 182</p><p class="P161">Gr.move &lt;object_ptr_nexp&gt;{{, dx}{, dy}}, 182</p><p class="P161">Gr.newDL &lt;dl_array[{&lt;start&gt;,&lt;length&gt;}]&gt;, 185</p><p class="P161">Gr.onGrTouch.resume, 169</p><p class="P161">Gr.open {{alpha}{, red}{, green}{, blue}{, &lt;ShowStatusBar_lexp&gt;}{, &lt;Orientation_nexp&gt;}}, 158</p><p class="P161">Gr.orientation &lt;nexp&gt;, 160</p><p class="P161">Gr.oval &lt;obj_nvar&gt;, left, top, right, bottom, 163</p><p class="P161">Gr.paint.copy {{&lt;src_nexp&gt;}{, &lt;dst_nexp&gt;}}, 177</p><p class="P161">Gr.paint.get &lt;object_ptr_nvar&gt;, 178</p><p class="P161">Gr.paint.reset {&lt;nexp&gt;}, 178</p><p class="P161">Gr.point &lt;obj_nvar&gt;, x, y, 163</p><p class="P161">Gr.poly &lt;obj_nvar&gt;, list_pointer {,x,y}, 165</p><p class="P161">Gr.rect &lt;obj_nvar&gt;, left, top, right, bottom, 163</p><p class="P161">Gr.render, 161</p><p class="P161">Gr.rotate.end {&lt;obj_nvar&gt;}, 179</p><p class="P161">Gr.rotate.start angle, x, y{,&lt;obj_nvar&gt;}, 178</p><p class="P161">Gr.save &lt;filename_sexp&gt; {,&lt;quality_nexp&gt;}, 181</p><p class="P161">Gr.scale x_factor, y_factor, 161</p><p class="P161">Gr.screen width, height{, density }, 161</p><p class="P161">Gr.screen.to_bitmap &lt;bm_ptr_nvar&gt;, 181</p><p class="P161">Gr.set.antialias {{&lt;lexp&gt;}{,&lt;paint_nexp&gt;}}, 160</p><p class="P161">Gr.set.pixels &lt;obj_nvar&gt;, pixels[{&lt;start&gt;,&lt;length&gt;}] {,x,y}, 164</p><p class="P161">Gr.set.stroke {{&lt;nexp&gt;}{,&lt;paint_nexp&gt;}}, 160</p><p class="P161">Gr.show &lt;object_number_nexp&gt;, 167</p><p class="P161">Gr.show.toggle &lt;object_number_nexp&gt;, 167</p><p class="P161">Gr.statusbar {&lt;height_nvar&gt;} {, showing_lvar}, 160</p><p class="P161">Gr.statusbar.show &lt;nexp&gt;, 161</p><p class="P161">Gr.text.align {{&lt;type_nexp&gt;}{,&lt;paint_nexp&gt;}}, 169</p><p class="P161">Gr.text.bold {{&lt;lexp&gt;}{,&lt;paint_nexp&gt;}}, 169</p><p class="P161">Gr.text.draw &lt;object_number_nvar&gt;, &lt;x_nexp&gt;, &lt;y_nexp&gt;, &lt;text_object_sexp&gt;, 174</p><p class="P161">Gr.text.height {&lt;height_nvar&gt;} {, &lt;up_nvar&gt;} {, &lt;down_nvar&gt;}, 172</p><p class="P161">Gr.text.setfont {{&lt;font_ptr_nexp&gt;|&lt;font_family_sexp&gt;} {, &lt;style_sexp&gt;} {,&lt;paint_nexp&gt;}}, 170</p><p class="P161">Gr.text.size {{&lt;size_nexp&gt;}{,&lt;paint_nexp&gt;}}, 170</p><p class="P161">Gr.text.skew {{&lt;skew_nexp&gt;}{,&lt;paint_nexp&gt;}}, 170</p><p class="P161">Gr.text.strike {{&lt;lexp&gt;}{,&lt;paint_nexp&gt;}}, 170</p><p class="P161">Gr.text.typeface {{&lt;nexp&gt;} {, &lt;style_nexp&gt;} {,&lt;paint_nexp&gt;}}, 171</p><p class="P161">Gr.text.underline {{&lt;lexp&gt;}{,&lt;paint_nexp&gt;}}, 170</p><p class="P161">Gr.text.width &lt;nvar&gt;, &lt;exp&gt;, 172</p><p class="P161">Gr.touch touched, x, y, 168</p><p class="P161">Gr.touch2 touched, x, y, 168</p><p class="P161">GR_COLLISION( &lt;object_1_nvar&gt;, &lt;object_2_nvar&gt;), 63</p><p class="P161">GrabFile &lt;result_svar&gt;, &lt;path_sexp&gt;{, &lt;unicode_flag_lexp&gt;}, 112</p><p class="P161">GrabURL &lt;result_svar&gt;, &lt;url_sexp&gt;{, &lt;timeout_nexp&gt;}, 111</p><p class="P161">Headset &lt;state_nvar&gt;, &lt;type_svar&gt;, &lt;mic_nvar&gt;, 147</p><p class="P161"><span class="T6">HEX$(&lt;nexp&gt;)</span>, 70</p><p class="P161">HEX(&lt;sexp&gt;), 61</p><p class="P161">Home, 145</p><p class="P161">Html.clear.cache, 120</p><p class="P161">Html.clear.history, 120</p><p class="P161">Html.close, 120</p><p class="P161">Html.get.datalink &lt;data_svar&gt;, 119</p><p class="P161">Html.go.back, 120</p><p class="P161">Html.go.forward, 120</p><p class="P161">Html.load.string &lt;html_sexp&gt;, 119</p><p class="P161">Html.load.url &lt;file_sexp&gt;, 118</p><p class="P161">Html.open {&lt;ShowStatusBar_lexp&gt; {, &lt;Orientation_nexp&gt;}}, 118</p><p class="P161">Html.orientation &lt;nexp&gt;, 118</p><p class="P161">Html.post &lt;url_sexp&gt;, &lt;list_nexp&gt;, 119</p><p class="P161">Http.post &lt;url_sexp&gt;, &lt;list_nexp&gt;, &lt;result_svar&gt;, 121</p><p class="P161">HYPOT(&lt;nexp_x&gt;, &lt;nexp_y), 60</p><p class="P161">If / Then / Else, 80</p><p class="P161">If / Then / Else / Elseif / Endif, 79</p><p class="P161">Include FilePath, 85</p><p class="P161">Inkey$ &lt;svar&gt;, 101</p><p class="P161">Input {&lt;prompt_sexp&gt;}, &lt;result_var&gt;{, {&lt;default_exp&gt;}{,&lt;canceled_nvar&gt;}}, 100</p><p class="P161"><span class="T6">INT$(&lt;nexp&gt;)</span>, 70</p><p class="P161">INT(&lt;nexp&gt;), 58</p><p class="P161"><span class="T6">IS_IN(&lt;sub</span>_sexp&gt;<span class="T6">, &lt;base</span>_sexp&gt;{, &lt;start_nexp&gt;}, 62</p><p class="P161">IS_NUMBER(&lt;sexp&gt;), 61</p><p class="P161">Join &lt;source_array$[]&gt;, &lt;result_svar&gt; {, &lt;separator_sexp&gt;{, &lt;wrapper_sexp}}, 136</p><p class="P161">Join.all &lt;source_array$[]&gt;, &lt;result_svar&gt; {, &lt;separator_sexp&gt;{, &lt;wrapper_sexp}}, 136</p><p class="P161">Kb.hide, 102</p><p class="P161">Kb.resume, 104</p><p class="P161">Kb.show, 103</p><p class="P161">Kb.showing &lt;lvar&gt;, 103</p><p class="P161">Kb.toggle, 103</p><p class="P161">Key.resume, 91</p><p class="P161"><span class="T6">LEFT$(&lt;sexp&gt;, </span>&lt;count_nexp&gt;<span class="T6">)</span>, 65</p><p class="P161">LEN(&lt;sexp&gt;), 61</p><p class="P161">Let, 55</p><p class="P161">List.add &lt;pointer_nexp&gt;{, &lt;exp&gt;}..., 46</p><p class="P161">List.add.array numeric_list_pointer, Array[{&lt;start&gt;,&lt;length&gt;}], 46</p><p class="P161">List.add.array string_list_pointer, Array$[{&lt;start&gt;,&lt;length&gt;}], 46</p><p class="P161">List.add.list &lt;destination_list_pointer_nexp&gt;, &lt;source_list_pointer_nexp&gt;, 46</p><p class="P161">List.clear &lt;pointer_nexp&gt;, 47</p><p class="P161">List.create N|S, &lt;pointer_nvar&gt;, 46</p><p class="P161">List.get &lt;pointer_nexp&gt;, &lt;index_nexp&gt;, &lt;var&gt;, 47</p><p class="P161">List.insert &lt;pointer_nexp&gt;, &lt;index_nexp&gt;, &lt;sexp&gt;|&lt;nexp&gt;, 47</p><p class="P161">List.remove &lt;pointer_nexp&gt;,&lt;index_nexp&gt;, 47</p><p class="P161">List.replace &lt;pointer_nexp&gt;, &lt;index_nexp&gt;, &lt;sexp&gt;|&lt;nexp&gt;, 47</p><p class="P161">List.search &lt;pointer_nexp&gt;, value|value$, &lt;result_nvar&gt;{,&lt;start_nexp&gt;}, 47</p><p class="P161">List.size &lt;pointer_nexp&gt;, &lt;nvar&gt;, 47</p><p class="P161">List.toArray &lt;pointer_nexp&gt;, Array$[] | Array[], 48</p><p class="P161">List.type &lt;pointer_nexp&gt;, &lt;svar&gt;, 47</p><p class="P161">LOG(&lt;nexp&gt;), 59</p><p class="P161">LOG10(&lt;nexp&gt;), 59</p><p class="P161"><span class="T6">LOWER$(</span>&lt;sexp&gt;<span class="T6">)</span>, 70</p><p class="P161">LowMemory.resume, 92</p><p class="P161">MAX(&lt;nexp&gt;, &lt;nexp&gt;), 58</p><p class="P161">MenuKey.resume, 91</p><p class="P161"><span class="T6">MID$(&lt;sexp&gt;, </span>&lt;start_nexp&gt;{, &lt;count_nexp&gt;}<span class="T6">)</span>, 65</p><p class="P161">MIN(&lt;nexp&gt;, &lt;nexp&gt;), 58</p><p class="P161">mkdir &lt;path_sexp&gt;, 107</p><p class="P161">MOD(&lt;nexp1&gt;, &lt;nexp2&gt;), 58</p><p class="P161">MyPhoneNumber &lt;svar&gt;, 130</p><p class="P161">Notify &lt;title_sexp&gt;, &lt;subtitle_sexp&gt;, &lt;alert_sexp&gt;, &lt;wait_lexp&gt;, 147</p><p class="P161">OCT$(&lt;nexp&gt;), 70</p><p class="P161">OCT(&lt;sexp&gt;), 61</p><p class="P161">OnBackground:, 145</p><p class="P161">OnBackKey:, 91</p><p class="P161">OnBtReadReady:, 129</p><p class="P161">OnConsoleTouch:, 90</p><p class="P161">OnError:, 90</p><p class="P161">OnGrTouch:, 169</p><p class="P161">OnKbChange:, 103</p><p class="P161">OnKeyPress:, 91</p><p class="P161">OnLowMemory:, 91</p><p class="P161">OnMenuKey:, 91</p><p class="P161">OnTimer:, 134</p><p class="P161">Pause &lt;ticks_nexp&gt;, 148</p><p class="P161">Phone.call &lt;sexp&gt;, 130</p><p class="P161">Phone.dial &lt;sexp&gt;, 131</p><p class="P161">Phone.info &lt;nexp&gt;|&lt;nvar&gt;, 142</p><p class="P161">Phone.rcv.init, 131</p><p class="P161">Phone.rcv.next &lt;state_nvar&gt;, &lt;number_svar&gt;, 131</p><p class="P161">PI(), 60</p><p class="P161">Popup &lt;message_sexp&gt;{{, &lt;x_nexp&gt;}{, &lt;y_nexp&gt;}{, &lt;duration_lexp&gt;}}, 101</p><p class="P161">POW(&lt;nexp1&gt;, &lt;nexp2&gt;), 59</p><p class="P161">Print {&lt;exp&gt; {,|;}} ..., 97</p><p class="P161">Program.info &lt;nexp&gt;|&lt;nvar&gt;, 86</p><p class="P161">RANDOMIZE({&lt;nexp&gt;}), 57</p><p class="P161">Read.data &lt;number&gt;|&lt;string&gt; {,&lt;number&gt;|&lt;string&gt;...,&lt;number&gt;|&lt;string&gt;}, 92</p><p class="P161">Read.from &lt;nexp&gt;, 92</p><p class="P161">Read.next &lt;var&gt;, ..., 92</p><p class="P161">Rem, 52</p><p class="P161"><span class="T6">REPLACE$( &lt;sexp&gt;, &lt;argument_sexp&gt;, &lt;replace_sexp&gt;)</span>, 66</p><p class="P161"><span class="T6">RIGHT$(</span>&lt;sexp&gt;, &lt;count_nexp&gt;<span class="T6">)</span>, 65</p><p class="P161">Ringer.get.mode &lt;nvar&gt;, 135</p><p class="P161">Ringer.get.volume &lt;vol_nvar&gt; { , &lt;max_nvar&gt;, 136</p><p class="P161">Ringer.set.mode &lt;nexp&gt;, 135</p><p class="P161">Ringer.set.volume &lt;nexp&gt;, 136</p><p class="P161">RND(), 57</p><p class="P161">ROUND(&lt;value_nexp&gt;{, &lt;count_nexp&gt;{, &lt;mode_sexp&gt;}}), 58</p><p class="P161">Run &lt;filename_sexp&gt;{, &lt;data_sexp&gt;}, 85</p><p class="P161">Screen rotation, size[], realsize[], density, 143</p><p class="P161">Screen.rotation &lt;nvar&gt;, 144</p><p class="P161">Screen.size size[], realsize[], density, 144</p><p class="P161">Select &lt;sel_nvar&gt;, &lt; Array$[]&gt;|&lt;list_nexp&gt;, {,&lt;title_sexp&gt; {, &lt;message_sexp&gt; } } {,&lt;press_lvar&gt; }, 101</p><p class="P161">Sensors.close, 197</p><p class="P161">Sensors.list &lt;sensor_array$[]&gt;, 196</p><p class="P161">Sensors.open &lt;type_nexp&gt;{:&lt;delay_nexp&gt;}{, &lt;type_nexp&gt;{:&lt;delay_nexp&gt;}, ...}, 196</p><p class="P161">Sensors.read sensor_type, p1, p2, p3, 197</p><p class="P161">SGN(&lt;nexp&gt;), 57</p><p class="P161">SHIFT(&lt;value_nexp&gt;, &lt;bits_nexp&gt;), 62</p><p class="P161">SIN(&lt;nexp&gt;), 60</p><p class="P161">SINH(&lt;nexp&gt;), 60</p><p class="P161">Sms.rcv.init, 131</p><p class="P161">Sms.rcv.next &lt;svar&gt;, 132</p><p class="P161">Sms.send &lt;number_sexp&gt;, &lt;message_sexp&gt;, 131</p><p class="P161">Socket.client.close, 123</p><p class="P161">Socket.client.connect &lt;server_sexp&gt;, &lt;port_nexp&gt; { , &lt;wait_lexp&gt; }, 122</p><p class="P161">Socket.client.read.file &lt;file_nexp&gt;, 122</p><p class="P161">Socket.client.read.line &lt;line_svar&gt;, 122</p><p class="P161">Socket.client.read.ready &lt;nvar&gt;, 122</p><p class="P161">Socket.client.server.ip &lt;svar&gt;, 122</p><p class="P161">Socket.client.status &lt;status_nvar&gt;, 122</p><p class="P161">Socket.client.write.bytes &lt;sexp&gt;, 123</p><p class="P161">Socket.client.write.file &lt;file_nexp&gt;, 123</p><p class="P161">Socket.client.write.line &lt;line_sexp&gt;, 123</p><p class="P161">Socket.myIP &lt;array$[]&gt;{, &lt;nvar&gt;}, 123</p><p class="P161">Socket.myIP &lt;svar&gt;, 123</p><p class="P161">Socket.server.client.ip &lt;nvar&gt;, 125</p><p class="P161">Socket.server.close, 125</p><p class="P161">Socket.server.connect {&lt;wait_lexp&gt;}, 124</p><p class="P161">Socket.server.create &lt;port_nexp&gt;, 124</p><p class="P161">Socket.server.disconnect, 125</p><p class="P161">Socket.server.read.file &lt;file_nexp&gt;, 125</p><p class="P161">Socket.server.read.line &lt;svar&gt;, 124</p><p class="P161">Socket.server.read.ready &lt;nvar&gt;, 124</p><p class="P161">Socket.server.status &lt;status_nvar&gt;, 124</p><p class="P161">Socket.server.write.bytes &lt;sexp&gt;, 124</p><p class="P161">Socket.server.write.file &lt;file_nexp&gt;, 125</p><p class="P161">Socket.server.write.line &lt;line_sexp&gt;, 124</p><p class="P161">Soundpool.load &lt;soundID_nvar&gt;, &lt;file_path_sexp&gt;, 189</p><p class="P161">Soundpool.open &lt;MaxStreams_nexp&gt;, 189</p><p class="P161">Soundpool.pause &lt;streamID_nexp&gt;, 190</p><p class="P161">Soundpool.play &lt;streamID_nvar&gt;, &lt;soundID_nexp&gt;, &lt;rightVolume_nexp&gt;, &lt;leftVolume_nexp&gt;, &lt;priority_nexp&gt;, &lt;loop_nexp&gt;, &lt;rate_nexp&gt;, 189</p><p class="P161">Soundpool.release, 190</p><p class="P161">Soundpool.resume &lt;streamID_nexp&gt;, 190</p><p class="P161">Soundpool.setpriority &lt;streamID_nexp&gt;, &lt;priority_nexp&gt;, 190</p><p class="P161">Soundpool.setrate &lt;streamID_nexp&gt;, &lt;rate_nexp&gt;, 190</p><p class="P161">Soundpool.setvolume &lt;streamID_nexp&gt;, &lt;leftVolume_nexp&gt;, &lt;rightVolume_nexp&gt;, 190</p><p class="P161">Soundpool.stop &lt;streamID_nexp&gt;, 190</p><p class="P161">Soundpool.unload &lt;soundID_nexp&gt;, 189</p><p class="P161">Split &lt;result_array$[]&gt;, &lt;sexp&gt; {, &lt;test_sexp&gt;}, 137</p><p class="P161">Split.all &lt;result_array$[]&gt;, &lt;sexp&gt; {, &lt;test_sexp&gt;}, 137</p><p class="P161">Sql.close &lt;DB_pointer_nvar&gt;, 150</p><p class="P161">Sql.delete &lt;DB_pointer_nvar&gt;, &lt;table_name_sexp&gt;{,&lt;where_sexp&gt;{,&lt;count_nvar&gt;} }, 153</p><p class="P161">Sql.drop_table &lt;DB_pointer_nvar&gt;, &lt;table_name_sexp&gt;, 151</p><p class="P161">Sql.exec &lt;DB_pointer_nvar&gt;, &lt;command_sexp&gt;, 153</p><p class="P161">Sql.insert &lt;DB_pointer_nvar&gt;, &lt;table_name_sexp&gt;, C1$, V1$, C2$, V2$, ...,CN$, VN$, 151</p><p class="P161">Sql.new_table &lt;DB_pointer_nvar&gt;, &lt;table_name_sexp&gt;, C1$, C2$, ...,CN$, 150</p><p class="P161">Sql.next doneFlag, cursorVar {{, svar}...{, array$[]{, nColVar}}}, 152</p><p class="P161">Sql.open &lt;DB_pointer_nvar&gt;, &lt;DB_name_sexp&gt;, 150</p><p class="P161">Sql.query &lt;cursor_nvar&gt;, &lt;DB_pointer_nvar&gt;, &lt;table_name_sexp&gt;, &lt;columns_sexp&gt; {, &lt;where_sexp&gt; {, &lt;order_sexp&gt;} }, 151</p><p class="P161">Sql.query.length &lt;length_nvar&gt;, &lt;cursor_nvar&gt;, 152</p><p class="P161">Sql.query.position &lt;position_nvar&gt;, &lt;cursor_nvar&gt;, 152</p><p class="P161">Sql.raw_query &lt;cursor_nvar&gt;, &lt;DB_pointer_nvar&gt;, &lt;query_sexp&gt;, 153</p><p class="P161">Sql.update &lt;DB_ptr_nvar&gt;, &lt;table_name_sexp&gt;, C1$, V1$, C2$, V2$,...,CN$, VN${: &lt;where_sexp&gt;}, 153</p><p class="P161">SQR(&lt;nexp&gt;), 59</p><p class="P161">Stack.clear &lt;ptr_nexp&gt;, 52</p><p class="P161">Stack.create N|S, &lt;ptr_nvar&gt;, 51</p><p class="P161">Stack.isEmpty &lt;ptr_nexp&gt;, &lt;nvar&gt;, 52</p><p class="P161">Stack.peek &lt;ptr_nexp&gt;, &lt;nvar&gt;|&lt;svar&gt;, 51</p><p class="P161">Stack.pop &lt;ptr_nexp&gt;, &lt;nvar&gt;|&lt;svar&gt;, 51</p><p class="P161">Stack.push &lt;ptr_nexp&gt;, &lt;nexp&gt;|&lt;sexp&gt;, 51</p><p class="P161">Stack.type &lt;ptr_nexp&gt;, &lt;svar&gt;, 52</p><p class="P161">STARTS_WITH(&lt;sub_sexp&gt;, &lt;base_sexp&gt;{, &lt;start_nexp&gt;}, 62</p><p class="P161"><span class="T6">STR$(</span>&lt;nexp&gt;<span class="T6">)</span>, 70</p><p class="P161">STT.listen, 139</p><p class="P161">STT.results &lt;string_list_ptr_nexp&gt;, 139</p><p class="P161">Su.close, 199</p><p class="P161">Su.open, 198</p><p class="P161">Su.read.line &lt;svar&gt;, 198</p><p class="P161">Su.read.ready &lt;nvar&gt;, 198</p><p class="P161">Su.write &lt;sexp&gt;, 198</p><p class="P161">Sw.begin &lt;exp&gt;, 88</p><p class="P161">Sw.break, 89</p><p class="P161">Sw.case &lt;exp &gt;, ..., 88</p><p class="P161">Sw.case &lt;op&gt;&lt;exp &gt;, 88</p><p class="P161">Sw.default, 89</p><p class="P161">Sw.end, 89</p><p class="P161">Swap &lt;nvar_a&gt;|&lt;svar_a&gt;, &lt;nvar_b&gt;|&lt;svar_b&gt;, 148</p><p class="P161">System.close, 198</p><p class="P161">System.open, 198</p><p class="P161">System.read.line &lt;svar&gt;, 198</p><p class="P161">System.read.ready &lt;nvar&gt;, 198</p><p class="P161">System.write &lt;sexp&gt;, 198</p><p class="P161">TAN(&lt;nexp&gt;), 60</p><p class="P161">Text.close &lt;file_table_nexp&gt;, 109</p><p class="P161">Text.eof &lt;file_table_nexp&gt;, &lt;lvar&gt;, 110</p><p class="P161"><span class="T6">Text.input &lt;svar&gt;{, { &lt;text_sexp&gt;} , &lt;title_sexp&gt; }</span>, 102</p><p class="P161">Text.open {r|w|a}, &lt;file_table_nvar&gt;, &lt;path_sexp&gt;, 109</p><p class="P161">Text.position.get &lt;file_table_nexp&gt;, &lt;position_nvar&gt;, 111</p><p class="P161">Text.position.mark {{&lt;file_table_nexp&gt;}{, &lt;marklimit_nexp&gt;}}, 111</p><p class="P161">Text.position.set &lt;file_table_nexp&gt;, &lt;position_nexp&gt;, 111</p><p class="P161">Text.readln &lt;file_table_nexp&gt; {,&lt;svar&gt;}..., 110</p><p class="P161">Text.writeln &lt;file_table_nexp&gt;, {&lt;exp&gt; {,|;}} ..., 110</p><p class="P161">TGet &lt;result_svar&gt;, &lt;prompt_sexp&gt; {, &lt;title_sexp&gt;}, 102</p><p class="P161">Time {&lt;time_nexp&gt;,} Year$, Month$, Day$, Hour$, Minute$, Second$, WeekDay, isDST, 132</p><p class="P161">TIME(), 63</p><p class="P161">TIME(&lt;year_exp&gt;, &lt;month_exp&gt;, &lt;day_exp&gt;, &lt;hour_exp&gt;, &lt;minute_exp&gt;, &lt;second_exp&gt;), 64</p><p class="P161">Timer.clear, 134</p><p class="P161">Timer.resume, 134</p><p class="P161">Timer.set &lt;interval_nexp&gt;, 134</p><p class="P161">TimeZone.get &lt;tz_svar&gt;, 133</p><p class="P161">TimeZone.list &lt;tz_list_pointer_nexp&gt;, 133</p><p class="P161">TimeZone.set { &lt;tz_sexp&gt; }, 133</p><p class="P161">TODEGREES(&lt;nexp&gt;), 60</p><p class="P161">Tone &lt;frequency_nexp&gt;, &lt;duration_nexp&gt;{, &lt;duration_chk_lexp}, 148</p><p class="P161">TORADIANS(&lt;nexp&gt;), 61</p><p class="P161">TRIM$(&lt;sexp&gt;{, &lt;test_sexp&gt;}), 66</p><p class="P161">TTS.init, 138</p><p class="P161">TTS.speak &lt;sexp&gt; {, &lt;wait_lexp&gt;}, 138</p><p class="P161">TTS.speak.toFile &lt;sexp&gt; {, &lt;path_sexp&gt;}, 138</p><p class="P161">TTS.stop, 138</p><p class="P161">UCODE(&lt;sexp&gt;{, &lt;index_nexp&gt;}), 62</p><p class="P161">UnDim Array[], Array$[], ..., 41</p><p class="P161"><span class="T6">UPPER$(</span>&lt;sexp&gt;<span class="T6">)</span>, 70</p><p class="P161">USING$({&lt;locale_sexp&gt;} , &lt;format_sexp&gt; { , &lt;exp&gt;}...), 70</p><p class="P161">VAL(&lt;sexp&gt;), 61</p><p class="P161"><span class="T6">VERSION$()</span>, 70</p><p class="P161">Vibrate &lt;pattern_array[{&lt;start&gt;,&lt;length&gt;}]&gt;,&lt;nexp&gt;, 149</p><p class="P161">VolKeys.off, 149</p><p class="P161">VolKeys.on, 149</p><p class="P161">W_R.break, 82</p><p class="P161">W_R.continue, 81</p><p class="P161">WakeLock &lt;code_nexp&gt;{, &lt;flags_nexp&gt;, 145</p><p class="P161">While &lt;lexp&gt; / Repeat, 81</p><p class="P161">WiFi.info {{&lt;SSID_svar&gt;}{, &lt;BSSID_svar&gt;}{, &lt;MAC_svar&gt;}{, &lt;IP_var&gt;}{, &lt;speed_nvar&gt;}}, 145</p><p class="P161">WifiLock &lt;code_nexp&gt;, 146</p><p class="P161"><span class="T6">WORD$(&lt;source_sexp&gt;, &lt;n_nexp&gt; {, &lt;test_sexp&gt;})</span>, 66</p><p class="P161">Zip.close, &lt;file_table_nexp&gt;, 117</p><p class="P161">Zip.count &lt;path_sexp&gt;, &lt;nvar}, 116</p><p class="P161">Zip.dir &lt;path_sexp&gt;, Array$[] {,&lt;dirmark_sexp&gt;}, 116</p><p class="P161">Zip.open {r|w|a}, &lt;file_table_nvar&gt;, &lt;path_sexp&gt;, 116</p><p class="P161">Zip.read &lt;file_table_nexp&gt; ,&lt;buffer_svar&gt;, &lt;file_name_sexp&gt;, 117</p><p class="Standard"> </p><h1 class="P17"><a id="a__Appendix_B___Sample_Programs"><span/></a><a id="_Toc5236340"/>Appendix B – Sample Programs</h1><p class="Standard">The programs are loaded into "&lt;pref base drive&gt;/rfo-basic/source/Sample_Programs" when a new release of BASIC! is installed. You can access them by selecting Menu-&gt;Load. Tap the "Sample_Programs" lines. The sample programs will be listed and can be loaded.</p><p class="Standard">If you load and save one of these programs, the program will be saved in "&lt;pref base drive&gt;/rfo-basic/source/" not in "&lt;pref base drive&gt;/rfo-basic/source/Sample_Programs"</p><p class="Standard">You can force BASIC! to re-load these programs by:</p><ul><li><p class="P76" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>Select Menu-&gt;Delete<span class="odfLiEnd"/> </p></li><li><p class="P76" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>Navigate to "rfo-basic/source/Sample_Programs/"<span class="odfLiEnd"/> </p></li><li><p class="P76" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>Delete the "f01_vxx.xx_read_me file"<span class="odfLiEnd"/> </p></li><li><p class="P76" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>Exit BASIC! using Menu-&gt;Exit or Menu-&gt;More-&gt;Exit<span class="odfLiEnd"/> </p></li><li><p class="P76" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>Re-enter BASIC!<span class="odfLiEnd"/> </p></li></ul><p class="P129"> </p><h1 class="P17"><a id="a__Appendix_C___Launcher_Shortcut_Tutorial"><span/></a><a id="_Toc5236341"/>Appendix C – Launcher Shortcut Tutorial</h1><h2 class="Heading_20_2"><a id="a__Introduction"><span/></a><a id="_Toc5236342"/>Introduction</h2><p class="Standard">This tutorial will "compile" a BASIC! program and create an "application" that resides on your Android device home page. This "application" will have its own Icon and Name. The official Android name for<br/>this type of "application" is "Shortcut." The BASIC! application must be installed for this to work.</p><p class="Standard">There is also an option to actually build a standalone application .apk file that does not require the BASIC! application to be installed. The process is more difficult but it will result in an application that can be offered on the Google Play Store. See Appendix D.</p><h2 class="Heading_20_2"><a id="a__How_to_Make_a_Shortcut_Application__older_versions_of_Android—prior_to_Android_4_0_"><span/></a><a id="_Toc5236343"/>How to Make a Shortcut Application (older versions of Android—prior to Android 4.0)</h2><p class="Standard">1. Start BASIC!<br/>2. Select Menu-&gt;Exit orMenu-&gt;More-&gt;Exit to Exit BASIC!<br/>3. Do a long press on the HOME screen.<br/>4. You should see something like the following:</p><!--Next 'div' was a 'text:p'.--><div class="Standard"><!--Next '
           span' is a draw:frame.
       --><span style="height:3.81cm;width:6.35cm; padding:0; " class="fr1" id="Picture_5"><img style="height:3.81cm;width:6.35cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><!--Next 'div' was a 'text:p'.--><div class="Standard"><!--Next '
           span' is a draw:frame.
       --><span style="height:3.757cm;width:6.262cm; padding:0; " class="fr1" id="Picture_4"><img style="height:3.757cm;width:6.262cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><!--Next 'div' was a 'text:p'.--><div class="P155"><br/>8. This screen will appear:<br/><br/><!--Next '
           span' is a draw:frame.
       --><span style="height:5.652cm;width:9.627cm; padding:0; " class="fr1" id="Picture_1"><img style="height:5.652cm;width:9.627cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><ul><li><p class="P77" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>The Program File Name is Sample_Programs/f13_animations.bas<span class="odfLiEnd"/> </p></li><li><p class="P77" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>The Icon File Name is cartman.png<span class="odfLiEnd"/> </p></li><li><p class="P77" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>The Shortcut Name is Cartman<span class="odfLiEnd"/> </p></li></ul><!--Next 'div' was a 'text:p'.--><div class="Standard"><br/>10. Tap OK.<br/><br/><!--Next '
           span' is a draw:frame.
       --><span style="height:5.63cm;width:9.386cm; padding:0; " class="fr1" id="Image1"><img style="height:5.63cm;width:9.386cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><h2 class="Heading_20_2"><a id="a__How_to_Make_a_Shortcut_Application__newer_versions_of_Android—Android_4_0_and_later_"><span/></a><a id="_Toc5236344"/>How to Make a Shortcut Application (newer versions of Android—Android 4.0 and later)</h2><p class="P109">1. Select the Apps Page.</p><p class="P109">2. At the top of the screen, tap Widgets.</p><p class="P109">3. Scroll horizontally until you see the BASIC! icon that says Launcher Shortcuts.</p><p class="P109">4. Touch and hold that entry. It will be moved to the Home page.</p><p class="Standard">5. Continue with step 8, above.</p><h2 class="Heading_20_2"><a id="a__What_you_need_to_know"><span/></a><a id="_Toc5236345"/>What you need to know</h2><ul><li><p class="P55" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>The icon image file must be located in the "&lt;pref base drive&gt;/rfo-basic/data/" directory.<span class="odfLiEnd"/> </p></li><li><p class="P55" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>The program that you are going to run must be in the "source" directory or one of its sub directories. In this example, the file was located in the Sample_Programs(d) subdirectory of the "source(d)" directory.<span class="odfLiEnd"/> </p></li><li><p class="P55" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>The icon should be a .png file. A Google search for "icon" will reveal thousands for free icons. Just copy your icon into "rfo-basic/data" on the SD card.<span class="odfLiEnd"/> </p></li><li><p class="P55" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>Be very careful to correctly spell the names of the program and icon files. BASIC! does not check to see if these files actually exist during the "compile" process. If you enter the name of an icon file that does not exist, your shortcut will have the generic Android icon. If the file name you specified does not exist, when you tap the Shortcut you will see an error message in the form of program file in the Editor.<span class="odfLiEnd"/> </p></li><li><p class="P55" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>The Shortcut name should be nine (9) characters or less. Android will not show more than nine characters.<span class="odfLiEnd"/> </p></li><li><p class="P55" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>You can create as many shortcuts as you home screen(s) can handle.<span class="odfLiEnd"/> </p></li><li><p class="P55" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>Tapping "Cancel" in the Launcher Shortcuts dialog will simply cancel the operation and return to the home screen.<span class="odfLiEnd"/> </p></li><li><p class="P55" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;"></span>If you plan to use a BASIC! Launcher Shortcut, you should always exit BASIC! using Exit-Menu or Menu-&gt;More-&gt;Exit. If a Launched program is running, tapping BACK once or twice will exit BASIC back to the Home Screen.<span class="odfLiEnd"/> </p></li></ul><p class="P92"> </p><h1 class="P17"><a id="a__Appendix_D___Building_a_Standalone_Application"><span/></a><a id="_Toc5236346"/>Appendix D – Building a Standalone Application</h1><table border="0" cellspacing="0" cellpadding="0" class="Table44"><colgroup><col width="738"/></colgroup><tr class="Table441"><td style="text-align:left;width:16.891cm; " class="Table44_A1"><p class="P130"><span class="T40">Note: BASIC! collaborator Nicolas Mougin, has created a suite of automated tools for generating standalone applications. These tools can be downloaded from this website:</span></p><p class="P130"><a href="http://rfo-basic.com" class="Internet_20_link"><span class="Internet_20_link"><span class="T40"/></span></a></p><p class="P98"><a href="http://rfo-basic.com" class="Internet_20_link"><span class="Internet_20_link"><span class="T40">http://rfo-basic.com</span></span></a></p><p class="P101">Using Mr. Mougin’s tools, you avoid having to do all of the following.</p><p class="P101">If you have any questions or problems with this tool you can contact Mr. Mougin and other users of the tool at the BASIC! forum in this thread:</p><p class="P96"><a href="http://rfobasic.freeforums.org/rfo-basic-app-builder-f20.html" class="Internet_20_link"><span class="Internet_20_link"><span class="T40">http://rfobasic.freeforums.org/rfo-basic-app-builder-f20.html</span></span></a></p><p class="P114"> </p></td></tr></table><p class="Standard"> </p><h2 class="Heading_20_2"><a id="a__Introduction"><span/></a><a id="_Toc5236347"/>Introduction</h2><p class="Standard">This document will demonstrate how to create a standalone application from a BASIC! program. The resulting application does not need to have BASIC! installed to run. It will have its own application name and application icon. It may be distributed in the Google Play Store or elsewhere. The process involves setting up the Android development environment and making some simple, directed changes to the BASIC! Java source code. Since Google changes the Development Environment every so often, this procedure does not necessarily reflect the latest version of the ADT.</p><h2 class="Heading_20_2"><a id="a__License_Information"><span/></a><a id="_Toc5236348"/>License Information</h2><p class="Standard">BASIC! is distributed under the terms of the <a href="http://laughton.com/basic/license.html" class="Internet_20_link"><span class="Internet_20_link">GNU GENERAL PUBLIC LICENSE</span></a>. The license requires that the source code for "derivative works" be made available to anyone who asks. The author of BASIC! interprets this to mean that the license applies only to derivatives of the BASIC! <span class="T18">source interpreter code</span>. It does not apply to source code for BASIC! applications, i.e., code that you have written using the BASIC! language.</p><h2 class="Heading_20_2"><a id="a__Before_You_Start"><span/></a><a id="_Toc5236349"/>Before You Start</h2><p class="Standard">Run the sample program, <span class="T7">source/my_program.bas</span>.</p><p class="Standard">We are going to turn this program into a practice APK.</p><h2 class="Heading_20_2"><a id="a__Setting_Up_the_Development_Environment"><span/></a><a id="_Toc5236350"/>Setting Up the Development Environment</h2><p class="Standard">These instructions are based on using the Android Developer Tools (ADT) plug-in for the Eclipse Integrated Development Environment (IDE) to build an Android application.</p><p class="Standard">This is no longer the recommended toolset. Android Studio is now the official IDE for Android. For information about Android Studio, visit Android’s Developer Tools page at <a href="http://developer.android.com/sdk/index.html" class="Internet_20_link"><span class="Internet_20_link">http://developer.android.com/sdk/index.html</span></a>.</p><p class="Standard">These instructions will be updated for the new tools in a future version of this manual.</p><ol><li><p class="P56" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">1.</span>Download and install the latest version of the Java Development Kit (JDK). Find this by Googling "java jdk download" and going to the listed oracle.com download site. Do not download from any other site. Note: The JDK download includes the Java Run Time Environment (JRE) which is also needed.<span class="odfLiEnd"/> </p></li><li><p class="P56" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">2.</span>Download and install the "Eclipse IDE for Java Developers" from <a href="https://eclipse.org/downloads/" class="Internet_20_link"><span class="Internet_20_link">https://eclipse.org/downloads/</span></a>. The current version is 4.4.1 "Luna". You may prefer to download and install an older version from <a href="https://eclipse.org/kepler/" class="Internet_20_link"><span class="Internet_20_link">https://eclipse.org/kepler</span></a>/ or <a href="https://eclipse.org/juno/" class="Internet_20_link"><span class="Internet_20_link">https://eclipse.org/juno</span></a>/, because these instructions were written from "Juno".<span class="odfLiEnd"/> </p></li><li><p class="P56" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">3.</span>Visit Android’s "Installing the Eclipse Plugin" page at <a href="http://developer.android.com/sdk/installing/installing-adt.html" class="Internet_20_link"><span class="Internet_20_link">http://developer.android.com/sdk/installing/installing-adt.html</span></a>. From there you can download the Android Developer Tools (ADT) Plugin. Follow the installation instructions found there.<span class="odfLiEnd"/> </p></li></ol><p class="P156">The instructions below have been changed over time for different versions, most recently for Eclipse 4.2 (Juno) and ADT 22.2, and you may find differences in the version you have installed. Please visit the BASIC! users’ forum at <a href="http://rfobasic.freeforums.org" class="Internet_20_link"><span class="Internet_20_link">http://rfobasic.freeforums.org</span></a> to report any problems you find.</p><ol><li><p class="P69" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">4.</span>BASIC! supports most versions of Android, which can lead to spurious build errors. You may need to change API level checking from Error to Warning:<span class="odfLiEnd"/> </p><ol><li><p class="P78" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">a.</span>Select <span class="T7">Window-&gt;Preferences-&gt;Android-&gt;Lint Error Checking</span><span class="odfLiEnd"/> </p></li><li><p class="P78" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">b.</span>Find <span class="T7">NewApi</span> and click on it.<span class="odfLiEnd"/> </p></li><li><p class="P78" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">c.</span>In the dropdown list, change the Severity from Error to Warning.<span class="odfLiEnd"/> </p></li><li><p class="P78" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">d.</span>Click <span class="T7">Apply</span><span class="odfLiEnd"/> </p></li></ol></li></ol><h2 class="Heading_20_2"><a id="a__Download_the_BASIC!_Source_Code_from_the_GitHub_Repository"><span/></a><a id="_Toc5236351"/>Download the BASIC! Source Code from the GitHub Repository</h2><ol><li><p class="P57" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">1.</span>Go to: <a href="https://github.com/RFO-BASIC/Basic" class="Internet_20_link"><span class="Internet_20_link">https://github.com/RFO-BASIC/Basic</span></a>.<span class="odfLiEnd"/> </p></li><li><div class="P57" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">2.</span>Find the branch/tag selection button:<!--Next '
           span' is a draw:frame.
       --><span style="height:0.686cm;width:5.295cm; padding:0; " class="fr1" id="Image2"><img style="height:0.686cm;width:5.295cm;" alt="" src=""/></span><!--Next 'div' added for floating.--><div style="position:relative; left:-1.27cm;">Click the button and the "Tags" tab to select the tagged release version you want. If you do not select a tag, you will get the source for the latest development build. The latest development source is not guaranteed to be stable.</div>Click the button and the "Tags" tab to select the tagged release version you want. If you do not select a tag, you will get the source for the latest development build. The latest development source is not guaranteed to be stable.<span class="odfLiEnd"/> </div></li><li><div class="P57" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">3.</span>Click the "Download ZIP" button:<!--Next '
           span' is a draw:frame.
       --><span style="height:0.706cm;width:3.448cm; padding:0; " class="fr1" id="Image3"><img style="height:0.706cm;width:3.448cm;" alt="" src=""/></span><!--Next 'div' added for floating.--><div style="position:relative; left:-1.27cm;"> found on the right side of the page. The name of the downloaded ZIP file depends on which tag you selected in the previous step.</div> found on the right side of the page. The name of the downloaded ZIP file depends on which tag you selected in the previous step.<span class="odfLiEnd"/> </div></li><li><p class="P57" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">4.</span>Put the unzipped source files into a folder. For this exercise, name the folder "Cats". You should use a different folder for each new APK that you create.<span class="odfLiEnd"/> </p></li></ol><p class="P91"><span class="T63">– OR –</span></p><h2 class="Heading_20_2"><a id="a__Download_the_BASIC!_Source_Code_from_the_Legacy_Archive"><span/></a><a id="_Toc5236352"/>Download the BASIC! Source Code from the Legacy Archive</h2><ol><li><p class="P58" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">1.</span>Go to: <a href="http://laughton.com/basic/versions/index.html" class="Internet_20_link"><span class="Internet_20_link">http://laughton.com/basic/versions/index.html</span></a> and select the version number you want. For versions later than v01.77, you must download the source from GitHub.<span class="odfLiEnd"/> </p></li><li><p class="P58" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">2.</span>Look for the section heading, "<span class="T7">Download BASIC! Source Code.</span>" Click on the "<span class="T64">here</span>" to download "Basic.zip".<span class="odfLiEnd"/> </p></li><li><p class="P58" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">3.</span>Older versions of this file contain only the BASIC! source code. More recent versions also contain a copy of the Android-loadable Basic.apk file and a copy of this manual.<span class="odfLiEnd"/> </p></li><li><p class="P58" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">4.</span>Put the unzipped source files into a folder. For this exercise, name the folder "Cats". You should use a different folder for each new APK that you create.<span class="odfLiEnd"/> </p></li></ol><p class="P156">Note: In the remainder of this tutorial, we assume our application is about cats, thus we are using the name "Cats". For your own APK, you should choose a name that matches your application.</p><h2 class="Heading_20_2"><a id="a__Create_a_New_Project_in_Eclipse"><span/></a><a id="_Toc5236353"/>Create a New Project in Eclipse</h2><p class="Standard">Note: to simplify later steps, turn off the automatic build feature of Eclipse before creating the new project:</p><ol><li><p class="P59" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">1.</span>On the menu, click <span class="T7">Project</span>.<span class="odfLiEnd"/> </p></li><li><p class="P59" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">2.</span>Uncheck <span class="T7">Build Automatically</span>.<span class="odfLiEnd"/> </p></li></ol><p class="Standard">Now you can create the project.</p><ol><li><p class="P59" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">3.</span>Select: <span class="T7">File -&gt; New -&gt; Project…-&gt;Android-&gt;Android Project from Existing Code</span>.<span class="odfLiEnd"/> </p></li><li><p class="P59" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">4.</span>In the <span class="T7">Import Projects</span> dialog box, browse to the folder where you put the BASIC! source files.<span class="odfLiEnd"/> </p></li><li><p class="P59" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">5.</span>Under <span class="T7">Projects to Import</span>, click the project you are importing. Make sure it is checked.<span class="odfLiEnd"/> </p></li><li><p class="P59" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">6.</span>Under <span class="T7">New Project Name</span>, change the project name from "Basic" to "Cats". Click <span class="T7">Finish</span>.<span class="odfLiEnd"/> </p></li><li><p class="P59" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">7.</span>In the <span class="T7">Package Explorer</span> window on the left, right-click on <span class="T7">Cats</span> and select <span class="T7">Properties</span> (near the bottom of the list).<span class="odfLiEnd"/> </p></li><li><div class="P59" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">8.</span>In the Properties dialog box, select <span class="T7">Android</span>: <!--Next '
           span' is a draw:frame.
       --><span style="height:5.971cm;width:14.818cm; padding:0; " class="fr1" id="Picture_19"><img style="height:5.971cm;width:14.818cm;" alt="" src=""/></span><span class="odfLiEnd"/> </div></li><li><p class="P59" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">9.</span>Check the highest level of the Android OS available in this list. Do this without regard to the level of OS in your device(s). (Note for KitKat users: BASIC! is currently compiled with API 18. The build works with higher levels, but you may choose to limit the OS level to 4.3, API 18.)<span class="odfLiEnd"/> </p></li><li><p class="P70" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">10.</span>Click <span class="T7">Apply</span> then <span class="T7">OK</span>.<span class="odfLiEnd"/> </p></li></ol><p class="P149">The Basic source is now ready for making an APK.</p><h2 class="Heading_20_2"><a id="a__Rename_the_Package"><span/></a><a id="_Toc5236354"/>Rename the Package</h2><p class="Standard">The package name is what makes your application different from every other application that runs on Android devices. No matter what you name your application, it is the package name that Android uses to identify your particular application.</p><h3 class="Heading_20_3"><a id="a__In_Eclipse"><span/></a><a id="_Toc5236355"/>In Eclipse</h3><p class="P149">First, use the search-and-replace dialog to update references to the package name.</p><ol><li><p class="P60" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">1.</span>From the Menu Bar, select: <span class="T7">Search-&gt;File</span>.<span class="odfLiEnd"/> </p></li><li><div class="P60" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">2.</span>Fill in the dialog like this:<br/><span style="margin-left:0cm"/><!--Next '
           span' is a draw:frame.
       --><span style="height:8.133cm;width:9.657cm; padding:0; " class="fr1" id="Picture_11"><img style="height:8.133cm;width:9.657cm;" alt="" src=""/></span><span class="odfLiEnd"/> </div></li><li><p class="P60" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">3.</span>Click <span class="T7">Replace</span>. The Replace Text Matches Dialog Box opens.<span class="odfLiEnd"/> </p></li><li><p class="P60" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">4.</span>Enter "com.rfo.cats" in the <span class="T7">With:</span> field, and click <span class="T7">OK</span>.<span class="odfLiEnd"/> </p></li></ol><p class="Standard">Next, tell Eclipse about the package change.</p><ol><li><p class="P60" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">5.</span>In the <span class="T7">Package Explorer</span>, click and open the <span class="T7">Cats -&gt; src</span> hierarchy as shown below.<span class="odfLiEnd"/> </p></li><li><p class="P60" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">6.</span>Select the <span class="T7">com.rfo.basic</span> package.<span class="odfLiEnd"/> </p></li><li><p class="P60" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">7.</span>From the Menu Bar, select <span class="T7">File-&gt;Rename</span> to open the <span class="T7">Rename Package</span> dialog.<span class="odfLiEnd"/> </p></li><li><p class="P60" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">8.</span>In the <span class="T7">New name:</span> field, enter "com.rfo.cats".<span class="odfLiEnd"/> </p></li><li><div class="P60" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">9.</span>Make sure the <span class="T7">Update references</span> box is checked and click <span class="T7">OK</span>.<br/><span style="margin-left:0cm"/><!--Next '
           span' is a draw:frame.
       --><span style="height:5.943cm;width:11.718cm; padding:0; " class="fr1" id="Picture_7"><img style="height:5.943cm;width:11.718cm;" alt="" src=""/></span><span class="odfLiEnd"/> </div></li></ol><p class="Standard">Your project is ready to build. Restore the automatic build feature of Eclipse:</p><ol><li><p class="P71" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">10.</span>Click <span class="T7">Project-&gt;Build Automatically</span>. Make sure the checkmark appears.<span class="odfLiEnd"/> </p></li></ol><p class="Standard">The project should build without errors.</p><h3 class="Heading_20_3"><a id="a__Other_IDEs"><span/></a><a id="_Toc5236356"/>Other IDEs</h3><p class="Standard">Most changes in this Appendix are simply changes in source files, and so they apply to any IDE. Editing the package name is a more complex. Eclipse hides some of the complexity, but it also requires special actions when renaming the package so the IDE knows about the change. A different IDE, it may have its own requirements.</p><p class="Standard">This section will describe all of the changes necessary to rename the package. Your IDE may do them, or you may have to do them yourself with a text editor. Some editors can do global search-and-replace across an entire file tree, which can save you a lot of work.</p><ol><li><p class="P61" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">1.</span>The package name is also a path name. If all of your source files are in a directory called "<span class="T7">src</span>", and your package name is "<span class="T50">com.rfo.basic</span>", then your source files are really in a directory called <span class="T50">src/com/rfo/basic</span>. If you change the package, for example, to "<span class="T50">com.rfo.cats</span>", then you must also move all of the source files to the new directory, in this case <span class="T50">src/com/rfo/cats</span>.<span class="odfLiEnd"/> </p></li><li><p class="P61" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">2.</span>Everywhere it occurs, the string "<span class="T45">com.rfo.basic</span>" must be changed to your new package name.<span class="odfLiEnd"/> </p><ol><li><p class="P61" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">a.</span>The Android manifest file (<span class="T46">AndroidManifest.xml</span>) contains the line<br/><span style="margin-left:0cm"/><span class="T65">package</span><span class="T45">=</span><span class="T66">"com.rfo.basic"<br/></span>If you have a <span class="T50">bin</span> directory in your project, it may contain a copy of the manifest file. It was generated by the Eclipse build process. You may ignore it or delete it.<span class="odfLiEnd"/> </p></li><li><p class="P61" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">b.</span>Two layout files, <span class="T46">res/layout/editor.xml</span> and <span class="T46">res/layout/console.xml</span>, contain <span class="T65">class</span> attributes:<br/><span style="margin-left:0cm"/><span class="T65">class</span><span class="T45">=</span><span class="T66">"com.rfo.basic.Editor$LinedEditText"<br/></span><span class="T65">class</span><span class="T45">=</span><span class="T66">"com.rfo.basic.Run$ConsoleListView"</span><span class="odfLiEnd"/> </p></li><li><p class="P61" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">c.</span>Every <span class="T50">.java</span> file in the source directory (<span class="T46">*.java</span>) contains the line<br/><span style="margin-left:0cm"/><span class="T68">package</span><span class="T45"> com.rfo.basic;</span><span class="odfLiEnd"/> </p></li><li><p class="P61" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">d.</span>Several <span class="T50">.java</span> files (currently 7) files contain a line that starts like one of these:<br/><span style="margin-left:0cm"/><span class="T68">import </span><span class="T45">com.rfo.basic.<br/></span><span class="T68">import static</span><span class="T45"> com.rfo.basic.<br/></span>Some files have more than one such line.<span class="odfLiEnd"/> </p></li><li><p class="P61" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">e.</span>Two files, <span class="T46">Editor.java</span> and <span class="T46">LauncherShortcuts.java</span>, contain one of these strings:<br/><span style="margin-left:0cm"/><span class="T69">public static final String</span><span class="T47"> EXTRA_LS_FILENAME = "com.rfo.basic.fn";</span><span class="T67"><br/></span><span class="T69">public static final String</span><span class="T47"> EXTRA_LS_FILENAME = "com.rfo.basic.doRestart";<br/></span>You may safely ignore these, since they are not used in a standalone APK. However, it does not hurt to change these instances of <span class="T45">com.rfo.basic</span> along with all the others.<span class="odfLiEnd"/> </p></li></ol></li></ol><h3 class="Heading_20_3"><a id="a__Renaming_complete"><span/></a><a id="_Toc5236357"/>Renaming complete</h3><p class="Standard">At this point the package has been successfully renamed. Next we will create a practice APK that you then use to make your own APK.</p><h2 class="Heading_20_2"><a id="a__Modifications_to_setup_xml"><span/></a><a id="_Toc5236358"/>Modifications to setup.xml</h2><p class="Standard">You can customize your apk with settings in the resource file <span class="T7">setup.xml</span>. Some changes are required for any apk.</p><p class="Standard">In the <span class="T7">Package Explorer</span>, expand <span class="T7">Cats/res/values</span> and then double-click <span class="T7">setup.xml</span>. The file opens in the window on the right. There are tabs at the bottom of the window that let you change how the file is displayed. If the <span class="T7">Resources</span> tab is selected, you see a special Eclipse Resource Editor. This editor does not know how to modify all of the properties in this file. Click on the <span class="T7">setup.xml</span> tab to display the actual XML text, as shown in the image below. In this view, you can also see the comments describing the values you can change for your application.</p><p class="Standard">Be sure you change only values, not names. Names are shown as blue text in quotes. Values are shown as black text with no quotation marks. If you change a name, Java can not find the item to get its value.</p><p class="Standard">Change the value of <span class="T7">"app_name"</span> from <span class="T7">BASIC!</span> to <span class="T7">Cats!</span>. This is the name of the application as it will appear on your Android device.</p><p class="Standard">Change the value of <span class="T7">"app_path"</span> to <span class="T7">rfo-cats</span>. This will be the directory on the SD card where your files are stored, if you choose to have a directory for files for your application. Make this change even if you do not choose to create directories for your application. It has implications in other parts of the code.</p><p class="Standard">Change the value of <span class="T7">"is_apk"</span> to <span class="T7">true</span>.</p><p class="Standard">The items <span class="T7">"apk_create_data_dir"</span> and <span class="T7">"apk_create_database_dir"</span> are flags that control whether directories are created under <span class="T7">"app_path"</span> for your application’s files. Since this practice application does not need any directories, change the values of both to <span class="T7">false</span>.</p><p class="Standard">The item <span class="T7">"load_file_names"</span> is a list of files that you want loaded to the SD card. This practice application uses the sound clip <span class="T7">meow.wav</span>. Running under standard BASIC!, the program would use the file <span class="T7">rfo-basic/data/meow.wav</span>. As a standalone application, it can use a file image built into APK. Since the practice application is not using a real file, you can leave the <span class="T7">"load_file_names"</span> list empty.</p><!--Next 'div' was a 'text:p'.--><div class="Standard"><!--Next '
           span' is a draw:frame.
       --><span style="height:8.819cm;width:14.686cm; padding:0; " class="fr1" id="Picture_38"><img style="height:8.819cm;width:14.686cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><p class="Standard">Save the changes to setup.xml.</p><!--Next 'div' was a 'text:p'.--><div class="Standard">Note: If you do want to load files to the SD card, you must allow the creation of the data directory (set "<span class="T7">apk_create_data_dir</span>" to <span class="T7">true</span>) and put the file names in the "<span class="T7">load_file_names</span>" list like this: <!--Next '
           span' is a draw:frame.
       --><span style="height:2.743cm;width:12.305cm; padding:0; " class="fr1" id="Picture_26"><img style="height:2.743cm;width:12.305cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><p class="Standard">At this point, you have modified the source files of the BASIC! interpreter so it can be packaged into a standalone application. You can build and run it, if you like, but it will display a blank Console. That’s result you get when you build BASIC! into an application but you don’t give it a program to run.</p><h2 class="Heading_20_2"><a id="a__Advanced_Customization_with_setup_xml"><span/></a><a id="_Toc5236359"/>Advanced Customization with setup.xml</h2><p class="Standard">The <span class="T7">setup.xml</span> file allows more customization than the minimum required for <span class="T7">Cats</span>.</p><p class="Standard">The VERSION$() function gets its value from the item named <span class="T7">"version"</span>. If your application uses VERSION$(), this is where you set the value you want it to return.</p><p class="Standard">The item <span class="T7">"my_program"</span> is the name of the BASIC! program you want your application to run. This will be explained in the next section.</p><p class="Standard">If the <span class="T7">.bas</span> program files in the <span class="T7">source</span> subdirectory of your <span class="T7">assets</span> are encrypted, you must set the item <span class="T7">"apk_programs_encrypted"</span> to <span class="T7">true</span>. This tells BASIC! that it must decrypt programs as it loads them.</p><p class="Standard">The item <span class="T7">"run_name"</span> is the default title of the Console. Your program can set the Console title, but you may want to change the default title here. Similarly, <span class="T7">"select_name"</span> and <span class="T7">"textinput_name"</span> set the names of the screens for the <span class="T7">Select</span>, <span class="T7">Text.Input</span>, and <span class="T7">TGet</span> commands.</p><p class="Standard">If your app uses Console output, you can set the text colors here. The mapping of <span class="T7">"color1"</span>, <span class="T7">"color2"</span>, and <span class="T7">"color3"</span> to text foreground, background, and underline depend on your <span class="T7">Screen Colors</span> setting under <span class="T7">Preferences</span>.</p><p class="Standard">As mentioned earlier, the <span class="T7">"load_file_names"</span> is a list of files that you want loaded to the SD card. Any files listed here will be copied from the <span class="T7">assets</span> directory to the SD card every time your app starts. This may be the internal Android file system or a file system mounted on an external SD card. After that, your app will access the files from the SD card file system, not from <span class="T7">assets</span>. Any changes your program makes to these files will be overwritten the next time the app starts. To preserve changes, your program must copy or rename the file. The copied/renamed file will not be overwritten when your program runs again.</p><p class="Standard">Several items in <span class="T7">setup.xml</span> control the splash screen and file-load progress indicator. If you don’t change anything, your <span class="T7">Cats</span> app will display the default BASIC! splash screen briefly. You may not see it because the apk does not load any files.</p><p class="Standard">You can turn off the splash screen by setting <span class="T7">"splash_display"</span> to <span class="T7">false</span>.</p><p class="Standard">The splash screen image is the resource file <span class="T7">res/drawable/splash.png</span>. To customize the splash screen, replace this file in your project with an image of your own. Your image file must be named <span class="T7">splash.jpg</span>.</p><p class="Standard">If you do not use a splash screen, you may remove this file from your project to make your apk a little smaller. Do not remove the file <span class="T7">res/drawable/blank.jpg</span>.</p><p class="Standard">You can also customize the file-load progress indicator. Progress is shown in a pop-up over the splash screen. The title comes from the string <span class="T7">"loading_msg"</span>. Each increment of progress is a copy of the string <span class="T7">"progress_marker "</span>. The default string is a single period (<span class="T7">.</span>).</p><p class="Standard">You can turn off the progress indicator by making the <span class="T7">"loading_msg"</span> an empty string.</p><p class="Standard">The <span class="T7">setup.xml</span> file is intended to collect the fields you are most likely to want to change all in one place. There are many other strings and values that can be set to customize your app. Another file with fields you may find interesting is <span class="T7">strings.xml</span>, where default values of many strings are set. For example, you can change the default title string for the Speech-to-Text dialog by editing the string named <span class="T7">sst_prompt</span>.</p><p class="Standard">Later, we will describe how to change the default values of Preference options in the file <span class="T7">settings.xml</span>.</p><h2 class="Heading_20_2"><a id="a__Files_and_Resources"><span/></a><a id="_Toc5236360"/>Files and Resources</h2><p class="Standard">Standard BASIC! loads its sample programs and the data files they need from the <span class="T7">assets</span> folder of the Eclipse project. Android treats the <span class="T7">assets</span> folder like a file system. At startup, BASIC! simply copies the entire <span class="T7">assets/rfo-basic</span> folder to the SD card.</p><p class="Standard">Your application can use the <span class="T7">assets</span> folder, too. Most of the BASIC! file-handling commands look in the SD card file system first. If the file does not exist on the SD card, your program compiled into an APK looks in your projects’s <span class="T7">res</span> folder, and finally in <span class="T7">assets</span>. Resources may be built into the APK in either the <span class="T7">res</span> or <span class="T7">assets</span> folder, but <span class="T7">res</span> is not treated as a file system and has more restrictive naming rules. For example, the name of a resource in <span class="T7">res</span> must not contain spaces or hyphens.</p><p class="Standard">Both <span class="T7">Byte.open</span> and <span class="T7">Text.open</span> are able to open resources in your APK. However, <span class="T7">Zip.open</span> cannot open resources; it looks only in the SD card file system. If you want to read a ZIP that is in <span class="T7">assets</span>, you must first copy it from <span class="T7">assets</span> to the SD card. Then you can open the SD card file with <span class="T7">Zip.Open</span>.</p><p class="Standard"><span class="T7">File.Exists</span> looks only for files on the SD card, but <span class="T7">File.Type</span> works with items in <span class="T7">assets</span> as well. You can use them together to determine where an item is. The other <span class="T7">File.*</span> commands work with either files or resources. <span class="T7">Font.Load</span> can load a resource if it does not find the font file on the SD card.</p><p class="Standard">Files in <span class="T7">assets</span> are <span class="T17">read-only</span>. Your program can create and modify files on the SD card. It cannot create or modify files in <span class="T7">assets</span>. If you want BASIC! to copy files from <span class="T7">assets</span> to the SD card, list them the <span class="T7">"load_file_names"</span> tag of <span class="T7">setup.xml</span> as described above in "<span class="T7">Advanced Customization with setup.xml</span>".</p><p class="Standard">File names in <span class="T7">assets</span> are <span class="T17">case-sensitive</span>. If your program looks for a file on the SD card, the name is not case-sensitive: "meow.wav" and "Meow.WAV" are the same file. However, to find a file in <span class="T7">assets</span>, your program must name the file exactly as you put it in <span class="T7">assets</span>. <span class="T7">Audio.Load aft, "meow.wav"</span> will <span class="T7">not</span> find <span class="T7">assets/rfo-cats/data/Meow.WAV</span>.</p><p class="Standard">For this practice APK, make the following changes:</p><ol><li><p class="P62" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">1.</span>In the <span class="T7">Package Explorer</span>, expand <span class="T7">Cats/assets/rfo-basic</span> and its <span class="T7">data</span> and <span class="T7">source</span> folders.<span class="odfLiEnd"/> </p></li><li><p class="P62" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">2.</span>Right-click <span class="T7">assets</span> and select <span class="T7">New -&gt; Folder</span>.<span class="odfLiEnd"/> </p></li><li><p class="P62" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">3.</span>In the <span class="T7">Folder name:</span> field, enter "rfo-cats/data".<span class="odfLiEnd"/> </p></li><li><p class="P62" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">4.</span>Click <span class="T7">Finish</span>.<span class="odfLiEnd"/> </p></li><li><p class="P62" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">5.</span>In the same way, create "rfo-cats/source".<span class="odfLiEnd"/> </p></li><li><p class="P62" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">6.</span>Drag <span class="T7">assets/rfo-basic/data/meow.wav</span> to <span class="T7">assets/rfo-cats/data/</span>.<span class="odfLiEnd"/> </p></li><li><p class="P62" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">7.</span>Drag <span class="T7">assets/rfo-basic/source/my_program.bas</span> to <span class="T7">assets/rfo-cats/source/</span>.<span class="odfLiEnd"/> </p></li></ol><p class="P156">Note: the top folder in <span class="T7">assets</span> must exactly match what you put in the "<span class="T7">app_path</span>" item in <span class="T7">res/values/setup.xml</span>. For this practice program, it is <span class="T7">rfo-cats</span>.</p><p class="P156">If you expand your new folders, your <span class="T7">Package Explorer</span> should look like this:</p><!--Next 'div' was a 'text:p'.--><div class="List_20_Paragraph"><!--Next '
           span' is a draw:frame.
       --><span style="height:8.876cm;width:5.256cm; padding:0; " class="fr1" id="Picture_29"><img style="height:8.876cm;width:5.256cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><p class="Standard">Your APK does not need anything in <span class="T7">assets/rfo-basic</span>. Delete the entire folder:</p><ol><li><p class="P62" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">8.</span>In the <span class="T7">Package Explorer</span>, right-click <span class="T7">Cats/assets/rfo-basic</span> and select <span class="T7">Delete</span>.<span class="odfLiEnd"/> </p></li><li><p class="P62" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">9.</span>In the confirmation window that appears, click <span class="T7">OK</span>.<span class="odfLiEnd"/> </p></li><li><p class="P62" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">10.</span>You are done making changes! It wouldn’t hurt to do a <span class="T7">Project-&gt;Clean</span> here.<span class="odfLiEnd"/> </p></li></ol><h2 class="Heading_20_2"><a id="a__Testing_the_APK"><span/></a><a id="_Toc5236361"/>Testing the APK</h2><p class="Standard">We are now ready to test this practice APK.</p><p class="Standard">The first thing you will do is to create a Keystore. The Keystore is used to sign your application. Google Play requires this signing. Android devices will not install unsigned APKs. You will use this one Keystore for all your APKs. Preserve and protect it. You will not be able to update your APK without it.</p><p class="Standard">For more information about the Keystore and signing, see:</p><p class="P94"><a href="http://developer.android.com/tools/publishing/app-signing.html" class="Internet_20_link"><span class="Internet_20_link">http://developer.android.com/tools/publishing/app-signing.html</span></a></p><ol><li><p class="P63" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">1.</span>In the <span class="T7">Package Explorer</span>, right-click <span class="T7">Cats</span>.<span class="odfLiEnd"/> </p></li><li><p class="P63" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">2.</span>Select: <span class="T7">Android Tools -&gt; Export Signed Application Package</span>.<span class="odfLiEnd"/> </p></li><li><p class="P63" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">3.</span>In the <span class="T7">Project Checks</span> dialog box click <span class="T7">Next</span>.<span class="odfLiEnd"/> </p></li><li><p class="P63" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">4.</span>Select <span class="T7">Create New Keystore</span>. <span class="odfLiEnd"/> </p><ol><li><p class="P63" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">a.</span>Provide a name and location for the Keystore.<span class="odfLiEnd"/> </p></li><li><p class="P63" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">b.</span>Provide a password and confirm it.<span class="odfLiEnd"/> </p></li><li><p class="P63" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">c.</span>Click <span class="T7">Next</span>.<span class="odfLiEnd"/> </p></li></ol></li><li><p class="P63" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">5.</span>Fill out the <span class="T7">Key Creation</span> dialog.<span class="odfLiEnd"/> </p><ol><li><p class="P63" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">a.</span>Pick any name for an Alias.<span class="odfLiEnd"/> </p></li><li><p class="P63" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">b.</span>Enter 25 for Validity (Years).<span class="odfLiEnd"/> </p></li><li><p class="P63" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">c.</span>Click next.<span class="odfLiEnd"/> </p></li></ol></li><li><p class="P63" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">6.</span>In the <span class="T7">Destination and Key/Certificate Checks</span> dialog,<span class="odfLiEnd"/> </p><ol><li><p class="P63" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">a.</span>Browse to the folder where you want to put the APK.<span class="odfLiEnd"/> </p></li><li><p class="P63" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">b.</span>Name the APK "Cats.apk".<span class="odfLiEnd"/> </p></li><li><p class="P63" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">c.</span>Click next.<span class="odfLiEnd"/> </p></li></ol></li><li><p class="P63" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">7.</span>Now, install and run Cats.apk.<span class="odfLiEnd"/> </p></li></ol><p class="Standard">The APK will have the BASIC! icon. The name below the icon on your device will be "Cats!". Double click the icon to run your application.</p><p class="Standard">If you have reached this point successfully then you are ready to customize the APK for your application.</p><p class="Standard">Start over with a new copy of Basic.zip but use names and information particular to your application and then continue below.</p><h2 class="Heading_20_2"><a id="a__Installing_a_BASIC!_Program_into_the_Application"><span/></a><a id="_Toc5236362"/>Installing a BASIC! Program into the Application</h2><p class="Standard">You must build your BASIC! program into your application my putting it into the <span class="T7">assets</span> folder, just as you saw in the practice program. One very simple way is to copy your text into <span class="T7">assets/&lt;your-app&gt;/my_program.bas</span>. <span class="T7">&lt;your-app&gt;</span> is the path you named in the <span class="T7">setup.xml</span> item <span class="T7">"app_path"</span>.</p><ol><li><p class="P64" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">1.</span>In the Eclipse <span class="T7">Package Explorer</span>, expand the <span class="T7">assets</span> folder.<span class="odfLiEnd"/> </p></li><li><p class="P64" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">2.</span>Double-click <span class="T7">assets/&lt;your-app&gt;/source/my_program.bas</span>.<span class="odfLiEnd"/> </p></li><li><div class="P64" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">3.</span>The file will open in the edit window to the right: <!--Next '
           span' is a draw:frame.
       --><span style="height:7.352cm;width:12.61cm; padding:0; " class="fr1" id="Picture_56"><img style="height:7.352cm;width:12.61cm;" alt="" src=""/></span><span class="odfLiEnd"/> </div></li></ol><!--Next 'div' was a 'text:p'.--><div class="Standard">Now you can edit the file directly in Eclipse. If you prefer, you can open your program outside of Eclipse, copy its contents to the clipboard, and paste it into the Eclipse editor. When you are finished, select <span class="T7">File-</span><span class="T7">&gt;Save</span> from the menu bar, or just close the file by clicking the <span class="T7">X</span> <!--Next '
           span' is a draw:frame.
       --><span style="height:0.61cm;width:1.543cm; padding:0; " class="fr1" id="Picture_59"><img style="height:0.61cm;width:1.543cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><p class="Standard">For more complex projects, here is another way to do it.</p><ol><li><p class="P65" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">1.</span>In the Eclipse <span class="T7">Package Explorer</span>, expand your program’s <span class="T7">assets</span> folder.<span class="odfLiEnd"/> </p></li><li><p class="P65" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">2.</span>If you have a <span class="T7">my_program.bas</span> in your <span class="T7">assets</span> folder, delete it.<span class="odfLiEnd"/> </p></li><li><p class="P65" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">3.</span>In a file browser, browse to the file containing your program.<span class="odfLiEnd"/> </p></li><li><p class="P65" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">4.</span>Drag your program from your file browser to your <span class="T7">assets/&lt;your-app&gt;/source</span> folder in Eclipse.<span class="odfLiEnd"/> </p></li><li><p class="P65" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">5.</span>If your program uses <span class="T7">INCLUDE</span> files, drag them to the <span class="T7">source</span> folder, too.<span class="odfLiEnd"/> </p></li></ol><p class="Standard">With either method, you now have a program to run. If your program uses graphics, audio files, or other resources, you must put them in your Android <span class="T7">assets</span> folder, too.</p><p class="Standard">If your program uses data files, drag them to your <span class="T7">assets/&lt;your-app&gt;/data</span> folder.</p><p class="Standard">If your program uses data base files with the ".db" extension, create a new folder for them called <span class="T7">assets/&lt;your-app&gt;/databases</span> and drag your file into the new folder.</p><p class="Standard">The result might look something like this:</p><!--Next 'div' was a 'text:p'.--><div class="Standard"> <!--Next '
           span' is a draw:frame.
       --><span style="height:9.41cm;width:14.781cm; padding:0; " class="fr1" id="Picture_47"><img style="height:9.41cm;width:14.781cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><p class="Standard">Notice that the top folder in <span class="T7">assets</span> matches the "<span class="T7">app_path</span>" value, and there is a program in its <span class="T7">source</span> folder named the same as the "<span class="T7">my_program</span>" value.</p><h2 class="Heading_20_2"><a id="a__Application_Icons"><span/></a><a id="_Toc5236363"/>Application Icons</h2><p class="Standard">Android specifies that Application icons must be provided in specific sizes: low dpi (36x36 pixels), medium dpi (48x48 pixels), high dpi (72x72), x-high dpi (96x96), and so on. The icons must be .png files. There are tens of thousands of free icons available on the web. Most image editing programs can be used to re-sample the icons to the proper sizes and to save them as .png files. If you are not going to put your application on the Google Play Store then you do not really need to worry about getting this exactly right.</p><p class="Standard">To get your icon into your application, in res, open drawable-ldpi, drawable-mdpi, drawable-hdpi.</p><!--Next 'div' was a 'text:p'.--><div class="P149"><!--Next '
           span' is a draw:frame.
       --><span style="height:2.616cm;width:2.718cm; padding:0; " class="fr1" id="Picture_10"><img style="height:2.616cm;width:2.718cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><ol><li><p class="P72" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">1.</span>Outside of Eclipse, copy the icon file<span class="odfLiEnd"/> </p></li><li><p class="P72" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">2.</span>In Eclipse, right click on the appropriate <span class="T7">drawable-</span> for the copied icon's size<span class="odfLiEnd"/> </p></li><li><p class="P72" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">3.</span>Select <span class="T7">Paste</span><span class="odfLiEnd"/> </p></li><li><p class="P72" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">4.</span>Right click on the icon.png file and delete it<span class="odfLiEnd"/> </p></li><li><p class="P72" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">5.</span>Select the newly pasted icon and rename it to "icon.png" by selecting <span class="T7">File -&gt; Rename</span>.<span class="odfLiEnd"/> </p></li></ol><p class="P149">Yes, it is tedious work.</p><h2 class="Heading_20_2"><a id="a__Modifications_to_the_AndroidManifest_xml_File"><span/></a><a id="_Toc5236364"/>Modifications to the AndroidManifest.xml File</h2><p class="Standard">The <span class="T7">AndroidManifest.xml</span> file defines many aspects of how your application is built, and how it is presented to the Android system. For example, when you changed the package name, Eclipse wrote the change into the Android manifest.</p><p class="Standard">You can build and run your application with no further changes to AndroidManifest.xml. However, the manifest carries information that your application may not need. You should customize it to suit your application.</p><!--Next 'div' was a 'text:p'.--><div class="Standard">In the <span class="T7">Package Explorer</span>, find the <span class="T7">AndroidManifest.xml</span> file. Double-click to open it: <!--Next '
           span' is a draw:frame.
       --><span style="height:4.893cm;width:12.915cm; padding:0; " class="fr1" id="Picture_41"><img style="height:4.893cm;width:12.915cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><p class="Standard">Eclipse has special editors to display different views of the Manifest. If you don’t see the actual XML text as shown here, click on the rightmost tab at the bottom of the window, labeled <span class="T7">AndroidManifest.xml</span>.</p><h3 class="Heading_20_3"><a id="a__Setting_the_Version_Number_and_Version_Name"><span/></a><a id="_Toc5236365"/>Setting the Version Number and Version Name</h3><p class="Standard">If you are going to put the application on the Google Play Store, you will need to change the version number and name for each new release.</p><p class="Standard">Make the appropriate changes to the <span class="T7">android:versionCode</span> and <span class="T7">android:versionName</span> items of the <span class="T7">&lt;manifest&gt;</span> tag at the top of <span class="T7">AndroidManifest.xml</span>.</p><p class="Standard">If you want to use the BASIC! <span class="T7">VERSION$()</span> function to have your program read your version number, you will also have to change the version number in <span class="T7">res-&gt;values-&gt;strings</span>.</p><h3 class="Heading_20_3"><a id="a__Permissions"><span/></a><a id="_Toc5236366"/>Permissions</h3><p class="Standard">BASIC! uses many features about which the APK user is warned and must approve. Your particular APK may not need all or any of these permissions. The permission notifications are contained in the <span class="T7">&lt;uses-permission&gt;</span> tags of the <span class="T7">AndroidManiest.xml</span>. They look like this:</p><p class="P94"><span class="T70">&lt;</span><span class="T71">uses-permission</span><span class="T50"> </span><span class="T65">android:name</span><span class="T45">=</span><span class="T66">" android.permission. </span>… <span class="T66">"</span><span class="T50"> </span><span class="T70">/&gt;</span></p><p class="Standard">Look them over. If you feel that your APK does not need them then delete or comment them out.</p><p class="Standard">If your application uses the SD card, do not comment out:</p><p class="P94"><span class="T70">&lt;</span><span class="T71">uses-permission</span><span class="T50"> </span><span class="T65">android:name</span><span class="T45">=</span><span class="T66">"android.permission.WRITE_EXTERNAL_STORAGE"</span><span class="T50"> </span><span class="T70">/&gt;</span></p><p class="Standard">Note: your application does <span class="T7">not</span> need WRITE_EXTERNAL_STORAGE permission if you use only the private storage named in the SysPath key of the <span class="T7">Program.info</span> command.</p><p class="Standard">If you want your application to run when the device boots (see "Launch at device boot", below), do not comment out:</p><p class="P94"><span class="T70">&lt;</span><span class="T71">uses-permission</span><span class="T50"> </span><span class="T65">android:name</span><span class="T45">=</span><span class="T66">"android.permission.RECEIVE_BOOT_COMPLETED"</span><span class="T50"> </span><span class="T70">/&gt;</span></p><p class="Standard">Be sure to test your APK after changing permissions.</p><h3 class="Heading_20_3"><a id="a__Disable_the_Shortcut_Launcher"><span/></a><a id="_Toc5236367"/>Disable the Shortcut Launcher</h3><p class="Standard">Each Activity screen that BASIC! can present to a user is declared in an <span class="T7">&lt;activity&gt;</span> tag in the <span class="T7">AndroidManifest.xml</span> file. Your application may not use every Activity BASIC! offers. You may remove the unsed <span class="T7">&lt;activity&gt;</span> tags if you wish, but they don’t hurt anything if you leave them in.</p><p class="Standard">However, the <span class="T7">&lt;activity&gt;</span> tags also tell the Android system what events should start your application. You probably do not want your application to respond to these two events:</p><ol><li><p class="P66" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">1)</span>A user can launch BASIC! by tapping a file with a ".bas" extension<span class="odfLiEnd"/> </p></li><li><p class="P66" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">2)</span>A user can use the Shortcut Launcher to create a shortcut for a BASIC! program<span class="odfLiEnd"/> </p></li></ol><p class="Standard">You remove these by deleting their tags from the Manifest:</p><ol><li><p class="P67" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">1)</span>Find the <span class="T7">&lt;activity&gt;</span> tag that contains <span class="T7">android:name="Basic"</span>.<span class="odfLiEnd"/> </p><ol><li><p class="P67" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">a)</span>In it, find the <span class="T7">&lt;intent-filter&gt;</span> tag that contains <span class="T7">&lt;data android:pathPattern=".*\\.bas" /&gt;</span>.<span class="odfLiEnd"/> </p></li><li><p class="P67" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">b)</span>Remove all of the <span class="T7">&lt;intent-filter&gt;</span> tag, from <span class="T7">&lt;intent-filter&gt;</span> to <span class="T7">&lt;/intent_filter&gt;</span>.<br/><span style="margin-left:0cm"/>Do <span class="T7">not</span> remove the <span class="T7">&lt;activity&gt;</span> tag.<span class="odfLiEnd"/> </p></li></ol></li></ol><!--Next 'div' was a 'text:p'.--><div class="Standard"><!--Next '
           span' is a draw:frame.
       --><span style="height:7.264cm;width:16.256cm; padding:0; " class="fr1" id="Image4"><img style="height:7.264cm;width:16.256cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><ol><li><p class="P67" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">2)</span>There are two shortcut tags:<span class="odfLiEnd"/> </p><ol><li><p class="P67" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">a)</span>Find and remove the <span class="T7">&lt;activity&gt;</span> tag that contains <span class="T7">android:name="LauncherShortcuts"</span>.<span class="odfLiEnd"/> </p></li><li><p class="P67" style="margin-left:1.27cm;"><span style="display:block;float:left;min-width:0.635cm;">b)</span>Find and remove the <span class="T7">&lt;activity-alias&gt;</span> tag that contains <span class="T7">android:name="CreateShortcuts"</span>.<span class="odfLiEnd"/> </p></li></ol></li></ol><!--Next 'div' was a 'text:p'.--><div class="Standard"><!--Next '
           span' is a draw:frame.
       --><span style="height:7.639cm;width:16.491cm; padding:0; " class="fr1" id="Picture_34"><img style="height:7.639cm;width:16.491cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><h3 class="Heading_20_3"><a id="a__Launch_at_device_boot"><span/></a><a id="_Toc5236368"/>Launch at device boot</h3><p class="Standard">Your APK can be set up to automatically launch just after the Android device has booted. This is accomplished by changing another item in <span class="T7">AndroidManifest.xml</span>.</p><p class="Standard">Find the <span class="T7">&lt;receiver&gt;</span> tag with <span class="T7">android:name=".BootUpReceiver".<br/></span>Change <span class="T7">android:enabled="false"</span> to <span class="T7">android:enabled="true"</span>.</p><p class="Standard">You must also make sure your app has "RECEIVE_BOOT_COMPLETED" permission. See the "Permissions" section, above.</p><h2 class="Heading_20_2"><a id="a__Preferences"><span/></a><a id="_Toc5236369"/>Preferences</h2><p class="Standard">There are certain preferences such as screen colors and font sizes that you have set for your application. The preferences that you will get with an APK will be BASIC!’s default preferences. You can change the default preferences if you wish.</p><p class="Standard">Some preferences are simple check boxes. To change these, open the <span class="T7">res/xml</span> hierarchy and double click on the <span class="T7">settings.xml</span> file as shown below:</p><!--Next 'div' was a 'text:p'.--><div class="Standard">For example, to change the default Console Lines preference from lined console to unlined console, change the value on the indicated line from <span class="T7">"true"</span> to <span class="T7">"false"</span>.<!--Next '
           span' is a draw:frame.
       --><span style="height:5.41cm;width:14.148cm; padding:0; " class="fr1" id="Picture_12"><img style="height:5.41cm;width:14.148cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><p class="Standard">If your app uses graphics mode, and you have determined it works correctly with hardware-accelerated graphics, you may want to change the default setting of the CheckBoxPreference named "gr_accel". The default is normally "false", but to enable graphics acceleration in an APK you must change it to "true".</p><p class="Standard">Other preferences are multiple-choice lists. To see the list values, open the <span class="T7">res/values</span> hierarchy and double click on <span class="T7">arrays.xml</span>. Each preference has two blocks. The top block lists the words that will be seen on the Android screen. The second block lists the internal names that correspond to the displayed words.</p><p class="Standard">In the image below:</p><!--Next 'div' was a 'text:p'.--><div class="Standard"><!--Next '
           span' is a draw:frame.
       --><span style="height:5.156cm;width:14.173cm; padding:0; " class="fr1" id="Picture_35"><img style="height:5.156cm;width:14.173cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><p class="Standard">To set a default value for Screen Orientation, we need to go back to <span class="T7">settings.xml</span>:</p><!--Next 'div' was a 'text:p'.--><div class="Standard"><!--Next '
           span' is a draw:frame.
       --><span style="height:3.45cm;width:16.51cm; padding:0; " class="fr1" id="Picture_37"><img style="height:3.45cm;width:16.51cm;" alt="" src=""/></span></div><div style="clear:both; line-height:0; width:0; height:0; margin:0; padding:0;"> </div><p class="Standard">Find the <span class="T7">&lt;ListPreference&gt;</span> tag with <span class="T7">android:title"="Screen Orientation"</span>. The title is the preference name that you see on the Android screen. The default value is in the <span class="T7">android:defaultValue ="0"</span> line. Here we see the default value for the screen orientation is "0". Looking at the Array.xml file we can see the "0" is the internal name for <span class="T7">Variable By Sensors</span>. To change the default value to <span class="T7">Fixed Reverse Landscape</span>, change the <span class="T7">"0"</span> to <span class="T7">"2"</span>.</p><p class="Standard">The other list preferences follow the same logic.</p><p class="Standard">Note: Be sure to test your application with your chosen preferences before burning them into an APK.</p><h2 class="Heading_20_2"><a id="a__Finished"><span/></a><a id="_Toc5236370"/>Finished</h2><p class="Standard">Create your finished APK in the same way we created the practice APK.</p><p class="P149">Now that was not too bad, was it?<br/></p><h1 class="P17"><a id="a__Appendix_E___BASIC!_Distribution_License"><span/></a><a id="_Toc5236371"/>Appendix E – BASIC! Distribution License</h1><p class="P109">BASIC! is distributed under the terms of the GNU General Public License which is reproduced here.</p><p class="Standard">--------------------------------------------------------------------------------------------------------------------------------------</p><p class="P132"><span class="T34">GNU GENERAL PUBLIC LICENSE<br/>                       Version 3, 29 June 2007<br/><br/> Copyright (C) 2007 Free Software Foundation, Inc. &lt;http://fsf.org/&gt;<br/> Everyone is permitted to copy and distribute verbatim copies<br/> of this license document, but changing it is not allowed.<br/><br/>                            Preamble<br/><br/>  The GNU General Public License is a free, copyleft license for<br/>software and other kinds of works.<br/><br/>  The licenses for most software and other practical works are designed<br/>to take away your freedom to share and change the works.  By contrast,<br/>the GNU General Public License is intended to guarantee your freedom to<br/>share and change all versions of a program--to make sure it remains free<br/>software for all its users.  We, the Free Software Foundation, use the<br/>GNU General Public License for most of our software; it applies also to<br/>any other work released this way by its authors.  You can apply it to<br/>your programs, too.<br/><br/>  When we speak of free software, we are referring to freedom, not<br/>price.  Our General Public Licenses are designed to make sure that you<br/>have the freedom to distribute copies of free software (and charge for<br/>them if you wish), that you receive source code or can get it if you<br/>want it, that you can change the software or use pieces of it in new<br/>free programs, and that you know you can do these things.<br/><br/>  To protect your rights, we need to prevent others from denying you<br/>these rights or asking you to surrender the rights.  Therefore, you have<br/>certain responsibilities if you distribute copies of the software, or if<br/>you modify it: responsibilities to respect the freedom of others.<br/><br/>  For example, if you distribute copies of such a program, whether<br/>gratis or for a fee, you must pass on to the recipients the same<br/>freedoms that you received.  You must make sure that they, too, receive<br/>or can get the source code.  And you must show them these terms so they<br/>know their rights.<br/><br/>  Developers that use the GNU GPL protect your rights with two steps:<br/>(1) assert copyright on the software, and (2) offer you this License<br/>giving you legal permission to copy, distribute and/or modify it.<br/><br/>  For the developers' and authors' protection, the GPL clearly explains<br/>that there is no warranty for this free software.  For both users' and<br/>authors' sake, the GPL requires that modified versions be marked as<br/>changed, so that their problems will not be attributed erroneously to<br/>authors of previous versions.<br/><br/></span><span class="T34">  Some devices are designed to deny users access to install or run<br/>modified versions of the software inside them, although the manufacturer<br/>can do so.  This is fundamentally incompatible with the aim of<br/>protecting users' freedom to change the software.  The systematic<br/>pattern of such abuse occurs in the area of products for individuals to<br/>use, which is precisely where it is most unacceptable.  Therefore, we<br/>have designed this version of the GPL to prohibit the practice for those<br/>products.  If such problems arise substantially in other domains, we<br/>stand ready to extend this provision to those domains in future versions<br/>of the GPL, as needed to protect the freedom of users.<br/><br/>  Finally, every program is threatened constantly by software patents.<br/>States should not allow patents to restrict development and use of<br/>software on general-purpose computers, but in those that do, we wish to<br/>avoid the special danger that patents applied to a free program could<br/>make it effectively proprietary.  To prevent this, the GPL assures that<br/>patents cannot be used to render the program non-free.<br/><br/>  The precise terms and conditions for copying, distribution and<br/>modification follow.<br/><br/>                       TERMS AND CONDITIONS<br/><br/>  0. Definitions.<br/><br/>  "This License" refers to version 3 of the GNU General Public License.<br/><br/>  "Copyright" also means copyright-like laws that apply to other kinds of<br/>works, such as semiconductor masks.<br/><br/>  "The Program" refers to any copyrightable work licensed under this<br/>License.  Each licensee is addressed as "you".  "Licensees" and<br/>"recipients" may be individuals or organizations.<br/><br/>  To "modify" a work means to copy from or adapt all or part of the work<br/>in a fashion requiring copyright permission, other than the making of an<br/>exact copy.  The resulting work is called a "modified version" of the<br/>earlier work or a work "based on" the earlier work.<br/><br/>  A "covered work" means either the unmodified Program or a work based<br/>on the Program.<br/><br/>  To "propagate" a work means to do anything with it that, without<br/>permission, would make you directly or secondarily liable for<br/>infringement under applicable copyright law, except executing it on a<br/>computer or modifying a private copy.  Propagation includes copying,<br/>distribution (with or without modification), making available to the<br/>public, and in some countries other activities as well.<br/><br/>  To "convey" a work means any kind of propagation that enables other<br/>parties to make or receive copies.  Mere interaction with a user through<br/>a computer network, with no transfer of a copy, is not conveying.<br/><br/>  An interactive user interface displays "Appropriate Legal Notices"<br/>to the extent that it includes a convenient and prominently visible<br/>feature that (1) displays an appropriate copyright notice, and (2)<br/>tells the user that there is no warranty for the work (except to the<br/></span><span class="T34">extent that warranties are provided), that licensees may convey the<br/>work under this License, and how to view a copy of this License.  If<br/>the interface presents a list of user commands or options, such as a<br/>menu, a prominent item in the list meets this criterion.<br/><br/>  1. Source Code.<br/><br/>  The "source code" for a work means the preferred form of the work<br/>for making modifications to it.  "Object code" means any non-source<br/>form of a work.<br/><br/>  A "Standard Interface" means an interface that either is an official<br/>standard defined by a recognized standards body, or, in the case of<br/>interfaces specified for a particular programming language, one that<br/>is widely used among developers working in that language.<br/><br/>  The "System Libraries" of an executable work include anything, other<br/>than the work as a whole, that (a) is included in the normal form of<br/>packaging a Major Component, but which is not part of that Major<br/>Component, and (b) serves only to enable use of the work with that<br/>Major Component, or to implement a Standard Interface for which an<br/>implementation is available to the public in source code form.  A<br/>"Major Component", in this context, means a major essential component<br/>(kernel, window system, and so on) of the specific operating system<br/>(if any) on which the executable work runs, or a compiler used to<br/>produce the work, or an object code interpreter used to run it.<br/><br/>  The "Corresponding Source" for a work in object code form means all<br/>the source code needed to generate, install, and (for an executable<br/>work) run the object code and to modify the work, including scripts to<br/>control those activities.  However, it does not include the work's<br/>System Libraries, or general-purpose tools or generally available free<br/>programs which are used unmodified in performing those activities but<br/>which are not part of the work.  For example, Corresponding Source<br/>includes interface definition files associated with source files for<br/>the work, and the source code for shared libraries and dynamically<br/>linked subprograms that the work is specifically designed to require,<br/>such as by intimate data communication or control flow between those<br/>subprograms and other parts of the work.<br/><br/>  The Corresponding Source need not include anything that users<br/>can regenerate automatically from other parts of the Corresponding<br/>Source.<br/><br/>  The Corresponding Source for a work in source code form is that<br/>same work.<br/><br/>  2. Basic Permissions.<br/><br/>  All rights granted under this License are granted for the term of<br/>copyright on the Program, and are irrevocable provided the stated<br/>conditions are met.  This License explicitly affirms your unlimited<br/>permission to run the unmodified Program.  The output from running a<br/>covered work is covered by this License only if the output, given its<br/>content, constitutes a covered work.  This License acknowledges your<br/>rights of fair use or other equivalent, as provided by copyright law.<br/><br/></span><span class="T34">  You may make, run and propagate covered works that you do not<br/>convey, without conditions so long as your license otherwise remains<br/>in force.  You may convey covered works to others for the sole purpose<br/>of having them make modifications exclusively for you, or provide you<br/>with facilities for running those works, provided that you comply with<br/>the terms of this License in conveying all material for which you do<br/>not control copyright.  Those thus making or running the covered works<br/>for you must do so exclusively on your behalf, under your direction<br/>and control, on terms that prohibit them from making any copies of<br/>your copyrighted material outside their relationship with you.<br/><br/>  Conveying under any other circumstances is permitted solely under<br/>the conditions stated below.  Sublicensing is not allowed; section 10<br/>makes it unnecessary.<br/><br/>  3. Protecting Users' Legal Rights From Anti-Circumvention Law.<br/><br/>  No covered work shall be deemed part of an effective technological<br/>measure under any applicable law fulfilling obligations under article<br/>11 of the WIPO copyright treaty adopted on 20 December 1996, or<br/>similar laws prohibiting or restricting circumvention of such<br/>measures.<br/><br/>  When you convey a covered work, you waive any legal power to forbid<br/>circumvention of technological measures to the extent such circumvention<br/>is effected by exercising rights under this License with respect to<br/>the covered work, and you disclaim any intention to limit operation or<br/>modification of the work as a means of enforcing, against the work's<br/>users, your or third parties' legal rights to forbid circumvention of<br/>technological measures.<br/><br/>  4. Conveying Verbatim Copies.<br/><br/>  You may convey verbatim copies of the Program's source code as you<br/>receive it, in any medium, provided that you conspicuously and<br/>appropriately publish on each copy an appropriate copyright notice;<br/>keep intact all notices stating that this License and any<br/>non-permissive terms added in accord with section 7 apply to the code;<br/>keep intact all notices of the absence of any warranty; and give all<br/>recipients a copy of this License along with the Program.<br/><br/>  You may charge any price or no price for each copy that you convey,<br/>and you may offer support or warranty protection for a fee.<br/><br/>  5. Conveying Modified Source Versions.<br/><br/>  You may convey a work based on the Program, or the modifications to<br/>produce it from the Program, in the form of source code under the<br/>terms of section 4, provided that you also meet all of these conditions:<br/><br/>    a) The work must carry prominent notices stating that you modified<br/>    it, and giving a relevant date.<br/><br/>    b) The work must carry prominent notices stating that it is<br/>    released under this License and any conditions added under section<br/>    7.  This requirement modifies the requirement in section 4 to<br/>    "keep intact all notices".<br/></span><span class="T34"><br/>    c) You must license the entire work, as a whole, under this<br/>    License to anyone who comes into possession of a copy.  This<br/>    License will therefore apply, along with any applicable section 7<br/>    additional terms, to the whole of the work, and all its parts,<br/>    regardless of how they are packaged.  This License gives no<br/>    permission to license the work in any other way, but it does not<br/>    invalidate such permission if you have separately received it.<br/><br/>    d) If the work has interactive user interfaces, each must display<br/>    Appropriate Legal Notices; however, if the Program has interactive<br/>    interfaces that do not display Appropriate Legal Notices, your<br/>    work need not make them do so.<br/><br/>  A compilation of a covered work with other separate and independent<br/>works, which are not by their nature extensions of the covered work,<br/>and which are not combined with it such as to form a larger program,<br/>in or on a volume of a storage or distribution medium, is called an<br/>"aggregate" if the compilation and its resulting copyright are not<br/>used to limit the access or legal rights of the compilation's users<br/>beyond what the individual works permit.  Inclusion of a covered work<br/>in an aggregate does not cause this License to apply to the other<br/>parts of the aggregate.<br/><br/>  6. Conveying Non-Source Forms.<br/><br/>  You may convey a covered work in object code form under the terms<br/>of sections 4 and 5, provided that you also convey the<br/>machine-readable Corresponding Source under the terms of this License,<br/>in one of these ways:<br/><br/>    a) Convey the object code in, or embodied in, a physical product<br/>    (including a physical distribution medium), accompanied by the<br/>    Corresponding Source fixed on a durable physical medium<br/>    customarily used for software interchange.<br/><br/>    b) Convey the object code in, or embodied in, a physical product<br/>    (including a physical distribution medium), accompanied by a<br/>    written offer, valid for at least three years and valid for as<br/>    long as you offer spare parts or customer support for that product<br/>    model, to give anyone who possesses the object code either (1) a<br/>    copy of the Corresponding Source for all the software in the<br/>    product that is covered by this License, on a durable physical<br/>    medium customarily used for software interchange, for a price no<br/>    more than your reasonable cost of physically performing this<br/>    conveying of source, or (2) access to copy the<br/>    Corresponding Source from a network server at no charge.<br/><br/>    c) Convey individual copies of the object code with a copy of the<br/>    written offer to provide the Corresponding Source.  This<br/>    alternative is allowed only occasionally and noncommercially, and<br/>    only if you received the object code with such an offer, in accord<br/>    with subsection 6b.<br/><br/>    d) Convey the object code by offering access from a designated<br/>    place (gratis or for a charge), and offer equivalent access to the<br/>    Corresponding Source in the same way through the same place at no<br/></span><span class="T34">    further charge.  You need not require recipients to copy the<br/>    Corresponding Source along with the object code.  If the place to<br/>    copy the object code is a network server, the Corresponding Source<br/>    may be on a different server (operated by you or a third party)<br/>    that supports equivalent copying facilities, provided you maintain<br/>    clear directions next to the object code saying where to find the<br/>    Corresponding Source.  Regardless of what server hosts the<br/>    Corresponding Source, you remain obligated to ensure that it is<br/>    available for as long as needed to satisfy these requirements.<br/><br/>    e) Convey the object code using peer-to-peer transmission, provided<br/>    you inform other peers where the object code and Corresponding<br/>    Source of the work are being offered to the general public at no<br/>    charge under subsection 6d.<br/><br/>  A separable portion of the object code, whose source code is excluded<br/>from the Corresponding Source as a System Library, need not be<br/>included in conveying the object code work.<br/><br/>  A "User Product" is either (1) a "consumer product", which means any<br/>tangible personal property which is normally used for personal, family,<br/>or household purposes, or (2) anything designed or sold for incorporation<br/>into a dwelling.  In determining whether a product is a consumer product,<br/>doubtful cases shall be resolved in favor of coverage.  For a particular<br/>product received by a particular user, "normally used" refers to a<br/>typical or common use of that class of product, regardless of the status<br/>of the particular user or of the way in which the particular user<br/>actually uses, or expects or is expected to use, the product.  A product<br/>is a consumer product regardless of whether the product has substantial<br/>commercial, industrial or non-consumer uses, unless such uses represent<br/>the only significant mode of use of the product.<br/><br/>  "Installation Information" for a User Product means any methods,<br/>procedures, authorization keys, or other information required to install<br/>and execute modified versions of a covered work in that User Product from<br/>a modified version of its Corresponding Source.  The information must<br/>suffice to ensure that the continued functioning of the modified object<br/>code is in no case prevented or interfered with solely because<br/>modification has been made.<br/><br/>  If you convey an object code work under this section in, or with, or<br/>specifically for use in, a User Product, and the conveying occurs as<br/>part of a transaction in which the right of possession and use of the<br/>User Product is transferred to the recipient in perpetuity or for a<br/>fixed term (regardless of how the transaction is characterized), the<br/>Corresponding Source conveyed under this section must be accompanied<br/>by the Installation Information.  But this requirement does not apply<br/>if neither you nor any third party retains the ability to install<br/>modified object code on the User Product (for example, the work has<br/>been installed in ROM).<br/><br/>  The requirement to provide Installation Information does not include a<br/>requirement to continue to provide support service, warranty, or updates<br/>for a work that has been modified or installed by the recipient, or for<br/>the User Product in which it has been modified or installed.  Access to a<br/>network may be denied when the modification itself materially and<br/>adversely affects the operation of the network or violates the rules and<br/></span><span class="T34">protocols for communication across the network.<br/><br/>  Corresponding Source conveyed, and Installation Information provided,<br/>in accord with this section must be in a format that is publicly<br/>documented (and with an implementation available to the public in<br/>source code form), and must require no special password or key for<br/>unpacking, reading or copying.<br/><br/>  7. Additional Terms.<br/><br/>  "Additional permissions" are terms that supplement the terms of this<br/>License by making exceptions from one or more of its conditions.<br/>Additional permissions that are applicable to the entire Program shall<br/>be treated as though they were included in this License, to the extent<br/>that they are valid under applicable law.  If additional permissions<br/>apply only to part of the Program, that part may be used separately<br/>under those permissions, but the entire Program remains governed by<br/>this License without regard to the additional permissions.<br/><br/>  When you convey a copy of a covered work, you may at your option<br/>remove any additional permissions from that copy, or from any part of<br/>it.  (Additional permissions may be written to require their own<br/>removal in certain cases when you modify the work.)  You may place<br/>additional permissions on material, added by you to a covered work,<br/>for which you have or can give appropriate copyright permission.<br/><br/>  Notwithstanding any other provision of this License, for material you<br/>add to a covered work, you may (if authorized by the copyright holders of<br/>that material) supplement the terms of this License with terms:<br/><br/>    a) Disclaiming warranty or limiting liability differently from the<br/>    terms of sections 15 and 16 of this License; or<br/><br/>    b) Requiring preservation of specified reasonable legal notices or<br/>    author attributions in that material or in the Appropriate Legal<br/>    Notices displayed by works containing it; or<br/><br/>    c) Prohibiting misrepresentation of the origin of that material, or<br/>    requiring that modified versions of such material be marked in<br/>    reasonable ways as different from the original version; or<br/><br/>    d) Limiting the use for publicity purposes of names of licensors or<br/>    authors of the material; or<br/><br/>    e) Declining to grant rights under trademark law for use of some<br/>    trade names, trademarks, or service marks; or<br/><br/>    f) Requiring indemnification of licensors and authors of that<br/>    material by anyone who conveys the material (or modified versions of<br/>    it) with contractual assumptions of liability to the recipient, for<br/>    any liability that these contractual assumptions directly impose on<br/>    those licensors and authors.<br/><br/>  All other non-permissive additional terms are considered "further<br/>restrictions" within the meaning of section 10.  If the Program as you<br/>received it, or any part of it, contains a notice stating that it is<br/>governed by this License along with a term that is a further<br/></span><span class="T34">restriction, you may remove that term.  If a license document contains<br/>a further restriction but permits relicensing or conveying under this<br/>License, you may add to a covered work material governed by the terms<br/>of that license document, provided that the further restriction does<br/>not survive such relicensing or conveying.<br/><br/>  If you add terms to a covered work in accord with this section, you<br/>must place, in the relevant source files, a statement of the<br/>additional terms that apply to those files, or a notice indicating<br/>where to find the applicable terms.<br/><br/>  Additional terms, permissive or non-permissive, may be stated in the<br/>form of a separately written license, or stated as exceptions;<br/>the above requirements apply either way.<br/><br/>  8. Termination.<br/><br/>  You may not propagate or modify a covered work except as expressly<br/>provided under this License.  Any attempt otherwise to propagate or<br/>modify it is void, and will automatically terminate your rights under<br/>this License (including any patent licenses granted under the third<br/>paragraph of section 11).<br/><br/>  However, if you cease all violation of this License, then your<br/>license from a particular copyright holder is reinstated (a)<br/>provisionally, unless and until the copyright holder explicitly and<br/>finally terminates your license, and (b) permanently, if the copyright<br/>holder fails to notify you of the violation by some reasonable means<br/>prior to 60 days after the cessation.<br/><br/>  Moreover, your license from a particular copyright holder is<br/>reinstated permanently if the copyright holder notifies you of the<br/>violation by some reasonable means, this is the first time you have<br/>received notice of violation of this License (for any work) from that<br/>copyright holder, and you cure the violation prior to 30 days after<br/>your receipt of the notice.<br/><br/>  Termination of your rights under this section does not terminate the<br/>licenses of parties who have received copies or rights from you under<br/>this License.  If your rights have been terminated and not permanently<br/>reinstated, you do not qualify to receive new licenses for the same<br/>material under section 10.<br/><br/>  9. Acceptance Not Required for Having Copies.<br/><br/>  You are not required to accept this License in order to receive or<br/>run a copy of the Program.  Ancillary propagation of a covered work<br/>occurring solely as a consequence of using peer-to-peer transmission<br/>to receive a copy likewise does not require acceptance.  However,<br/>nothing other than this License grants you permission to propagate or<br/>modify any covered work.  These actions infringe copyright if you do<br/>not accept this License.  Therefore, by modifying or propagating a<br/>covered work, you indicate your acceptance of this License to do so.<br/><br/>  10. Automatic Licensing of Downstream Recipients.<br/><br/>  Each time you convey a covered work, the recipient automatically<br/></span><span class="T34">receives a license from the original licensors, to run, modify and<br/>propagate that work, subject to this License.  You are not responsible<br/>for enforcing compliance by third parties with this License.<br/><br/>  An "entity transaction" is a transaction transferring control of an<br/>organization, or substantially all assets of one, or subdividing an<br/>organization, or merging organizations.  If propagation of a covered<br/>work results from an entity transaction, each party to that<br/>transaction who receives a copy of the work also receives whatever<br/>licenses to the work the party's predecessor in interest had or could<br/>give under the previous paragraph, plus a right to possession of the<br/>Corresponding Source of the work from the predecessor in interest, if<br/>the predecessor has it or can get it with reasonable efforts.<br/><br/>  You may not impose any further restrictions on the exercise of the<br/>rights granted or affirmed under this License.  For example, you may<br/>not impose a license fee, royalty, or other charge for exercise of<br/>rights granted under this License, and you may not initiate litigation<br/>(including a cross-claim or counterclaim in a lawsuit) alleging that<br/>any patent claim is infringed by making, using, selling, offering for<br/>sale, or importing the Program or any portion of it.<br/><br/>  11. Patents.<br/><br/>  A "contributor" is a copyright holder who authorizes use under this<br/>License of the Program or a work on which the Program is based.  The<br/>work thus licensed is called the contributor's "contributor version".<br/><br/>  A contributor's "essential patent claims" are all patent claims<br/>owned or controlled by the contributor, whether already acquired or<br/>hereafter acquired, that would be infringed by some manner, permitted<br/>by this License, of making, using, or selling its contributor version,<br/>but do not include claims that would be infringed only as a<br/>consequence of further modification of the contributor version.  For<br/>purposes of this definition, "control" includes the right to grant<br/>patent sublicenses in a manner consistent with the requirements of<br/>this License.<br/><br/>  Each contributor grants you a non-exclusive, worldwide, royalty-free<br/>patent license under the contributor's essential patent claims, to<br/>make, use, sell, offer for sale, import and otherwise run, modify and<br/>propagate the contents of its contributor version.<br/><br/>  In the following three paragraphs, a "patent license" is any express<br/>agreement or commitment, however denominated, not to enforce a patent<br/>(such as an express permission to practice a patent or covenant not to<br/>sue for patent infringement).  To "grant" such a patent license to a<br/>party means to make such an agreement or commitment not to enforce a<br/>patent against the party.<br/><br/>  If you convey a covered work, knowingly relying on a patent license,<br/>and the Corresponding Source of the work is not available for anyone<br/>to copy, free of charge and under the terms of this License, through a<br/>publicly available network server or other readily accessible means,<br/>then you must either (1) cause the Corresponding Source to be so<br/>available, or (2) arrange to deprive yourself of the benefit of the<br/>patent license for this particular work, or (3) arrange, in a manner<br/></span><span class="T34">consistent with the requirements of this License, to extend the patent<br/>license to downstream recipients.  "Knowingly relying" means you have<br/>actual knowledge that, but for the patent license, your conveying the<br/>covered work in a country, or your recipient's use of the covered work<br/>in a country, would infringe one or more identifiable patents in that<br/>country that you have reason to believe are valid.<br/><br/>  If, pursuant to or in connection with a single transaction or<br/>arrangement, you convey, or propagate by procuring conveyance of, a<br/>covered work, and grant a patent license to some of the parties<br/>receiving the covered work authorizing them to use, propagate, modify<br/>or convey a specific copy of the covered work, then the patent license<br/>you grant is automatically extended to all recipients of the covered<br/>work and works based on it.<br/><br/>  A patent license is "discriminatory" if it does not include within<br/>the scope of its coverage, prohibits the exercise of, or is<br/>conditioned on the non-exercise of one or more of the rights that are<br/>specifically granted under this License.  You may not convey a covered<br/>work if you are a party to an arrangement with a third party that is<br/>in the business of distributing software, under which you make payment<br/>to the third party based on the extent of your activity of conveying<br/>the work, and under which the third party grants, to any of the<br/>parties who would receive the covered work from you, a discriminatory<br/>patent license (a) in connection with copies of the covered work<br/>conveyed by you (or copies made from those copies), or (b) primarily<br/>for and in connection with specific products or compilations that<br/>contain the covered work, unless you entered into that arrangement,<br/>or that patent license was granted, prior to 28 March 2007.<br/><br/>  Nothing in this License shall be construed as excluding or limiting<br/>any implied license or other defenses to infringement that may<br/>otherwise be available to you under applicable patent law.<br/><br/>  12. No Surrender of Others' Freedom.<br/><br/>  If conditions are imposed on you (whether by court order, agreement or<br/>otherwise) that contradict the conditions of this License, they do not<br/>excuse you from the conditions of this License.  If you cannot convey a<br/>covered work so as to satisfy simultaneously your obligations under this<br/>License and any other pertinent obligations, then as a consequence you may<br/>not convey it at all.  For example, if you agree to terms that obligate you<br/>to collect a royalty for further conveying from those to whom you convey<br/>the Program, the only way you could satisfy both those terms and this<br/>License would be to refrain entirely from conveying the Program.<br/><br/>  13. Use with the GNU Affero General Public License.<br/><br/>  Notwithstanding any other provision of this License, you have<br/>permission to link or combine any covered work with a work licensed<br/>under version 3 of the GNU Affero General Public License into a single<br/>combined work, and to convey the resulting work.  The terms of this<br/>License will continue to apply to the part which is the covered work,<br/>but the special requirements of the GNU Affero General Public License,<br/>section 13, concerning interaction through a network will apply to the<br/>combination as such.<br/><br/></span><span class="T34">  14. Revised Versions of this License.<br/><br/>  The Free Software Foundation may publish revised and/or new versions of<br/>the GNU General Public License from time to time.  Such new versions will<br/>be similar in spirit to the present version, but may differ in detail to<br/>address new problems or concerns.<br/><br/>  Each version is given a distinguishing version number.  If the<br/>Program specifies that a certain numbered version of the GNU General<br/>Public License "or any later version" applies to it, you have the<br/>option of following the terms and conditions either of that numbered<br/>version or of any later version published by the Free Software<br/>Foundation.  If the Program does not specify a version number of the<br/>GNU General Public License, you may choose any version ever published<br/>by the Free Software Foundation.<br/><br/>  If the Program specifies that a proxy can decide which future<br/>versions of the GNU General Public License can be used, that proxy's<br/>public statement of acceptance of a version permanently authorizes you<br/>to choose that version for the Program.<br/><br/>  Later license versions may give you additional or different<br/>permissions.  However, no additional obligations are imposed on any<br/>author or copyright holder as a result of your choosing to follow a<br/>later version.<br/><br/>  15. Disclaimer of Warranty.<br/><br/>  THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY<br/>APPLICABLE LAW.  EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT<br/>HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY<br/>OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,<br/>THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR<br/>PURPOSE.  THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM<br/>IS WITH YOU.  SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF<br/>ALL NECESSARY SERVICING, REPAIR OR CORRECTION.<br/><br/>  16. Limitation of Liability.<br/><br/>  IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING<br/>WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS<br/>THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY<br/>GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE<br/>USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF<br/>DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD<br/>PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),<br/>EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF<br/>SUCH DAMAGES.<br/><br/>  17. Interpretation of Sections 15 and 16.<br/><br/>  If the disclaimer of warranty and limitation of liability provided<br/>above cannot be given local legal effect according to their terms,<br/>reviewing courts shall apply local law that most closely approximates<br/>an absolute waiver of all civil liability in connection with the<br/>Program, unless a warranty or assumption of liability accompanies a<br/>copy of the Program in return for a fee.<br/></span><span class="T34"><br/>                     END OF TERMS AND CONDITIONS</span></p><h2 class="Heading_20_2"><a id="a__Apache_Commons"><span/></a><a id="_Toc5236372"/><span class="T6">Apache Commons</span></h2><p class="Standard">Portions of BASIC! use Apache Commons.</p><p class="Standard">Apache Commons Net</p><p class="Standard">Copyright 2001-2019 The Apache Software Foundation</p><p class="Standard"> </p><p class="Standard">This product includes software developed by</p><p class="Standard">The Apache Software Foundation (http://www.apache.org/).</p></div><p class="Footnote"><span class="footnodeNumber"><a class="Footnote_20_Symbol" id="ftn1" href="#body_ftn1">1</a></span> This container is called a "directory" because it is a listing of the items it contains. You can also call it a "folder", and you can say "a folder is a container for files and other folders." Both expressions mean the same thing.</p></body></html>