/************************************************************************* * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: syshelp.cxx,v $ * * $Revision: 1.10 $ * * last change: $Author: rt $ $Date: 2005-09-09 11:58:31 $ * * 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 * ************************************************************************/ #include // NOT FULLY DEFINED SERVICES #include #include "sistr.hxx" #include "list.hxx" #ifdef WNT #include #elif defined(UNX) #include #include #include #define stricmp strcasecmp #else #error Must run under unix or windows, please define UNX or WNT. #endif char C_sSpaceInName[] = "   "; void WriteName( std::ostream & o_rFile, const Simstr & i_rIdlDocuBaseDir, const Simstr & i_rName, E_LinkType i_eLinkType ) { if (i_rName.l() == 0) return; const char * pNameEnd = strstr( i_rName.str(), " in " ); // No link: if ( i_eLinkType == lt_nolink ) { if ( pNameEnd != 0 ) { const char * pStart = i_rName.str(); o_rFile.write( pStart, pNameEnd - pStart ); WriteStr( o_rFile, C_sSpaceInName ); WriteStr( o_rFile, pNameEnd ); } else { WriteStr( o_rFile, i_rName ); } return; } if ( i_eLinkType == lt_idl ) { Simstr sPath(i_rName); sPath.replace_all('.','/'); int nNameEnd = sPath.pos_first(' '); int nPathStart = sPath.pos_last(' '); WriteStr( o_rFile, " -1 ) { WriteStr( o_rFile, "file:///" ); WriteStr( o_rFile, i_rIdlDocuBaseDir ); WriteStr( o_rFile, "/" ); WriteStr( o_rFile, sPath.str() + 1 + nPathStart ); WriteStr( o_rFile, "/" ); o_rFile.write( sPath.str(), nNameEnd ); WriteStr( o_rFile, ".html\">" ); } else { // Should not be reached: WriteStr(o_rFile, i_rName); return; } } else if ( i_eLinkType == lt_html ) { int nKomma = i_rName.pos_first(','); int nEnd = i_rName.pos_first(' '); if ( nKomma > -1 ) { o_rFile.write( i_rName.str(), nKomma ); WriteStr( o_rFile, ": " ); WriteStr( o_rFile, " -1 ) o_rFile.write( i_rName.str() + nKomma + 1, nEnd - nKomma ); else WriteStr( o_rFile, i_rName.str() + nKomma + 1 ); WriteStr( o_rFile, "\">" ); o_rFile.write( i_rName.str() + nKomma + 1, nEnd - nKomma ); } else { WriteStr( o_rFile, "" ); WriteStr( o_rFile, i_rName ); } WriteStr( o_rFile, "" ); return; } if ( pNameEnd != 0 ) { const char * pStart = i_rName.str(); if ( pNameEnd > pStart ) o_rFile.write( pStart, pNameEnd - pStart ); WriteStr( o_rFile, "" ); WriteStr( o_rFile, C_sSpaceInName ); WriteStr( o_rFile, pNameEnd ); } else { WriteStr( o_rFile, i_rName ); WriteStr( o_rFile, "" ); } } void WriteStr( std::ostream & o_rFile, const char * i_sStr ) { o_rFile.write( i_sStr, strlen(i_sStr) ); } void WriteStr( std::ostream & o_rFile, const Simstr & i_sStr ) { o_rFile.write( i_sStr.str(), i_sStr.l() ); } const char C_sXML_END[] = "\\*.xml"; void GatherFileNames( List & o_sFiles, const char * i_sSrcDirectory ) { static int nAliveCounter = 0; char * sNextDir = 0; Simstr sNew = 0; #ifdef WNT struct _finddata_t aEntry; long hFile = 0; int bFindMore = 0; char * sFilter = new char[ strlen(i_sSrcDirectory) + sizeof C_sXML_END ]; // Stayingalive sign if (++nAliveCounter % 100 == 1) std::cout << "." << std::flush; strcpy(sFilter, i_sSrcDirectory); // STRCPY SAFE HERE strcat(sFilter,C_sXML_END); // STRCAT SAFE HERE hFile = _findfirst( sFilter, &aEntry ); for ( bFindMore = hFile == -1; bFindMore == 0; bFindMore = _findnext( hFile, &aEntry ) ) { sNew = i_sSrcDirectory; sNew += "\\"; sNew += aEntry.name; o_sFiles.push_back(sNew); } // end for _findclose(hFile); delete [] sFilter; #elif defined(UNX) DIR * pDir = opendir( i_sSrcDirectory ); dirent * pEntry = 0; char * sEnding; // Stayingalive sign if (++nAliveCounter % 100 == 1) std::cout << "." << std::flush; while ( (pEntry = readdir(pDir)) != 0 ) { sEnding = strrchr(pEntry->d_name,'.'); if (sEnding != 0 ? stricmp(sEnding,".xml") == 0 : 0 ) { sNew = i_sSrcDirectory; sNew += "/"; sNew += pEntry->d_name; o_sFiles.push_back(sNew); } } // end while closedir( pDir ); #else #error Must run on unix or windows, please define UNX or WNT. #endif // gathering from subdirectories: List aSubDirectories; GatherSubDirectories( aSubDirectories, i_sSrcDirectory ); unsigned d_max = aSubDirectories.size(); for ( unsigned d = 0; d < d_max; ++d ) { sNextDir = new char[ strlen(i_sSrcDirectory) + 2 + aSubDirectories[d].l() ]; strcpy(sNextDir, i_sSrcDirectory); strcat(sNextDir, C_sSLASH); strcat(sNextDir, aSubDirectories[d].str()); GatherFileNames(o_sFiles, sNextDir); delete [] sNextDir; } } const char * C_sANYDIR = "\\*.*"; void GatherSubDirectories( List & o_sSubDirectories, const char * i_sParentdDirectory ) { Simstr sNew; #ifdef WNT struct _finddata_t aEntry; long hFile = 0; int bFindMore = 0; char * sFilter = new char[strlen(i_sParentdDirectory) + sizeof C_sANYDIR]; strcpy(sFilter, i_sParentdDirectory); strcat(sFilter,C_sANYDIR); hFile = _findfirst( sFilter, &aEntry ); for ( bFindMore = hFile == -1; bFindMore == 0; bFindMore = _findnext( hFile, &aEntry ) ) { if (aEntry.attrib == _A_SUBDIR) { // Do not gather . .. and outputtree directories if ( strchr(aEntry.name,'.') == 0 && strncmp(aEntry.name, "wnt", 3) != 0 && strncmp(aEntry.name, "unx", 3) != 0 ) { sNew = aEntry.name; o_sSubDirectories.push_back(sNew); } } // endif (aEntry.attrib == _A_SUBDIR) } // end for _findclose(hFile); delete [] sFilter; #elif defined(UNX) DIR * pDir = opendir( i_sParentdDirectory ); dirent * pEntry = 0; struct stat aEntryStatus; while ( ( pEntry = readdir(pDir) ) != 0 ) { stat(pEntry->d_name, &aEntryStatus); if ( ( aEntryStatus.st_mode & S_IFDIR ) == S_IFDIR ) { // Do not gather . .. and outputtree directories if ( strchr(pEntry->d_name,'.') == 0 && strncmp(pEntry->d_name, "wnt", 3) != 0 && strncmp(pEntry->d_name, "unx", 3) != 0 ) { sNew = pEntry->d_name; o_sSubDirectories.push_back(sNew); } } // endif (aEntry.attrib == _A_SUBDIR) } // end while closedir( pDir ); #else #error Must run on unix or windows, please define UNX or WNT. #endif }