Skip to Main Content
IBM Z Software


This portal is to open public enhancement requests against IBM Z Software products. 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).


Shape the future of IBM!

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:

Search existing ideas

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 your ideas
  1. Post an idea.

  2. Get feedback from the IBM team and other customers to refine your idea.

  3. Follow the idea through the IBM Ideas process.


Specific links you will want to bookmark for future use

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.

Status Delivered
Workspace PL/I Compilers
Created by Guest
Created on Jan 24, 2017

Add FASTALLOC builtin for allocation in AREA

Since EPLI 4.4, the ALLOC() builtin allows the specification of an AREA to do the allocation in, which is extremely useful as it allows the complete clean-up of complex list and tree structures with a single "AREA=EMPTY();" statement.

Idea priority Medium
  • Guest
    Reply
    |
    Dec 12, 2017

    this has been delivered with the 5.2 update of 12 Dec

  • Guest
    Reply
    |
    Feb 22, 2017

    thanks for the reply, we'll raise AREA etc if not enough storage, but we won't name it FASTALLOC - it might not always be faster

  • Guest
    Reply
    |
    Feb 17, 2017

    Given that I originally suggested the enhancement of the ALLOC() builtin to allow the fast clean-up of trees and lists (via AREA=EMPTY()", the current RFE should make the allocations as fast as possible, given the fact that the trees resulting from parsing XML might be substantial.

    A pure inline solution would be the best, but it should definitely generate the AREA condition if not enough space is available, so that the program can then take corrective action, such as moving the AREA to a larger one, or allocating a new one (if the original is CONTROLLED), so that upon return from the condition handler the repeated ALLOC would succeed. However, I would expect most users to empirically tune the the size of the AREA to be used for building the tree to based on actual data to prevent this from ever happening.

    A compiler option to allow the compiler to generate code to actually call the current library routine to scan for free space might be useful, but given the fact that it's somewhat unlikely that branches or leafs of an XML tree would be deleted in the middle of parsing the XML input, it might be superfluous, but a "*PROCESS DEFAULT(NEXTALLOC(NOSCAN/SCAN))" would give users a choice, with "NOSCAN" the default.

    And NEXTALLOC is a much better name!

  • Guest
    Reply
    |
    Feb 15, 2017

    I would prefer to do this via a new BIF called ALLOCNEXT, as in ALLOCNEXT( n, a ) where n is an amount and a the area in which to allocate n bytes. It would try to get the n bytes from the next/first available space and would do that inline. But I have a question: should it raise STORAGE or AREA if that bit is too small? or should it generate the loop of code and library call it normally generates if that bit is to small? the latter would produce more code of course and might duplicate what's already available. But it also provides more function. Any preferences??