mirror of
https://github.com/reactos/reactos.git
synced 2025-01-01 03:54:02 +00:00
Add a variable to change the name of the ReactOS directory on bootcd.
If a non default name is chosen, the cdrom is created, but it is unusable as freeldr doesn't find txtsetup.inf svn path=/trunk/; revision=26131
This commit is contained in:
parent
b0385e2a41
commit
87bde6d032
34 changed files with 136 additions and 57 deletions
|
@ -69,6 +69,11 @@
|
|||
# Examples of output files include *.exe, *.dll, and *.sys. N.B. Don't
|
||||
# put a path separator at the end. The variable defaults to .\output-i386.
|
||||
#
|
||||
# ROS_CDOUTPUT
|
||||
# This variable controls the name of the ReactOS directory on cdrom.
|
||||
# The variable defaults to reactos.
|
||||
# Warning: setting this value may lead to a not bootable/installable cdrom.
|
||||
#
|
||||
# ROS_TEMPORARY
|
||||
# This variable controls where to put temporary files. Temporary files
|
||||
# are (usually small) generated files that are needed to generate the
|
||||
|
@ -321,17 +326,32 @@ endif
|
|||
ifneq ($(ROS_INTERMEDIATE),)
|
||||
INTERMEDIATE := $(ROS_INTERMEDIATE)
|
||||
else
|
||||
ifneq ($(ROS_CDOUTPUT),)
|
||||
INTERMEDIATE := obj-$(ROS_CDOUTPUT)
|
||||
else
|
||||
INTERMEDIATE := obj-i386
|
||||
endif
|
||||
endif
|
||||
INTERMEDIATE_ := $(INTERMEDIATE)$(SEP)
|
||||
|
||||
ifneq ($(ROS_OUTPUT),)
|
||||
OUTPUT := $(ROS_OUTPUT)
|
||||
else
|
||||
ifneq ($(ROS_CDOUTPUT),)
|
||||
OUTPUT := output-$(ROS_CDOUTPUT)
|
||||
else
|
||||
OUTPUT := output-i386
|
||||
endif
|
||||
endif
|
||||
OUTPUT_ := $(OUTPUT)$(SEP)
|
||||
|
||||
ifneq ($(ROS_CDOUTPUT),)
|
||||
CDOUTPUT := $(ROS_CDOUTPUT)
|
||||
else
|
||||
CDOUTPUT := reactos
|
||||
endif
|
||||
CDOUTPUT_ := $(CDOUTPUT)$(SEP)
|
||||
|
||||
ifneq ($(ROS_TEMPORARY),)
|
||||
TEMPORARY := $(ROS_TEMPORARY)
|
||||
else
|
||||
|
@ -342,7 +362,11 @@ TEMPORARY_ := $(TEMPORARY)$(SEP)
|
|||
ifneq ($(ROS_INSTALL),)
|
||||
INSTALL := $(ROS_INSTALL)
|
||||
else
|
||||
ifneq ($(ROS_CDOUTPUT),)
|
||||
INSTALL := reactos.$(ROS_CDOUTPUT)
|
||||
else
|
||||
INSTALL := reactos
|
||||
endif
|
||||
endif
|
||||
INSTALL_ := $(INSTALL)$(SEP)
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="reactos" type="win32gui">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<include base="reactos">.</include>
|
||||
<define name="_WIN32_IE">0x0501</define>
|
||||
<define name="_WIN32_WINNT">0x0501</define>
|
||||
|
|
|
@ -2,12 +2,12 @@
|
|||
<cdfile>autorun.inf</cdfile>
|
||||
<cdfile>icon.ico</cdfile>
|
||||
<cdfile>readme.txt</cdfile>
|
||||
<cdfile base="reactos">hivecls.inf</cdfile>
|
||||
<cdfile base="reactos">hivedef.inf</cdfile>
|
||||
<cdfile base="reactos">hivesft.inf</cdfile>
|
||||
<cdfile base="reactos">hivesys.inf</cdfile>
|
||||
<cdfile base="reactos">txtsetup.sif</cdfile>
|
||||
<!--<cdfile base="reactos">unattend.inf</cdfile>-->
|
||||
<cdfile base="$(CDOUTPUT)">hivecls.inf</cdfile>
|
||||
<cdfile base="$(CDOUTPUT)">hivedef.inf</cdfile>
|
||||
<cdfile base="$(CDOUTPUT)">hivesft.inf</cdfile>
|
||||
<cdfile base="$(CDOUTPUT)">hivesys.inf</cdfile>
|
||||
<cdfile base="$(CDOUTPUT)">txtsetup.sif</cdfile>
|
||||
<!--<cdfile base="$(CDOUTPUT)">unattend.inf</cdfile>-->
|
||||
<directory name="bootcd">
|
||||
<xi:include href="bootcd/bootcd.rbuild" />
|
||||
</directory>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="ntdll" type="win32dll" entrypoint="0" baseaddress="${BASEADDRESS_NTDLL}" installbase="system32" installname="ntdll.dll">
|
||||
<bootstrap base="reactos/system32" />
|
||||
<bootstrap base="$(CDOUTPUT)/system32" />
|
||||
<importlibrary definition="def/ntdll.def" />
|
||||
<include base="ntdll">inc</include>
|
||||
<include base="ReactOS">include/reactos/subsys</include>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="blue" type="kernelmodedriver" installbase="system32/drivers" installname="blue.sys">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<define name="__USE_W32API" />
|
||||
<include base="ReactOS">include/reactos/drivers</include>
|
||||
<library>ntoskrnl</library>
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
<module name="bootvid" type="kernelmodedll" entrypoint="DriverEntry@8" installbase="system32/drivers" installname="bootvid.dll">
|
||||
<importlibrary definition="bootvid.def"></importlibrary>
|
||||
<bootstrap base="reactos" nameoncd="bootvid.dll" />
|
||||
<bootstrap base="$(CDOUTPUT)" nameoncd="bootvid.dll" />
|
||||
<include base="bootvid">.</include>
|
||||
<define name="__USE_W32API" />
|
||||
<library>ntoskrnl</library>
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
<module name="kdcom" type="kernelmodedll" entrypoint="DriverEntry@8" installbase="system32/drivers" installname="kdcom.dll">
|
||||
<importlibrary definition="kdcom.def"></importlibrary>
|
||||
<bootstrap base="reactos" nameoncd="kdcom.dll" />
|
||||
<bootstrap base="$(CDOUTPUT)" nameoncd="kdcom.dll" />
|
||||
<include base="kdcom">.</include>
|
||||
<define name="__USE_W32API" />
|
||||
<library>ntoskrnl</library>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="cdfs" type="kernelmodedriver" installbase="system32/drivers" installname="cdfs.sys">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<include base="cdfs">.</include>
|
||||
<define name="__USE_W32API" />
|
||||
<library>ntoskrnl</library>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="ntfs" type="kernelmodedriver" installbase="system32/drivers" installname="ntfs.sys">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<include base="ntfs">.</include>
|
||||
<define name="__USE_W32API" />
|
||||
<library>ntoskrnl</library>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="vfatfs" type="kernelmodedriver" installbase="system32/drivers" installname="vfatfs.sys">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<include base="vfatfs">.</include>
|
||||
<define name="__USE_W32API" />
|
||||
<linkerflag>-lgcc</linkerflag>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="i8042prt" type="kernelmodedriver" installbase="system32/drivers" installname="i8042prt.sys">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<include base="i8042prt">.</include>
|
||||
<define name="__USE_W32API" />
|
||||
<define name="__REACTOS__" />
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="kbdclass" type="kernelmodedriver" installbase="system32/drivers" installname="kbdclass.sys">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<define name="__USE_W32API" />
|
||||
<define name="NDEBUG" />
|
||||
<library>pseh</library>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="atapi" type="kernelmodedriver" installbase="system32/drivers" installname="atapi.sys">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<define name="__USE_W32API" />
|
||||
<include base="atapi">.</include>
|
||||
<library>ntoskrnl</library>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="buslogic" type="kernelmodedriver" installbase="system32/drivers" installname="buslogic.sys">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<define name="__USE_W32API" />
|
||||
<include base="buslogic">.</include>
|
||||
<library>ntoskrnl</library>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="cdrom" type="kernelmodedriver" installbase="system32/drivers" installname="cdrom.sys">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<define name="__USE_W32API" />
|
||||
<library>ntoskrnl</library>
|
||||
<library>hal</library>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="class2" type="exportdriver" installbase="system32/drivers" installname="class2.sys">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<define name="__USE_W32API" />
|
||||
<importlibrary definition="class2.def" />
|
||||
<library>ntoskrnl</library>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="disk" type="kernelmodedriver" installbase="system32/drivers" installname="disk.sys" allowwarnings="true">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<define name="__USE_W32API" />
|
||||
<linkerflag>-lgcc</linkerflag>
|
||||
<library>ntoskrnl</library>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="diskdump" type="exportdriver" installbase="system32/drivers" installname="diskdump.sys">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<define name="__USE_W32API" />
|
||||
<include base="ReactOS">include/reactos/drivers</include>
|
||||
<library definition="diskdump.def" />
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="floppy" type="kernelmodedriver" installbase="system32/drivers" installname="floppy.sys">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<define name="__USE_W32API" />
|
||||
<include base="floppy">.</include>
|
||||
<library>ntoskrnl</library>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="scsiport" type="exportdriver" installbase="system32/drivers" installname="scsiport.sys">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<define name="__USE_W32API" />
|
||||
<define name="_SCSIPORT_" />
|
||||
<importlibrary definition="scsiport.def" />
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="csqtest" type="kernelmodedriver" installbase="system32/drivers" installname="csqtest.sys">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<define name="__USE_W32API" />
|
||||
<include base="ReactOS">include/reactos/drivers</include>
|
||||
<library>ntoskrnl</library>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="kmtest" type="kernelmodedriver" installbase="system32/drivers" installname="kmtest.sys">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<define name="__USE_W32API" />
|
||||
<include base="ReactOS">include/reactos/drivers</include>
|
||||
<library>ntoskrnl</library>
|
||||
|
|
|
@ -15,7 +15,7 @@
|
|||
|
||||
/* PRIVATE FUNCTIONS *********************************************************/
|
||||
|
||||
VOID
|
||||
static VOID
|
||||
NTAPI
|
||||
HalpWriteResetCommand(VOID)
|
||||
{
|
||||
|
@ -23,7 +23,7 @@ HalpWriteResetCommand(VOID)
|
|||
WRITE_PORT_UCHAR((PUCHAR)0x64, 0xFE);
|
||||
};
|
||||
|
||||
VOID
|
||||
static VOID
|
||||
NTAPI
|
||||
HalpReboot(VOID)
|
||||
{
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
<module name="halmp" type="kernelmodedll" entrypoint="0">
|
||||
<importlibrary definition="../../hal/hal.def" />
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<include base="hal_generic">../include</include>
|
||||
<include base="ntoskrnl">include</include>
|
||||
<define name="_DISABLE_TIDENTS" />
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
<module name="halup" type="kernelmodedll" entrypoint="0">
|
||||
<importlibrary definition="../../hal/hal.def" />
|
||||
<bootstrap base="reactos" nameoncd="hal.dll" />
|
||||
<bootstrap base="$(CDOUTPUT)" nameoncd="hal.dll" />
|
||||
<include base="hal_generic">../include</include>
|
||||
<include base="ntoskrnl">include</include>
|
||||
<define name="_DISABLE_TIDENTS" />
|
||||
|
|
|
@ -1,6 +1,8 @@
|
|||
<cdfile base="reactos">services</cdfile>
|
||||
<group>
|
||||
<cdfile base="$(CDOUTPUT)">services</cdfile>
|
||||
<installfile base="system32/drivers/etc">services</installfile>
|
||||
<if property="KDBG" value="1">
|
||||
<cdfile base="reactos">KDBinit</cdfile>
|
||||
<cdfile base="$(CDOUTPUT)">KDBinit</cdfile>
|
||||
<installfile base="system32/drivers/etc">KDBinit</installfile>
|
||||
</if>
|
||||
</group>
|
|
@ -1,7 +1,7 @@
|
|||
<group>
|
||||
<cdfile base="reactos">c_437.nls</cdfile>
|
||||
<cdfile base="reactos">c_1252.nls</cdfile>
|
||||
<cdfile base="reactos">l_intl.nls</cdfile>
|
||||
<cdfile base="$(CDOUTPUT)">c_437.nls</cdfile>
|
||||
<cdfile base="$(CDOUTPUT)">c_1252.nls</cdfile>
|
||||
<cdfile base="$(CDOUTPUT)">l_intl.nls</cdfile>
|
||||
|
||||
<installfile base="system32">c_037.nls</installfile>
|
||||
<installfile base="system32">c_424.nls</installfile>
|
||||
|
|
|
@ -326,7 +326,15 @@ DBGKD_GET_VERSION64 KdVersionBlock =
|
|||
DBGKD_64BIT_PROTOCOL_VERSION2,
|
||||
KD_SECONDARY_VERSION_DEFAULT,
|
||||
DBGKD_VERS_FLAG_DATA,
|
||||
#if defined(_M_IX86)
|
||||
IMAGE_FILE_MACHINE_I386,
|
||||
#elif defined(_M_PPC)
|
||||
IMAGE_FILE_MACHINE_POWERPC,
|
||||
#elif defined(_M_MIPS)
|
||||
IMAGE_FILE_MACHINE_R4000,
|
||||
#else
|
||||
#error Unknown platform
|
||||
#endif
|
||||
PACKET_TYPE_MAX,
|
||||
0,
|
||||
0,
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<module name="ntoskrnl" type="kernel" installbase="system32" installname="ntoskrnl.exe">
|
||||
<bootstrap base="reactos" />
|
||||
<bootstrap base="$(CDOUTPUT)" />
|
||||
<importlibrary definition="ntoskrnl.def" />
|
||||
<define name="_SEH_NO_NATIVE_NLG" />
|
||||
<define name="_DISABLE_TIDENTS" />
|
||||
|
|
|
@ -3153,7 +3153,7 @@ MingwIsoModuleHandler::GenerateIsoModuleTarget ()
|
|||
NormalizeFilename ( "boot" + sSep + "freeldr" + sSep + "bootsect" + sSep + bootloader.c_str() ),
|
||||
backend->outputDirectory );
|
||||
|
||||
string bootcdReactosNoFixup = bootcdDirectory + sSep + "reactos";
|
||||
string bootcdReactosNoFixup = bootcdDirectory + sSep + Environment::GetCdOutputPath ();
|
||||
string bootcdReactos = PassThruCacheDirectory (
|
||||
NormalizeFilename ( bootcdReactosNoFixup + sSep ),
|
||||
backend->outputDirectory );
|
||||
|
|
|
@ -73,6 +73,18 @@ Bootstrap::IsSupportedModuleType ( ModuleType type )
|
|||
__LINE__ );
|
||||
}
|
||||
|
||||
string
|
||||
Bootstrap::ReplaceVariable ( const string& name,
|
||||
const string& value,
|
||||
string path )
|
||||
{
|
||||
size_t i = path.find ( name );
|
||||
if ( i != string::npos )
|
||||
return path.replace ( i, name.length (), value );
|
||||
else
|
||||
return path;
|
||||
}
|
||||
|
||||
void
|
||||
Bootstrap::Initialize ()
|
||||
{
|
||||
|
@ -85,7 +97,7 @@ Bootstrap::Initialize ()
|
|||
|
||||
const XMLAttribute* att = node.GetAttribute ( "base", false );
|
||||
if ( att != NULL )
|
||||
base = att->value;
|
||||
base = ReplaceVariable ( "$(CDOUTPUT)", Environment::GetCdOutputPath (), att->value );
|
||||
else
|
||||
base = "";
|
||||
|
||||
|
|
|
@ -22,6 +22,18 @@
|
|||
|
||||
using std::string;
|
||||
|
||||
string
|
||||
CDFile::ReplaceVariable ( const string& name,
|
||||
const string& value,
|
||||
string path )
|
||||
{
|
||||
size_t i = path.find ( name );
|
||||
if ( i != string::npos )
|
||||
return path.replace ( i, name.length (), value );
|
||||
else
|
||||
return path;
|
||||
}
|
||||
|
||||
CDFile::CDFile ( const Project& project_,
|
||||
const XMLElement& cdfileNode,
|
||||
const string& path )
|
||||
|
@ -30,7 +42,7 @@ CDFile::CDFile ( const Project& project_,
|
|||
{
|
||||
const XMLAttribute* att = node.GetAttribute ( "base", false );
|
||||
if ( att != NULL )
|
||||
base = att->value;
|
||||
base = ReplaceVariable ( "$(CDOUTPUT)", Environment::GetCdOutputPath (), att->value );
|
||||
else
|
||||
base = "";
|
||||
|
||||
|
|
|
@ -49,21 +49,34 @@ Environment::GetEnvironmentVariablePathOrDefault ( const string& name,
|
|||
/* static */ string
|
||||
Environment::GetIntermediatePath ()
|
||||
{
|
||||
string defaultIntermediate =
|
||||
string( "obj-" ) + GetEnvironmentVariablePathOrDefault ( "ROS_CDOUTPUT", "i386" );
|
||||
return GetEnvironmentVariablePathOrDefault ( "ROS_INTERMEDIATE",
|
||||
"obj-i386" );
|
||||
defaultIntermediate );
|
||||
}
|
||||
|
||||
/* static */ string
|
||||
Environment::GetOutputPath ()
|
||||
{
|
||||
string defaultOutput =
|
||||
string( "output-" ) + GetEnvironmentVariablePathOrDefault ( "ROS_CDOUTPUT", "i386" );
|
||||
return GetEnvironmentVariablePathOrDefault ( "ROS_OUTPUT",
|
||||
"output-i386" );
|
||||
defaultOutput );
|
||||
}
|
||||
|
||||
/* static */ string
|
||||
Environment::GetInstallPath ()
|
||||
{
|
||||
string defaultInstall =
|
||||
string( "reactos." ) + GetEnvironmentVariablePathOrDefault ( "ROS_CDOUTPUT", "" );
|
||||
return GetEnvironmentVariablePathOrDefault ( "ROS_INSTALL",
|
||||
defaultInstall );
|
||||
}
|
||||
|
||||
/* static */ string
|
||||
Environment::GetCdOutputPath ()
|
||||
{
|
||||
return GetEnvironmentVariablePathOrDefault ( "ROS_CDOUTPUT",
|
||||
"reactos" );
|
||||
}
|
||||
|
||||
|
|
|
@ -155,6 +155,7 @@ public:
|
|||
static std::string GetVariable ( const std::string& name );
|
||||
static std::string GetIntermediatePath ();
|
||||
static std::string GetOutputPath ();
|
||||
static std::string GetCdOutputPath ();
|
||||
static std::string GetInstallPath ();
|
||||
static std::string GetEnvironmentVariablePathOrDefault ( const std::string& name,
|
||||
const std::string& defaultValue );
|
||||
|
@ -761,6 +762,9 @@ public:
|
|||
private:
|
||||
bool IsSupportedModuleType ( ModuleType type );
|
||||
void Initialize();
|
||||
static std::string ReplaceVariable ( const std::string& name,
|
||||
const std::string& value,
|
||||
std::string path );
|
||||
};
|
||||
|
||||
|
||||
|
@ -780,6 +784,10 @@ public:
|
|||
~CDFile ();
|
||||
void ProcessXML();
|
||||
std::string GetPath () const;
|
||||
private:
|
||||
static std::string ReplaceVariable ( const std::string& name,
|
||||
const std::string& value,
|
||||
std::string path );
|
||||
};
|
||||
|
||||
|
||||
|
|
Loading…
Reference in a new issue