netradiant-custom/plugins/model/plugin.cpp
Garux df02774ff5 tweak StringOutputStream use
auto str = StringOutputStream()(bla) use form was not doing copy elision or move, but copy
2024-01-29 16:54:08 +06:00

176 lines
4.3 KiB
C++

/*
Copyright (C) 2001-2006, William Joseph.
All Rights Reserved.
This file is part of GtkRadiant.
GtkRadiant is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
GtkRadiant 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with GtkRadiant; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include "plugin.h"
#include <cstdio>
#include "picomodel.h"
typedef unsigned char byte;
#include <cstdlib>
#include <algorithm>
#include <list>
#include "iscenegraph.h"
#include "irender.h"
#include "iselection.h"
#include "iimage.h"
#include "imodel.h"
#include "igl.h"
#include "ifilesystem.h"
#include "iundo.h"
#include "ifiletypes.h"
#include "modulesystem/singletonmodule.h"
#include "stream/textstream.h"
#include "string/string.h"
#include "stream/stringstream.h"
#include "typesystem.h"
#include "model.h"
void PicoPrintFunc( int level, const char *str ){
if ( str == 0 ) {
return;
}
switch ( level )
{
case PICO_NORMAL:
globalOutputStream() << str << '\n';
break;
case PICO_VERBOSE:
//globalOutputStream() << "PICO_VERBOSE: " << str << '\n';
break;
case PICO_WARNING:
globalWarningStream() << "PICO_WARNING: " << str << '\n';
break;
case PICO_ERROR:
globalErrorStream() << "PICO_ERROR: " << str << '\n';
break;
case PICO_FATAL:
globalErrorStream() << "PICO_FATAL: " << str << '\n';
break;
}
}
void PicoLoadFileFunc( const char *name, byte **buffer, int *bufSize ){
*bufSize = vfsLoadFile( name, (void**) buffer );
}
void PicoFreeFileFunc( void* file ){
vfsFreeFile( file );
}
void pico_initialise(){
PicoInit();
PicoSetMallocFunc( malloc );
PicoSetFreeFunc( free );
PicoSetPrintFunc( PicoPrintFunc );
PicoSetLoadFileFunc( PicoLoadFileFunc );
PicoSetFreeFileFunc( PicoFreeFileFunc );
}
class PicoModelLoader : public ModelLoader
{
const picoModule_t* m_module;
public:
PicoModelLoader( const picoModule_t* module ) : m_module( module ){
}
scene::Node& loadModel( ArchiveFile& file ){
return loadPicoModel( m_module, file );
}
};
class ModelPicoDependencies :
public GlobalFileSystemModuleRef,
public GlobalOpenGLModuleRef,
public GlobalUndoModuleRef,
public GlobalSceneGraphModuleRef,
public GlobalShaderCacheModuleRef,
public GlobalSelectionModuleRef,
public GlobalFiletypesModuleRef
{
};
class ModelPicoAPI : public TypeSystemRef
{
PicoModelLoader m_modelLoader;
public:
typedef ModelLoader Type;
ModelPicoAPI( const char* extension, const picoModule_t* module ) :
m_modelLoader( module ){
const auto filter = StringStream<16>( "*.", extension );
GlobalFiletypesModule::getTable().addType( Type::Name, extension, filetype_t( module->displayName, filter ) );
}
ModelLoader* getTable(){
return &m_modelLoader;
}
};
class PicoModelAPIConstructor
{
CopiedString m_extension;
const picoModule_t* m_module;
public:
PicoModelAPIConstructor( const char* extension, const picoModule_t* module ) :
m_extension( extension ), m_module( module ){
}
const char* getName(){
return m_extension.c_str();
}
ModelPicoAPI* constructAPI( ModelPicoDependencies& dependencies ){
return new ModelPicoAPI( m_extension.c_str(), m_module );
}
void destroyAPI( ModelPicoAPI* api ){
delete api;
}
};
typedef SingletonModule<ModelPicoAPI, ModelPicoDependencies, PicoModelAPIConstructor> PicoModelModule;
typedef std::list<PicoModelModule> PicoModelModules;
PicoModelModules g_PicoModelModules;
extern "C" void RADIANT_DLLEXPORT Radiant_RegisterModules( ModuleServer& server ){
initialiseModule( server );
pico_initialise();
const picoModule_t** modules = PicoModuleList( 0 );
while ( *modules != 0 )
{
const picoModule_t* module = *modules++;
if ( module->canload && module->load ) {
for ( char*const* ext = module->defaultExts; *ext != 0; ++ext )
{
g_PicoModelModules.push_back( PicoModelModule( PicoModelAPIConstructor( *ext, module ) ) );
g_PicoModelModules.back().selfRegister();
}
}
}
}