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
25*b1cdbd2cSJim Jagielski // MARKER(update_precomp.py): autogen include statement, do not remove
26*b1cdbd2cSJim Jagielski #include "precompiled_l10ntools.hxx"
27*b1cdbd2cSJim Jagielski #include <l10ntools/directory.hxx>
28*b1cdbd2cSJim Jagielski #include "tools/string.hxx"
29*b1cdbd2cSJim Jagielski #include <iostream>
30*b1cdbd2cSJim Jagielski #include <vector>
31*b1cdbd2cSJim Jagielski #include <algorithm>
32*b1cdbd2cSJim Jagielski
33*b1cdbd2cSJim Jagielski namespace transex
34*b1cdbd2cSJim Jagielski {
35*b1cdbd2cSJim Jagielski
Directory(const rtl::OUString sFullpath)36*b1cdbd2cSJim Jagielski Directory::Directory( const rtl::OUString sFullpath ) : bSkipLinks( false )
37*b1cdbd2cSJim Jagielski {
38*b1cdbd2cSJim Jagielski sFullName = sFullpath;
39*b1cdbd2cSJim Jagielski }
40*b1cdbd2cSJim Jagielski
Directory(const rtl::OUString sFullPath,const rtl::OUString sEntry)41*b1cdbd2cSJim Jagielski Directory::Directory( const rtl::OUString sFullPath , const rtl::OUString sEntry ) : bSkipLinks( false )
42*b1cdbd2cSJim Jagielski {
43*b1cdbd2cSJim Jagielski sFullName = sFullPath;
44*b1cdbd2cSJim Jagielski sDirectoryName = sEntry;
45*b1cdbd2cSJim Jagielski }
46*b1cdbd2cSJim Jagielski
47*b1cdbd2cSJim Jagielski
Directory(const ByteString sFullPath)48*b1cdbd2cSJim Jagielski Directory::Directory( const ByteString sFullPath ) : bSkipLinks( false )
49*b1cdbd2cSJim Jagielski {
50*b1cdbd2cSJim Jagielski sDirectoryName = rtl::OUString( sFullPath.GetBuffer() , RTL_TEXTENCODING_UTF8 , sFullPath.Len() );
51*b1cdbd2cSJim Jagielski }
52*b1cdbd2cSJim Jagielski
lessDir(const Directory & rKey1,const Directory & rKey2)53*b1cdbd2cSJim Jagielski bool Directory::lessDir ( const Directory& rKey1, const Directory& rKey2 )
54*b1cdbd2cSJim Jagielski {
55*b1cdbd2cSJim Jagielski rtl::OUString sName1( ( static_cast< Directory >( rKey1 ) ).getDirectoryName() );
56*b1cdbd2cSJim Jagielski rtl::OUString sName2( ( static_cast< Directory >( rKey2 ) ).getDirectoryName() );
57*b1cdbd2cSJim Jagielski
58*b1cdbd2cSJim Jagielski return sName1.compareTo( sName2 ) < 0 ;
59*b1cdbd2cSJim Jagielski }
60*b1cdbd2cSJim Jagielski
61*b1cdbd2cSJim Jagielski
dump()62*b1cdbd2cSJim Jagielski void Directory::dump()
63*b1cdbd2cSJim Jagielski {
64*b1cdbd2cSJim Jagielski
65*b1cdbd2cSJim Jagielski for( std::vector< transex::File >::iterator iter = aFileVec.begin() ; iter != aFileVec.end() ; ++iter )
66*b1cdbd2cSJim Jagielski {
67*b1cdbd2cSJim Jagielski std::cout << "FILE " << rtl::OUStringToOString( (*iter).getFullName().getStr() , RTL_TEXTENCODING_UTF8 , (*iter).getFullName().getLength() ).getStr() << "\n";
68*b1cdbd2cSJim Jagielski }
69*b1cdbd2cSJim Jagielski
70*b1cdbd2cSJim Jagielski for( std::vector< transex::Directory >::iterator iter = aDirVec.begin() ; iter != aDirVec.end() ; ++iter )
71*b1cdbd2cSJim Jagielski {
72*b1cdbd2cSJim Jagielski std::cout << "DIR " << rtl::OUStringToOString( (*iter).getFullName().getStr() , RTL_TEXTENCODING_UTF8 , (*iter).getFullName().getLength() ).getStr() << "\n";
73*b1cdbd2cSJim Jagielski }
74*b1cdbd2cSJim Jagielski
75*b1cdbd2cSJim Jagielski }
76*b1cdbd2cSJim Jagielski
scanSubDir(int nLevels)77*b1cdbd2cSJim Jagielski void Directory::scanSubDir( int nLevels )
78*b1cdbd2cSJim Jagielski {
79*b1cdbd2cSJim Jagielski readDirectory( sFullName );
80*b1cdbd2cSJim Jagielski dump();
81*b1cdbd2cSJim Jagielski if( nLevels > 0 ) {
82*b1cdbd2cSJim Jagielski for( std::vector< transex::Directory >::iterator iter = aDirVec.begin() ; iter != aDirVec.end() || nLevels > 0 ; ++iter , nLevels-- )
83*b1cdbd2cSJim Jagielski {
84*b1cdbd2cSJim Jagielski ( *iter ).scanSubDir();
85*b1cdbd2cSJim Jagielski }
86*b1cdbd2cSJim Jagielski }
87*b1cdbd2cSJim Jagielski }
88*b1cdbd2cSJim Jagielski
setSkipLinks(bool is_skipped)89*b1cdbd2cSJim Jagielski void Directory::setSkipLinks( bool is_skipped )
90*b1cdbd2cSJim Jagielski {
91*b1cdbd2cSJim Jagielski bSkipLinks = is_skipped;
92*b1cdbd2cSJim Jagielski }
93*b1cdbd2cSJim Jagielski
readDirectory()94*b1cdbd2cSJim Jagielski void Directory::readDirectory()
95*b1cdbd2cSJim Jagielski {
96*b1cdbd2cSJim Jagielski readDirectory( sFullName );
97*b1cdbd2cSJim Jagielski }
98*b1cdbd2cSJim Jagielski
99*b1cdbd2cSJim Jagielski #ifdef WNT
100*b1cdbd2cSJim Jagielski #include <tools/prewin.h>
101*b1cdbd2cSJim Jagielski #include <windows.h>
102*b1cdbd2cSJim Jagielski #include <tools/postwin.h>
103*b1cdbd2cSJim Jagielski
readDirectory(const rtl::OUString & sFullpath)104*b1cdbd2cSJim Jagielski void Directory::readDirectory ( const rtl::OUString& sFullpath )
105*b1cdbd2cSJim Jagielski {
106*b1cdbd2cSJim Jagielski sal_Bool fFinished;
107*b1cdbd2cSJim Jagielski HANDLE hList;
108*b1cdbd2cSJim Jagielski TCHAR szDir[MAX_PATH+1];
109*b1cdbd2cSJim Jagielski TCHAR szSubDir[MAX_PATH+1];
110*b1cdbd2cSJim Jagielski WIN32_FIND_DATA FileData;
111*b1cdbd2cSJim Jagielski
112*b1cdbd2cSJim Jagielski rtl::OString sFullpathext = rtl::OUStringToOString( sFullpath , RTL_TEXTENCODING_UTF8 , sFullpath.getLength() );
113*b1cdbd2cSJim Jagielski const char *dirname = sFullpathext.getStr();
114*b1cdbd2cSJim Jagielski
115*b1cdbd2cSJim Jagielski // Get the proper directory path
116*b1cdbd2cSJim Jagielski sprintf(szDir, "%s\\*", dirname);
117*b1cdbd2cSJim Jagielski
118*b1cdbd2cSJim Jagielski // Get the first file
119*b1cdbd2cSJim Jagielski hList = FindFirstFile(szDir, &FileData);
120*b1cdbd2cSJim Jagielski if (hList == INVALID_HANDLE_VALUE)
121*b1cdbd2cSJim Jagielski {
122*b1cdbd2cSJim Jagielski //FindClose(hList);
123*b1cdbd2cSJim Jagielski //printf("No files found %s\n", szDir ); return;
124*b1cdbd2cSJim Jagielski }
125*b1cdbd2cSJim Jagielski else
126*b1cdbd2cSJim Jagielski {
127*b1cdbd2cSJim Jagielski fFinished = sal_False;
128*b1cdbd2cSJim Jagielski while (!fFinished)
129*b1cdbd2cSJim Jagielski {
130*b1cdbd2cSJim Jagielski
131*b1cdbd2cSJim Jagielski sprintf(szSubDir, "%s\\%s", dirname, FileData.cFileName);
132*b1cdbd2cSJim Jagielski rtl::OString myfile( FileData.cFileName );
133*b1cdbd2cSJim Jagielski rtl::OString mydir( szSubDir );
134*b1cdbd2cSJim Jagielski
135*b1cdbd2cSJim Jagielski if (FileData.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY)
136*b1cdbd2cSJim Jagielski {
137*b1cdbd2cSJim Jagielski if ( (strcmp(FileData.cFileName, ".") != 0 ) &&
138*b1cdbd2cSJim Jagielski (strcmp(FileData.cFileName, "..") != 0 ) )
139*b1cdbd2cSJim Jagielski {
140*b1cdbd2cSJim Jagielski //sprintf(szSubDir, "%s\\%s", dirname, FileData.cFileName);
141*b1cdbd2cSJim Jagielski transex::Directory aDir( rtl::OStringToOUString( mydir , RTL_TEXTENCODING_UTF8 , mydir.getLength() ),
142*b1cdbd2cSJim Jagielski rtl::OStringToOUString( myfile , RTL_TEXTENCODING_UTF8 , myfile.getLength() ) );
143*b1cdbd2cSJim Jagielski aDirVec.push_back( aDir );
144*b1cdbd2cSJim Jagielski }
145*b1cdbd2cSJim Jagielski }
146*b1cdbd2cSJim Jagielski else
147*b1cdbd2cSJim Jagielski {
148*b1cdbd2cSJim Jagielski transex::File aFile( rtl::OStringToOUString( mydir , RTL_TEXTENCODING_UTF8 , mydir.getLength() ),
149*b1cdbd2cSJim Jagielski rtl::OStringToOUString( myfile , RTL_TEXTENCODING_UTF8 , myfile.getLength() ) );
150*b1cdbd2cSJim Jagielski aFileVec.push_back( aFile );
151*b1cdbd2cSJim Jagielski }
152*b1cdbd2cSJim Jagielski if (!FindNextFile(hList, &FileData))
153*b1cdbd2cSJim Jagielski {
154*b1cdbd2cSJim Jagielski if (GetLastError() == ERROR_NO_MORE_FILES)
155*b1cdbd2cSJim Jagielski {
156*b1cdbd2cSJim Jagielski fFinished = sal_True;
157*b1cdbd2cSJim Jagielski }
158*b1cdbd2cSJim Jagielski }
159*b1cdbd2cSJim Jagielski }
160*b1cdbd2cSJim Jagielski }
161*b1cdbd2cSJim Jagielski
162*b1cdbd2cSJim Jagielski FindClose(hList);
163*b1cdbd2cSJim Jagielski
164*b1cdbd2cSJim Jagielski ::std::sort( aFileVec.begin() , aFileVec.end() , File::lessFile );
165*b1cdbd2cSJim Jagielski ::std::sort( aDirVec.begin() , aDirVec.end() , Directory::lessDir );
166*b1cdbd2cSJim Jagielski }
167*b1cdbd2cSJim Jagielski
168*b1cdbd2cSJim Jagielski #else
169*b1cdbd2cSJim Jagielski
170*b1cdbd2cSJim Jagielski class dirholder
171*b1cdbd2cSJim Jagielski {
172*b1cdbd2cSJim Jagielski private:
173*b1cdbd2cSJim Jagielski DIR *mpDir;
174*b1cdbd2cSJim Jagielski public:
dirholder(DIR * pDir)175*b1cdbd2cSJim Jagielski dirholder(DIR *pDir) : mpDir(pDir) {}
close()176*b1cdbd2cSJim Jagielski int close() { int nRet = mpDir ? closedir(mpDir) : 0; mpDir = NULL; return nRet; }
~dirholder()177*b1cdbd2cSJim Jagielski ~dirholder() { close(); }
178*b1cdbd2cSJim Jagielski };
179*b1cdbd2cSJim Jagielski
readDirectory(const rtl::OUString & sFullpath)180*b1cdbd2cSJim Jagielski void Directory::readDirectory( const rtl::OUString& sFullpath )
181*b1cdbd2cSJim Jagielski {
182*b1cdbd2cSJim Jagielski struct stat statbuf;
183*b1cdbd2cSJim Jagielski struct stat statbuf2;
184*b1cdbd2cSJim Jagielski struct dirent *dirp;
185*b1cdbd2cSJim Jagielski DIR *dir;
186*b1cdbd2cSJim Jagielski
187*b1cdbd2cSJim Jagielski if( sFullpath.getLength() < 1 ) return;
188*b1cdbd2cSJim Jagielski
189*b1cdbd2cSJim Jagielski rtl::OString sFullpathext = rtl::OUStringToOString( sFullpath , RTL_TEXTENCODING_UTF8 , sFullpath.getLength() ).getStr();
190*b1cdbd2cSJim Jagielski
191*b1cdbd2cSJim Jagielski // stat
192*b1cdbd2cSJim Jagielski if( stat( sFullpathext.getStr() , &statbuf ) < 0 ){ printf("warning: Can not stat %s" , sFullpathext.getStr() ); return; }// error }
193*b1cdbd2cSJim Jagielski
194*b1cdbd2cSJim Jagielski if( S_ISDIR(statbuf.st_mode ) == 0 ) { return; }// error } return; // not dir
195*b1cdbd2cSJim Jagielski
196*b1cdbd2cSJim Jagielski if( (dir = opendir( sFullpathext.getStr() ) ) == NULL ) {printf("readerror 2 in %s \n",sFullpathext.getStr()); return; } // error } return; // error
197*b1cdbd2cSJim Jagielski
198*b1cdbd2cSJim Jagielski dirholder aHolder(dir);
199*b1cdbd2cSJim Jagielski
200*b1cdbd2cSJim Jagielski sFullpathext += rtl::OString( "/" );
201*b1cdbd2cSJim Jagielski
202*b1cdbd2cSJim Jagielski const rtl::OString sDot ( "." ) ;
203*b1cdbd2cSJim Jagielski const rtl::OString sDDot( ".." );
204*b1cdbd2cSJim Jagielski
205*b1cdbd2cSJim Jagielski if ( chdir( sFullpathext.getStr() ) == -1 ) { printf("chdir error in %s \n",sFullpathext.getStr()); return; } // error
206*b1cdbd2cSJim Jagielski
207*b1cdbd2cSJim Jagielski while( ( dirp = readdir( dir ) ) != NULL )
208*b1cdbd2cSJim Jagielski {
209*b1cdbd2cSJim Jagielski rtl::OString sEntryName( dirp->d_name );
210*b1cdbd2cSJim Jagielski
211*b1cdbd2cSJim Jagielski if( sEntryName.equals( sDot ) || sEntryName.equals( sDDot ) )
212*b1cdbd2cSJim Jagielski continue;
213*b1cdbd2cSJim Jagielski
214*b1cdbd2cSJim Jagielski // add dir entry
215*b1cdbd2cSJim Jagielski rtl::OString sEntity = sFullpathext;
216*b1cdbd2cSJim Jagielski sEntity += sEntryName;
217*b1cdbd2cSJim Jagielski
218*b1cdbd2cSJim Jagielski // stat new entry
219*b1cdbd2cSJim Jagielski if( lstat( sEntity.getStr() , &statbuf2 ) < 0 )
220*b1cdbd2cSJim Jagielski {
221*b1cdbd2cSJim Jagielski printf("error on entry %s\n" , sEntity.getStr() ) ; // error
222*b1cdbd2cSJim Jagielski continue;
223*b1cdbd2cSJim Jagielski }
224*b1cdbd2cSJim Jagielski
225*b1cdbd2cSJim Jagielski // add file / dir to vector
226*b1cdbd2cSJim Jagielski switch( statbuf2.st_mode & S_IFMT )
227*b1cdbd2cSJim Jagielski {
228*b1cdbd2cSJim Jagielski case S_IFREG:
229*b1cdbd2cSJim Jagielski {
230*b1cdbd2cSJim Jagielski rtl::OString sFile = sFullpathext;
231*b1cdbd2cSJim Jagielski sFile += sEntryName ;
232*b1cdbd2cSJim Jagielski transex::File aFile( rtl::OStringToOUString( sEntity , RTL_TEXTENCODING_UTF8 , sEntity.getLength() ) ,
233*b1cdbd2cSJim Jagielski rtl::OStringToOUString( sEntryName , RTL_TEXTENCODING_UTF8 , sEntryName.getLength() )
234*b1cdbd2cSJim Jagielski );
235*b1cdbd2cSJim Jagielski
236*b1cdbd2cSJim Jagielski aFileVec.push_back( aFile ) ;
237*b1cdbd2cSJim Jagielski break;
238*b1cdbd2cSJim Jagielski }
239*b1cdbd2cSJim Jagielski case S_IFLNK:
240*b1cdbd2cSJim Jagielski {
241*b1cdbd2cSJim Jagielski if( bSkipLinks ) break;
242*b1cdbd2cSJim Jagielski }
243*b1cdbd2cSJim Jagielski case S_IFDIR:
244*b1cdbd2cSJim Jagielski {
245*b1cdbd2cSJim Jagielski rtl::OString sDir = sFullpathext;
246*b1cdbd2cSJim Jagielski sDir += sEntryName ;
247*b1cdbd2cSJim Jagielski
248*b1cdbd2cSJim Jagielski transex::Directory aDir(
249*b1cdbd2cSJim Jagielski rtl::OStringToOUString( sEntity , RTL_TEXTENCODING_UTF8 , sEntity.getLength() ) ,
250*b1cdbd2cSJim Jagielski rtl::OStringToOUString( sEntryName , RTL_TEXTENCODING_UTF8 , sEntryName.getLength() )
251*b1cdbd2cSJim Jagielski ) ;
252*b1cdbd2cSJim Jagielski aDirVec.push_back( aDir ) ;
253*b1cdbd2cSJim Jagielski break;
254*b1cdbd2cSJim Jagielski }
255*b1cdbd2cSJim Jagielski }
256*b1cdbd2cSJim Jagielski }
257*b1cdbd2cSJim Jagielski if ( chdir( ".." ) == -1 ) { printf("chdir error in .. \n"); return; } // error
258*b1cdbd2cSJim Jagielski if( aHolder.close() < 0 ) return ; // error
259*b1cdbd2cSJim Jagielski
260*b1cdbd2cSJim Jagielski std::sort( aFileVec.begin() , aFileVec.end() , File::lessFile );
261*b1cdbd2cSJim Jagielski std::sort( aDirVec.begin() , aDirVec.end() , Directory::lessDir );
262*b1cdbd2cSJim Jagielski
263*b1cdbd2cSJim Jagielski }
264*b1cdbd2cSJim Jagielski
265*b1cdbd2cSJim Jagielski #endif
266*b1cdbd2cSJim Jagielski }
267