Merge pull request #575 from illwieckz/shaderlists

load shaderlist.txt from more than one VFS, fix #573
This commit is contained in:
Timothee "TTimo" Besset 2018-01-21 15:01:50 -06:00 committed by GitHub
commit ac48f23d4d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -469,7 +469,7 @@ void DumpUnreferencedShaders(){
================== ==================
*/ */
void BuildShaderList(){ void BuildShaderList(){
int count; int count, i;
char filename[1024]; char filename[1024];
char *pBuff; char *pBuff;
char dirstring[NAME_MAX]; char dirstring[NAME_MAX];
@ -486,41 +486,45 @@ void BuildShaderList(){
Sys_FPrintf( SYS_ERR, "Couldn't find '%s'\n", g_pGameDescription->mShaderlist.GetBuffer() ); Sys_FPrintf( SYS_ERR, "Couldn't find '%s'\n", g_pGameDescription->mShaderlist.GetBuffer() );
return; return;
} }
// NOTE TTimo we use vfsGetFullPath solely to get the full path of the shader list we are gonna load
// but we actually send the relative path to vfsLoadFile
// so let's hope there is no disparity between the two functions
if ( !vfsGetFullPath( filename, 0, 0 ) ) {
Sys_FPrintf( SYS_ERR, "Couldn't find full path for '%s'\n", g_pGameDescription->mShaderlist.GetBuffer() );
return;
}
Sys_Printf( "Parsing shader files from %s\n", vfsGetFullPath( filename, 0, 0 ) );
nLen = vfsLoadFile( filename, reinterpret_cast<void**>( &pBuff ), 0 );
if ( nLen > 0 ) {
StartTokenParsing( pBuff );
nLen = 0;
while ( GetToken( true ) )
{
GSList *tmp;
bool found = false;
// each token should be a shader filename for ( i = 0; i < count; i++ )
sprintf( dirstring, "%s.shader", token ); {
// NOTE TTimo we use vfsGetFullPath solely to get the full path of the shader list we are gonna load
for ( tmp = l_shaderfiles; tmp != NULL; tmp = tmp->next ) // but we actually send the relative path to vfsLoadFile
// so let's hope there is no disparity between the two functions
if ( !vfsGetFullPath( filename, i, 0 ) ) {
Sys_FPrintf( SYS_ERR, "Couldn't find full path for '%s'\n", g_pGameDescription->mShaderlist.GetBuffer() );
return;
}
Sys_Printf( "Parsing shader files from %s\n", vfsGetFullPath( filename, i, 0 ) );
nLen = vfsLoadFile( filename, reinterpret_cast<void**>( &pBuff ), i );
if ( nLen > 0 ) {
StartTokenParsing( pBuff );
nLen = 0;
while ( GetToken( true ) )
{ {
if ( !strcmp( dirstring, (char*)tmp->data ) ) { GSList *tmp;
found = true; bool found = false;
Sys_FPrintf( SYS_WRN, "duplicate entry \"%s\" in shaderlist.txt\n", (char*)tmp->data );
break; // each token should be a shader filename
sprintf( dirstring, "%s.shader", token );
for ( tmp = l_shaderfiles; tmp != NULL; tmp = tmp->next )
{
if ( !strcmp( dirstring, (char*)tmp->data ) ) {
found = true;
Sys_FPrintf( SYS_WRN, "duplicate entry \"%s\" in shaderlist.txt\n", (char*)tmp->data );
break;
}
}
if ( !found ) {
l_shaderfiles = g_slist_append( l_shaderfiles, strdup( dirstring ) );
nLen++;
} }
} }
g_free( pBuff );
if ( !found ) {
l_shaderfiles = g_slist_append( l_shaderfiles, strdup( dirstring ) );
nLen++;
}
} }
g_free( pBuff );
} }
} }
} }
@ -1088,7 +1092,7 @@ void Texture_ShowStartupShaders(){
} }
if ( g_PrefsDlg.m_nShader == PrefsDlg::SHADER_ALL ) { if ( g_PrefsDlg.m_nShader == PrefsDlg::SHADER_ALL ) {
int count; int count, i;
char filename[1024]; char filename[1024];
char *pBuff; char *pBuff;
char dirstring[NAME_MAX]; char dirstring[NAME_MAX];
@ -1107,36 +1111,39 @@ void Texture_ShowStartupShaders(){
return; return;
} }
Sys_Printf( "Parsing shader files from %s\n", vfsGetFullPath( filename, 0, 0 ) ); for ( i = 0; i < count; i++ )
nLen = vfsLoadFile( filename, reinterpret_cast<void**>( &pBuff ), 0 ); {
if ( nLen > 0 ) { Sys_Printf( "Parsing shader files from %s\n", vfsGetFullPath( filename, i, 0 ) );
StartTokenParsing( pBuff ); nLen = vfsLoadFile( filename, reinterpret_cast<void**>( &pBuff ), i );
nLen = 0; if ( nLen > 0 ) {
while ( GetToken( true ) ) StartTokenParsing( pBuff );
{ nLen = 0;
GSList *tmp; while ( GetToken( true ) )
bool found = false;
// each token should be a shader filename
sprintf( dirstring, "%s.shader", token );
for ( tmp = shaderfiles; tmp != NULL; tmp = tmp->next )
{ {
if ( !strcmp( dirstring, (char*)tmp->data ) ) { GSList *tmp;
found = true; bool found = false;
Sys_FPrintf( SYS_WRN, "duplicate entry \"%s\" in shaderlist.txt\n", (char*)tmp->data );
break; // each token should be a shader filename
sprintf( dirstring, "%s.shader", token );
for ( tmp = shaderfiles; tmp != NULL; tmp = tmp->next )
{
if ( !strcmp( dirstring, (char*)tmp->data ) ) {
found = true;
Sys_FPrintf( SYS_WRN, "duplicate entry \"%s\" in shaderlist.txt\n", (char*)tmp->data );
break;
}
}
if ( !found ) {
shaderfiles = g_slist_append( l_shaderfiles, strdup( dirstring ) );
strcpy( texture_directory, dirstring );
Texture_ShowDirectory();
nLen++;
} }
} }
g_free( pBuff );
if ( !found ) {
shaderfiles = g_slist_append( l_shaderfiles, strdup( dirstring ) );
strcpy( texture_directory, dirstring );
Texture_ShowDirectory();
nLen++;
}
} }
g_free( pBuff );
} }
} }
} }