blob: 0b31e777da82a193bf6ceebcabe5a8e4c4de57e6 [file] [log] [blame]
/**************************************************************
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*
*************************************************************/
#include <syshelp.hxx>
// NOT FULLY DEFINED SERVICES
#include <string.h>
#include "sistr.hxx"
#include "list.hxx"
#ifdef WNT
#include <io.h>
#elif defined(UNX) || defined(OS2)
#include <sys/types.h>
#include <sys/stat.h>
#include <dirent.h>
#define stricmp strcasecmp
#else
#error Must run under unix or windows, please define UNX or WNT.
#endif
char C_sSpaceInName[] = "&nbsp;&nbsp;&nbsp;";
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, "<A HREF=\"" );
if ( nNameEnd > -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, "<A HREF=\"" );
o_rFile.write( i_rName.str(), nKomma );
WriteStr( o_rFile, ".html#" );
if ( nEnd > -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, "<A HREF=\"" );
WriteStr( o_rFile, i_rName );
WriteStr( o_rFile, ".html\">" );
WriteStr( o_rFile, i_rName );
}
WriteStr( o_rFile, "</A>" );
return;
}
if ( pNameEnd != 0 )
{
const char * pStart = i_rName.str();
if ( pNameEnd > pStart )
o_rFile.write( pStart, pNameEnd - pStart );
WriteStr( o_rFile, "</A>" );
WriteStr( o_rFile, C_sSpaceInName );
WriteStr( o_rFile, pNameEnd );
}
else
{
WriteStr( o_rFile, i_rName );
WriteStr( o_rFile, "</A>" );
}
}
void
WriteStr( std::ostream & o_rFile,
const char * i_sStr )
{
o_rFile.write( i_sStr, (int) 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<Simstr> & 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) || defined(OS2)
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<Simstr> 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<Simstr> & 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) || defined(OS2)
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
}