/************************************************************************* * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: mkcreate.cxx,v $ * * $Revision: 1.16 $ * * last change: $Author: hr $ $Date: 2007-06-27 22:06:52 $ * * 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 * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_tools.hxx" // global includes #include // local includes #include "bootstrp/mkcreate.hxx" #include "bootstrp/inimgr.hxx" #include "bootstrp/appdef.hxx" #include #include #include "bootstrp/prj.hxx" char const *NoBuildProject[] = { "solenv", "EndOf_NoBuildProject" }; char const *LimitedPath[] = { "jurt\\com\\sun\\star", "r_tools", "ridljar", "setup2", "connectivity", "EndOf_LimitedPath" }; // // class SourceDirectory // /*****************************************************************************/ SourceDirectory::SourceDirectory( const ByteString &rDirectoryName, USHORT nOperatingSystem, SourceDirectory *pParentDirectory ) /*****************************************************************************/ : ByteString( rDirectoryName ), pParent( pParentDirectory ), pSubDirectories( NULL ), nOSType( nOperatingSystem ), nDepth( 0 ), pDependencies( NULL ), pCodedDependencies( NULL ), pCodedIdentifier( NULL ) { if ( pParent ) { if ( !pParent->pSubDirectories ) pParent->pSubDirectories = new SourceDirectoryList(); pParent->pSubDirectories->InsertSorted( this ); nDepth = pParent->nDepth + 1; } } /*****************************************************************************/ SourceDirectory::~SourceDirectory() /*****************************************************************************/ { delete pSubDirectories; } /*****************************************************************************/ CodedDependency *SourceDirectory::AddCodedDependency( const ByteString &rCodedIdentifier, USHORT nOperatingSystems ) /*****************************************************************************/ { CodedDependency *pReturn = NULL; if ( !pCodedDependencies ) { pCodedDependencies = new SByteStringList(); pReturn = new CodedDependency( rCodedIdentifier, nOperatingSystems ); pCodedDependencies->PutString(( ByteString * ) pReturn ); } else { ULONG nPos = pCodedDependencies->IsString( (ByteString *) (& rCodedIdentifier) ); if ( nPos == NOT_THERE ) { pReturn = new CodedDependency( rCodedIdentifier, nOperatingSystems ); pCodedDependencies->PutString(( ByteString * ) pReturn ); } else { pReturn = ( CodedDependency * ) pCodedDependencies->GetObject( nPos ); pReturn->TryToMerge( rCodedIdentifier, nOperatingSystems ); } } return pReturn; } /*****************************************************************************/ CodedDependency *SourceDirectory::AddCodedIdentifier( const ByteString &rCodedIdentifier, USHORT nOperatingSystems ) /*****************************************************************************/ { CodedDependency *pReturn = NULL; if ( !pCodedIdentifier ) { pCodedIdentifier = new SByteStringList(); pReturn = new CodedDependency( rCodedIdentifier, nOperatingSystems ); pCodedIdentifier->PutString(( ByteString * ) pReturn ); } else { ULONG nPos = pCodedIdentifier->IsString( ( ByteString *) (& rCodedIdentifier) ); if ( nPos == NOT_THERE ) { pReturn = new CodedDependency( rCodedIdentifier, nOperatingSystems ); pCodedIdentifier->PutString(( ByteString * ) pReturn ); } else { pReturn = ( CodedDependency * ) pCodedIdentifier->GetObject( nPos ); pReturn->TryToMerge( rCodedIdentifier, nOperatingSystems ); } } if ( pParent && pParent->nDepth > 1 ) pParent->AddCodedIdentifier( rCodedIdentifier, nOperatingSystems ); return pReturn; } /*****************************************************************************/ ByteString SourceDirectory::GetFullPath() /*****************************************************************************/ { ByteString sFullPath; if ( pParent ) { sFullPath = pParent->GetFullPath(); sFullPath += ByteString( PATH_SEPARATOR ); } sFullPath += *this; return sFullPath; } /*****************************************************************************/ SourceDirectory *SourceDirectory::GetRootDirectory() /*****************************************************************************/ { if ( !pParent ) return this; return pParent->GetRootDirectory(); } /*****************************************************************************/ SourceDirectory *SourceDirectory::GetSubDirectory( const ByteString &rDirectoryPath, USHORT nOperatingSystem ) /*****************************************************************************/ { ByteString sSearch; BOOL bSubs = TRUE; ULONG nIndex = 0; while ( bSubs && ByteString( LimitedPath[ nIndex ]) != "EndOf_LimitedPath" ) { SourceDirectory *pActDir = this; ByteString sLimitation( LimitedPath[ nIndex ]); BOOL bBreak = FALSE; for ( ULONG i = sLimitation.GetTokenCount( '\\' ); i > 0 && !bBreak; i-- ) { if (( !pActDir ) || ( *pActDir != sLimitation.GetToken(( USHORT )( i - 1 ), '\\' ))) bBreak = TRUE; else pActDir = pActDir->pParent; } bSubs = bBreak; nIndex++; } if ( !bSubs ) { sSearch = rDirectoryPath; } else sSearch = rDirectoryPath.GetToken( 0, PATH_SEPARATOR ); SourceDirectory *pSubDirectory = NULL; if ( pSubDirectories ) pSubDirectory = pSubDirectories->Search( sSearch ); if ( !pSubDirectory ) pSubDirectory = new SourceDirectory( sSearch, nOperatingSystem, this ); pSubDirectory->nOSType |= nOperatingSystem; if ( sSearch.Len() == rDirectoryPath.Len()) return pSubDirectory; ByteString sPath = rDirectoryPath.Copy( sSearch.Len() + 1 ); return pSubDirectory->GetSubDirectory( sPath, nOperatingSystem ); } /*****************************************************************************/ SourceDirectory *SourceDirectory::GetDirectory( const ByteString &rDirectoryName, USHORT nOperatingSystem ) /*****************************************************************************/ { ByteString sDirectoryName( rDirectoryName ); #ifdef UNX sDirectoryName.SearchAndReplaceAll( "\\", "/" ); #endif SourceDirectory *pRoot = GetRootDirectory(); if ( sDirectoryName.Search( *pRoot ) != 0 ) return NULL; if ( sDirectoryName.Len() == pRoot->Len()) return pRoot; if ( sDirectoryName.GetChar( pRoot->Len()) == PATH_SEPARATOR ) { ByteString sSub = sDirectoryName.Copy( pRoot->Len() + 1 ); return pRoot->GetSubDirectory( sSub, nOperatingSystem ); } return NULL; } /*****************************************************************************/ SourceDirectory *SourceDirectory::Insert( const ByteString &rDirectoryName, USHORT nOperatingSystem ) /*****************************************************************************/ { SourceDirectory *pSubDirectory = NULL; if ( pSubDirectories ) pSubDirectory = pSubDirectories->Search( rDirectoryName ); if ( !pSubDirectory ) pSubDirectory = new SourceDirectory( rDirectoryName, nOperatingSystem, this ); return pSubDirectory; } /*****************************************************************************/ Dependency *SourceDirectory::ResolvesDependency( CodedDependency *pCodedDependency ) /*****************************************************************************/ { if ( !pCodedIdentifier ) return NULL; ULONG nPos = pCodedIdentifier->IsString( pCodedDependency ); if ( nPos != NOT_THERE ) { CodedDependency *pIdentifier = ( CodedDependency * ) pCodedIdentifier->GetObject( nPos ); USHORT nResult = pIdentifier->GetOperatingSystem() & pCodedDependency->GetOperatingSystem(); Dependency *pReturn = new Dependency( *this, nResult ); nResult ^= pCodedDependency->GetOperatingSystem(); pCodedDependency->SetOperatingSystem( nResult ); return pReturn; } return NULL; } /*****************************************************************************/ void SourceDirectory::ResolveDependencies() /*****************************************************************************/ { if ( !pSubDirectories ) return; for ( ULONG i = 0; i < pSubDirectories->Count(); i++ ) { SourceDirectory *pActDirectory = ( SourceDirectory * ) pSubDirectories->GetObject( i ); if ( pActDirectory->pSubDirectories ) pActDirectory->ResolveDependencies(); if ( pActDirectory->pCodedDependencies ) { while ( pActDirectory->pCodedDependencies->Count()) { CodedDependency *pCodedDependency = ( CodedDependency * ) pActDirectory->pCodedDependencies->GetObject(( ULONG ) 0 ); for ( ULONG k = 0; ( k < pSubDirectories->Count()) && ( pCodedDependency->GetOperatingSystem() != OS_NONE ); k++ ) { Dependency *pDependency = ((SourceDirectory *) pSubDirectories->GetObject( k ))-> ResolvesDependency( pCodedDependency ); if ( pDependency ) { if ( !pActDirectory->pDependencies ) pActDirectory->pDependencies = new SByteStringList(); pActDirectory->pDependencies->PutString( pDependency ); } } if ( pCodedDependency->GetOperatingSystem()) { if ( !pCodedDependencies ) pCodedDependencies = new SByteStringList(); pCodedDependencies->PutString( pCodedDependency ); } else delete pCodedDependency; pActDirectory->pCodedDependencies->Remove(( ULONG ) 0 ); } } } } /*****************************************************************************/ ByteString SourceDirectory::GetTarget() /*****************************************************************************/ { ByteString sReturn; if ( !pDependencies ) return sReturn; ULONG k = 0; while ( k < pDependencies->Count()) { if ( *this == *pDependencies->GetObject( k )) delete pDependencies->Remove( k ); else k++; } if ( !pDependencies->Count()) { delete pDependencies; pDependencies = NULL; return sReturn; } BOOL bDependsOnPlatform = FALSE; for ( ULONG i = 0; i < pDependencies->Count(); i++ ) if ((( Dependency * ) pDependencies->GetObject( i ))-> GetOperatingSystem() != OS_ALL ) bDependsOnPlatform = TRUE; ByteString sTarget( *this ); sTarget.SearchAndReplaceAll( "\\", "$/" ); if ( !bDependsOnPlatform ) { sReturn = sTarget; sReturn += " :"; for ( ULONG i = 0; i < pDependencies->Count(); i++ ) { ByteString sDependency( *pDependencies->GetObject( i )); sDependency.SearchAndReplaceAll( "\\", "$/" ); sReturn += " "; sReturn += sDependency; } } else { ByteString sUNX( ".IF \"$(GUI)\" == \"UNX\"\n" ); sUNX += sTarget; sUNX += " :"; BOOL bUNX = FALSE; ByteString sWNT( ".IF \"$(GUI)\" == \"WNT\"\n" ); sWNT += sTarget; sWNT += " :"; BOOL bWNT = FALSE; for ( ULONG i = 0; i < pDependencies->Count(); i++ ) { Dependency *pDependency = ( Dependency * ) pDependencies->GetObject( i ); ByteString sDependency( *pDependency ); sDependency.SearchAndReplaceAll( "\\", "$/" ); if ( pDependency->GetOperatingSystem() & OS_UNX ) { sUNX += " "; sUNX += sDependency; bUNX = TRUE; } if ( pDependency->GetOperatingSystem() & OS_WIN32 ) { sWNT += " "; sWNT += sDependency; bWNT = TRUE; } } if ( bUNX ) { sReturn += sUNX; sReturn += "\n.ENDIF\n"; } if ( bWNT ) { sReturn += sWNT; sReturn += "\n.ENDIF\n"; } } sReturn.EraseTrailingChars( '\n' ); return sReturn; } /*****************************************************************************/ ByteString SourceDirectory::GetSubDirsTarget() /*****************************************************************************/ { ByteString sReturn; if ( pSubDirectories ) { BOOL bDependsOnPlatform = FALSE; for ( ULONG i = 0; i < pSubDirectories->Count(); i++ ) if ((( SourceDirectory * ) pSubDirectories->GetObject( i ))-> GetOperatingSystems() != OS_ALL ) bDependsOnPlatform = TRUE; if ( !bDependsOnPlatform ) { sReturn = "RC_SUBDIRS = "; for ( ULONG i = 0; i < pSubDirectories->Count(); i++ ) { ByteString sSubDirectory( *pSubDirectories->GetObject( i )); sSubDirectory.SearchAndReplaceAll( "\\", "$/" ); sReturn += " \\\n\t"; sReturn += sSubDirectory; } sReturn += "\n"; } else { ByteString sUNX( ".IF \"$(GUI)\" == \"UNX\"\n" ); sUNX += "RC_SUBDIRS = "; BOOL bUNX = FALSE; ByteString sWNT( ".IF \"$(GUI)\" == \"WNT\"\n" ); sWNT += "RC_SUBDIRS = "; BOOL bWNT = FALSE; for ( ULONG i = 0; i < pSubDirectories->Count(); i++ ) { SourceDirectory *pDirectory = ( SourceDirectory * ) pSubDirectories->GetObject( i ); ByteString sDirectory( *pDirectory ); sDirectory.SearchAndReplaceAll( "\\", "$/" ); if ( pDirectory->GetOperatingSystems() & OS_UNX ) { sUNX += " \\\n\t"; sUNX += sDirectory; bUNX = TRUE; } if ( pDirectory->GetOperatingSystems() & OS_WIN32 ) { sWNT += " \\\n\t"; sWNT += sDirectory; bWNT = TRUE; } } if ( bUNX ) { sReturn += sUNX; sReturn += "\n.ENDIF\n"; } if ( bWNT ) { sReturn += sWNT; sReturn += "\n.ENDIF\n"; } } } return sReturn; } /*****************************************************************************/ USHORT SourceDirectory::GetOSType( const ByteString &sDependExt ) /*****************************************************************************/ { USHORT nOSType = 0; if ( sDependExt == "" ) nOSType |= OS_ALL; else if ( sDependExt == "N" || sDependExt == "W" ) nOSType |= OS_WIN32; else if ( sDependExt == "U" ) nOSType |= OS_UNX; return nOSType; } /*****************************************************************************/ SourceDirectory *SourceDirectory::CreateRootDirectory( const ByteString &rRoot, const ByteString &rVersion, BOOL bAll ) /*****************************************************************************/ { IniManager aIniManager; aIniManager.Update(); ByteString sDefLst( GetDefStandList()); ByteString sStandLst( aIniManager.ToLocal( sDefLst )); String s = String( sStandLst, gsl_getSystemTextEncoding()); InformationParser aParser; // fprintf( stderr, // "Reading database %s ...\n", sStandLst.GetBuffer()); GenericInformationList *pVerList = aParser.Execute( s ); /* ByteString sPath( rVersion ); #ifndef UNX sPath += ByteString( "/settings/solarlist" ); #else sPath += ByteString( "/settings/unxsolarlist" ); #endif ByteString sSolarList( _SOLARLIST ); GenericInformation *pInfo = pVerList->GetInfo( sPath, TRUE ); if ( pInfo ) { ByteString aIniRoot( GetIniRoot() ); DirEntry aIniEntry( String( aIniRoot, RTL_TEXTENCODING_ASCII_US )); aIniEntry += DirEntry( String( pInfo->GetValue(), RTL_TEXTENCODING_ASCII_US )).GetBase( PATH_SEPARATOR ); sSolarList = ByteString( aIniEntry.GetFull(), RTL_TEXTENCODING_ASCII_US ); } sSolarList = aIniManager.ToLocal( sSolarList ); fprintf( stderr, "Reading directory information %s ...\n", sSolarList.GetBuffer()); */ ByteString sVersion( rVersion ); Star aStar( pVerList, sVersion, TRUE, rRoot.GetBuffer()); // fprintf( stderr, // "Creating virtual directory tree ...\n" ); SourceDirectory *pSourceRoot = new SourceDirectory( rRoot, OS_ALL ); for ( ULONG i = 0; i < aStar.Count(); i++ ) { Prj *pPrj = aStar.GetObject( i ); BOOL bBuildable = TRUE; ULONG nIndex = 0; while ( bBuildable && ByteString( NoBuildProject[ nIndex ]) != "EndOf_NoBuildProject" ) { bBuildable = ( ByteString( NoBuildProject[ nIndex ]) != pPrj->GetProjectName()); nIndex ++; } if ( bBuildable ) { SourceDirectory *pProject = pSourceRoot->Insert( pPrj->GetProjectName(), OS_ALL ); SByteStringList *pPrjDependencies = pPrj->GetDependencies( FALSE ); if ( pPrjDependencies ) for ( ULONG x = 0; x < pPrjDependencies->Count(); x++ ) pProject->AddCodedDependency( *pPrjDependencies->GetObject( x ), OS_ALL ); pProject->AddCodedIdentifier( pPrj->GetProjectName(), OS_ALL ); for ( ULONG j = 0; j < pPrj->Count(); j++ ) { CommandData *pData = pPrj->GetObject( j ); if ( bAll || ( pData->GetCommandType() == COMMAND_NMAKE )) { ByteString sDirPath( rRoot ); sDirPath += ByteString( PATH_SEPARATOR ); sDirPath += pData->GetPath(); SourceDirectory *pDirectory = pSourceRoot->InsertFull( sDirPath, pData->GetOSType()); SByteStringList *pDependencies = pData->GetDependencies(); if ( pDependencies ) { for ( ULONG k = 0; k < pDependencies->Count(); k++ ) { ByteString sDependency(*pDependencies->GetObject( k )); ByteString sDependExt(sDependency.GetToken( 1, '.' )); sDependExt.ToUpperAscii(); pDirectory->AddCodedDependency( sDependency.GetToken( 0, '.' ), GetOSType( sDependExt )); } } ByteString sIdentifier = pData->GetLogFile(); ByteString sIdExt = sIdentifier.GetToken( 1, '.' ); sIdExt.ToUpperAscii(); pDirectory->AddCodedIdentifier( sIdentifier.GetToken( 0, '.' ), GetOSType( sIdExt )); } } } } delete pVerList; return pSourceRoot; } /*****************************************************************************/ BOOL SourceDirectory::RemoveDirectoryTreeAndAllDependencies() /*****************************************************************************/ { if ( !pParent ) return FALSE; SourceDirectoryList *pParentContent = pParent->pSubDirectories; ULONG i = 0; while ( i < pParentContent->Count()) { SourceDirectory *pCandidate = ( SourceDirectory * )pParentContent->GetObject( i ); if ( pCandidate == this ) { pParentContent->Remove( i ); } else { if ( pCandidate->pDependencies ) { ULONG nPos = pCandidate->pDependencies->IsString( this ); if ( nPos != NOT_THERE ) delete pCandidate->pDependencies->Remove( nPos ); } i++; } } delete this; return TRUE; } /*****************************************************************************/ BOOL SourceDirectory::CreateRecursiveMakefile( BOOL bAllChilds ) /*****************************************************************************/ { if ( !pSubDirectories ) return TRUE; fprintf( stdout, "%s", GetFullPath().GetBuffer()); String aTmpStr( GetFullPath(), gsl_getSystemTextEncoding()); DirEntry aEntry( aTmpStr ); if ( !aEntry.Exists()) { fprintf( stdout, " ... no directory!n" ); return FALSE; } ULONG j = 0; while( j < pSubDirectories->Count()) { String sSubDirectory( (( SourceDirectory * ) pSubDirectories->GetObject( j ))-> GetFullPath(), gsl_getSystemTextEncoding() ); DirEntry aSubDirectory( sSubDirectory ); if ( !aSubDirectory.Exists()) (( SourceDirectory * ) pSubDirectories->GetObject( j ))-> RemoveDirectoryTreeAndAllDependencies(); else j++; } DirEntry aRCFile( String( "makefile.rc", gsl_getSystemTextEncoding())); DirEntry aRCEntry( aEntry ); aRCEntry += aRCFile; DirEntry aMKFile( String( "makefile.mk", gsl_getSystemTextEncoding())); DirEntry aMKEntry( aEntry ); aMKEntry += aMKFile; BOOL bMakefileMk = FALSE; if ( aMKEntry.Exists()) { if ( nDepth == 1 && *this == ByteString( "api" )) fprintf( stdout, " ... makefile.mk exists, ignoring (hack: prj == api)!" ); else { fprintf( stdout, " ... makefile.mk exists, including!" ); bMakefileMk = TRUE; } } SvFileStream aMakefile( aRCEntry.GetFull(), STREAM_STD_WRITE | STREAM_TRUNC ); if ( !aMakefile.IsOpen()) { fprintf( stdout, " ... failed!\n" ); return FALSE; } ByteString sHeader( "#*************************************************************************\n" "#\n" "# OpenOffice.org - a multi-platform office productivity suite\n" "#\n" "# $RCSfile: mkcreate.cxx,v $\n" "#\n" "# $Revision: 1.16 $\n" "#\n" "# last change: $Author: hr $ $Date: 2007-06-27 22:06:52 $\n" "#\n" "# The Contents of this file are made available subject to\n" "# the terms of GNU Lesser General Public License Version 2.1.\n" "#\n" "#\n" "# GNU Lesser General Public License Version 2.1\n" "# =============================================\n" "# Copyright 2005 by Sun Microsystems, Inc.\n" "# 901 San Antonio Road, Palo Alto, CA 94303, USA\n" "#\n" "# This library is free software; you can redistribute it and/or\n" "# modify it under the terms of the GNU Lesser General Public\n" "# License version 2.1, as published by the Free Software Foundation.\n" "#\n" "# This library is distributed in the hope that it will be useful,\n" "# but WITHOUT ANY WARRANTY; without even the implied warranty of\n" "# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU\n" "# Lesser General Public License for more details.\n" "#\n" "# You should have received a copy of the GNU Lesser General Public\n" "# License along with this library; if not, write to the Free Software\n" "# Foundation, Inc., 59 Temple Place, Suite 330, Boston,\n" "# MA 02111-1307 USA\n" "#\n" "#*************************************************************************\n" "\n" ); if ( !bMakefileMk ) { if ( nDepth == 0 ) { sHeader += ByteString( "\n" "# \n" "# mark this makefile as a recursive one\n" "# \n" "\n" "MAKEFILERC=yes\n" "\n" "# \n" "# implementation of cvs checkout\n" "# \n" "\n" ".IF \"$(checkout)\"==\"\"\n" "all_target: ALLTAR\n" ".ELSE\t# \"$(checkout)\"==\"\"\n" ".IF \"$(checkout)\"==\"true\"\n" "% : $(NULL)\n" "\t_cvs co $@\n" ".ELSE\t# \"$(checkout)\"==\"true\"\n" "% : $(NULL)\n" "\t_cvs co -r$(checkout) $@\n" ".ENDIF\t# \"$(checkout)\"==\"true\"\n" "all_subdirs : $(RC_SUBDIRS)\n" ".ENDIF\t# \"$(checkout)\"==\"\"\n" ); } else { sHeader += ByteString( "\n" "# \n" "# mark this makefile as a recursive one\n" "# \n" "\n" "MAKEFILERC=yes\n" ); if ( nDepth == 1 ) sHeader += ByteString( ".IF \"$(build_deliver)\"==\"true\"\n" "all_target:\t\t\\\n" "\tTG_DELIVER\t\\\n" "\tALLTAR\n" ".ELSE # \"$(build_deliver)\"==\"true\"\n" "all_target: ALLTAR\n" ".ENDIF # \"$(build_deliver)\"==\"true\"\n" ); else sHeader += ByteString( "all_target: ALLTAR\n" ); } } else { if ( nDepth == 1 ) sHeader += ByteString( ".IF \"$(build_deliver)\"==\"true\"\n" "all_target:\t\t\\\n" "\tTG_DELIVER\t\\\n" "\tALLTAR\n" ".ELSE # \"$(build_deliver)\"==\"true\"\n" "all_target: ALLTAR\n" ".ENDIF # \"$(build_deliver)\"==\"true\"\n" ); } sHeader += ByteString( "\n" "# \n" "# macro RC_SUBDIRS handles iteration over\n" "# all mandatory sub directories\n" "# \n" ); aMakefile.WriteLine( sHeader ); aMakefile.WriteLine( GetSubDirsTarget()); if ( nDepth == 0 ) { ByteString sBootstrapTarget( "# \n" "# bootstrap target\n" "# \n\n" "bootstrap .PHONY :\n" "\t@config_office/bootstrap\n\n" ); aMakefile.WriteLine( sBootstrapTarget ); ByteString sConfigureTarget( "# \n" "# configure target\n" "# \n\n" "configure .PHONY SETDIR=config_office :\n" "\t@configure\n" ); aMakefile.WriteLine( sConfigureTarget ); } else if ( nDepth == 1 ) { ByteString sDeliverTarget( "# \n" "# deliver target to handle\n" "# project dependencies\n" "# \n\n" "TG_DELIVER : $(RC_SUBDIRS)\n" "\t$(DELIVER)\n" ); aMakefile.WriteLine( sDeliverTarget ); } if ( bMakefileMk ) { ByteString sInclude( "# \n" "# local makefile\n" "# \n" "\n" ".INCLUDE : makefile.mk\n" ); if ( nDepth != 1 ) sInclude += ByteString( "\n" "all_rc_target: ALLTAR\n" ); aMakefile.WriteLine( sInclude ); } ByteString sComment( "# \n" "# single directory targets for\n" "# dependency handling between directories\n" "# \n" ); aMakefile.WriteLine( sComment ); for ( ULONG i = 0; i < pSubDirectories->Count(); i++ ) { ByteString sTarget( (( SourceDirectory * )pSubDirectories->GetObject( i ))-> GetTarget() ); if ( sTarget.Len()) aMakefile.WriteLine( sTarget ); } ByteString sFooter( "\n" ); if ( !bMakefileMk ) { sFooter += ByteString( "# \n" "# central target makefile\n" "# \n" "\n" ); if ( nDepth != 0 ) { sFooter += ByteString( ".INCLUDE : target.mk\n" ); } else { sFooter += ByteString( ".IF \"$(checkout)\"==\"\"\n" ".INCLUDE : target.mk\n" ".ENDIF\t#\"$(checkout)\"==\"\"\n" ); } } sFooter += ByteString( "\n" "#*************************************************************************\n" ); aMakefile.WriteLine( sFooter ); aMakefile.Close(); fprintf( stdout, "\n" ); BOOL bSuccess = TRUE; if ( bAllChilds ) for ( ULONG k = 0; k < pSubDirectories->Count(); k++ ) if ( !(( SourceDirectory * ) pSubDirectories->GetObject( k ))-> CreateRecursiveMakefile( TRUE )) bSuccess = FALSE; return bSuccess; } // // class SourceDirectoryList // /*****************************************************************************/ SourceDirectoryList::~SourceDirectoryList() /*****************************************************************************/ { for ( ULONG i = 0; i < Count(); i++ ) delete GetObject( i ); } /*****************************************************************************/ SourceDirectory *SourceDirectoryList::Search( const ByteString &rDirectoryName ) /*****************************************************************************/ { ULONG nPos = IsString( ( ByteString * ) (&rDirectoryName) ); if ( nPos != LIST_ENTRY_NOTFOUND ) return ( SourceDirectory * ) GetObject( nPos ); return NULL; }