SOP/SOP_BlindData.C

/*
 * Copyright (c) 2013
 *      Side Effects Software Inc.  All rights reserved.
 *
 * Redistribution and use of Houdini Development Kit samples in source and
 * binary forms, with or without modification, are permitted provided that the
 * following conditions are met:
 * 1. Redistributions of source code must retain the above copyright notice,
 *    this list of conditions and the following disclaimer.
 * 2. The name of Side Effects Software may not be used to endorse or
 *    promote products derived from this software without specific prior
 *    written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY SIDE EFFECTS SOFTWARE `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 SIDE EFFECTS SOFTWARE 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.
 *
 *----------------------------------------------------------------------------
 * The BlindData SOP.  This SOP simply saves some additional information to the
 * HIP file.  It's cook method is simply copies the source geometry.
 */

// For saving and loading we need to know about CPIO packets...
#include <UT/UT_CPIO.h>

#include <UT/UT_DSOVersion.h>
#include <GU/GU_Detail.h>
#include <PRM/PRM_Include.h>
#include <OP/OP_Operator.h>
#include <OP/OP_OperatorTable.h>
#include <OP/OP_SaveFlags.h>
#include "SOP_BlindData.h"

using namespace HDK_Sample;

void
newSopOperator(OP_OperatorTable *table)
{
     table->addOperator(new OP_Operator("hdk_blinddata",
                                        "BlindData",
                                         SOP_BlindData::myConstructor,
                                         SOP_BlindData::myTemplateList,
                                         1,
                                         1,
                                         0));
}

PRM_Template
SOP_BlindData::myTemplateList[] = {
    PRM_Template(),
};


OP_Node *
SOP_BlindData::myConstructor(OP_Network *net, const char *name, OP_Operator *op)
{
    return new SOP_BlindData(net, name, op);
}

SOP_BlindData::SOP_BlindData(OP_Network *net, const char *name, OP_Operator *op)
        : SOP_Node(net, name, op)
{
}

SOP_BlindData::~SOP_BlindData() {}

OP_ERROR
SOP_BlindData::cookMySop(OP_Context &context)
{
    // Before we do anything, we must lock our inputs.  Before returning,
    //  we have to make sure that the inputs get unlocked.
    if (lockInputs(context) >= UT_ERROR_ABORT)
        return error();

    duplicateSource(0, context);

    unlockInputs();
    return error();
}

const char *
SOP_BlindData::inputLabel(unsigned) const
{
    return "Source Geometry";
}

static const char       *theExtension = "mydata";

OP_ERROR
SOP_BlindData::save(ostream &os, const OP_SaveFlags &flags,
                    const char *path_prefix)
{
    UT_CPIO      packet;
    char         path[UT_SMALLBUF];

    clearErrors();

    // First, let the base class save its stuff.
    if (SOP_Node::save(os, flags, path_prefix) >= UT_ERROR_ABORT)
        return error();

    ostrstream ts(path, UT_SMALLBUF); ts << path_prefix << getName() << "."
                                  << theExtension << ends;
    packet.open(os, path);
    savePrivateData(os, flags.getBinary());
    packet.close(os);

    return error();
}

bool
SOP_BlindData::load(UT_IStream &is, const char *extension, const char *path)
{
    if (!strcmp(extension, theExtension))
    {
        // Here's my blind data!
        loadPrivateData(is);
        return (error() < UT_ERROR_ABORT);
    }
    return SOP_Node::load(is, extension, path);
}

int
SOP_BlindData::loadPrivateData(UT_IStream &is)
{
    UT_String   data;
    bool        result;

    result = data.load(is);
    return !result ? 0 : 1;
}

int
SOP_BlindData::savePrivateData(ostream &os, int binary)
{
    UT_String   data;

    data = "This is my private data";
    data.save(os, binary);
    return !os ? 0 : 1;
}

Generated on Mon Jan 28 00:45:45 2013 for HDK by  doxygen 1.5.9