Focal Point Banner
Community Center Education Summit Technical Support User Groups
Let's Get Social!

Facebook Twitter LinkedIn YouTube
Focal Point    Focal Point Forums  Hop To Forum Categories  WebFOCUS/FOCUS Forum on Focal Point     [CLOSED] Variable assignment problem
Go
New
Search
Notify
Tools
Reply
  
[CLOSED] Variable assignment problem
 Login/Join
 
Virtuoso
posted
We have (part of) some code that gets values from a database field and logs that to a file.
It turns out that in some rare occasions, the field ends with newline+carriage return, and that breaks our Dialog Manager code.

Example:
-* Simulate data from database
-* Normally called with:  EX dw_logParameter PARM='TUPLE',TUPLE=&TUPLE.QUOTEDSTRING 
-SET &PARM = 'TUPLE';
-SET &TUPLE = 'Frobblemox' || HEXBYT(13, 'A1') || HEXBYT(10, 'A1');

-* dw_logParameter.fex
-SET &PVAR = '&' || &PARM;
-SET &PVAL = RTRIM(&PVAR.EVAL);
-SET &_MESSAGE = &PARM || '=' || &PVAL.QUOTEDSTRING;

-TYPE &_MESSAGE


Which results in:
quote:
 0 NUMBER OF RECORDS IN TABLE=        0  LINES=      0
 0 ERROR AT OR NEAR LINE     39  IN PROCEDURE ADHOCRQ FOCEXEC *
 (FOC257) MISSING QUOTE MARKS: 'Frobblemox


Is there any way to catch this in the breaking code?

The text causing the issue is part of the primary key of a table; modifying the value on read would break references to the records in this table.

I could exclude this data, the rows are marked with a 'Cancelled' status, but sometimes that is relevant information, so I consider that among the last resorts.

This message has been edited. Last edited by: FP Mod Chuck,


WebFOCUS 8.1.03, Windows 7-64/2008-64, IBM DB2/400, Oracle 11g & RDB, MS SQL-Server 2005, SAP, PostgreSQL 11, Output: HTML, PDF, Excel 2010
: Member of User Group Benelux :
 
Posts: 1652 | Location: Enschede, Netherlands | Registered: August 12, 2010Reply With QuoteReport This Post
Virtuoso
posted Hide Post
Does this is good for you Wep ?
-* Simulate data from database
-* Normally called with:  EX dw_logParameter PARM='TUPLE',TUPLE=&TUPLE.QUOTEDSTRING 
-SET &PARM = 'TUPLE';
-SET &TUPLE = '''' || 'Frobblemox' || HEXBYT(13, 'A1') || HEXBYT(10, 'A1') || '''';

-* dw_logParameter.fex
-SET &PVAR = '&' || &PARM;
-SET &PVAL = RTRIM(&PVAR.EVAL);
-SET &_MESSAGE = &PARM || '=' || &PVAL.QUOTEDSTRING;

-TYPE &_MESSAGE



WF versions : Prod 8.2.0.1M gen 240, Dev 8.2.04 gen 48, OS : Windows, DB : MSSQL, Outputs : HTML, Excel, PDF
In Focus since 2007
 
Posts: 2231 | Location: Montreal Area, Qc, CA | Registered: September 25, 2013Reply With QuoteReport This Post
Virtuoso
posted Hide Post
Interesting idea to add extra quotes at the procedure calling parameter.

Unfortunately, it would change the output relative to previous output; we eventually store the result in a database table. I'm not too worried about the backwards compatibility there, though.

I would prefer to fix that procedure parameter value within the procedure. After all, the procedure accepted the parameter value, it should be able to use it!

Well, at least if that turns out to be impossible, I have a workaround. Thanks.


WebFOCUS 8.1.03, Windows 7-64/2008-64, IBM DB2/400, Oracle 11g & RDB, MS SQL-Server 2005, SAP, PostgreSQL 11, Output: HTML, PDF, Excel 2010
: Member of User Group Benelux :
 
Posts: 1652 | Location: Enschede, Netherlands | Registered: August 12, 2010Reply With QuoteReport This Post
Master
posted Hide Post
What about trimming off the TRAILING line feed after the RTRIM?
  
-* Simulate data from database
-* Normally called with:  EX dw_logParameter PARM='TUPLE',TUPLE=&TUPLE.QUOTEDSTRING 
-SET &PARM = 'TUPLE';
-SET &TUPLE = 'Frobblemox' || HEXBYT(13, 'A1') || HEXBYT(10, 'A1');

-* dw_logParameter.fex
-SET &PVAR = '&' || &PARM;
-SET &PVAL = TRIM_(TRAILING, HEXBYT(10, 'A1'), RTRIM(&PVAR.EVAL));
-SET &_MESSAGE = &PARM || '=' || &PVAL.QUOTEDSTRING;

-TYPE &_MESSAGE


That gave me:
quote:

 PVAL 'Frobblemox'
 TUPLE=Frobblemox  



Hallway
WF(Prod):8202M
WF(Test):8202M
OS/Platform:Win 10
Outputs:All
 
Posts: 491 | Location: Salt Lake City, UT, USA | Registered: November 18, 2015Reply With QuoteReport This Post
  Powered by Social Strata  
 

Focal Point    Focal Point Forums  Hop To Forum Categories  WebFOCUS/FOCUS Forum on Focal Point     [CLOSED] Variable assignment problem

Copyright © 1996-2018 Information Builders, leaders in enterprise business intelligence.