This portal is to open public enhancement requests against IBM Power Systems products, including IBM i. To view all of your ideas submitted to IBM, create and manage groups of Ideas, or create an idea explicitly set to be either visible by all (public) or visible only to you and IBM (private), use the IBM Unified Ideas Portal (https://ideas.ibm.com).
We invite you to shape the future of IBM, including product roadmaps, by submitting ideas that matter to you the most. Here's how it works:
Start by searching and reviewing ideas and requests to enhance a product or service. Take a look at ideas others have posted, and add a comment, vote, or subscribe to updates on them if they matter to you. If you can't find what you are looking for,
Post an idea.
Get feedback from the IBM team and other customers to refine your idea.
Follow the idea through the IBM Ideas process.
Welcome to the IBM Ideas Portal (https://www.ibm.com/ideas) - Use this site to find out additional information and details about the IBM Ideas process and statuses.
IBM Unified Ideas Portal (https://ideas.ibm.com) - Use this site to view all of your ideas, create new ideas for any IBM product, or search for ideas across all of IBM.
ideasibm@us.ibm.com - Use this email to suggest enhancements to the Ideas process or request help from IBM for submitting your Ideas.
IBM does not intend to provide a solution to this request at this time, so it is being closed.
This team has quite a long list of higher priority requirements, so this request is not likely to be implemented anytime soon.
In cases where the RPG programmer does not have the ability to add additional procedures to the service program providing the procedure that returns a data structure, the RPG programmer could do one of the following:
1. Create a wrapper module with additional procedures to return individual subfields of the returned data structure.
2. Request that the owner of the procedure provide additional procedures with more granular information.
IBM has received the requirement and is evaluating it. IBM will provide a response after evaluation is complete.
Thanks for the comment. Of course, if you need 10 fields you should still store the result in a data structure.
The problem should not be so different from using procedures that return one field.
I would also feel tempted to re-code the following code with a one-field return value:
if getCurrentTemperature() > 0;
dsply getCurrentTemperature();
elseif getCurrentTemperature() > 10;
// blabla
endif;
In web APIs you often receive huge data structures, e.g. if you call a web service to get weather data, you might want to only use the temperature in your program. So getWeatherDataFromApi(date:time).temperature would make sense to me.
In another program I would use getWeatherDataFromApi(date:time).weatherWarning, and in the third I would store the returned data structure in a field to output all of the data.
Or I might want to use just a sub data structure:
Program A: MyWeatherDS = getWeatherDataFromApi().currentWeatherDataStructure;
Program B: MyWeatherDS = getWeatherDataFromApi().tomorrowsWeatherDataStructure;
So, if there are 10 fields to check, the procedure is going to be called 10 times? Or is the system going to check to see if input parameters have changed to decide to actually perform the call (more overhead)? What if the procedure is not deterministic? I see potential for really bad performance or undesired results with this idea.