Diff for /freem/src/expr.c between versions 1.7 and 1.8

version 1.7, 2025/03/22 03:39:23 version 1.8, 2025/03/22 04:47:18
Line 24 Line 24
  *   along with FreeM.  If not, see <https://www.gnu.org/licenses/>.   *   along with FreeM.  If not, see <https://www.gnu.org/licenses/>.
  *   *
  *   $Log$   *   $Log$
    *   Revision 1.8  2025/03/22 04:47:18  snw
    *   Silently truncate long names in STRING exprs when  evaluates to an obsolete MDC standard
    *
  *   Revision 1.7  2025/03/22 03:39:23  snw   *   Revision 1.7  2025/03/22 03:39:23  snw
  *   Fix reverse query polyfill call-in from C side and make NAME exprs silently truncate long names in obsolete MDC dialects   *   Fix reverse query polyfill call-in from C side and make NAME exprs silently truncate long names in obsolete MDC dialects
  *   *
Line 366  scan_name: Line 369  scan_name:
                     merr_raise (INVEXPR);                      merr_raise (INVEXPR);
                     return;                      return;
                 }                  }
                   
                 varnam[i++] = ch;                  if ((i + 1) <= max_namlen) {
                       varnam[i++] = ch;
                   }
                   else {
                       if ((rtn_dialect () == D_M77) ||
                           (rtn_dialect () == D_M84) ||
                           (rtn_dialect () == D_M90) ||
                           (rtn_dialect () == D_M95)) {
                           /* silently truncate... yeah, the standard is stupid af */
                           continue;
                       }
                       else {
                           merr_raise (M56);
                           return;
                       }
                   }                
   
                 lastch = ch;                  lastch = ch;
             }              }
Line 383  scan_name: Line 401  scan_name:
         else {          /* local variable name */          else {          /* local variable name */
   
             while (isalnum (ch = *++codptr)) {              while (isalnum (ch = *++codptr)) {
                 varnam[i++] = ch;                  
                   if ((i + 1) <= max_namlen) {
                       varnam[i++] = ch;
                   }
                   else {
                       if ((rtn_dialect () == D_M77) ||
                           (rtn_dialect () == D_M84) ||
                           (rtn_dialect () == D_M90) ||
                           (rtn_dialect () == D_M95)) {
                           /* silently truncate... yeah, the standard is stupid af */
                           continue;
                       }
                       else {
                           merr_raise (M56);
                           return;
                       }
                   }                
                   
             }              }
                   
             varnam[i] = EOL;              varnam[i] = EOL;

Removed from v.1.7  
changed lines
  Added in v.1.8


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>