aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llprimitive/llvolumexml.cpp
diff options
context:
space:
mode:
authorJacek Antonelli2008-08-15 23:44:46 -0500
committerJacek Antonelli2008-08-15 23:44:46 -0500
commit38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4 (patch)
treeadca584755d22ca041a2dbfc35d4eca01f70b32c /linden/indra/llprimitive/llvolumexml.cpp
parentREADME.txt (diff)
downloadmeta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.zip
meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.gz
meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.bz2
meta-impy-38d6d37f2d982fa959e9e8a4a3f7e1ccfad7b5d4.tar.xz
Second Life viewer sources 1.13.2.12
Diffstat (limited to 'linden/indra/llprimitive/llvolumexml.cpp')
-rw-r--r--linden/indra/llprimitive/llvolumexml.cpp76
1 files changed, 76 insertions, 0 deletions
diff --git a/linden/indra/llprimitive/llvolumexml.cpp b/linden/indra/llprimitive/llvolumexml.cpp
new file mode 100644
index 0000000..101eace
--- /dev/null
+++ b/linden/indra/llprimitive/llvolumexml.cpp
@@ -0,0 +1,76 @@
1/**
2 * @file llvolumexml.cpp
3 * @brief LLVolumeXml base class
4 *
5 * Copyright (c) 2001-2007, Linden Research, Inc.
6 *
7 * The source code in this file ("Source Code") is provided by Linden Lab
8 * to you under the terms of the GNU General Public License, version 2.0
9 * ("GPL"), unless you have obtained a separate licensing agreement
10 * ("Other License"), formally executed by you and Linden Lab. Terms of
11 * the GPL can be found in doc/GPL-license.txt in this distribution, or
12 * online at http://secondlife.com/developers/opensource/gplv2
13 *
14 * There are special exceptions to the terms and conditions of the GPL as
15 * it is applied to this Source Code. View the full text of the exception
16 * in the file doc/FLOSS-exception.txt in this software distribution, or
17 * online at http://secondlife.com/developers/opensource/flossexception
18 *
19 * By copying, modifying or distributing this software, you acknowledge
20 * that you have read and understood your obligations described above,
21 * and agree to abide by those obligations.
22 *
23 * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO
24 * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY,
25 * COMPLETENESS OR PERFORMANCE.
26 */
27
28#include "linden_common.h"
29
30#include "llvolumexml.h"
31
32//============================================================================
33
34// LLVolumeXml is just a wrapper class; all members are static
35
36//============================================================================
37
38LLXMLNode *LLVolumeXml::exportProfileParams(const LLProfileParams* params)
39{
40 LLXMLNode *ret = new LLXMLNode("profile", FALSE);
41
42 ret->createChild("curve_type", TRUE)->setByteValue(1, &params->getCurveType());
43 ret->createChild("interval", FALSE)->setFloatValue(2, &params->getBegin());
44 ret->createChild("hollow", FALSE)->setFloatValue(1, &params->getHollow());
45
46 return ret;
47}
48
49
50LLXMLNode *LLVolumeXml::exportPathParams(const LLPathParams* params)
51{
52 LLXMLNode *ret = new LLXMLNode("path", FALSE);
53 ret->createChild("curve_type", TRUE)->setByteValue(1, &params->getCurveType());
54 ret->createChild("interval", FALSE)->setFloatValue(2, &params->getBegin());
55 ret->createChild("scale", FALSE)->setFloatValue(2, params->getScale().mV);
56 ret->createChild("shear", FALSE)->setFloatValue(2, params->getShear().mV);
57 ret->createChild("twist_interval", FALSE)->setFloatValue(2, &params->getTwistBegin());
58 ret->createChild("radius_offset", FALSE)->setFloatValue(1, &params->getRadiusOffset());
59 ret->createChild("taper", FALSE)->setFloatValue(2, params->getTaper().mV);
60 ret->createChild("revolutions", FALSE)->setFloatValue(1, &params->getRevolutions());
61 ret->createChild("skew", FALSE)->setFloatValue(1, &params->getSkew());
62
63 return ret;
64}
65
66
67LLXMLNode *LLVolumeXml::exportVolumeParams(const LLVolumeParams* params)
68{
69 LLXMLNode *ret = new LLXMLNode("shape", FALSE);
70
71 exportPathParams(&params->getPathParams())->setParent(ret);
72 exportProfileParams(&params->getProfileParams())->setParent(ret);
73
74 return ret;
75}
76