93 lines
3.7 KiB
C++
93 lines
3.7 KiB
C++
|
|
/*****************************************************************************
|
||
|
|
*
|
||
|
|
* Copyright (c) 2000 - 2013, Lawrence Livermore National Security, LLC
|
||
|
|
* Produced at the Lawrence Livermore National Laboratory
|
||
|
|
* LLNL-CODE-442911
|
||
|
|
* All rights reserved.
|
||
|
|
*
|
||
|
|
* This file is part of VisIt. For details, see https://visit.llnl.gov/. The
|
||
|
|
* full copyright notice is contained in the file COPYRIGHT located at the root
|
||
|
|
* of the VisIt distribution or at http://www.llnl.gov/visit/copyright.html.
|
||
|
|
*
|
||
|
|
* Redistribution and use in source and binary forms, with or without
|
||
|
|
* modification, are permitted provided that the following conditions are met:
|
||
|
|
*
|
||
|
|
* - Redistributions of source code must retain the above copyright notice,
|
||
|
|
* this list of conditions and the disclaimer below.
|
||
|
|
* - Redistributions in binary form must reproduce the above copyright notice,
|
||
|
|
* this list of conditions and the disclaimer (as noted below) in the
|
||
|
|
* documentation and/or other materials provided with the distribution.
|
||
|
|
* - Neither the name of the LLNS/LLNL nor the names of its contributors may
|
||
|
|
* be used to endorse or promote products derived from this software without
|
||
|
|
* specific prior written permission.
|
||
|
|
*
|
||
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||
|
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL LAWRENCE LIVERMORE NATIONAL SECURITY,
|
||
|
|
* LLC, THE U.S. DEPARTMENT OF ENERGY OR CONTRIBUTORS BE LIABLE FOR ANY
|
||
|
|
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
||
|
|
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
||
|
|
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
|
||
|
|
* DAMAGE.
|
||
|
|
*
|
||
|
|
*****************************************************************************/
|
||
|
|
|
||
|
|
#include <LBMPluginInfo.h>
|
||
|
|
#include <avtLBMFileFormat.h>
|
||
|
|
#include <avtMTMDFileFormatInterface.h>
|
||
|
|
#include <avtGenericDatabase.h>
|
||
|
|
|
||
|
|
// ****************************************************************************
|
||
|
|
// Method: LBMCommonPluginInfo::GetDatabaseType
|
||
|
|
//
|
||
|
|
// Purpose:
|
||
|
|
// Returns the type of a LBM database.
|
||
|
|
//
|
||
|
|
// Programmer: generated by xml2info
|
||
|
|
// Creation: omitted
|
||
|
|
//
|
||
|
|
// ****************************************************************************
|
||
|
|
DatabaseType
|
||
|
|
LBMCommonPluginInfo::GetDatabaseType()
|
||
|
|
{
|
||
|
|
return DB_TYPE_MTMD;
|
||
|
|
}
|
||
|
|
|
||
|
|
// ****************************************************************************
|
||
|
|
// Method: LBMCommonPluginInfo::SetupDatabase
|
||
|
|
//
|
||
|
|
// Purpose:
|
||
|
|
// Sets up a LBM database.
|
||
|
|
//
|
||
|
|
// Arguments:
|
||
|
|
// list A list of file names.
|
||
|
|
// nList The number of timesteps in list.
|
||
|
|
// nBlocks The number of blocks in the list.
|
||
|
|
//
|
||
|
|
// Returns: A LBM database from list.
|
||
|
|
//
|
||
|
|
// Programmer: generated by xml2info
|
||
|
|
// Creation: omitted
|
||
|
|
//
|
||
|
|
// ****************************************************************************
|
||
|
|
avtDatabase *
|
||
|
|
LBMCommonPluginInfo::SetupDatabase(const char *const *list,
|
||
|
|
int nList, int nBlock)
|
||
|
|
{
|
||
|
|
// ignore any nBlocks past 1
|
||
|
|
int nTimestepGroups = nList / nBlock;
|
||
|
|
avtMTMDFileFormat **ffl = new avtMTMDFileFormat*[nTimestepGroups];
|
||
|
|
for (int i = 0 ; i < nTimestepGroups ; i++)
|
||
|
|
{
|
||
|
|
ffl[i] = new avtLBMFileFormat(list[i*nBlock]);
|
||
|
|
}
|
||
|
|
avtMTMDFileFormatInterface *inter
|
||
|
|
= new avtMTMDFileFormatInterface(ffl, nTimestepGroups);
|
||
|
|
return new avtGenericDatabase(inter);
|
||
|
|
}
|
||
|
|
|