Code coverage tests

This page documents the degree to which the PARI/GP source code is tested by our public test suite, distributed with the source distribution in directory src/test/. This is measured by the gcov utility; we then process gcov output using the lcov frond-end.

We test a few variants depending on Configure flags on the pari.math.u-bordeaux.fr machine (x86_64 architecture), and agregate them in the final report:

The target is to exceed 90% coverage for all mathematical modules (given that branches depending on DEBUGLEVEL or DEBUGMEM are not covered). This script is run to produce the results below.

LCOV - code coverage report
Current view: top level - language - parse.y (source / functions) Hit Total Coverage
Test: PARI/GP v2.18.1 lcov report (development 29861-d235532887) Lines: 111 117 94.9 %
Date: 2025-01-09 09:08:32 Functions: 0 0 -
Legend: Lines: hit not hit

          Line data    Source code
       1             : %{
       2             : /* Copyright (C) 2006  The PARI group.
       3             : 
       4             : This file is part of the PARI package.
       5             : 
       6             : PARI/GP is free software; you can redistribute it and/or modify it under the
       7             : terms of the GNU General Public License as published by the Free Software
       8             : Foundation; either version 2 of the License, or (at your option) any later
       9             : version. It is distributed in the hope that it will be useful, but WITHOUT
      10             : ANY WARRANTY WHATSOEVER.
      11             : 
      12             : Check the License for details. You should have received a copy of it, along
      13             : with the package; see the file 'COPYING'. If not, write to the Free Software
      14             : Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */
      15             : 
      16             : #define PARI_STYPE union token_value
      17             : #define PARI_LTYPE struct node_loc
      18             : #define YYPTRDIFF_T long
      19             : #define YYPTRDIFF_MAXIMUM LONG_MAX
      20             : #define YYSIZE_T size_t
      21             : #define YYLLOC_DEFAULT(Current, Rhs, N)     \
      22             :         ((Current).start  = ((N)?(Rhs)[1].start:(Rhs)[0].end),  \
      23             :          (Current).end    = (Rhs)[N].end)
      24             : #include "parsec.h"
      25             : #define NOARG(x) newnode(Fnoarg,-1,-1,&(x))
      26             : #define NORANGE(x) newnode(Fnorange,-1,-1,&(x))
      27             : %}
      28             : %define parse.error verbose
      29             : %define api.prefix {pari_}
      30             : %define api.pure full
      31             : %parse-param {char **lex}
      32             : %lex-param {char **lex}
      33      932648 : %initial-action{ @$.start=@$.end=*lex; }
      34             : %token KPARROW ")->"
      35             : %token KARROW "->"
      36             : %token KDOTDOT ".."
      37             : %token KPE   "+="
      38             : %token KSE   "-="
      39             : %token KME   "*="
      40             : %token KDE   "/="
      41             : %token KDRE  "\\/="
      42             : %token KEUCE "\\="
      43             : %token KMODE "%="
      44             : %token KAND  "&&"
      45             : %token KOR   "||"
      46             : %token KID   "==="
      47             : %token KEQ   "=="
      48             : %token KNE   "!="
      49             : %token KGE   ">="
      50             : %token KLE   "<="
      51             : %token KSRE  ">>="
      52             : %token KSLE  "<<="
      53             : %token KSR   ">>"
      54             : %token KSL   "<<"
      55             : %token KDR   "\\/"
      56             : %token KPP   "++"
      57             : %token KSS   "--"
      58             : %token <gen> KINTEGER "integer"
      59             : %token <gen> KREAL "real number"
      60             : %token KENTRY "variable name"
      61             : %token KSTRING "character string"
      62             : %left SEQ DEFFUNC
      63             : %left INT LVAL
      64             : %right ")->" "->"
      65             : %left ';' ',' ".."
      66             : %right '=' "+=" "-=" "*=" "/=" "\\/=" "\\=" "%=" ">>=" "<<="
      67             : %left '&' "&&" "||"
      68             : %left "===" "==" "!=" '>' ">=" '<' "<="
      69             : %left '+' '-'
      70             : %left '%' "\\/" '\\' '/' '*' ">>" "<<"
      71             : %left SIGN
      72             : %right '^'
      73             : %left '#'
      74             : %left '!' '~' '[' DERIV
      75             : %left '\''
      76             : %left '.'
      77             : %left "++" "--"
      78             : %left '('
      79             : %left ':'
      80             : %type <val> seq sequence
      81             : %type <val> range matrix matrix_index expr exprno
      82             : %type <val> lvalue deriv
      83             : %type <val> matrixelts matrixeltsno matrixlines arg listarg definition
      84             : %type <val> funcid memberid
      85             : %type <val> backticks history
      86             : %type <val> compr in inseq
      87           0 : %destructor { pari_discarded++; } seq matrix range matrix_index expr exprno lvalue matrixelts matrixeltsno matrixlines arg listarg definition funcid memberid backticks history compr in inseq deriv
      88             : %%
      89             : 
      90      932648 : sequence: seq        {$$=$1; (void) pari_nerrs;} /* skip the destructor */
      91             : ;
      92             : 
      93       15070 : seq: /**/ %prec SEQ  {$$=NOARG(@$);}
      94     1311448 :    | expr %prec SEQ  {$$=$1;}
      95       43694 :    | seq ';'         {$$=$1; @$=@1;}
      96       32172 :    | seq ';' expr    {$$=newnode(Fseq,$1,$3,&@$);}
      97             : ;
      98             : 
      99         952 : range: /* */          { $$=newnode(Frange,NORANGE(@$),NORANGE(@$),&@$); }
     100       14107 :      | expr           { $$=newnode(Frange,$1,NORANGE(@$),&@$); }
     101         735 :      | expr ".." expr { $$=newnode(Frange,$1,$3,&@$); }
     102          98 :      | '^' expr       { $$=newnode(Frange,NORANGE(@$),$2,&@$); }
     103             : ;
     104             : 
     105        1750 : matrix_index: '[' range ',' range ']' {$$=newnode(Fmatrix,$2,$4,&@$);}
     106       12392 :             | '[' range ']'           {$$=newnode(Fmatrix,$2,-1,&@$);}
     107             : ;
     108             : 
     109          35 : backticks: '`' {$$=1;}
     110          84 :          | backticks '`' {$$=$1+1;}
     111             : ;
     112             : 
     113          49 : history: '%'           {$$=newopcall(OPhist,-1,-1,&@$);}
     114          14 :        | '%' KINTEGER  {$$=newopcall(OPhist,newintnode(&@2),-1,&@$);}
     115          28 :        | '%' backticks {$$=newopcall(OPhist,newnode(Fsmall,-$2,-1,&@$),-1,&@$);}
     116           7 :        | '%' '#'          {$$=newopcall(OPhisttime,-1,-1,&@$);}
     117          11 :        | '%' '#' KINTEGER {$$=newopcall(OPhisttime,newintnode(&@3),-1,&@$);}
     118           7 :        | '%' '#' backticks{$$=newopcall(OPhisttime,newnode(Fsmall,-$3,-1,&@$),-1,&@$);}
     119             : ;
     120             : 
     121         147 : deriv: '\'' {$$ = 1;}
     122          42 :      | deriv '\'' {$$ = $1+1;}
     123             : ;
     124             : 
     125    11950996 : expr: KINTEGER %prec INT  {$$=newintnode(&@1);}
     126        5422 :     | KREAL               {$$=newconst(CSTreal,&@$);}
     127           0 :     | '.'                 {$$=newconst(CSTreal,&@$);}
     128           0 :     | KINTEGER '.' KENTRY {$$=newnode(Ffunction,newconst(CSTmember,&@3),
     129             :                                                 newintnode(&@1),&@$);}
     130      880059 :     | KSTRING       {$$=newconst(CSTstr,&@$);}
     131        3685 :     | '\'' KENTRY   {$$=newconst(CSTquote,&@$);}
     132         116 :     | history           {$$=$1;}
     133         322 :     | expr '(' listarg ')'  {$$=newnode(Fcall,$1,$3,&@$);}
     134      202341 :     | funcid            {$$=$1;}
     135      291079 :     | lvalue %prec LVAL {$$=$1;}
     136     4472907 :     | matrix            {$$=$1;}
     137         823 :     | compr             {$$=$1;}
     138        9106 :     | definition        {$$=$1;}
     139        1187 :     | matrix '=' expr {$$=newnode(Fassign,$1,$3,&@$);}
     140       50396 :     | lvalue '=' expr {$$=newnode(Fassign,$1,$3,&@$);}
     141         183 :     | lvalue "++"     {$$=newopcall(OPpp,$1,-1,&@$);}
     142          28 :     | lvalue "--"     {$$=newopcall(OPss,$1,-1,&@$);}
     143         195 :     | lvalue "*="   expr {$$=newopcall(OPme,$1,$3,&@$);}
     144          35 :     | lvalue "/="   expr {$$=newopcall(OPde,$1,$3,&@$);}
     145           7 :     | lvalue "\\/=" expr {$$=newopcall(OPdre,$1,$3,&@$);}
     146           7 :     | lvalue "\\="  expr {$$=newopcall(OPeuce,$1,$3,&@$);}
     147           7 :     | lvalue "%="   expr {$$=newopcall(OPmode,$1,$3,&@$);}
     148           7 :     | lvalue "<<="  expr {$$=newopcall(OPsle,$1,$3,&@$);}
     149           7 :     | lvalue ">>="  expr {$$=newopcall(OPsre,$1,$3,&@$);}
     150         229 :     | lvalue "+="   expr {$$=newopcall(OPpe,$1,$3,&@$);}
     151          63 :     | lvalue "-="   expr {$$=newopcall(OPse,$1,$3,&@$);}
     152         819 :     | '!' expr         {$$=newopcall(OPnb,$2,-1,&@$);}
     153        3766 :     | '#' expr         {$$=newopcall(OPlength,$2,-1,&@$);}
     154         413 :     | expr "||"  expr  {$$=newopcall(OPor,$1,$3,&@$);}
     155         816 :     | expr "&&"  expr  {$$=newopcall(OPand,$1,$3,&@$);}
     156           0 :     | expr '&'   expr  {$$=newopcall(OPand,$1,$3,&@$);}
     157         343 :     | expr "===" expr  {$$=newopcall(OPid,$1,$3,&@$);}
     158       11572 :     | expr "=="  expr  {$$=newopcall(OPeq,$1,$3,&@$);}
     159        2149 :     | expr "!="  expr  {$$=newopcall(OPne,$1,$3,&@$);}
     160         125 :     | expr ">="  expr  {$$=newopcall(OPge,$1,$3,&@$);}
     161         494 :     | expr '>'   expr  {$$=newopcall(OPg,$1,$3,&@$);}
     162         237 :     | expr "<="  expr  {$$=newopcall(OPle,$1,$3,&@$);}
     163        1361 :     | expr '<'   expr  {$$=newopcall(OPl,$1,$3,&@$);}
     164       28941 :     | expr '-'   expr  {$$=newopcall(OPs,$1,$3,&@$);}
     165       56518 :     | expr '+'   expr  {$$=newopcall(OPp,$1,$3,&@$);}
     166         147 :     | expr "<<"  expr  {$$=newopcall(OPsl,$1,$3,&@$);}
     167          21 :     | expr ">>"  expr  {$$=newopcall(OPsr,$1,$3,&@$);}
     168         686 :     | expr '%'   expr  {$$=newopcall(OPmod,$1,$3,&@$);}
     169          28 :     | expr "\\/" expr  {$$=newopcall(OPdr,$1,$3,&@$);}
     170         189 :     | expr '\\'  expr  {$$=newopcall(OPeuc,$1,$3,&@$);}
     171      116276 :     | expr '/'   expr  {$$=newopcall(OPd,$1,$3,&@$);}
     172       58444 :     | expr '*'   expr  {$$=newopcall(OPm,$1,$3,&@$);}
     173          84 :     | '+' expr %prec SIGN {$$=$2;}
     174     4110799 :     | '-' expr %prec SIGN {$$=newopcall(OPn,$2,-1,&@$);}
     175       73824 :     | expr '^' expr {$$=newopcall(OPpow,$1,$3,&@$);}
     176        4879 :     | expr '~' {$$=newopcall(OPtrans,$1,-1,&@$);}
     177         147 :     | expr deriv %prec DERIV {$$=newopcall(OPderivn,$1, newnode(Fsmall,$2,-1,&@$),&@$);}
     178         243 :     | expr '!'  {$$=newopcall(OPfact,$1,-1,&@$);}
     179          28 :     | expr '#'  {$$=newopcall(OPprim,$1,-1,&@$);}
     180        4506 :     | expr matrix_index {$$=newnode(Fmatcoeff,$1,$2,&@$);}
     181       12565 :     | memberid {$$=$1;}
     182           0 :     | expr ':' KENTRY   {$$=newnode(Ftag,$1,0,&@$);}
     183       14040 :     | '(' expr ')' {$$=$2;}
     184             : ;
     185             : 
     186      346610 : lvalue: KENTRY %prec LVAL   {$$=newnode(Fentry,newconst(CSTentry,&@1),-1,&@$);}
     187        9636 :       | lvalue matrix_index {$$=newnode(Fmatcoeff,$1,$2,&@$);}
     188           0 :       | lvalue ':' KENTRY   {$$=newnode(Ftag,$1,newconst(CSTentry,&@2),&@$);}
     189             : ;
     190             : 
     191    11964420 : exprno: expr {$$=$1;}
     192          35 :       | /**/ {$$=NOARG(@$);}
     193             : 
     194    11964448 : matrixeltsno: matrixelts {$$=$1;}
     195           7 :             | /**/ {$$=NOARG(@$);}
     196             : ;
     197             : 
     198     4136618 : matrixelts: expr {$$=$1;}
     199    11964455 :           | matrixeltsno ',' exprno {$$=newnode(Fmatrixelts,$1,$3,&@$);}
     200             : ;
     201             : 
     202        8610 : matrixlines: matrixelts  ';' matrixelts {$$=newnode(Fmatrixlines,$1,$3,&@$);}
     203       20902 :            | matrixlines ';' matrixelts {$$=newnode(Fmatrixlines,$1,$3,&@$);}
     204             : ;
     205             : 
     206      365085 : matrix: '[' ']'             {$$=newnode(Fvec,-1,-1,&@$);}
     207         902 :       | '[' expr ".." expr ']' {$$=newopcall(OPrange,$2,$4,&@$);}
     208         994 :       | '[' ';' ']'         {$$=newnode(Fmat,-1,-1,&@$);}
     209     4098503 :       | '[' matrixelts ']'  {$$=newnode(Fvec,$2,-1,&@$);}
     210        8610 :       | '[' matrixlines ']' {$$=newnode(Fmat,$2,-1,&@$);}
     211             : ;
     212             : 
     213         921 : in: lvalue '<' '-' expr {$$=newnode(Flistarg,$4,$1,&@$);}
     214             : ;
     215             : 
     216         676 : inseq: in                    {$$=newopcall(OPcompr,$1,-2,&@$);}
     217         147 :      | in ',' expr           {$$=newopcall3(OPcompr,$1,-2,$3,&@$);}
     218          84 :      | in ';' inseq          {$$=newopcall(OPcomprc,$1,$3,&@$);}
     219          14 :      | in ',' expr ';' inseq {$$=newopcall3(OPcomprc,$1,$5,$3,&@$);}
     220             : ;
     221             : 
     222         823 : compr: '[' expr '|' inseq ']' {$$=addcurrexpr($4,$2,&@$);}
     223             : ;
     224             : 
     225      384764 : arg: seq        {$$=$1;}
     226          21 :    | lvalue '[' ".." ']' {$$=newnode(Fvararg,$1,-1,&@$);}
     227        1505 :    | '&' lvalue {$$=newnode(Frefarg,$2,-1,&@$);}
     228         588 :    | '~' lvalue {$$=newnode(Findarg,$2,-1,&@$);}
     229         140 :    | arg error  {if (!pari_once) { yyerrok; } pari_once=1;}  expr
     230         105 :                      {pari_once=0; $$=newopcall(OPcat,$1,$4,&@$);}
     231             : ;
     232             : 
     233      210423 : listarg: arg {$$=$1;}
     234      176455 :        | listarg ',' arg {$$=newnode(Flistarg,$1,$3,&@$);}
     235             : ;
     236             : 
     237      202341 : funcid: KENTRY '(' listarg ')' {$$=newnode(Ffunction,newconst(CSTentry,&@1),$3,&@$);}
     238             : ;
     239             : 
     240       12565 : memberid: expr '.' KENTRY {$$=newnode(Ffunction,newconst(CSTmember,&@3),$1,&@$);}
     241             : ;
     242             : 
     243             : definition: KENTRY '(' listarg ')' '=' seq %prec DEFFUNC
     244        3660 :                                    {$$=newfunc(CSTentry,&@1,$3,$6,&@$);}
     245             :           | expr '.' KENTRY '=' seq %prec DEFFUNC
     246          14 :                                    {$$=newfunc(CSTmember,&@3,newnode(Findarg,$1,-1,&@1),$5,&@$);}
     247        1332 :           | lvalue "->" seq              {$$=newnode(Flambda, $1,$3,&@$);}
     248        4100 :           | '(' listarg ")->" seq        {$$=newnode(Flambda, $2,$4,&@$);}
     249             : ;
     250             : 
     251             : %%

Generated by: LCOV version 1.16