diff options
Diffstat (limited to 'o3d')
21 files changed, 2526 insertions, 0 deletions
diff --git a/o3d/converter_edge/README.converter_edge b/o3d/converter_edge/README.converter_edge new file mode 100644 index 0000000..17edbf4 --- /dev/null +++ b/o3d/converter_edge/README.converter_edge @@ -0,0 +1,59 @@ +The converter is a command line utility that will convert from COLLADA +to the form that the sample JavaScript scene loader (in +samples/o3djs/serialization.js) can read. + +It is able to read COLLADA files as either DAE text files (and +associated asset files in subdirectories), or as part of a ZIP archive +(or KMZ file). It outputs a gzip-compressed tar archive (.tgz) which +contains a JSON file and any associated assets (textures, shaders, +etc.) from the source COLLADA model. By default we don't use the .tgz +extension, as it can cause problems with some webservers; we put .o3dtgz on +instead. + +In order to run the converter on Windows, you need the DirectX SDK installed. +Installing it requires administrator privileges. You can get it here: +http://msdn.microsoft.com/en-us/library/bb219737(VS.85).aspx. + +The command line arguments are as follows: + +Usage: o3dConverter.exe [--base-path=<path>] + [--up-axis=x,y,z] + [--no-condition] + [--pretty-print] + [--sharp-edge-threshold=<threshold>] + [--sharp-edge-color=r,g,b] + <infile.dae> [ <outfile> ] + +--base-path=<path>: This specifies the path elements to remove from + the beginning of the filenames placed into the + .o3dtgz file (to avoid including sensitive paths in + the .o3dtgz file). + +--up-axis=x,y,z: This specifies the up-axis for the resulting model, + if you wish it to be different from the axis in the + COLLADA file. + +--pretty-print: This simply formats the JSON file in the resulting + .o3dtgz file to be human readable, instead of compacted + into one line. + +--no-condition: This will prevent conditioning of the shaders from + COLLADA form to the form expected by O3D. [This is + useful only for pre-release data conditioned before + the converter existed.] + +--sharp-edge-threshold=<threshold>: Adds edges with normal angle + larger than <threshold>. + +--sharp-edge-color=r,g,b: Specify color of the additional edges, + (value 0 to 1).Default value is 1,0,0. + +<infile.dae|infile.zip|infile.kmz>: This is the input file in one of + ZIP, KMZ, or DAE formats. The + DAE format expects to find assets + relative to the .dae file. + +<outfile>: An optional argument giving the name of the + gzip-compressed tar archive output file. By default + this has the same basename as the input file, and has the extension + .o3dtgz. diff --git a/o3d/converter_edge/build.scons b/o3d/converter_edge/build.scons new file mode 100644 index 0000000..283502b --- /dev/null +++ b/o3d/converter_edge/build.scons @@ -0,0 +1,152 @@ +# Copyright 2009, Google Inc. +# All rights reserved. +# +# 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 following disclaimer. +# * Redistributions in binary form must reproduce the above +# copyright notice, this list of conditions and the following disclaimer +# in the documentation and/or other materials provided with the +# distribution. +# * Neither the name of Google Inc. 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 THE COPYRIGHT +# OWNER 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. + + +Import('env') + +env.Append( + LIBPATH = [ + '$NACL_LIB_DIR', + '$ANTLRLIBC_DIR/lib', + '$OBJ_ROOT/compiler/technique', + '$OBJ_ROOT/compiler/antlr', + '$CG_DIR/lib', + ], + LIBS = [ + 'o3dConvertEdge', + 'o3dCore', + 'o3dArchive', + 'o3dImport', + 'o3dImportConditioner', + 'o3dCorePlatform', + 'o3dSerializer', + 'o3dSerializationObjects', + 'o3dUtils', + 'o3d_base', + 'FColladaU', + 'technique', + 'antlr3c', + 'google_nacl_imc', + 'skia', + ] + env['ICU_LIBS'], +) + +# add renderer specific libraries and includes to the linker environment +env.Append(CPPPATH = env['RENDERER_INCLUDE_PATH'], + LIBPATH = env['RENDERER_LIB_PATH'], + LIBS = env['RENDERER_LIBS']) + +if env.Bit('windows'): + env.Append( + CCFLAGS=['/Wp64', '/D_CRT_SECURE_NO_WARNINGS'], + LINKFLAGS=['/SUBSYSTEM:CONSOLE'], + LIBS = [ + 'cg', + 'cgGL', + 'd3dx9', + 'ole32', + ], + ) + +if env.Bit('mac'): + env.Append( + LINKFLAGS = ['-F$CG_DIR'], + FRAMEWORKS = [ + 'ApplicationServices', + 'Cg', + 'Foundation', + 'OpenGL', + ], + ) + +inputs = [ + 'cross/converter.cc', + 'cross/renderer_stub.cc', + 'cross/buffer_stub.cc', + 'cross/texture_stub.cc', + ] + +# Create converter library. +lib = env.ComponentLibrary('o3dConvertEdge', inputs) + +# Create a target executable program called 'o3dConverterEdge' +if env.Bit('mac'): + exe = env.ComponentProgram('o3dConverterEdge', + ['mac/converter_main.mm', + 'cross/converter_main.cc', + ]) + # Fix executable to look for Cg.framework in the appropriate place. + exe_fix = env.Command('$ARTIFACTS_DIR/converter/fixed_exe.stamp', + [exe], [ + '/usr/bin/install_name_tool' + ' -change ' + '@executable_path/../Library/Frameworks/Cg.framework/Cg ' + '@executable_path/Frameworks/Cg.framework/Cg ' + "$SOURCE", + 'touch $TARGET', + ]) + # Copy the resulting executable to the Artifacts directory. + exe_install = env.Replicate('$ARTIFACTS_DIR/converter', [exe]) + env.Depends(exe_install, exe_fix) +else: + exe = env.ComponentProgram('o3dConverterEdge', ['cross/converter_main.cc']) + # Copy the resulting executable to the Artifacts directory. + exe_install = env.Replicate('$ARTIFACTS_DIR', [exe]) + +# Put the Cg DLL's, cgc and the d3dx9 DLL there as well. +if env.Bit('windows'): + env.Requires(exe_install, env.Replicate( + '$ARTIFACTS_DIR', [ + '$CG_DIR/bin/cgc.exe', + '$CG_DIR/bin/cg.dll', + '$CG_DIR/bin/cgGL.dll', + ])) + +if env.Bit('mac'): + env.Requires( + exe_install, + env.Command(env.Dir('$ARTIFACTS_DIR/converter/Frameworks'), + env.Dir("$CG_DIR/Cg.framework"), + [ # Copy in a Cg framework for the converter to use. + 'ditto --arch i386 "$CG_DIR/Cg.framework" ' + '"$ARTIFACTS_DIR/converter/Frameworks/Cg.framework"', + ])) + env.Requires(exe_install, env.Replicate( + '$ARTIFACTS_DIR/converter', [ + '$CG_DIR/bin/cgc', + ])) + +if env.Bit('linux'): + env.Requires(exe_install, env.Replicate( + '$ARTIFACTS_DIR', [ + '$CG_DIR/bin/cgc', + '$CG_DIR/lib/libCg.so', + '$CG_DIR/lib/libCgGL.so', + '$GLEW_DIR/lib/libGLEW.so.1.5', + ])) diff --git a/o3d/converter_edge/cross/buffer_stub.cc b/o3d/converter_edge/cross/buffer_stub.cc new file mode 100644 index 0000000..1549939 --- /dev/null +++ b/o3d/converter_edge/cross/buffer_stub.cc @@ -0,0 +1,87 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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. + */ + + +// This file contains the definition of the VertexBufferStub and +// IndexBufferStub classes. + +#include "converter_edge/cross/buffer_stub.h" + +namespace o3d { + +bool VertexBufferStub::ConcreteAllocate(size_t size_in_bytes) { + buffer_.reset(new int8[size_in_bytes]); + return true; +} + +void VertexBufferStub::ConcreteFree() { + buffer_.reset(); +} + +bool VertexBufferStub::ConcreteLock(AccessMode access_mode, + void** buffer_data) { + *buffer_data = buffer_.get(); + DCHECK(locked_ == false); + locked_ = true; + return (buffer_.get() != NULL); +} + +bool VertexBufferStub::ConcreteUnlock() { + bool status = locked_; + DCHECK(locked_ == true); + locked_ = false; + return status; +} + +bool IndexBufferStub::ConcreteAllocate(size_t size_in_bytes) { + buffer_.reset(new int8[size_in_bytes]); + return true; +} + +void IndexBufferStub::ConcreteFree() { + buffer_.reset(); +} + +bool IndexBufferStub::ConcreteLock(AccessMode access_mode, void** buffer_data) { + *buffer_data = buffer_.get(); + DCHECK(locked_ == false); + locked_ = true; + return (buffer_.get() != NULL); +} + +bool IndexBufferStub::ConcreteUnlock() { + bool status = locked_; + DCHECK(locked_ == true); + locked_ = false; + return status; +} + +} // end namespace o3d diff --git a/o3d/converter_edge/cross/buffer_stub.h b/o3d/converter_edge/cross/buffer_stub.h new file mode 100644 index 0000000..d1da197 --- /dev/null +++ b/o3d/converter_edge/cross/buffer_stub.h @@ -0,0 +1,112 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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. + */ + + +// This file contains the declaration of the platform specific +// VertexBufferStub and IndexBufferStub objects used by O3D + +#ifndef O3D_CONVERTER_EDGE_CROSS_BUFFER_STUB_H_ +#define O3D_CONVERTER_EDGE_CROSS_BUFFER_STUB_H_ + +#include "base/basictypes.h" +#include "base/scoped_ptr.h" +#include "core/cross/buffer.h" + +namespace o3d { + +// VertexBufferStub is a wrapper around an Stub Vertex Buffer Object (VBO). +// The buffer starts out empty. Calling Allocate() will reserve video memory +// for the buffer. Buffer contents are are updated by calling Lock() to get a +// pointer to the memory allocated for the buffer, updating that data in place +// and calling Unlock() to notify Stub that the edits are done. + +class VertexBufferStub : public VertexBuffer { + public: + explicit VertexBufferStub(ServiceLocator* service_locator) + : VertexBuffer(service_locator), locked_(false) {} + ~VertexBufferStub() {} + + protected: + // Creates a Stub vertex buffer object of the specified size. + virtual bool ConcreteAllocate(size_t size_in_bytes); + + // Frees the buffer. + virtual void ConcreteFree(); + + // Returns a pointer to the current contents of the buffer. A matching + // call to Unlock is necessary to update the contents of the buffer. + virtual bool ConcreteLock(AccessMode access_mode, void** buffer_data); + + // Notifies Stub that the buffer data has been updated. Unlock is only + // valid if it follows a Lock operation. + virtual bool ConcreteUnlock(); + private: + scoped_array<int8> buffer_; + bool locked_; + + DISALLOW_COPY_AND_ASSIGN(VertexBufferStub); +}; + +// IndexBufferStub is a wrapper around a Stub Index Buffer Object. +// The buffer starts out empty. A call to Allocate() will create a stub +// index buffer of the requested size. Updates the to the contents of the +// buffer are done via the Lock/Unlock calls. +class IndexBufferStub : public IndexBuffer { + public: + explicit IndexBufferStub(ServiceLocator* service_locator) + : IndexBuffer(service_locator), locked_(false) {} + ~IndexBufferStub() {} + + protected: + // Creates a OpenGL index buffer of the specified size. + virtual bool ConcreteAllocate(size_t size_in_bytes); + + // Frees the buffer. + virtual void ConcreteFree(); + + // Returns a pointer to the current contents of the buffer. After calling + // Lock, the contents of the buffer can be updated in place. + virtual bool ConcreteLock(AccessMode access_mode, void** buffer_data); + + // Notifies OpenGL that the buffer data has been updated. Unlock is only + // valid if it follows a Lock operation. + virtual bool ConcreteUnlock(); + private: + scoped_array<int8> buffer_; + bool locked_; + + DISALLOW_COPY_AND_ASSIGN(IndexBufferStub); +}; + +} // namespace o3d + + +#endif // O3D_CONVERTER_EDGE_CROSS_BUFFER_STUB_H_ diff --git a/o3d/converter_edge/cross/converter.cc b/o3d/converter_edge/cross/converter.cc new file mode 100644 index 0000000..8936213 --- /dev/null +++ b/o3d/converter_edge/cross/converter.cc @@ -0,0 +1,639 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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. + */ + + +// This file contains the logic for converting the scene graph to a +// JSON-encoded file that is stored in a zip archive. +#include "converter_edge/cross/converter.h" + +#include <cmath> +#include <map> +#include <utility> + +#include "base/file_path.h" +#include "base/file_util.h" +#include "base/scoped_ptr.h" +#include "core/cross/class_manager.h" +#include "core/cross/client.h" +#include "core/cross/client_info.h" +#include "core/cross/effect.h" +#include "core/cross/error.h" +#include "core/cross/features.h" +#include "core/cross/object_manager.h" +#include "core/cross/pack.h" +#include "core/cross/renderer.h" +#include "core/cross/service_locator.h" +#include "core/cross/transform.h" +#include "core/cross/tree_traversal.h" +#include "core/cross/types.h" +#include "core/cross/primitive.cc" +#include "import/cross/collada.h" +#include "import/cross/collada_conditioner.h" +#include "import/cross/file_output_stream_processor.h" +#include "import/cross/targz_generator.h" +#include "import/cross/archive_request.h" +#include "serializer/cross/serializer.h" +#include "utils/cross/file_path_utils.h" +#include "utils/cross/json_writer.h" +#include "utils/cross/string_writer.h" +#include "utils/cross/temporary_file.h" + +namespace o3d { + +namespace { +static const float kPi = 3.14159265358979f; +static const float kEpsilon = 0.0001f; + +void AddBinaryElements(const Collada& collada, + TarGzGenerator* archive_generator) { + const ColladaDataMap& data_map(collada.original_data_map()); + std::vector<FilePath> paths = data_map.GetOriginalDataFilenames(); + for (std::vector<FilePath>::const_iterator iter = paths.begin(); + iter != paths.end(); + ++iter) { + const std::string& data = data_map.GetOriginalData(*iter); + + archive_generator->AddFile(FilePathToUTF8(*iter), data.size()); + archive_generator->AddFileBytes( + reinterpret_cast<const uint8*>(data.c_str()), + data.length()); + } +} +} // end anonymous namespace + +namespace converter { +// Constructor, make sure points order is unique. +// If x-coordinates are the same, compare y-coordinate. +// If y values are also the same, compare z. +Edge::Edge(Point3 p1, Point3 p2) { + bool isRightOrder = false; + if (fabs(p1.getX() - p2.getX()) < kEpsilon) { + if (fabs(p1.getY() - p2.getY()) < kEpsilon) { + if (p1.getZ() < p2.getZ()) + isRightOrder = true; + } else { + if (p1.getY() < p2.getY()) + isRightOrder = true; + } + } else { + if (p1.getX() < p2.getX()) + isRightOrder = true; + } + if (isRightOrder) { + pts.push_back(p1); + pts.push_back(p2); + } else { + pts.push_back(p2); + pts.push_back(p1); + } +} + +// less than operator overload, necessary function for edge-triangle map. +bool operator<(const Edge& left, const Edge& right) { + // compare two edges by their actually coordinates, not indices. + // Beceause two different indices may point to one actually coordinates. + if (dist(left.pts[0], right.pts[0]) < kEpsilon) { + if (fabs(left.pts[1].getX() - right.pts[1].getX()) < kEpsilon) { + if (fabs(left.pts[1].getY() - right.pts[1].getY()) < kEpsilon) { + return left.pts[1].getZ() < right.pts[1].getZ(); + } + return left.pts[1].getY() < right.pts[1].getY(); + } + return left.pts[1].getX() < right.pts[1].getX(); + } else { + if (fabs(left.pts[0].getX() - right.pts[0].getX()) < kEpsilon) { + if (fabs(left.pts[0].getY() - right.pts[0].getY()) < kEpsilon) { + return left.pts[0].getZ() < right.pts[0].getZ(); + } + return left.pts[0].getY() < right.pts[0].getY(); + } + return left.pts[0].getX() < right.pts[0].getX(); + } +} + +void CheckSharpEdge(const Edge& shared_edge, + const std::vector<Triangle>& triangle_list, + std::vector<Edge>* sharp_edges, float threshold) { + for (size_t i = 0; i < triangle_list.size(); i++) + for (size_t j = i + 1; j < triangle_list.size(); j++) { + Triangle t1 = triangle_list[i]; + Triangle t2 = triangle_list[j]; + int same_vertices_count = 0; + // Same triangle might be stored twice to represent inner and outer faces. + // Check the order of indices of vertices to not mix inner and outer faces + // togeter. + std::vector<int> same_vertices_pos; + for (int k = 0; k < 3; k++) + for (int l = 0; l < 3; l++) { + if (dist(t1.pts[k], t2.pts[l]) < kEpsilon) { + same_vertices_count++; + same_vertices_pos.push_back(k); + same_vertices_pos.push_back(l); + } + } + if (same_vertices_count != 2) + continue; + // check the order of positions to make sure triangles are on + // the same face. + int i1 = same_vertices_pos[2] - same_vertices_pos[0]; + int i2 = same_vertices_pos[3] - same_vertices_pos[1]; + // if triangles are on different faces. + if (!(i1 * i2 == -1 || i1 * i2 == 2 || i1 * i2 == -4)) + continue; + + Vector3 v12 = t1.pts[1] - t1.pts[0]; + Vector3 v13 = t1.pts[2] - t1.pts[0]; + Vector3 n1 = cross(v12, v13); + Vector3 v22 = t2.pts[1] - t2.pts[0]; + Vector3 v23 = t2.pts[2] - t2.pts[0]; + Vector3 n2 = cross(v22, v23); + float iAngle = acos(dot(n1, n2) / (length(n1) * length(n2))); + iAngle = iAngle * 180 / kPi; + if (iAngle >= threshold) { + sharp_edges->push_back(shared_edge); + return; + } + } +} + +// create a single color material and effect and attach it to +// sharp edge primitive. +Material* GetSingleColorMaterial(Pack::Ref pack, const Vector3& edge_color) { + Material* singleColorMaterial = pack->Create<Material>(); + singleColorMaterial->set_name("singleColorMaterial"); + ParamString* lighting_param = singleColorMaterial->CreateParam<ParamString>( + Collada::kLightingTypeParamName); + lighting_param->set_value(Collada::kLightingTypeConstant); + ParamFloat4* emissive_param = singleColorMaterial->CreateParam<ParamFloat4>( + Collada::kMaterialParamNameEmissive); + emissive_param->set_value(Float4(edge_color.getX(), edge_color.getY(), + edge_color.getZ(), 1)); + + return singleColorMaterial; +} + +// insert edge-triangle pair to edge triangle map. +void InsertEdgeTrianglePair(const Edge& edge, const Triangle& triangle, + std::map<Edge, std::vector<Triangle>>* et_map) { + std::map<Edge, std::vector<Triangle>>::iterator iter1 = + et_map->find(edge); + if (iter1 == et_map->end()) { + std::vector<Triangle> same_edge_triangle_list; + same_edge_triangle_list.push_back(triangle); + et_map->insert(make_pair(edge, same_edge_triangle_list)); + } else { + iter1->second.push_back(triangle); + } +} + +// Loads the Collada input file and writes it to the zipped JSON output file. +bool Convert(const FilePath& in_filename, + const FilePath& out_filename, + const Options& options, + String *error_messages) { + // Create a service locator and renderer. + ServiceLocator service_locator; + EvaluationCounter evaluation_counter(&service_locator); + ClassManager class_manager(&service_locator); + ClientInfoManager client_info_manager(&service_locator); + ObjectManager object_manager(&service_locator); + Profiler profiler(&service_locator); + ErrorStatus error_status(&service_locator); + Features features(&service_locator); + + Collada::Init(&service_locator); + features.Init("MaxCapabilities"); + + // Collect error messages. + ErrorCollector error_collector(&service_locator); + + scoped_ptr<Renderer> renderer( + Renderer::CreateDefaultRenderer(&service_locator)); + renderer->InitCommon(); + + Pack::Ref pack(object_manager.CreatePack()); + Transform* root = pack->Create<Transform>(); + root->set_name(String(Serializer::ROOT_PREFIX) + String("root")); + + // Setup a ParamFloat to be the source to all animations in this file. + ParamObject* param_object = pack->Create<ParamObject>(); + // This is some arbitrary name + param_object->set_name(O3D_STRING_CONSTANT("animSourceOwner")); + ParamFloat* param_float = param_object->CreateParam<ParamFloat>("animSource"); + + Collada::Options collada_options; + collada_options.condition_document = options.condition; + collada_options.keep_original_data = true; + collada_options.base_path = options.base_path; + collada_options.file_paths = options.file_paths; + collada_options.up_axis = options.up_axis; + Collada collada(pack.Get(), collada_options); + bool result = collada.ImportFile(in_filename, root, param_float); + if (!result || !error_collector.errors().empty()) { + if (error_messages) { + *error_messages += error_collector.errors(); + } + return false; + } + + // Remove the animation param_object (and indirectly the param_float) + // if there is no animation. + if (param_float->output_connections().empty()) { + pack->RemoveObject(param_object); + } + + // Add edges whose normals angle is larger than predefined threshold. + if (options.enable_add_sharp_edge) { + std::vector<Shape*> shapes = pack->GetByClass<Shape>(); + for (unsigned s = 0; s < shapes.size(); ++s) { + Shape* shape = shapes[s]; + const ElementRefArray& elements = shape->GetElementRefs(); + for (unsigned e = 0; e < elements.size(); ++e) { + if (elements[e]->IsA(Primitive::GetApparentClass())) { + Primitive* primitive = down_cast<Primitive*>(elements[e].Get()); + // Get vertices and indices of this primitive. + if (primitive->primitive_type() != Primitive::TRIANGLELIST) + continue; + FieldReadAccessor<Point3> vertices; + FieldReadAccessorUnsignedInt indices; + if (!GetVerticesAccessor(primitive, 0, &vertices)) + return false; + + unsigned int index_count; + if (primitive->indexed()) { + if (!Primitive::GetIndexCount(Primitive::TRIANGLELIST, + primitive->number_primitives(), + &index_count)) + continue; + + if (!GetIndicesAccessor(primitive, &indices, + primitive->start_index(), index_count)) + continue; + index_count = std::min(index_count, indices.max_index()); + } else { + index_count = primitive->number_vertices(); + indices.InitializeJustCount(primitive->start_index(), index_count); + } + // If there are no vertices then exit early. + if (vertices.max_index() == 0) { + continue; + } + // generate triangle list. + int prim = 0; + std::vector<Triangle> triangle_list; + std::vector<Point3> point_list; + for (size_t i = 0; i < 48; i++) { + point_list.push_back(vertices[i]); + } + for (unsigned int prim_base = 0; prim_base + 2 < index_count; + prim_base += 3) { + Triangle triangle(vertices[indices[prim_base + 0]], + vertices[indices[prim_base + 1]], + vertices[indices[prim_base + 2]]); + triangle_list.push_back(triangle); + } + // build edge and triangle map. + std::map<Edge, std::vector<Triangle>> edge_triangle_map; + for (size_t i = 0; i < triangle_list.size(); i++) { + Triangle triangle = triangle_list[i]; + Edge e1(triangle.pts[0], triangle.pts[1]); + Edge e2(triangle.pts[1], triangle.pts[2]); + Edge e3(triangle.pts[0], triangle.pts[2]); + InsertEdgeTrianglePair(e1, triangle, &edge_triangle_map); + InsertEdgeTrianglePair(e2, triangle, &edge_triangle_map); + InsertEdgeTrianglePair(e3, triangle, &edge_triangle_map); + } + // go through the edge-triangle map. + std::map<Edge, std::vector<Triangle>>::iterator iter; + std::vector<Edge> sharp_edges; + for (iter = edge_triangle_map.begin(); + iter != edge_triangle_map.end(); iter++) { + if (iter->second.size() < 2) + continue; + CheckSharpEdge(iter->first, iter->second, &sharp_edges, + options.sharp_edge_threshold); + } + + if (sharp_edges.size() > 0) { + Primitive* sharp_edge_primitive = pack->Create<Primitive>(); + sharp_edge_primitive->SetOwner(shape); + sharp_edge_primitive->set_name("sharp_edge_primitive"); + StreamBank* stream_bank = pack->Create<StreamBank>(); + + VertexBuffer* vertex_buffer = pack->Create<VertexBuffer>(); + vertex_buffer->set_name("sharp_edges_vertex_buffer"); + size_t num_vertices = sharp_edges.size() * 2; + + Field* field = vertex_buffer->CreateField( + FloatField::GetApparentClass(), 3); + if (!vertex_buffer->AllocateElements(static_cast<unsigned int>( + sharp_edges.size() * 2))) { + O3D_ERROR(&service_locator) << "Failed to allocate vertex buffer"; + return NULL; + } + scoped_array<float> values(new float[num_vertices * 3]); + for (unsigned int i = 0; i < num_vertices; i++) { + Point3 currentPoint; + if (i % 2 == 0) + currentPoint = sharp_edges[i / 2].pts[0]; + else + currentPoint = sharp_edges[i / 2].pts[1]; + values[i * 3 + 0] = currentPoint.getX(); + values[i * 3 + 1] = currentPoint.getY(); + values[i * 3 + 2] = currentPoint.getZ(); + } + field->SetFromFloats(&values[0], 3, 0, + static_cast<unsigned int>(num_vertices)); + stream_bank->SetVertexStream(Stream::POSITION, 0, field, 0); + stream_bank->set_name("sharp_edges_stream_bank"); + + Material* material = + GetSingleColorMaterial(pack, options.sharp_edge_color); + sharp_edge_primitive->set_material(material); + sharp_edge_primitive->set_primitive_type(Primitive::LINELIST); + sharp_edge_primitive->set_number_vertices(static_cast<int>( + sharp_edges.size() * 2)); + sharp_edge_primitive->set_number_primitives(static_cast<int>( + sharp_edges.size())); + sharp_edge_primitive->set_stream_bank(stream_bank); + } + } + } + } + } + // Mark all Samplers to use tri-linear filtering + if (!options.keep_filters) { + std::vector<Sampler*> samplers = pack->GetByClass<Sampler>(); + for (unsigned ii = 0; ii < samplers.size(); ++ii) { + Sampler* sampler = samplers[ii]; + sampler->set_mag_filter(Sampler::LINEAR); + sampler->set_min_filter(Sampler::LINEAR); + sampler->set_mip_filter(Sampler::LINEAR); + } + } + + // Mark all Materials that are on Primitives that have no normals as constant. + if (!options.keep_materials) { + std::vector<Primitive*> primitives = pack->GetByClass<Primitive>(); + for (unsigned ii = 0; ii < primitives.size(); ++ii) { + Primitive* primitive = primitives[ii]; + StreamBank* stream_bank = primitive->stream_bank(); + if (stream_bank && !stream_bank->GetVertexStream(Stream::NORMAL, 0)) { + Material* material = primitive->material(); + if (material) { + ParamString* lighting_param = material->GetParam<ParamString>( + Collada::kLightingTypeParamName); + if (lighting_param) { + // If the lighting type is lambert, blinn, or phong + // copy the diffuse color to the emissive since that's most likely + // what the user wants to see. + if (lighting_param->value().compare( + Collada::kLightingTypeLambert) == 0 || + lighting_param->value().compare( + Collada::kLightingTypeBlinn) == 0 || + lighting_param->value().compare( + Collada::kLightingTypePhong) == 0) { + // There's 4 cases: (to bad they are not the same names) + // 1) Diffuse -> Emissive + // 2) DiffuseSampler -> Emissive + // 3) Diffuse -> EmissiveSampler + // 4) DiffuseSampler -> EmissiveSampler + ParamFloat4* diffuse_param = material->GetParam<ParamFloat4>( + Collada::kMaterialParamNameDiffuse); + ParamFloat4* emissive_param = material->GetParam<ParamFloat4>( + Collada::kMaterialParamNameEmissive); + ParamSampler* diffuse_sampler_param = + material->GetParam<ParamSampler>( + Collada::kMaterialParamNameDiffuseSampler); + ParamSampler* emissive_sampler_param = + material->GetParam<ParamSampler>( + Collada::kMaterialParamNameEmissive); + Param* source_param = diffuse_param ? + static_cast<Param*>(diffuse_param) : + static_cast<Param*>(diffuse_sampler_param); + Param* destination_param = emissive_param ? + static_cast<Param*>(emissive_param) : + static_cast<Param*>(emissive_sampler_param); + if (!source_param->IsA(destination_param->GetClass())) { + // The params do not match type so we need to make the emissive + // Param the same as the diffuse Param. + material->RemoveParam(destination_param); + destination_param = material->CreateParamByClass( + diffuse_param ? Collada::kMaterialParamNameEmissive : + Collada::kMaterialParamNameEmissiveSampler, + source_param->GetClass()); + DCHECK(destination_param); + } + destination_param->CopyDataFromParam(source_param); + } + lighting_param->set_value(Collada::kLightingTypeConstant); + } + } + } + } + } + + // Attempt to open the output file. + FILE* out_file = file_util::OpenFile(out_filename, "wb"); + if (out_file == NULL) { + O3D_ERROR(&service_locator) << "Could not open output file \"" + << FilePathToUTF8(out_filename).c_str() + << "\""; + if (error_messages) { + *error_messages += error_collector.errors(); + } + return false; + } + + // Create an archive file and serialize the JSON scene graph and assets to it. + FileOutputStreamProcessor stream_processor(out_file); + TarGzGenerator archive_generator(&stream_processor); + + archive_generator.AddFile(ArchiveRequest::O3D_MARKER, + ArchiveRequest::O3D_MARKER_CONTENT_LENGTH); + archive_generator.AddFileBytes( + reinterpret_cast<const uint8*>(ArchiveRequest::O3D_MARKER_CONTENT), + ArchiveRequest::O3D_MARKER_CONTENT_LENGTH); + + // Serialize the created O3D scene graph to JSON. + StringWriter out_writer(StringWriter::LF); + JsonWriter json_writer(&out_writer, 2); + if (!options.pretty_print) { + json_writer.BeginCompacting(); + } + Serializer serializer(&service_locator, &json_writer, &archive_generator); + serializer.SerializePack(pack.Get()); + json_writer.Close(); + out_writer.Close(); + if (!options.pretty_print) { + json_writer.EndCompacting(); + } + + String json = out_writer.ToString(); + + archive_generator.AddFile("scene.json", json.length()); + archive_generator.AddFileBytes(reinterpret_cast<const uint8*>(json.c_str()), + json.length()); + + // Now add original data (e.g. compressed textures) collected during + // the loading process. + AddBinaryElements(collada, &archive_generator); + + archive_generator.Close(true); + + pack->Destroy(); + if (error_messages) { + *error_messages = error_collector.errors(); + } + return true; +} + +// Loads the input shader file and validates it. +bool Verify(const FilePath& in_filename, + const FilePath& out_filename, + const Options& options, + String* error_messages) { + FilePath source_filename(in_filename); + // Create a service locator and renderer. + ServiceLocator service_locator; + EvaluationCounter evaluation_counter(&service_locator); + ClassManager class_manager(&service_locator); + ObjectManager object_manager(&service_locator); + Profiler profiler(&service_locator); + ErrorStatus error_status(&service_locator); + + // Collect error messages. + ErrorCollector error_collector(&service_locator); + + scoped_ptr<Renderer> renderer( + Renderer::CreateDefaultRenderer(&service_locator)); + renderer->InitCommon(); + + Pack::Ref pack(object_manager.CreatePack()); + Transform* root = pack->Create<Transform>(); + root->set_name(O3D_STRING_CONSTANT("root")); + + Collada::Options collada_options; + collada_options.condition_document = options.condition; + collada_options.keep_original_data = false; + Collada collada(pack.Get(), collada_options); + + ColladaConditioner conditioner(&service_locator); + String vertex_shader_entry_point; + String fragment_shader_entry_point; + TemporaryFile temp_file; + if (options.condition) { + if (!TemporaryFile::Create(&temp_file)) { + O3D_ERROR(&service_locator) << "Could not create temporary file"; + if (error_messages) { + *error_messages = error_collector.errors(); + } + return false; + } + SamplerStateList state_list; + if (!conditioner.RewriteShaderFile(NULL, + in_filename, + temp_file.path(), + &state_list, + &vertex_shader_entry_point, + &fragment_shader_entry_point)) { + O3D_ERROR(&service_locator) << "Could not rewrite shader file"; + if (error_messages) { + *error_messages = error_collector.errors(); + } + return false; + } + source_filename = temp_file.path(); + } else { + source_filename = in_filename; + } + + std::string shader_source_in; + // Load file into memory + if (!file_util::ReadFileToString(source_filename, &shader_source_in)) { + O3D_ERROR(&service_locator) << "Could not read shader file " + << FilePathToUTF8(source_filename).c_str(); + if (error_messages) { + *error_messages = error_collector.errors(); + } + return false; + } + + Effect::MatrixLoadOrder matrix_load_order; + scoped_ptr<Effect> effect(pack->Create<Effect>()); + if (!effect->ValidateFX(shader_source_in, + &vertex_shader_entry_point, + &fragment_shader_entry_point, + &matrix_load_order)) { + O3D_ERROR(&service_locator) << "Could not validate shader file"; + if (error_messages) { + *error_messages = error_collector.errors(); + } + return false; + } + + if (!conditioner.CompileHLSL(shader_source_in, + vertex_shader_entry_point, + fragment_shader_entry_point)) { + O3D_ERROR(&service_locator) << "Could not HLSL compile shader file"; + if (error_messages) { + *error_messages = error_collector.errors(); + } + return false; + } + + if (!conditioner.CompileCg(in_filename, + shader_source_in, + vertex_shader_entry_point, + fragment_shader_entry_point)) { + O3D_ERROR(&service_locator) << "Could not Cg compile shader file"; + if (error_messages) { + *error_messages = error_collector.errors(); + } + return false; + } + + // If we've validated the file, then we write out the conditioned + // shader to the given output file, if there is one. + if (options.condition && !out_filename.empty()) { + if (file_util::WriteFile(out_filename, shader_source_in.c_str(), + static_cast<int>(shader_source_in.size())) == -1) { + O3D_ERROR(&service_locator) << "Warning: Could not write to output file '" + << FilePathToUTF8(in_filename).c_str() << "'"; + } + } + if (error_messages) { + *error_messages = error_collector.errors(); + } + return true; +} +} // end namespace converter +} // end namespace o3d diff --git a/o3d/converter_edge/cross/converter.h b/o3d/converter_edge/cross/converter.h new file mode 100644 index 0000000..af360e5 --- /dev/null +++ b/o3d/converter_edge/cross/converter.h @@ -0,0 +1,139 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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. + */ + + +// This file contains the declarations for the functions in the +// O3D converter namespace. These functions do most of the actual +// work of conditioning and packagaging a JSON file for use in +// O3D. + +#ifndef O3D_CONVERTER_EDGE_CROSS_CONVERTER_H_ +#define O3D_CONVERTER_EDGE_CROSS_CONVERTER_H_ + +#include <vector> +#include <cmath> +#include "base/file_path.h" +#include "core/cross/types.h" +#include "utils/cross/file_path_utils.h" + +namespace o3d { +namespace converter { + +// Options struct for passing to the converter. +struct Options { + Options() + : base_path(FilePath::kCurrentDirectory), + condition(true), + up_axis(0, 0, 0), + pretty_print(false), + keep_filters(false), + keep_materials(false), + enable_add_sharp_edge(false), + sharp_edge_threshold(0), + sharp_edge_color(1, 0, 0) { + } + + // A list of paths to search for assets.. + std::vector<FilePath> file_paths; + + // The path to the "base" of the model path, from which all paths + // are made relative. Defaults to the current directory. + FilePath base_path; + + // Indicates if the converter should condition the input shaders or + // not. + bool condition; + + // The up axis of the output. The input will be converted to a new coordinate + // system if it indicates a different up axis. Zero means no conversion. + Vector3 up_axis; + + // This indicates whether or not the serialized JSON code should be + // pretty-printed (formatted with spaces and newlines) or just + // emitted as one huge one-line string. Defaults to false. + bool pretty_print; + + // Tells the converter not to set all filters to tri-linear. + bool keep_filters; + + // Tells the converter not to change materials to constant if they are used by + // a mesh that has no normals. + bool keep_materials; + + // Add edges with normal angle larger than soften_edge_threshold. + bool enable_add_sharp_edge; + + // The threshold of normal angle of edge, if angle of certain edge is larger + // than this threshold, it will be added into the output file. + float sharp_edge_threshold; + + // The color of edges been added. + Vector3 sharp_edge_color; +}; + +// Edge class is used in sharp edge detect process. +// It stores two points in a specific order, +// and it serves as key class in edge-triangle map. +struct Edge { + Edge(Point3 p1, Point3 p2); + std::vector<Point3> pts; +}; + +// Triangle class is used in detect sharp edge process. +struct Triangle { + Triangle(Point3 p1, Point3 p2, Point3 p3) { + pts.push_back(p1); + pts.push_back(p2); + pts.push_back(p3); + } + std::vector<Point3> pts; +}; + +// Converts the given file for use in O3D. This is done by +// loading the input file, traversing the scene graph and serializing +// what is found there. +bool Convert(const FilePath& in_filename, + const FilePath& out_filename, + const Options& options, + String* error_messages); + +// Verifies the given shader file as "valid". Returns true if input +// shader file contains valid code (code that can be compiled +// successfully). +bool Verify(const FilePath& in_filename, + const FilePath& out_filename, + const Options& options, + String* error_messages); + +} // namespace converter +} // namespace o3d + +#endif // O3D_CONVERTER_EDGE_CROSS_CONVERTER_H_ diff --git a/o3d/converter_edge/cross/converter_main.cc b/o3d/converter_edge/cross/converter_main.cc new file mode 100644 index 0000000..ee40311 --- /dev/null +++ b/o3d/converter_edge/cross/converter_main.cc @@ -0,0 +1,180 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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. + */ + + +// This file contains the main routine for the converter that writes +// out a scene graph as a JSON file. + +#include <string> +#include <iostream> +#include <vector> + +#include "base/at_exit.h" +#include "base/command_line.h" +#include "base/file_path.h" +#include "base/string_util.h" +#include "converter_edge/cross/converter.h" +#include "utils/cross/file_path_utils.h" + +using std::string; +using std::wstring; + +#if defined(OS_WIN) +int wmain(int argc, wchar_t **argv) { + // On Windows, CommandLine::Init ignores its arguments and uses + // GetCommandLineW. + CommandLine::Init(0, NULL); +#endif +#if defined(OS_LINUX) +int main(int argc, char **argv) { + CommandLine::Init(argc, argv); +#endif +#if defined(OS_MACOSX) +// The "real" main on Mac is in mac/converter_main.mm, so we can get +// memory pool initialization for Cocoa. +int CrossMain(int argc, char**argv) { + CommandLine::Init(argc, argv); +#endif + // Create an at_exit_manager so that base singletons will get + // deleted properly. + base::AtExitManager at_exit_manager; + const CommandLine* command_line = CommandLine::ForCurrentProcess(); + + FilePath in_filename, out_filename; + + std::vector<std::wstring> values = command_line->GetLooseValues(); + if (values.size() == 1) { + // If we're only given one argument, then construct the output + // filename by substituting the extension on the filename (if any) + // with .o3dtgz. + in_filename = o3d::WideToFilePath(values[0]); + out_filename = in_filename.ReplaceExtension(FILE_PATH_LITERAL(".o3dtgz")); + } else if (values.size()== 2) { + in_filename = o3d::WideToFilePath(values[0]); + out_filename = o3d::WideToFilePath(values[1]); + } else { + std::cerr << "Usage: " << argv[0] + << " [ options ] <infile.dae> [ <outfile> ]\n"; + std::cerr + << "--no-condition\n" + << " Stops the converter from conditioning shaders.\n" + << "--base-path=<path>\n" + << " Sets the path to remove from URIs of external files\n" + << "--asset-paths=<comma separted list of paths>\n" + << " Sets the paths for finding textures and other external\n" + << " files.\n" + << "--up-axis=x,y,z\n" + << " Converts the file to have this up axis.\n" + << "--pretty-print\n" + << " Makes the exported JSON easier to read.\n" + << "--keep-filters\n" + << " Stops the converter from forcing all texture samplers to use\n" + << " tri-linear filtering.\n" + << "--keep-materials\n" + << " Stops the converter from changing materials to <constant> if\n" + << " they are used by a mesh that has no normals.\n" + << "--sharp-edge-threshold=<threshold>\n" + << " Adds edges with normal angle larger than <threshold>.\n" + << "--sharp-edge-color=r,g,b\n" + << " Specify color of the additional edges, (value 0 to 1).\n" + << " Default value is 1,0,0.\n"; + return EXIT_FAILURE; + } + + o3d::converter::Options options; + options.condition = !command_line->HasSwitch(L"no-condition"); + options.pretty_print = command_line->HasSwitch(L"pretty-print"); + if (command_line->HasSwitch(L"base-path")) { + options.base_path = o3d::WideToFilePath( + command_line->GetSwitchValue(L"base-path")); + } + if (command_line->HasSwitch(L"asset-paths")) { + std::vector<std::wstring> paths; + SplitString(command_line->GetSwitchValue(L"asset-paths"), ',', &paths); + for (size_t ii = 0; ii < paths.size(); ++ii) { + options.file_paths.push_back(o3d::WideToFilePath(paths[ii])); + } + } + if (command_line->HasSwitch(L"up-axis")) { + wstring up_axis_string = command_line->GetSwitchValue(L"up-axis"); + int x, y, z; + if (swscanf(up_axis_string.c_str(), L"%d,%d,%d", &x, &y, &z) != 3) { + std::cerr << "Invalid --up-axis value. Should be --up-axis=x,y,z\n"; + return EXIT_FAILURE; + } + options.up_axis = o3d::Vector3(static_cast<float>(x), + static_cast<float>(y), + static_cast<float>(z)); + } + if (command_line->HasSwitch(L"sharp-edge-threshold")) { + wstring soften_edge_string = + command_line->GetSwitchValue(L"sharp-edge-threshold"); + float soft_threshold; + if (swscanf(soften_edge_string.c_str(), L"%f", &soft_threshold) != 1) { + std::cerr << "Invalid --sharp-edges-threshold value.\n"; + return EXIT_FAILURE; + } + options.enable_add_sharp_edge = true; + options.sharp_edge_threshold = soft_threshold; + } + if (command_line->HasSwitch(L"sharp-edge-color")) { + wstring edge_color_str = + command_line->GetSwitchValue(L"sharp-edge-color"); + int r, g, b; + if (swscanf(edge_color_str.c_str(), L"%d,%d,%d", &r, &g, &b) != 3) { + std::cerr << "Invalid --sharp-edge-color value. Should be " + << "--sharp-edge-color=r,g,b\n"; + return EXIT_FAILURE; + } + options.sharp_edge_color = o3d::Vector3(static_cast<float>(r), + static_cast<float>(g), + static_cast<float>(b)); + } + + o3d::String error_messages; + bool result = o3d::converter::Convert(in_filename, + out_filename, + options, + &error_messages); + if (result) { + std::cerr << "Converted '" << o3d::FilePathToUTF8(in_filename).c_str() + << "' to '" << o3d::FilePathToUTF8(out_filename).c_str() + << "'." << std::endl; + return EXIT_SUCCESS; + } else { + std::cerr << error_messages.c_str() << std::endl; + std::cerr << "FAILED to convert '" + << o3d::FilePathToUTF8(in_filename).c_str() + << "' to '" << o3d::FilePathToUTF8(out_filename).c_str() + << "'." << std::endl; + return EXIT_FAILURE; + } +} diff --git a/o3d/converter_edge/cross/draw_element_stub.h b/o3d/converter_edge/cross/draw_element_stub.h new file mode 100644 index 0000000..8ed3de6 --- /dev/null +++ b/o3d/converter_edge/cross/draw_element_stub.h @@ -0,0 +1,58 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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. + */ + + +// This file contains the declaration of the DrawElementGL class. + +#ifndef O3D_CONVERTER_EDGE_CROSS_DRAW_ELEMENT_STUB_H_ +#define O3D_CONVERTER_EDGE_CROSS_DRAW_ELEMENT_STUB_H_ + +#include "core/cross/draw_element.h" + +namespace o3d { + +class ServiceLocator; + +// DrawElementStub is the Stub implementation of the DrawElement. It +// provides a place for the renderer to store platform specific cache +// information. +class DrawElementStub : public DrawElement { + public: + explicit DrawElementStub(ServiceLocator* service_locator) + : DrawElement(service_locator) {} + ~DrawElementStub() {} + + private: + DISALLOW_COPY_AND_ASSIGN(DrawElementStub); +}; +} // o3d + +#endif // O3D_CONVERTER_EDGE_CROSS_DRAW_ELEMENT_STUB_H_ diff --git a/o3d/converter_edge/cross/effect_stub.h b/o3d/converter_edge/cross/effect_stub.h new file mode 100644 index 0000000..dfe9a84 --- /dev/null +++ b/o3d/converter_edge/cross/effect_stub.h @@ -0,0 +1,73 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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. + */ + + +// This file contains the declaration of the EffectGL class. + +#ifndef O3D_CONVERTER_EDGE_CROSS_EFFECT_STUB_H_ +#define O3D_CONVERTER_EDGE_CROSS_EFFECT_STUB_H_ + +#include "core/cross/effect.h" + +namespace o3d { + +class ServiceLocator; + +// EffectStub is an implementation of the Effect object for the +// converter. It provides the API for setting the vertex and fragment +// shaders for the Effect using the Cg Runtime. +class EffectStub : public Effect { + public: + explicit EffectStub(ServiceLocator* service_locator) + : Effect(service_locator) {} + virtual ~EffectStub() {} + + // Reads the vertex and fragment shaders from string in the FX format. + // It returns true if the shaders were successfully compiled. + virtual bool LoadFromFXString(const String& effect) { return true; } + + // Gets info about the parameters this effect needs. + // Overriden from Effect. + virtual void GetParameterInfo(EffectParameterInfoArray* info_array) {} + + // Gets info about the varying parameters this effects vertex shader needs. + // Parameters: + // info_array: EffectParameterInfoArray to receive info. + virtual void GetStreamInfo( + EffectStreamInfoArray* info_array) { + } + + private: + DISALLOW_COPY_AND_ASSIGN(EffectStub); +}; +} // namespace o3d + +#endif // O3D_CONVERTER_EDGE_CROSS_EFFECT_STUB_H_ diff --git a/o3d/converter_edge/cross/param_cache_stub.h b/o3d/converter_edge/cross/param_cache_stub.h new file mode 100644 index 0000000..38efe6e --- /dev/null +++ b/o3d/converter_edge/cross/param_cache_stub.h @@ -0,0 +1,69 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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. + */ + + +// This file contains the declaration of the ParamCacheStub class. + +#ifndef O3D_CONVERTER_EDGE_CROSS_PARAM_CACHE_STUB_H_ +#define O3D_CONVERTER_EDGE_CROSS_PARAM_CACHE_STUB_H_ + +#include "core/cross/param_cache.h" + +namespace o3d { + +class Effect; +class DrawElement; +class Element; +class Material; +class ParamObject; + +class ParamCacheStub : public ParamCache { + public: + ParamCacheStub() : ParamCache() {} + + // Overridden from ParamCache. + virtual void UpdateCache(Effect* effect, + DrawElement* draw_element, + Element* element, + Material* material, + ParamObject* override) {} + + protected: + // Overridden from ParamCache + // Validates platform specific information about the effect. + virtual bool ValidateEffect(Effect* effect) { return true; } + + private: + DISALLOW_COPY_AND_ASSIGN(ParamCacheStub); +}; +} // o3d + +#endif // O3D_CONVERTER_EDGE_CROSS_PARAM_CACHE_STUB_H_ diff --git a/o3d/converter_edge/cross/primitive_stub.h b/o3d/converter_edge/cross/primitive_stub.h new file mode 100644 index 0000000..5dd43ac --- /dev/null +++ b/o3d/converter_edge/cross/primitive_stub.h @@ -0,0 +1,71 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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. + */ + + +// This file contains the declaration of the PrimitiveStub class. + +#ifndef O3D_CONVERTER_EDGE_CROSS_PRIMITIVE_STUB_H_ +#define O3D_CONVERTER_EDGE_CROSS_PRIMITIVE_STUB_H_ + +#include "core/cross/primitive.h" + +namespace o3d { + +class DrawElement; +class Material; +class ParamCache; +class ParamObject; +class Renderer; +class ServiceLocator; + +// PrimitiveStub is the Stub implementation of the Primitive. It provides the +// necessary interfaces for setting the geometry streams on the Primitive. +class PrimitiveStub : public Primitive { + public: + explicit PrimitiveStub(ServiceLocator* service_locator) + : Primitive(service_locator) {} + virtual ~PrimitiveStub() {} + + // Overridden from Element + // Renders this Element using the parameters from override first, followed by + // the draw_element, followed by params on this Primitive and material. + virtual void Render(Renderer* renderer, + DrawElement* draw_element, + Material* material, + ParamObject* override, + ParamCache* param_cache) {} + + private: + DISALLOW_COPY_AND_ASSIGN(PrimitiveStub); +}; +} // o3d + +#endif // O3D_CONVERTER_EDGE_CROSS_PRIMITIVE_STUB_H_ diff --git a/o3d/converter_edge/cross/render_surface_stub.h b/o3d/converter_edge/cross/render_surface_stub.h new file mode 100644 index 0000000..8b018b4 --- /dev/null +++ b/o3d/converter_edge/cross/render_surface_stub.h @@ -0,0 +1,75 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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. + */ + + +// This file contains the declarations for RenderSurfaceGL and +// RenderDepthStencilSurfaceGL. + +#ifndef O3D_CONVERTER_EDGE_CROSS_RENDER_SURFACE_STUB_H_ +#define O3D_CONVERTER_EDGE_CROSS_RENDER_SURFACE_STUB_H_ + +#include "core/cross/render_surface.h" +#include "core/cross/texture.h" + +namespace o3d { + +class RenderSurfaceStub : public RenderSurface { + public: + typedef SmartPointer<RenderSurfaceStub> Ref; + + // Constructs a RenderSurfaceStub instance. + // Parameters: + // service_locator: Service locator for the instance. + RenderSurfaceStub(ServiceLocator *service_locator, + int width, + int height) + : RenderSurface(service_locator, width, height, NULL) {} + virtual ~RenderSurfaceStub() {} + private: + DISALLOW_COPY_AND_ASSIGN(RenderSurfaceStub); +}; + +class RenderDepthStencilSurfaceStub : public RenderDepthStencilSurface { + public: + typedef SmartPointer<RenderDepthStencilSurfaceStub> Ref; + + RenderDepthStencilSurfaceStub(ServiceLocator *service_locator, + int width, + int height) + : RenderDepthStencilSurface(service_locator, width, height) {} + virtual ~RenderDepthStencilSurfaceStub() {} + private: + DISALLOW_COPY_AND_ASSIGN(RenderDepthStencilSurfaceStub); +}; + +} // namespace o3d + +#endif // O3D_CONVERTER_EDGE_CROSS_RENDER_SURFACE_STUB_H_ diff --git a/o3d/converter_edge/cross/renderer_stub.cc b/o3d/converter_edge/cross/renderer_stub.cc new file mode 100644 index 0000000..1ede3d4 --- /dev/null +++ b/o3d/converter_edge/cross/renderer_stub.cc @@ -0,0 +1,204 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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. + */ + + +// This file contains the definition of abstract functions in the +// cross platform API so that we can use it for serialization of the +// scene graph on all systems without needing graphics. + +#include "converter/cross/renderer_stub.h" +#include "core/cross/object_manager.h" +#include "core/cross/service_locator.h" +#include "converter_edge/cross/buffer_stub.h" +#include "converter_edge/cross/draw_element_stub.h" +#include "converter_edge/cross/effect_stub.h" +#include "converter_edge/cross/param_cache_stub.h" +#include "converter_edge/cross/primitive_stub.h" +#include "converter_edge/cross/render_surface_stub.h" +#include "converter_edge/cross/sampler_stub.h" +#include "converter_edge/cross/stream_bank_stub.h" +#include "converter_edge/cross/texture_stub.h" + +namespace o3d { + +Renderer* RendererStub::CreateDefault(ServiceLocator* service_locator) { + return new RendererStub(service_locator); +} + +RendererStub::RendererStub(ServiceLocator* service_locator) + : Renderer(service_locator) { +} + +Renderer::InitStatus RendererStub::InitPlatformSpecific( + const DisplayWindow&, bool) { + DCHECK(false); + return SUCCESS; +} + +void RendererStub::InitCommon() { +} + +void RendererStub::UninitCommon() { +} + +void RendererStub::Destroy(void) { + DCHECK(false); +} + +bool RendererStub::BeginDraw(void) { + DCHECK(false); + return true; +} + +void RendererStub::EndDraw(void) { + DCHECK(false); +} + +bool RendererStub::StartRendering(void) { + DCHECK(false); + return true; +} + +void RendererStub::FinishRendering(void) { + DCHECK(false); +} + +void RendererStub::Resize(int, int) { + DCHECK(false); +} + +void RendererStub::Clear(const Float4 &, bool, float, bool, int, bool) { + DCHECK(false); +} + +void RendererStub::RenderElement(Element *, + DrawElement *, + Material *, + ParamObject *, + ParamCache *) { + DCHECK(false); +} + +void RendererStub::SetRenderSurfacesPlatformSpecific( + RenderSurface* surface, + RenderDepthStencilSurface* surface_depth) { + DCHECK(false); +} + +void RendererStub::SetBackBufferPlatformSpecific() { + DCHECK(false); +} + +Primitive::Ref RendererStub::CreatePrimitive(void) { + return Primitive::Ref(new PrimitiveStub(service_locator())); +} + +DrawElement::Ref RendererStub::CreateDrawElement(void) { + return DrawElement::Ref(new DrawElementStub(service_locator())); +} + +VertexBuffer::Ref RendererStub::CreateVertexBuffer(void) { + return VertexBuffer::Ref(new VertexBufferStub(service_locator())); +} + +IndexBuffer::Ref RendererStub::CreateIndexBuffer(void) { + return IndexBuffer::Ref(new IndexBufferStub(service_locator())); +} + +Effect::Ref RendererStub::CreateEffect(void) { + return Effect::Ref(new EffectStub(service_locator())); +} + +Sampler::Ref RendererStub::CreateSampler(void) { + return Sampler::Ref(new SamplerStub(service_locator())); +} + +Texture2D::Ref RendererStub::CreatePlatformSpecificTexture2D( + int width, + int height, + Texture::Format format, + int levels, + bool enable_render_surfaces) { + return Texture2D::Ref(new Texture2DStub(service_locator(), + width, + height, + format, + levels, + enable_render_surfaces)); +} + +TextureCUBE::Ref RendererStub::CreatePlatformSpecificTextureCUBE( + int edge_length, + Texture::Format format, + int levels, + bool enable_render_surfaces) { + return TextureCUBE::Ref(new TextureCUBEStub(service_locator(), + edge_length, + format, + levels, + enable_render_surfaces)); +} + +RenderDepthStencilSurface::Ref RendererStub::CreateDepthStencilSurface( + int width, + int height) { + return RenderDepthStencilSurface::Ref( + new RenderDepthStencilSurfaceStub(service_locator(), width, height)); +} + +StreamBank::Ref RendererStub::CreateStreamBank() { + return StreamBank::Ref(new StreamBankStub(service_locator())); +} + +Bitmap::Ref RendererStub::TakeScreenshot() { + return Bitmap::Ref(); +} + +ParamCache *RendererStub::CreatePlatformSpecificParamCache(void) { + return new ParamCacheStub; +} + +void RendererStub::SetViewportInPixels(int, int, int, int, float, float) { + DCHECK(false); +} + +const int* RendererStub::GetRGBAUByteNSwizzleTable() { + static int swizzle_table[] = { 0, 1, 2, 3, }; + return swizzle_table; +} + +// This is a factory function for creating Renderer objects. Since +// we're implementing a stub renderer, we only ever return a stub renderer. +Renderer* Renderer::CreateDefaultRenderer(ServiceLocator* service_locator) { + return RendererStub::CreateDefault(service_locator); +} + +} // namespace o3d diff --git a/o3d/converter_edge/cross/renderer_stub.h b/o3d/converter_edge/cross/renderer_stub.h new file mode 100644 index 0000000..e924cf1 --- /dev/null +++ b/o3d/converter_edge/cross/renderer_stub.h @@ -0,0 +1,123 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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. + */ + + +// This file contains the declaration of functions needed to +// instantiate a renderer from the core cross-platform API so that we +// can use it for serialization of the scene graph on all systems +// without needing graphics. + +#ifndef O3D_CONVERTER_EDGE_CROSS_RENDERER_STUB_H_ +#define O3D_CONVERTER_EDGE_CROSS_RENDERER_STUB_H_ + +#include "core/cross/renderer.h" + +namespace o3d { + +// Please see core/cross/renderer.h for documentation of these +// functions. With the exception of the "Create..." methods, these +// are mostly just stubbed out here, and don't do anything. + +class RendererStub : public Renderer { + public: + static Renderer* CreateDefault(ServiceLocator* service_locator); + virtual InitStatus InitPlatformSpecific(const DisplayWindow& display, + bool off_screen); + virtual void InitCommon(); + virtual void UninitCommon(); + virtual void Destroy(); + virtual bool BeginDraw(); + virtual void EndDraw(); + virtual bool StartRendering(); + virtual void FinishRendering(); + virtual void Resize(int width, int height); + virtual void Clear(const Float4 &color, + bool color_flag, + float depth, + bool depth_flag, + int stencil, + bool stencil_flag); + virtual void RenderElement(Element* element, + DrawElement* draw_element, + Material* material, + ParamObject* override, + ParamCache* param_cache); + virtual Primitive::Ref CreatePrimitive(); + virtual DrawElement::Ref CreateDrawElement(); + virtual VertexBuffer::Ref CreateVertexBuffer(); + virtual IndexBuffer::Ref CreateIndexBuffer(); + virtual Effect::Ref CreateEffect(); + virtual Sampler::Ref CreateSampler(); + virtual RenderDepthStencilSurface::Ref CreateDepthStencilSurface(int width, + int height); + virtual StreamBank::Ref CreateStreamBank(); + virtual Bitmap::Ref TakeScreenshot(); + ParamCache *CreatePlatformSpecificParamCache(); + virtual void SetViewportInPixels(int left, + int top, + int width, + int height, + float min_z, + float max_z); + + // Overridden from Renderer. + virtual const int* GetRGBAUByteNSwizzleTable(); + + protected: + explicit RendererStub(ServiceLocator* service_locator); + + // Overridden from Renderer. + virtual void SetBackBufferPlatformSpecific(); + + // Overridden from Renderer. + virtual void SetRenderSurfacesPlatformSpecific( + RenderSurface* surface, + RenderDepthStencilSurface* depth_surface); + + // Overridden from Renderer. + virtual Texture2D::Ref CreatePlatformSpecificTexture2D( + int width, + int height, + Texture::Format format, + int levels, + bool enable_render_surfaces); + + // Overridden from Renderer. + virtual TextureCUBE::Ref CreatePlatformSpecificTextureCUBE( + int edge_length, + Texture::Format format, + int levels, + bool enable_render_surfaces); +}; + +} // namespace o3d + +#endif // O3D_CONVERTER_EDGE_CROSS_RENDERER_STUB_H_ diff --git a/o3d/converter_edge/cross/sampler_stub.h b/o3d/converter_edge/cross/sampler_stub.h new file mode 100644 index 0000000..1eb3fcc --- /dev/null +++ b/o3d/converter_edge/cross/sampler_stub.h @@ -0,0 +1,53 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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. + */ + + +// This file contains the class declaration for SamplerStub. + +#ifndef O3D_CONVERTER_EDGE_CROSS_SAMPLER_STUB_H_ +#define O3D_CONVERTER_EDGE_CROSS_SAMPLER_STUB_H_ + +#include "core/cross/sampler.h" + +namespace o3d { + +// SamplerStub is an implementation of the Sampler object for the converter. +class SamplerStub : public Sampler { + public: + explicit SamplerStub(ServiceLocator* service_locator) + : Sampler(service_locator) {} + virtual ~SamplerStub() {} + private: + DISALLOW_COPY_AND_ASSIGN(SamplerStub); +}; +} // namespace o3d + +#endif // O3D_CONVERTER_EDGE_CROSS_SAMPLER_STUB_H_ diff --git a/o3d/converter_edge/cross/stream_bank_stub.h b/o3d/converter_edge/cross/stream_bank_stub.h new file mode 100644 index 0000000..3ee9dc5 --- /dev/null +++ b/o3d/converter_edge/cross/stream_bank_stub.h @@ -0,0 +1,51 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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. + */ + + +// This file contains the declaration of the StreamBankGL class. + +#ifndef O3D_CONVERTER_EDGE_CROSS_STREAM_BANK_STUB_H_ +#define O3D_CONVERTER_EDGE_CROSS_STREAM_BANK_STUB_H_ + +#include "core/cross/stream_bank.h" + +namespace o3d { + +// StreamBankStub is the Stub implementation of the StreamBank. +class StreamBankStub : public StreamBank { + public: + explicit StreamBankStub(ServiceLocator* service_locator) + : StreamBank(service_locator) {} + virtual ~StreamBankStub() {} +}; +} // o3d + +#endif // O3D_CONVERTER_EDGE_CROSS_STREAM_BANK_STUB_H_ diff --git a/o3d/converter_edge/cross/texture_stub.cc b/o3d/converter_edge/cross/texture_stub.cc new file mode 100644 index 0000000..c287b58 --- /dev/null +++ b/o3d/converter_edge/cross/texture_stub.cc @@ -0,0 +1,51 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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 "converter_edge/cross/texture_stub.h" + +namespace o3d { + +namespace { + +Texture::RGBASwizzleIndices g_stub_abgr32f_swizzle_indices = {0, 1, 2, 3}; + +} // anonymous namespace. + +const Texture::RGBASwizzleIndices& Texture2DStub::GetABGR32FSwizzleIndices() { + return g_stub_abgr32f_swizzle_indices; +} + +const Texture::RGBASwizzleIndices& TextureCUBEStub::GetABGR32FSwizzleIndices() { + return g_stub_abgr32f_swizzle_indices; +} + +} // namespace o3d diff --git a/o3d/converter_edge/cross/texture_stub.h b/o3d/converter_edge/cross/texture_stub.h new file mode 100644 index 0000000..7b31a17 --- /dev/null +++ b/o3d/converter_edge/cross/texture_stub.h @@ -0,0 +1,174 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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. + */ + + +// This file contains the declarations for Texture2DStub and TextureCUBEStub. + +#ifndef O3D_CONVERTER_EDGE_CROSS_TEXTURE_STUB_H_ +#define O3D_CONVERTER_EDGE_CROSS_TEXTURE_STUB_H_ + +#include "core/cross/bitmap.h" +#include "core/cross/texture.h" +#include "core/cross/types.h" + +namespace o3d { + +// Texture2DStub implements the stub Texture2D interface for the converter. +class Texture2DStub : public Texture2D { + public: + typedef SmartPointer<Texture2DStub> Ref; + + Texture2DStub(ServiceLocator* service_locator, + int width, + int height, + Texture::Format format, + int levels, + bool enable_render_surfaces) + : Texture2D(service_locator, + width, + height, + format, + levels, + enable_render_surfaces) {} + virtual ~Texture2DStub() {} + + // Overridden from Texture2D + virtual void SetRect(int level, + unsigned left, + unsigned top, + unsigned width, + unsigned height, + const void* src_data, + int src_pitch) { + } + + // Returns a RenderSurface object associated with a mip_level of a texture. + // Parameters: + // mip_level: [in] The mip-level of the surface to be returned. + // pack: [in] The pack in which the surface will reside. + // Returns: + // Reference to the RenderSurface object. + virtual RenderSurface::Ref GetRenderSurface(int mip_level, Pack *pack) { + return RenderSurface::Ref(NULL); + } + + // Returns the implementation-specific texture handle for this texture. + void* GetTextureHandle() const { + return NULL; + } + + // Gets a RGBASwizzleIndices that contains a mapping from + // RGBA to the internal format used by the rendering API. + virtual const RGBASwizzleIndices& GetABGR32FSwizzleIndices(); + + protected: + // Locks the image buffer of a given mipmap level for writing from main + // memory. + virtual bool Lock(int level, void** texture_data, int* pitch) { + return false; + } + + // Unlocks this texture and returns it to Stub control. + virtual bool Unlock(int level) { return true; } + + private: + DISALLOW_COPY_AND_ASSIGN(Texture2DStub); +}; + + +// TextureCUBEStub implements the TextureCUBE interface for the converter stub. +class TextureCUBEStub : public TextureCUBE { + public: + typedef SmartPointer<TextureCUBEStub> Ref; + TextureCUBEStub(ServiceLocator* service_locator, + int edge_length, + Texture::Format format, + int levels, + bool enable_render_surfaces) + : TextureCUBE(service_locator, + edge_length, + format, + levels, + enable_render_surfaces) {} + virtual ~TextureCUBEStub() {} + + // Overridden from TextureCUBE + virtual void SetRect(CubeFace face, + int level, + unsigned dst_left, + unsigned dst_top, + unsigned width, + unsigned height, + const void* src_data, + int src_pitch) { + }; + + // Returns a RenderSurface object associated with a given cube face and + // mip_level of a texture. + // Parameters: + // face: [in] The cube face from which to extract the surface. + // mip_level: [in] The mip-level of the surface to be returned. + // pack: [in] The pack in which the surface will reside. + // Returns: + // Reference to the RenderSurface object. + virtual RenderSurface::Ref GetRenderSurface(CubeFace face, + int level, + Pack* pack) { + return RenderSurface::Ref(NULL); + } + + // Returns the implementation-specific texture handle for this texture. + void* GetTextureHandle() const { + return NULL; + } + + // Gets a RGBASwizzleIndices that contains a mapping from + // RGBA to the internal format used by the rendering API. + virtual const RGBASwizzleIndices& GetABGR32FSwizzleIndices(); + + protected: + // Locks the image buffer of a given face and mipmap level for loading + // from main memory. + virtual bool Lock( + CubeFace face, int level, void** texture_data, int* pitch) { + return false; + } + + // Unlocks the image buffer of a given face and mipmap level. + virtual bool Unlock(CubeFace face, int level) { return true; } + + private: + DISALLOW_COPY_AND_ASSIGN(TextureCUBEStub); +}; + +} // namespace o3d + +#endif // O3D_CONVERTER_EDGE_CROSS_TEXTURE_STUB_H_ diff --git a/o3d/converter_edge/cross/verifier_main.cc b/o3d/converter_edge/cross/verifier_main.cc new file mode 100644 index 0000000..bc0e8a9 --- /dev/null +++ b/o3d/converter_edge/cross/verifier_main.cc @@ -0,0 +1,106 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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. + */ + + +// This file contains the main routine for the converter that writes +// out a scene graph as a JSON file. + +#include <string> +#include <iostream> +#include <vector> + +#include "base/at_exit.h" +#include "base/file_path.h" +#include "base/command_line.h" +#include "converter_edge/cross/converter.h" +#include "utils/cross/file_path_utils.h" + +using std::string; +using std::wstring; + +#if defined(OS_WIN) +int wmain(int argc, wchar_t **argv) { + // On Windows, CommandLine::Init ignores its arguments and uses + // GetCommandLineW. + CommandLine::Init(0, NULL); +#endif +#if defined(OS_LINUX) +int main(int argc, char **argv) { + CommandLine::Init(argc, argv); +#endif +#if defined(OS_MACOSX) +// The "real" main on Mac is in mac/converter_main.mm, so we can get +// memory pool initialization for Cocoa. +int CrossMain(int argc, char**argv) { + CommandLine::Init(argc, argv); +#endif + // Create an at_exit_manager so that base singletons will get + // deleted properly. + base::AtExitManager at_exit_manager; + const CommandLine* command_line = CommandLine::ForCurrentProcess(); + + FilePath in_filename, out_filename; + + std::vector<std::wstring> values = command_line->GetLooseValues(); + if (values.size() == 1) { + in_filename = o3d::WideToFilePath(values[0]); + } else if (values.size()== 2) { + in_filename = o3d::WideToFilePath(values[0]); + out_filename = o3d::WideToFilePath(values[1]); + } else { + std::cerr << "Usage: " << FilePath(argv[0]).BaseName().value() + << " [--no-condition] <infile.fx> [<outfile.fx>]\n"; + return EXIT_FAILURE; + } + + o3d::converter::Options options; + options.condition = !command_line->HasSwitch(L"no-condition"); + + if (!options.condition && !out_filename.empty()) { + std::cerr << "Warning: Ignoring output filename because conditioning " + << "has been turned off.\n"; + out_filename = FilePath(); + } + + o3d::String errors; + bool result = o3d::converter::Verify(in_filename, out_filename, options, + &errors); + if (result) { + std::cerr << "Shader in '" << o3d::FilePathToUTF8(in_filename).c_str() + << "' has been validated." << std::endl; + return EXIT_SUCCESS; + } else { + std::cerr << errors.c_str() << std::endl; + std::cerr << "Shader in '" << o3d::FilePathToUTF8(in_filename).c_str() + << "' FAILED to be validated." << std::endl; + return EXIT_FAILURE; + } +} diff --git a/o3d/converter_edge/mac/converter_main.mm b/o3d/converter_edge/mac/converter_main.mm new file mode 100644 index 0000000..4e9a4af --- /dev/null +++ b/o3d/converter_edge/mac/converter_main.mm @@ -0,0 +1,49 @@ +/* + * Copyright 2009, Google Inc. + * All rights reserved. + * + * 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 following disclaimer. + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * * Neither the name of Google Inc. 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 THE COPYRIGHT + * OWNER 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. + */ + + +// This file contains the main routine for the converter that writes +// out a scene graph as a JSON file. Really, just a shell for the +// common main routine in cross so we can get memory pool +// initialization for Cocoa. + +#import <Cocoa/Cocoa.h> + +// Defined in converter/cross/converter_main.cc +extern int CrossMain(int argc, char** argv); + +int main(int argc, char** argv) { + // Make a pool to use for any Cocoa objects in the app. + NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init]; + int result = CrossMain(argc, argv); + [pool release]; + return result; +} diff --git a/o3d/main.scons b/o3d/main.scons index 3f2ce28..726ca9d 100644 --- a/o3d/main.scons +++ b/o3d/main.scons @@ -179,6 +179,7 @@ binaries_env.Append( 'compiler/antlr', 'compiler/technique', 'converter', + 'converter_edge', 'core', 'import', 'ipc', |