1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
|
/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: mkcreate.hxx,v $
*
* $Revision: 1.2 $
*
* last change: $Author: hr $ $Date: 2006-06-19 13:32:14 $
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
*
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2005 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
************************************************************************/
#ifndef _MK_CREATE_HXX
#define _MK_CREATE_HXX
#include "string.hxx"
#ifndef _SSTRING_HXX
#include "bootstrp/sstring.hxx"
#endif
#include "list.hxx"
#ifndef _PRJ_HXX
#include "bootstrp/prj.hxx"
#endif
class SvStream;
class SourceDirectoryList;
//
// class SourceDirectoryDependency
//
class CodedDependency : public ByteString
{
private:
USHORT nOSType; // operating systems where dependeny exists
public:
/* create a dependency instance with given coded directory name
*/
CodedDependency(
const ByteString &rCodedIdentifier, // the coded name of the directory
USHORT nOperatingSystems // the operating systems where this dependency exists
) :
ByteString( rCodedIdentifier ),
nOSType( nOperatingSystems )
{
}
/* returns the operating system
*/
USHORT GetOperatingSystem()
{
return nOSType;
}
/* set operating system
*/
void SetOperatingSystem( USHORT nOperatingSystems )
{
nOSType = nOperatingSystems;
}
/* add operating systems if same dependency
*/
BOOL TryToMerge(
const ByteString &rCodedIdentifier, // the coded name of the directory
USHORT nOperatingSystems // the operating systems where this dependency exists
)
{
if ( rCodedIdentifier != *this )
return FALSE;
nOSType |= nOperatingSystems;
return TRUE;
}
};
//
// class Dependecy
//
class Dependency : public ByteString
{
private:
USHORT nOSType; // operating systems where dependecy exists
public:
/* create a dependency instance with given directory name
*/
Dependency(
const ByteString &rDirectoryName, // the coded name of the directory
USHORT nOperatingSystems // the operating systems where this dependency exists
) :
ByteString( rDirectoryName ),
nOSType( nOperatingSystems )
{
}
/* returns the operating system
*/
USHORT GetOperatingSystem()
{
return nOSType;
}
};
//
// class SourceDirectory
//
class SourceDirectory : public ByteString
{
private:
SourceDirectory *pParent; // the parent directory
SourceDirectoryList *pSubDirectories; // list of sub directories
USHORT nOSType; // operating systems where this directory is used
USHORT nDepth; // depth of directory structure (root is 0)
SByteStringList *pDependencies; // dependencies on other directories in this depth
SByteStringList *pCodedDependencies; // dependencies on other directories in different depth
SByteStringList *pCodedIdentifier; // symbolic identifier to resolve dependencies
/* try to resolve a single dependency
*/
Dependency *ResolvesDependency(
CodedDependency *pCodedDependency // the dependency
);
/* returns the operating systems of a coded dependency
*/
static USHORT GetOSType(
const ByteString &sDependExt // the corresponding dependency extension (see also prj.hxx)
);
/* removes this and all sub directories with all dependencies
*/
BOOL RemoveDirectoryTreeAndAllDependencies();
public:
/* create a directory instance with given parent and name, no parent means this is the root
* (not the file system root but the root of the source tree, e.g. o:\569)
*/
SourceDirectory(
const ByteString &rDirectoryName, // name without parent
USHORT nOperatingSystem, // the operating systems where this directory is used
SourceDirectory *pParentDirectory = NULL // parent (if not root)
);
~SourceDirectory();
/* returns the full absolute path of this directory
*/
ByteString GetFullPath();
/* returns a list of all sub directories
*/
SourceDirectoryList *GetSubDirectories() { return pSubDirectories; }
/* returns the Operating systems where this directory is used
*/
USHORT GetOperatingSystems() { return nOSType; }
/* returns the given directory
*/
SourceDirectory *GetDirectory(
const ByteString &rDirectoryName, // full path
USHORT nOperatingSystem // the operating systems where this directory is used
);
/* create the directory and all mandatory parents
*/
SourceDirectory *InsertFull(
const ByteString &rDirectoryName, // full path
USHORT nOperatingSystem // the operating systems where this directory is used
)
{
return GetDirectory( rDirectoryName, nOperatingSystem );
}
/* create the directory as sub directory of this directory
*/
SourceDirectory *Insert(
const ByteString &rDirectoryName, // name without parent
USHORT nOperatingSystem // the operating systems where this directory is used
);
/* get the root directory
*/
SourceDirectory *GetRootDirectory();
/* get sub directory if exists
*/
SourceDirectory *GetSubDirectory(
const ByteString &rDirectoryPath, // full sub path
USHORT nOperatingSystem // the operating systems where this directory is used
);
/* add a dependency for several platforms
*/
CodedDependency *AddCodedDependency(
const ByteString &rCodedIdentifier, // the coded name of the directory
USHORT nOperatingSystems // the operating systems where this dependency exists
);
/* returns the dependency list
*/
SByteStringList *GetCodedDependencies()
{
return pCodedDependencies;
}
/* add symbolic identifier to resolve dependencies (to this directory and all parents)
*/
CodedDependency *AddCodedIdentifier(
const ByteString &rCodedIdentifier, // the coded name of the directory
USHORT nOperatingSystems // the operating systems where this dependency exists
);
/* returns the identifier list
*/
SByteStringList *GetCodedIdentifier()
{
return pCodedIdentifier;
}
/* create dependencies on other directory, coded dependecies are used
*/
void ResolveDependencies();
/* returns the target definition for this directory (if dependencies exist)
*/
ByteString GetTarget();
/* returns the target definition for all sub directory
*/
ByteString GetSubDirsTarget();
/* create the full directory tree (only virtual, not in file system)
*/
static SourceDirectory *CreateRootDirectory(
const ByteString &rRoot, // the root directory in file system
const ByteString &rVersion, // the solar verion (r.g. SRC590, SRC591 etc.)
BOOL bAll = FALSE // add all directories or only buildable ones
);
/* create the makefile.rc in file system
*/
BOOL CreateRecursiveMakefile(
BOOL bAllChilds = FALSE // create rcursive for all sub directories
);
};
//
// class SourceDirectoryList
//
class SourceDirectoryList : public SByteStringList
{
public:
/* create a empty directory list
*/
SourceDirectoryList()
{
}
~SourceDirectoryList();
/* search for a directory by directory name
*/
SourceDirectory *Search(
const ByteString &rDirectoryName // name without parent
);
/* insert a new directory
*/
ULONG InsertSorted(
SourceDirectory *pDirectory // directory
)
{
return PutString(( ByteString * ) pDirectory );
}
};
#endif
|