xref: /aoo4110/main/idlc/source/idlcproduce.cxx (revision b1cdbd2c)
1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
25*b1cdbd2cSJim Jagielski #include "precompiled_idlc.hxx"
26*b1cdbd2cSJim Jagielski #include <idlc/idlc.hxx>
27*b1cdbd2cSJim Jagielski #include <idlc/astmodule.hxx>
28*b1cdbd2cSJim Jagielski #include <rtl/strbuf.hxx>
29*b1cdbd2cSJim Jagielski #include <osl/file.hxx>
30*b1cdbd2cSJim Jagielski #include <osl/thread.h>
31*b1cdbd2cSJim Jagielski 
32*b1cdbd2cSJim Jagielski #if defined(SAL_W32) || defined(SAL_OS2)
33*b1cdbd2cSJim Jagielski #include <io.h>
34*b1cdbd2cSJim Jagielski #include <direct.h>
35*b1cdbd2cSJim Jagielski #include <errno.h>
36*b1cdbd2cSJim Jagielski #endif
37*b1cdbd2cSJim Jagielski 
38*b1cdbd2cSJim Jagielski #ifdef SAL_UNX
39*b1cdbd2cSJim Jagielski #include <unistd.h>
40*b1cdbd2cSJim Jagielski #include <sys/stat.h>
41*b1cdbd2cSJim Jagielski #include <errno.h>
42*b1cdbd2cSJim Jagielski #endif
43*b1cdbd2cSJim Jagielski 
44*b1cdbd2cSJim Jagielski #include <string.h>
45*b1cdbd2cSJim Jagielski 
46*b1cdbd2cSJim Jagielski using namespace ::rtl;
47*b1cdbd2cSJim Jagielski using namespace ::osl;
48*b1cdbd2cSJim Jagielski 
49*b1cdbd2cSJim Jagielski StringList* pCreatedDirectories = NULL;
50*b1cdbd2cSJim Jagielski 
checkOutputPath(const OString & completeName)51*b1cdbd2cSJim Jagielski static sal_Bool checkOutputPath(const OString& completeName)
52*b1cdbd2cSJim Jagielski {
53*b1cdbd2cSJim Jagielski     OString sysPathName = convertToAbsoluteSystemPath(completeName);
54*b1cdbd2cSJim Jagielski 	OStringBuffer buffer(sysPathName.getLength());
55*b1cdbd2cSJim Jagielski 
56*b1cdbd2cSJim Jagielski 	if ( sysPathName.indexOf( SEPARATOR ) == -1 )
57*b1cdbd2cSJim Jagielski 		return sal_True;
58*b1cdbd2cSJim Jagielski 
59*b1cdbd2cSJim Jagielski     sal_Int32 nIndex = 0;
60*b1cdbd2cSJim Jagielski 	OString token(sysPathName.getToken(0, SEPARATOR, nIndex));
61*b1cdbd2cSJim Jagielski 	const sal_Char* p = token.getStr();
62*b1cdbd2cSJim Jagielski 	if (strcmp(p, "..") == 0
63*b1cdbd2cSJim Jagielski         || *(p+1) == ':'
64*b1cdbd2cSJim Jagielski         || strcmp(p, ".") == 0)
65*b1cdbd2cSJim Jagielski 	{
66*b1cdbd2cSJim Jagielski 		buffer.append(token);
67*b1cdbd2cSJim Jagielski 		buffer.append(SEPARATOR);
68*b1cdbd2cSJim Jagielski 	}
69*b1cdbd2cSJim Jagielski     else
70*b1cdbd2cSJim Jagielski         nIndex = 0;
71*b1cdbd2cSJim Jagielski 
72*b1cdbd2cSJim Jagielski     do
73*b1cdbd2cSJim Jagielski 	{
74*b1cdbd2cSJim Jagielski 		buffer.append(sysPathName.getToken(0, SEPARATOR, nIndex));
75*b1cdbd2cSJim Jagielski 
76*b1cdbd2cSJim Jagielski 		if ( buffer.getLength() > 0 && nIndex != -1 )
77*b1cdbd2cSJim Jagielski 		{
78*b1cdbd2cSJim Jagielski #if defined(SAL_UNX) || defined(SAL_OS2)
79*b1cdbd2cSJim Jagielski 			if (mkdir((char*)buffer.getStr(), 0777) == -1)
80*b1cdbd2cSJim Jagielski #else
81*b1cdbd2cSJim Jagielski 			if (mkdir((char*)buffer.getStr()) == -1)
82*b1cdbd2cSJim Jagielski #endif
83*b1cdbd2cSJim Jagielski 			{
84*b1cdbd2cSJim Jagielski 				if (errno == ENOENT)
85*b1cdbd2cSJim Jagielski 				{
86*b1cdbd2cSJim Jagielski 					fprintf(stderr, "%s: cannot create directory '%s'\n",
87*b1cdbd2cSJim Jagielski 							idlc()->getOptions()->getProgramName().getStr(), buffer.getStr());
88*b1cdbd2cSJim Jagielski 					return sal_False;
89*b1cdbd2cSJim Jagielski 				}
90*b1cdbd2cSJim Jagielski 	        } else
91*b1cdbd2cSJim Jagielski 			{
92*b1cdbd2cSJim Jagielski 				if ( !pCreatedDirectories )
93*b1cdbd2cSJim Jagielski 					pCreatedDirectories = new StringList();
94*b1cdbd2cSJim Jagielski 				pCreatedDirectories->push_front(buffer.getStr());
95*b1cdbd2cSJim Jagielski 			}
96*b1cdbd2cSJim Jagielski 		}
97*b1cdbd2cSJim Jagielski         buffer.append(SEPARATOR);
98*b1cdbd2cSJim Jagielski 	} while( nIndex != -1 );
99*b1cdbd2cSJim Jagielski 	return sal_True;
100*b1cdbd2cSJim Jagielski }
101*b1cdbd2cSJim Jagielski 
cleanPath()102*b1cdbd2cSJim Jagielski static sal_Bool cleanPath()
103*b1cdbd2cSJim Jagielski {
104*b1cdbd2cSJim Jagielski 	if ( pCreatedDirectories )
105*b1cdbd2cSJim Jagielski 	{
106*b1cdbd2cSJim Jagielski 		StringList::iterator iter = pCreatedDirectories->begin();
107*b1cdbd2cSJim Jagielski 		StringList::iterator end = pCreatedDirectories->end();
108*b1cdbd2cSJim Jagielski 		while ( iter != end )
109*b1cdbd2cSJim Jagielski 		{
110*b1cdbd2cSJim Jagielski //#ifdef SAL_UNX
111*b1cdbd2cSJim Jagielski //			if (rmdir((char*)(*iter).getStr(), 0777) == -1)
112*b1cdbd2cSJim Jagielski //#else
113*b1cdbd2cSJim Jagielski 			if (rmdir((char*)(*iter).getStr()) == -1)
114*b1cdbd2cSJim Jagielski //#endif
115*b1cdbd2cSJim Jagielski 			{
116*b1cdbd2cSJim Jagielski 				fprintf(stderr, "%s: cannot remove directory '%s'\n",
117*b1cdbd2cSJim Jagielski 						idlc()->getOptions()->getProgramName().getStr(), (*iter).getStr());
118*b1cdbd2cSJim Jagielski 				return sal_False;
119*b1cdbd2cSJim Jagielski 			}
120*b1cdbd2cSJim Jagielski 			++iter;
121*b1cdbd2cSJim Jagielski 		}
122*b1cdbd2cSJim Jagielski 		delete pCreatedDirectories;
123*b1cdbd2cSJim Jagielski 	}
124*b1cdbd2cSJim Jagielski 	return sal_True;
125*b1cdbd2cSJim Jagielski }
126*b1cdbd2cSJim Jagielski 
removeIfExists(const OString & pathname)127*b1cdbd2cSJim Jagielski void removeIfExists(const OString& pathname)
128*b1cdbd2cSJim Jagielski {
129*b1cdbd2cSJim Jagielski     unlink(pathname.getStr());
130*b1cdbd2cSJim Jagielski }
131*b1cdbd2cSJim Jagielski 
produceFile(const OString & regFileName)132*b1cdbd2cSJim Jagielski sal_Int32 SAL_CALL produceFile(const OString& regFileName)
133*b1cdbd2cSJim Jagielski {
134*b1cdbd2cSJim Jagielski 	Options* pOptions = idlc()->getOptions();
135*b1cdbd2cSJim Jagielski 
136*b1cdbd2cSJim Jagielski     OString regTmpName = regFileName.replaceAt(regFileName.getLength() -3, 3, "_idlc_");
137*b1cdbd2cSJim Jagielski 
138*b1cdbd2cSJim Jagielski 	if ( !checkOutputPath(regFileName) )
139*b1cdbd2cSJim Jagielski 	{
140*b1cdbd2cSJim Jagielski 		fprintf(stderr, "%s: could not create path of registry file '%s'.\n",
141*b1cdbd2cSJim Jagielski 				pOptions->getProgramName().getStr(), regFileName.getStr());
142*b1cdbd2cSJim Jagielski 		return 1;
143*b1cdbd2cSJim Jagielski 	}
144*b1cdbd2cSJim Jagielski 
145*b1cdbd2cSJim Jagielski 	removeIfExists(regTmpName);
146*b1cdbd2cSJim Jagielski     OString urlRegTmpName = convertToFileUrl(regTmpName);
147*b1cdbd2cSJim Jagielski 
148*b1cdbd2cSJim Jagielski 	Registry regFile;
149*b1cdbd2cSJim Jagielski 	if ( regFile.create(OStringToOUString(urlRegTmpName, RTL_TEXTENCODING_UTF8)) != REG_NO_ERROR )
150*b1cdbd2cSJim Jagielski 	{
151*b1cdbd2cSJim Jagielski 		fprintf(stderr, "%s: could not create registry file '%s'\n",
152*b1cdbd2cSJim Jagielski 				pOptions->getProgramName().getStr(), regTmpName.getStr());
153*b1cdbd2cSJim Jagielski 		removeIfExists(regTmpName);
154*b1cdbd2cSJim Jagielski 		removeIfExists(regFileName);
155*b1cdbd2cSJim Jagielski 		cleanPath();
156*b1cdbd2cSJim Jagielski 		return 1;
157*b1cdbd2cSJim Jagielski 	}
158*b1cdbd2cSJim Jagielski 
159*b1cdbd2cSJim Jagielski 	RegistryKey rootKey;
160*b1cdbd2cSJim Jagielski 	if ( regFile.openRootKey(rootKey) != REG_NO_ERROR )
161*b1cdbd2cSJim Jagielski 	{
162*b1cdbd2cSJim Jagielski 		fprintf(stderr, "%s: could not open root of registry file '%s'\n",
163*b1cdbd2cSJim Jagielski 				pOptions->getProgramName().getStr(), regFileName.getStr());
164*b1cdbd2cSJim Jagielski 		removeIfExists(regTmpName);
165*b1cdbd2cSJim Jagielski 		removeIfExists(regFileName);
166*b1cdbd2cSJim Jagielski 		cleanPath();
167*b1cdbd2cSJim Jagielski 		return 1;
168*b1cdbd2cSJim Jagielski 	}
169*b1cdbd2cSJim Jagielski 
170*b1cdbd2cSJim Jagielski 	// produce registry file
171*b1cdbd2cSJim Jagielski 	if ( !idlc()->getRoot()->dump(rootKey) )
172*b1cdbd2cSJim Jagielski 	{
173*b1cdbd2cSJim Jagielski 		rootKey.releaseKey();
174*b1cdbd2cSJim Jagielski 		regFile.close();
175*b1cdbd2cSJim Jagielski 		regFile.destroy(OStringToOUString(regFileName, RTL_TEXTENCODING_UTF8));
176*b1cdbd2cSJim Jagielski 		removeIfExists(regFileName);
177*b1cdbd2cSJim Jagielski 		cleanPath();
178*b1cdbd2cSJim Jagielski 		return 1;
179*b1cdbd2cSJim Jagielski 	}
180*b1cdbd2cSJim Jagielski 
181*b1cdbd2cSJim Jagielski 	rootKey.releaseKey();
182*b1cdbd2cSJim Jagielski 	if ( regFile.close() != REG_NO_ERROR )
183*b1cdbd2cSJim Jagielski 	{
184*b1cdbd2cSJim Jagielski 		fprintf(stderr, "%s: could not close registry file '%s'\n",
185*b1cdbd2cSJim Jagielski 				pOptions->getProgramName().getStr(), regFileName.getStr());
186*b1cdbd2cSJim Jagielski 		removeIfExists(regTmpName);
187*b1cdbd2cSJim Jagielski 		removeIfExists(regFileName);
188*b1cdbd2cSJim Jagielski 		cleanPath();
189*b1cdbd2cSJim Jagielski 		return 1;
190*b1cdbd2cSJim Jagielski 	}
191*b1cdbd2cSJim Jagielski 
192*b1cdbd2cSJim Jagielski 	removeIfExists(regFileName);
193*b1cdbd2cSJim Jagielski 
194*b1cdbd2cSJim Jagielski     if ( File::move(OStringToOUString(regTmpName, osl_getThreadTextEncoding()),
195*b1cdbd2cSJim Jagielski                     OStringToOUString(regFileName, osl_getThreadTextEncoding())) != FileBase::E_None ) {
196*b1cdbd2cSJim Jagielski 		fprintf(stderr, "%s: cannot rename temporary registry '%s' to '%s'\n",
197*b1cdbd2cSJim Jagielski 				idlc()->getOptions()->getProgramName().getStr(),
198*b1cdbd2cSJim Jagielski 				regTmpName.getStr(), regFileName.getStr());
199*b1cdbd2cSJim Jagielski 		removeIfExists(regTmpName);
200*b1cdbd2cSJim Jagielski 		cleanPath();
201*b1cdbd2cSJim Jagielski 		return 1;
202*b1cdbd2cSJim Jagielski     }
203*b1cdbd2cSJim Jagielski 	removeIfExists(regTmpName);
204*b1cdbd2cSJim Jagielski 
205*b1cdbd2cSJim Jagielski 	return 0;
206*b1cdbd2cSJim Jagielski }
207