% -*- coding: utf-8 -*- \section{Preudfyldning} Inden en makro sendes til klienten sker der en preudfyldningsprocess på serveren.\\ Et givet inputfelt kan blive preudfyldt med \begin{itemize} \item en målt værdi via Pentominos. \item en tidligere lagret værdi i databasen. \item en defaultværdi. \end{itemize} Præcis hvilken af de tre metoder som vil blive brugt til det enkeklte felt afhænger af tidskoder. \subsection{Pentominos} I headeren på en makro forefindes en række queries til pentominos serveren. Disse udføres samlet inden makroen behandles, og producerer et namespace hvor navnene er dikteret af deres nesting i svaret fra pentominos serveren.\\ En query kan f.eks se sådan ud: \begin{verbatim} <queries> <query class="lensmeter" ttl="10000"/> </queries> \end{verbatim} Et svar kan f.eks se sådan ud: \begin{verbatim} <results> <result class="lensmeter" timestamp="1211808877"> <group name="right"> <value name="sphere" value="-4.75"/> <value name="cyl" value="-0.25"/> <value name="axis" value="56"/> </group> <group name="left"> <value name="sphere" value="-4.76"/> <value name="cyl" value="-0.23"/> <value name="axis" value="32"/> </group> </result> </results> \end{verbatim} For hvert resultat produceres en \texttt{result} knude med tilhørende tidkode som beskriver hvornår den givne måling er indrapporteret.\\ Disse knuder oversættes til et namespace med nesting, separeret med \texttt{.} (punktum), bestående af først klassenavnet på querien, dernest alle grupper og sidst navnet på værdien, f.eks \texttt{lensmeter.right.axis}.\\ Hver af disse værdier indeholder en value og en timestamp som sat iflg. svaret.\\ Svaret bliver nu filtreret igennem en række LUA mapper programmer som hver især returnerer en værdi og en tidskode.\\ Mapper programmerne kan f.eks se sådan ud: \begin{verbatim} <maps> <map name="axis"> -- LUA program, returning explicit values return math.pi, 1234567890 </map> <map name="sphere"> -- LUA program, returning a value and its timestamp return lensmeter.right.sphere.value, lensmeter.right.sphere.timestamp </map> <map name="cyl"> -- LUA program, returning an average, with oldest timestamp timestamp = lensmeter.right.cyl.timestamp if( timestamp > lensmeter.right.axis.timestamp ) timestamp = lensmeter.right.axis.timestamp value = ( lensmeter.right.cyl.value + lensmeter.right.axis.value ) / 2.0 return value, timestamp </map> </maps> \end{verbatim} Et inputfelt angiver at det skal (eller kan) udfyldes via sådan et map, ved hjælp af et \texttt{map} tag. Hvis dette tag ikke findes, eller hvis det er tomt, eller refererer til et ikke-eksisterende map, ignoreres det. \subsection{Pracro} Alle input felter i makroen har et navn tilknyttet. Disse navne benyttes til at lave opslag i pracro databasen for at finde ud af om der er tidligere indtastede værdier.\\ Disse eventuelle værdier har ligesom værdierne fra pentominos tidskoder.\\ Ved opslaget benyttes en fast defineret (i configurationsfilen) ttl. Overskrides denne af en værdi, ignoreres den i opslaget.\\ Hvis pentominos svaret ikke har givet anledning til en konkret værdi, eller hvis værdiens tidskode er ældre end den pracro opslaget giver, så har pracro værdien precedens over pentominos. Hvis det modsatte er tilfældet, benyttes værdien fra pentominos.\\ Hvis hverken pentominos eller pracro giver noget bugbart resultat, benyttes default værdien. \subsection{Default værdi} Alle inputfelter har en predefineret værdi, i kraft af et value felt.\\ Et ikke eksisterende value felt resulterer i en default værdi værende den tomme streng.