Vely logo install

Vely 15.2.0 released on Jan 18, 2023
Articles updated Jan 17, 2023


Issues with this documentation page? Report here.


Free memory.


delete-mem <memory> status [ define ] <status>


delete-mem frees memory allocated by Vely. Do not use it on memory allocated by any C-library functions (such as malloc(), calloc() or realloc()).

delete-mem will handle memory violations or invalid pointers, and will not error out if there is an issue (Vely handles SIGSEGV, SIGBUS and SIGABRT signals typically raised for most issues). Rather, you can obtain the status of freeing memory in variable <status> by using "status" clause (you can create this number variable with "define" if it does not exist). The reason for this is that freeing memory is in many cases unnecessary as Vely will automatically do so at the end of each request and problems in freeing memory will not affect doing so in the end.

If <status> is VV_OKAY, the memory has been freed successfully. If <status> is VV_ERR_MEMORY, there was a problem; most likely <string> was not a valid memory pointer allocated by any of Vely statements; or it was a bad memory pointer for any number of reasons. Either way, delete-mem will not error out, and your program will continue.


Allocate and free memory:

new-mem define mystr size 300
delete-mem mystr status define st
if (st != VV_OKAY) {
    @Error in memory release!

Free memory allocated by write-string (consisting of 100 "Hello World" statements):

write-string define ws
    num i;
    for (i = 0; i < 100; i++) {
        @Hello World
delete-mem ws

See also:

Memory ( delete-mem   memory_handling   new-mem   resize-mem  )  SEE ALL (documentation)

Copyright (c) 2022 DaSoftver LLC. Vely is a trademark of Dasoftver LLC. The software and information herein are provided "AS IS" and without any warranties or guarantees of any kind. Vely elephant logo (c) 2022 DaSoftver LLC. This web page is licensed under CC-BY-SA-4.0.