Added missing properties.
[tangerine.git] / rom / dos / deletevar.c
blob41a3b0aeaf5fb22e6390945a4231da5b3c40e6e3
1 /*
2 Copyright © 1995-2007, The AROS Development Team. All rights reserved.
3 $Id$
5 Desc: DeleteVar() - Deletes a local or environmental variable.
6 Lang: english
7 */
8 #include "dos_intern.h"
9 #include <proto/exec.h>
11 /*****************************************************************************
13 NAME */
14 #include <dos/var.h>
15 #include <proto/dos.h>
17 AROS_LH2(LONG, DeleteVar,
19 /* SYNOPSIS */
20 AROS_LHA(CONST_STRPTR, name, D1),
21 AROS_LHA(ULONG , flags, D2),
23 /* LOCATION */
24 struct DosLibrary *, DOSBase, 152, Dos)
26 /* FUNCTION
27 Deletes a local or environment variable.
29 The default is to delete a local variable if one was found,
30 or to delete a global environmental variable otherwise.
32 A global environmental variable will only be deleted for the
33 type LV_VAR.
35 INPUTS
36 name - the name of the variable to delete. Note that variable
37 names follow the same syntax and semantics as filesystem
38 names.
40 flags - A combination of the type of variable (low 8 bits), and
41 flags to control the behaviour of this routine.
42 Currently defined flags:
44 GVF_LOCAL_ONLY - delete a local variable.
45 GVF_GLOBAL_ONLY - delete a global environmental variable.
48 RESULT
49 If non-zero, the variable was deleted successfully,
50 DOSFALSE otherwise.
52 NOTES
53 When the GVF_SAVE_VAR flag is set, and only one of the global
54 variable pair could be deleted (either the in memory or on disk
55 variable), DOSFALSE will be returned.
57 EXAMPLE
59 BUGS
61 SEE ALSO
63 INTERNALS
64 XXX: Find out whether GVF_SAVE_VAR does actually effect this function.
66 *****************************************************************************/
68 AROS_LIBFUNC_INIT
70 if(name)
72 if((flags & GVF_GLOBAL_ONLY) == 0)
74 struct LocalVar *lv = NULL;
75 lv = FindVar(name, flags & 0xFF);
76 if(lv)
78 /* free allocated memory for value of variable */
79 FreeMem(lv -> lv_Value, lv -> lv_Len);
81 Remove((struct Node *)lv);
82 FreeVec(lv);
83 return DOSTRUE;
85 } /* !global only => local variable */
87 /* If we are allowed to delete globals, and not deleting an alias */
88 if( ((flags & GVF_LOCAL_ONLY) == 0) && ((flags & 0x7F) == 0) )
90 /* Variable names should be less than 256 characters. */
91 /* as a standard: look for the file in ENV: if no path is
92 given in the variable
94 UBYTE filebuffer[256] = "ENV:";
95 BPTR filelock;
96 BOOL delMemory = FALSE, delDisk = FALSE;
98 AddPart(filebuffer, name, 256);
100 if((filelock = Lock(filebuffer, EXCLUSIVE_LOCK)))
102 UnLock(filelock);
103 delMemory = DeleteFile(filebuffer);
106 if(flags & GVF_SAVE_VAR)
108 filebuffer[0] = 0;
109 AddPart(filebuffer, "ENVARC:", 256);
110 AddPart(filebuffer, name, 256);
112 if((filelock = Lock(filebuffer, EXCLUSIVE_LOCK)))
114 UnLock(filelock);
115 delDisk = DeleteFile(filebuffer);
118 else delDisk = TRUE;
120 if( (delDisk != FALSE) && (delMemory != FALSE))
121 return TRUE;
122 } /* !local only => Global variable */
123 } /* if(name) */
125 return DOSFALSE;
127 AROS_LIBFUNC_EXIT
128 } /* DeleteVar */