📄 list.c
字号:
/*
Copyright 1994-2003 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
02111-1307, USA.
You may contact the author at:
mailto::camille@bluegrass.net
or by snail mail at:
David Lindauer
850 Washburn Ave Apt 99
Louisville, KY 40222
*/
#include <stdio.h>
#include <stdarg.h>
#include <stdlib.h>
#include <ctype.h>
#include <string.h>
#include <dos.h>
#include <time.h>
#include "langext.h"
#include "defines.h"
#include "types.h"
#include "subs.h"
#include "globals.h"
/* LIST.C */
/*+-------------------------------------------------------------------------+
| |
| ListDelete |
| |
+-------------------------------------------------------------------------+*/
void ListDelete(Generic_Element_ptr elem,
Generic_Element_list *lst)
BeginDeclarations
#define Elem (*elem)
#define Lst (*lst)
Generic_Element_ptr current;
#define Current (*current)
Generic_Element_ptr prior;
#define Prior (*prior)
EndDeclarations
BeginCode
prior = Null;
TraverseList(Lst, current)
BeginTraverse
If current Is elem
Then
If prior Is Null
Then
First(Lst) = Elem.next;
If First(Lst) Is Null
Then
Last(Lst) = Null;
EndIf;
Else
Prior.next = Elem.next;
If Last(Lst) Is elem
Then
Last(Lst) = prior;
EndIf;
EndIf;
ExitLoop;
EndIf;
prior = current;
EndTraverse;
return;
EndCode
#undef Elem
#undef Lst
#undef Current
#undef Prior
/*+-------------------------------------------------------------------------+
| |
| ListInsert |
| |
+-------------------------------------------------------------------------+*/
void ListInsert(Generic_Element_ptr elem,
bit_16 type_insert,
Generic_Element_ptr aftr,
Generic_Element_list *lst)
BeginDeclarations
#define Elem (*elem)
#define Aftr (*aftr)
#define Lst (*lst)
EndDeclarations
BeginCode
Using type_insert
BeginCase
/*+-------------------------------------------------------------------------+
| |
| Handle: Insert ptr After aftr InList lst EndInsert; |
| |
+-------------------------------------------------------------------------+*/
When 0:
Elem.next = Aftr.next;
Aftr.next = elem;
If Elem.next IsNull
Then
Last(Lst) = elem;
EndIf;
break;
/*+-------------------------------------------------------------------------+
| |
| Handle: Insert ptr AtEnd InList lst EndInsert; |
| |
+-------------------------------------------------------------------------+*/
When 1:
If Last(Lst) IsNull
Then
First(Lst) = elem;
Else
(*Last(Lst)).next = elem;
EndIf;
Last(Lst) = elem;
Elem.next = Null;
break;
/*+-------------------------------------------------------------------------+
| |
| Handle: Insert ptr AtBeginning InList lst EndInsert; |
| |
+-------------------------------------------------------------------------+*/
When 2:
Elem.next = First(Lst);
First(Lst) = elem;
If Last(Lst) IsNull
Then
Last(Lst) = elem;
EndIf;
break;
EndCase;
return;
EndCode
#undef Elem
#undef Aftr
#undef Lst
/*+-------------------------------------------------------------------------+
| |
| ListPop |
| |
+-------------------------------------------------------------------------+*/
void ListPop(Generic_Element_list *lst,
Generic_Element_ptr *elem)
BeginDeclarations
#define Elem (*elem)
#define Lst (*lst)
EndDeclarations
BeginCode
If First(Lst) IsNull
Then
Elem = Null;
return;
EndIf;
Elem = First(Lst);
First(Lst) = (*Elem).next;
If First(Lst) IsNull
Then
Last(Lst) = Null;
EndIf;
return;
EndCode
#undef Elem
#undef Lst
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -