source: trunk/dll/makelist.c@ 201

Last change on this file since 201 was 51, checked in by root, 23 years ago

Standardize EA match

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.9 KB
Line 
1
2/***********************************************************************
3
4 $Id: makelist.c 51 2003-02-12 20:22:14Z root $
5
6 Make file lists
7
8 Copyright (c) 1993-98 M. Kimes
9 Copyright (c) 2003 Steven H.Levine
10
11 Revisions 12 Feb 03 SHL - AddToFileList: standardize EA math
12
13***********************************************************************/
14#define INCL_DOS
15#define INCL_WIN
16
17#include <os2.h>
18#include <stdio.h>
19#include <stdlib.h>
20#include <string.h>
21#include <ctype.h>
22#include "fm3dll.h"
23
24#pragma alloc_text(MAKELIST,AddToList,AddToFileList,BuildList,FreeListInfo,FreeList)
25#pragma alloc_text(MAKELIST,SortList,BuildArcList,RemoveFromList,CombineLists)
26
27
28VOID SortList (LISTINFO *li) {
29
30 /* bubble-sort entries by size, descending */
31
32 INT x;
33 CHAR *s;
34 ULONG l;
35 BOOL swapped;
36
37 if(li && li->list && li->list[0] && li->cbFile) {
38 do {
39 swapped = FALSE;
40 for(x = 0;li->list[x] && li->list[x + 1];x++) {
41 if(li->cbFile[x] < li->cbFile[x + 1]) {
42 s = li->list[x];
43 li->list[x] = li->list[x + 1];
44 li->list[x + 1] = s;
45 l = li->cbFile[x];
46 li->cbFile[x] = li->cbFile[x + 1];
47 li->cbFile[x + 1] = l;
48 if(li->ulitemID) {
49 l = li->ulitemID[x];
50 li->ulitemID[x] = li->ulitemID[x + 1];
51 li->ulitemID[x + 1] = l;
52 }
53 swapped = TRUE;
54 }
55 }
56 } while(swapped);
57 }
58}
59
60
61VOID FreeListInfo (LISTINFO *li) {
62
63 if(li) {
64 if(li->ulitemID)
65 free(li->ulitemID);
66 if(li->cbFile)
67 free(li->cbFile);
68 if(li->list)
69 FreeList(li->list);
70 free(li);
71 }
72}
73
74
75VOID FreeList (CHAR **list) {
76
77 register INT x;
78
79 if(list) {
80 for(x = 0;list[x];x++) {
81#ifdef __DEBUG_ALLOC__
82 _heap_check();
83#endif
84 free(list[x]);
85 }
86#ifdef __DEBUG_ALLOC__
87 _heap_check();
88#endif
89 free(list);
90 }
91 DosPostEventSem(CompactSem);
92}
93
94
95INT AddToFileList (CHAR *string,FILEFINDBUF4 *ffb4,FILELIST ***list,
96 INT *numfiles,INT *numalloced)
97{
98
99 FILELIST **test;
100
101 if(string && ffb4) {
102 if(((*numfiles) + 3) > *numalloced) {
103 if((test = realloc(*list,(((*numalloced) + 6) *
104 sizeof(FILELIST *)))) == NULL)
105 return 1;
106 (*numalloced) += 6;
107 *list = test;
108 }
109 if(((*list)[*numfiles] = malloc(sizeof(FILELIST) +
110 strlen(string))) == NULL)
111 return 2;
112 (*list)[*numfiles]->attrFile = ffb4->attrFile;
113 (*list)[*numfiles]->date = ffb4->fdateLastWrite;
114 (*list)[*numfiles]->time = ffb4->ftimeLastWrite;
115 (*list)[*numfiles]->ladate = ffb4->fdateLastAccess;
116 (*list)[*numfiles]->latime = ffb4->ftimeLastAccess;
117 (*list)[*numfiles]->crdate = ffb4->fdateCreation;
118 (*list)[*numfiles]->crtime = ffb4->ftimeCreation;
119 (*list)[*numfiles]->cbFile = ffb4->cbFile;
120 (*list)[*numfiles]->easize = CBLIST_TO_EASIZE(ffb4->cbList);
121 strcpy((*list)[*numfiles]->fname,string);
122 (*numfiles)++;
123 (*list)[*numfiles] = NULL;
124 (*list)[(*numfiles) + 1] = NULL;
125#ifdef __DEBUG_ALLOC__
126 _heap_check();
127#endif
128 }
129 return 0;
130}
131
132
133INT AddToList (CHAR *string,CHAR ***list,INT *numfiles,INT *numalloced) {
134
135 CHAR **test;
136
137 if(string) {
138 if(((*numfiles) + 3) > *numalloced) {
139 if((test = realloc(*list,(((*numalloced) + 6) * sizeof(CHAR *)))) == NULL)
140 return 1;
141 (*numalloced) += 6;
142 *list = test;
143 }
144 if(((*list)[*numfiles] = malloc(strlen(string) + 1)) == NULL)
145 return 2;
146 strcpy((*list)[*numfiles],string);
147 (*numfiles)++;
148 (*list)[*numfiles] = NULL;
149 (*list)[(*numfiles) + 1] = NULL;
150#ifdef __DEBUG_ALLOC__
151 _heap_check();
152#endif
153 }
154 return 0;
155}
156
157
158CHAR ** BuildList (HWND hwndCnr) {
159
160 PCNRITEM pci;
161 CHAR **list = NULL,**test;
162 INT numfiles = 0,numalloc = 0,error = 0,attribute = CRA_CURSORED;
163
164 pci = (PCNRITEM)CurrentRecord(hwndCnr);
165 if(pci && (INT)pci != -1 && !(pci->flags & RECFLAGS_ENV)) {
166 if(pci->rc.flRecordAttr & CRA_SELECTED) {
167 attribute = CRA_SELECTED;
168 pci = WinSendMsg(hwndCnr,CM_QUERYRECORDEMPHASIS,MPFROMLONG(CMA_FIRST),
169 MPFROMSHORT(attribute));
170 }
171 }
172 while(pci && (INT)pci != -1 && !error) {
173 if(!(pci->rc.flRecordAttr & CRA_FILTERED))
174 error = AddToList(pci->szFileName,&list,&numfiles,&numalloc);
175 pci = WinSendMsg(hwndCnr,CM_QUERYRECORDEMPHASIS,MPFROMP(pci),
176 MPFROMSHORT(attribute));
177 }
178 if(numalloc > numfiles + 1) {
179 test = realloc(list,sizeof(CHAR *) * (numfiles + 1));
180 if(test)
181 list = test;
182 }
183 return list;
184}
185
186
187CHAR ** BuildArcList (HWND hwndCnr) {
188
189 PARCITEM pai;
190 CHAR **list = NULL;
191 INT numfiles = 0,numalloc = 0,error = 0,attribute = CRA_CURSORED;
192
193 pai = (PARCITEM)CurrentRecord(hwndCnr);
194 if(pai && (INT)pai != -1) {
195 if(pai->rc.flRecordAttr & CRA_SELECTED) {
196 attribute = CRA_SELECTED;
197 pai = WinSendMsg(hwndCnr,CM_QUERYRECORDEMPHASIS,MPFROMLONG(CMA_FIRST),
198 MPFROMSHORT(attribute));
199 }
200 }
201 while( pai && (INT)pai != -1 && !error) {
202 if(!(pai->rc.flRecordAttr & CRA_FILTERED))
203 error = AddToList(pai->szFileName,&list,&numfiles,&numalloc);
204 pai = WinSendMsg(hwndCnr,CM_QUERYRECORDEMPHASIS,MPFROMP(pai),
205 MPFROMSHORT(attribute));
206 }
207 return list;
208}
209
210
211CHAR ** RemoveFromList (CHAR **list,CHAR *item) {
212
213 register INT x,y;
214
215 if(list && list[0] && item) {
216 for(x = 0;list[x];x++) {
217 if(item == list[x]) {
218 free(list[x]);
219 list[x] = NULL;
220 for(y = x;;y++) {
221 if(y != x && !list[y])
222 break;
223 list[y] = list[y + 1];
224 }
225 if(!list[0]) {
226 FreeList(list);
227 list = NULL;
228 }
229 break;
230 }
231 }
232 }
233 return list;
234}
235
236
237CHAR ** CombineLists (CHAR **prime,CHAR **add) {
238
239 register INT x;
240 INT numalloc,numfiles = 0;
241
242 if(add && add[0]) {
243 if(prime) {
244 for(x = 0;prime[x];x++)
245 numfiles++;
246 }
247 numalloc = numfiles;
248 for(x = 0;add[x];x++) {
249 if(*add[x])
250 AddToList(add[x],&prime,&numfiles,&numalloc);
251 }
252 FreeList(add);
253 }
254 return prime;
255}
Note: See TracBrowser for help on using the repository browser.