bool CourseWriterCRS::Write( const Course &course, RageFileBasic &f, bool bSavingCache ) { ASSERT( !course.m_bIsAutogen ); f.PutLine( ssprintf("#COURSE:%s;", course.m_sMainTitle.c_str()) ); if( course.m_sMainTitleTranslit != "" ) f.PutLine( ssprintf("#COURSETRANSLIT:%s;", course.m_sMainTitleTranslit.c_str()) ); if( course.m_sScripter != "" ) f.PutLine( ssprintf("#SCRIPTER:%s;", course.m_sScripter.c_str()) ); if( course.m_bRepeat ) f.PutLine( "#REPEAT:YES;" ); if( course.m_iLives != -1 ) f.PutLine( ssprintf("#LIVES:%i;", course.m_iLives) ); if( !course.m_sBannerPath.empty() ) f.PutLine( ssprintf("#BANNER:%s;", course.m_sBannerPath.c_str()) ); if( !course.m_setStyles.empty() ) { vector<RString> asStyles; asStyles.insert( asStyles.begin(), course.m_setStyles.begin(), course.m_setStyles.end() ); f.PutLine( ssprintf("#STYLE:%s;", join( ",", asStyles ).c_str()) ); } FOREACH_ENUM( CourseDifficulty,cd ) { if( course.m_iCustomMeter[cd] == -1 ) continue; f.PutLine( ssprintf("#METER:%s:%i;", DifficultyToCRSString(cd).c_str(), course.m_iCustomMeter[cd]) ); } if( bSavingCache ) { f.PutLine( "// cache tags:" ); Course::RadarCache_t::const_iterator it; for( it = course.m_RadarCache.begin(); it != course.m_RadarCache.end(); ++it ) { // #RADAR:type:difficulty:value,value,value...; const Course::CacheEntry &entry = it->first; StepsType st = entry.first; CourseDifficulty cd = entry.second; vector<RString> asRadarValues; const RadarValues &rv = it->second; for( int r=0; r < NUM_RadarCategory; r++ ) asRadarValues.push_back( ssprintf("%.3f", rv[r]) ); RString sLine = ssprintf( "#RADAR:%i:%i:", st, cd ); sLine += join( ",", asRadarValues ) + ";"; f.PutLine( sLine ); } f.PutLine( "// end cache tags" ); } for( unsigned i=0; i<course.m_vEntries.size(); i++ ) { const CourseEntry& entry = course.m_vEntries[i]; for( unsigned j = 0; j < entry.attacks.size(); ++j ) { if( j == 0 ) f.PutLine( "#MODS:" ); const Attack &a = entry.attacks[j]; f.Write( ssprintf( " TIME=%.2f:LEN=%.2f:MODS=%s", a.fStartSecond, a.fSecsRemaining, a.sModifiers.c_str() ) ); if( j+1 < entry.attacks.size() ) f.Write( ":" ); else f.Write( ";" ); f.PutLine( "" ); } if( entry.fGainSeconds > 0 ) f.PutLine( ssprintf("#GAINSECONDS:%f;", entry.fGainSeconds) ); if( entry.songSort == SongSort_MostPlays && entry.iChooseIndex != -1 ) { f.Write( ssprintf( "#SONG:BEST%d", entry.iChooseIndex+1 ) ); } else if( entry.songSort == SongSort_FewestPlays && entry.iChooseIndex != -1 ) { f.Write( ssprintf( "#SONG:WORST%d", entry.iChooseIndex+1 ) ); } else if( entry.songID.ToSong() ) { Song *pSong = entry.songID.ToSong(); const RString &sSong = Basename( pSong->GetSongDir() ); f.Write( "#SONG:" ); if( !entry.songCriteria.m_sGroupName.empty() ) f.Write( entry.songCriteria.m_sGroupName + '/' ); f.Write( sSong ); } else if( !entry.songCriteria.m_sGroupName.empty() ) { f.Write( ssprintf( "#SONG:%s/*", entry.songCriteria.m_sGroupName.c_str() ) ); } else { f.Write( "#SONG:*" ); } f.Write( ":" ); if( entry.stepsCriteria.m_difficulty != Difficulty_Invalid ) f.Write( DifficultyToString(entry.stepsCriteria.m_difficulty) ); else if( entry.stepsCriteria.m_iLowMeter != -1 && entry.stepsCriteria.m_iHighMeter != -1 ) f.Write( ssprintf( "%d..%d", entry.stepsCriteria.m_iLowMeter, entry.stepsCriteria.m_iHighMeter ) ); f.Write( ":" ); RString sModifiers = entry.sModifiers; if( entry.bSecret ) { if( sModifiers != "" ) sModifiers += ","; sModifiers += entry.bSecret? "noshowcourse":"showcourse"; } if( entry.bNoDifficult ) { if( sModifiers != "" ) sModifiers += ","; sModifiers += "nodifficult"; } if( entry.iGainLives > -1 ) { if( !sModifiers.empty() ) sModifiers += ','; sModifiers += ssprintf( "award%d", entry.iGainLives ); } f.Write( sModifiers ); f.PutLine( ";" ); } return true; }
//======================================================== // Name : GetXML // Desc : convert plain xml text from parsed xml node // Param : // Return : converted plain string //-------------------------------------------------------- // Coder Date Desc // bro 2002-10-29 //======================================================== bool XNode::GetXML( RageFileBasic &f, DISP_OPT *opt ) const { // tab if( opt && opt->newline ) { if( opt && opt->newline ) if( f.Write("\r\n") == -1 ) return false; if( opt->write_tabs ) for( int i = 0 ; i < opt->tab_base ; i++) if( f.Write("\t") == -1 ) return false; } // <TAG if( f.Write("<" + m_sName) == -1 ) return false; // <TAG Attr1="Val1" if( !m_attrs.empty() ) if( f.Write(" ") == -1 ) return false; FOREACH_CONST_Attr( this, p ) if( !p->GetXML(f, opt) ) return false; if( m_childs.empty() && m_sValue.empty() ) { // <TAG Attr1="Val1"/> alone tag if( f.Write("/>") == -1 ) return false; } else { // <TAG Attr1="Val1"> and get child if( f.Write(">") == -1 ) return false; if( opt && opt->newline && !m_childs.empty() ) { opt->tab_base++; } FOREACH_CONST_Child( this, p ) if( !p->GetXML( f, opt ) ) return false; // Text Value if( m_sValue != ("") ) { if( opt && opt->newline && !m_childs.empty() ) { if( opt && opt->newline ) if( f.Write("\r\n") == -1 ) return false; if( opt->write_tabs ) for( int i = 0 ; i < opt->tab_base ; i++) if( f.Write("\t") == -1 ) return false; } if( f.Write((opt && opt->reference_value && opt->entitys ? opt->entitys->Entity2Ref(m_sValue) : m_sValue)) == -1 ) return false; } // </TAG> CloseTag if( opt && opt->newline && !m_childs.empty() ) { if( f.Write("\r\n") == -1 ) return false; if( opt->write_tabs ) for( int i = 0 ; i < opt->tab_base-1 ; i++) if( f.Write("\t") == -1 ) return false; } if( f.Write("</" + m_sName + ">") == -1 ) return false; if( opt && opt->newline ) { if( !m_childs.empty() ) opt->tab_base--; } } return true; }
void ThreadedFileWorker::HandleRequest( int iRequest ) { { m_DeletedFilesLock.Lock(); vector<RageFileBasic *> apDeletedFiles = m_apDeletedFiles; m_apDeletedFiles.clear(); m_DeletedFilesLock.Unlock(); for( unsigned i = 0; i < apDeletedFiles.size(); ++i ) delete apDeletedFiles[i]; } /* We have a request. */ switch( iRequest ) { case REQ_OPEN: ASSERT( m_pResultFile == NULL ); ASSERT( !m_sRequestPath.empty() ); m_iResultRequest = 0; m_pResultFile = m_pChildDriver->Open( m_sRequestPath, m_iRequestMode, m_iResultRequest ); break; case REQ_CLOSE: ASSERT( m_pRequestFile != NULL ); delete m_pRequestFile; /* Clear m_pRequestFile, so RequestTimedOut doesn't double-delete. */ m_pRequestFile = NULL; break; case REQ_GET_FILE_SIZE: ASSERT( m_pRequestFile != NULL ); m_iResultRequest = m_pRequestFile->GetFileSize(); break; case REQ_SEEK: ASSERT( m_pRequestFile != NULL ); m_iResultRequest = m_pRequestFile->Seek( m_iRequestPos ); m_sResultError = m_pRequestFile->GetError(); break; case REQ_READ: ASSERT( m_pRequestFile != NULL ); ASSERT( m_pResultBuffer != NULL ); m_iResultRequest = m_pRequestFile->Read( m_pResultBuffer, m_iRequestSize ); m_sResultError = m_pRequestFile->GetError(); break; case REQ_WRITE: ASSERT( m_pRequestFile != NULL ); ASSERT( m_pRequestBuffer != NULL ); m_iResultRequest = m_pRequestFile->Write( m_pRequestBuffer, m_iRequestSize ); m_sResultError = m_pRequestFile->GetError(); break; case REQ_FLUSH: ASSERT( m_pRequestFile != NULL ); m_iResultRequest = m_pRequestFile->Flush(); m_sResultError = m_pRequestFile->GetError(); break; case REQ_COPY: ASSERT( m_pRequestFile != NULL ); m_pResultFile = m_pRequestFile->Copy(); break; case REQ_POPULATE_FILE_SET: ASSERT( !m_sRequestPath.empty() ); m_ResultFileSet = FileSet(); m_pChildDriver->FDB->GetFileSetCopy( m_sRequestPath, m_ResultFileSet ); break; case REQ_FLUSH_DIR_CACHE: m_pChildDriver->FlushDirCache( m_sRequestPath ); break; case REQ_REMOVE: ASSERT( !m_sRequestPath.empty() ); m_iResultRequest = m_pChildDriver->Remove( m_sRequestPath )? 0:-1; break; case REQ_MOVE: ASSERT( !m_sRequestPath.empty() ); ASSERT( !m_sRequestPath2.empty() ); m_iResultRequest = m_pChildDriver->Move( m_sRequestPath, m_sRequestPath2 ) ? 0 : -1; break; default: FAIL_M( ssprintf("%i", iRequest) ); } }
//======================================================== // Name : GetXML // Desc : convert plain xml text from parsed xml attirbute // Param : // Return : converted plain string //-------------------------------------------------------- // Coder Date Desc // bro 2002-10-29 //======================================================== bool XAttr::GetXML( RageFileBasic &f, DISP_OPT *opt ) const { return f.Write(m_sName + "='" + (opt && opt->reference_value && opt->entitys ? opt->entitys->Entity2Ref(m_sValue) : m_sValue) + "' ") != -1; }
int URLRageFile_write( avcodec::URLContext *h, unsigned char *buf, int size ) { RageFileBasic *f = (RageFileBasic *) h->priv_data; return f->Write( buf, size ); }