bug 7040 : Modification of the example and the description for getMatrixOfIntegerPrec... 92/14092/2
Sylvain GENIN [Fri, 21 Mar 2014 08:56:15 +0000 (09:56 +0100)]
Change-Id: Ied91fa5bf2a1cdd8ebc06d6e7e188ba87f29f7a5

scilab/CHANGES_5.5.X
scilab/modules/api_scilab/help/en_US/low_level_functions/int_getmatrixofintegerprecision_api.xml

index d8cf21c..9f0ca94 100644 (file)
@@ -305,6 +305,8 @@ Scilab Bug Fixes
 
 * Bug #7038 fixed - A toggle button now manages datatip mode.
 
+* Bug #7040 fixed - Example and the description for getMatrixOfIntegerPrecision modified.
+
 * Bug #7047 fixed - milk_drop is now obsolete. It will be removed in Scilab 5.5.1, but will be kept as a demonstration.
 
 * Bug #7051 fixed - fieldnames help page updated.
index 547d4f4..d41fb0a 100644 (file)
@@ -53,7 +53,7 @@
                 <term>_piPrecision</term>
                 <listitem>
                     <para>
-                        Return precision of an integer variable. ( SCI_INT8, SCI_UINT8, SCI_INT16, ... )
+                        Return precision of an integer variable. If value is greater then 10 then the variable is unsigned.
                     </para>
                 </listitem>
             </varlistentry>
@@ -84,143 +84,85 @@ SciErr printf_info(int _iVar);
 
 int common_function(char *fname,unsigned long fname_len)
 {
-    SciErr sciErr;
-    int i;
-    int *piAddr1    = NULL;
-    int iBool       = 0;
-
-    for(i = 0 ; i < nbInputArgument(pvApiCtx) ; i++)
-    {
-        sciErr = printf_info(i + 1);
-        if(sciErr.iErr)
-        {
-            printError(&sciErr, 0);
-            break;
-        }
-        sciprint("\n\n");
-    }
-
-    //1 for true, 0 for false
-    iBool = sciErr.iErr == 0 ? 1 : 0;
-
-    sciErr = createMatrixOfBoolean(pvApiCtx, nbInputArgument(pvApiCtx) + 1, 1, 1, &iBool);
-    if(sciErr.iErr)
-    {
-        printError(&sciErr, 0);
-        return 0;
-    }
-
-    //assign allocated variables to Lhs position
-    AssignOutputVariable(pvApiCtx, 1) = nbInputArgument(pvApiCtx) + 1;
-    return 0;
+       SciErr sciErr;
+       int i;
+       int *piAddr1    = NULL;
+       int iBool       = 0;
+
+       for(i = 0 ; i < nbInputArgument(pvApiCtx) ; i++)
+       {
+               sciErr = printf_info(i + 1);
+               if(sciErr.iErr)
+               {
+                       printError(&sciErr, 0);
+                       break;
+               }
+               sciprint("\n\n");
+       }
+
+       //1 for true, 0 for false
+       iBool = sciErr.iErr == 0 ? 1 : 0;
+
+       sciErr = createMatrixOfBoolean(pvApiCtx, nbInputArgument(pvApiCtx) + 1, 1, 1, &iBool);
+       if(sciErr.iErr)
+       {
+               printError(&sciErr, 0);
+               return 0;
+       }
+
+       //assign allocated variables to Lhs position
+       AssignOutputVariable(pvApiCtx, 1) = nbInputArgument(pvApiCtx) + 1;
+       return 0;
 }
+
 SciErr printf_info(int _iVar)
 {
-    SciErr sciErr;
-    int* piAddr     = NULL;
-    int iType       = 0;
-    int iRows       = 0;
-    int iCols       = 0;
-    int iItem       = 0;
-    int iComplex    = 0;
-
-    sciErr = getVarAddressFromPosition(pvApiCtx, _iVar, &piAddr);
-    if(sciErr.iErr)
-    {
-        return sciErr;
-    }
-
-    sciprint("Variable %d information:\n", _iVar);
-
-    sciErr = getVarType(pvApiCtx, piAddr, &iType);
-    if(sciErr.iErr)
-    {
-        return sciErr;
+       SciErr sciErr;
+       int* piAddr     = NULL;
+       int iType       = 0;
+
+       sciErr = getVarAddressFromPosition(pvApiCtx, _iVar, &piAddr);
+       if(sciErr.iErr)
+       {
+               return sciErr;
+       }
+
+       sciprint("Variable %d information:\n", _iVar);
+
+       sciErr = getVarType(pvApiCtx, piAddr, &iType);
+       if(sciErr.iErr)
+       {
+               return sciErr;
+       }
+
+       sciprint("\tType: ");
+       if(iType == sci_ints)
+       {
+               char pstSigned[]    = "signed";
+               char pstUnsigned[]  = "unsigned";
+               char* pstSign       = pstSigned;
+               int iPrec           = 0;
+
+               sciErr = getMatrixOfIntegerPrecision(pvApiCtx, piAddr, &iPrec);
+               if(sciErr.iErr)
+               {
+                       return sciErr;
+               }
+
+               if(iPrec > 10)
+               {
+                       pstSign = pstUnsigned;
+               }
+
+               sciprint("%s integer %d bits\n", pstSign, (iPrec % 10) * 8);
     }
-
-    sciprint("\tType: ");
-    switch(iType)
-    {
-        case sci_matrix :
-            sciprint("double\n");
-            break;
-        case sci_poly :
-            sciprint("polynomial\n");
-            break;
-        case sci_boolean :
-            sciprint("boolean\n");
-            break;
-        case sci_sparse :
-            sciprint("sparse\n");
-            break;
-        case sci_boolean_sparse :
-            sciprint("boolean_sparse\n");
-            break;
-        case sci_ints :
-        {
-            char pstSigned[]    = "signed";
-            char pstUnsigned[]  = "unsigned";
-            char* pstSign       = pstSigned;
-            int iPrec           = 0;
-
-            sciErr = getMatrixOfIntegerPrecision(pvApiCtx, piAddr, &iPrec);
-            if(sciErr.iErr)
-            {
-                return sciErr;
-            }
-
-            if(iPrec > 10)
-            {
-                pstSign = pstUnsigned;
-            }
-
-            sciprint("%s integer %d bits\n", pstSign, (iPrec % 10) * 8);
-        }
-        break;
-        case sci_strings :
-            sciprint("strings\n");
-            break;
-        case sci_list :
-            sciprint("list\n");
-            break;
-        case sci_tlist :
-            sciprint("tlist\n");
-            break;
-        case sci_mlist :
-            sciprint("mlist\n");
-            break;
-        default :
-            sciprint("Not manage by this function\n");
-            return sciErr;
-    }
-
-    if(isVarComplex(pvApiCtx, piAddr))
-    {
-        sciprint("\tComplex: Yes\n");
-    }
-
-    sciprint("\tDimensions: ");
-    if(isVarMatrixType(pvApiCtx, piAddr))
-    {
-        sciErr = getVarDimension(pvApiCtx, piAddr, &iRows, &iCols);
-        if(sciErr.iErr)
-        {
-            return sciErr;
-        }
-
-        sciprint("%d x %d", iRows, iCols);
-    }
-    else
-    {
-        sciErr = getListItemNumber(pvApiCtx, piAddr, &iItem);
-        if(sciErr.iErr)
-        {
-            return sciErr;
-        }
-
-        sciprint("%d", iItem);
+       else
+       {
+               sciprint("Not manage by this function\n");
+               return sciErr;
     }
-    return sciErr;
+       
+       return sciErr;
 }
  ]]>
         </programlisting>